/* ================================================================
   CULTIVE UNIVERSE — style.css
   Dark-first tech agency design — matching Figma
   Edit the :root tokens to rebrand the entire site
   ================================================================ */

/* ── 1. TOKENS ─────────────────────────────────────────────────── */
:root {
  /* Dark (default) */
  --bg:          #0d0d0d;
  --bg-2:        #111111;
  --bg-3:        #161616;
  --surface:     #1a1a1a;
  --surface-2:   #222222;
  --border:      #2a2a2a;
  --border-2:    #333333;
  --text:        #f0f0ee;
  --text-muted:  #888880;
  --text-dim:    #555550;
  --accent:      #9b5dff;   /* purple — matches Figma highlight */
  --accent-2:    #c084fc;
  --accent-glow: rgba(155,93,255,.25);
  --gold:        #f0c040;
  --green:       #22c55e;

  --font-head:   'Syne', sans-serif;
  --font-body:   'Space Grotesk', sans-serif;
  --font-mono:   'DM Mono', monospace;

  --r:    12px;
  --r-sm: 6px;
  --ease: cubic-bezier(.16,1,.3,1);
  --dur:  .45s;
}

[data-theme="light"] {
  --bg:          #f2f2f0;
  --bg-2:        #e8e8e5;
  --bg-3:        #ddddd8;
  --surface:     #ffffff;
  --surface-2:   #f5f5f2;
  --border:      #dcdcd5;
  --border-2:    #c8c8c0;
  --text:        #0d0d0d;
  --text-muted:  #555550;
  --text-dim:    #aaaaaa;
  --accent:      #7c3aed;
  --accent-2:    #9b5dff;
  --accent-glow: rgba(124,58,237,.15);
}

/* ── 2. RESET ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  overflow-x:hidden;
  transition:background .4s var(--ease),color .4s var(--ease);
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}

/* ── 3. CURSOR ──────────────────────────────────────────────────── */
.c-cursor{
  width:40px;height:40px;
  border:1.5px solid var(--accent);
  border-radius:50%;
  position:fixed;top:0;left:0;
  transform:translate(-50%,-50%);
  pointer-events:none;z-index:9999;
  transition:width .3s,height .3s,border-color .3s,background .3s;
  mix-blend-mode:difference;
}
.c-cursor-dot{
  width:5px;height:5px;
  background:var(--accent);border-radius:50%;
  position:fixed;top:0;left:0;
  transform:translate(-50%,-50%);
  pointer-events:none;z-index:9999;
  transition:transform .1s;
}
.c-cursor.is-hover{width:64px;height:64px;background:var(--accent-glow)}
@media(pointer:coarse){.c-cursor,.c-cursor-dot{display:none}}

/* ── 4. PRELOADER ───────────────────────────────────────────────── */
.preloader{
  position:fixed;inset:0;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  z-index:10000;
  transition:opacity .8s var(--ease),visibility .8s;
}
.preloader.gone{opacity:0;visibility:hidden}
.pre-inner{display:flex;flex-direction:column;align-items:center;gap:20px}
.pre-logo{
  font-family:var(--font-head);
  font-size:clamp(2rem,6vw,4rem);
  font-weight:800;
  letter-spacing:.2em;
  color:var(--text);
  animation:pulseLogo 1.2s ease-in-out infinite alternate;
}
@keyframes pulseLogo{from{opacity:.3}to{opacity:1}}
.pre-bar{
  width:180px;height:2px;
  background:var(--border);
  border-radius:99px;overflow:hidden;
}
.pre-fill{
  height:100%;width:0;
  background:var(--accent);
  border-radius:99px;
  transition:width .05s linear;
}
.pre-pct{
  font-family:var(--font-mono);font-size:.8rem;
  color:var(--text-muted);
}

/* ── 5. LAYOUT ──────────────────────────────────────────────────── */
.container{
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;
}
.section{padding:100px 0}
.mt-16{margin-top:16px}

/* ── 6. TYPOGRAPHY HELPERS ─────────────────────────────────────── */
.accent{color:var(--accent)}
.label-tag{
  display:inline-block;
  font-family:var(--font-mono);font-size:.75rem;font-weight:500;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--accent);
  border:1px solid var(--accent);
  padding:5px 12px;border-radius:99px;
  margin-bottom:20px;
}
.section-title{
  font-family:var(--font-head);
  font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:800;
  line-height:1.15;
  margin-bottom:48px;
}

