*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F4F0FF;
  --ink:#110C1E;
  --plum:#C8285A;
  --plum2:#F0407A;
  --plumdk:#8C1A3E;
  --dust:#EAE4FF;
  --mist:#CFC8F0;
  --mid:#7A708C;
  --white:#FEFCFF;
  --lime:#C2F542;
  --limeDk:#94C018;
  --disp:'Syne',sans-serif;
  --serif:'Instrument Serif',Georgia,serif;
  --body:'DM Sans',sans-serif;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--body);overflow-x:hidden;cursor:none}

/* ── CURSOR ── */
#cur-dot{position:fixed;z-index:9999;width:8px;height:8px;background:var(--plum);border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);transition:transform .12s,background .2s}
#cur-ring{position:fixed;z-index:9998;width:38px;height:38px;border:1.5px solid var(--plum);border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);opacity:.45;transition:width .3s,height .3s,opacity .3s}
body.on-dark #cur-dot{background:var(--plum2)}
body.on-dark #cur-ring{border-color:var(--plum2)}
.hoverable:hover~#cur-dot,body.hovering #cur-dot{transform:translate(-50%,-50%) scale(3);background:var(--plum2)}
body.hovering #cur-ring{opacity:.8;width:54px;height:54px}

/* ── NOISE ── */
body::before{content:'';position:fixed;inset:0;z-index:8800;pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.025}

/* ══════════════════════════════
   NAV
══════════════════════════════ */
nav{position:fixed;top:0;left:0;right:0;z-index:700;display:flex;align-items:center;justify-content:space-between;padding:20px 52px;transition:all .4s}
nav.stuck{background:rgba(247,244,240,.95);backdrop-filter:blur(18px);padding:14px 52px;border-bottom:1px solid var(--mist)}
.nav-logo{height:40px;flex-shrink:0}
.nav-logo img{height:100%;width:auto;display:block}
.nav-center{display:flex;gap:0;list-style:none;background:rgba(255,255,255,.6);border:1px solid var(--mist);border-radius:100px;overflow:hidden}
.nav-center li a{display:block;font-family:var(--disp);font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);text-decoration:none;padding:10px 22px;transition:all .25s;position:relative}
.nav-center li a.active,
.nav-center li a:hover{color:var(--white);background:var(--plum)}
.nav-cta{font-family:var(--disp);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;background:var(--ink);color:var(--white);padding:11px 26px;text-decoration:none;border-radius:100px;transition:background .25s,transform .2s}
.nav-cta:hover{background:var(--plum);transform:translateY(-1px)}

/* ══════════════════════════════
   PAGE SYSTEM
══════════════════════════════ */
.page{display:none;min-height:100vh;padding-top:80px}
.page.active{display:block}

/* ══════════════════════════════
   HOME — HERO
══════════════════════════════ */
#home{padding-top:0}
.hero{min-height:100vh;display:grid;grid-template-rows:1fr auto;position:relative;overflow:hidden;background:var(--ink)}
.hero-canvas{position:absolute;inset:0;overflow:hidden}
/* Animated gradient orb */
.hero-orb{
  position:absolute;width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#f0407a 0%,#c8285a 40%,#6a0f2a 70%,transparent 100%);
  right:-180px;top:-100px;opacity:.6;
  animation:orbFloat 8s ease-in-out infinite alternate}
