/* ── RESET & VARIABLES ── */
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --bg:#07091a;--surface:#0b0f26;--surface2:#101530;--card:#111830;
  --blue-dim:#1a2a50;--blue-mid:#1e3870;--blue:#2358a8;--blue-bright:#3a78d8;
  --blue-light:#6aaae8;--blue-glow:#4a90f8;
  --teal:#1a8888;--teal-light:#2aaaba;
  --gold:#c8a84a;--gold-light:#e0cc80;--gold-dim:rgba(200,168,74,0.28);
  --crimson:#b83232;--crimson-bright:#d94040;--crimson-dim:rgba(184,50,50,0.18);
  --rose:rgba(200,70,70,0.1);
  --text:#eef4ff;--text-muted:#a8c8e8;--text-dim:#526880;
  --border:#0e1830;--border-mid:#162248;
}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'EB Garamond',serif;overflow-x:hidden;line-height:1.7;}
::selection{background:rgba(184,50,50,0.25);color:var(--text);}
::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--blue-mid),var(--crimson-dim));}

/* ── CURSOR GLOW ── */
#cursor-glow{
  position:fixed;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(74,144,248,0.06) 0%,transparent 68%);
  pointer-events:none;z-index:2;
  transform:translate(-50%,-50%);
  left:-260px;top:-260px;
  transition:left 0.16s ease-out,top 0.16s ease-out;
}

/* ── AURORA ── */
#aurora{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;}
.aorb{
  position:absolute;border-radius:50%;
  width:var(--w,600px);height:var(--w,600px);
  top:var(--top,50%);left:var(--left,50%);
  transform:translate(-50%,-50%);
  background:radial-gradient(circle,var(--c,rgba(35,88,168,0.5)),transparent 70%);
  filter:blur(50px);
  animation:orbDrift var(--dur,20s) ease-in-out infinite alternate;
}
@keyframes orbDrift{
  from{transform:translate(-50%,-50%);}
  to{transform:translate(calc(-50% + var(--tx,0px)),calc(-50% + var(--ty,0px))) scale(var(--s,1));}
}

/* ── PROGRESS ── */
#progress{
  position:fixed;top:0;left:0;height:2px;width:0%;z-index:999;
  background:linear-gradient(90deg,var(--blue),var(--teal-light),var(--gold),var(--crimson));
  transition:width 0.1s;
}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;height:84px;
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:center;padding:0 52px;transition:all 0.4s;
}
nav.scrolled{background:rgba(7,9,26,0.96);backdrop-filter:blur(28px);border-bottom:1px solid var(--border);}

.nav-brand{display:flex;flex-direction:column;text-decoration:none;gap:3px;}
.brand-name{
  font-family:'Cormorant Garamond',serif;font-size:46px;font-weight:700;
  color:var(--text);letter-spacing:5px;line-height:1;
  text-shadow:0 0 50px rgba(106,170,232,0.5),0 0 100px rgba(58,120,216,0.2);
}
.brand-sub{
  font-family:'Josefin Sans',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:8px;color:var(--blue-light);text-transform:uppercase;
}

.nav-links{
  display:flex;align-items:center;justify-content:center;
  gap:44px;list-style:none;position:relative;
}

/* sliding pill indicator */
.nav-pill{
  position:absolute;bottom:-2px;height:2px;
  background:linear-gradient(90deg,var(--blue-glow),var(--teal-light),var(--gold));
  border-radius:2px;
  /* spring overshoot easing — snappy forward, soft settle */
  transition:left 0.22s cubic-bezier(0.34,1.4,0.64,1),
             width 0.22s cubic-bezier(0.34,1.4,0.64,1),
             opacity 0.18s ease;
  opacity:0;pointer-events:none;
  box-shadow:0 0 10px rgba(74,144,248,0.55),0 0 24px rgba(74,144,248,0.2);
}

/* dot above active link */
.nav-dot{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%) scale(0);
  width:4px;height:4px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 8px var(--gold),0 0 16px rgba(200,168,74,0.4);
  opacity:0;
  transition:opacity 0.22s ease,transform 0.3s cubic-bezier(0.34,1.56,0.64,1);
}

