/* ============ INVICTUS VISUALS · shared styles ============ */
:root{
  --teal:#4FAEAB; --teal-deep:#2E7E7B; --teal-dark:#1a4a48;
  --ink:#0b1413; --ink-2:#101c1b; --ink-3:#162422;
  --cloud:#F4F7F6; --mist:#b8cfcc; --faint:#7fa09c;
  --gold:#e8c979; --gold-soft:#f3e3b3;
  --serif:"Didot","Bodoni 72","Playfair Display",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue",Arial,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{font-size:calc(19px * var(--a11y-scale, 1))}
@media(max-width:640px){html{font-size:calc(17.5px * var(--a11y-scale, 1))}}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--cloud);font-family:var(--sans);line-height:1.7;overflow-x:hidden}
::selection{background:var(--teal);color:var(--ink)}
img{max-width:100%;display:block}
a{color:var(--teal);text-decoration:none}
a:focus-visible,button:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}

/* ---------- sky ---------- */
#sky{position:fixed;inset:0;z-index:0;pointer-events:none}
.aurora{position:fixed;inset:-20%;z-index:0;pointer-events:none;opacity:.55;
  background:
    radial-gradient(38% 30% at 18% 22%, rgba(79,174,171,.14), transparent 70%),
    radial-gradient(30% 26% at 82% 12%, rgba(232,201,121,.08), transparent 70%),
    radial-gradient(45% 40% at 70% 85%, rgba(46,126,123,.12), transparent 70%);
  animation:drift 26s ease-in-out infinite alternate}
@keyframes drift{from{transform:translate3d(-1.5%,0,0) scale(1)}to{transform:translate3d(1.5%,1%,0) scale(1.04)}}
.butterfly{position:fixed;z-index:1;pointer-events:none;opacity:.5;will-change:transform;
  animation:flutterPath var(--dur,38s) linear infinite}
.butterfly svg{width:100%;height:100%;animation:flap 1.1s ease-in-out infinite;transform-origin:center}
@keyframes flap{0%,100%{transform:scaleX(1) rotate(8deg)}50%{transform:scaleX(.55) rotate(-6deg)}}
@keyframes flutterPath{
  0%{transform:translate(-6vw,78vh)}25%{transform:translate(28vw,32vh)}
  50%{transform:translate(60vw,58vh)}75%{transform:translate(84vw,22vh)}
  100%{transform:translate(108vw,48vh)}}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .butterfly{display:none}
}

/* ---------- nav ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(11,20,19,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(79,174,171,.16)}
.nav{max-width:1240px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding:.6rem 1.4rem}
.brand{display:flex;align-items:center;gap:.65rem;color:var(--cloud)}
.brand img{width:46px;height:46px;object-fit:contain;filter:drop-shadow(0 0 10px rgba(79,174,171,.35))}
.brand span{font-family:var(--serif);letter-spacing:.22em;font-size:.82rem;text-transform:uppercase;white-space:nowrap}
@media(max-width:600px){
  .brand{gap:.5rem}
  .brand img{width:38px;height:38px}
  .brand span{font-size:.66rem;letter-spacing:.14em}
}
@media(max-width:350px){.brand span{font-size:.58rem;letter-spacing:.1em}}
nav ul{display:flex;gap:1.05rem;list-style:none;align-items:center;flex-wrap:nowrap}
nav a{color:var(--mist);font-size:.72rem;letter-spacing:.11em;text-transform:uppercase;transition:color .25s;white-space:nowrap}
nav a:hover{color:var(--gold)}
nav a[aria-current="page"]{color:var(--gold);border-bottom:1px solid var(--gold);padding-bottom:2px}
#menuBtn{display:none;background:none;border:1px solid rgba(79,174,171,.4);color:var(--cloud);
  padding:.45rem .8rem;border-radius:8px;font-size:.8rem;letter-spacing:.12em;cursor:pointer}
@media(max-width:1180px){
  #menuBtn{display:block}
  nav ul{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:rgba(11,20,19,.97);border-bottom:1px solid rgba(79,174,171,.2);padding:.6rem 0}
  nav ul.open{display:flex}
  nav ul li{width:100%;text-align:center}
  nav ul a{display:block;padding:.85rem}
  nav a[aria-current="page"]{border-bottom:none}
}

/* ---------- shared ---------- */
main{position:relative;z-index:2}
section{padding:5.5rem 1.4rem;max-width:1200px;margin:0 auto}
.page-hero{padding-top:9.5rem;padding-bottom:3rem}
.kicker{color:var(--gold);letter-spacing:.34em;text-transform:uppercase;font-size:.76rem;margin-bottom:1rem}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.15}
h1{font-size:clamp(2.3rem,5.4vw,3.9rem)}
h2{font-size:clamp(1.9rem,4.2vw,3rem);margin-bottom:1.2rem}
.lede{color:var(--mist);max-width:62ch;font-size:1.14rem;line-height:1.75}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}
.btn{display:inline-block;padding:.85rem 1.9rem;border-radius:999px;font-size:.8rem;
  letter-spacing:.2em;text-transform:uppercase;transition:all .3s;cursor:pointer}
