/* =================================================================
   NASCORP GLOBAL SOFTTECH — LINEAR / MODERN
   Deep space · layered ambient light · red accent glow ·
   multi-layer shadows · precision micro-interactions.
   ================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root{
  --bg:#050506;
  --bg-deep:#020203;
  --bg-elev:#0a0a0c;
  --surface:rgba(255,255,255,0.045);
  --surface-2:rgba(255,255,255,0.08);
  --fg:#EDEDEF;
  --fg-muted:#8A8F98;
  --fg-subtle:rgba(255,255,255,0.55);

  --accent:#FF4438;        /* brand red */
  --accent-bright:#FF5C4D;
  --accent-deep:#D50000;
  --glow:rgba(255,68,56,0.30);
  --glow-soft:rgba(255,68,56,0.12);

  --border:rgba(255,255,255,0.07);
  --border-hover:rgba(255,255,255,0.13);
  --border-accent:rgba(255,68,56,0.32);

  --font:"Inter",system-ui,-apple-system,sans-serif;
  --mono:"Geist Mono",ui-monospace,"SF Mono",Menlo,monospace;

  --sh-card:0 0 0 1px rgba(255,255,255,0.05),0 2px 20px rgba(0,0,0,0.45),0 0 40px rgba(0,0,0,0.25);
  --sh-card-hover:0 0 0 1px rgba(255,255,255,0.11),0 10px 44px rgba(0,0,0,0.55),0 0 80px rgba(255,68,56,0.10);
  --sh-cta:0 0 0 1px rgba(255,68,56,0.5),0 6px 18px rgba(255,68,56,0.32),inset 0 1px 0 0 rgba(255,255,255,0.22);
  --ease:cubic-bezier(0.16,1,0.3,1);
  --maxw:1280px;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;background:var(--bg);color:var(--fg);font-family:var(--font);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;position:relative;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
::selection{background:var(--accent);color:#fff;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,64px);}
.mono{font-family:var(--mono);}

.skip{position:absolute;left:-999px;top:0;background:var(--accent);color:#fff;padding:12px 18px;z-index:300;border-radius:8px;}
.skip:focus{left:12px;top:12px;}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--accent);border-radius:8px;}

/* =================================================================
   AMBIENT BACKGROUND
   ================================================================= */