@keyframes orbFloat{from{transform:translate(0,0) scale(1)}to{transform:translate(-30px,40px) scale(1.06)}}
.hero-grid-lines{position:absolute;inset:0;background-image:linear-gradient(rgba(200,180,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(200,180,255,.06) 1px,transparent 1px);background-size:80px 80px}

.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;min-height:100vh;align-items:center;padding:120px 52px 80px}
.hero-l{}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--disp);font-size:.65rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--plum2);margin-bottom:32px;opacity:0;animation:fadUp .7s .2s forwards}
.hero-eyebrow-dot{width:6px;height:6px;background:var(--plum2);border-radius:50%}
.hero-h{font-family:var(--disp);font-size:clamp(52px,7vw,96px);font-weight:800;line-height:.95;color:var(--white);letter-spacing:-.02em;margin-bottom:32px}
.hero-h-line{overflow:hidden;display:block}
.hero-h-word{display:inline-block;transform:translateY(105%);animation:slideUp .75s cubic-bezier(.77,0,.18,1) forwards}
.l1 .hero-h-word{animation-delay:.25s}
.l2 .hero-h-word{animation-delay:.38s}
.l3 .hero-h-word{animation-delay:.51s}
.hero-pos{font-family:var(--serif);font-style:italic;font-size:clamp(1rem,1.6vw,1.3rem);color:rgba(255,255,255,.55);line-height:1.7;max-width:440px;margin-bottom:48px;opacity:0;animation:fadUp .8s .7s forwards}
.hero-actions{display:flex;align-items:center;gap:20px;opacity:0;animation:fadUp .8s .9s forwards}
.btn-plum{font-family:var(--disp);font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;background:var(--plum);color:var(--white);padding:14px 32px;text-decoration:none;border-radius:100px;transition:background .25s,transform .2s}
.btn-plum:hover{background:var(--plum2);transform:translateY(-2px)}
.btn-ghost-wh{font-family:var(--disp);font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);text-decoration:none;display:flex;align-items:center;gap:8px;transition:color .25s}
.btn-ghost-wh:hover{color:var(--white)}
.btn-ghost-wh::after{content:'→';transition:transform .25s}
.btn-ghost-wh:hover::after{transform:translateX(4px)}

.hero-r{display:flex;flex-direction:column;justify-content:center;align-items:flex-end;gap:0;padding-left:40px}
/* Stat cards */
.hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:2px;width:100%;max-width:380px;opacity:0;animation:fadUp .8s 1s forwards}
.hstat{background:rgba(255,255,255,.07);border:1px solid rgba(200,180,255,.15);padding:28px 24px;backdrop-filter:blur(8px);transition:background .3s,border-color .3s}
.hstat:hover{background:rgba(194,245,66,.08);border-color:rgba(194,245,66,.3)}
.hstat-n{font-family:var(--disp);font-size:2.8rem;font-weight:800;color:var(--lime);line-height:1}
.hstat-l{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:6px}

/* hero bottom bar */
.hero-bottom{position:relative;z-index:2;border-top:1px solid rgba(200,180,255,.1);display:flex;align-items:center;justify-content:space-between;padding:20px 52px}
.hero-clients{display:flex;align-items:center;gap:16px;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3)}
.hero-client-list{display:flex;gap:24px}
.hero-client-list span{color:rgba(255,255,255,.55);font-size:.7rem;letter-spacing:.08em}
.hero-scroll-hint{display:flex;align-items:center;gap:10px;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.3)}
.scroll-pulse{width:1px;height:48px;background:linear-gradient(to bottom,var(--lime),transparent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scaleY(1)}50%{opacity:.4;transform:scaleY(.6)}}

/* ── WHAT WE DO GRID ── */
.services-grid-home{padding:100px 52px;background:var(--white)}
.sgh-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:64px}
.tag{font-family:var(--disp);font-size:.62rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--plum);margin-bottom:14px}
.h2{font-family:var(--disp);font-size:clamp(2rem,4vw,3.6rem);font-weight:800;line-height:.95;letter-spacing:-.02em;color:var(--ink)}
.h2 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--plum)}
.sgh-note{max-width:300px;font-size:.88rem;color:var(--mid);line-height:1.85;text-align:right;align-self:flex-end}
.sgh-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--mist)}
.sgh-card{background:var(--white);padding:44px 32px;transition:background .3s;position:relative;overflow:hidden}
.sgh-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--plum),var(--lime));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.sgh-card:hover{background:var(--dust)}
.sgh-card:hover::after{transform:scaleX(1)}
.sgh-icon{width:44px;height:44px;border-radius:50%;background:var(--dust);display:flex;align-items:center;justify-content:center;margin-bottom:24px;font-size:1.1rem;transition:background .3s}
.sgh-card:hover .sgh-icon{background:var(--lime)}
.sgh-title{font-family:var(--disp);font-size:1.05rem;font-weight:700;color:var(--ink);margin-bottom:10px}
.sgh-desc{font-size:.83rem;color:var(--mid);line-height:1.85}

