/* ============================================================
   Vertex Devs — Digital product studio
   Design tokens, layout, components, motion
   ============================================================ */

:root{
  --bg:        #08080a;
  --bg-2:      #0e0e11;
  --surface:   #131318;
  --surface-2: #1a1a21;
  --line:      rgba(255,255,255,.10);
  --line-2:    rgba(255,255,255,.06);
  --ink:       #f4f4f2;
  --ink-dim:   #a3a3ad;
  --ink-faint: #6c6c78;

  --accent:    #d6ff3f;   /* electric lime */
  --accent-2:  #9b5cff;   /* violet */
  --accent-3:  #3fd0ff;   /* cyan */
  --accent-4:  #ff7a59;   /* coral */

  --font-display: 'Space Grotesk', system-ui, sans-serif;
  --font-body:    'Inter', system-ui, sans-serif;

  --container: 1320px;
  --pad: clamp(20px, 5vw, 80px);

  --r-sm: 12px;
  --r-md: 20px;
  --r-lg: 28px;

  --ease: cubic-bezier(.22,1,.36,1);
  --ease-2: cubic-bezier(.65,.05,.36,1);
}

/* ---------- Reset ---------- */
*{ margin:0; padding:0; box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-stopped{ overflow:hidden; }

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body.is-loading{ overflow:hidden; height:100vh; }

a{ color:inherit; text-decoration:none; }
ul,ol{ list-style:none; }
img,svg{ display:block; max-width:100%; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
input,textarea,select{ font:inherit; color:inherit; }
::selection{ background:var(--accent); color:#000; }

/* ---------- Layout ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--pad);
}

.tag{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--font-display);
  font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-dim); font-weight:500;
}
.tag i{ width:7px; height:7px; border-radius:50%; background:var(--accent); }

.section-head{ max-width:760px; margin-bottom:clamp(40px,6vw,80px); }
.section-head__tag{ display:block; margin-bottom:1.2rem; }
.section-head__title{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(2rem, 5.2vw, 4.2rem);
  line-height:1.02; letter-spacing:-.02em;
}
.section-head__note{ margin-top:1.2rem; color:var(--ink-dim); max-width:46ch; font-size:1.05rem; }

/* ============================================================
   Custom cursor
   ============================================================ */
.cursor{ position:fixed; inset:0; pointer-events:none; z-index:9999; mix-blend-mode:difference; }
.cursor__dot,.cursor__ring{
  position:absolute; top:0; left:0; border-radius:50%;
  transform:translate(-50%,-50%);
}
.cursor__dot{ width:7px; height:7px; background:#fff; }
.cursor__ring{
  width:38px; height:38px; border:1.5px solid #fff;
  transition:width .3s var(--ease), height .3s var(--ease), opacity .3s, background .3s;
}
.cursor.is-hover .cursor__ring{ width:64px; height:64px; background:rgba(255,255,255,.12); }
.cursor.is-hide .cursor__ring{ opacity:0; }
.cursor.is-down .cursor__ring{ width:26px; height:26px; }
@media (hover:none),(pointer:coarse){ .cursor{ display:none; } }

/* ============================================================
   Loader
   ============================================================ */
.loader{
  position:fixed; inset:0; z-index:10000; background:var(--bg);
  display:grid; place-items:center;
}
.loader__inner{
  display:flex; align-items:baseline; gap:.4em;
  font-family:var(--font-display); font-weight:600;
}
.loader__mark{ font-size:clamp(3rem,12vw,7rem); color:var(--accent); }
.loader__count{ font-size:clamp(1rem,4vw,2rem); color:var(--ink-dim); font-variant-numeric:tabular-nums; }
.loader.is-done{ transform:translateY(-101%); transition:transform .9s var(--ease); }

/* ============================================================
   Navigation
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:900;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px var(--pad);
  transition:transform .5s var(--ease), background .4s, padding .4s, backdrop-filter .4s;
}
.nav.is-hidden{ transform:translateY(-110%); }
.nav.is-scrolled{
  background:rgba(8,8,10,.72);
  backdrop-filter:blur(14px);
  padding-top:14px; padding-bottom:14px;
  border-bottom:1px solid var(--line-2);
}

.nav__logo{ display:flex; align-items:center; gap:.55rem; font-family:var(--font-display); font-weight:600; font-size:1.25rem; }
.nav__logo-mark path{ fill:none; stroke:var(--accent); stroke-width:6; stroke-linecap:round; stroke-linejoin:round; }
.nav__logo-reg{ font-size:.7rem; color:var(--accent); transform:translateY(-.4em); }
.nav__logo-word{ letter-spacing:-.01em; }

.nav__links{ display:flex; gap:.4rem; }
.nav__link{
  position:relative; padding:.5rem 1rem; border-radius:100px;
  font-size:.95rem; color:var(--ink-dim); overflow:hidden;
  transition:color .3s;
}
.nav__link span{ position:relative; z-index:1; }
.nav__link::before{
  content:""; position:absolute; inset:0; background:var(--surface-2);
  border-radius:100px; transform:scale(.6); opacity:0;
  transition:transform .4s var(--ease), opacity .4s;
}
.nav__link:hover{ color:var(--ink); }
.nav__link:hover::before{ transform:scale(1); opacity:1; }

.nav__burger{ display:none; flex-direction:column; gap:6px; width:30px; }
.nav__burger span{ height:2px; background:var(--ink); border-radius:2px; transition:transform .4s var(--ease), opacity .3s; }
.nav.menu-open .nav__burger span:nth-child(1){ transform:translateY(4px) rotate(45deg); }
.nav.menu-open .nav__burger span:nth-child(2){ transform:translateY(-4px) rotate(-45deg); }

/* ---------- Buttons ---------- */
.btn{
  position:relative; display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--font-display); font-weight:500; font-size:.98rem;
  padding:.95rem 1.6rem; border-radius:100px;
  transition:transform .3s var(--ease), background .3s, color .3s, border-color .3s;
  will-change:transform;
}
.btn__label{ position:relative; z-index:1; }
.btn__arrow{ width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; transition:transform .3s var(--ease); }
.btn:hover .btn__arrow{ transform:translateX(4px); }

.btn--solid{ background:var(--accent); color:#0a0a0a; }
.btn--solid:hover{ background:#e9ff7a; }
.btn--ghost{ border:1px solid var(--line); color:var(--ink); }
.btn--ghost:hover{ border-color:var(--ink); background:rgba(255,255,255,.04); }
.btn--block{ width:100%; justify-content:center; margin-top:.5rem; }

.btn--pill{ background:var(--surface-2); border:1px solid var(--line); padding-right:1.1rem; }
.btn--pill .btn__dot{ width:9px; height:9px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 0 var(--accent); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(214,255,63,.5);} 70%{box-shadow:0 0 0 9px rgba(214,255,63,0);} 100%{box-shadow:0 0 0 0 rgba(214,255,63,0);} }
.btn--pill:hover{ background:var(--surface); }

/* ============================================================
   Mobile menu
   ============================================================ */
.menu{
  position:fixed; inset:0; z-index:850; background:var(--bg-2);
  display:flex; flex-direction:column; justify-content:center;
  padding:var(--pad);
  clip-path:circle(0% at calc(100% - 40px) 40px);
  transition:clip-path .7s var(--ease);
  pointer-events:none;
}
.menu.is-open{ clip-path:circle(150% at calc(100% - 40px) 40px); pointer-events:auto; }
.menu__inner{ display:flex; flex-direction:column; gap:.4rem; }
.menu__link{
  font-family:var(--font-display); font-weight:600;
  font-size:clamp(2.4rem,11vw,4.5rem); line-height:1.1; letter-spacing:-.02em;
  display:flex; align-items:baseline; gap:1rem;
  transition:color .3s, padding-left .4s var(--ease);
}
.menu__link em{ font-size:.9rem; font-style:normal; color:var(--ink-faint); font-weight:400; }
.menu__link:hover{ color:var(--accent); padding-left:.6rem; }
.menu__foot{ margin-top:3rem; display:flex; flex-direction:column; gap:.4rem; color:var(--ink-dim); }

/* ============================================================
   Hero
   ============================================================ */
.hero{
  position:relative; min-height:100svh; padding-top:140px; padding-bottom:48px;
  display:flex; flex-direction:column; justify-content:space-between;
  overflow:hidden;
}
.hero__bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero__blob{
  position:absolute; width:120vmax; height:120vmax;
  top:-30vmax; left:50%; transform:translateX(-50%);
  filter:blur(20px); opacity:.9; animation:blobFloat 18s var(--ease) infinite alternate;
}
@keyframes blobFloat{ 0%{transform:translateX(-55%) scale(1);} 100%{transform:translateX(-45%) scale(1.15);} }
.hero__grid{
  position:absolute; inset:0;
  background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 72%);
          mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 72%);
}
.hero>*{ position:relative; z-index:1; }

.hero__eyebrow{ font-size:.78rem; }

.hero__title{
  font-family:var(--font-display); font-weight:600;
  font-size:clamp(3rem, 12.5vw, 11rem);
  line-height:.92; letter-spacing:-.035em;
  margin:auto 0;
}
.hero__title .line{ display:block; overflow:hidden; padding-bottom:.04em; }
.hero__title .word{ display:inline-block; }
.word--accent{ color:var(--accent); position:relative; }
.hero__squiggle{
  position:absolute; left:0; bottom:-.18em; width:.95em; height:.3em; overflow:visible;
}
.hero__squiggle path{ fill:none; stroke:var(--accent); stroke-width:6; stroke-linecap:round; stroke-dasharray:400; stroke-dashoffset:400; }
.hero.in-view .hero__squiggle path{ animation:draw 1.1s var(--ease) 1.1s forwards; }
@keyframes draw{ to{ stroke-dashoffset:0; } }

.hero__bottom{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:2rem; }
.hero__sub{ max-width:42ch; color:var(--ink-dim); font-size:clamp(1rem,1.5vw,1.2rem); }
.hero__actions{ display:flex; gap:.8rem; flex-wrap:wrap; }

.hero__trust{ margin-top:2.4rem; display:flex; flex-wrap:wrap; align-items:center; gap:1.4rem; }
.hero__trust-label{ font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); }
.hero__trust-logos{ display:flex; flex-wrap:wrap; align-items:center; gap:.8rem; font-family:var(--font-display); color:var(--ink-dim); font-size:.95rem; }
.hero__trust-logos i{ color:var(--ink-faint); }

.hero__scroll{
  position:absolute; right:var(--pad); bottom:40px; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.5rem;
  font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-dim);
}
.hero__scroll svg{ width:18px; height:18px; fill:none; stroke:var(--accent); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; animation:bob 1.8s var(--ease) infinite; }
@keyframes bob{ 0%,100%{transform:translateY(0);} 50%{transform:translateY(6px);} }
@media (max-width:720px){ .hero__scroll{ display:none; } }