.nav-links a{
  font-family:'Josefin Sans',sans-serif;font-size:12px;font-weight:700;
  letter-spacing:3.5px;color:var(--text-muted);text-decoration:none;
  text-transform:uppercase;position:relative;padding:6px 0 10px;
  transition:color 0.18s ease;overflow:visible;
}

.nav-links a .nav-lbl{
  display:inline-block;position:relative;
  transition:transform 0.22s cubic-bezier(0.34,1.56,0.64,1),
             letter-spacing 0.22s ease,
             text-shadow 0.22s ease;
}
.nav-links a:hover .nav-lbl,
.nav-links a.active .nav-lbl{
  transform:translateY(-2px);
  text-shadow:0 0 20px rgba(106,170,232,0.6);
}

.nav-links a:hover,
.nav-links a.active{ color:var(--text); }

.nav-links a.active .nav-dot{
  opacity:1;
  transform:translateX(-50%) scale(1);
}
.nav-links a:not(.active) .nav-dot{
  opacity:0;
  transform:translateX(-50%) scale(0);
}

.hamburger{display:none;flex-direction:column;gap:6px;cursor:pointer;padding:8px;background:none;border:none;justify-self:end;}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--blue-light);transition:all 0.3s;}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* ── MOBILE MENU ── */
.mob-menu{
  display:none;
  position:fixed;top:72px;right:16px;
  background:rgba(11,15,38,0.97);
  backdrop-filter:blur(24px);
  border:1px solid rgba(74,144,248,0.18);
  border-radius:14px;
  box-shadow:0 8px 40px rgba(0,0,0,0.55),0 0 0 1px rgba(74,144,248,0.06);
  z-index:250;
  flex-direction:column;
  min-width:200px;
  padding:10px 0;
  transform-origin:top right;
  animation:menuDrop 0.18s cubic-bezier(.22,1,.36,1) forwards;
}
.mob-menu.open{display:flex;}
.mob-menu a{
  font-family:'Josefin Sans',sans-serif;
  font-size:12px;font-weight:700;
  letter-spacing:.2em;
  color:var(--text-muted);
  text-decoration:none;
  text-transform:uppercase;
  padding:13px 24px;
  transition:color 0.2s,background 0.2s;
  border-radius:0;
}
.mob-menu a:hover{color:var(--blue-light);background:rgba(74,144,248,0.07);}
.mob-menu a:first-child{border-radius:14px 14px 0 0;}
.mob-menu a:last-child{border-radius:0 0 14px 14px;}
@keyframes menuDrop{from{opacity:0;transform:scale(0.95) translateY(-6px);}to{opacity:1;transform:scale(1) translateY(0);}}

/* ── PARTICLES ── */
#particles{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden;}
.pt{
  position:absolute;border-radius:50%;cursor:pointer;pointer-events:all;
  background:radial-gradient(circle at 32% 28%, rgba(255,255,255,0.22), rgba(74,144,248,0.08) 50%, transparent 78%);
  border:1px solid rgba(100,170,240,0.35);
  box-shadow:0 0 16px rgba(74,144,248,0.15), inset 0 0 8px rgba(255,255,255,0.08);
  animation:floatUp linear infinite;
  transition:border-color 0.3s, box-shadow 0.3s;
}
.pt:hover{border-color:rgba(200,168,74,0.6);box-shadow:0 0 28px rgba(200,168,74,0.25), inset 0 0 12px rgba(255,255,255,0.12);}
@keyframes floatUp{
  0%  {transform:translateY(100vh) translateX(0);   opacity:0;}
  6%  {opacity:0.85;}
  45% {transform:translateY(52vh)  translateX(18px);}
  75% {transform:translateY(25vh)  translateX(-12px);}
  95% {opacity:0.35;}
  100%{transform:translateY(-90px) translateX(6px); opacity:0;}
}
/* Easter egg keyframes */
@keyframes popBubble{0%{transform:scale(1);opacity:0.8;}100%{transform:scale(3.5);opacity:0;}}
@keyframes goldenFlash{0%,100%{opacity:0;}20%,80%{opacity:1;}}
@keyframes secretFadeUp{from{opacity:0;transform:translate(-50%,-40%);}to{opacity:1;transform:translate(-50%,-50%);}}