.ambient{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;
  background:radial-gradient(ellipse at top,#0c0c12 0%,#050506 52%,#020203 100%);}
.ambient::after{content:'';position:absolute;inset:0;opacity:0.025;
  background-image:linear-gradient(rgba(255,255,255,0.5) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.5) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(ellipse at 50% 0%,#000 30%,transparent 78%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 0%,#000 30%,transparent 78%);}
.blob{position:absolute;border-radius:50%;filter:blur(140px);will-change:transform;}
.blob--1{top:-18%;left:50%;width:900px;height:760px;transform:translateX(-50%);background:radial-gradient(circle,rgba(255,68,56,0.22),transparent 66%);animation:float1 11s ease-in-out infinite;}
.blob--2{top:18%;left:-12%;width:620px;height:760px;background:radial-gradient(circle,rgba(180,40,90,0.14),transparent 66%);animation:float2 13s ease-in-out infinite;}
.blob--3{top:8%;right:-10%;width:560px;height:680px;background:radial-gradient(circle,rgba(94,106,210,0.12),transparent 66%);animation:float3 15s ease-in-out infinite;}
@keyframes float1{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(26px);}}
@keyframes float2{0%,100%{transform:translateY(0) rotate(0deg);}50%{transform:translateY(-28px) rotate(2deg);}}
@keyframes float3{0%,100%{transform:translateY(0) rotate(0deg);}50%{transform:translateY(24px) rotate(-2deg);}}
@media(prefers-reduced-motion:reduce){.blob{animation:none;}}
body > *:not(.ambient){position:relative;z-index:1;}

/* =================================================================
   NAV
   ================================================================= */
.nav{position:sticky;top:0;z-index:100;background:rgba(5,5,6,0.6);backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);border-bottom:1px solid var(--border);}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:66px;}
.nav__mark img{height:18px;width:auto;}
.nav__links{display:flex;align-items:center;gap:2px;}
.nav__links a{font-size:14px;color:var(--fg-muted);padding:9px 14px;border-radius:8px;transition:color .2s var(--ease),background .2s var(--ease);}
.nav__links a:not(.nav__cta):hover{color:var(--fg);background:var(--surface);}
.nav__cta{color:#fff !important;background:var(--accent);padding:9px 16px;font-weight:500;box-shadow:var(--sh-cta);transition:background .2s,transform .2s var(--ease);}
.nav__cta:hover{background:var(--accent-bright);}
.nav__cta:active{transform:scale(0.98);}
.nav__burger{display:none;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;padding:9px;}
.nav__burger span{display:block;width:20px;height:2px;background:var(--fg);margin:4px 0;border-radius:2px;}
@media(max-width:860px){
  .nav__links{position:fixed;inset:66px 0 auto 0;flex-direction:column;align-items:stretch;gap:4px;background:rgba(5,5,6,0.96);backdrop-filter:blur(18px);border-bottom:1px solid var(--border);padding:14px clamp(20px,5vw,64px) 20px;transform:translateY(-130%);transition:transform .3s var(--ease);}
  .nav__links.open{transform:translateY(0);}
  .nav__links a{padding:14px;font-size:15px;}
  .nav__links .nav__cta{margin-top:8px;text-align:center;}
  .nav__burger{display:block;}
}

/* =================================================================
   REVEAL — transform only (renderer won't repaint opacity transitions)
   ================================================================= */
.rv-on .rv{transform:translateY(20px);transition:transform .6s var(--ease);}
.rv-on .rv.in{transform:none;}
@media(prefers-reduced-motion:reduce){.rv-on .rv{transform:none;transition:none;}}

/* =================================================================
   BUTTONS
   ================================================================= */
.btn{font-family:var(--font);font-weight:500;font-size:15px;padding:13px 22px;display:inline-flex;align-items:center;gap:10px;border-radius:10px;cursor:pointer;border:none;transition:transform .2s var(--ease),background .2s,box-shadow .2s;position:relative;overflow:hidden;}
.btn--primary{background:var(--accent);color:#fff;box-shadow:var(--sh-cta);}
.btn--primary:hover{background:var(--accent-bright);transform:translateY(-2px);}
.btn--primary:active{transform:scale(0.98);}
.btn--secondary{background:var(--surface);color:var(--fg);box-shadow:inset 0 0 0 1px var(--border),inset 0 1px 0 0 rgba(255,255,255,0.06);}
.btn--secondary:hover{background:var(--surface-2);transform:translateY(-2px);}
.btn--secondary:active{transform:scale(0.98);}
.btn .arr{transition:transform .2s var(--ease);}
.btn:hover .arr{transform:translateX(3px);}

.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--fg-subtle);border:1px solid var(--border);background:var(--surface);border-radius:100px;padding:7px 14px;}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);}

/* =================================================================
   HERO — quiet, intelligent
   ================================================================= */
