:root{--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--space-9:96px;--space-10:128px;--container-max:1240px;--container-px:clamp(20px,4vw,40px);--section-py:clamp(64px,9vw,128px);--bg:#0E1116;--fg:#E7EAEF;--accent:#FF6A2B;--bgAlt:#161B22;--textOnAccent:#0E1116;--muted:color-mix(in srgb,var(--fg) 62%,transparent);--font-display:'Space Grotesk',system-ui,sans-serif;--font-body:'IBM Plex Sans',system-ui,sans-serif;--ar-portrait:3/4;--ar-landscape:16/9;--ar-square:1/1;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--hairline:1px solid color-mix(in srgb,var(--fg) 14%,transparent);--ease:cubic-bezier(.2,.6,.2,1);--shadow:0 18px 50px -20px rgba(0,0,0,.62)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{overflow-x:hidden}
body{background:var(--bg);color:var(--fg);font-family:var(--font-body);line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
::selection{background:var(--accent);color:var(--textOnAccent)}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.15;letter-spacing:-.01em}
h1{font-size:clamp(40px,5vw,64px);line-height:1.08}
h2{font-size:clamp(28px,3.2vw,40px);line-height:1.18}
h3{font-size:clamp(20px,2vw,26px);line-height:1.3}
h4{font-size:18px;line-height:1.35}
p{font-size:clamp(15px,1.05vw,17px);line-height:1.65}
.prose{max-width:65ch}
.prose p+p{margin-top:18px}
small{font-size:13px}
.text-center{text-align:center}
.container{max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-px);position:relative}
.section{padding-block:var(--section-py);position:relative}
.section.bg-alt{background:var(--bgAlt)}
.section.bg-dark{background:var(--fg);color:var(--bg)}
.section.bg-dark .muted,.section.bg-dark p{color:color-mix(in srgb,var(--bg) 64%,transparent)}
.section.bg-accent{background:var(--accent);color:var(--textOnAccent)}
.section.full-bleed{padding-inline:0}
.section.narrow .container{max-width:860px}
.section.wide .container{max-width:1440px}
.section.compact{padding-block:clamp(48px,6vw,80px)}
.section.dense{padding-block:clamp(96px,14vw,168px)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.split.asym{grid-template-columns:1.12fr .88fr}
.split.media-left{direction:rtl}
.split.media-left>*{direction:ltr}
@media(max-width:880px){.split{grid-template-columns:1fr}}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);font-family:var(--font-display)}
.eyebrow::before{content:'';width:26px;height:1px;background:var(--accent)}
.section.bg-dark .eyebrow{color:color-mix(in srgb,var(--bg) 58%,transparent)}
.section-head{max-width:740px;margin-bottom:clamp(32px,4vw,56px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{margin-top:14px}
.section-head .lede{margin-top:16px;color:var(--muted);font-size:clamp(16px,1.2vw,18px);max-width:60ch}
.media{position:relative;overflow:hidden;aspect-ratio:var(--ar-landscape);background:var(--bgAlt);border-radius:var(--radius-md)}
.media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.media.portrait{aspect-ratio:var(--ar-portrait)}
.media.square{aspect-ratio:var(--ar-square)}
.reveal{opacity:1;transform:translateY(24px);transition:transform .7s var(--ease)}
.reveal.in{transform:none}
@media(prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important}html{scroll-behavior:auto}}
.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 70%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:var(--hairline);transition:background .3s var(--ease),box-shadow .3s var(--ease)}
.site-header.is-scrolled{background:color-mix(in srgb,var(--bg) 93%,transparent);box-shadow:0 12px 30px -24px rgba(0,0,0,.85)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-block:14px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-.01em;white-space:nowrap}
.brand .mark{width:30px;height:30px;display:grid;place-items:center;background:var(--accent);color:var(--textOnAccent);border-radius:6px;font-weight:700;font-size:16px}
.site-nav{display:flex;align-items:center;gap:26px}
.site-nav a{font-size:14px;font-weight:500;color:var(--muted);position:relative;padding-block:6px;transition:color .2s var(--ease)}
.site-nav a:hover{color:var(--fg)}
.site-nav a.is-active{color:var(--fg)}
.site-nav a.is-active::after{content:'';position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent)}
.header-cta{display:flex;align-items:center;gap:12px}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:600;font-size:15px;padding:13px 24px;border-radius:8px;border:1.5px solid transparent;cursor:pointer;line-height:1;transition:transform .2s var(--ease),background .2s var(--ease),color .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease)}
.btn:hover{transform:translateY(-1px)}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.btn-primary{background:var(--accent);color:var(--textOnAccent);border-color:var(--accent);box-shadow:0 10px 26px -12px color-mix(in srgb,var(--accent) 70%,transparent)}
.btn-primary:hover{background:color-mix(in srgb,var(--accent) 88%,#fff);box-shadow:0 16px 34px -12px color-mix(in srgb,var(--accent) 75%,transparent)}
.btn-ghost{background:transparent;color:var(--fg);border:1.5px solid color-mix(in srgb,var(--fg) 55%,transparent)}
.btn-ghost:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.section.bg-dark .btn-ghost{color:var(--bg);border-color:color-mix(in srgb,var(--bg) 58%,transparent)}
.section.bg-dark .btn-ghost:hover{background:var(--bg);color:var(--fg)}
.section.bg-accent .btn-primary{background:var(--bg);color:var(--fg);border-color:var(--bg);box-shadow:none}
.section.bg-accent .btn-primary:hover{background:color-mix(in srgb,var(--bg) 84%,#000)}
.section.bg-accent .btn-ghost{color:var(--bg);border-color:color-mix(in srgb,var(--bg) 55%,transparent)}
.section.bg-accent .btn-ghost:hover{background:var(--bg);color:var(--accent)}
.burger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;border:var(--hairline);border-radius:8px;background:transparent;cursor:pointer;align-items:center;justify-content:center}
.burger span{display:block;width:20px;height:2px;background:var(--fg);transition:transform .3s var(--ease),opacity .3s var(--ease)}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:960px){.burger{display:flex}.site-nav{position:fixed;inset:0 0 0 auto;width:min(320px,82vw);flex-direction:column;align-items:flex-start;gap:4px;background:var(--bgAlt);border-left:var(--hairline);padding:92px 28px 28px;transform:translateX(100%);transition:transform .35s var(--ease);z-index:45}.site-nav.is-open{transform:none;box-shadow:var(--shadow)}.site-nav a{font-size:18px;width:100%;padding-block:13px;border-bottom:var(--hairline)}.header-cta .btn-primary{display:none}}
.hero{padding-block:clamp(80px,13vw,140px)}
.hero .container{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.hero.narrow .container{grid-template-columns:1fr;max-width:860px}
.hero-content{max-width:620px}
.hero-content h1{margin-top:18px}
.hero-sub{margin-top:22px;font-size:clamp(17px,1.5vw,21px);color:color-mix(in srgb,var(--fg) 80%,transparent);max-width:50ch;line-height:1.55}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-media{position:relative;max-height:480px;border-radius:var(--radius-lg);overflow:hidden}
.hero-media .media{aspect-ratio:16/10;max-height:480px;border-radius:var(--radius-lg)}
.hero-badge{position:absolute;left:18px;bottom:18px;background:color-mix(in srgb,var(--bg) 82%,transparent);backdrop-filter:blur(6px);border:var(--hairline);border-radius:10px;padding:12px 16px;font-family:var(--font-display);font-size:13px;display:flex;gap:8px;align-items:center;z-index:2}
.hero-badge b{color:var(--accent);font-size:16px}
@media(max-width:880px){.hero .container{grid-template-columns:1fr}.hero-media{max-width:520px;margin-inline:auto;width:100%}}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6)}
.service-card{padding:var(--space-6);background:var(--bgAlt);border:var(--hairline);border-radius:var(--radius-md);transition:transform .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease)}
.service-card:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--accent) 60%,transparent);box-shadow:var(--shadow)}
.service-card .ico{width:48px;height:48px;display:grid;place-items:center;border-radius:8px;background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent);margin-bottom:18px}
.service-card .ico svg{width:24px;height:24px}
.service-card h3{margin-bottom:10px}
.service-card p{color:var(--muted);font-size:15px}
.service-card .spec-mini{margin-top:14px;display:grid;gap:6px}
.service-card .spec-mini li{font-size:13px;color:var(--muted);padding-left:16px;position:relative}
.service-card .spec-mini li::before{content:'';position:absolute;left:0;top:8px;width:6px;height:6px;background:var(--accent);border-radius:50%}
.service-card .more{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--accent)}
.service-card .more::after{content:'→';transition:transform .2s var(--ease)}
.service-card:hover .more::after{transform:translateX(4px)}
.capability-card{padding:var(--space-6);border:var(--hairline);border-radius:var(--radius-md);background:linear-gradient(180deg,var(--bgAlt),color-mix(in srgb,var(--bgAlt) 70%,var(--bg)));display:flex;flex-direction:column;gap:14px}
.capability-card h3{font-size:20px}
.capability-card p{color:var(--muted);font-size:15px}
.capability-card .cap-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:8px}
.capability-card .tag{font-size:12px;font-family:var(--font-display);padding:5px 10px;border:var(--hairline);border-radius:999px;color:var(--muted)}
.spec-list{display:grid;border-top:var(--hairline);margin-top:8px}
.spec-list .row{display:grid;grid-template-columns:1fr 1.5fr;gap:24px;padding-block:16px;border-bottom:var(--hairline);align-items:baseline}
.spec-list .row dt{font-family:var(--font-display);font-weight:600;color:var(--fg)}
.spec-list .row dd{color:var(--muted)}
@media(max-width:600px){.spec-list .row{grid-template-columns:1fr;gap:4px}}
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-5)}
.project-card{border:var(--hairline);border-radius:var(--radius-md);overflow:hidden;background:var(--bgAlt);transition:transform .3s var(--ease),border-color .3s var(--ease)}
.project-card:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--accent) 50%,transparent)}
.project-card .media{aspect-ratio:4/3;border-radius:0}
.project-card:hover .media img{transform:scale(1.05)}
.project-card .pc-body{padding:var(--space-5)}
.project-card .pc-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-family:var(--font-display);margin-bottom:10px}
.project-card .pc-meta span:first-child{color:var(--accent)}
.project-card h3{font-size:20px;margin-bottom:8px}
.project-card p{color:var(--muted);font-size:14px}
.process-steps{display:grid}
.step-item{display:grid;grid-template-columns:auto 1fr;gap:22px;padding-block:var(--space-5);border-top:var(--hairline);align-items:start}
.step-item:last-child{border-bottom:var(--hairline)}
.step-item .num{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,3vw,40px);color:color-mix(in srgb,var(--fg) 28%,transparent);line-height:1}
.step-item.is-accent .num{color:var(--accent)}
.step-item h3{margin-bottom:8px}
.step-item p{color:var(--muted);max-width:60ch}
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-6);text-align:center}
.stat-item .n{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,5vw,54px);line-height:1;color:var(--accent)}
.stat-item .n.sm{font-size:clamp(20px,2.4vw,28px)}
.stat-item .l{margin-top:10px;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.section.bg-dark .stat-item .l{color:color-mix(in srgb,var(--bg) 60%,transparent)}
.testimonials-track{display:flex;gap:var(--space-5);overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:14px;-webkit-overflow-scrolling:touch}
.testimonial{scroll-snap-align:start;flex:0 0 min(420px,86%);padding:var(--space-6);border:var(--hairline);border-radius:var(--radius-md);background:var(--bgAlt);display:flex;flex-direction:column;gap:18px}
.testimonial.solo{flex:1 1 auto;max-width:760px;margin-inline:auto;text-align:center}
.testimonial .quote{font-size:18px;line-height:1.55;font-family:var(--font-display);font-weight:500;color:var(--fg)}
.testimonial .quote::before{content:'“';color:var(--accent);font-size:42px;line-height:0;vertical-align:-14px;margin-right:4px}
.testimonial .who{display:flex;align-items:center;gap:12px;margin-top:auto}
.testimonial.solo .who{justify-content:center}
.testimonial .who .ava{width:44px;height:44px;border-radius:50%;background:color-mix(in srgb,var(--accent) 22%,var(--bgAlt));display:grid;place-items:center;font-family:var(--font-display);font-weight:700;color:var(--accent);flex:0 0 auto}
.testimonial .who b{display:block;font-family:var(--font-display);font-size:15px}
.testimonial .who span{font-size:13px;color:var(--muted)}
.cta-band{text-align:center}
.cta-band .container{max-width:760px}
.cta-band h2{margin-bottom:16px}
.cta-band p{color:color-mix(in srgb,var(--textOnAccent) 78%,transparent);margin-bottom:28px;font-size:18px}
.cta-band .hero-actions{justify-content:center;margin-top:0}
.contact-layout{display:grid;grid-template-columns:1.3fr .7fr;gap:clamp(32px,5vw,64px);align-items:start}
@media(max-width:880px){.contact-layout{grid-template-columns:1fr}}
.contact-form{display:grid;gap:18px}
.contact-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:560px){.contact-form .row2{grid-template-columns:1fr}}
.contact-form .field{display:grid;gap:8px}
.contact-form label{font-size:13px;font-family:var(--font-display);font-weight:600;letter-spacing:.02em}
.contact-form input,.contact-form textarea{width:100%;background:var(--bgAlt);border:var(--hairline);border-radius:8px;padding:13px 14px;color:var(--fg);font-family:var(--font-body);font-size:15px;transition:border-color .2s var(--ease)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--accent)}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-form .hint{font-size:12px;color:var(--muted);margin-top:-6px}
.contact-info{padding:var(--space-6);border:var(--hairline);border-radius:var(--radius-md);background:var(--bgAlt);display:grid;gap:18px}
.contact-info .ci-row{display:grid;gap:4px}
.contact-info .ci-row .k{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-family:var(--font-display)}
.contact-info .ci-row .v{font-size:15px;color:var(--fg)}
.map-section{padding-block:var(--section-py)}
.map-section .section-head{margin-bottom:24px}
.map-frame{width:100%;min-height:460px;border:0;border-radius:var(--radius-md);display:block;filter:grayscale(.2) contrast(1.04)}
@media(max-width:600px){.map-frame{min-height:340px}}
.faq{display:grid;border-top:var(--hairline)}
.faq-item{border-bottom:var(--hairline)}
.faq-item .q{width:100%;text-align:left;background:none;border:none;color:var(--fg);font-family:var(--font-display);font-weight:600;font-size:17px;padding:20px 44px 20px 0;cursor:pointer;position:relative}
.faq-item .q::after{content:'+';position:absolute;right:6px;top:50%;transform:translateY(-50%);color:var(--accent);font-size:26px;line-height:0;transition:transform .3s var(--ease)}
.faq-item.is-open .q::after{transform:translateY(-50%) rotate(45deg)}
.faq-item .a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-item .a p{padding-bottom:20px;color:var(--muted);max-width:72ch}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:var(--space-5)}
.team-card .media{aspect-ratio:3/4;border-radius:var(--radius-md);margin-bottom:16px}
.team-card:hover .media img{transform:scale(1.04)}
.team-card h3{font-size:19px}
.team-card .role{color:var(--accent);font-size:12px;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;margin-block:5px 10px}
.team-card p{color:var(--muted);font-size:14px}
.value-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-5)}
.value-card{padding:var(--space-5);border:var(--hairline);border-radius:var(--radius-md);background:var(--bgAlt)}
.value-card h3{font-size:18px;margin-bottom:8px}
.value-card p{color:var(--muted);font-size:14px}
.case-bleed{position:relative;min-height:clamp(420px,52vw,560px);display:grid;align-items:center}
.case-bleed .bg{position:absolute;inset:0;overflow:hidden}
.case-bleed .bg img{width:100%;height:100%;object-fit:cover}
.case-bleed .bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(14,17,22,.92),rgba(14,17,22,.62))}
.case-bleed .container{position:relative;z-index:2;max-width:var(--container-max)}
.case-bleed .case-inner{max-width:560px}
.case-bleed .case-inner h2{margin:14px 0 16px}
.case-bleed .case-inner p{color:color-mix(in srgb,var(--fg) 82%,transparent)}
.case-bleed .case-quote{margin:22px 0;font-family:var(--font-display);font-size:18px;border-left:2px solid var(--accent);padding-left:16px}
.site-footer{background:var(--bgAlt);border-top:var(--hairline);padding-block:var(--space-8) var(--space-6)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:clamp(32px,5vw,64px)}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}.footer-grid .f-brand{grid-column:1/-1}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-grid h4{font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:18px}
.f-brand p{color:var(--muted);font-size:14px;margin-top:14px;max-width:36ch;line-height:1.6}
.f-brand a{color:var(--muted)}
.f-brand a:hover{color:var(--fg)}
.f-nav a{color:var(--muted);font-size:14px;display:inline-block;padding-block:5px;transition:color .2s var(--ease)}
.f-nav a:hover{color:var(--fg)}
.social-row{display:flex;gap:12px;margin-top:4px}
.social-row a{width:38px;height:38px;border:var(--hairline);border-radius:8px;display:grid;place-items:center;color:var(--muted);transition:color .2s var(--ease),border-color .2s var(--ease),transform .2s var(--ease)}
.social-row a:hover{color:var(--accent);border-color:var(--accent);transform:translateY(-2px)}
.social-row svg{width:18px;height:18px}
.footer-bottom{margin-top:var(--space-7);padding-top:var(--space-5);border-top:var(--hairline);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:13px}
#cookie-banner{position:fixed;left:20px;right:20px;bottom:20px;max-width:640px;margin-inline:auto;background:var(--bgAlt);border:var(--hairline);border-radius:var(--radius-md);padding:18px 20px;display:flex;gap:16px;align-items:center;flex-wrap:wrap;z-index:80;box-shadow:var(--shadow);transform:translateY(160%);transition:transform .4s var(--ease)}
#cookie-banner.show{transform:none}
#cookie-banner p{font-size:13px;color:var(--muted);flex:1;min-width:220px;margin:0}
#cookie-banner .cb-actions{display:flex;gap:10px}
#cookie-banner .btn{padding:9px 16px;font-size:13px}
#back-to-top{position:fixed;right:22px;bottom:22px;width:46px;height:46px;border-radius:50%;background:var(--accent);color:var(--textOnAccent);border:none;cursor:pointer;font-size:20px;display:grid;place-items:center;opacity:0;pointer-events:none;transform:translateY(12px);transition:opacity .3s var(--ease),transform .3s var(--ease);z-index:70;box-shadow:var(--shadow)}
#back-to-top.show{opacity:1;pointer-events:auto;transform:none}