/* ============================================================
   MIKROMATION — dark cinematic agency site
   Design system
   ============================================================ */

:root{
  /* base — cool near-black */
  --bg:        #07080b;
  --bg-1:      #0a0c11;
  --bg-2:      #0e1118;
  --bg-3:      #141823;
  --panel:     #0c0f16;
  --line:      rgba(255,255,255,.08);
  --line-2:    rgba(255,255,255,.14);

  /* text */
  --text:      #eef1f6;
  --dim:       #9aa3b3;
  --mute:      #626b7c;

  /* brand accent — pulled from the logo */
  --cyan:      #2ad4f0;
  --blue:      #2f6bff;
  --accent:    #2ad4f0;
  --grad:      linear-gradient(100deg, #2ad4f0 0%, #2f6bff 100%);
  --grad-soft: linear-gradient(100deg, rgba(42,212,240,.16), rgba(47,107,255,.16));
  --glow:      0 0 0 1px rgba(42,212,240,.35), 0 0 40px -8px rgba(42,212,240,.5);

  /* type */
  --display: "Space Grotesk", system-ui, sans-serif;
  --body:    "Sora", system-ui, sans-serif;
  --mono:    "Space Mono", ui-monospace, monospace;

  /* layout */
  --maxw: 1280px;
  --pad:  clamp(20px, 5vw, 80px);
  --r:    16px;
  --r-lg: 26px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body.noscroll{ overflow:hidden; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
::selection{ background:rgba(42,212,240,.3); color:#fff; }

/* page grain / vignette overlay */
.grain{
  position:fixed; inset:0; pointer-events:none; z-index:1; opacity:.55;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(47,107,255,.10), transparent 60%),
    radial-gradient(100% 60% at 100% 110%, rgba(42,212,240,.06), transparent 60%);
  mix-blend-mode:screen;
}

/* ---------- TORCH CURSOR ---------- */
:root{ --tx:-400px; --ty:-400px; }
/* veil: shadows the page everywhere except a clear pool around the cursor */
.torch-veil{
  position:fixed; inset:0; z-index:78; pointer-events:none; opacity:0;
  transition:opacity .5s ease;
  background:radial-gradient(circle at var(--tx) var(--ty),
    transparent 0,
    transparent 150px,
    rgba(3,5,9,.30) 360px,
    rgba(2,3,7,.62) 720px);
}
/* beam: warm cyan light cast by the torch, screen-blended so it lifts content */
.torch-beam{
  position:fixed; inset:0; z-index:79; pointer-events:none; opacity:0;
  transition:opacity .5s ease; mix-blend-mode:screen;
  background:radial-gradient(circle at var(--tx) var(--ty),
    rgba(180,240,255,.16) 0,
    rgba(42,212,240,.13) 90px,
    rgba(47,107,255,.06) 240px,
    transparent 400px);
}
.torch-on .torch-veil, .torch-on .torch-beam{ opacity:1; }
@media (prefers-reduced-motion: reduce){
  .torch-veil, .torch-beam{ transition:none; }
}

/* ---------- shared layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }
section{ position:relative; z-index:2; }
.eyebrow{
  font-family:var(--mono); font-size:12.5px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--cyan); display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--cyan); opacity:.7; }
.eyebrow.center{ justify-content:center; }

h1,h2,h3,h4{ font-family:var(--display); font-weight:700; line-height:1.02; letter-spacing:-.02em; }
h2.section-title{
  font-size:clamp(32px, 5vw, 60px); margin-top:18px; max-width:16ch; text-wrap:balance;
}
.section-head{ margin-bottom:clamp(40px,6vw,72px); }
.section-head.center{ text-align:center; }
.section-head.center h2{ margin-inline:auto; }
.lead{ color:var(--dim); font-size:clamp(16px,1.4vw,19px); max-width:52ch; margin-top:20px; }
.lead.center{ margin-inline:auto; }
.index{ font-family:var(--mono); font-size:13px; color:var(--mute); }

.grad-text{
  background:var(--grad); -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}

/* ---------- buttons ---------- */
.btn{
  --bg:transparent;
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--body); font-weight:600; font-size:15px; letter-spacing:-.01em;
  padding:14px 24px; border-radius:100px; cursor:pointer; border:1px solid var(--line-2);
  background:var(--bg); color:var(--text); position:relative;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), background .25s, border-color .25s, box-shadow .25s;
  will-change:transform;
}
.btn:hover{ transform:translateY(-2px); }
.btn .arr{ transition:transform .3s cubic-bezier(.2,.8,.2,1); }
.btn:hover .arr{ transform:translateX(4px); }
.btn-primary{
  background:var(--grad); color:#04121a; border-color:transparent; font-weight:700;
  box-shadow:0 10px 30px -10px rgba(42,212,240,.6);
}
.btn-primary:hover{ box-shadow:0 16px 40px -10px rgba(42,212,240,.8); }
.btn-ghost:hover{ border-color:var(--cyan); background:rgba(42,212,240,.06); }
.btn-lg{ padding:17px 30px; font-size:16px; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--pad);
  transition:padding .3s, background .3s, border-color .3s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  padding-block:12px;
  background:rgba(7,8,11,.72); backdrop-filter:blur(18px) saturate(1.4);
  border-bottom:1px solid var(--line);
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:34px; width:auto; }
.brand .wm{ font-family:var(--display); font-weight:700; font-size:19px; letter-spacing:.01em; }
.brand .wm b{ font-weight:700; }
.nav-links{ display:flex; gap:6px; align-items:center; }
.nav-links a{
  font-size:14.5px; color:var(--dim); padding:9px 14px; border-radius:100px;
  transition:color .2s, background .2s; position:relative;
}
.nav-links a:hover{ color:var(--text); background:rgba(255,255,255,.05); }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-burger{ display:none; }