.hero{position:relative;padding:clamp(60px,12vh,150px) 0 clamp(40px,7vh,90px);}
.hero__inner{display:flex;flex-direction:column;align-items:center;text-align:center;}
.hero__title{font-weight:600;letter-spacing:-0.035em;line-height:1.04;margin:clamp(24px,4vw,38px) 0 0;font-size:clamp(34px,5.6vw,72px);max-width:18ch;
  background:linear-gradient(180deg,#fff 0%,rgba(237,237,239,0.96) 46%,rgba(237,237,239,0.62) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero__lede{margin:clamp(20px,3vw,28px) 0 0;max-width:54ch;font-size:clamp(16px,1.4vw,20px);line-height:1.6;color:var(--fg-muted);font-weight:400;}
.hero__cta{display:flex;gap:12px;margin-top:clamp(26px,3.5vw,36px);flex-wrap:wrap;justify-content:center;}

/* hero showcase — browser window + flanking panels, all landscape (no crop) */
.hero__showcase{margin-top:clamp(44px,7vw,84px);width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.4vw,20px);align-items:center;}
@media(max-width:860px){.hero__showcase{grid-template-columns:1fr 1fr;gap:14px;}.hero__showcase .hprev--side.last{display:none;}}
@media(max-width:560px){.hero__showcase{grid-template-columns:1fr;max-width:300px;margin-inline:auto;}.hero__showcase .hprev--side{display:none;}}
.hprev{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--border);background:var(--bg-elev);box-shadow:var(--sh-card);transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s,opacity .4s;}
.hprev::before{content:'';position:absolute;left:0;right:0;top:0;height:1px;z-index:4;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.22),transparent);}
.hprev__shot{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top center;display:block;}
.hprev__grad{position:absolute;left:0;right:0;bottom:0;height:44%;background:linear-gradient(180deg,transparent,rgba(5,5,6,0.78));pointer-events:none;z-index:2;}
.hprev--side{opacity:0.92;}
.hprev--side.first{transform:translateY(12px) rotate(-0.5deg);}
.hprev--side.last{transform:translateY(12px) rotate(0.5deg);}
.hprev--side:hover{opacity:1;transform:translateY(5px);box-shadow:var(--sh-card-hover);border-color:var(--border-hover);}
.hprev--main{border-color:var(--border-hover);box-shadow:var(--sh-card),0 0 100px -12px var(--glow);transform:translateY(-10px);}
.hprev--main:hover{transform:translateY(-16px);box-shadow:var(--sh-card-hover),0 0 120px -10px var(--glow);}
.winbar{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--border);background:rgba(255,255,255,0.025);}
.winbar .d{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,0.16);}
.winbar .url{margin-left:10px;font-family:var(--mono);font-size:10.5px;letter-spacing:0.02em;color:var(--fg-subtle);}
.hprev__tag{position:absolute;left:14px;bottom:13px;z-index:3;font-family:var(--mono);font-size:10px;letter-spacing:0.06em;text-transform:uppercase;color:var(--fg);background:rgba(5,5,6,0.6);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:100px;padding:5px 11px;}
.hprev__tag b{color:var(--accent);font-weight:500;}

/* mouse-tracking spotlight (signature interaction) */
.spot::after{content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:1;opacity:0;transition:opacity .35s var(--ease);
  background:radial-gradient(280px circle at var(--mx,50%) var(--my,50%),var(--glow-soft),transparent 62%);}
.spot:hover::after{opacity:1;}
.spot > *{position:relative;z-index:2;}

/* =================================================================
   MARQUEE (subtle metric ticker)
   ================================================================= */
.ticker{border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;padding:18px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);}
.ticker__track{display:flex;width:max-content;animation:tick 32s linear infinite;}
.ticker__track span{font-family:var(--mono);font-size:13px;letter-spacing:0.04em;text-transform:uppercase;color:var(--fg-muted);white-space:nowrap;padding:0 30px;display:inline-flex;align-items:center;gap:30px;}
.ticker__track span::after{content:'';width:4px;height:4px;border-radius:50%;background:var(--accent);}
.ticker__track b{color:var(--fg);font-weight:600;}
@keyframes tick{to{transform:translateX(-50%);}}
@media(prefers-reduced-motion:reduce){.ticker__track{animation:none;}}

/* =================================================================
   SECTION SCAFFOLD
   ================================================================= */