/* ── HERO ── */
#home{min-height:100vh;display:flex;align-items:center;padding:120px 60px 80px;position:relative;overflow:hidden;}
.hero-glow{
  position:absolute;width:900px;height:900px;border-radius:50%;
  background:radial-gradient(circle,rgba(35,88,168,0.14) 0%,transparent 70%);
  top:50%;left:42%;transform:translate(-50%,-50%);pointer-events:none;
  animation:breathe 7s ease-in-out infinite;
}
@keyframes breathe{
  0%,100%{transform:translate(-50%,-50%) scale(1);opacity:0.7;}
  50%{transform:translate(-50%,-50%) scale(1.2);opacity:1;}
}
.hero-ring{
  position:absolute;right:-60px;top:50%;transform:translateY(-50%);
  width:600px;height:600px;border-radius:50%;
  border:1px solid rgba(58,120,216,0.1);
  animation:ringRotate 60s linear infinite;pointer-events:none;
}
.hero-ring::before{content:'';position:absolute;inset:55px;border-radius:50%;border:1px solid rgba(42,170,186,0.07);}
.hero-ring::after{content:'';position:absolute;inset:140px;border-radius:50%;border:1px solid rgba(200,168,74,0.06);}
@keyframes ringRotate{to{transform:translateY(-50%) rotate(360deg);}}

.hero-inner{position:relative;z-index:1;max-width:860px;}

.h-orn{display:flex;align-items:center;gap:14px;margin-bottom:28px;opacity:0;animation:fadeUp 0.9s 0.1s forwards;}
.h-orn-line{height:1px;width:52px;background:linear-gradient(to right,transparent,var(--gold-dim));}
.h-orn-line--r{background:linear-gradient(to left,transparent,var(--gold-dim));}
.h-orn-glyph{font-size:10px;color:var(--gold);animation:ornSpin 30s linear infinite;display:inline-block;}
@keyframes ornSpin{to{transform:rotate(360deg);}}

.h-eye{
  font-family:'Josefin Sans',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:9px;color:var(--teal-light);text-transform:uppercase;
  margin-bottom:28px;display:flex;align-items:center;gap:16px;
  opacity:0;animation:fadeUp 0.9s 0.25s forwards;
}
.h-eye::before{content:'';width:36px;height:1px;background:var(--teal);}

.h-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(64px,9vw,128px);font-weight:300;line-height:0.96;
  color:var(--text);margin-bottom:48px;
  opacity:0;animation:fadeUp 1s 0.45s forwards;
}
.h-title em{
  display:block;font-style:italic;
  background:linear-gradient(135deg,var(--blue-light) 0%,var(--teal-light) 50%,var(--gold-light) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;background-size:200%;
  animation:shimmer 6s ease infinite;
}
@keyframes shimmer{0%,100%{background-position:0%;}50%{background-position:100%;}}

.h-sub{display:flex;align-items:flex-start;gap:28px;margin-bottom:56px;opacity:0;animation:fadeUp 0.9s 0.65s forwards;}
.h-line{width:2px;min-height:90px;background:linear-gradient(to bottom,var(--crimson),var(--blue-mid),transparent);flex-shrink:0;margin-top:4px;}
.h-quote{font-family:'EB Garamond',serif;font-size:21px;font-style:italic;color:var(--text-muted);line-height:1.85;}

.h-cta{display:flex;gap:18px;flex-wrap:wrap;opacity:0;animation:fadeUp 0.9s 0.82s forwards;}
.h-commission-cta{display:block;margin-top:18px;font-family:'Josefin Sans',sans-serif;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);opacity:0;animation:fadeUp 0.9s 1.1s forwards;text-decoration:none;transition:color .25s;}
.h-commission-cta:hover{color:var(--gold-light);}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Josefin Sans',sans-serif;font-size:10px;font-weight:700;
  letter-spacing:4px;text-transform:uppercase;padding:18px 44px;
  text-decoration:none;cursor:pointer;border:none;
  transition:transform 0.2s ease,box-shadow 0.3s;
  position:relative;overflow:hidden;
}
.btn-bg{position:absolute;inset:0;transform:translateX(-100%);transition:transform 0.4s;}
.btn:hover .btn-bg{transform:translateX(0);}
.btn-txt{position:relative;z-index:1;}
.btn-primary{background:var(--blue);color:var(--text);}
.btn-primary .btn-bg{background:var(--blue-bright);}
.btn-primary:hover{box-shadow:0 0 50px rgba(58,120,216,0.4);}
.btn-outline{background:transparent;color:var(--blue-light);border:1px solid var(--blue-mid);}
.btn-outline .btn-bg{background:rgba(35,88,168,0.22);}
.btn-outline:hover{box-shadow:0 0 30px rgba(35,88,168,0.2);}

