*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#000;
  --bg2:#0a0a0a;
  --bg3:#111;
  --bg4:#181818;
  --bg5:#222;
  --pink:#e8365d;
  --pink-dim:rgba(232,54,93,.12);
  --text:#fff;
  --text2:rgba(255,255,255,.85);
  --muted:rgba(255,255,255,.62);
  --dim:rgba(255,255,255,.78);
  --border:rgba(255,255,255,.08);
  --border2:rgba(255,255,255,.14);
  --sans:'Inter',sans-serif;
  --serif:'Instrument Serif',serif;
  --mono:'Space Mono',monospace;
  --radius:14px;
  --radius-sm:8px;
  --radius-pill:999px;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --ease-out:cubic-bezier(0,0,.2,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
}

html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  overflow-y:scroll;
}

/* GRAIN */
body::after{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;z-index:999;
  opacity:.018;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px 200px;
  animation:grain 8s steps(10) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)}10%{transform:translate(-5%,-10%)}
  20%{transform:translate(-15%,5%)}30%{transform:translate(7%,-25%)}
  40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}
  60%{transform:translate(15%,0)}70%{transform:translate(0,15%)}
  80%{transform:translate(3%,35%)}90%{transform:translate(-10%,10%)}
  100%{transform:translate(0,0)}
}
@media (prefers-reduced-motion: reduce){
  body::after{animation:none;opacity:.012}
}

::-webkit-scrollbar{width:2px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--pink);border-radius:2px}

main{position:relative;z-index:1}
/* CURSOR */
.cur-dot,.cur-ring{
  position:fixed;top:0;left:0;
  pointer-events:none;z-index:9999;
  border-radius:50%;
  will-change:transform;
}
.cur-dot{width:4px;height:4px;background:var(--pink)}
.cur-ring{
  width:34px;height:34px;
  border:1px solid rgba(232,54,93,.4);
  transition:transform .14s var(--ease),border-color .25s;
}
.cur-ring.hov{
  border-color:var(--pink);
}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;
  z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 2.5rem;
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--border);
  transition:padding .3s;
}
nav.scrolled{padding:.75rem 2.5rem}
.nav-logo{
  font-family:var(--sans);
  font-size:.95rem;font-weight:700;
  color:var(--text);text-decoration:none;
  letter-spacing:-.01em;
}
.nav-logo span{color:var(--pink)}
.nav-links{display:flex;gap:1.75rem;list-style:none}
.nav-links a{
  font-size:.82rem;font-weight:500;
  color:var(--muted);text-decoration:none;
  transition:color .2s;
  letter-spacing:-.01em;
}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-cta{
  display:flex;align-items:center;gap:.75rem;
}
.nav-ham{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:4px;
}
.nav-ham span{
  display:block;width:20px;height:1.5px;
  background:var(--text);transition:all .3s var(--ease);
}