.section{padding:clamp(64px,11vh,140px) 0;border-top:1px solid var(--border);}
.sec-head{margin-bottom:clamp(40px,6vw,68px);max-width:80ch;}
.sec-num{font-family:var(--mono);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);}
.sec-head h2{font-size:clamp(28px,4.4vw,52px);font-weight:600;letter-spacing:-0.03em;line-height:1.06;margin:16px 0 0;
  background:linear-gradient(180deg,#fff,rgba(237,237,239,0.72));-webkit-background-clip:text;background-clip:text;color:transparent;}
.sec-head h2 em{font-style:normal;color:var(--fg-muted);-webkit-text-fill-color:var(--fg-muted);}
.sec-lead{font-size:clamp(16px,1.35vw,18px);color:var(--fg-muted);margin:18px 0 0;max-width:62ch;line-height:1.6;}

/* =================================================================
   SERVICES — bento
   ================================================================= */
.services{display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(14px,1.5vw,20px);}
@media(max-width:860px){.services{grid-template-columns:repeat(2,1fr);}}
@media(max-width:520px){.services{grid-template-columns:1fr;}}
.svc{grid-column:span 2;position:relative;background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.015));border:1px solid var(--border);border-radius:16px;padding:clamp(24px,2.4vw,32px);box-shadow:var(--sh-card);overflow:hidden;display:flex;flex-direction:column;min-height:210px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;}
.svc::before{content:'';position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent);}
.svc:hover{transform:translateY(-4px);box-shadow:var(--sh-card-hover);border-color:var(--border-hover);}
.svc--hero{grid-column:span 4;}
@media(max-width:860px){.svc,.svc--hero{grid-column:span 1;}}
.svc__num{font-family:var(--mono);font-size:12px;letter-spacing:0.1em;color:var(--accent);}
.svc h3{font-size:clamp(18px,1.6vw,22px);font-weight:600;letter-spacing:-0.02em;margin:16px 0 10px;line-height:1.2;}
.svc p{color:var(--fg-muted);font-size:14.5px;line-height:1.55;margin:0;}
.svc__credit{margin-top:auto;padding-top:18px;font-family:var(--mono);font-size:11.5px;color:var(--fg-subtle);display:flex;justify-content:space-between;gap:10px;border-top:1px solid var(--border);}
.svc__credit .m{color:var(--accent);}

/* =================================================================
   WORK — refined cards (bento-ish)
   ================================================================= */
.posters{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,1.8vw,24px);}
@media(max-width:920px){.posters{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.posters{grid-template-columns:1fr;}}
.poster{display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.015));border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--sh-card);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;}
.poster:hover{transform:translateY(-6px);box-shadow:var(--sh-card-hover);border-color:var(--border-accent);}
.poster__frame{position:relative;aspect-ratio:16/11;overflow:hidden;border-bottom:1px solid var(--border);background:var(--bg-elev);}
.poster__img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .5s var(--ease);filter:saturate(0.95);}
.poster:hover .poster__img{transform:scale(1.04);}
.poster__num{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:11px;color:var(--fg);background:rgba(5,5,6,0.6);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:8px;padding:4px 9px;}
.poster__kind{position:absolute;top:12px;right:12px;font-family:var(--mono);font-size:9.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--accent);background:rgba(5,5,6,0.6);backdrop-filter:blur(8px);border:1px solid var(--border-accent);border-radius:100px;padding:4px 9px;}
.poster__body{padding:clamp(16px,1.6vw,22px);display:flex;flex-direction:column;gap:9px;}
.poster__client{font-family:var(--mono);font-size:11px;letter-spacing:0.03em;color:var(--fg-subtle);text-transform:uppercase;}
.poster__title{font-size:clamp(19px,1.7vw,23px);font-weight:600;letter-spacing:-0.02em;line-height:1.12;}
.poster__title .x{color:var(--fg-muted);font-weight:400;}
.poster__foot{display:flex;justify-content:space-between;align-items:center;margin-top:6px;padding-top:14px;border-top:1px solid var(--border);}
.poster__metric{font-family:var(--mono);font-size:11.5px;color:var(--fg-muted);}
.poster__metric b{color:var(--accent);font-weight:600;}
.poster__arrow{font-size:15px;color:var(--fg-subtle);transition:transform .25s var(--ease),color .25s;}
.poster:hover .poster__arrow{color:var(--accent);transform:translate(3px,-3px);}

/* =================================================================
   VENTURES
   ================================================================= */