/* ── SECTIONS ── */
section{position:relative;z-index:1;}
.sec{padding:120px 60px;}
.sec-hd{margin-bottom:76px;}
.kicker{
  font-family:'Josefin Sans',sans-serif;font-size:10px;font-weight:700;
  letter-spacing:8px;text-transform:uppercase;
  display:flex;align-items:center;gap:18px;margin-bottom:24px;
}
.kicker::before{content:'';width:28px;height:1.5px;}

/* Alternate kicker colors per section */
#poems .kicker{color:var(--teal-light);}
#poems .kicker::before{background:var(--teal);}
#music .kicker{color:var(--gold);}
#music .kicker::before{background:var(--gold);}
#about .kicker{color:var(--crimson-bright);}
#about .kicker::before{background:var(--crimson);}
#commission .kicker{color:var(--blue-light);}
#commission .kicker::before{background:var(--blue);}

.sec-title{font-family:'Cormorant Garamond',serif;font-size:clamp(52px,5.5vw,84px);font-weight:300;line-height:1.08;color:var(--text);}
.sec-title em{font-style:italic;color:var(--blue-light);}

/* ── SCROLL REVEAL ── */
.rv{opacity:0;transform:translateY(36px);transition:opacity 0.85s cubic-bezier(.22,1,.36,1),transform 0.85s cubic-bezier(.22,1,.36,1);}
.rv.vis{opacity:1;transform:none;}
.rv.d1{transition-delay:0.12s;}.rv.d2{transition-delay:0.22s;}
.rv.d3{transition-delay:0.32s;}.rv.d4{transition-delay:0.42s;}

/* ── POEMS SECTION ── */
#poems{background:var(--bg);}
.filter-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:56px;}
.fbtn{
  font-family:'Josefin Sans',sans-serif;font-size:9px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;padding:11px 24px;
  border:1px solid var(--border-mid);background:transparent;color:var(--text-muted);
  cursor:pointer;transition:all 0.3s;
}
.fbtn:hover{background:rgba(35,88,168,0.15);border-color:var(--blue);color:var(--text);}
.fbtn.on{background:var(--blue);border-color:var(--blue);color:var(--text);box-shadow:0 0 24px rgba(35,88,168,0.3);}

.pgrid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:1px;background:var(--border);perspective:1200px;
}