/* ── 7. BUTTONS ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-body);font-weight:600;font-size:.9rem;
  padding:12px 24px;border-radius:var(--r-sm);
  transition:all var(--dur) var(--ease);
  white-space:nowrap;position:relative;overflow:hidden;
}
.btn::after{
  content:'';
  position:absolute;inset:0;
  background:rgba(255,255,255,.08);
  opacity:0;
  transition:opacity .2s;
}
.btn:hover::after{opacity:1}
.btn--primary{background:var(--accent);color:#fff;box-shadow:0 0 24px var(--accent-glow)}
.btn--primary:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:0 0 40px var(--accent-glow)}
.btn--ghost{border:1.5px solid var(--border-2);color:var(--text)}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn--sm{padding:9px 18px;font-size:.85rem}
.btn--lg{padding:16px 36px;font-size:1rem}
.btn--xl{padding:20px 48px;font-size:1.1rem}

/* ── 8. NAVBAR ─────────────────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;
  z-index:1000;
  padding:20px 0;
  transition:background .3s,box-shadow .3s,padding .3s;
}
.nav.scrolled{
  background:rgba(13,13,13,.92);
  backdrop-filter:blur(16px);
  box-shadow:0 1px 0 var(--border);
  padding:12px 0;
}
[data-theme="light"] .nav.scrolled{
  background:rgba(242,242,240,.92);
}
.nav__wrap{
  max-width:1200px;margin:0 auto;padding:0 24px;
  display:flex;align-items:center;gap:40px;
}
.nav__logo{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-head);font-weight:800;font-size:1rem;
  color:var(--text);flex-shrink:0;letter-spacing:.02em;
}
.logo-mark{color:var(--accent);font-size:1.2rem}
.nav__links{display:flex;gap:28px;flex:1;justify-content:center}
.nav__a{
  font-size:.875rem;font-weight:500;color:var(--text-muted);
  position:relative;transition:color .25s;
  padding-bottom:2px;
}
.nav__a::after{
  content:'';position:absolute;left:0;bottom:-2px;right:0;
  height:1px;background:var(--accent);
  transform:scaleX(0);transition:transform .25s var(--ease);
}
.nav__a:hover,.nav__a.active{color:var(--text)}
.nav__a:hover::after,.nav__a.active::after{transform:scaleX(1)}
.nav__right{display:flex;align-items:center;gap:16px;margin-left:auto}

/* Theme button */
.theme-btn{
  width:36px;height:36px;border-radius:50%;
  border:1px solid var(--border-2);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);font-size:1rem;
  transition:border-color .25s,color .25s;
}
.theme-btn:hover{border-color:var(--accent);color:var(--accent)}
.t-icon{transition:opacity .3s}
.sun{display:none}[data-theme="light"] .sun{display:block}
.moon{display:block}[data-theme="light"] .moon{display:none}

/* Burger */
.burger{display:none;flex-direction:column;gap:7px;padding:4px}
.burger span{display:block;width:22px;height:1.5px;background:var(--text);transition:.3s}
.burger.open span:first-child{transform:rotate(45deg) translate(6px,6px)}
.burger.open span:last-child{transform:rotate(-45deg) translate(6px,-6px)}

/* Mobile nav */
.nav__mobile{
  display:none;flex-direction:column;gap:0;
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:var(--bg);padding:100px 32px 40px;
  transform:translateX(100%);
  transition:transform .5s var(--ease);
  z-index:999;
}
.nav__mobile.open{transform:none}
.nav__mobile a{
  padding:18px 0;border-bottom:1px solid var(--border);
  font-family:var(--font-head);font-size:1.5rem;font-weight:800;
  color:var(--text);
}
.nav__mobile a:hover{color:var(--accent)}

/* ── 9. HERO ────────────────────────────────────────────────────── */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  padding-top:80px;
  position:relative;overflow:hidden;
}
.hero__noise{
  position:absolute;inset:0;
  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='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  pointer-events:none;z-index:0;
  opacity:.6;
}
.hero__grid{
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;gap:64px;
  padding:80px 24px;
  position:relative;z-index:1;
}
.hero__tag{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:.8rem;
  color:var(--green);margin-bottom:24px;
}
.dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--green);
  animation:blink 2s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero__h1{
  font-family:var(--font-head);
  font-size:clamp(2.6rem,5vw,4.2rem);
  font-weight:800;line-height:1.1;
  margin-bottom:28px;
}
.hero__h1 em{font-style:normal;color:var(--accent)}
.hero__sub{
  font-size:1.05rem;color:var(--text-muted);
  max-width:480px;margin-bottom:40px;
}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap}