/* MOBILE MENU */
.mob-nav{
  display:none;position:fixed;inset:0;
  background:var(--bg);z-index:490;
  flex-direction:column;align-items:center;
  justify-content:center;gap:2.5rem;
}
.mob-nav.open{display:flex}
.mob-nav a{
  font-family:var(--sans);
  font-size:2.5rem;font-weight:800;
  color:var(--text);text-decoration:none;
  letter-spacing:-.04em;
  transition:color .2s;
}
.mob-nav a:hover{color:var(--pink)}
.mob-close{
  position:absolute;top:1.5rem;right:2.5rem;
  background:var(--bg3);border:1px solid var(--border2);
  color:var(--dim);font-size:.85rem;cursor:pointer;
  width:36px;height:36px;border-radius:var(--radius-pill);
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.mob-close:hover{color:var(--text);border-color:var(--dim)}

/* PAGE WRAP */
.page{padding-top:72px}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--sans);
  font-size:.82rem;font-weight:600;
  letter-spacing:-.01em;
  text-decoration:none;
  padding:.65rem 1.25rem;
  border-radius:var(--radius-pill);
  transition:all .25s var(--ease);
  cursor:pointer;border:none;
  white-space:nowrap;
}
.btn-white{background:var(--text);color:#000}
.btn-white:hover{background:rgba(255,255,255,.9);transform:translateY(-1px)}
.btn-ghost{
  background:rgba(255,255,255,.06);
  color:var(--text);
  border:1px solid var(--border2);
}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.22)}
.btn-pink{background:var(--pink);color:#fff;font-weight:600}
.btn-pink:hover{background:#f04d6e;transform:translateY(-1px);box-shadow:0 8px 32px rgba(232,54,93,.3)}
.btn-sm{font-size:.75rem;padding:.45rem 1rem}
.btn-lg{font-size:.9rem;padding:.85rem 1.75rem}

/* HERO */
.hero{
  min-height:100vh;
  min-height:100dvh;
  display:flex;flex-direction:column;
  justify-content:center;align-items:center;
  text-align:center;
  padding:5rem 2.5rem 3rem;
  position:relative;overflow:hidden;
  isolation:isolate;
}
.hero-glow{
  position:absolute;pointer-events:none;
  border-radius:50%;filter:blur(140px);
}
.hero-glow-1{
  width:55vw;height:55vw;
  background:radial-gradient(var(--pink),transparent 70%);
  opacity:.08;top:-20%;right:-10%;
  animation:glowPulse 8s ease-in-out infinite alternate;
}
.hero-glow-2{
  width:40vw;height:40vw;
  background:radial-gradient(#7c3aed,transparent 70%);
  opacity:.06;bottom:-10%;left:-10%;
  animation:glowPulse 10s ease-in-out infinite alternate-reverse;
}
@keyframes glowPulse{
  from{opacity:.04;transform:scale(1)}
  to{opacity:.12;transform:scale(1.1)}
}
/* Stars bg */
.hero::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    radial-gradient(1px 1px at 20% 30%,rgba(255,255,255,.18) 0%,transparent 100%),
    radial-gradient(1px 1px at 65% 15%,rgba(255,255,255,.14) 0%,transparent 100%),
    radial-gradient(1px 1px at 80% 60%,rgba(255,255,255,.12) 0%,transparent 100%),
    radial-gradient(1px 1px at 40% 75%,rgba(255,255,255,.1) 0%,transparent 100%),
    radial-gradient(1px 1px at 10% 55%,rgba(255,255,255,.1) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 55% 85%,rgba(255,255,255,.12) 0%,transparent 100%),
    radial-gradient(1px 1px at 90% 25%,rgba(255,255,255,.08) 0%,transparent 100%);
  pointer-events:none;z-index:0;
}
.hero-eyebrow{
  font-size:.7rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);margin-bottom:1.25rem;
}
.hero-name{
  font-family:var(--sans);
  font-size:clamp(4rem,12vw,12rem);
  font-weight:900;
  line-height:.9;
  letter-spacing:-.04em;
  margin-bottom:0;
  text-transform:uppercase;
  opacity:0;
  transform:translateY(20px);
  animation:fadeUp .8s .1s var(--ease-out) forwards;
}
.hero-name .accent-dot{color:var(--pink)}
.hero-sub{
  font-size:clamp(1rem,2vw,1.25rem);
  color:var(--dim);max-width:52ch;
  line-height:1.7;font-weight:400;
  margin-top:1.5rem;margin-bottom:.5rem;
  opacity:0;animation:fadeUp .8s .35s var(--ease-out) forwards;
}
.hero-roles{
  font-size:.72rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);margin-bottom:2rem;
  opacity:0;animation:fadeUp .8s .5s var(--ease-out) forwards;
}
.hero-actions{
  display:flex;gap:.75rem;align-items:center;
  justify-content:center;flex-wrap:wrap;
  opacity:0;animation:fadeUp .8s .62s var(--ease-out) forwards;
  margin-bottom:2rem;
}
.hero-social{
  display:flex;gap:1.5rem;align-items:center;
  justify-content:center;
  opacity:0;animation:fadeUp .7s .75s var(--ease-out) forwards;
}
.hero-social a{
  color:var(--muted);text-decoration:none;
  font-size:.78rem;font-weight:500;
  letter-spacing:.04em;
  transition:color .2s;
}
.hero-social a:hover{color:var(--text)}
.hero-social-sep{color:var(--border2)}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}

