/* ============================================================
 * Saryon Studio, Linear-inspired theme
 * ============================================================ */

*, *::before, *::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html{overflow-x:hidden}
body{
 font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
 background:#08080A;
 color:#F7F8F8;
 line-height:1.55;
 font-weight:400;
 font-size:15px;
 overflow-x:hidden;
 max-width:100vw;
 -webkit-font-smoothing:antialiased;
 -moz-osx-font-smoothing:grayscale;
 font-feature-settings:"cv11", "ss01", "ss03";
}
::selection{background:#5E6AD2;color:#fff}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .15s ease}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

body[data-lang="en"] .t-sv,
body[data-lang="sv"] .t-en{display:none}

.serif{font-family:'Inter', sans-serif;letter-spacing:-.02em;font-weight:600}
.italic{font-style:normal}
.mono{font-family:'JetBrains Mono', ui-monospace, monospace;letter-spacing:.02em}
.small{font-family:'JetBrains Mono', ui-monospace, monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#6F7079;font-weight:500}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}

/* ============================================================
 * Background mesh / global gradients
 * ============================================================ */
body::before{
 content:'';position:fixed;inset:0;z-index:-2;pointer-events:none;
 background:
 radial-gradient(ellipse 60% 40% at 20% 0%, rgba(94, 106, 210, .18), transparent 60%),
 radial-gradient(ellipse 50% 30% at 80% 10%, rgba(78, 167, 252, .12), transparent 60%),
 #08080A;
}
body::after{
 content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.4;
 background-image:url("data:image/svg+xml, %3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.025 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
 * HEADER
 * ============================================================ */
.site-header{
 position:fixed;top:0;left:0;right:0;z-index:1000;
 padding:14px 32px;
 background:rgba(8, 8, 10, .6);
 backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);
 border-bottom:1px solid rgba(255, 255, 255, .06);
 transition:background .3s ease;
}
.site-header.scrolled{background:rgba(8, 8, 10, .85)}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1240px;margin:0 auto;gap:32px}
.brand{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:-.015em}
.brand-logo{height:38px;width:auto;display:block}
.site-header.scrolled .brand-logo{height:32px}
.brand-logo--footer{height:52px}
.brand-name{font-size:15px;color:#F7F8F8;font-weight:600}
.brand-mark{font-size:12px;color:#6F7079;font-weight:400;letter-spacing:0}
.brand-mark::before{content:'/ '}
.nav{display:flex;align-items:center;gap:24px}
.nav-list{display:flex;list-style:none;gap:4px}
.nav-list a{
 font-size:13px;font-weight:500;color:#B4BCD0;
 padding:7px 12px;border-radius:6px;
 transition:color .15s, background .15s;
 letter-spacing:-.005em;
}
.nav-list a:hover{color:#F7F8F8;background:rgba(255, 255, 255, .04)}
.nav-num{display:none}
.lang-switch{
 display:inline-flex;align-items:center;gap:0;
 font-family:'JetBrains Mono', monospace;font-size:10px;letter-spacing:.06em;
 border:1px solid rgba(255, 255, 255, .08);border-radius:6px;overflow:hidden;
 background:rgba(255, 255, 255, .02);
}
.lang-switch button{padding:6px 9px;color:#B4BCD0;transition:.15s;line-height:1;font-weight:500}
.lang-switch button.active{background:#1F1F25;color:#F7F8F8}
.nav-cta{
 display:inline-flex;align-items:center;gap:8px;
 font-size:13px;font-weight:500;color:#08080A;
 padding:8px 14px;border-radius:6px;
 background:#F7F8F8;
 transition:.2s;letter-spacing:-.005em;
}
.nav-cta:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 16px rgba(247, 248, 248, .15)}
.nav-cta-dot{width:6px;height:6px;border-radius:50%;background:#5E6AD2;box-shadow:0 0 8px #5E6AD2;animation:dot 2s ease-in-out infinite}
@keyframes dot{0%, 100%{opacity:1}50%{opacity:.4}}
.menu-toggle{display:none;flex-direction:column;gap:4px;width:32px;height:32px;align-items:center;justify-content:center;border-radius:6px}
.menu-toggle:hover{background:rgba(255, 255, 255, .05)}
.menu-toggle span{width:18px;height:1.5px;background:#F7F8F8;border-radius:1px}

/* ============================================================
 * HERO
 * ============================================================ */
.hero{position:relative;padding:160px 0 100px;text-align:center;overflow:hidden}
.hero::before{
 content:'';position:absolute;left:50%;top:80px;transform:translateX(-50%);
 width:min(1100px,100vw);height:600px;pointer-events:none;
 background:
 radial-gradient(ellipse 60% 50% at 50% 50%, rgba(94, 106, 210, .35), transparent 70%),
 radial-gradient(ellipse 40% 30% at 30% 60%, rgba(78, 167, 252, .25), transparent 70%),
 radial-gradient(ellipse 40% 30% at 70% 40%, rgba(235, 87, 87, .15), transparent 70%);
 filter:blur(60px);opacity:.7;
}
.hero .wrap{position:relative;z-index:1}

.hero-meta{display:none}

.hero-tag{
 display:inline-flex;align-items:center;gap:8px;
 padding:5px 12px 5px 6px;border-radius:100px;
 background:rgba(255, 255, 255, .04);border:1px solid rgba(255, 255, 255, .08);
 font-size:12px;font-weight:500;color:#B4BCD0;
 margin-bottom:32px;letter-spacing:-.005em;
 transition:.2s;
}
.hero-tag:hover{background:rgba(255, 255, 255, .06);color:#F7F8F8}
.hero-tag-pill{
 display:inline-flex;align-items:center;
 padding:2px 8px;border-radius:100px;
 background:linear-gradient(135deg, #5E6AD2, #4EA7FC);
 font-family:'JetBrains Mono', monospace;font-size:9px;font-weight:600;
 text-transform:uppercase;letter-spacing:.08em;color:#fff;
}
.hero-tag-arrow{font-size:10px;opacity:.5}

.hero-headline{
 font-family:'Inter', sans-serif;
 font-size:clamp(48px, 8vw, 96px);
 line-height:1.02;letter-spacing:-.04em;
 color:#F7F8F8;font-weight:600;
 margin:0 auto 24px;max-width:1000px;
}
.hero-headline .row{display:inline}
.hero-headline .ind{display:none}
.hero-headline em{
 font-style:normal;font-weight:600;
 background:linear-gradient(135deg, #5E6AD2 0%, #4EA7FC 60%, #A78BFA 100%);
 -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-headline sup{display:none}
.hero-headline br{display:none}

.hero-foot{display:flex;flex-direction:column;align-items:center;gap:32px;padding:0;border:none;margin-top:0}
.hero-statement{
 font-family:'Inter', sans-serif;font-style:normal;font-weight:400;
 font-size:clamp(16px, 1.4vw, 18px);line-height:1.5;letter-spacing:-.005em;
 color:#B4BCD0;max-width:600px;margin:0 auto 8px;
}
.hero-statement::before{display:none}
.hero-actions{flex-direction:row;gap:10px;align-items:center;justify-content:center}
.btn{
 display:inline-flex;align-items:center;gap:6px;
 font-size:13px;font-weight:500;letter-spacing:-.005em;
 padding:10px 18px;border-radius:6px;
 border:1px solid transparent;transition:.2s;
}
.hero-actions .btn:first-child{
 background:#F7F8F8;color:#08080A;border-color:#F7F8F8;
}
.hero-actions .btn:first-child:hover{background:#fff;transform:translateY(-1px);box-shadow:0 6px 20px rgba(247, 248, 248, .18)}
.hero-actions .btn:last-child{
 background:rgba(255, 255, 255, .04);color:#F7F8F8;
 border-color:rgba(255, 255, 255, .08);
}
.hero-actions .btn:last-child:hover{background:rgba(255, 255, 255, .08);border-color:rgba(255, 255, 255, .14)}
.btn-arrow{font-family:inherit;font-style:normal;font-size:14px;transition:transform .2s}
.btn:hover .btn-arrow{transform:translateX(2px)}
.hero-coords{display:none}

/* ============================================================
 * STRIP, logo cloud
 * ============================================================ */
.strip{
 padding:40px 0;background:transparent;color:#62656D;
 border-bottom:1px solid rgba(255, 255, 255, .06);
 border-top:1px solid rgba(255, 255, 255, .06);
 overflow:hidden;
 mask-image:linear-gradient(90deg, transparent, #000 15%, #000 85%, transparent);
}
.strip::before{
 content:'TRUSTED BY RESTAURANTS ACROSS SWEDEN';
 display:block;text-align:center;margin-bottom:24px;
 font-family:'JetBrains Mono', monospace;font-size:11px;color:#62656D;letter-spacing:.1em;font-weight:500;
}
.strip-track{
 display:flex;gap:64px;align-items:center;
 animation:marquee 40s linear infinite;white-space:nowrap;
 font-family:'Inter', sans-serif;font-size:22px;font-weight:600;
 letter-spacing:-.02em;
}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.strip-track span{display:inline-flex;align-items:center;gap:64px;color:#62656D;font-style:normal}
.strip-track span::after{content:'';width:6px;height:6px;border-radius:50%;background:#28282D;color:transparent}

/* ============================================================
 * SECTIONS
 * ============================================================ */
.section{padding:120px 0;border-bottom:1px solid rgba(255, 255, 255, .05);position:relative}
.section-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;margin-bottom:64px}
.section-head-l{display:flex;flex-direction:column;align-items:center;gap:14px}
.section-num{
 display:inline-block;padding:4px 10px;border-radius:100px;
 background:rgba(94, 106, 210, .12);border:1px solid rgba(94, 106, 210, .25);
 font-family:'JetBrains Mono', monospace;font-size:11px;font-weight:500;
 color:#A5B0E8;letter-spacing:.06em;text-transform:uppercase;font-style:normal;
}
.section-num span, .section-num{font-style:normal}
.section-title{
 font-family:'Inter', sans-serif;
 font-size:clamp(34px, 4.5vw, 56px);
 line-height:1.05;letter-spacing:-.03em;
 color:#F7F8F8;font-weight:600;max-width:760px;
}
.section-title em{
 font-style:normal;font-weight:600;
 background:linear-gradient(135deg, #5E6AD2, #4EA7FC);
 -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-lead{
 font-size:16px;color:#B4BCD0;line-height:1.55;max-width:560px;font-weight:400;
 letter-spacing:-.005em;
}
.section-lead .small{display:block;margin-bottom:14px;color:#62656D}

/* ============================================================
 * CAPABILITIES
 * ============================================================ */
.capa{padding:80px 0;border-bottom:1px solid rgba(255, 255, 255, .05)}
.capa-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;margin-bottom:48px}
.capa-head .small{font-family:'JetBrains Mono', monospace;color:#62656D}
.capa-h{font-family:'Inter', sans-serif;font-size:clamp(28px, 3vw, 40px);letter-spacing:-.025em;color:#F7F8F8;font-weight:600;max-width:680px;line-height:1.1}
.capa-h em{font-style:normal;background:linear-gradient(135deg, #5E6AD2, #4EA7FC);-webkit-background-clip:text;background-clip:text;color:transparent}
.capa-grid{
 display:grid;grid-template-columns:repeat(6, 1fr);gap:1px;
 background:rgba(255, 255, 255, .06);
 border:1px solid rgba(255, 255, 255, .06);border-radius:12px;overflow:hidden;
}
.capa-cell{
 padding:24px 20px;background:#0F0F11;
 font-family:'JetBrains Mono', monospace;font-size:12px;color:#F7F8F8;letter-spacing:0;
 display:flex;flex-direction:column;gap:8px;
 transition:background .2s ease;border:none;
}
.capa-cell:hover{background:#15151A}
.capa-cell:hover .capa-cat{color:#A5B0E8}
.capa-cat{font-size:10px;color:#62656D;text-transform:uppercase;letter-spacing:.08em;font-weight:500;transition:.2s}
.capa-name{font-weight:500;font-size:13px;color:#F7F8F8}

/* ============================================================
 * SERVICES, card grid
 * ============================================================ */
.services-list{display:grid;grid-template-columns:repeat(3, 1fr);gap:1px;background:rgba(255, 255, 255, .06);border:1px solid rgba(255, 255, 255, .06);border-radius:14px;overflow:hidden}
.service{
 display:flex;flex-direction:column;align-items:flex-start;
 padding:32px;background:#0F0F11;gap:0;
 transition:background .25s ease;border:none;min-height:280px;
}
.service:hover{background:#15151A;padding-left:32px}
.service:hover .service-name{color:#F7F8F8}
.service-num{
 display:inline-block;padding:3px 8px;border-radius:6px;
 background:rgba(94, 106, 210, .1);color:#A5B0E8;
 font-family:'JetBrains Mono', monospace;font-size:10px;font-weight:500;letter-spacing:.05em;
 margin-bottom:24px;font-style:normal;
}
.service-name{
 font-family:'Inter', sans-serif;font-size:22px;font-weight:600;
 letter-spacing:-.02em;line-height:1.2;color:#F7F8F8;
 margin-bottom:12px;transition:color .2s;
}
.service-name br{display:inline}
.service-desc{
 font-size:14px;color:#B4BCD0;line-height:1.55;flex:1;
 max-width:none;opacity:1;letter-spacing:-.005em;
}
.service-tools{
 font-family:'JetBrains Mono', monospace;font-size:11px;color:#62656D;
 text-align:left;line-height:1.7;margin-top:24px;
 padding-top:20px;border-top:1px solid rgba(255, 255, 255, .06);
 width:100%;letter-spacing:.02em;
}

/* ============================================================
 * WORK, featured + index
 * ============================================================ */
.feature{display:grid;grid-template-columns:1.3fr 1fr;gap:32px;align-items:stretch;margin-bottom:48px}
.feature-visual{
 position:relative;aspect-ratio:5/4;overflow:hidden;
 background:#0F0F11;display:block;border-radius:14px;
 border:1px solid rgba(255, 255, 255, .06);
}
.feature-visual::before{
 content:'';position:absolute;inset:0;
 background:
 radial-gradient(ellipse 70% 60% at 30% 30%, rgba(94, 106, 210, .5), transparent 60%),
 radial-gradient(ellipse 80% 70% at 70% 80%, rgba(78, 167, 252, .4), transparent 60%),
 radial-gradient(ellipse 50% 50% at 50% 50%, rgba(167, 139, 250, .3), transparent 60%),
 #0F0F11;
}
.feature-visual.has-image::before{display:none}
.feature-visual.has-image img{width:100%;height:100%;object-fit:cover;position:relative;z-index:1}
.feature-visual::after{
 content:'';position:absolute;inset:0;opacity:.3;pointer-events:none;
 background-image:url("data:image/svg+xml, %3Csvg viewBox='0 0 300 300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.feature-overlay{
 position:absolute;left:24px;right:24px;bottom:24px;z-index:2;color:#F7F8F8;
 display:flex;justify-content:space-between;align-items:flex-end;gap:16px;
}
.feature-tag{
 font-family:'JetBrains Mono', monospace;font-style:normal;font-weight:500;
 font-size:11px;color:#F7F8F8;opacity:.85;
 padding:4px 10px;border-radius:100px;
 background:rgba(0, 0, 0, .4);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
 letter-spacing:.05em;text-transform:uppercase;
}
.feature-title-overlay{font-family:'Inter', sans-serif;font-weight:600;font-size:36px;line-height:1.05;letter-spacing:-.025em}
.feature-content{
 display:flex;flex-direction:column;justify-content:center;
 padding:32px;background:#0F0F11;border:1px solid rgba(255, 255, 255, .06);border-radius:14px;
}
.feature-eyebrow{
 font-family:'JetBrains Mono', monospace;font-style:normal;font-weight:500;
 color:#A5B0E8;font-size:11px;margin-bottom:16px;letter-spacing:.05em;text-transform:uppercase;
}
.feature-h{
 font-family:'Inter', sans-serif;font-size:36px;line-height:1.1;letter-spacing:-.025em;
 color:#F7F8F8;margin-bottom:16px;font-weight:600;
}
.feature-h em{font-style:normal;font-weight:600;background:linear-gradient(135deg, #5E6AD2, #4EA7FC);-webkit-background-clip:text;background-clip:text;color:transparent}
.feature-body{font-size:14px;color:#B4BCD0;line-height:1.6;margin-bottom:32px;max-width:none;opacity:1;letter-spacing:-.005em}
.feature-data{display:grid;grid-template-columns:repeat(3, 1fr);gap:16px;padding-top:24px;border-top:1px solid rgba(255, 255, 255, .08)}
.feature-data .small{display:block;margin-bottom:6px;color:#62656D}
.feature-data strong{font-family:'Inter', sans-serif;font-weight:500;font-size:14px;color:#F7F8F8;letter-spacing:-.01em}

.work-index{
 display:flex;flex-direction:column;
 border:1px solid rgba(255, 255, 255, .06);border-radius:14px;overflow:hidden;
 background:#0F0F11;
}
.work-row{
 display:grid;grid-template-columns:60px 1.5fr 1fr 1fr 24px;
 gap:24px;align-items:center;
 padding:18px 24px;
 border-top:1px solid rgba(255, 255, 255, .05);
 position:relative;cursor:pointer;
 transition:background .2s ease;
}
.feature-data--two{grid-template-columns:repeat(2, 1fr)}
.project-modal-meta--two{grid-template-columns:repeat(2, 1fr)}
.work-row:first-child{border-top:none}
.work-row:last-child{border-bottom:none}
.work-row:hover{background:#15151A}
.work-row:hover .work-row-name{color:#A5B0E8}
.work-row:hover .work-row-arrow{opacity:1;transform:translateX(0);color:#A5B0E8}
.work-row--inert{cursor:default}
.work-row--inert:hover{background:transparent}
.work-row--inert:hover .work-row-name{color:#F7F8F8}
.feature-visual:not(a){cursor:default}

/* Buttons used as work tiles, strip default styling */
button.feature-visual, button.work-row{font:inherit;color:inherit;text-align:inherit;cursor:pointer;width:100%;border:none;background:none;padding:0}
button.feature-visual{display:block}
button.work-row{padding:18px 24px}

/* ============================================================
 * PROJECT MODAL
 * ============================================================ */
.project-modal{
 position:fixed;inset:0;z-index:2000;
 display:none;align-items:center;justify-content:center;
 padding:32px;
}
.project-modal.open{display:flex;animation:projectFade .2s ease-out}
@keyframes projectFade{from{opacity:0}to{opacity:1}}
.project-modal-backdrop{
 position:absolute;inset:0;
 background:rgba(8, 8, 10, .7);
 backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.project-modal-panel{
 position:relative;z-index:1;
 width:100%;max-width:920px;max-height:90vh;
 background:#0F0F11;
 border:1px solid rgba(255, 255, 255, .08);
 border-radius:16px;overflow:hidden;
 display:flex;flex-direction:column;
 box-shadow:0 32px 80px rgba(0, 0, 0, .6);
 animation:projectSlide .25s cubic-bezier(.2, .8, .2, 1);
}
@keyframes projectSlide{from{transform:translateY(20px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.project-modal-close{
 position:absolute;top:16px;right:16px;z-index:3;
 width:34px;height:34px;border-radius:50%;
 background:rgba(8, 8, 10, .6);color:#F7F8F8;
 font-size:22px;line-height:1;cursor:pointer;
 display:flex;align-items:center;justify-content:center;
 transition:.15s;backdrop-filter:blur(8px);
}
.project-modal-close:hover{background:rgba(8, 8, 10, .9);transform:rotate(90deg)}
.project-modal-cover{
 position:relative;width:100%;aspect-ratio:21/9;
 background:#0F0F11;flex-shrink:0;overflow:hidden;
}
.project-modal-cover::before{
 content:'';position:absolute;inset:0;
 background:
 radial-gradient(ellipse 70% 60% at 30% 30%, rgba(94, 106, 210, .5), transparent 60%),
 radial-gradient(ellipse 80% 70% at 70% 80%, rgba(78, 167, 252, .4), transparent 60%),
 #0F0F11;
}
.project-modal-cover.has-image::before{display:none}
.project-modal-cover img{width:100%;height:100%;object-fit:cover}
.project-modal-body{
 padding:32px 40px 40px;overflow-y:auto;
 display:flex;flex-direction:column;gap:18px;
}
.project-modal-eyebrow{
 font-family:'JetBrains Mono', monospace;font-size:11px;font-weight:500;
 color:#A5B0E8;letter-spacing:.06em;text-transform:uppercase;
 display:inline-block;padding:4px 10px;border-radius:100px;
 background:rgba(94, 106, 210, .12);border:1px solid rgba(94, 106, 210, .25);
 align-self:flex-start;
}
.project-modal-title{
 font-family:'Inter', sans-serif;font-size:36px;line-height:1.1;letter-spacing:-.025em;
 color:#F7F8F8;font-weight:600;margin:0;
}
.project-modal-deck{
 font-family:'Inter', sans-serif;font-size:18px;line-height:1.4;letter-spacing:-.01em;
 color:#B4BCD0;margin:0;
}
.project-modal-deck em{font-style:normal;font-weight:600;background:linear-gradient(135deg, #5E6AD2, #4EA7FC);-webkit-background-clip:text;background-clip:text;color:transparent}
.project-modal-prose{font-size:14px;color:#B4BCD0;line-height:1.65;letter-spacing:-.005em}
.project-modal-prose p{margin:0 0 12px}
.project-modal-meta{
 display:grid;grid-template-columns:repeat(3, 1fr);gap:18px;
 padding:18px 0;margin-top:8px;
 border-top:1px solid rgba(255, 255, 255, .08);
 border-bottom:1px solid rgba(255, 255, 255, .08);
}
.project-modal-meta div{display:flex;flex-direction:column;gap:4px}
.project-modal-meta .small{color:#62656D}
.project-modal-meta strong{font-family:'Inter', sans-serif;font-weight:500;color:#F7F8F8;font-size:14px;letter-spacing:-.005em}
.project-modal-cta{
 align-self:flex-start;margin-top:8px;padding:11px 18px;border-radius:6px;
 background:#F7F8F8;color:#08080A;font-size:13px;font-weight:500;
 display:inline-flex;align-items:center;gap:8px;transition:.2s;
}
.project-modal-cta:hover{background:#fff;transform:translateY(-1px);box-shadow:0 6px 20px rgba(247, 248, 248, .18)}
body.project-modal-open{overflow:hidden}

@media(max-width:760px){
 .project-modal{padding:0;align-items:flex-end}
 .project-modal-panel{max-height:95vh;border-radius:16px 16px 0 0}
 .project-modal-cover{aspect-ratio:16/9}
 .project-modal-body{padding:24px}
 .project-modal-title{font-size:28px}
 .project-modal-deck{font-size:16px}
 .project-modal-meta{grid-template-columns:1fr;gap:12px}
}

/* ============================================================
 * CASE STUDY (single project page)
 * ============================================================ */
.case{padding:140px 0 100px;position:relative}
.case-back{
 display:inline-flex;align-items:center;gap:8px;
 font-size:13px;color:#B4BCD0;font-weight:500;
 padding:6px 12px;border-radius:6px;
 background:rgba(255, 255, 255, .04);border:1px solid rgba(255, 255, 255, .08);
 transition:.15s;margin-bottom:48px;
}
.case-back:hover{color:#F7F8F8;background:rgba(255, 255, 255, .06)}
.case-back-arrow{font-size:14px;transition:transform .2s}
.case-back:hover .case-back-arrow{transform:translateX(-3px)}
.case-head{max-width:920px;margin:0 0 64px}
.case-eyebrow{
 display:inline-block;padding:4px 12px;border-radius:100px;
 background:rgba(94, 106, 210, .12);border:1px solid rgba(94, 106, 210, .25);
 font-family:'JetBrains Mono', monospace;font-size:11px;font-weight:500;
 color:#A5B0E8;letter-spacing:.06em;text-transform:uppercase;
 margin-bottom:24px;
}
.case-year{opacity:.7}
.case-title{
 font-family:'Inter', sans-serif;
 font-size:clamp(40px, 6vw, 72px);line-height:1.05;letter-spacing:-.035em;
 color:#F7F8F8;font-weight:600;margin-bottom:20px;
}
.case-deck{
 font-family:'Inter', sans-serif;font-size:clamp(18px, 2vw, 24px);
 line-height:1.4;letter-spacing:-.015em;color:#B4BCD0;font-weight:400;
}
.case-deck em{
 font-style:normal;font-weight:600;
 background:linear-gradient(135deg, #5E6AD2, #4EA7FC);
 -webkit-background-clip:text;background-clip:text;color:transparent;
}
.case-cover{
 position:relative;aspect-ratio:16/9;overflow:hidden;
 background:#0F0F11;border-radius:14px;
 border:1px solid rgba(255, 255, 255, .06);margin-bottom:64px;
}
.case-cover::before{
 content:'';position:absolute;inset:0;
 background:
 radial-gradient(ellipse 70% 60% at 30% 30%, rgba(94, 106, 210, .5), transparent 60%),
 radial-gradient(ellipse 80% 70% at 70% 80%, rgba(78, 167, 252, .4), transparent 60%),
 #0F0F11;
}
.case-cover.has-image::before{display:none}
.case-cover img{width:100%;height:100%;object-fit:cover;position:relative;z-index:1}
.case-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:64px;align-items:start;margin-bottom:96px}
.case-body{font-size:16px;color:#B4BCD0;line-height:1.7;letter-spacing:-.005em}
.case-body p{margin-bottom:18px}
.case-body p:last-child{margin-bottom:0}
.case-content{margin-top:24px}
.case-meta{
 display:flex;flex-direction:column;gap:24px;
 padding:28px;background:#0F0F11;border:1px solid rgba(255, 255, 255, .06);
 border-radius:14px;position:sticky;top:96px;
}
.case-meta div{display:flex;flex-direction:column;gap:4px}
.case-meta .small{color:#62656D}
.case-meta strong{font-family:'Inter', sans-serif;font-weight:500;color:#F7F8F8;font-size:15px;letter-spacing:-.005em}
.case-cta{
 margin-top:8px;padding:12px 18px;border-radius:6px;
 background:#F7F8F8;color:#08080A;font-size:13px;font-weight:500;
 display:inline-flex;align-items:center;justify-content:center;gap:8px;
 transition:.2s;letter-spacing:-.005em;
}
.case-cta:hover{background:#fff;transform:translateY(-1px);box-shadow:0 6px 20px rgba(247, 248, 248, .15)}
.case-more{padding-top:64px;border-top:1px solid rgba(255, 255, 255, .06)}
.case-more-h{
 font-family:'Inter', sans-serif;font-size:24px;font-weight:600;
 letter-spacing:-.02em;color:#F7F8F8;margin-bottom:24px;
}
.case-more-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:1px;background:rgba(255, 255, 255, .06);border:1px solid rgba(255, 255, 255, .06);border-radius:14px;overflow:hidden}
.case-more-item{
 display:flex;flex-direction:column;gap:6px;
 padding:24px;background:#0F0F11;
 transition:background .2s ease;
}
.case-more-item:hover{background:#15151A}
.case-more-item:hover h4{color:#A5B0E8}
.case-more-cat{font-family:'JetBrains Mono', monospace;font-size:10px;color:#62656D;letter-spacing:.06em;text-transform:uppercase;font-weight:500}
.case-more-item h4{font-family:'Inter', sans-serif;font-weight:600;font-size:18px;letter-spacing:-.015em;color:#F7F8F8;margin:4px 0;line-height:1.2;transition:color .2s}
.case-more-year{font-family:'JetBrains Mono', monospace;font-size:11px;color:#62656D;letter-spacing:.04em;margin-top:auto}
@media(max-width:1080px){
 .case-grid{grid-template-columns:1fr;gap:32px}
 .case-meta{position:static}
}
@media(max-width:760px){
 .case{padding:100px 0 60px}
 .case-head{margin-bottom:40px}
 .case-cover{margin-bottom:40px}
 .case-more-grid{grid-template-columns:1fr}
}
.work-row-num{font-family:'JetBrains Mono', monospace;font-size:11px;color:#62656D;letter-spacing:.05em}
.work-row-name{font-family:'Inter', sans-serif;font-size:18px;font-weight:600;letter-spacing:-.015em;line-height:1.2;color:#F7F8F8;transition:.2s}
.work-row-cat{font-size:13px;color:#B4BCD0;letter-spacing:-.005em}
.work-row-stack{font-family:'JetBrains Mono', monospace;font-style:normal;font-size:11px;color:#62656D;letter-spacing:.02em}
.work-row-year{font-family:'JetBrains Mono', monospace;font-size:11px;color:#62656D;text-align:right;letter-spacing:.02em}
.work-row-arrow{font-family:inherit;font-style:normal;font-size:16px;color:#62656D;opacity:0;transform:translateX(-6px);transition:.2s;text-align:right}

/* ============================================================
 * STUDIO
 * ============================================================ */
.studio{padding:120px 0;border-bottom:1px solid rgba(255, 255, 255, .05)}
.studio-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:64px;align-items:start}
.studio-l{position:sticky;top:100px;display:flex;flex-direction:column;gap:16px}
.studio-photo{
 aspect-ratio:4/5;background:#0F0F11;position:relative;overflow:hidden;
 border-radius:14px;border:1px solid rgba(255, 255, 255, .06);
}
.studio-photo::before{
 content:'';position:absolute;inset:0;
 background:
 radial-gradient(ellipse 100% 70% at 50% 100%, rgba(94, 106, 210, .5), transparent 60%),
 radial-gradient(ellipse 60% 50% at 30% 30%, rgba(78, 167, 252, .3), transparent 60%),
 linear-gradient(180deg, #15151A 0%, #0F0F11 100%);
}
.studio-photo::after{
 content:'';position:absolute;inset:0;opacity:.25;
 background-image:url("data:image/svg+xml, %3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.06 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.studio-photo-cap{
 position:absolute;left:16px;bottom:16px;color:#F7F8F8;z-index:2;
 font-family:'JetBrains Mono', monospace;font-style:normal;font-size:11px;
 opacity:.6;letter-spacing:.02em;
}
/* Studio left column, stats variant */
.studio-stats{
 display:flex;flex-direction:column;gap:0;
 background:#0F0F11;border:1px solid rgba(255, 255, 255, .06);
 border-radius:14px;overflow:hidden;
}
.studio-stat{
 padding:24px 28px;
 border-bottom:1px solid rgba(255, 255, 255, .06);
 display:flex;flex-direction:column;gap:8px;
 transition:background .2s ease;position:relative;
}
.studio-stat:last-child{border-bottom:none}
.studio-stat:hover{background:#15151A}
.studio-stat strong{
 font-family:'Inter', sans-serif;
 font-size:clamp(40px, 5vw, 56px);
 font-weight:600;line-height:1;letter-spacing:-.03em;
 background:linear-gradient(135deg, #F7F8F8 0%, #B4BCD0 100%);
 -webkit-background-clip:text;background-clip:text;color:transparent;
}
.studio-stat span{
 font-family:'JetBrains Mono', monospace;font-size:11px;
 color:#62656D;letter-spacing:.06em;text-transform:uppercase;font-weight:500;
}
.studio-stat:hover strong{
 background:linear-gradient(135deg, #5E6AD2 0%, #4EA7FC 100%);
 -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* Studio left column, Promises variant */
.studio-promises{
 background:#0F0F11;border:1px solid rgba(255, 255, 255, .06);
 border-radius:14px;padding:32px 28px;
}
.studio-promises-label{
 display:block;font-family:'JetBrains Mono', monospace;
 font-size:11px;color:#62656D;letter-spacing:.08em;
 text-transform:uppercase;margin-bottom:28px;font-weight:500;
}
.studio-promises-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}
.studio-promises-list li{
 display:grid;grid-template-columns:36px 1fr;gap:14px;align-items:start;
 padding:20px 0;border-bottom:1px solid rgba(255, 255, 255, .06);
}
.studio-promises-list li:first-child{padding-top:0}
.studio-promises-list li:last-child{border-bottom:none;padding-bottom:0}
.studio-promise-num{
 font-family:'JetBrains Mono', monospace;font-size:11px;color:#A5B0E8;
 letter-spacing:.05em;font-weight:500;padding-top:5px;
}
.studio-promise-text{
 font-family:'Inter', sans-serif;font-size:17px;line-height:1.4;
 color:#F7F8F8;font-weight:500;letter-spacing:-.015em;
}
.studio-r{display:flex;flex-direction:column;gap:48px}
.studio-eyebrow{
 display:inline-block;padding:4px 10px;border-radius:100px;
 background:rgba(94, 106, 210, .12);border:1px solid rgba(94, 106, 210, .25);
 font-family:'JetBrains Mono', monospace;font-style:normal;color:#A5B0E8;font-size:11px;
 font-weight:500;letter-spacing:.06em;text-transform:uppercase;align-self:flex-start;
}
.studio-h{font-family:'Inter', sans-serif;font-size:clamp(28px, 3.4vw, 44px);line-height:1.1;letter-spacing:-.025em;color:#F7F8F8;font-weight:600}
.studio-h em{font-style:normal;font-weight:600;background:linear-gradient(135deg, #5E6AD2, #4EA7FC);-webkit-background-clip:text;background-clip:text;color:transparent}
.studio-body{font-size:15px;line-height:1.65;color:#B4BCD0;max-width:580px;opacity:1;letter-spacing:-.005em}
.studio-body p+p{margin-top:16px}
.studio-body .drop{font-family:'Inter', sans-serif;font-size:36px;line-height:.9;float:left;margin:4px 10px 0 0;color:#5E6AD2;font-style:normal;font-weight:600}

.principles{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.principle{
 padding:24px;background:#0F0F11;
 border:1px solid rgba(255, 255, 255, .06);border-radius:12px;
 border-top:1px solid rgba(255, 255, 255, .06);
 transition:.2s;
}
.principle:hover{background:#15151A;border-color:rgba(94, 106, 210, .25)}
.principle-num{
 display:inline-block;padding:2px 7px;border-radius:4px;
 background:rgba(94, 106, 210, .12);color:#A5B0E8;
 font-family:'JetBrains Mono', monospace;font-style:normal;font-size:10px;font-weight:500;
 margin-bottom:14px;letter-spacing:.05em;
}
.principle h4{font-family:'Inter', sans-serif;font-weight:600;font-size:16px;letter-spacing:-.015em;color:#F7F8F8;margin-bottom:8px;line-height:1.3}
.principle p{font-size:13px;color:#B4BCD0;line-height:1.55;opacity:1;letter-spacing:-.005em}

/* ============================================================
 * PROCESS
 * ============================================================ */
.process{padding:120px 0;background:transparent;color:#F7F8F8;border-bottom:1px solid rgba(255, 255, 255, .05)}
.process .section-head{margin-bottom:64px}
.process .section-num{color:#A5B0E8;background:rgba(94, 106, 210, .12);border-color:rgba(94, 106, 210, .25)}
.process .section-title{color:#F7F8F8}
.process .section-lead{color:#B4BCD0;opacity:1}
.process .section-lead .small{color:#62656D}
.process-grid{
 display:grid;grid-template-columns:repeat(5, 1fr);gap:1px;
 background:rgba(255, 255, 255, .06);
 border:1px solid rgba(255, 255, 255, .06);border-radius:14px;overflow:hidden;
}
.proc{padding:32px;background:#0F0F11;border:none;transition:background .2s}
.proc:hover{background:#15151A}
.proc-num{
 font-family:'JetBrains Mono', monospace;font-style:normal;color:#A5B0E8;
 font-size:13px;font-weight:500;line-height:1;margin-bottom:24px;display:block;
 padding:4px 8px;background:rgba(94, 106, 210, .12);border-radius:5px;
 letter-spacing:.05em;width:fit-content;
}
.proc h4{font-family:'Inter', sans-serif;font-weight:600;font-size:18px;letter-spacing:-.015em;margin-bottom:10px;color:#F7F8F8;line-height:1.3}
.proc p{font-size:13px;color:#B4BCD0;opacity:1;line-height:1.55;margin-bottom:20px;letter-spacing:-.005em}
.proc-time{font-family:'JetBrains Mono', monospace;color:#62656D;font-size:10px;letter-spacing:.08em;font-weight:500}

/* ============================================================
 * TESTIMONIAL
 * ============================================================ */
.testi{padding:120px 0;border-bottom:1px solid rgba(255, 255, 255, .05);position:relative}
.testi::before{
 content:'';position:absolute;left:50%;top:50%;transform:translate(-50%, -50%);
 width:600px;height:300px;pointer-events:none;
 background:radial-gradient(ellipse 60% 50% at 50% 50%, rgba(94, 106, 210, .18), transparent 70%);
 filter:blur(40px);
}
.testi-inner{max-width:900px;margin:0 auto;text-align:center;position:relative;z-index:1}
.testi-mark{
 font-family:'Inter', sans-serif;font-style:normal;color:#5E6AD2;
 font-size:48px;line-height:.5;margin-bottom:24px;display:block;font-weight:600;
}
.testi-quote{
 font-family:'Inter', sans-serif;font-size:clamp(22px, 2.6vw, 34px);
 line-height:1.3;letter-spacing:-.02em;color:#F7F8F8;
 font-weight:500;font-style:normal;margin-bottom:32px;
}
.testi-author{display:flex;align-items:center;justify-content:center;gap:14px}
.testi-avatar{
 width:42px;height:42px;border-radius:50%;
 background:linear-gradient(135deg, #5E6AD2, #4EA7FC);
 display:flex;align-items:center;justify-content:center;
 color:#fff;font-family:'Inter', sans-serif;font-style:normal;font-size:15px;font-weight:600;
}
.testi-meta{text-align:left}
.testi-meta strong{display:block;font-size:13px;font-weight:600;color:#F7F8F8;letter-spacing:-.005em}
.testi-meta span{font-family:'Inter', sans-serif;font-style:normal;font-size:12px;color:#62656D}

/* ============================================================
 * CONTACT
 * ============================================================ */
.contact{padding:140px 0 120px;border-bottom:1px solid rgba(255, 255, 255, .05);position:relative;text-align:center}
.contact::before{
 content:'';position:absolute;left:50%;bottom:0;transform:translateX(-50%);
 width:1100px;height:500px;pointer-events:none;
 background:radial-gradient(ellipse 60% 60% at 50% 100%, rgba(94, 106, 210, .25), transparent 70%);
 filter:blur(60px);
}
.contact .wrap{position:relative;z-index:1}
.contact-grid{display:flex;flex-direction:column;align-items:center;gap:48px}
.contact-h{
 font-family:'Inter', sans-serif;font-size:clamp(40px, 6vw, 72px);
 line-height:1.05;letter-spacing:-.035em;color:#F7F8F8;font-weight:600;
 margin-bottom:24px;text-align:center;
}
.contact-h em{font-style:normal;font-weight:600;background:linear-gradient(135deg, #5E6AD2, #4EA7FC);-webkit-background-clip:text;background-clip:text;color:transparent}
.contact-h sup{display:none}
.contact-h br{display:none}
.contact-body{font-size:16px;color:#B4BCD0;line-height:1.6;max-width:560px;opacity:1;margin:0 auto 32px;letter-spacing:-.005em}
.contact-email{
 display:inline-flex;align-items:center;gap:10px;
 font-family:'Inter', sans-serif;font-size:18px;font-weight:500;
 color:#08080A;font-style:normal;letter-spacing:-.005em;
 background:#F7F8F8;padding:14px 24px;border-radius:8px;
 border:none;transition:.2s;
}
.contact-email:hover{background:#fff;transform:translateY(-1px);box-shadow:0 8px 24px rgba(247, 248, 248, .18);gap:14px}

.contact-aside{
 margin-top:48px;padding:32px;
 border:1px solid rgba(255, 255, 255, .06);border-radius:14px;
 display:grid;grid-template-columns:repeat(3, 1fr);gap:32px;
 background:#0F0F11;width:100%;max-width:900px;text-align:left;
}
.aside-block .small{display:block;margin-bottom:10px;color:#62656D;font-family:'JetBrains Mono', monospace;font-size:10px;letter-spacing:.06em}
.aside-block p, .aside-block a{font-size:13px;color:#B4BCD0;line-height:1.6;letter-spacing:-.005em}
.aside-block a:hover{color:#F7F8F8}
.aside-block strong{font-family:'Inter', sans-serif;font-weight:600;font-size:14px;color:#F7F8F8;letter-spacing:-.005em}

/* PRODUCT SHOWCASE (Smakland) */
.product{padding:120px 0;border-bottom:1px solid rgba(255,255,255,.05);position:relative;overflow:hidden}
.product::before{
 content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
 width:1100px;height:500px;pointer-events:none;
 background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(94,106,210,.18),transparent 70%);
 filter:blur(60px);
}
.product .wrap{position:relative;z-index:1}
.product-grid{
 display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:center;
 background:#0F0F11;border:1px solid rgba(255,255,255,.08);border-radius:18px;
 padding:56px;overflow:hidden;position:relative;
}
.product-content{display:flex;flex-direction:column;gap:18px}
.product-eyebrow{
 display:inline-block;padding:5px 12px;border-radius:100px;
 background:rgba(94,106,210,.12);border:1px solid rgba(94,106,210,.25);
 font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:500;
 color:#A5B0E8;letter-spacing:.06em;text-transform:uppercase;align-self:flex-start;
}
.product-title{
 font-family:'Inter',sans-serif;font-size:clamp(56px,7vw,96px);
 line-height:1;letter-spacing:-.04em;color:#F7F8F8;font-weight:700;margin:0;
}
.product-title-dot{
 background:linear-gradient(135deg,#5E6AD2,#4EA7FC);
 -webkit-background-clip:text;background-clip:text;color:transparent;
}
.product-deck{
 font-family:'Inter',sans-serif;font-size:17px;line-height:1.5;
 color:#F7F8F8;font-weight:400;letter-spacing:-.005em;margin:8px 0 0;max-width:520px;
}
.product-meta{
 font-size:13px;color:#B4BCD0;line-height:1.55;letter-spacing:-.005em;
 padding-top:14px;border-top:1px solid rgba(255,255,255,.06);max-width:520px;
}
.product-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.product-cta{
 display:inline-flex;align-items:center;gap:8px;
 padding:11px 20px;border-radius:8px;font-size:14px;font-weight:500;
 letter-spacing:-.005em;transition:.2s;
 background:#F7F8F8;color:#08080A;border:1px solid #F7F8F8;
}
.product-cta:hover{background:#fff;transform:translateY(-1px);box-shadow:0 6px 20px rgba(247,248,248,.2);gap:12px}
.product-cta--ghost{background:transparent;color:#F7F8F8;border:1px solid rgba(255,255,255,.12)}
.product-cta--ghost:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.22);box-shadow:none}
.product-visual{
 position:relative;aspect-ratio:16/10;
 background:#15151A;
 border-radius:14px;border:1px solid rgba(255,255,255,.08);overflow:hidden;
 display:block;cursor:pointer;transition:.25s;
}
.product-visual:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.18);box-shadow:0 16px 48px rgba(0,0,0,.4)}
.product-visual-img{width:100%;height:100%;object-fit:cover;display:block}
.product-visual-tag{
 position:absolute;bottom:14px;right:14px;
 padding:6px 10px;border-radius:6px;
 background:rgba(8,8,10,.75);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
 font-family:'JetBrains Mono',monospace;font-size:10px;color:#F7F8F8;
 letter-spacing:.05em;font-weight:500;z-index:2;
 transition:.2s;
}
.product-visual:hover .product-visual-tag{background:rgba(8,8,10,.9)}
@media(max-width:900px){
 .product{padding:60px 0}
 .product-grid{grid-template-columns:1fr;padding:32px;gap:32px}
 .product-visual{aspect-ratio:16/10;max-height:300px}
 .product-visual-mark{font-size:120px}
}

/* PAGE TEMPLATE (legal docs, etc.) */
.page-doc{padding:160px 0 100px;color:#B4BCD0}
.page-doc .wrap{max-width:760px}
.page-doc-head{margin-bottom:48px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.08)}
.page-doc-title{
 font-family:'Inter',sans-serif;font-size:clamp(36px,5vw,56px);
 line-height:1.05;letter-spacing:-.03em;color:#F7F8F8;font-weight:600;
}
.page-doc-body{font-size:15px;line-height:1.7;letter-spacing:-.005em}
.page-doc-body h2{
 font-family:'Inter',sans-serif;font-size:18px;font-weight:600;letter-spacing:-.015em;
 color:#F7F8F8;margin:36px 0 12px;
}
.page-doc-body p{margin:0 0 14px}
.page-doc-body ul{margin:0 0 14px 0;padding-left:18px;list-style:none}
.page-doc-body ul li{position:relative;padding-left:14px;margin-bottom:8px}
.page-doc-body ul li::before{content:'·';position:absolute;left:0;color:#A5B0E8;font-weight:700}
.page-doc-body strong{color:#F7F8F8;font-weight:600}
.page-doc-body a{color:#A5B0E8;border-bottom:1px solid rgba(165,176,232,.3);transition:.15s}
.page-doc-body a:hover{color:#C5CFFF;border-bottom-color:#C5CFFF}
.page-doc-back{margin-top:64px;padding-top:32px;border-top:1px solid rgba(255,255,255,.08)}
.page-doc-back a{
 display:inline-flex;align-items:center;gap:8px;
 font-size:13px;color:#B4BCD0;font-weight:500;
 padding:8px 14px;border-radius:6px;background:rgba(255,255,255,.04);
 border:1px solid rgba(255,255,255,.08);transition:.15s;
}
.page-doc-back a:hover{color:#F7F8F8;background:rgba(255,255,255,.06)}

/* CONTACT v2: form + colophon */
.contact-header{text-align:center;max-width:680px;margin:0 auto 64px}
.contact-header .contact-h{margin-bottom:18px}
.contact-header .contact-body{margin:0 auto;max-width:520px}
.contact .contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:start;text-align:left}
.contact-form{
 background:#0F0F11;border:1px solid rgba(255,255,255,.06);border-radius:14px;
 padding:32px;display:flex;flex-direction:column;gap:18px;position:relative;
}
.contact-status{
 padding:12px 16px;border-radius:8px;font-size:13px;letter-spacing:-.005em;
 display:flex;flex-direction:column;
}
.contact-status--ok{background:rgba(94,210,134,.08);border:1px solid rgba(94,210,134,.25);color:#9CE2B5}
.contact-status--err{background:rgba(235,87,87,.08);border:1px solid rgba(235,87,87,.25);color:#F4A8A8}
.contact-field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-field{display:flex;flex-direction:column;gap:8px}
.contact-field-label{
 font-family:'JetBrains Mono',monospace;font-size:11px;color:#62656D;
 letter-spacing:.06em;text-transform:uppercase;font-weight:500;
}
.contact-form input[type=text],
.contact-form input[type=email],
.contact-form select,
.contact-form textarea{
 width:100%;background:#08080A;border:1px solid rgba(255,255,255,.08);
 border-radius:8px;padding:12px 14px;
 font-family:'Inter',sans-serif;font-size:14px;color:#F7F8F8;
 letter-spacing:-.005em;transition:border-color .15s,box-shadow .15s;outline:none;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
 border-color:rgba(94,106,210,.5);box-shadow:0 0 0 3px rgba(94,106,210,.12);
}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#62656D}
.contact-form textarea{resize:vertical;min-height:120px;font-family:'Inter',sans-serif;line-height:1.5}
.contact-form select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23B4BCD0'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}
.contact-honey{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.contact-submit{
 align-self:flex-start;margin-top:8px;
 display:inline-flex;align-items:center;gap:10px;
 padding:12px 22px;border-radius:8px;cursor:pointer;
 background:#F7F8F8;color:#08080A;border:none;
 font-family:'Inter',sans-serif;font-size:14px;font-weight:500;
 letter-spacing:-.005em;transition:.2s;
}
.contact-submit:hover{background:#fff;transform:translateY(-1px);box-shadow:0 8px 24px rgba(247,248,248,.18);gap:14px}
.contact-card{
 padding:32px;background:#0F0F11;border:1px solid rgba(255,255,255,.06);
 border-radius:14px;display:flex;flex-direction:column;gap:24px;
 position:sticky;top:96px;margin:0;max-width:none;
}
.contact-card-block{display:flex;flex-direction:column;gap:6px}
.contact-card-block .small{margin-bottom:4px;color:#62656D}
.contact-card-block p,.contact-card-block a{font-size:14px;color:#F7F8F8;line-height:1.5;letter-spacing:-.005em}
.contact-card-email{font-family:'Inter',sans-serif;font-weight:500;color:#A5B0E8;transition:color .15s;word-break:break-all}
.contact-card-email:hover{color:#C5CFFF}
.contact-card-social{display:flex;flex-wrap:wrap;gap:12px}
.contact-card-social a{color:#B4BCD0;transition:color .15s}
.contact-card-social a:hover{color:#F7F8F8}
@media(max-width:1080px){
 .contact .contact-grid{grid-template-columns:1fr;gap:24px}
 .contact-card{position:static}
}
@media(max-width:760px){
 .contact-form,.contact-card{padding:24px}
 .contact-field-row{grid-template-columns:1fr}
}

/* ============================================================
 * FOOTER
 * ============================================================ */
.site-footer{padding:64px 0 32px;background:transparent;border-top:1px solid rgba(255, 255, 255, .05)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255, 255, 255, .05);margin-bottom:24px}
.footer-brand .brand{margin-bottom:16px;display:inline-flex}
.footer-partner{
 display:inline-flex;align-items:center;gap:14px;
 margin-top:24px;padding:12px 18px;
 background:#F7F8F8;border:1px solid rgba(0,0,0,.06);
 border-radius:10px;transition:.2s;
}
.footer-partner:hover{background:#fff;border-color:rgba(0,0,0,.12);transform:translateY(-1px);box-shadow:0 6px 20px rgba(247,248,248,.12)}
.footer-partner-label{
 font-family:'JetBrains Mono',monospace;font-size:10px;
 color:#62656D;letter-spacing:.08em;text-transform:uppercase;font-weight:500;
}
.footer-partner-logo{height:24px;width:auto;display:block}
.footer-brand .brand-name{font-size:16px}
.footer-tagline{font-family:'Inter', sans-serif;font-style:normal;font-weight:400;font-size:13px;color:#B4BCD0;line-height:1.6;max-width:300px;opacity:1;letter-spacing:-.005em}
.footer-col h5{font-family:'JetBrains Mono', monospace;font-size:10px;color:#62656D;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;font-weight:500}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:8px}
.footer-col a{font-size:13px;color:#B4BCD0;transition:color .15s;letter-spacing:-.005em}
.footer-col a:hover{color:#F7F8F8}
.footer-bot{display:flex;justify-content:space-between;align-items:center;font-family:'JetBrains Mono', monospace;font-size:11px;color:#62656D;flex-wrap:wrap;gap:18px;letter-spacing:.02em}
.footer-bot .serif{font-family:'JetBrains Mono', monospace;font-style:normal;font-size:11px;font-weight:400}
.footer-bot a:hover{color:#B4BCD0}
.footer-legal, .footer-meta{display:inline-flex;align-items:center;flex-wrap:wrap;gap:10px}
.footer-sep{opacity:.45}

.giant-mark{display:none}

/* ============================================================
 * Animations
 * ============================================================ */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============================================================
 * Responsive
 * ============================================================ */
@media(max-width:1080px){
 .feature{grid-template-columns:1fr}
 .feature-visual{aspect-ratio:16/10}
 .studio-grid{grid-template-columns:1fr;gap:48px}
 .studio-l{position:static}
 .studio-photo{max-width:380px;aspect-ratio:4/5}
 .process-grid{grid-template-columns:repeat(3, 1fr)}
 .capa-grid{grid-template-columns:repeat(3, 1fr)}
 .services-list{grid-template-columns:repeat(2, 1fr)}
 .work-row{grid-template-columns:50px 1fr 1fr 1fr 24px}
 .work-row-cat{display:none}
}
@media(max-width:760px){
 .wrap{padding:0 18px;max-width:100%}
 .site-header, .site-header.scrolled{padding:10px 18px}
 .header-inner{gap:12px}
 .brand-logo{height:26px}
 .site-header.scrolled .brand-logo{height:24px}
 .nav-list, .nav-cta, .lang-switch{display:none !important}
 .menu-toggle{display:flex !important;flex-shrink:0;z-index:1001;position:relative}
 .menu-toggle span{transition:transform .2s ease, opacity .2s ease}

 /* Mobile nav drawer (open state) */
 body.nav-open{overflow:hidden}
 body.nav-open .site-header{background:#08080A !important}
 body.nav-open .nav{
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  justify-content:flex-start !important;
  position:fixed !important;
  top:54px !important;
  right:0 !important;
  bottom:0 !important;
  left:0 !important;
  width:100vw !important;
  height:calc(100dvh - 54px) !important;
  max-height:none !important;
  z-index:9999 !important;
  background:#08080A !important;
  padding:32px 24px 40px !important;
  gap:0 !important;
  border-top:1px solid rgba(255,255,255,.08);
  overflow-y:auto !important;
  margin:0 !important;
  animation:navDrop .22s ease-out;
 }
 body.nav-open .nav-list{
  display:flex !important;
  flex-direction:column !important;
  list-style:none;
  width:100%;
  gap:0;
  margin:0 0 28px 0;
  padding:0;
 }
 body.nav-open .nav-list li{display:block;width:100%}
 body.nav-open .nav-list a{
  display:block !important;
  font-size:26px;
  font-weight:600;
  color:#F7F8F8 !important;
  padding:18px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  letter-spacing:-.025em;
  background:transparent;
 }
 body.nav-open .nav-num{
  display:inline-block !important;
  color:#62656D;
  margin-right:12px;
  font-size:13px;
  vertical-align:baseline;
  font-family:'JetBrains Mono', monospace;
  font-style:normal;
 }
 body.nav-open .nav-cta{
  display:inline-flex !important;
  align-self:flex-start;
  font-size:15px;
  padding:13px 22px;
  margin-bottom:20px;
 }
 body.nav-open .lang-switch{
  display:inline-flex !important;
  align-self:flex-start;
  font-size:12px;
 }
 body.nav-open .menu-toggle span:nth-child(1){transform:translateY(3px) rotate(45deg)}
 body.nav-open .menu-toggle span:nth-child(2){transform:translateY(-3px) rotate(-45deg)}
 @keyframes navDrop{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

 .hero{padding:100px 0 60px}
 .hero-tag{font-size:11px;padding:4px 10px 4px 4px;margin-bottom:24px}
 .hero-tag-pill{font-size:8px}
 .hero-headline{font-size:clamp(36px,9vw,52px);margin-bottom:20px}
 .hero-foot{gap:24px}
 .hero-statement{font-size:15px;padding:0 4px}
 .hero-actions{flex-direction:column;width:100%;align-items:stretch;gap:8px}
 .hero-actions .btn{justify-content:center;padding:13px 18px;font-size:14px}
 .section, .studio, .testi{padding:80px 0}
 .section-head .section-title{font-size:clamp(30px,8vw,42px)}
 .product-title{font-size:clamp(48px,12vw,64px)}
 .product-grid{padding:24px}
 .studio-h{font-size:clamp(26px,6vw,36px)}
 .contact-h{font-size:clamp(36px,10vw,56px)}
 .feature-title-overlay{font-size:28px}
 .feature-h{font-size:28px}
 .contact{padding:100px 0 80px}
 .section-head{margin-bottom:40px}
 .services-list{grid-template-columns:1fr}
 .service{min-height:auto}
 .work-row{grid-template-columns:1fr;gap:6px;padding:18px 20px}
 .work-row-arrow{display:none}
 .work-row-year, .work-row-stack{justify-self:flex-start;text-align:left}
 .principles{grid-template-columns:1fr}
 .process-grid{grid-template-columns:1fr}
 .feature-data{grid-template-columns:1fr;gap:12px}
 .feature-content{padding:24px}
 .footer-top{grid-template-columns:1fr 1fr;gap:32px}
 .footer-bot{flex-direction:column;text-align:center}
 .capa-grid{grid-template-columns:repeat(2, 1fr)}
 .contact-aside{grid-template-columns:1fr;gap:24px}
 .testi::before, .contact::before{width:100vw;left:0;transform:none}
 .strip{max-width:100vw}
 .strip-track{max-width:none}
 .footer-top{grid-template-columns:1fr;gap:32px}
 .footer-bot{font-size:11px}
 .footer-partner{flex-wrap:wrap}
}

/* WP admin bar offset */
body.admin-bar .site-header{top:32px}
@media(max-width:782px){body.admin-bar .site-header{top:46px}}