.mobile-drawer{
  position:fixed; inset:0; z-index:55; background:rgba(7,8,11,.96); backdrop-filter:blur(20px);
  display:flex; flex-direction:column; gap:6px; align-items:flex-start; justify-content:center;
  padding:0 var(--pad); transform:translateY(-100%); transition:transform .45s cubic-bezier(.2,.8,.2,1);
}
.mobile-drawer.open{ transform:none; }
.mobile-drawer a{ font-family:var(--display); font-weight:700; font-size:34px; letter-spacing:-.02em; color:var(--text); padding:10px 0; }
.mobile-drawer a.btn{ margin-top:24px; font-size:16px; }

@media (max-width:960px){
  .nav-links{ display:none; }
  .nav-cta .btn-ghost{ display:none; }
  .nav-burger{ display:grid; place-items:center; width:44px; height:44px; border-radius:50%; border:1px solid var(--line-2); background:transparent; color:var(--text); cursor:pointer; }
}
@media (min-width:961px){ .mobile-drawer{ display:none; } }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  padding-top:120px; padding-bottom:80px; overflow:hidden;
}
#hero-canvas{ position:absolute; inset:0; z-index:0; width:100%; height:100%; }
.hero::after{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(80% 60% at 50% 40%, transparent 30%, var(--bg) 88%),
    linear-gradient(to bottom, transparent 60%, var(--bg) 98%);
}
.hero .wrap{ position:relative; z-index:2; }
.hero-tag{
  display:inline-flex; align-items:center; gap:10px; padding:8px 16px; border-radius:100px;
  border:1px solid var(--line-2); background:rgba(255,255,255,.03);
  font-size:13px; color:var(--dim); margin-bottom:30px;
}
.hero-tag .dot{ width:7px; height:7px; border-radius:50%; background:#37e08a; box-shadow:0 0 10px #37e08a; }
.hero h1{
  font-size:clamp(44px, 8.2vw, 112px); line-height:.96; letter-spacing:-.035em; max-width:15ch;
}
.hero h1 .rot{ display:inline-grid; }
.hero h1 .rot span{ grid-area:1/1; }
.hero p.sub{ color:var(--dim); font-size:clamp(17px,1.7vw,22px); max-width:56ch; margin-top:30px; }
.hero-actions{ display:flex; gap:14px; margin-top:42px; flex-wrap:wrap; }
.hero-meta{
  margin-top:64px; display:flex; gap:clamp(24px,5vw,64px); flex-wrap:wrap; align-items:center;
}
.hero-stat .n{ font-family:var(--display); font-size:clamp(26px,3vw,40px); font-weight:700; letter-spacing:-.02em; }
.hero-stat .l{ font-family:var(--mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--mute); margin-top:4px; }
.hero-sep{ width:1px; align-self:stretch; background:var(--line); }
.scroll-cue{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:3;
  font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--mute);
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.scroll-cue .bar{ width:1px; height:46px; background:linear-gradient(var(--cyan), transparent); }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  border-block:1px solid var(--line); padding:26px 0; overflow:hidden;
  display:flex; gap:0; background:var(--bg-1); position:relative; z-index:2;
}
.marquee-track{ display:flex; gap:56px; white-space:nowrap; animation:marq 32s linear infinite; padding-right:56px; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee .item{ font-family:var(--display); font-weight:700; font-size:clamp(22px,2.6vw,34px); color:var(--mute); display:flex; align-items:center; gap:56px; letter-spacing:-.02em; }
.marquee .item::after{ content:"✦"; color:var(--cyan); font-size:.55em; }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ============================================================
   SERVICES
   ============================================================ */
.services{ padding:clamp(90px,11vw,150px) 0; }
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.svc{
  position:relative; padding:34px 30px 30px; border-radius:var(--r-lg);
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--line); overflow:hidden;
  transition:transform .4s cubic-bezier(.2,.8,.2,1), border-color .4s, background .4s;
}
.svc::before{
  content:""; position:absolute; inset:0; opacity:0; transition:opacity .4s;
  background:radial-gradient(120% 120% at 0% 0%, rgba(42,212,240,.10), transparent 55%);
}
.svc:hover{ transform:translateY(-6px); border-color:var(--line-2); }
.svc:hover::before{ opacity:1; }
.svc .num{ font-family:var(--mono); font-size:12px; color:var(--mute); letter-spacing:.1em; }
.svc .ico{
  width:52px; height:52px; border-radius:14px; margin:18px 0 22px;
  display:grid; place-items:center; background:var(--grad-soft); border:1px solid var(--line-2);
  color:var(--cyan);
}
.svc .ico svg{ width:26px; height:26px; }
.svc h3{ font-size:22px; letter-spacing:-.02em; }
.svc p{ color:var(--dim); font-size:15px; margin-top:12px; }
.svc .tags{ display:flex; flex-wrap:wrap; gap:7px; margin-top:20px; }
.svc .tags span{ font-family:var(--mono); font-size:11px; color:var(--dim); padding:5px 11px; border-radius:100px; border:1px solid var(--line); }