/* ============================================================
   Marquee
   ============================================================ */
.marquee{
  border-block:1px solid var(--line);
  padding:1.6rem 0; overflow:hidden; background:var(--bg-2);
}
.marquee__track{
  display:flex; align-items:center; gap:2.5rem; width:max-content;
  font-family:var(--font-display); font-weight:600;
  font-size:clamp(1.8rem,5vw,3.4rem); letter-spacing:-.02em;
  will-change:transform;
}
.marquee__track span{ white-space:nowrap; }
.marquee__track i{ color:var(--accent); font-size:.6em; font-style:normal; }

/* ============================================================
   Intro / Stats
   ============================================================ */
.intro{ padding:clamp(80px,12vw,160px) 0; }
.intro__grid{ display:grid; gap:clamp(48px,6vw,90px); }
.intro__tag{ display:block; margin-bottom:1rem; }
.intro__lead{
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(1.5rem,3.6vw,2.6rem); line-height:1.25; letter-spacing:-.01em;
  max-width:22ch; color:var(--ink);
}
.intro__lead strong{ color:var(--accent); font-weight:500; }
.intro__lead{ max-width:none; }

.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line-2); border:1px solid var(--line-2); border-radius:var(--r-md); overflow:hidden; }
.stat{ background:var(--bg); padding:clamp(28px,4vw,48px) clamp(20px,3vw,36px); }
.stat__num{ display:block; font-family:var(--font-display); font-weight:600; font-size:clamp(2.6rem,6vw,4.6rem); line-height:1; letter-spacing:-.03em; color:var(--accent); font-variant-numeric:tabular-nums; }
.stat__label{ display:block; margin-top:.6rem; color:var(--ink-dim); font-size:.95rem; }