.pc{
  background:var(--bg);padding:48px 44px;cursor:pointer;
  position:relative;overflow:hidden;
  transition:background 0.35s,opacity 0.4s;
  transform-style:preserve-3d;
}
.pc-glow{
  position:absolute;width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(58,120,216,0.1),transparent 70%);
  top:-150px;right:-150px;
  transition:all 0.6s;opacity:0;pointer-events:none;
}
.pc:hover .pc-glow{opacity:1;top:-30px;right:-30px;}
.pc:hover{background:var(--surface);}
.pc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;}
.pc-num{font-family:'Josefin Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:4px;color:var(--blue-dim);}
.pc-chip{
  font-family:'Josefin Sans',sans-serif;font-size:8px;font-weight:700;
  letter-spacing:2px;padding:4px 11px;text-transform:uppercase;
}

/* Chip color variants by position */
.pc:nth-child(3n+1) .pc-chip{color:var(--teal-light);background:rgba(26,136,136,0.1);border:1px solid rgba(26,136,136,0.22);}
.pc:nth-child(3n+2) .pc-chip{color:var(--gold);background:rgba(200,168,74,0.08);border:1px solid rgba(200,168,74,0.2);}
.pc:nth-child(3n)   .pc-chip{color:var(--crimson-bright);background:var(--crimson-dim);border:1px solid rgba(184,50,50,0.25);}

.pc-title{
  font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:400;
  color:var(--text);margin-bottom:14px;line-height:1.15;
  transition:transform 0.3s;
}
.pc:hover .pc-title{transform:translateY(-3px);}
.pc-excerpt{font-family:'EB Garamond',serif;font-size:17px;font-style:italic;color:var(--text-muted);line-height:1.8;}
.pc-read{
  display:flex;align-items:center;gap:8px;margin-top:28px;
  font-family:'Josefin Sans',sans-serif;font-size:9px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;
  opacity:0;transform:translateX(-10px);transition:all 0.35s;
}
.pc-read::after{content:'';width:20px;height:1px;background:currentColor;transition:width 0.3s;}
.pc:hover .pc-read{opacity:1;transform:none;}
.pc:hover .pc-read::after{width:44px;}

/* Read prompt color variants */
.pc:nth-child(3n+1) .pc-read{color:var(--blue-bright);}
.pc:nth-child(3n+2) .pc-read{color:var(--gold);}
.pc:nth-child(3n)   .pc-read{color:var(--crimson-bright);}

.pgrid.has-hover .pc:not(.pc-focused){opacity:0.35;}

.pc::after{
  content:'';position:absolute;inset:0;
  border:1px solid transparent;transition:border-color 0.4s;pointer-events:none;
}
.pc:nth-child(3n+1):hover::after{border-color:rgba(58,120,216,0.2);}
.pc:nth-child(3n+2):hover::after{border-color:rgba(200,168,74,0.2);}
.pc:nth-child(3n):hover::after{border-color:rgba(184,50,50,0.2);}

/* ── POEM MODAL ── */
.mbg{display:none;position:fixed;inset:0;background:rgba(7,9,26,0.97);z-index:300;overflow-y:auto;}
.mbg.open{display:flex;justify-content:center;padding:64px 24px;}
.mbox{max-width:700px;width:100%;animation:mIn 0.45s cubic-bezier(.22,1,.36,1) forwards;}
.mnav{display:flex;align-items:center;justify-content:space-between;margin-bottom:64px;}
.mclose{
  display:flex;align-items:center;gap:12px;
  font-family:'Josefin Sans',sans-serif;font-size:10px;font-weight:700;
  letter-spacing:4px;color:var(--text-muted);cursor:pointer;
  background:none;border:none;text-transform:uppercase;transition:color 0.3s;
}
.mclose::before{content:'';width:28px;height:1px;background:currentColor;transition:width 0.3s;}
.mclose:hover{color:var(--crimson-bright);}
.mclose:hover::before{width:52px;}
.marrows{display:flex;gap:12px;}
.marr{
  width:44px;height:44px;border:1px solid var(--border-mid);
  background:transparent;color:var(--text-muted);font-size:16px;
  cursor:pointer;transition:all 0.3s;display:flex;align-items:center;justify-content:center;
}
.marr:hover{border-color:var(--gold);color:var(--gold);background:rgba(200,168,74,0.08);}
.mk{font-family:'Josefin Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:6px;color:var(--crimson-bright);text-transform:uppercase;margin-bottom:16px;}
.mt{font-family:'Cormorant Garamond',serif;font-size:clamp(46px,6vw,72px);font-weight:300;color:var(--text);line-height:1.04;margin-bottom:10px;}
.mby{font-family:'Josefin Sans',sans-serif;font-size:9px;font-weight:600;letter-spacing:5px;color:var(--text-muted);text-transform:uppercase;margin-bottom:56px;}
.mline{width:64px;height:1px;background:linear-gradient(to right,var(--crimson),var(--gold-dim),transparent);margin-bottom:56px;}
.mpb{font-family:'Cormorant Garamond',serif;font-size:25px;font-weight:300;line-height:2.15;color:var(--text);user-select:none;-webkit-user-select:none;}
.mpb p{margin-bottom:36px;}
.mpb p:last-child{margin-bottom:0;}
.mcopy{font-family:'Josefin Sans',sans-serif;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin-top:48px;padding-top:24px;border-top:1px solid var(--border-mid);}

/* ── MUSIC SECTION ── */
#music{background:var(--surface);}
.music-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;max-width:1060px;margin:0 auto;}
.embed-wrap{background:var(--card);border:1px solid var(--border-mid);overflow:hidden;border-top:2px solid var(--gold);}
.embed-lbl{padding:20px 24px 0;font-family:'Josefin Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:4px;color:var(--gold);text-transform:uppercase;}
.mquote{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:300;font-style:italic;line-height:1.28;color:var(--text);margin-bottom:28px;}
.mquote em{color:var(--gold-light);}
.mdesc{font-family:'EB Garamond',serif;font-size:19px;color:var(--text-muted);line-height:1.95;margin-bottom:28px;}
.genres{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:28px;}
.genre-pill{
  font-family:'Josefin Sans',sans-serif;font-size:8px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;padding:7px 15px;transition:all 0.3s;
}
.genre-pill:nth-child(1){border:1px solid var(--blue-mid);color:var(--blue-light);}
.genre-pill:nth-child(2){border:1px solid var(--teal);color:var(--teal-light);}
.genre-pill:nth-child(3){border:1px solid var(--gold-dim);color:var(--gold);}
.genre-pill:nth-child(4){border:1px solid var(--crimson-dim);color:var(--crimson-bright);}
.genre-pill:nth-child(5){border:1px solid var(--blue-mid);color:var(--blue-light);}
.genre-pill:hover{background:rgba(255,255,255,0.05);}
.mviz{display:flex;align-items:flex-end;gap:4px;height:52px;margin-bottom:28px;}
.mbar{border-radius:2px 2px 0 0;animation:pulse var(--d,.8s) ease-in-out infinite alternate;width:4px;}
.mbar:nth-child(3n+1){background:var(--blue-bright);}
.mbar:nth-child(3n+2){background:var(--teal-light);}
.mbar:nth-child(3n){background:var(--gold);}
@keyframes pulse{from{height:var(--lo,8px);opacity:0.4;}to{height:var(--hi,32px);opacity:1;}}
.spot-btn{
  display:inline-flex;align-items:center;gap:12px;background:#1DB954;color:#000;
  font-family:'Josefin Sans',sans-serif;font-size:10px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;padding:15px 28px;
  text-decoration:none;transition:all 0.3s;
}
.spot-btn:hover{opacity:0.88;box-shadow:0 0 40px rgba(29,185,84,0.3);}
.spot-btn svg{width:18px;height:18px;flex-shrink:0;}

/* ── ABOUT SECTION ── */
#about{background:var(--bg);}
.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:96px;align-items:start;max-width:1160px;margin:0 auto;}
.atext{font-family:'EB Garamond',serif;font-size:20px;color:var(--text-muted);line-height:1.95;margin-bottom:28px;}
.atext strong{color:var(--text);font-weight:500;}
.astats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);margin-top:48px;}
.ast{background:var(--bg);padding:28px 24px;transition:background 0.3s;}
.ast:hover{background:var(--surface);}
.ast-n{font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:300;line-height:1;margin-bottom:6px;transition:color 0.3s;}
.ast:nth-child(1) .ast-n{color:var(--blue-light);}
.ast:nth-child(2) .ast-n{color:var(--gold);}
.ast:nth-child(3) .ast-n{color:var(--teal-light);}
.ast:nth-child(4) .ast-n{color:var(--crimson-bright);}
.ast:hover .ast-n{filter:brightness(1.3);}
.ast-l{font-family:'Josefin Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:3px;color:var(--text-muted);text-transform:uppercase;}
.acard{background:var(--card);border:1px solid var(--border-mid);padding:46px;position:relative;overflow:hidden;}
.acard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),var(--teal),var(--gold),var(--crimson));}
.acard-title{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:300;font-style:italic;color:var(--text);margin-bottom:18px;}
.acard-body{font-family:'EB Garamond',serif;font-size:18px;color:var(--text-muted);line-height:1.95;margin-bottom:28px;}
.atag{
  display:inline-block;font-family:'Josefin Sans',sans-serif;font-size:8px;
  font-weight:700;letter-spacing:3px;text-transform:uppercase;
  padding:7px 15px;margin:0 8px 8px 0;transition:all 0.3s;cursor:default;
}
.atag:nth-child(1){border:1px solid var(--blue-mid);color:var(--blue-light);}
.atag:nth-child(2){border:1px solid var(--teal);color:var(--teal-light);}
.atag:nth-child(3){border:1px solid var(--gold-dim);color:var(--gold);}
.atag:nth-child(4){border:1px solid var(--crimson-dim);color:var(--crimson-bright);}
.atag:nth-child(5){border:1px solid var(--blue-mid);color:var(--blue-light);}
.atag:nth-child(6){border:1px solid var(--teal);color:var(--teal-light);}
.atag:hover{background:rgba(255,255,255,0.06);filter:brightness(1.2);}
.amission{margin-top:30px;padding-top:30px;border-top:1px solid var(--border);}
.amission-lbl{font-family:'Josefin Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:4px;color:var(--crimson-bright);text-transform:uppercase;margin-bottom:12px;}
.amission-txt{font-family:'Cormorant Garamond',serif;font-size:21px;font-style:italic;color:var(--text-muted);line-height:1.75;}

/* ── COMMISSION SECTION ── */
#commission{background:var(--surface);}
/* ── TESTIMONIALS ── */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1160px;margin:0 auto 64px;}
.testi{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:28px 28px 24px;position:relative;}
.testi::before{content:'\201C';position:absolute;top:12px;left:20px;font-family:'Cormorant Garamond',serif;font-size:56px;line-height:1;color:var(--gold);opacity:0.35;pointer-events:none;}
.testi-q{font-family:'EB Garamond',serif;font-size:17px;font-style:italic;color:var(--text-muted);line-height:1.85;margin:0 0 18px;padding-top:22px;}
.testi-name{font-family:'Josefin Sans',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);opacity:0.8;}
@media(max-width:960px){.testi-grid{grid-template-columns:1fr;}}
.comm-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:72px;max-width:1160px;margin:0 auto;align-items:start;}
.comm-intro{font-family:'EB Garamond',serif;font-size:20px;font-style:italic;color:var(--text-muted);line-height:1.95;margin-bottom:48px;}
.tiers{display:flex;flex-direction:column;gap:1px;background:var(--border);}
.tier{background:var(--surface);padding:28px 32px;cursor:pointer;transition:background 0.3s;position:relative;overflow:hidden;}
.tier::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;transition:width 0.35s;}
.tier:nth-child(1)::before{background:var(--blue);}
.tier:nth-child(2)::before{background:var(--gold);}
.tier:nth-child(3)::before{background:var(--crimson);}
.tier.sel,.tier:hover{background:var(--card);}
.tier.sel::before{width:3px;}
.tier-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.tier-name{font-family:'Josefin Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:3px;color:var(--text-muted);text-transform:uppercase;}
.tier-price{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:300;}
.tier:nth-child(1) .tier-price{color:var(--blue-light);}
.tier:nth-child(2) .tier-price{color:var(--gold);}
.tier:nth-child(3) .tier-price{color:var(--crimson-bright);}
.tier.sel .tier-name{color:var(--text);}
.tier.sel .tier-price{filter:brightness(1.2);}
.tier-desc{font-family:'EB Garamond',serif;font-size:15px;color:var(--text-dim);font-style:italic;}
.tier.sel .tier-desc{color:var(--text-muted);}
.fg{display:flex;flex-direction:column;gap:8px;margin-bottom:22px;}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.fl{font-family:'Josefin Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:4px;color:var(--blue-light);text-transform:uppercase;}
.fi,.fta{
  background:var(--card);border:1px solid var(--border-mid);
  color:var(--text);font-family:'EB Garamond',serif;font-size:18px;
  padding:14px 18px;outline:none;transition:border-color 0.3s,box-shadow 0.3s;
  width:100%;resize:vertical;
}
.fi:focus,.fta:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(35,88,168,0.1);}
.fi::placeholder,.fta::placeholder{color:var(--text-dim);}
.tier-sel-disp{
  background:rgba(35,88,168,0.08);border:1px solid var(--blue-mid);
  padding:13px 18px;font-family:'Josefin Sans',sans-serif;font-size:9px;
  font-weight:700;letter-spacing:3px;color:var(--blue-light);
  text-transform:uppercase;margin-bottom:22px;
}
.sub-btn{
  background:var(--blue);color:var(--text);
  font-family:'Josefin Sans',sans-serif;font-size:10px;font-weight:700;
  letter-spacing:4px;text-transform:uppercase;padding:18px 48px;
  border:none;cursor:pointer;transition:all 0.3s;
  display:flex;align-items:center;gap:12px;
}
.sub-btn:hover{background:var(--blue-bright);box-shadow:0 0 50px rgba(58,120,216,0.35);}
.sub-btn svg{width:16px;height:16px;transition:transform 0.3s;}
.sub-btn:hover svg{transform:translateX(6px);}
.fsuc{display:none;text-align:center;padding:64px 24px;}
.fsuc-ico{font-size:52px;margin-bottom:24px;color:var(--gold);}
.fsuc-title{font-family:'Cormorant Garamond',serif;font-size:42px;font-style:italic;color:var(--text);margin-bottom:12px;}
.fsuc-sub{font-family:'EB Garamond',serif;font-size:18px;color:var(--text-muted);}

/* ── FOOTER ── */
footer{background:var(--bg);border-top:1px solid var(--border);padding:56px 60px;}
.foot-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:28px;}
.fbrand{font-family:'Cormorant Garamond',serif;font-size:26px;letter-spacing:4px;font-style:italic;color:var(--blue-light);}
.fcopy{font-family:'Josefin Sans',sans-serif;font-size:9px;font-weight:400;letter-spacing:3px;color:var(--text-dim);text-transform:uppercase;}
.flinks{display:flex;gap:36px;}
.flinks a{font-family:'Josefin Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:3px;color:var(--text-muted);text-decoration:none;text-transform:uppercase;transition:color 0.3s;}
.flinks a:hover{color:var(--gold);}

/* ── BACK TO TOP ── */
#btt{
  position:fixed;bottom:36px;right:36px;z-index:900;
  width:48px;height:48px;border-radius:50%;border:none;
  background:rgba(10,18,40,0.85);
  border:1px solid rgba(74,144,248,0.35);
  box-shadow:0 4px 24px rgba(74,144,248,0.18),0 0 0 0 rgba(74,144,248,0);
  color:var(--blue-light);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  opacity:0;transform:translateY(16px);pointer-events:none;
  transition:opacity 0.4s,transform 0.4s,box-shadow 0.3s,border-color 0.3s,background 0.3s;
  backdrop-filter:blur(10px);
}
#btt svg{width:18px;height:18px;display:block;}
#btt.vis{opacity:1;transform:translateY(0);pointer-events:all;}
#btt:hover{
  background:rgba(35,88,168,0.7);
  border-color:rgba(74,144,248,0.7);
  box-shadow:0 6px 32px rgba(74,144,248,0.35),0 0 0 4px rgba(74,144,248,0.08);
  color:#eef4ff;
}
#btt:active{transform:translateY(2px);}