/* Hero card stack */
.hero__visual{display:flex;justify-content:center;align-items:center}
.hero__card-stack{
  position:relative;width:320px;height:360px;
}
.h-card{
  position:absolute;
  background:var(--surface);
  border:1px solid var(--border-2);
  border-radius:var(--r);
  padding:24px;
  display:flex;justify-content:space-between;align-items:flex-end;
  transition:transform .4s var(--ease),box-shadow .4s;
}
.h-card:hover{box-shadow:0 0 40px var(--accent-glow)}
.h-card__label{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted)}
.h-card__num{font-family:var(--font-head);font-size:2.5rem;font-weight:800;color:var(--border-2)}
.h-card--1{width:290px;top:0;left:0;z-index:4;animation:floatCard1 6s ease-in-out infinite}
.h-card--2{width:260px;top:80px;left:30px;z-index:3;animation:floatCard2 7s ease-in-out infinite}
.h-card--3{width:240px;top:160px;left:20px;z-index:2;animation:floatCard3 8s ease-in-out infinite}
.h-card--4{width:220px;top:240px;left:40px;z-index:1;animation:floatCard4 5s ease-in-out infinite}
.h-card__glow{
  position:absolute;top:50%;left:50%;
  width:200px;height:200px;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle,var(--accent-glow),transparent 70%);
  border-radius:50%;
  pointer-events:none;
  animation:glowPulse 4s ease-in-out infinite;
}
@keyframes floatCard1{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-10px) rotate(-1deg)}}
@keyframes floatCard2{0%,100%{transform:translateY(0) rotate(1deg)}50%{transform:translateY(-8px) rotate(2deg)}}
@keyframes floatCard3{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-6px) rotate(0)}}
@keyframes floatCard4{0%,100%{transform:translateY(0) rotate(2deg)}50%{transform:translateY(-4px) rotate(1deg)}}
@keyframes glowPulse{0%,100%{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.3)}}

/* Scroll hint */
.hero__scroll{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding-bottom:40px;
  font-family:var(--font-mono);font-size:.7rem;
  color:var(--text-dim);letter-spacing:.1em;
  position:relative;z-index:1;
}
.scroll-track{
  width:1px;height:48px;background:var(--border-2);
  position:relative;overflow:hidden;
}
.scroll-thumb{
  position:absolute;top:0;left:0;right:0;
  height:50%;background:var(--accent);
  animation:scrollDown 2s ease-in-out infinite;
}
@keyframes scrollDown{
  0%{top:0;opacity:1}
  100%{top:100%;opacity:0}
}

/* ── 10. MARQUEE ────────────────────────────────────────────────── */
.marquee-wrap{
  overflow:hidden;padding:16px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--bg-2);
}
.marquee-inner{
  display:flex;gap:40px;width:max-content;
  animation:marquee 30s linear infinite;
}
.marquee-inner span{
  font-family:var(--font-head);font-size:.8rem;font-weight:800;
  letter-spacing:.15em;color:var(--text-dim);white-space:nowrap;
}
.marquee-inner .sep{color:var(--accent)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ── 11. REAL TALK ──────────────────────────────────────────────── */
.real-talk{background:var(--bg-2)}
.rt__head{margin-bottom:48px}
.rt__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.rt__item{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:32px;
  transition:border-color var(--dur),transform var(--dur);
}
.rt__item:hover{border-color:var(--accent);transform:translateY(-4px)}
.rt__ico{font-size:1.8rem;margin-bottom:16px}
.rt__item h3{
  font-family:var(--font-head);font-size:1.05rem;font-weight:800;
  margin-bottom:12px;
}
.rt__item p{font-size:.9rem;color:var(--text-muted);line-height:1.6}

/* ── 12. SERVICES ───────────────────────────────────────────────── */
.services{background:var(--bg)}
.svc__grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
}
.svc__card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:36px 32px;
  position:relative;overflow:hidden;
  transition:border-color var(--dur),transform var(--dur),box-shadow var(--dur);
}
.svc__card::before{
  content:'';position:absolute;
  bottom:0;left:0;right:0;height:2px;
  background:var(--accent);transform:scaleX(0);
  transition:transform var(--dur) var(--ease);
}
.svc__card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.3)}
.svc__card:hover::before{transform:scaleX(1)}
.svc__num{
  font-family:var(--font-mono);font-size:.75rem;
  color:var(--accent);margin-bottom:16px;
  display:block;
}
.svc__card h3{
  font-family:var(--font-head);font-size:1.3rem;font-weight:800;
  margin-bottom:12px;
}
.svc__card p{font-size:.9rem;color:var(--text-muted);line-height:1.6;margin-bottom:20px}
.svc__link{
  font-family:var(--font-mono);font-size:.8rem;font-weight:500;
  color:var(--accent);letter-spacing:.05em;
  transition:letter-spacing .3s;
}
.svc__card:hover .svc__link{letter-spacing:.1em}