/* SECTION DOT TITLE (Drishti style) */
.section-heading{
  font-size:clamp(2.5rem,6vw,5rem);
  font-weight:900;
  letter-spacing:-.04em;
  line-height:1;
  margin-bottom:3rem;
}
.section-heading .dot{color:var(--pink)}

/* SECTIONS */
section{padding:5rem 2.5rem}
section.tight{padding:3rem 2.5rem}
.s-label{
  font-size:.72rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin-bottom:1.25rem;
}
.s-title{
  font-family:var(--sans);
  font-size:clamp(2rem,5vw,4rem);
  font-weight:800;
  line-height:1.05;
  letter-spacing:-.03em;
  margin-bottom:1.25rem;
}
.s-title em{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  color:var(--pink);
}
.s-body{
  font-size:.95rem;color:var(--dim);
  max-width:56ch;line-height:1.8;
  font-weight:300;
}

/* BENTO GRID */
.bento{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:.75rem;
  margin-top:2.5rem;
}
.bento-card{
  background:var(--bg2);
  border-radius:var(--radius);
  border:1px solid var(--border);
  padding:2rem;
  position:relative;
  overflow:hidden;
  transition:border-color .3s,background .3s;
}
.bento-card:hover{border-color:var(--border2);background:var(--bg3)}
.bento-card.span-4{grid-column:span 4}
.bento-card.span-5{grid-column:span 5}
.bento-card.span-6{grid-column:span 6}
.bento-card.span-7{grid-column:span 7}
.bento-card.span-8{grid-column:span 8}
.bento-card.span-12{grid-column:span 12}
.bento-card.span-3{grid-column:span 3}
.bc-label{
  font-size:.65rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--pink);margin-bottom:1rem;
}
.bc-title{
  font-family:var(--sans);
  font-size:1.35rem;font-weight:700;
  letter-spacing:-.02em;line-height:1.2;
  margin-bottom:.65rem;
}
.bc-body{font-size:.85rem;color:var(--dim);line-height:1.75;font-weight:300}
.bc-num{
  font-family:var(--sans);
  font-size:clamp(3rem,7vw,6rem);
  font-weight:900;
  line-height:1;letter-spacing:-.04em;
  color:var(--text);
}
.bc-num span{color:var(--pink)}
.bc-num-label{
  font-size:.65rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin-top:.5rem;
}
.bc-accent{
  position:absolute;bottom:0;right:0;
  width:120px;height:120px;
  background:radial-gradient(var(--pink),transparent 70%);
  opacity:.12;pointer-events:none;
  border-radius:50%;filter:blur(30px);
}

/* EXPERIENCE CARDS (Drishti-style bordered cards) */
.xp-list{display:flex;flex-direction:column;gap:1rem;margin-top:2.5rem}
.xp-card{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:2rem 2rem 2rem 2.25rem;
  position:relative;
  transition:border-color .3s;
}
.xp-card:hover{border-color:var(--border2)}
.xp-card-top{
  display:flex;align-items:center;gap:.75rem;
  flex-wrap:wrap;margin-bottom:.85rem;
}
.xp-badge{
  font-size:.6rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:.25rem .65rem;border-radius:var(--radius-pill);
  background:rgba(74,222,128,.15);
  color:#4ade80;border:1px solid rgba(74,222,128,.3);
}
.xp-badge.past{
  background:rgba(255,255,255,.06);
  color:var(--muted);border-color:var(--border);
}
.xp-date{font-size:.72rem;color:var(--muted);font-weight:400}
.xp-role{
  font-size:1.1rem;font-weight:800;
  letter-spacing:-.03em;margin-bottom:.2rem;
}
.xp-org{
  font-size:1.1rem;font-weight:800;
  letter-spacing:-.03em;
  color:var(--pink);display:inline;
}
.xp-body{
  font-size:.875rem;color:var(--dim);
  line-height:1.8;margin-top:.75rem;
  font-weight:300;max-width:72ch;
}
.xp-points{list-style:none;margin-top:.85rem;display:flex;flex-direction:column;gap:.3rem}
.xp-points li{
  font-size:.85rem;color:var(--dim);
  line-height:1.7;padding-left:1.25rem;
  position:relative;font-weight:300;
}
.xp-points li::before{
  content:'·';position:absolute;left:0;
  color:var(--pink);font-size:1rem;top:-.1rem;
}
.xp-tags{margin-top:1.1rem}