/* ============================================================
   Services
   ============================================================ */
.services{ padding:clamp(60px,9vw,120px) 0; }
.svc-list{ border-top:1px solid var(--line); }
.svc{
  position:relative; display:grid;
  grid-template-columns:80px 1.1fr 1.4fr auto;
  align-items:center; gap:1.5rem;
  padding:clamp(28px,3.4vw,48px) 0;
  border-bottom:1px solid var(--line);
  transition:padding-left .5s var(--ease);
}
.svc::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:0; z-index:-1;
  background:linear-gradient(90deg, rgba(214,255,63,.10), transparent 70%);
  transition:width .5s var(--ease);
}
.svc:hover{ padding-left:24px; }
.svc:hover::before{ width:100%; }
.svc__no{ font-family:var(--font-display); color:var(--ink-faint); font-size:1rem; }
.svc__name{ font-family:var(--font-display); font-weight:600; font-size:clamp(1.4rem,2.8vw,2.2rem); letter-spacing:-.02em; transition:color .3s; }
.svc:hover .svc__name{ color:var(--accent); }
.svc__desc{ color:var(--ink-dim); max-width:48ch; }
.svc__tags{ display:flex; gap:.5rem; flex-wrap:wrap; justify-content:flex-end; }
.svc__tags span{ font-size:.78rem; padding:.3rem .7rem; border:1px solid var(--line); border-radius:100px; color:var(--ink-dim); white-space:nowrap; }
.svc__icon{ position:absolute; right:0; top:50%; transform:translateY(-50%) scale(.8); width:120px; height:120px; opacity:0; pointer-events:none; fill:none; stroke:var(--accent); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; transition:opacity .4s, transform .5s var(--ease); }
.svc:hover .svc__icon{ opacity:.14; transform:translateY(-50%) scale(1); }