/* ── FEATURED WORK ── */
.feat-work{padding:100px 52px;background:var(--bg)}
.fw-head{margin-bottom:64px}
.fw-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr;grid-template-rows:auto auto;gap:3px}
.fw-card{position:relative;overflow:hidden;cursor:none}
.fw-card:first-child{grid-row:span 2}
.fw-bg{position:absolute;inset:0;transition:transform .7s cubic-bezier(.23,1,.32,1)}
.fw-card:hover .fw-bg{transform:scale(1.06)}
.fw-shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,8,12,.92) 0%,rgba(10,8,12,.1) 50%,transparent 100%)}
.fw-bg-1{background:linear-gradient(140deg,#1e0814 0%,#3d1230 55%,#180a10 100%)}
.fw-bg-2{background:linear-gradient(140deg,#0d1018 0%,#1a1a38 55%,#0a0c12 100%)}
.fw-bg-3{background:linear-gradient(140deg,#100d18 0%,#281230 55%,#0c0812 100%)}
.fw-bg-4{background:linear-gradient(140deg,#0d1410 0%,#1a3020 55%,#0a1010 100%)}
.fw-bg-1::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 65% 65% at 45% 40%,rgba(168,48,95,.2) 0%,transparent 65%)}
.fw-bg-2::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 60% 35%,rgba(80,100,200,.14) 0%,transparent 65%)}
.fw-bg-3::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 35% 60%,rgba(160,80,200,.12) 0%,transparent 65%)}
.fw-bg-4::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(80,160,80,.1) 0%,transparent 65%)}
.fw-inner{aspect-ratio:3/2;position:relative}
.fw-card:first-child .fw-inner{aspect-ratio:unset;height:100%;min-height:460px}
.fw-content{position:absolute;bottom:0;left:0;right:0;padding:28px}
.fw-cat{font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--plum2);margin-bottom:6px}
.fw-title{font-family:var(--serif);font-size:clamp(1.1rem,2.2vw,1.7rem);color:#fff;line-height:1.25}
.fw-arrow{position:absolute;top:20px;right:20px;width:38px;height:38px;border:1px solid rgba(200,80,130,.3);display:flex;align-items:center;justify-content:center;color:var(--plum2);opacity:0;transform:translateY(6px);transition:all .3s}
.fw-card:hover .fw-arrow{opacity:1;transform:none}
.fw-more{margin-top:40px;text-align:center}
.btn-outline{display:inline-flex;align-items:center;gap:10px;font-family:var(--disp);font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);border:1.5px solid var(--ink);padding:13px 32px;text-decoration:none;border-radius:100px;transition:all .25s}
.btn-outline:hover{background:var(--ink);color:var(--white);gap:16px}