.btn-gold{background:linear-gradient(120deg,var(--gold),#d9ae4e);color:#231a05;font-weight:600}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 10px 34px rgba(232,201,121,.28)}
.btn-ghost{border:1px solid rgba(79,174,171,.55);color:var(--cloud)}
.btn-ghost:hover{background:rgba(79,174,171,.12);border-color:var(--teal)}
.card{background:linear-gradient(160deg,rgba(22,36,34,.9),rgba(16,28,27,.9));
  border:1px solid rgba(79,174,171,.18);border-radius:18px;padding:1.8rem;
  transition:transform .35s,border-color .35s,box-shadow .35s;position:relative;overflow:hidden}
.card:hover{transform:translateY(-6px);border-color:rgba(232,201,121,.45);box-shadow:0 18px 44px rgba(0,0,0,.45)}
/* light sweep on hover: a photographer's flash passing over the card */
.card::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(115deg,transparent 30%,rgba(244,247,246,.07) 46%,rgba(232,201,121,.1) 50%,rgba(244,247,246,.07) 54%,transparent 70%);
  transform:translateX(-130%);transition:transform .9s ease}
.card:hover::after{transform:translateX(130%)}
.grid{display:grid;gap:1.4rem}
.g2{grid-template-columns:repeat(auto-fit,minmax(290px,1fr))}
.g3{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}

/* ---------- home hero ---------- */
#hero{min-height:92vh;display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;padding-top:7rem;position:relative}
#hero img.hero-logo{width:min(165px,38vw);margin-bottom:1.6rem;
  filter:drop-shadow(0 0 44px rgba(79,174,171,.35)) drop-shadow(0 0 90px rgba(244,247,246,.14));
  animation:moonfloat 7s ease-in-out infinite alternate}
@keyframes moonfloat{from{transform:translateY(0)}to{transform:translateY(-12px)}}
#hero h1{font-size:clamp(2.6rem,7vw,5.2rem);letter-spacing:.08em}
#hero h1 em{font-style:italic;color:var(--gold)}
.hero-sub{margin:1.3rem auto 0;max-width:56ch;color:var(--mist);font-size:1.08rem}
.hero-cta{margin-top:2.4rem;display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}
.scroll-hint{position:absolute;bottom:2rem;color:var(--faint);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;animation:bob 2.6s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* ---------- constellation (replaces ticker) ---------- */
.constellation{position:relative;z-index:2;border-top:1px solid rgba(79,174,171,.14);
  border-bottom:1px solid rgba(79,174,171,.14);background:rgba(16,28,27,.5);
  height:120px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.constellation svg{width:min(520px,90vw);height:100%}
.const-word{font-family:var(--serif);font-size:26px;letter-spacing:.5em;fill:var(--gold-soft);text-transform:uppercase}
.const-line{stroke:rgba(79,174,171,.5);stroke-width:1;fill:none}
.const-star{fill:var(--gold)}
.const-g{opacity:0;transition:opacity 1.2s ease}
.const-g.on{opacity:1}
.const-line{stroke-dasharray:600;stroke-dashoffset:600;transition:stroke-dashoffset 2.2s ease}
.const-g.on .const-line{stroke-dashoffset:0}

/* ---------- poem / manifesto ---------- */
.poem{font-family:var(--serif);font-size:clamp(1.35rem,3vw,2rem);line-height:1.75;color:var(--gold-soft);
  max-width:34ch;margin:2.6rem auto;font-style:italic}
.poem small{display:block;margin-top:1.4rem;font-style:normal;font-family:var(--sans);
  font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--faint)}
.creed{max-width:66ch;margin:0 auto;color:var(--mist);text-align:left}
.creed p{margin-bottom:1.2rem}
.creed strong{color:var(--cloud)}

/* ---------- film strip ---------- */
.filmwrap{max-width:100%;overflow:hidden;padding:2.2rem 0}
.filmstrip{display:flex;gap:0;overflow-x:auto;cursor:grab;user-select:none;-webkit-user-select:none;
  scrollbar-width:none;padding:0 8vw;background:#120f0b;
  border-top:10px solid #0c0a07;border-bottom:10px solid #0c0a07;counter-reset:frame}
.filmstrip::-webkit-scrollbar{display:none}
.filmstrip.dragging{cursor:grabbing;scroll-behavior:auto}
.filmcell{flex:0 0 auto;width:min(300px,72vw);background:#120f0b;padding:40px 7px;position:relative;
  counter-increment:frame}
/* 35mm-style rounded perforations */
.filmcell::before,.filmcell::after{content:"";position:absolute;left:0;right:0;height:14px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='14'%3E%3Crect x='7' y='3' width='12' height='8' rx='2.4' fill='%23d9d2c2' fill-opacity='0.22'/%3E%3C/svg%3E");
  background-repeat:repeat-x;background-position:center}
.filmcell::before{top:7px}
.filmcell::after{bottom:7px}
/* edge print, like the markings on real stock */
.filmcell .edge{position:absolute;top:24px;left:12px;right:12px;display:flex;justify-content:space-between;
  font-family:"Courier New",monospace;font-size:.55rem;letter-spacing:.28em;
  color:rgba(232,164,80,.65);text-transform:uppercase;pointer-events:none}
.filmcell .edge::after{content:"№ " counter(frame, decimal-leading-zero) " ▸"}
.filmcell img{width:100%;aspect-ratio:3/2;object-fit:cover;filter:saturate(.92) contrast(1.04);
  transition:filter .4s;pointer-events:none}
.filmcell:hover img{filter:saturate(1.1) contrast(1.06)}
.filmcell figcaption{position:absolute;bottom:30px;left:16px;right:16px;font-size:.68rem;
  letter-spacing:.2em;text-transform:uppercase;color:rgba(244,247,246,.85);
  text-shadow:0 1px 8px rgba(0,0,0,.8)}
.film-hint{text-align:center;color:var(--faint);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;margin-top:1rem}

/* ---------- gallery ---------- */
.filters{display:flex;flex-wrap:wrap;gap:.6rem;margin:1.8rem 0 2.2rem}
.filters button{background:none;border:1px solid rgba(79,174,171,.4);color:var(--mist);border-radius:999px;
  padding:.45rem 1.2rem;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:all .25s}
.filters button.active,.filters button:hover{background:var(--teal-deep);border-color:var(--teal);color:#fff}
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.1rem}
.pitem{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/5;
  border:1px solid rgba(79,174,171,.16);background:var(--ink-3);cursor:zoom-in}
.pitem img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.pitem:hover img{transform:scale(1.05)}
.pitem .cap{position:absolute;left:0;right:0;bottom:0;padding:2.2rem 1.1rem .9rem;
  background:linear-gradient(180deg,transparent,rgba(11,20,19,.92));font-size:.88rem;color:var(--cloud)}
.pitem .cap i{display:block;font-style:normal;color:var(--gold);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;margin-bottom:.2rem}
.slot{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;height:100%;
  color:var(--faint);text-align:center;padding:1rem;
  background:radial-gradient(60% 45% at 50% 30%, rgba(79,174,171,.16), transparent 70%),
    linear-gradient(160deg,var(--ink-3),var(--ink-2))}
.slot .star{color:var(--gold);font-size:1.5rem}
.slot p{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase}

/* ---------- darkroom spotlight ---------- */
@property --mx{syntax:"<percentage>";inherits:true;initial-value:50%}
@property --my{syntax:"<percentage>";inherits:true;initial-value:45%}
.darkroom{position:relative;border-radius:20px;overflow:hidden;min-height:340px;
  display:flex;align-items:center;justify-content:center;text-align:center;
  border:1px solid rgba(79,174,171,.2);margin-top:2.5rem}
.darkroom .dr-img{position:absolute;inset:0;background-size:cover;background-position:center}
.darkroom .dr-shade{position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,45%),
    rgba(7,13,12,0) 0, rgba(7,13,12,.14) 13%, rgba(7,13,12,.9) 34%, rgba(7,13,12,.97) 58%)}