/* ── KEYFRAMES ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px);filter:blur(3px);}to{opacity:1;transform:none;filter:blur(0);}}
@keyframes mIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:none;}}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  nav{padding:0 24px;height:72px;grid-template-columns:auto auto;}
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .sec{padding:88px 24px;}
  #home{padding:110px 24px 80px;}
  .music-grid,.about-grid,.comm-grid{grid-template-columns:1fr;}
  .fr2{grid-template-columns:1fr;}
  footer{padding:36px 24px;}
  .h-title{font-size:clamp(48px,12vw,80px);}
  .hero-ring{display:none;}
  #cursor-glow{display:none;}
  .pgrid{grid-template-columns:1fr;}
}

/* ── REDUCED MOTION ── */
@media(prefers-reduced-motion:reduce){
  /* Kill all transitions and animations globally, then restore visibility below */
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
  /* Hero elements start at opacity:0 and animate in — make them immediately visible */
  .h-orn,.h-eye,.h-title,.h-sub,.h-cta,.h-commission-cta{
    opacity:1;
    transform:none;
    filter:none;
  }
  /* Scroll-reveal elements start hidden — show them immediately */
  .rv{
    opacity:1;
    transform:none;
  }
  /* Aurora orbs — freeze in place, no drift */
  .aorb{animation:none;}
  /* Floating particles — hide entirely (motion is the whole point) */
  #particles{display:none;}
  /* Cursor glow — no follow animation */
  #cursor-glow{display:none;}
  /* Hero ring rotation */
  .hero-ring{animation:none;}
  /* Hero glow breathe */
  .hero-glow{animation:none;}
  /* Ornament star spin */
  .h-orn-glyph{animation:none;}
  /* Title shimmer */
  .h-title{animation:none;background:var(--text);-webkit-background-clip:text;}
  /* Scroll progress bar — no transition needed */
  #progress{transition:none;}
  /* Music visualiser bars — freeze at mid height */
  .mbar{animation:none;height:16px;}
  /* Modal slide-in */
  .mbox{animation:none;opacity:1;transform:none;}
  /* Back-to-top button — skip transform animation */
  #btt{transition:opacity 0.01ms;}
}