/* Legacy timeline (kept for other pages) */
.timeline{margin-top:2.5rem}
.tl-item{
  display:grid;grid-template-columns:180px 1fr;gap:2rem;
  padding:2rem 0;border-top:1px solid var(--border);
}
.tl-item:last-child{border-bottom:1px solid var(--border)}
.tl-date{font-size:.78rem;font-weight:500;color:var(--muted);padding-top:.2rem;line-height:1.55}
.tl-content{padding-left:1.5rem}
.tl-role{font-size:1.05rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.2rem}
.tl-org{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--pink);margin-bottom:.85rem}
.tl-list{list-style:none;display:flex;flex-direction:column;gap:.35rem}
.tl-list li{font-size:.85rem;color:var(--dim);line-height:1.7;padding-left:1.1rem;position:relative;font-weight:300}
.tl-list li::before{content:'—';position:absolute;left:0;color:var(--pink);font-size:.75rem}

/* TAGS */
.tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem}
.tag{
  font-size:.7rem;font-weight:500;
  color:var(--dim);
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  padding:.3rem .7rem;border-radius:var(--radius-pill);
  transition:all .2s;letter-spacing:-.01em;
}
.tag:hover{color:var(--text);border-color:var(--border2);background:rgba(255,255,255,.1)}

/* PILLS */
.pill{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.65rem;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;
  padding:.3rem .75rem;border-radius:var(--radius-pill);
  border:1px solid;white-space:nowrap;
}
.pill-green{color:#4ade80;border-color:rgba(74,222,128,.3);background:rgba(74,222,128,.06)}
.pill-pink{color:var(--pink);border-color:rgba(232,54,93,.35);background:rgba(232,54,93,.08)}
.pill-white{color:var(--text);border-color:var(--border2);background:rgba(255,255,255,.06)}
.pill-gold{color:#f0b429;border-color:rgba(240,180,41,.3);background:rgba(240,180,41,.06)}

/* TWO COL */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start}
.two-col.ratio-4-8{grid-template-columns:4fr 8fr}
.two-col.ratio-5-7{grid-template-columns:5fr 7fr}

/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s var(--ease-out),transform .65s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.08s}
.reveal-delay-2{transition-delay:.16s}
.reveal-delay-3{transition-delay:.26s}

/* ACCORDION */
.acc-item{border-top:1px solid var(--border);cursor:pointer}
.acc-item:last-child{border-bottom:1px solid var(--border)}
.acc-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.5rem 0;gap:1rem;
}
.acc-title{
  font-size:clamp(1.1rem,2.5vw,1.5rem);
  font-weight:700;letter-spacing:-.02em;
  color:var(--dim);transition:color .3s;
}
.acc-item.active .acc-title,.acc-head:hover .acc-title{color:var(--text)}
.acc-icon{
  font-size:.9rem;color:var(--muted);
  transition:transform .3s var(--ease),color .3s;
  flex-shrink:0;
}
.acc-item.active .acc-icon{transform:rotate(45deg);color:var(--pink)}
.acc-body{
  max-height:0;overflow:hidden;
  transition:max-height .4s var(--ease-out),padding .4s;
}
.acc-item.active .acc-body{max-height:300px}
.acc-content{padding-bottom:1.5rem;font-size:.9rem;color:var(--dim);line-height:1.8;font-weight:300}