/* ── 13. ALLERGIC ───────────────────────────────────────────────── */
.allergic{
  background:var(--bg-3);
  position:relative;overflow:hidden;
}
.allergic__inner{
  max-width:720px;margin:0 auto;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:24px;
  position:relative;z-index:1;
}
.allergic__bg-text{
  position:absolute;
  font-family:var(--font-head);font-size:clamp(5rem,15vw,12rem);
  font-weight:800;color:transparent;
  -webkit-text-stroke:1px var(--border);
  top:50%;left:50%;transform:translate(-50%,-50%);
  white-space:nowrap;pointer-events:none;
  opacity:.4;z-index:0;
  user-select:none;
}
.allergic__title{
  font-family:var(--font-head);
  font-size:clamp(2.5rem,7vw,5.5rem);
  font-weight:800;line-height:1.05;
  text-align:center;
}
.allergic p{font-size:1.05rem;color:var(--text-muted);max-width:520px}

/* ── 14. STATS ──────────────────────────────────────────────────── */
.stats{background:var(--bg-2)}
.stats__grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:32px;text-align:center;
}
.stat__item{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:32px 24px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  transition:border-color var(--dur),transform var(--dur);
}
.stat__item:hover{border-color:var(--accent);transform:translateY(-4px)}
.stat__num{
  font-family:var(--font-head);
  font-size:clamp(2.5rem,5vw,4rem);
  font-weight:800;color:var(--accent);
  line-height:1;
}
.stat__sfx{
  font-family:var(--font-head);font-size:1.5rem;font-weight:800;
  color:var(--text-muted);
}
.stat__item p{font-size:.875rem;color:var(--text-muted)}

/* ── 15. CTA BANNER ─────────────────────────────────────────────── */
.cta-banner{background:var(--bg)}
.cta-banner__inner{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:80px 48px;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:24px;
  position:relative;overflow:hidden;
}
.cta-banner__inner::before{
  content:'';position:absolute;inset:-1px;
  background:linear-gradient(135deg,var(--accent-glow),transparent,var(--accent-glow));
  border-radius:var(--r);opacity:.5;
  animation:borderGlow 4s linear infinite;
}
@keyframes borderGlow{0%,100%{opacity:.3}50%{opacity:.8}}
.cta-banner__inner h2{
  font-family:var(--font-head);
  font-size:clamp(2.5rem,6vw,5rem);
  font-weight:800;line-height:1.1;
  position:relative;z-index:1;
}
.cta-banner__inner p{
  font-size:1.05rem;color:var(--text-muted);
  max-width:480px;position:relative;z-index:1;
}
.cta-banner__inner .btn{position:relative;z-index:1}

/* ── 16. REVEAL ANIMATIONS ──────────────────────────────────────── */
[data-reveal]{
  opacity:0;
  transform:translateY(40px);
  transition:opacity .8s var(--ease),transform .8s var(--ease);
}
[data-reveal].revealed{opacity:1;transform:none}