@media (max-width:900px){
  .svc{ grid-template-columns:50px 1fr; grid-template-areas:"no name" ". desc" ". tags"; row-gap:.8rem; }
  .svc__no{ grid-area:no; } .svc__name{ grid-area:name; } .svc__desc{ grid-area:desc; } .svc__tags{ grid-area:tags; justify-content:flex-start; }
  .svc__icon{ display:none; }
}

/* ============================================================
   Work / Cases
   ============================================================ */
.work{ padding:clamp(60px,9vw,120px) 0; }
.cases{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(20px,2.4vw,36px); }
.case{
  --c:var(--accent);
  position:relative; border:1px solid var(--line); border-radius:var(--r-lg);
  background:var(--surface); overflow:hidden;
  display:flex; flex-direction:column;
  transition:transform .5s var(--ease), border-color .5s, background .5s;
  will-change:transform;
}
.case:hover{ transform:translateY(-6px); border-color:color-mix(in srgb,var(--c) 60%, transparent); }
.case__media{ overflow:hidden; aspect-ratio:16/10; background:linear-gradient(135deg,var(--surface-2),var(--bg-2)); border-bottom:1px solid var(--line); }
.case__visual{ width:100%; height:100%; display:grid; place-items:center; padding:24px; transition:transform .6s var(--ease); }
.case:hover .case__visual{ transform:scale(1.04); }
.case__art{ width:100%; height:auto; filter:drop-shadow(0 24px 60px rgba(0,0,0,.5)); }

/* SVG art tokens (use accent var) */
.case{ }
.art-bg{ fill:#101015; stroke:rgba(255,255,255,.06); }
.art-card{ fill:rgba(255,255,255,.05); stroke:rgba(255,255,255,.07); }
.art-line{ fill:rgba(255,255,255,.55); }
.art-dim{ fill:rgba(255,255,255,.16); }
.art-accent{ fill:var(--c); }
.art-stroke{ fill:none; stroke:var(--c); stroke-width:4; stroke-linecap:round; stroke-linejoin:round; }
.art-stroke-fill{ fill:var(--c); }
.art-ring{ fill:none; stroke:var(--c); stroke-width:3; stroke-dasharray:6 8; }
.art-spokes{ fill:none; stroke:rgba(255,255,255,.3); stroke-width:3; stroke-linecap:round; }

.case__body{ padding:clamp(24px,3vw,40px); display:flex; flex-direction:column; gap:1rem; flex:1; }
.case__meta{ display:flex; align-items:center; justify-content:space-between; font-size:.82rem; }
.case__index{ font-family:var(--font-display); color:var(--c); font-weight:600; }
.case__industry{ color:var(--ink-faint); letter-spacing:.04em; text-transform:uppercase; font-size:.72rem; }
.case__name{ font-family:var(--font-display); font-weight:600; font-size:clamp(1.8rem,3.4vw,2.6rem); letter-spacing:-.02em; line-height:1; }
.case__pitch{ color:var(--ink); font-size:1.05rem; }

.case__detail{ display:grid; gap:.8rem; margin-top:.2rem; border-top:1px solid var(--line-2); padding-top:1rem; }
.case__detail>div{ display:grid; grid-template-columns:120px 1fr; gap:1rem; }
.case__detail dt{ font-size:.74rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-faint); }
.case__detail dd{ color:var(--ink-dim); font-size:.92rem; }