/* ============================================================
   PROCESS
   ============================================================ */
.process{ padding:clamp(90px,11vw,150px) 0; background:var(--bg-1); border-block:1px solid var(--line); }
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; margin-top:20px; }
.step{ padding:34px 26px 30px; border-left:1px solid var(--line); position:relative; }
.step:first-child{ border-left:none; }
.step .sn{
  font-family:var(--display); font-weight:700; font-size:15px; width:40px; height:40px; border-radius:50%;
  display:grid; place-items:center; border:1px solid var(--line-2); color:var(--cyan); margin-bottom:26px;
}
.step h3{ font-size:21px; }
.step p{ color:var(--dim); font-size:14.5px; margin-top:12px; }
.step .line{ position:absolute; top:54px; left:60px; right:0; height:1px; background:linear-gradient(90deg,var(--line-2),transparent); }
.step:last-child .line{ display:none; }

/* ============================================================
   WORK / CASE STUDIES
   ============================================================ */
.work{ padding:clamp(90px,11vw,150px) 0; }
.work-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.case{
  border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line);
  background:var(--bg-2); position:relative; transition:transform .45s cubic-bezier(.2,.8,.2,1), border-color .45s;
}
.case:hover{ transform:translateY(-6px); border-color:var(--line-2); }
.case .media{ position:relative; aspect-ratio:16/10; overflow:hidden; background:var(--bg-3); }
.case .media image-slot{ width:100%; height:100%; display:block; }
.case .media img{ width:100%; height:100%; object-fit:cover; display:block; }
.case.wide .media img{ min-height:360px; }
.case .media .badge{
  position:absolute; top:16px; left:16px; z-index:3; font-family:var(--mono); font-size:11px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--text);
  padding:7px 13px; border-radius:100px; background:rgba(7,8,11,.6); backdrop-filter:blur(8px);
  border:1px solid var(--line-2);
}
.case .body{ padding:26px 28px 30px; }
.case .body h3{ font-size:25px; }
.case .body p{ color:var(--dim); font-size:15px; margin-top:10px; }
.case .res{ display:flex; gap:30px; margin-top:22px; padding-top:22px; border-top:1px solid var(--line); }
.case .res .n{ font-family:var(--display); font-weight:700; font-size:26px; }
.case .res .n b{ color:var(--cyan); font-weight:700; }
.case .res .l{ font-size:12.5px; color:var(--mute); margin-top:2px; }
.case.wide{ grid-column:1 / -1; }
.case.wide{ display:grid; grid-template-columns:1.1fr .9fr; }
.case.wide .media{ aspect-ratio:auto; }
@media (max-width:760px){ .case.wide{ grid-template-columns:1fr; } }