/* LINK ROW */
.link-stack{display:flex;flex-direction:column;border-top:1px solid var(--border)}
.link-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem 0;border-bottom:1px solid var(--border);
  text-decoration:none;color:inherit;transition:all .25s;
}
.link-row:hover{padding-left:.75rem}
.lr-left{display:flex;flex-direction:column;gap:.2rem}
.lr-label{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.lr-value{font-size:1rem;font-weight:600;letter-spacing:-.02em;color:var(--text)}
.lr-arr{font-size:1rem;color:var(--muted);transition:all .3s}
.link-row:hover .lr-arr{color:var(--pink);transform:translate(4px,-4px)}

/* FOOTER */
footer{
  padding:2.5rem 2.5rem;
  border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1.25rem;background:var(--bg);
}
.foot-logo{font-weight:800;font-size:.9rem;letter-spacing:-.01em}
.foot-logo span{color:var(--pink)}
.foot-links{display:flex;gap:1.75rem}
.foot-links a{
  font-size:.75rem;font-weight:500;
  color:var(--text2);text-decoration:none;
  transition:color .2s;
}
.foot-links a:hover{color:var(--text)}
.foot-copy{font-size:.72rem;color:var(--dim)}

/* FULL CALLOUT */
.callout{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:3.5rem;
  text-align:center;margin-top:2.5rem;
}
.callout h2{
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:900;letter-spacing:-.04em;margin-bottom:1rem;
}
.callout h2 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--pink)}
.callout p{font-size:.9rem;color:var(--dim);max-width:46ch;margin:0 auto 2rem;line-height:1.8;font-weight:300}
.callout-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}

/* MARQUEE */
.marquee-wrap{
  overflow:hidden;border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);padding:.75rem 0;
  background:var(--bg2);
}
.marquee-track{
  display:flex;gap:4rem;white-space:nowrap;
  animation:scroll-x 30s linear infinite;
}
.marquee-track:hover{animation-play-state:paused}
@keyframes scroll-x{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-track span{
  font-size:.8rem;font-weight:500;letter-spacing:.06em;
  text-transform:uppercase;color:var(--muted);
}
.marquee-track em{color:var(--pink);font-style:normal;margin:0 .25rem}

/* DIVIDER */
.divider{height:1px;background:var(--border)}

/* RESEARCH CARD */
.rc{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:2.5rem;margin-bottom:.75rem;
  transition:border-color .3s;
}
.rc:hover{border-color:var(--border2)}
.rc-top{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1.75rem}
.rc-title{font-size:clamp(1.35rem,3vw,2rem);font-weight:800;letter-spacing:-.03em;margin-bottom:1rem}
.rc-title em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--pink)}
.rc-body{font-size:.875rem;color:var(--dim);line-height:1.85;margin-bottom:1.5rem;max-width:70ch;font-weight:300}
.rc-points{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem}
.rc-points li{
  font-size:.85rem;color:var(--dim);line-height:1.7;
  padding-left:1.75rem;position:relative;font-weight:300;
}
.rc-points li::before{
  content:'//';position:absolute;left:0;
  color:var(--pink);font-weight:700;font-size:.65rem;
  font-family:var(--mono);top:.2rem;
}

/* ITP BLOCK */
.itp-block{background:var(--bg3);border-radius:var(--radius-sm);padding:2rem;margin-bottom:1rem}
.itp-block-label{font-family:var(--mono);font-size:.6rem;color:var(--pink);letter-spacing:.12em;margin-bottom:1rem}
.log-line{display:flex;gap:1.25rem;padding:.65rem 0;border-bottom:1px solid var(--border)}
.log-line:last-child{border-bottom:none}
.log-tag{font-family:var(--mono);font-size:.62rem;color:var(--pink);min-width:80px;padding-top:.15rem;flex-shrink:0}
.log-text{font-size:.85rem;color:var(--dim);line-height:1.7;font-weight:300}