.ventures{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,1.5vw,20px);}
@media(max-width:820px){.ventures{grid-template-columns:1fr;}}
.vent{position:relative;background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.015));border:1px solid var(--border);border-radius:18px;padding:clamp(26px,2.8vw,40px);display:flex;flex-direction:column;gap:14px;min-height:270px;box-shadow:var(--sh-card);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;}
.vent::after{content:'';position:absolute;top:-30%;right:-15%;width:55%;height:120%;background:radial-gradient(circle,var(--glow-soft),transparent 64%);pointer-events:none;}
.vent:hover{transform:translateY(-4px);box-shadow:var(--sh-card-hover);border-color:var(--border-accent);}
.vent--wide{grid-column:span 2;flex-direction:row;align-items:center;justify-content:space-between;min-height:0;gap:18px;}
@media(max-width:820px){.vent--wide{grid-column:span 1;flex-direction:column;align-items:flex-start;}}
.vent__eyebrow{position:relative;font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);}
.vent__eyebrow .live{color:var(--fg-subtle);}
.vent h3{position:relative;font-size:clamp(26px,3vw,40px);font-weight:600;letter-spacing:-0.025em;margin:0;line-height:1.04;}
.vent__body{position:relative;color:var(--fg-muted);font-size:15px;line-height:1.55;margin:0;max-width:54ch;}
.vent__stats{position:relative;display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;}
.vent__stat{font-family:var(--mono);font-size:11px;color:var(--fg);border:1px solid var(--border);border-radius:100px;padding:6px 12px;background:var(--surface);}
.vent__cta{position:relative;font-family:var(--mono);font-size:12.5px;text-transform:uppercase;letter-spacing:0.04em;color:var(--fg);display:inline-flex;align-items:center;gap:9px;width:fit-content;border-bottom:1px solid var(--accent);padding-bottom:3px;transition:gap .2s var(--ease);}
.vent__cta:hover{gap:14px;}
.vent--stealth{opacity:0.82;}

/* =================================================================
   TEAM
   ================================================================= */
.team__grid{display:grid;grid-template-columns:300px 1fr;gap:clamp(28px,4vw,64px);align-items:start;}
@media(max-width:860px){.team__grid{grid-template-columns:1fr;}}
.team__portrait{aspect-ratio:4/5;border:1px solid var(--border);border-radius:16px;background:var(--bg-elev);width:100%;overflow:hidden;box-shadow:var(--sh-card);}
.team__portrait img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;}
.team__portrait image-slot{width:100%;height:100%;display:block;}
.team__role{font-family:var(--mono);font-size:12px;letter-spacing:0.04em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;}
.team__name{font-size:clamp(26px,2.6vw,36px);font-weight:600;letter-spacing:-0.025em;margin:0 0 18px;}
.team__intro{font-size:clamp(16px,1.35vw,19px);color:var(--fg-muted);line-height:1.65;margin:0 0 30px;max-width:62ch;}
.team__intro b{color:var(--fg);font-weight:500;}
.tl{border-top:1px solid var(--border);margin-bottom:28px;}
.tl__row{display:grid;grid-template-columns:150px 1fr auto;gap:clamp(12px,2vw,28px);padding:17px 0;border-bottom:1px solid var(--border);font-size:14.5px;align-items:baseline;transition:padding-left .25s var(--ease);}
.tl__row:hover{padding-left:8px;}
.tl__yr{font-family:var(--mono);font-size:12.5px;color:var(--accent);}
.tl__role{font-weight:600;}
.tl__role .w{display:block;font-weight:400;color:var(--fg-muted);font-size:13px;margin-top:3px;}
.tl__note{font-family:var(--mono);font-size:11.5px;color:var(--fg-subtle);text-align:right;}
@media(max-width:640px){.tl__row{grid-template-columns:1fr;gap:4px;}.tl__note{text-align:left;}}
.team__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
@media(max-width:640px){.team__stats{grid-template-columns:repeat(2,1fr);}}
.team__stat{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px 18px;box-shadow:var(--sh-card);}
.team__stat .v{font-size:clamp(22px,2.3vw,30px);font-weight:600;letter-spacing:-0.02em;}
.team__stat .k{font-family:var(--mono);font-size:10.5px;color:var(--fg-muted);margin-top:8px;line-height:1.4;}