.darkroom.auto .dr-shade{animation:sweep 9s ease-in-out infinite alternate}
@keyframes sweep{0%{--mx:22%;--my:40%}50%{--mx:55%;--my:60%}100%{--mx:80%;--my:38%}}
.darkroom .dr-copy{position:relative;z-index:2;padding:4rem 1.5rem;pointer-events:none}
.darkroom h2{text-shadow:0 2px 26px rgba(0,0,0,.8)}
.darkroom p{color:var(--mist);max-width:46ch;margin:0 auto;text-shadow:0 1px 14px rgba(0,0,0,.9)}

/* ---------- pricing ---------- */
.svc h3{color:var(--gold-soft);font-size:1.3rem;margin-bottom:.6rem}
.svc p{color:var(--mist);font-size:1rem}
.svc .tagline{color:var(--teal);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:.8rem;display:block}
.tiers{margin-top:3.4rem}
.tier{text-align:center}
.tier h3{font-size:1.6rem;color:var(--cloud)}
.tier .price{font-family:var(--serif);font-size:2.4rem;color:var(--gold);margin:.6rem 0 .2rem}
.tier .per{color:var(--faint);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase}
.tier ul{list-style:none;margin:1.4rem 0;text-align:left}
.tier li{padding:.48rem 0;color:var(--mist);font-size:.98rem;border-bottom:1px dashed rgba(79,174,171,.16)}
.tier li::before{content:"✦ ";color:var(--teal)}
.tier.featured{border-color:var(--gold);box-shadow:0 0 44px rgba(232,201,121,.12);overflow:visible}
.tier.featured::after{display:none}
.badge{position:absolute;top:-1px;left:50%;transform:translate(-50%,-50%);background:var(--gold);color:#231a05;
  font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:.3rem .9rem;border-radius:999px;z-index:3}
.alacarte{margin-top:2.6rem}
.alacarte table{width:100%;border-collapse:collapse}
.alacarte td{padding:.8rem .5rem;border-bottom:1px solid rgba(79,174,171,.14);color:var(--mist);font-size:1rem}
.alacarte td:last-child{text-align:right;color:var(--gold-soft);font-family:var(--serif);font-size:1.05rem}
.founding{margin-top:2.4rem;border:1px dashed rgba(232,201,121,.5);border-radius:16px;padding:1.6rem;text-align:center}

/* ---------- archive / resources ---------- */
.res-list{list-style:none;margin-top:.6rem}
.res-list li{padding:.6rem 0;border-bottom:1px dashed rgba(79,174,171,.16);font-size:1rem}
.res-list li span{display:block;color:var(--faint);font-size:.92rem}
.banned{margin-top:2.6rem}
.banned .shelf{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:.9rem;margin-top:1.4rem}
.book{border-left:4px solid var(--teal);background:rgba(22,36,34,.8);border-radius:0 12px 12px 0;padding:1rem 1.1rem}
.book b{display:block;font-family:var(--serif);font-weight:400;font-size:1.02rem;color:var(--gold-soft)}
.book span{color:var(--faint);font-size:.88rem}

/* ---------- about / story ---------- */
.about-wrap{display:grid;grid-template-columns:minmax(260px,420px) 1fr;gap:3rem;align-items:center}
@media(max-width:860px){.about-wrap{grid-template-columns:1fr}}
.about-photo{position:relative;border-radius:20px;overflow:hidden;border:1px solid rgba(232,201,121,.3)}
.about-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(11,20,19,.75))}
.cred-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.6rem}
.chip{border:1px solid rgba(79,174,171,.4);color:var(--mist);border-radius:999px;
  padding:.35rem .95rem;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase}

/* ---------- vinyl listening room ---------- */
.turntable{display:grid;grid-template-columns:minmax(240px,340px) 1fr;gap:2.6rem;align-items:center;margin-top:2.4rem}
@media(max-width:820px){.turntable{grid-template-columns:1fr;justify-items:center}}
.vinyl{position:relative;width:min(300px,74vw);aspect-ratio:1;border-radius:50%;
  background:
    radial-gradient(circle at 50% 50%, #10100f 0 15%, transparent 15.5%),
    repeating-radial-gradient(circle at 50% 50%, #171717 0 2px, #0d0d0d 2px 4px);
  box-shadow:0 14px 44px rgba(0,0,0,.6), inset 0 0 40px rgba(0,0,0,.8);
  display:flex;align-items:center;justify-content:center}
.vinyl::before{content:"";position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 160deg, transparent 0 40%, rgba(244,247,246,.06) 47%, transparent 55%, transparent 78%, rgba(232,201,121,.05) 86%, transparent 92%)}
.vinyl.spin{animation:vspin 3.2s linear infinite}
@keyframes vspin{to{transform:rotate(360deg)}}
.vinyl .label{width:34%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,#2E7E7B 0 58%,#1a4a48 100%);
  display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--serif);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);
  border:2px solid rgba(232,201,121,.4)}
.vinyl .hole{position:absolute;width:9px;height:9px;background:var(--ink);border-radius:50%}
.tracklist{list-style:none;width:100%}
.tracklist li{border-bottom:1px dashed rgba(79,174,171,.18)}
.tracklist button{width:100%;background:none;border:none;color:var(--mist);text-align:left;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem .3rem;
  font-size:.95rem;font-family:var(--sans);transition:color .25s}
.tracklist button:hover{color:var(--gold)}
.tracklist li.playing button{color:var(--gold-soft)}
.tracklist .no{font-family:var(--serif);color:var(--faint);margin-right:.6rem}
.eq{display:inline-flex;gap:2px;align-items:flex-end;height:14px;visibility:hidden}
li.playing .eq{visibility:visible}
.eq i{width:3px;background:var(--gold);animation:eqb .8s ease-in-out infinite}
.eq i:nth-child(2){animation-delay:.15s}.eq i:nth-child(3){animation-delay:.3s}.eq i:nth-child(4){animation-delay:.45s}
@keyframes eqb{0%,100%{height:4px}50%{height:14px}}
.liner{margin-top:1.2rem;color:var(--mist);font-size:1rem;min-height:3.2em;font-style:italic}
.liner b{color:var(--gold-soft);font-style:normal}

/* ---------- prints / collab ---------- */
.print-item .frame{aspect-ratio:4/5;border-radius:10px;margin-bottom:1rem;border:6px solid #20302e;
  background:radial-gradient(55% 40% at 50% 32%, rgba(232,201,121,.14), transparent 70%),
    linear-gradient(160deg,var(--ink-3),var(--ink-2));
  display:flex;align-items:center;justify-content:center;color:var(--faint);
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;text-align:center;padding:1rem}
.steps{counter-reset:step;margin-top:1.6rem}
.steps li{list-style:none;position:relative;padding:.6rem 0 .6rem 3rem;color:var(--mist)}
.steps li::before{counter-increment:step;content:counter(step);position:absolute;left:0;top:.55rem;
  width:2rem;height:2rem;border-radius:50%;border:1px solid var(--gold);color:var(--gold);
  display:flex;align-items:center;justify-content:center;font-family:var(--serif)}

/* ---------- contact ---------- */
.socials{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin-top:2rem}
.socials a{border:1px solid rgba(79,174,171,.4);border-radius:999px;padding:.55rem 1.25rem;
  color:var(--mist);font-size:.84rem;letter-spacing:.1em;transition:all .25s}
.socials a:hover{border-color:var(--gold);color:var(--gold)}
.mail{font-family:var(--serif);font-size:clamp(1.3rem,3.4vw,2rem);color:var(--gold-soft);display:inline-block;margin-top:1.6rem}

/* ---------- footer ---------- */
footer{position:relative;z-index:2;border-top:1px solid rgba(79,174,171,.16);
  padding:2.6rem 1.4rem;text-align:center;color:var(--faint);font-size:.8rem}
footer .star-btn{background:none;border:none;color:var(--gold);font-size:1.4rem;cursor:pointer;display:block;margin:0 auto .8rem}
.foot-links{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:1.2rem}
.foot-links a{color:var(--faint);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}
.foot-links a:hover{color:var(--gold)}
.spark{position:fixed;z-index:80;pointer-events:none;color:var(--gold);animation:sparkfall 1.2s ease-out forwards}
@keyframes sparkfall{from{opacity:1;transform:translate(0,0) scale(1)}to{opacity:0;transform:translate(var(--dx),var(--dy)) scale(.2)}}

/* ---------- lightbox ---------- */
#lb{position:fixed;inset:0;z-index:90;background:rgba(7,13,12,.94);display:none;
  align-items:center;justify-content:center;flex-direction:column;padding:2rem}
#lb.open{display:flex}
#lb img{max-width:min(1100px,92vw);max-height:78vh;object-fit:contain;border-radius:8px;
  box-shadow:0 30px 90px rgba(0,0,0,.6)}
#lbCap{margin-top:1rem;color:var(--mist);font-size:.96rem;text-align:center}
#lbCap i{font-style:normal;color:var(--gold);font-size:.65rem;letter-spacing:.24em;text-transform:uppercase;display:block}
.lb-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(22,36,34,.8);
  border:1px solid rgba(79,174,171,.4);color:var(--cloud);width:3rem;height:3rem;border-radius:50%;
  font-size:1.2rem;cursor:pointer;transition:all .25s}
.lb-btn:hover{border-color:var(--gold);color:var(--gold)}
#lbPrev{left:1rem}#lbNext{right:1rem}
#lbClose{position:absolute;top:1rem;right:1rem;transform:none}
@media(max-width:640px){.lb-btn{width:2.5rem;height:2.5rem}}

/* ---------- journeys map ---------- */
.mapwrap{position:relative;margin-top:2.4rem;border:1px solid rgba(79,174,171,.2);border-radius:20px;
  background:linear-gradient(160deg,rgba(16,28,27,.7),rgba(11,20,19,.9));padding:1.2rem;overflow:visible}
.mapwrap svg{width:100%;height:auto;display:block}
.map-dot{fill:rgba(79,150,147,.5)}
.map-pin{fill:var(--gold);cursor:pointer;transition:r .2s}
.map-pin.next{fill:#b98ae0}
.map-halo{fill:none;stroke:var(--gold);stroke-width:1;opacity:.7;transform-origin:center;pointer-events:none}
.map-halo.next{stroke:#b98ae0}
@keyframes halo{0%{opacity:.7}70%{opacity:0}100%{opacity:0}}
.map-tip{position:absolute;z-index:5;pointer-events:none;background:rgba(11,20,19,.96);
  border:1px solid rgba(232,201,121,.5);border-radius:12px;padding:.7rem 1rem;max-width:240px;
  opacity:0;transition:opacity .25s;transform:translate(-50%,-115%)}
.map-tip.show{opacity:1}
.map-tip.below{transform:translate(-50%,22px)}
.map-tip b{display:block;font-family:var(--serif);font-weight:400;color:var(--gold-soft);font-size:1rem}
.map-tip span{color:var(--mist);font-size:.85rem;line-height:1.5}
.map-legend{display:flex;gap:1.6rem;justify-content:center;margin-top:1rem;color:var(--faint);
  font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;flex-wrap:wrap}
.map-legend i{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:.45rem;vertical-align:middle}
.map-legend .gold i{background:var(--gold)}
.map-legend .next i{background:#b98ae0}

/* ---------- song of the day / playlists ---------- */
.songday{display:grid;grid-template-columns:auto 1fr;gap:1.6rem;align-items:center;
  border:1px dashed rgba(232,201,121,.45);border-radius:18px;padding:1.6rem 1.8rem;margin-top:2.4rem}
@media(max-width:640px){.songday{grid-template-columns:1fr}}
.songday .sun{font-size:2rem;color:var(--gold);align-self:start}
.songday h3{font-family:var(--serif);font-weight:400;color:var(--gold-soft);font-size:1.5rem}
.songday p{color:var(--mist);font-size:1rem}
.playlist .pl-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.3rem 1rem;margin-bottom:.6rem}
.playlist .use{margin-left:auto;text-align:right}
.playlist h3{color:var(--gold-soft);font-size:1.15rem}
.playlist .use{color:var(--teal);font-size:.73rem;letter-spacing:.2em;text-transform:uppercase}
.playlist ol{list-style:none;counter-reset:tr}
.playlist ol li{counter-increment:tr;color:var(--mist);font-size:.96rem;padding:.34rem 0;
  border-bottom:1px dashed rgba(79,174,171,.14)}
.playlist ol li::before{content:counter(tr,decimal-leading-zero);font-family:var(--serif);
  color:var(--faint);margin-right:.7rem}
.playlist .mood{margin-top:.9rem;color:var(--faint);font-size:.88rem;font-style:italic}

/* ---------- live music / band card ---------- */
.bandcard{display:grid;grid-template-columns:auto 1fr;gap:1.6rem;align-items:center;
  background:linear-gradient(150deg,rgba(30,22,34,.85),rgba(16,28,27,.9));
  border:1px solid rgba(185,138,224,.35);border-radius:18px;padding:1.8rem;margin-top:1.6rem}
@media(max-width:640px){.bandcard{grid-template-columns:1fr}}
.bandcard .amp{font-size:2.2rem}
.bandcard h3{font-family:var(--serif);font-weight:400;color:#d9c2ef;font-size:1.5rem}
.bandcard p{color:var(--mist);font-size:1rem}

/* ---------- preset lab / before-after ---------- */
.ba{position:relative;border-radius:16px;overflow:hidden;border:1px solid rgba(79,174,171,.25);
  aspect-ratio:3/2;user-select:none;-webkit-user-select:none}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba .after{clip-path:inset(0 0 0 var(--ba,50%))}
.ba .ba-line{position:absolute;top:0;bottom:0;left:var(--ba,50%);width:2px;background:var(--gold);
  pointer-events:none;transform:translateX(-1px)}
.ba .ba-knob{position:absolute;top:50%;left:var(--ba,50%);transform:translate(-50%,-50%);
  width:2.6rem;height:2.6rem;border-radius:50%;background:rgba(11,20,19,.85);border:1px solid var(--gold);
  color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:.9rem;pointer-events:none}
.ba .ba-tag{position:absolute;bottom:.8rem;font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(244,247,246,.9);background:rgba(11,20,19,.6);padding:.25rem .7rem;border-radius:999px;pointer-events:none}
.ba .tag-b{left:.8rem}.ba .tag-a{right:.8rem}
.ba input[type=range]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;margin:0}

/* ---------- newsletter ---------- */
.newsletter{max-width:560px;margin:0 auto 2.2rem;text-align:center;padding:1.6rem 1.4rem;
  border:1px dashed rgba(79,174,171,.35);border-radius:18px}
.newsletter p{color:var(--mist);font-size:.98rem;margin-bottom:1rem}
.newsletter form{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}
.newsletter input[type=email]{flex:1 1 220px;max-width:320px;padding:.8rem 1.1rem;border-radius:999px;
  border:1px solid rgba(79,174,171,.4);background:rgba(11,20,19,.7);color:var(--cloud);
  font-family:var(--sans);font-size:.95rem}
.newsletter input[type=email]::placeholder{color:var(--faint)}
.newsletter input[type=email]:focus{outline:2px solid var(--gold);outline-offset:2px}
.newsletter .btn{padding:.8rem 1.6rem}

/* ---------- merch ---------- */
.merch-item .frame{aspect-ratio:1;border-radius:12px;margin-bottom:1rem;border:1px solid rgba(79,174,171,.25);
  background:radial-gradient(50% 42% at 50% 36%, rgba(232,201,121,.15), transparent 72%),
    linear-gradient(160deg,var(--ink-3),var(--ink-2));
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;
  color:var(--faint);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;text-align:center;padding:1rem}
.merch-item .frame span{font-size:2.2rem}

/* ---------- social desk ---------- */
.desk{display:grid;grid-template-columns:minmax(250px,320px) 1fr;gap:2.4rem;align-items:start;margin-top:2.4rem}
@media(max-width:840px){.desk{grid-template-columns:1fr;justify-items:center}}
.phone{width:min(300px,84vw);border:1px solid rgba(79,174,171,.35);border-radius:32px;
  background:linear-gradient(170deg,#101c1b,#0b1413);padding:1rem;box-shadow:0 24px 60px rgba(0,0,0,.5)}
.phone .ph-top{display:flex;align-items:center;gap:.7rem;padding:.4rem .3rem .9rem}
.phone .ph-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:1.1rem;color:#fff;background:var(--acc,#2E7E7B);flex:none}
.phone .ph-handle{font-size:.85rem;color:var(--cloud);line-height:1.3}
.phone .ph-handle span{display:block;font-size:.66rem;color:var(--faint);letter-spacing:.1em;text-transform:uppercase}
.phone .ph-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;border-radius:14px;overflow:hidden}
.phone .ph-tile{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.25rem;text-align:center;padding:.3rem;font-size:.56rem;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.92);background:linear-gradient(150deg,var(--t1,#2E7E7B),var(--t2,#1a4a48));
  transition:transform .3s,filter .3s}
.phone .ph-tile:hover{transform:scale(1.04);filter:brightness(1.15)}
.phone .ph-tile b{font-size:1.05rem;font-weight:400}
.phone .ph-live{display:block;text-align:center;margin-top:.9rem;font-size:.7rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold)}
.desk-list{width:100%}
.desk-chips{display:flex;flex-wrap:wrap;gap:.5rem}
.desk-chips button{background:none;border:1px solid rgba(79,174,171,.4);color:var(--mist);border-radius:999px;
  padding:.46rem 1.05rem;font-size:.78rem;letter-spacing:.1em;cursor:pointer;transition:all .25s}
.desk-chips button.active,.desk-chips button:hover{border-color:var(--gold);color:var(--gold)}
.desk-note{margin-top:1.4rem;color:var(--mist);font-size:.92rem;min-height:4.5em}
.desk-note b{color:var(--gold-soft);font-family:var(--serif);font-weight:400;font-size:1.05rem;display:block;margin-bottom:.2rem}

/* ---------- accessibility widget ---------- */
#a11yBtn{position:fixed;left:1.1rem;bottom:1.1rem;z-index:95;width:3.2rem;height:3.2rem;border-radius:50%;
  background:linear-gradient(150deg,var(--teal-deep),var(--teal-dark));border:1px solid rgba(79,174,171,.6);
  color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 26px rgba(0,0,0,.5);transition:transform .25s,box-shadow .25s}
#a11yBtn:hover{transform:scale(1.08);box-shadow:0 10px 30px rgba(79,174,171,.4)}
#a11yBtn svg{width:1.7rem;height:1.7rem}
#a11yPanel{position:fixed;left:1.1rem;bottom:5rem;z-index:96;width:min(320px,calc(100vw - 2.2rem));
  background:rgba(11,20,19,.98);border:1px solid rgba(79,174,171,.4);border-radius:18px;
  padding:1.2rem 1.2rem 1rem;box-shadow:0 24px 60px rgba(0,0,0,.6);display:none}
#a11yPanel.open{display:block}
#a11yPanel h2{font-size:1.05rem;margin-bottom:.2rem;color:var(--gold-soft)}
#a11yPanel .a-sub{color:var(--faint);font-size:.72rem;margin-bottom:.9rem}
.a-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;
  padding:.5rem 0;border-bottom:1px dashed rgba(79,174,171,.16)}
.a-row span{color:var(--mist);font-size:.85rem}
.a-switch{width:2.6rem;height:1.4rem;border-radius:999px;border:1px solid rgba(79,174,171,.5);
  background:rgba(22,36,34,.9);cursor:pointer;position:relative;flex:none;transition:background .25s}
.a-switch::after{content:"";position:absolute;top:2px;left:2px;width:1rem;height:1rem;border-radius:50%;
  background:var(--mist);transition:transform .25s,background .25s}
.a-switch[aria-checked="true"]{background:var(--teal-deep)}
.a-switch[aria-checked="true"]::after{transform:translateX(1.2rem);background:var(--gold)}
.a-size{display:flex;align-items:center;gap:.5rem}
.a-size button{width:2rem;height:2rem;border-radius:50%;border:1px solid rgba(79,174,171,.5);
  background:none;color:var(--cloud);cursor:pointer;font-size:.95rem}
.a-size button:hover{border-color:var(--gold);color:var(--gold)}
.a-size b{color:var(--gold-soft);font-family:var(--serif);font-weight:400;min-width:2.4rem;text-align:center;font-size:.85rem}
#a11yReset{margin-top:.9rem;width:100%;background:none;border:1px solid rgba(232,201,121,.5);color:var(--gold);
  border-radius:999px;padding:.5rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer}
#a11yReset:hover{background:rgba(232,201,121,.12)}
#a11yGuide{position:fixed;left:0;right:0;top:50%;z-index:94;height:0;border-top:3px solid rgba(232,201,121,.85);
  pointer-events:none;display:none;box-shadow:0 0 18px rgba(232,201,121,.5)}
html.a11y-guide-on #a11yGuide{display:block}

/* modes */
html.a11y-contrast{--ink:#000;--ink-2:#050505;--ink-3:#101010;--cloud:#ffffff;--mist:#eaeaea;
  --faint:#d0d0d0;--gold:#ffd75e;--gold-soft:#ffe9a8;--teal:#7fe0dc;--teal-deep:#0f6b67}
html.a11y-contrast .card,html.a11y-contrast .newsletter,html.a11y-contrast #a11yPanel{border-color:rgba(255,255,255,.5)}
html.a11y-contrast .aurora{display:none}
html.a11y-font body,html.a11y-font h1,html.a11y-font h2,html.a11y-font h3,
html.a11y-font .poem,html.a11y-font .brand span,html.a11y-font .const-word,
html.a11y-font .tier .price,html.a11y-font .mail{font-family:var(--sans)!important;font-style:normal!important}
html.a11y-font body{line-height:2;letter-spacing:.02em;word-spacing:.08em}
html.a11y-links a{text-decoration:underline!important;text-underline-offset:3px}
html.a11y-links nav a,html.a11y-links .btn{outline:1px solid rgba(232,201,121,.5);outline-offset:2px}
html.a11y-motionoff *,html.a11y-motionoff *::before,html.a11y-motionoff *::after{
  animation:none!important;transition:none!important}
html.a11y-motionoff .butterfly{display:none}
html.a11y-motionoff #sky{opacity:.5}
html.a11y-gray main,html.a11y-gray header,html.a11y-gray footer,html.a11y-gray #sky,
html.a11y-gray .aurora,html.a11y-gray .butterfly,html.a11y-gray #lb{filter:grayscale(1)}

/* ---------- skip link ---------- */
.skip-link{position:fixed;top:-100px;left:1rem;z-index:200;background:var(--gold);color:#231a05;
  padding:.7rem 1.4rem;border-radius:0 0 12px 12px;font-size:.8rem;letter-spacing:.14em;
  text-transform:uppercase;font-weight:600;transition:top .3s}
.skip-link:focus{top:0}

/* ---------- journeys postcard ---------- */
.postcard{display:grid;grid-template-columns:minmax(240px,420px) 1fr;gap:2rem;align-items:center;
  margin-top:3rem;background:linear-gradient(160deg,rgba(22,36,34,.9),rgba(16,28,27,.9));
  border:1px solid rgba(79,174,171,.2);border-radius:18px;padding:1.4rem;overflow:hidden}
@media(max-width:760px){.postcard{grid-template-columns:1fr}}
.postcard img{border-radius:12px;width:100%;transform:rotate(-1.2deg);border:6px solid #f4f7f6;
  box-shadow:0 14px 34px rgba(0,0,0,.45)}
.postcard .stamp{color:var(--faint);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;margin-bottom:.5rem}

/* ---------- contact form ---------- */
.cform{max-width:680px;margin:3rem auto 0;text-align:left;padding:2rem 1.8rem;
  background:linear-gradient(160deg,rgba(22,36,34,.9),rgba(16,28,27,.9));
  border:1px solid rgba(79,174,171,.22);border-radius:18px}
.cform .frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:560px){.cform .frow{grid-template-columns:1fr}}
.cform label{display:block;margin-bottom:1.1rem;color:var(--mist);font-size:.78rem;
  letter-spacing:.14em;text-transform:uppercase}
.cform input,.cform select,.cform textarea{display:block;width:100%;margin-top:.45rem;
  padding:.8rem 1rem;border-radius:12px;border:1px solid rgba(79,174,171,.4);
  background:rgba(11,20,19,.75);color:var(--cloud);font-family:var(--sans);font-size:.95rem;
  letter-spacing:normal;text-transform:none}
.cform input::placeholder,.cform textarea::placeholder{color:var(--faint)}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:2px solid var(--gold);outline-offset:2px}
.cform select{appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23e8c979' stroke-width='1.6' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;background-size:12px}
.cform select option{background:var(--ink-2);color:var(--cloud)}
.cform textarea{min-height:150px;resize:vertical}
.cform .btn{width:100%;text-align:center;border:none}
.cform .fnote{color:var(--faint);font-size:.82rem;text-align:center;margin-top:.9rem}

/* ---------- publication logo marquee ---------- */
.logoband{position:relative;z-index:2;background:rgba(8,13,12,.85);
  border-top:1px solid rgba(79,174,171,.14);border-bottom:1px solid rgba(79,174,171,.14);
  padding:1.6rem 0;overflow:hidden}
.logoband .lb-kicker{text-align:center;color:var(--faint);font-size:.62rem;letter-spacing:.34em;
  text-transform:uppercase;margin-bottom:1.2rem}
.logotrack{display:flex;align-items:center;gap:4.5rem;width:max-content;
  animation:logoslide 36s linear infinite}
.logoband:hover .logotrack{animation-play-state:paused}
.logotrack img{height:30px;width:auto;max-width:min(340px,70vw);object-fit:contain;opacity:.78;transition:opacity .3s;flex:none}
.logotrack img.tall{height:54px;max-width:none}
.logotrack img.mid{height:46px;max-width:none}
.logotrack img:hover{opacity:1}
@keyframes logoslide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){
  .logotrack{animation:none;flex-wrap:wrap;justify-content:center;width:100%;gap:2.2rem;padding:0 1.4rem}
}

/* ---------- split feature card (image | text), stacks on mobile ---------- */
.fig-split{display:grid;grid-template-columns:minmax(240px,380px) 1fr;gap:0;padding:0;overflow:hidden}
.fig-split img{width:100%;height:100%;object-fit:cover}
@media(max-width:700px){
  .fig-split{grid-template-columns:1fr}
  .fig-split img{height:auto;max-height:340px}
}

/* ---------- playable listening room ---------- */
.playlist ol li a{color:var(--mist);transition:color .25s}
.playlist ol li a:hover{color:var(--gold)}
.playerwrap{margin-top:1.2rem}

/* preset tester thumbs */
.ba-thumbs{display:flex;gap:.7rem;margin-top:1rem}
.ba-thumbs button{background:none;border:2px solid rgba(79,174,171,.35);border-radius:10px;padding:0;
  overflow:hidden;cursor:pointer;width:74px;height:74px;transition:border-color .25s;flex:none}
.ba-thumbs button img{width:100%;height:100%;object-fit:cover;display:block}
.ba-thumbs button.active,.ba-thumbs button:hover{border-color:var(--gold)}

/* readability refinements (no visual style change) */
h1,h2,h3{text-wrap:balance}
p,.lede,figcaption,.creed p{text-wrap:pretty}
section,[id]{scroll-margin-top:5.5rem}
body{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