.case__outcomes{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top:auto; padding-top:.6rem; }
.case__outcomes li{ display:flex; flex-direction:column; padding:.6rem .9rem; border:1px solid var(--line); border-radius:var(--r-sm); background:var(--bg-2); font-size:.78rem; color:var(--ink-dim); min-width:96px; }
.case__outcomes b{ font-family:var(--font-display); font-size:1.2rem; color:var(--c); font-weight:600; }

@media (max-width:840px){
  .cases{ grid-template-columns:1fr; }
  .case__detail>div{ grid-template-columns:96px 1fr; }
}

/* ============================================================
   Process
   ============================================================ */
.process{ padding:clamp(60px,9vw,120px) 0; }
.steps{ display:grid; grid-template-columns:repeat(5,1fr); gap:1px; background:var(--line-2); border:1px solid var(--line-2); border-radius:var(--r-md); overflow:hidden; }
.step{ background:var(--bg); padding:clamp(28px,3vw,40px) clamp(22px,2.4vw,30px); display:flex; flex-direction:column; gap:1rem; min-height:280px; transition:background .4s; }
.step:hover{ background:var(--surface); }
.step__no{ font-family:var(--font-display); font-size:.95rem; color:var(--accent); }
.step__title{ font-family:var(--font-display); font-weight:600; font-size:1.5rem; letter-spacing:-.01em; margin-top:auto; }
.step__text{ color:var(--ink-dim); font-size:.92rem; }
@media (max-width:1000px){ .steps{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .steps{ grid-template-columns:1fr; } .step{ min-height:auto; } }

/* ============================================================
   Team
   ============================================================ */
.team{ padding:clamp(60px,9vw,120px) 0; }
.team__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,32px); }
.member{ border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(24px,2.6vw,34px); background:var(--surface); transition:transform .4s var(--ease), border-color .4s; }
.member:hover{ transform:translateY(-5px); border-color:rgba(255,255,255,.22); }
.member__avatar{ width:74px; height:74px; border-radius:50%; margin-bottom:1.2rem; overflow:hidden; background:linear-gradient(135deg,var(--a),var(--b)); display:grid; place-items:center; }
.member__avatar .av-bg{ fill:transparent; }
.member__avatar .av-fg{ fill:rgba(8,8,10,.85); }
.member__name{ font-family:var(--font-display); font-weight:600; font-size:1.25rem; }
.member__role{ display:block; color:var(--accent); font-size:.85rem; margin:.2rem 0 .8rem; }
.member__bio{ color:var(--ink-dim); font-size:.92rem; }
@media (max-width:900px){ .team__grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .team__grid{ grid-template-columns:1fr; } }

/* ============================================================
   Quotes
   ============================================================ */
.quotes{ padding:clamp(60px,9vw,120px) 0; }
.quotes__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,32px); }
.quote{ border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(28px,3vw,40px); background:var(--surface); display:flex; flex-direction:column; gap:1.6rem; }
.quote blockquote{ font-family:var(--font-display); font-weight:400; font-size:clamp(1.15rem,1.7vw,1.4rem); line-height:1.35; letter-spacing:-.01em; }
.quote figcaption{ display:flex; flex-direction:column; gap:.2rem; margin-top:auto; }
.quote figcaption b{ font-family:var(--font-display); }
.quote figcaption span{ color:var(--ink-dim); font-size:.88rem; }
@media (max-width:900px){ .quotes__grid{ grid-template-columns:1fr; } }

/* ============================================================
   Awards
   ============================================================ */
.awards{ padding:clamp(40px,6vw,70px) 0; border-block:1px solid var(--line); background:var(--bg-2); }
.awards__row{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:2rem; }
.award{ display:flex; flex-direction:column; gap:.2rem; }
.award__name{ font-family:var(--font-display); font-weight:600; font-size:1.25rem; }
.award__detail{ color:var(--ink-dim); font-size:.85rem; }

/* ============================================================
   Contact
   ============================================================ */