/* ── 17. FOOTER ─────────────────────────────────────────────────── */
.footer{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  padding:64px 0 32px;
}
.footer__top{
  display:grid;grid-template-columns:1.4fr 2fr;
  gap:64px;margin-bottom:48px;
}
.footer__brand{display:flex;flex-direction:column;gap:16px}
.footer__brand p{font-size:.875rem;color:var(--text-muted);max-width:280px;line-height:1.65}
.footer__socials{display:flex;gap:12px}
.footer__socials a{
  width:36px;height:36px;
  border-radius:50%;border:1px solid var(--border-2);
  color:var(--text-muted);
  display:flex;align-items:center;justify-content:center;
  font-size:.875rem;font-weight:700;
  transition:all .25s;
}
.footer__socials a:hover{border-color:var(--accent);color:var(--accent)}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.footer__col{display:flex;flex-direction:column;gap:12px}
.footer__col h4{
  font-family:var(--font-head);font-size:.875rem;font-weight:800;
  color:var(--text);margin-bottom:4px;
}
.footer__col a{font-size:.875rem;color:var(--text-muted);transition:color .25s}
.footer__col a:hover{color:var(--accent)}
.footer__bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;border-top:1px solid var(--border);
  font-size:.8rem;color:var(--text-dim);
}
.footer__legal{display:flex;gap:24px}
.footer__legal a{color:var(--text-dim);transition:color .25s}
.footer__legal a:hover{color:var(--text)}

/* ── 18. BACK TO TOP ────────────────────────────────────────────── */
.back-top{
  position:fixed;bottom:28px;right:28px;
  width:44px;height:44px;border-radius:50%;
  background:var(--accent);color:#fff;
  font-size:1.1rem;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 24px var(--accent-glow);
  opacity:0;pointer-events:none;
  transition:opacity .3s,transform .3s;
  z-index:500;
}
.back-top.show{opacity:1;pointer-events:auto}
.back-top:hover{transform:translateY(-3px)}

/* ── 19. PAGE-SPECIFIC: ABOUT ───────────────────────────────────── */
.page-hero{
  padding:160px 0 80px;
  position:relative;overflow:hidden;
}
.page-hero__tag{margin-bottom:24px}
.page-hero h1{
  font-family:var(--font-head);
  font-size:clamp(2.8rem,6vw,5rem);
  font-weight:800;line-height:1.1;
  margin-bottom:24px;
}
.page-hero p{font-size:1.1rem;color:var(--text-muted);max-width:560px}

/* WHY US grid */
.why-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:16px;margin-top:64px;
}
.why-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:32px;
  transition:border-color var(--dur),transform var(--dur);
}
.why-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.why-card h3{font-family:var(--font-head);font-size:1.1rem;font-weight:800;margin-bottom:12px}
.why-card p{font-size:.9rem;color:var(--text-muted);line-height:1.6}

/* PARTNERS */
.partners{background:var(--bg-2);padding:64px 0}
.partners h2{font-family:var(--font-head);font-size:1.5rem;font-weight:800;text-align:center;margin-bottom:40px}
.partners-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:16px;align-items:center;
}
.partner-item{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:20px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-size:1rem;font-weight:800;
  color:var(--text-muted);
  transition:border-color .25s,color .25s;
}
.partner-item:hover{border-color:var(--accent);color:var(--accent)}

/* ── 20. PAGE-SPECIFIC: TEAM ────────────────────────────────────── */
.team-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.team-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);overflow:hidden;
  transition:border-color var(--dur),transform var(--dur);
}
.team-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.team-card__img{
  aspect-ratio:1;background:var(--bg-3);
  display:flex;align-items:center;justify-content:center;
  font-size:4rem;
  position:relative;overflow:hidden;
}
.team-card__img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 60%,var(--surface));
}
.team-card__body{padding:24px}
.team-card__role{
  font-family:var(--font-mono);font-size:.75rem;
  color:var(--accent);margin-bottom:8px;display:block;
}
.team-card h3{font-family:var(--font-head);font-size:1.1rem;font-weight:800;margin-bottom:8px}
.team-card p{font-size:.875rem;color:var(--text-muted);line-height:1.55}