/* ── FOUNDER STRIP ── */
.founder-strip{background:var(--ink);padding:64px 52px;display:flex;align-items:center;justify-content:space-between;gap:40px;position:relative;overflow:hidden;border-top:3px solid var(--lime)}
.founder-strip::before{content:'';position:absolute;right:-80px;top:-80px;width:400px;height:400px;border-radius:50%;border:1px solid rgba(255,255,255,.1)}
.founder-strip::after{content:'';position:absolute;right:0px;top:40px;width:260px;height:260px;border-radius:50%;border:1px solid rgba(255,255,255,.07)}
.fs-l{position:relative;z-index:2}
.fs-label{font-family:var(--disp);font-size:.62rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--lime);margin-bottom:16px}
.fs-name{font-family:var(--disp);font-size:clamp(1.8rem,3.5vw,3rem);font-weight:800;color:var(--white);letter-spacing:-.02em;line-height:1}
.fs-roles{margin-top:8px;display:flex;gap:12px;flex-wrap:wrap}
.fs-role{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);background:rgba(255,255,255,.07);padding:5px 14px;border-radius:100px}
.fs-r{position:relative;z-index:2;max-width:520px}
.fs-quote{font-family:var(--serif);font-style:italic;font-size:clamp(1rem,1.8vw,1.4rem);color:rgba(255,255,255,.7);line-height:1.65;margin-bottom:24px}
.btn-wh{display:inline-flex;align-items:center;gap:8px;font-family:var(--disp);font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);background:var(--lime);padding:11px 26px;border-radius:100px;text-decoration:none;transition:all .25s}
.btn-wh:hover{background:#d4ff55;gap:14px}

/* ══════════════════════════════
   ABOUT PAGE
══════════════════════════════ */
#about-page{background:var(--bg)}
.about-hero{padding:120px 52px 80px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;border-bottom:1px solid var(--mist)}
.ah-l{}
.ah-tag{font-family:var(--disp);font-size:.62rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--plum);margin-bottom:18px}
.ah-h{font-family:var(--disp);font-size:clamp(2.8rem,6vw,6rem);font-weight:800;line-height:.9;letter-spacing:-.03em;color:var(--ink)}
.ah-h em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--plum)}
.ah-r{font-family:var(--serif);font-style:italic;font-size:clamp(1.1rem,2vw,1.7rem);color:var(--mid);line-height:1.6;padding-bottom:8px}

/* about body */
.about-body-sec{padding:80px 52px;display:grid;grid-template-columns:1fr 1fr;gap:80px;background:var(--white)}
.ab-copy{font-size:.98rem;color:var(--mid);line-height:2}
.ab-copy p+p{margin-top:20px}
.ab-right{}
/* differentiators */
.diffs{display:flex;flex-direction:column;gap:0}
.diff{padding:28px 0;border-top:1px solid var(--mist)}
.diff:last-child{border-bottom:1px solid var(--mist)}
.diff-title{font-family:var(--disp);font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:8px;display:flex;align-items:center;gap:12px}
.diff-dot{width:8px;height:8px;border-radius:50%;background:var(--plum);flex-shrink:0}
.diff-body{font-size:.85rem;color:var(--mid);line-height:1.85;padding-left:20px}

/* gayatri section */
.gayatri{background:var(--ink);padding:100px 52px;display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center}
.gay-l{}
.gay-avatar-wrap{width:280px;height:320px;background:linear-gradient(135deg,#180820,#3a0f40);border-radius:4px;position:relative;overflow:hidden;margin-bottom:32px}
.gay-avatar-wrap::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 70% at 40% 35%,rgba(194,245,66,.12) 0%,rgba(200,40,90,.25) 60%,transparent 100%)}
.gay-avatar-initial{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-size:7rem;font-weight:800;color:rgba(194,245,66,.15)}
.gay-name{font-family:var(--disp);font-size:2rem;font-weight:800;color:var(--white);letter-spacing:-.02em}
.gay-roles{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.gay-role{font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.4);background:rgba(255,255,255,.06);padding:5px 12px;border-radius:100px}
.gay-r{}
.gay-copy{font-size:.96rem;color:rgba(255,255,255,.55);line-height:2}
.gay-copy p+p{margin-top:18px}
.gay-belief{margin-top:44px;font-family:var(--serif);font-style:italic;font-size:clamp(1.3rem,2.5vw,2rem);color:var(--lime);line-height:1.5;border-left:2px solid var(--lime);padding-left:28px}