/* RESPONSIVE */
@media(max-width:1024px){
  .bento-card.span-4{grid-column:span 6}
  .bento-card.span-3{grid-column:span 6}
  .bento-card.span-5{grid-column:span 12}
  .bento-card.span-7{grid-column:span 12}
  .bento-card.span-8{grid-column:span 12}
}
@media(max-width:900px){
  .two-col,.two-col.ratio-4-8,.two-col.ratio-5-7{grid-template-columns:1fr;gap:2.5rem}
  .tl-item{grid-template-columns:1fr;gap:.5rem}
  .tl-content{padding-left:0}
}
@media(max-width:768px){
  nav{padding:.85rem 1.5rem}
  .nav-links{display:none}
  .nav-cta{display:none}
  .nav-ham{display:flex}
  section{padding:3.5rem 1.5rem}
  .hero{padding:1.5rem;padding-top:80px;min-height:100svh}
  .hero-name{font-size:clamp(3.25rem,18vw,6rem)}
  .hero-actions{flex-wrap:wrap}
  .hero-social{gap:1rem;flex-wrap:wrap}
  footer{flex-direction:column;text-align:center}
  .foot-links{justify-content:center;flex-wrap:wrap;gap:1rem}
  .bento-card.span-4,.bento-card.span-5,.bento-card.span-6,.bento-card.span-7,.bento-card.span-8,.bento-card.span-3{grid-column:span 12}
  .section-heading{font-size:clamp(2rem,12vw,3rem);margin-bottom:2rem}
  .xp-card{padding:1.5rem}
}

/* TOOLKIT ICONS */
.toolkit-icons{
  display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap;
}
.toolkit-icons svg, .toolkit-icons img{
  transition:transform .3s var(--ease),filter .3s;
  filter:grayscale(1) opacity(0.5);
}
.toolkit-icons svg:hover, .toolkit-icons img:hover{
  transform:scale(1.1) translateY(-3px);
  filter:grayscale(0) opacity(1);
}

/* HOVER IMAGE GALLERY */
#hover-gallery-container{position:relative}
#hover-image-display{
  position:fixed;top:0;left:0;pointer-events:none;z-index:100;
  opacity:0;transform:scale(0.8) translate(-50%,-50%);
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  width:300px;height:200px;
  border-radius:var(--radius);overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,0.5);
  border:1px solid var(--border);
}
#hover-image-display.active{
  opacity:1;transform:scale(1) translate(-50%,-50%);
}
#hover-img-tag{
  width:100%;height:100%;object-fit:cover;
}
.idx-link{position:relative;z-index:2;} /* ensure links are above other elements */

/* MASONRY GRID */
.masonry-grid{
  column-count:3;column-gap:1rem;margin-top:2rem;
}
.masonry-item{
  break-inside:avoid;margin-bottom:1rem;
}
@media(max-width:768px){.masonry-grid{column-count:2;}}
@media(max-width:480px){.masonry-grid{column-count:1;}}

/* LIQUID ETHER BACKGROUND */
.liquid-bg{
  position:fixed;inset:0;z-index:0;
  overflow:hidden;pointer-events:none;
}
.liquid-orb{
  position:absolute;border-radius:50%;
  filter:blur(80px);opacity:0.6;
  animation:floatOrb 20s infinite alternate ease-in-out;
}
.orb-1{
  width:60vw;height:60vw;background:rgba(232,54,93,0.25); /* pink */
  top:-10%;left:-10%;
}
.orb-2{
  width:70vw;height:70vw;background:rgba(124,58,237,0.2); /* purple */
  bottom:-20%;right:-10%;animation-delay:-5s;
}
.orb-3{
  width:50vw;height:50vw;background:rgba(96,165,250,0.2); /* blue */
  top:40%;left:50%;animation-delay:-10s;
}
@keyframes floatOrb{
  0%{transform:translate(0,0) scale(1);}
  33%{transform:translate(5vw,10vh) scale(1.1);}
  66%{transform:translate(-10vw,5vh) scale(0.9);}
  100%{transform:translate(0,-10vh) scale(1);}
}