/* =================================================================
   CONTACT
   ================================================================= */
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);}
@media(max-width:860px){.contact__grid{grid-template-columns:1fr;}}
.contact h2{font-size:clamp(40px,7vw,92px);font-weight:600;letter-spacing:-0.035em;line-height:0.98;margin:16px 0 0;
  background:linear-gradient(180deg,#fff,rgba(237,237,239,0.68));-webkit-background-clip:text;background-clip:text;color:transparent;}
.contact__meta{font-family:var(--mono);font-size:13.5px;color:var(--fg-muted);line-height:2.1;margin-top:26px;}
.contact__meta a{color:var(--fg);transition:color .2s;}
.contact__meta a:hover{color:var(--accent);}
.contact__status{margin-top:26px;}
.form{display:flex;flex-direction:column;gap:14px;background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.015));border:1px solid var(--border);border-radius:18px;padding:clamp(22px,2.6vw,32px);box-shadow:var(--sh-card);}
.form .lab{font-family:var(--mono);font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--fg-subtle);margin-bottom:8px;display:block;}
.form input,.form textarea,.form select{width:100%;border:1px solid var(--border-hover);background:#0f0f12;border-radius:10px;font-family:var(--font);font-size:15px;color:var(--fg);padding:13px 14px;outline:none;resize:none;transition:border-color .2s,box-shadow .2s;}
.form input::placeholder,.form textarea::placeholder{color:#55565c;}
.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--glow-soft);}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media(max-width:520px){.form .row2{grid-template-columns:1fr;}}
.form button{margin-top:4px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-family:var(--font);font-weight:500;font-size:15px;padding:15px;cursor:pointer;box-shadow:var(--sh-cta);transition:background .2s,transform .2s var(--ease);display:flex;align-items:center;justify-content:center;gap:9px;}
.form button:hover{background:var(--accent-bright);transform:translateY(-2px);}
.form button:active{transform:scale(0.99);}

/* =================================================================
   FOOTER
   ================================================================= */
.footer{background:var(--bg-deep);border-top:1px solid var(--border);padding:clamp(44px,6vw,72px) 0 44px;}
.footer__top{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:flex-start;}
.footer__mark img{height:20px;}
.footer__links{display:flex;gap:22px;flex-wrap:wrap;font-family:var(--mono);font-size:13px;color:var(--fg-muted);}
.footer__links a{transition:color .2s;}
.footer__links a:hover{color:var(--accent);}
.footer__legal{margin-top:clamp(32px,5vw,56px);padding-top:24px;border-top:1px solid var(--border);font-family:var(--mono);font-size:12px;color:var(--fg-subtle);line-height:1.8;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;}

/* =================================================================
   CASE PAGE
   ================================================================= */
.case-hero{position:relative;padding:clamp(36px,6vh,72px) 0 clamp(32px,5vh,56px);}
.case-back{font-family:var(--mono);font-size:13px;color:var(--fg-muted);display:inline-flex;gap:10px;align-items:center;margin-bottom:30px;transition:color .2s,gap .2s var(--ease);}
.case-back:hover{color:var(--accent);gap:14px;}
.case-hero__client{font-family:var(--mono);font-size:12.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--fg-muted);margin-bottom:22px;}
.case-hero__client .k{color:var(--accent);}
.case-hero h1{font-size:clamp(38px,7vw,92px);font-weight:600;letter-spacing:-0.035em;line-height:1.0;margin:0;
  background:linear-gradient(180deg,#fff,rgba(237,237,239,0.66));-webkit-background-clip:text;background-clip:text;color:transparent;}
.case-hero h1 .x{color:var(--fg-muted);-webkit-text-fill-color:var(--fg-muted);}
.case-hero__sub{display:flex;gap:14px;margin-top:clamp(28px,4vw,44px);flex-wrap:wrap;}
.case-hero__sub div{border:1px solid var(--border);background:var(--surface);border-radius:12px;padding:13px 17px;box-shadow:var(--sh-card);}
.case-hero__sub div b{display:block;font-size:clamp(14px,1.2vw,17px);font-weight:600;margin-bottom:5px;}
.case-hero__sub div span{font-family:var(--mono);font-size:10.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--fg-subtle);}
.case-hero__sub a{color:var(--accent);}

.cglance{padding:clamp(36px,5vh,68px) 0;}
.cglance__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
@media(max-width:760px){.cglance__grid{grid-template-columns:repeat(2,1fr);}}
.cgl{border:1px solid var(--border);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.015));padding:clamp(20px,2.4vw,30px);box-shadow:var(--sh-card);transition:transform .25s var(--ease),box-shadow .25s,border-color .25s;}
.cgl:hover{transform:translateY(-3px);box-shadow:var(--sh-card-hover);border-color:var(--border-hover);}
.cgl .v{font-size:clamp(28px,4vw,48px);font-weight:600;letter-spacing:-0.03em;line-height:1;font-variant-numeric:tabular-nums;}
.cgl .k{font-family:var(--mono);font-size:11px;color:var(--fg-muted);margin-top:12px;line-height:1.4;}