/* ══════════════════════════════
   PORTFOLIO PAGE
══════════════════════════════ */
#portfolio-page{background:var(--bg)}
.port-hero{padding:120px 52px 80px}
.port-hero-inner{display:flex;justify-content:space-between;align-items:flex-end}
.port-sub{max-width:400px;font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--mid);line-height:1.75;align-self:flex-end}

/* portfolio sections */
.port-section{padding:64px 52px;border-top:1px solid var(--mist)}
.port-section-label{font-family:var(--disp);font-size:.62rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--plum);margin-bottom:40px}
.port-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.port-card{background:var(--white);padding:40px 32px;position:relative;overflow:hidden;transition:background .3s}
.port-card:hover{background:var(--dust)}
.port-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--lime);transform:scaleY(0);transform-origin:top;transition:transform .4s}
.port-card:hover::before{transform:scaleY(1)}
.pc-cat{font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--plum2);margin-bottom:12px}
.pc-title{font-family:var(--disp);font-size:1.2rem;font-weight:700;color:var(--ink);margin-bottom:10px}
.pc-desc{font-size:.82rem;color:var(--mid);line-height:1.8}
.pc-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--plum);text-decoration:none;font-family:var(--disp);font-weight:600;transition:gap .25s}
.pc-link:hover{gap:12px}

/* approach strip */
.approach-strip{background:var(--ink);padding:80px 52px;display:flex;align-items:center;gap:80px}
.approach-label{font-family:var(--disp);font-size:.62rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--lime);flex-shrink:0}
.approach-words{display:flex;gap:20px;flex-wrap:wrap}
.approach-word{font-family:var(--disp);font-size:clamp(1.8rem,4vw,3.5rem);font-weight:800;color:rgba(255,255,255,.1);letter-spacing:-.02em;transition:color .3s;cursor:default}
.approach-word:hover{color:var(--lime)}

/* case studies teaser */
.case-studies{padding:80px 52px;background:var(--white)}
.cs-head{margin-bottom:48px}
.cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px}
.cs-card{background:var(--dust);padding:48px;position:relative;overflow:hidden;cursor:none;transition:background .3s}
.cs-card:hover{background:var(--mist)}
.cs-num{font-family:var(--disp);font-size:5rem;font-weight:800;color:rgba(168,48,95,.08);line-height:1;margin-bottom:20px}
.cs-cat{font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--plum);margin-bottom:10px}
.cs-title{font-family:var(--disp);font-size:1.4rem;font-weight:700;color:var(--ink);margin-bottom:12px}
.cs-desc{font-size:.84rem;color:var(--mid);line-height:1.85}
.cs-coming{position:absolute;top:24px;right:24px;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);background:var(--mist);padding:5px 12px;border-radius:100px}

/* ══════════════════════════════
   SERVICES PAGE
══════════════════════════════ */
#services-page{background:var(--ink)}
.srv-hero{padding:120px 52px 80px;border-bottom:1px solid rgba(255,255,255,.06)}
.srv-hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end}
.srv-hero .tag{color:var(--plum2)}
.srv-hero .h2{color:var(--white)}
.srv-hero .h2 em{color:var(--plum2)}
.srv-hero-r{font-family:var(--serif);font-style:italic;font-size:1.15rem;color:rgba(255,255,255,.45);line-height:1.75;align-self:flex-end}