/* ============================================================
   STATS BAND
   ============================================================ */
.band{ padding:clamp(60px,8vw,100px) 0; background:var(--bg-1); border-block:1px solid var(--line); }
.band-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
.band .n{ font-family:var(--display); font-weight:700; font-size:clamp(40px,6vw,72px); letter-spacing:-.03em; }
.band .l{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--mute); margin-top:8px; }

/* ============================================================
   PRICING
   ============================================================ */
.pricing{ padding:clamp(90px,11vw,150px) 0; }
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; align-items:start; }
.tier{
  padding:36px 32px; border-radius:var(--r-lg); border:1px solid var(--line);
  background:var(--bg-2); position:relative; transition:transform .4s, border-color .4s;
}
.tier:hover{ transform:translateY(-5px); }
.tier.featured{ border-color:transparent; background:linear-gradient(180deg, rgba(42,212,240,.08), var(--bg-2)); box-shadow:0 30px 80px -40px rgba(42,212,240,.6); }
.tier.featured::before{ content:""; position:absolute; inset:0; border-radius:var(--r-lg); padding:1px; background:var(--grad); -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none; }
.tier .pill{ position:absolute; top:-12px; left:32px; font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; padding:6px 14px; border-radius:100px; background:var(--grad); color:#04121a; font-weight:700; }
.tier h3{ font-size:21px; }
.tier .price{ font-family:var(--display); font-weight:700; font-size:46px; letter-spacing:-.03em; margin:18px 0 4px; }
.tier .price small{ font-family:var(--body); font-size:15px; color:var(--mute); font-weight:400; letter-spacing:0; }
.tier .desc{ color:var(--dim); font-size:14.5px; min-height:42px; }
.tier ul{ list-style:none; margin:24px 0 28px; display:flex; flex-direction:column; gap:13px; }
.tier li{ display:flex; gap:12px; font-size:14.5px; color:var(--text); align-items:flex-start; }
.tier li svg{ flex:none; width:18px; height:18px; color:var(--cyan); margin-top:2px; }
.tier li.off{ color:var(--mute); }
.tier li.off svg{ color:var(--mute); }
.tier .btn{ width:100%; justify-content:center; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi{ padding:clamp(90px,11vw,150px) 0; background:var(--bg-1); border-block:1px solid var(--line); }
.testi-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.quote{
  padding:32px 30px; border-radius:var(--r-lg); border:1px solid var(--line); background:var(--bg-2);
  display:flex; flex-direction:column; gap:22px;
}
.quote .stars{ color:var(--cyan); letter-spacing:3px; font-size:14px; }
.quote p{ font-size:17px; line-height:1.55; color:var(--text); }
.quote .who{ display:flex; align-items:center; gap:13px; margin-top:auto; }
.quote .who image-slot{ width:46px; height:46px; flex:none; }
.quote .who img.av{ width:46px; height:46px; border-radius:50%; object-fit:cover; flex:none; background:#0e1118; display:block; }
.quote .who .nm{ font-weight:600; font-size:14.5px; }
.quote .who .rl{ font-size:12.5px; color:var(--mute); }
.logos{ margin-top:54px; padding-top:46px; border-top:1px solid var(--line); }
.logos .lab{ text-align:center; font-family:var(--mono); font-size:11.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--mute); margin-bottom:30px; }
.logo-row{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:clamp(28px,5vw,64px); }
.logo-row span{ font-family:var(--display); font-weight:700; font-size:clamp(18px,2vw,26px); color:var(--mute); letter-spacing:-.02em; opacity:.7; transition:opacity .3s, color .3s; }
.logo-row span:hover{ opacity:1; color:var(--text); }

/* ============================================================
   ABOUT / TEAM
   ============================================================ */
.about{ padding:clamp(90px,11vw,150px) 0; }
.about-top{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:end; margin-bottom:60px; }
.about-top p.big{ font-family:var(--display); font-weight:500; font-size:clamp(22px,2.6vw,32px); line-height:1.25; letter-spacing:-.02em; text-wrap:balance; }
.about-top p.big b{ color:var(--cyan); font-weight:500; }
.creed{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:54px; }
.creed .col{ padding:30px 32px; border-radius:var(--r-lg); border:1px solid var(--line); background:var(--bg-2); }
.creed .col h4{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--mute); margin-bottom:20px; font-weight:400; }
.creed .col.are h4{ color:var(--cyan); }
.creed ul{ list-style:none; display:flex; flex-direction:column; gap:13px; }
.creed li{ display:flex; gap:12px; align-items:center; font-size:15.5px; }
.creed li svg{ width:18px; height:18px; flex:none; }
.creed .are li svg{ color:var(--cyan); }
.creed .not li{ color:var(--dim); }
.creed .not li svg{ color:var(--mute); }
.team{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.member{ }
.member image-slot{ width:100%; aspect-ratio:4/5; }
.member img.ph{ width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:18px; background:linear-gradient(135deg,#0e1118,#0a0e16); display:block; }
.member .nm{ font-weight:600; font-size:16px; margin-top:16px; }
.member .rl{ font-family:var(--mono); font-size:12px; color:var(--cyan); margin-top:3px; letter-spacing:.04em; }

/* ============================================================
   BLOG
   ============================================================ */
.blog{ padding:clamp(90px,11vw,150px) 0; background:var(--bg-1); border-block:1px solid var(--line); }
.posts{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.post{ border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); background:var(--bg-2); transition:transform .4s, border-color .4s; }
.post:hover{ transform:translateY(-5px); border-color:var(--line-2); }
.post image-slot{ width:100%; aspect-ratio:16/10; }
.post img.cover{ width:100%; aspect-ratio:16/10; object-fit:cover; background:linear-gradient(135deg,#0e1118,#0a0e16); display:block; }
.post .body{ padding:24px 26px 28px; }
.post .meta{ display:flex; gap:14px; font-family:var(--mono); font-size:11.5px; color:var(--mute); letter-spacing:.06em; text-transform:uppercase; }
.post .meta .cat{ color:var(--cyan); }
.post h3{ font-size:20px; margin-top:14px; letter-spacing:-.01em; }
.post .rd{ display:inline-flex; align-items:center; gap:8px; margin-top:18px; font-size:14px; color:var(--dim); }
.post:hover .rd{ color:var(--cyan); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ padding:clamp(90px,11vw,160px) 0; position:relative; overflow:hidden; }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,7vw,90px); align-items:start; }
.contact h2{ font-size:clamp(36px,6vw,72px); letter-spacing:-.035em; line-height:.98; }
.contact .lead{ margin-top:24px; }
.contact-info{ margin-top:44px; display:flex; flex-direction:column; gap:22px; }
.contact-info .row{ display:flex; gap:16px; align-items:center; }
.contact-info .ic{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; border:1px solid var(--line-2); color:var(--cyan); background:var(--grad-soft); flex:none; }
.contact-info .k{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--mute); }
.contact-info .v{ font-size:16px; }

.form{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(28px,4vw,42px); }
.field{ margin-bottom:22px; position:relative; }
.field label{ display:block; font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--dim); margin-bottom:10px; }
.field label .req{ color:var(--cyan); }
.field input, .field textarea, .field select{
  width:100%; background:var(--bg); border:1px solid var(--line-2); border-radius:12px;
  padding:15px 16px; color:var(--text); font-family:var(--body); font-size:16px; resize:none;
  transition:border-color .25s, box-shadow .25s, background .25s;
}
.field textarea{ min-height:140px; }
.field select{
  appearance:none; -webkit-appearance:none; -moz-appearance:none; cursor:pointer;
  padding-right:44px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23626b7c' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 16px center; background-size:16px;
}
.field select:invalid{ color:var(--mute); }
.field input::placeholder, .field textarea::placeholder{ color:var(--mute); }
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--cyan); box-shadow:0 0 0 3px rgba(42,212,240,.14); background:var(--bg-1); }
.field.err input, .field.err textarea, .field.err select{ border-color:#ff5a6e; box-shadow:0 0 0 3px rgba(255,90,110,.14); }
.field .msg{ font-size:12.5px; color:#ff8a96; margin-top:7px; display:none; }
.field.err .msg{ display:block; }
.form .submit{ width:100%; justify-content:center; margin-top:6px; position:relative; overflow:hidden; }
.form .submit.sending{ pointer-events:none; }
.form-note{ font-size:12.5px; color:var(--mute); text-align:center; margin-top:16px; }
.form-error{ display:none; font-size:12.5px; color:#ff8a96; text-align:center; margin-top:14px; }
.form-error.show{ display:block; }
.form-success{
  display:none; text-align:center; padding:30px 10px;
}
.form-success.show{ display:block; animation:pop .5s cubic-bezier(.2,1.2,.3,1) both; }
.form-success .ok{ width:64px; height:64px; border-radius:50%; margin:0 auto 22px; display:grid; place-items:center; background:var(--grad); color:#04121a; }
.form-success h3{ font-size:26px; }
.form-success p{ color:var(--dim); margin-top:10px; }
@keyframes pop{ from{ opacity:0; transform:scale(.9);} to{ opacity:1; transform:scale(1);} }

/* paper plane fly */
.plane{ position:absolute; inset:0; display:grid; place-items:center; pointer-events:none; }
.plane svg{ width:26px; height:26px; opacity:0; }
.submit.sending .label{ opacity:0; }
.submit.sending .plane svg{ animation:fly .7s cubic-bezier(.45,0,.2,1) forwards; opacity:1; }
@keyframes fly{ 0%{ transform:translate(-40px,12px) rotate(-8deg); opacity:0;} 30%{opacity:1;} 100%{ transform:translate(220px,-80px) rotate(8deg); opacity:0;} }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ padding:80px 0 40px; border-top:1px solid var(--line); background:var(--bg-1); }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:60px; border-bottom:1px solid var(--line); }
.footer .brand img{ height:38px; }
.footer .fcol h4{ font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--mute); font-weight:400; margin-bottom:18px; }
.footer .fcol a{ display:block; color:var(--dim); font-size:14.5px; padding:6px 0; transition:color .2s; }
.footer .fcol a:hover{ color:var(--cyan); }
.footer p.tag{ color:var(--dim); font-size:14.5px; margin-top:18px; max-width:32ch; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:30px; flex-wrap:wrap; gap:16px; }
.footer-bottom p{ font-size:13px; color:var(--mute); }
.footer-social{ display:flex; gap:10px; }
.footer-social a{ width:38px; height:38px; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; color:var(--dim); transition:all .25s; }
.footer-social a:hover{ border-color:var(--cyan); color:var(--cyan); transform:translateY(-2px); }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  [data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1); }
  [data-reveal].in{ opacity:1; transform:none; }
  [data-reveal-stagger]>*{ opacity:0; transform:translateY(28px); transition:opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1); }
  [data-reveal-stagger].in>*{ opacity:1; transform:none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .svc-grid, .tiers, .testi-grid, .posts{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .step{ border-left:none; border-top:1px solid var(--line); }
  .step .line{ display:none; }
  .team{ grid-template-columns:repeat(2,1fr); }
  .band-grid{ grid-template-columns:repeat(2,1fr); gap:40px 24px; }
  .creed{ grid-template-columns:1fr; }
}
@media (max-width:760px){
  .svc-grid, .tiers, .testi-grid, .posts, .work-grid, .about-top, .contact-grid, .footer-top{ grid-template-columns:1fr; }
  .footer-top{ gap:34px; }
  .hero-sep{ display:none; }
}