.clab{font-family:var(--mono);font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:12px;margin-bottom:clamp(24px,4vh,40px);}
.clab::before{content:'';width:24px;height:1px;background:var(--accent);}
.csec{padding:clamp(40px,6vh,80px) 0;border-top:1px solid var(--border);}

.coverview{display:grid;grid-template-columns:0.32fr 1fr;gap:clamp(20px,4vw,56px);}
@media(max-width:760px){.coverview{grid-template-columns:1fr;}}
.coverview h2{font-family:var(--mono);font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--fg-muted);margin:0;font-weight:400;}
.coverview p{font-size:clamp(16px,1.4vw,20px);line-height:1.65;margin:0 0 18px;color:var(--fg);}
.coverview p b{font-weight:600;color:#fff;}
.coverview p.muted{color:var(--fg-muted);}
.ctags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;}
.ctag{font-family:var(--mono);font-size:11px;border:1px solid var(--border);border-radius:100px;padding:7px 13px;color:var(--fg-muted);background:var(--surface);}
.ctag.nda{color:var(--accent);border-color:var(--border-accent);}

.cmetrics{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
@media(max-width:620px){.cmetrics{grid-template-columns:1fr;}}
.cmetric{border:1px solid var(--border);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.015));padding:clamp(24px,3vw,40px) clamp(18px,2vw,28px);box-shadow:var(--sh-card);}
.cmetric .v{font-size:clamp(32px,5vw,58px);font-weight:600;letter-spacing:-0.03em;line-height:1;}
.cmetric .v .ac{color:var(--accent);}
.cmetric .k{font-family:var(--mono);font-size:12px;color:var(--fg-muted);margin-top:14px;}

.cstack{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
@media(max-width:820px){.cstack{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.cstack{grid-template-columns:1fr;}}
.cst{border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:clamp(15px,1.7vw,22px);display:flex;flex-direction:column;gap:7px;transition:border-color .25s,background .25s;}
.cst:hover{border-color:var(--border-hover);background:var(--surface-2);}
.cst .lay{font-family:var(--mono);font-size:10.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--accent);}
.cst .tech{font-weight:600;font-size:clamp(14px,1.2vw,17px);letter-spacing:-0.01em;}

/* diagram */
.cdf{position:relative;width:100%;height:clamp(360px,46vh,520px);border:1px solid var(--border);border-radius:16px;background:var(--bg-elev);overflow:hidden;box-shadow:var(--sh-card);}
.cdf::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,0.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.035) 1px,transparent 1px);background-size:36px 36px;}
.cdf-svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible;}
.cdf-line{stroke:rgba(255,68,56,0.32);stroke-width:1.4;fill:none;}
.cdf-line.dim{stroke:var(--border-hover);stroke-dasharray:5 6;}
.cdf-node{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;gap:3px;align-items:center;text-align:center;background:rgba(20,20,24,0.92);border:1px solid var(--border-hover);border-radius:10px;padding:11px 15px;min-width:88px;box-shadow:0 8px 24px rgba(0,0,0,0.55);z-index:3;}
.cdf-node .t{font-weight:600;font-size:clamp(12px,1.05vw,15px);letter-spacing:-0.01em;line-height:1.1;white-space:nowrap;}
.cdf-node .s{font-family:var(--mono);font-size:9.5px;color:var(--fg-muted);line-height:1.3;}
.cdf-node.accent{border-color:var(--border-accent);box-shadow:0 0 30px -4px var(--glow);}
.cdf-node.accent .t{color:var(--accent);}
.cdf-node.dim{opacity:0.5;}
.cdf-pk{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);transform:translate(-50%,-50%);z-index:2;}
.cdf-pk.dim{background:var(--fg-subtle);box-shadow:none;}
@media(max-width:600px){.cdf{height:clamp(380px,80vw,460px);}.cdf-node{min-width:0;padding:8px 10px;}.cdf-node .s{display:none;}}