/* service list */
.srv-full-list{max-width:1300px;margin:0 auto;padding:0 52px}
.srv-item{display:grid;grid-template-columns:80px 1fr auto;align-items:start;gap:40px;padding:52px 0;border-top:1px solid rgba(255,255,255,.06);transition:padding .35s}
.srv-item:last-child{border-bottom:1px solid rgba(255,255,255,.06)}
.srv-item:hover{padding:52px 20px}
.si-num{font-family:var(--disp);font-size:1rem;font-weight:700;color:rgba(168,48,95,.5)}
.si-body{}
.si-title{font-family:var(--disp);font-size:clamp(1.6rem,3vw,2.6rem);font-weight:800;color:var(--white);letter-spacing:-.02em;margin-bottom:14px;transition:color .3s}
.srv-item:hover .si-title{color:var(--lime)}
.si-desc{font-size:.9rem;color:rgba(255,255,255,.4);line-height:1.9;max-width:560px}
.si-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.si-tag{font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(200,200,200,.3);border:1px solid rgba(255,255,255,.1);padding:5px 12px;border-radius:100px;transition:all .3s}
.srv-item:hover .si-tag{color:var(--lime);border-color:rgba(194,245,66,.4)}
.si-arrow{font-size:1.8rem;color:var(--lime);align-self:center;transition:all .3s;opacity:0;transform:translateX(-10px)}
.srv-item:hover .si-arrow{opacity:1;transform:none}

/* how we work */
.how-we-work{background:var(--bg);padding:100px 52px}
.hww-head{margin-bottom:64px}
.hww-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--mist)}
.hww-step{padding:44px 32px;border-right:1px solid var(--mist);position:relative}
.hww-step:last-child{border-right:none}
.hww-step-bar{position:absolute;top:0;left:0;right:0;height:3px;background:var(--mist);transition:background .4s}
.hww-step:hover .hww-step-bar{background:linear-gradient(90deg,var(--plum),var(--lime))}
.hww-n{font-family:var(--disp);font-size:4rem;font-weight:800;color:rgba(194,245,66,.08);line-height:1;margin-bottom:20px}
.hww-title{font-family:var(--disp);font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:10px}
.hww-desc{font-size:.83rem;color:var(--mid);line-height:1.85}
.hww-sep{position:absolute;top:48px;right:-14px;font-size:1rem;color:rgba(168,48,95,.2);z-index:2}

/* ══════════════════════════════
   CONTACT PAGE
══════════════════════════════ */
#contact-page{background:var(--bg)}
.contact-hero{padding:120px 52px 80px;border-bottom:1px solid var(--mist);display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end}
.ch-h{font-family:var(--disp);font-size:clamp(2.8rem,6vw,6rem);font-weight:800;line-height:.9;letter-spacing:-.03em;color:var(--ink)}
.ch-h em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--plum)}
.ch-r{align-self:flex-end}
.ch-note{font-size:.95rem;color:var(--mid);line-height:1.9;max-width:400px}

.contact-main{display:grid;grid-template-columns:1fr 1.3fr;gap:0;min-height:600px}
.contact-l-side{padding:60px 52px;background:var(--white);border-right:1px solid var(--mist)}
.cl-section{margin-bottom:48px}
.cl-label{font-family:var(--disp);font-size:.6rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--plum);margin-bottom:16px}
.cl-val{font-size:.95rem;color:var(--ink);line-height:1.7}
.cl-val a{color:var(--ink);text-decoration:none;transition:color .25s}
.cl-val a:hover{color:var(--plum)}
.contact-r-side{padding:60px 52px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.cf-group{margin-bottom:28px}
.cf-group label{display:block;font-family:var(--disp);font-size:.6rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--plum);margin-bottom:10px}
.cf-group input,
.cf-group textarea,
.cf-group select{width:100%;background:transparent;border:none;border-bottom:1.5px solid var(--mist);color:var(--ink);font-family:var(--body);font-size:.92rem;padding:10px 0;outline:none;transition:border-color .3s;-webkit-appearance:none;cursor:none}
.cf-group input:focus,
.cf-group textarea:focus,
.cf-group select:focus{border-color:var(--plum)}
.cf-group input::placeholder,
.cf-group textarea::placeholder{color:var(--mist)}
.cf-group textarea{resize:none;height:110px}
.cf-group select option{background:var(--bg)}
.cf-submit{width:100%;background:var(--plum);color:var(--white);border:none;font-family:var(--disp);font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:18px;cursor:none;transition:background .25s,transform .2s;border-radius:0}
.cf-submit:hover{background:var(--plum2);transform:translateY(-2px)}