/* ── 21. PAGE-SPECIFIC: CONTACT ─────────────────────────────────── */
.contact-grid{
  display:grid;grid-template-columns:1fr 1.4fr;
  gap:80px;align-items:start;
}
.contact-info{display:flex;flex-direction:column;gap:32px}
.contact-info h2{font-family:var(--font-head);font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.15}
.contact-info p{font-size:.9rem;color:var(--text-muted);line-height:1.65}
.contact-links{display:flex;flex-direction:column;gap:12px}
.contact-links a{
  display:flex;align-items:center;gap:12px;
  font-size:.9rem;color:var(--text-muted);
  padding:14px 16px;border-radius:var(--r-sm);
  border:1px solid var(--border);
  transition:border-color .25s,color .25s;
}
.contact-links a:hover{border-color:var(--accent);color:var(--accent)}
.contact-form{display:flex;flex-direction:column;gap:20px}
.form-group{display:flex;flex-direction:column;gap:8px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group label{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}
.form-group input,
.form-group select,
.form-group textarea{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  padding:14px 16px;
  font-family:var(--font-body);font-size:.9rem;
  color:var(--text);
  transition:border-color .25s,box-shadow .25s;
  outline:none;width:100%;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.form-group textarea{resize:vertical}
.form-group select option{background:var(--bg)}
.form-success{
  display:none;text-align:center;
  padding:14px;border-radius:var(--r-sm);
  background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);
  color:var(--green);font-family:var(--font-mono);font-size:.875rem;
}
.form-success.show{display:block;animation:fadeUp .5s var(--ease)}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── 22. PAGE-SPECIFIC: BLOG ────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color var(--dur),transform var(--dur);
}
.blog-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.blog-thumb{
  aspect-ratio:16/9;background:var(--bg-3);
  display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;
}
.blog-body{padding:24px;flex:1;display:flex;flex-direction:column;gap:12px}
.blog-cat{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.blog-body h3{font-family:var(--font-head);font-size:1.05rem;font-weight:800;line-height:1.3}
.blog-body p{font-size:.875rem;color:var(--text-muted);line-height:1.6;flex:1}
.blog-meta{font-family:var(--font-mono);font-size:.75rem;color:var(--text-dim)}
.blog-card .btn{margin-top:auto}

/* ── 23. PAGE-SPECIFIC: EVENTS ──────────────────────────────────── */
.events-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.event-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:28px;
  display:flex;gap:24px;align-items:flex-start;
  transition:border-color var(--dur),transform var(--dur);
}
.event-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.event-date{
  background:var(--accent);color:#fff;
  border-radius:var(--r-sm);padding:12px 16px;
  text-align:center;flex-shrink:0;min-width:64px;
}
.event-date .day{font-family:var(--font-head);font-size:1.8rem;font-weight:800;line-height:1}
.event-date .month{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;opacity:.8}
.event-info{flex:1}
.event-tag{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;display:block}
.event-info h3{font-family:var(--font-head);font-size:1.1rem;font-weight:800;margin-bottom:8px}
.event-info p{font-size:.875rem;color:var(--text-muted);line-height:1.55;margin-bottom:16px}
.event-meta{font-family:var(--font-mono);font-size:.75rem;color:var(--text-dim)}

/* Newsletter */
.newsletter{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:40px;
  display:flex;flex-direction:column;align-items:center;
  gap:20px;text-align:center;
  position:relative;overflow:hidden;
}
.newsletter::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at top,var(--accent-glow),transparent 70%);
  pointer-events:none;
}
.newsletter h3{font-family:var(--font-head);font-size:1.8rem;font-weight:800;position:relative}
.newsletter p{font-size:.9rem;color:var(--text-muted);max-width:440px;position:relative}
.nl-form{display:flex;gap:12px;width:100%;max-width:480px;position:relative}
.nl-form input{
  flex:1;background:var(--bg);border:1px solid var(--border-2);
  border-radius:var(--r-sm);padding:14px 16px;
  font-family:var(--font-body);font-size:.9rem;color:var(--text);
  outline:none;transition:border-color .25s;
}
.nl-form input:focus{border-color:var(--accent)}
.nl-form .btn{flex-shrink:0}

/* ── 24. RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:1024px){
  .hero__grid{grid-template-columns:1fr;text-align:center;gap:48px}
  .hero__sub{margin:0 auto 40px}
  .hero__cta{justify-content:center}
  .hero__visual{order:-1}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .footer__top{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:repeat(3,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .partners-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .section{padding:64px 0}
  .nav__links,.nav__right .btn--sm{display:none}
  .burger{display:flex}
  .rt__grid{grid-template-columns:1fr}
  .svc__grid{grid-template-columns:1fr}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .hero__h1{font-size:2.4rem}
  .hero__card-stack{width:260px;height:300px}
  .blog-grid{grid-template-columns:1fr}
  .events-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:1fr 1fr}
  .footer__bottom{flex-direction:column;gap:12px;text-align:center}
  .cta-banner__inner{padding:48px 28px}
  .nl-form{flex-direction:column}
  .form-row{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
}