/* steps */
.csteps{display:flex;flex-direction:column;}
.cstep{display:grid;grid-template-columns:70px 1fr;gap:clamp(18px,3vw,52px);padding:clamp(24px,3vw,38px) 0;border-top:1px solid var(--border);}
.cstep:last-child{border-bottom:1px solid var(--border);}
.cstep .n{font-family:var(--mono);font-size:13px;color:var(--accent);}
.cstep h4{font-size:clamp(18px,1.9vw,26px);font-weight:600;letter-spacing:-0.02em;margin:0 0 12px;line-height:1.15;}
.cstep p{color:var(--fg-muted);font-size:clamp(15px,1.1vw,17px);line-height:1.6;max-width:74ch;margin:0;}
.cstep p code{font-family:var(--mono);font-size:0.88em;color:var(--accent);background:var(--glow-soft);padding:2px 6px;border-radius:5px;}
@media(max-width:620px){.cstep{grid-template-columns:1fr;gap:10px;}}

/* pipeline */
.cpipe{display:flex;flex-wrap:wrap;align-items:center;gap:8px;}
.cstage{font-family:var(--mono);font-size:12px;letter-spacing:0.04em;text-transform:uppercase;border:1px solid var(--border);border-radius:100px;padding:10px 16px;display:inline-flex;align-items:center;gap:12px;background:var(--surface);}
.cstage .arr{color:var(--accent);}
.cstage:last-child{border-color:var(--border-accent);color:var(--accent);}

/* cards */
.ccards{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
@media(max-width:760px){.ccards{grid-template-columns:1fr;}}
.ccard{border:1px solid var(--border);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.015));padding:clamp(22px,2.4vw,32px);box-shadow:var(--sh-card);transition:transform .25s var(--ease),box-shadow .25s,border-color .25s;}
.ccard:hover{transform:translateY(-3px);box-shadow:var(--sh-card-hover);border-color:var(--border-hover);}
.ccard.inc{border-left:2px solid var(--accent);}
.ccard h4{font-size:clamp(17px,1.6vw,22px);font-weight:600;letter-spacing:-0.02em;margin:0 0 12px;}
.ccard p{color:var(--fg-muted);font-size:clamp(14px,1.05vw,16px);line-height:1.6;margin:0;}
.ccard p code{font-family:var(--mono);font-size:0.86em;color:var(--accent);background:var(--glow-soft);padding:2px 6px;border-radius:5px;}

/* gallery */
.cgallery{display:grid;grid-template-columns:1fr;gap:clamp(18px,2.4vw,30px);padding:clamp(40px,6vh,80px) 0;}
.cshot{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--bg-elev);box-shadow:var(--sh-card);}
.cshot img{width:100%;display:block;border-bottom:1px solid var(--border);}
.cshot figcaption{font-family:var(--mono);font-size:12px;color:var(--fg-muted);padding:14px 18px;}

/* next */
.cnext{display:flex;align-items:center;justify-content:space-between;gap:20px;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.015));padding:clamp(26px,3vw,44px);flex-wrap:wrap;box-shadow:var(--sh-card);transition:transform .25s var(--ease),box-shadow .25s,border-color .25s;}
.cnext:hover{transform:translateY(-3px);box-shadow:var(--sh-card-hover);border-color:var(--border-accent);}
.cnext__lab{font-family:var(--mono);font-size:12px;letter-spacing:0.08em;text-transform:uppercase;color:var(--fg-muted);}
.cnext__name{font-size:clamp(26px,4vw,48px);font-weight:600;letter-spacing:-0.03em;margin-top:8px;}
.cnext:hover .cnext__name{color:var(--accent);}
.cnext__arrow{font-size:26px;color:var(--fg-subtle);transition:transform .25s var(--ease),color .25s;}
.cnext:hover .cnext__arrow{color:var(--accent);transform:translate(4px,-4px);}

/* case reveal */
.cup-on .cup{transform:translateY(18px);transition:transform .6s var(--ease);}
.cup-on .cup.in{transform:none;}
@media(prefers-reduced-motion:reduce){.cup-on .cup{transform:none;}}
