:root{--ink:#10191d;--muted:#5a7078;--paper:#f5f8f7;--panel:#ffffff;--line:rgba(16,25,29,0.12);--glacier:#d9edf0;--ice:#f4fbfc;--stone:#2e4f5d;--ridge:#5a96a6;--deep:#173f4c;--shadow:0 24px 70px rgba(16,25,29,0.14)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:radial-gradient(circle at top left,rgba(90,150,166,.22),transparent 32rem),linear-gradient(180deg,#f9fcfb 0,var(--paper) 46%,#edf4f2 100%);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}.site-header{position:-webkit-sticky;position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:1.25rem;padding:1rem clamp(1rem,4vw,4rem);border-bottom:1px solid rgba(16,25,29,.08);background:rgba(249,252,251,.86);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand{display:inline-flex;align-items:center;gap:.65rem;min-width:0}.brand-mark{width:2.5rem;height:2.5rem}.brand-logo{width:clamp(8.5rem,18vw,12rem);height:auto}.nav{display:flex;align-items:center;gap:clamp(.75rem,3vw,2rem);color:var(--stone);font-size:.95rem;font-weight:700}.nav a{border-bottom:2px solid transparent;padding-block:.25rem}.nav a:hover{border-color:var(--ridge)}.hero{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(21rem,.82fr);align-items:center;grid-gap:clamp(2.5rem,7vw,6rem);gap:clamp(2.5rem,7vw,6rem);min-height:calc(100svh - 4.75rem);padding:clamp(3rem,7vw,7rem) clamp(1rem,4vw,4rem) clamp(4rem,7vw,6rem)}.hero-copy{max-width:49rem}.eyebrow{margin:0 0 .9rem;color:var(--ridge);font-size:.78rem;font-weight:900;letter-spacing:0;text-transform:uppercase}h1,h2,h3,p{margin-top:0}h1{max-width:48rem;margin-bottom:1.35rem;color:#102329;font-size:clamp(3.2rem,8vw,6.8rem);line-height:.95}h2{margin-bottom:1rem;color:#12313a;font-size:clamp(2rem,4vw,3.7rem);line-height:1.02}h3{margin-bottom:.7rem;color:#102b33;font-size:1.45rem;line-height:1.1}p{color:var(--muted);font-size:1.02rem;line-height:1.68}.hero-text{max-width:40rem;font-size:clamp(1.06rem,1.5vw,1.25rem)}.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}.button{display:inline-flex;align-items:center;justify-content:center;min-height:3rem;border:1px solid var(--line);border-radius:.45rem;padding:.85rem 1.2rem;font-weight:900}.button.primary{border-color:var(--deep);background:var(--deep);color:white}.button.secondary{background:rgba(255,255,255,.68);color:var(--deep)}.hero-visual{position:relative;min-height:32rem}.mountain-shell{position:absolute;inset:3.5rem 0 auto auto;width:min(82vw,28rem);border:1px solid rgba(255,255,255,.8);border-radius:1.4rem;padding:clamp(2rem,5vw,3.5rem);background:linear-gradient(145deg,rgba(255,255,255,.92),rgba(217,237,240,.5)),linear-gradient(180deg,rgba(90,150,166,.22),transparent);box-shadow:var(--shadow)}.mountain-shell img{width:100%;filter:drop-shadow(0 1.8rem 1.6rem rgba(23,63,76,.24))}.code-panel{position:absolute;width:min(18rem,56vw);border:1px solid rgba(255,255,255,.78);border-radius:.75rem;padding:1rem;background:rgba(16,25,29,.9);box-shadow:0 1.2rem 2.5rem rgba(16,25,29,.2);color:white}.code-panel span{display:block;margin-bottom:.5rem;color:#9dc7d1;font-size:.78rem;font-weight:800}.code-panel strong{display:block;font-size:.98rem;line-height:1.35}.panel-one{top:1.1rem;left:.4rem}.panel-two{right:0;bottom:2.2rem}.section{padding:clamp(3.5rem,8vw,7rem) clamp(1rem,4vw,4rem)}.split{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);grid-gap:clamp(2rem,6vw,5rem);gap:clamp(2rem,6vw,5rem);border-top:1px solid var(--line)}.section-copy{max-width:48rem}.capability-list{display:grid;grid-gap:.85rem;gap:.85rem;margin:1.5rem 0 0;padding:0;list-style:none}.capability-list li{border-left:.25rem solid var(--ridge);padding:.15rem 0 .15rem 1rem;color:#28454e;font-weight:750;line-height:1.45}.stack-band{display:flex;flex-wrap:wrap;gap:.75rem;padding-block:2rem;border-block:1px solid var(--line);background:rgba(255,255,255,.44)}.product-tags span,.stack-band span{border:1px solid rgba(90,150,166,.28);border-radius:999px;padding:.55rem .8rem;background:rgba(255,255,255,.7);color:var(--deep);font-size:.86rem;font-weight:850}.section-heading{max-width:46rem;margin-bottom:clamp(2rem,5vw,3.5rem)}.portfolio-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:1.2rem;gap:1.2rem}.product-card{overflow:hidden;border:1px solid rgba(16,25,29,.1);border-radius:.5rem;background:rgba(255,255,255,.78);box-shadow:0 1rem 2.5rem rgba(16,25,29,.08)}.product-shot{position:relative;min-height:15rem;padding:1rem;background:linear-gradient(135deg,#173f4c,#5a96a6)}.work-badge{position:absolute;top:1rem;right:1rem;z-index:2;border:1px solid rgba(255,255,255,.72);border-radius:999px;padding:.42rem .68rem;background:rgba(16,25,29,.78);color:white;font-size:.76rem;font-weight:900}.work-badge.online{border-color:rgba(134,239,172,.72);background:rgba(22,101,52,.92);color:#ecfdf5}.product-shot.ridge{background:linear-gradient(135deg,#10191d,#2e4f5d 48%,#78adba)}.product-shot.ice{background:linear-gradient(135deg,#2e4f5d,#8bb9c2 58%,#f4fbfc)}.product-shot.mal-ehrlich-shot{display:grid;place-items:center;background:#1c1e24}.product-logo-stage{display:grid;place-items:center;min-height:13rem;width:100%}.product-logo{width:min(11rem,68%);height:auto}.shot-bar{display:flex;gap:.35rem;border-radius:.45rem .45rem 0 0;padding:.75rem;background:rgba(255,255,255,.28)}.shot-bar span{width:.55rem;height:.55rem;border-radius:50%;background:rgba(255,255,255,.72)}.shot-body{display:grid;grid-template-columns:4.2rem 1fr;min-height:11rem;border-radius:0 0 .45rem .45rem;background:rgba(255,255,255,.82)}.shot-sidebar{margin:.9rem;border-radius:.35rem;background:linear-gradient(#5a96a6 0 0) top .8rem left .75rem /2.3rem .45rem no-repeat,linear-gradient(#d9edf0 0 0) top 2rem left .75rem /1.8rem .35rem no-repeat,linear-gradient(#d9edf0 0 0) top 3rem left .75rem /2.1rem .35rem no-repeat,rgba(23,63,76,.12)}.shot-main{padding:1rem 1rem 1rem 0}.shot-line{height:.7rem;width:58%;margin-bottom:.8rem;border-radius:999px;background:rgba(46,79,93,.2)}.shot-line.wide{width:82%;height:1rem;background:rgba(23,63,76,.42)}.shot-chart{display:grid;grid-template-columns:repeat(4,1fr);align-items:end;grid-gap:.55rem;gap:.55rem;height:5.6rem;margin-top:1.2rem}.shot-chart span{border-radius:.35rem .35rem 0 0;background:linear-gradient(180deg,#5a96a6,#173f4c)}.shot-chart span:first-child{height:42%}.shot-chart span:nth-child(2){height:74%}.shot-chart span:nth-child(3){height:56%}.shot-chart span:nth-child(4){height:92%}.product-content{padding:1.3rem}.product-kind{margin-bottom:.45rem;color:var(--ridge);font-size:.78rem;font-weight:900;text-transform:uppercase}.product-title-link{color:inherit;text-decoration:none}.product-title-link:focus-visible,.product-title-link:hover{text-decoration:underline;text-underline-offset:.14rem}.product-cta-link{display:inline-flex;align-items:center;gap:.35rem;margin-bottom:.65rem;color:var(--ridge);font-weight:800;text-decoration:none}.product-cta-link:focus-visible,.product-cta-link:hover{text-decoration:underline;text-underline-offset:.16rem}.product-tags{display:flex;flex-wrap:wrap;gap:.45rem;margin:1rem 0}details{border-top:1px solid var(--line);padding-top:1rem}summary{cursor:pointer;color:var(--deep);font-weight:900}details p{margin:.9rem 0 0}.contact{display:grid;grid-template-columns:minmax(0,1fr) minmax(18rem,34rem);grid-gap:clamp(2rem,6vw,5rem);gap:clamp(2rem,6vw,5rem);border-top:1px solid var(--line);background:linear-gradient(135deg,rgba(23,63,76,.08),rgba(217,237,240,.38))}.footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:1.5rem clamp(1rem,4vw,4rem);background:var(--ink);color:rgba(255,255,255,.76);font-size:.95rem}.footer span:first-child{color:white;font-weight:900}@media (max-width:940px){.contact,.hero,.split{grid-template-columns:1fr}.hero{min-height:auto}.hero-visual{min-height:29rem}.mountain-shell{left:50%;right:auto;transform:translateX(-50%)}.portfolio-grid{grid-template-columns:1fr}}@media (max-width:660px){.site-header{position:static;align-items:flex-start;flex-direction:column}.nav{width:100%;justify-content:space-between;gap:.5rem}.brand-logo{width:9rem}.hero{padding-top:2.5rem}h1{font-size:clamp(2.8rem,16vw,4.2rem)}.hero-visual{min-height:24rem}.mountain-shell{width:min(78vw,22rem);padding:2rem}.panel-one{left:0}.panel-two{right:0;bottom:0}}