.contact{ padding:clamp(70px,11vw,150px) 0; }
.contact__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,90px); }
.contact__title{ font-family:var(--font-display); font-weight:600; font-size:clamp(2.4rem,6vw,5rem); line-height:.98; letter-spacing:-.03em; margin:1rem 0 1.4rem; }
.contact__lead{ color:var(--ink-dim); font-size:1.1rem; max-width:42ch; }
.contact__info{ margin-top:3rem; }
.contact__email{ font-family:var(--font-display); font-size:clamp(1.3rem,2.6vw,1.9rem); border-bottom:2px solid var(--accent); padding-bottom:.15em; transition:color .3s; }
.contact__email:hover{ color:var(--accent); }
.contact__locations{ display:flex; flex-wrap:wrap; gap:2rem; margin-top:2.4rem; }
.contact__locations div{ display:flex; flex-direction:column; }
.contact__locations b{ font-family:var(--font-display); }
.contact__locations span{ color:var(--ink-dim); font-size:.9rem; }

.form{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; align-content:start; }
.field{ position:relative; }
.field--full{ grid-column:1/-1; }
.field input,.field textarea,.field select{
  width:100%; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-sm);
  padding:1.3rem 1rem .7rem; outline:none; transition:border-color .3s, background .3s; resize:vertical;
}
.field select{ padding-top:1rem; padding-bottom:1rem; appearance:none; color:var(--ink); }
.field input:focus,.field textarea:focus,.field select:focus{ border-color:var(--accent); background:var(--surface-2); }
.field label{
  position:absolute; left:1rem; top:1rem; color:var(--ink-faint); font-size:.95rem;
  pointer-events:none; transition:transform .25s var(--ease), color .25s, font-size .25s;
}
.field label em{ font-style:normal; color:var(--ink-faint); }
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{
  transform:translateY(-.55rem); font-size:.7rem; color:var(--accent);
}
.field__static{ position:static; transform:none; font-size:.7rem; }
.field select+.field__static{ display:none; }
.form__note{ grid-column:1/-1; font-size:.88rem; color:var(--accent); min-height:1.2em; }
.form__note.is-error{ color:var(--accent-4); }
@media (max-width:840px){ .contact__grid{ grid-template-columns:1fr; } }
@media (max-width:480px){ .form{ grid-template-columns:1fr; } }

/* ============================================================
   Footer
   ============================================================ */
.footer{ background:var(--bg-2); border-top:1px solid var(--line); padding-top:clamp(60px,8vw,100px); overflow:hidden; }
.footer__top{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:2rem; padding-bottom:3rem; border-bottom:1px solid var(--line); }
.footer__logo{ display:flex; align-items:center; gap:.6rem; font-family:var(--font-display); font-weight:600; font-size:1.5rem; }
.footer__logo svg path{ fill:none; stroke:var(--accent); stroke-width:6; stroke-linecap:round; stroke-linejoin:round; }
.footer__logo sup{ color:var(--accent); font-size:.6em; }
.footer__tag{ color:var(--ink-dim); max-width:34ch; }

.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; padding:3rem 0; }
.footer__col{ display:flex; flex-direction:column; gap:.7rem; }
.footer__col h4{ font-family:var(--font-display); font-size:.8rem; text-transform:uppercase; letter-spacing:.14em; color:var(--ink-faint); margin-bottom:.4rem; }
.footer__col a{ color:var(--ink-dim); transition:color .3s, padding-left .3s; width:fit-content; }
.footer__col a:hover{ color:var(--accent); padding-left:.3rem; }
.footer__social{ display:flex; gap:.7rem; }
.footer__social a{ width:42px; height:42px; border:1px solid var(--line); border-radius:50%; display:grid; place-items:center; transition:border-color .3s, background .3s, transform .3s; }
.footer__social a:hover{ border-color:var(--accent); background:var(--accent); transform:translateY(-3px); }
.footer__social svg{ width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.footer__social a:hover svg{ stroke:#000; }

.footer__bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; padding:2.4rem 0; color:var(--ink-faint); font-size:.85rem; }

.footer__big{ display:flex; gap:3rem; width:max-content; opacity:.05; user-select:none; line-height:.8; padding-bottom:1rem; }
.footer__big span{ font-family:var(--font-display); font-weight:700; font-size:clamp(5rem,22vw,18rem); letter-spacing:-.04em; }
@media (max-width:680px){ .footer__cols{ grid-template-columns:1fr 1fr; } }

/* ============================================================
   Reveal animations (fallback + GSAP enhanced)
   ============================================================ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }

.no-js .reveal{ opacity:1; transform:none; }

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.01ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .cursor{ display:none; }
}

/* ============================================================
   Responsive nav
   ============================================================ */
@media (max-width:880px){
  .nav__links,.nav__cta{ display:none; }
  .nav__burger{ display:flex; }
}