/* case studies on contact page */
.cs-on-contact{padding:80px 52px;background:var(--dust)}
.csc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin-top:48px}
.csc-card{background:var(--white);padding:40px 32px;position:relative;transition:background .3s;overflow:hidden}
.csc-card:hover{background:var(--bg)}
.csc-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--plum),var(--lime));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.csc-card:hover::after{transform:scaleX(1)}
.csc-icon{font-size:1.6rem;margin-bottom:20px}
.csc-title{font-family:var(--disp);font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:10px}
.csc-desc{font-size:.83rem;color:var(--mid);line-height:1.85}
.csc-badge{display:inline-block;margin-top:14px;font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mid);background:var(--mist);padding:4px 12px;border-radius:100px}

/* ══════════════════════════════
   GLOBAL REVEAL
══════════════════════════════ */
.r{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.r.on{opacity:1;transform:none}
.r-delay-1{transition-delay:.1s}
.r-delay-2{transition-delay:.2s}
.r-delay-3{transition-delay:.3s}
.r-delay-4{transition-delay:.4s}

/* ══════════════════════════════
   FOOTER
══════════════════════════════ */
footer{background:var(--ink);padding:44px 52px;display:flex;align-items:center;justify-content:space-between}
.ft-logo{height:34px}
.ft-logo img{height:100%;width:auto;mix-blend-mode:screen;filter:brightness(1.2)}
.ft-copy{font-size:.62rem;letter-spacing:.15em;color:rgba(255,255,255,.2)}
.ft-links{display:flex;gap:28px;list-style:none}
.ft-links a{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.25);text-decoration:none;transition:color .25s}
.ft-links a:hover{color:var(--plum2)}

/* ══════════════════════════════
   KEYFRAMES
══════════════════════════════ */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes slideUp{to{transform:translateY(0)}}

/* ══════════════════════════════
   RESPONSIVE
══════════════════════════════ */
@media(max-width:960px){
  nav{padding:16px 24px}
  nav.stuck{padding:12px 24px}
  .nav-center,.nav-cta{display:none}
  .hero-inner,.about-hero,.about-body-sec,.gayatri,.srv-hero-inner,.contact-hero,.contact-main{grid-template-columns:1fr;gap:40px}
  .hero-r{display:none}
  .hero-inner{padding:100px 24px 60px}
  .hero-bottom{padding:16px 24px;flex-direction:column;gap:12px;align-items:flex-start}
  .services-grid-home,.feat-work,.founder-strip,.port-hero,.port-section,.approach-strip,.case-studies,.how-we-work,.srv-full-list,.contact-hero,.contact-l-side,.contact-r-side,.cs-on-contact,.gay-avatar-wrap,.gayatri,.about-hero,.about-body-sec{padding-left:24px;padding-right:24px}
  .sgh-grid,.fw-grid,.port-cards,.cs-grid,.hww-steps,.csc-grid,.cf-row{grid-template-columns:1fr}
  .fw-card:first-child .fw-inner{min-height:300px;aspect-ratio:unset}
  .founder-strip{flex-direction:column;gap:32px}
  .approach-strip{flex-direction:column;gap:24px}
  .contact-main{grid-template-columns:1fr}
  .contact-l-side,.contact-r-side{padding:40px 24px}
  .srv-item{grid-template-columns:50px 1fr;gap:20px}
  .si-arrow{display:none}
  .hww-steps{grid-template-columns:1fr 1fr}
  .sgh-head,.fw-head,.srv-hero-inner,.hww-head{flex-direction:column;gap:20px;align-items:flex-start}
  footer{flex-direction:column;gap:16px;text-align:center;padding:32px 24px}
}

/* Ticker animation */
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }
