/* ============================================================
   Tranquil Streams — bespoke theme styles
   Ported from the approved mockup (site-redesign-mockup v3).
   Dropped vs mockup: the single-page .page switcher, the dead
   wave-canvas/.wl layers, the design-notes + toast chrome, and
   the header logo float (the homepage logo sits still).
   ============================================================ */

:root{
  --paper:#f4f8f9; --paper2:#ffffff; --mist:#e6eff1; --mist2:#f0f6f6;
  --ink:#2f3f47; --ink2:#56686f; --dim:#8aa0a7;
  --teal:#3B7494; --teal-soft:#5e93a8; --powder:#79b3c8; --powder2:#a9d0de;
  --sage:#a9c3a0; --sage2:#c7dac0; --sage-bg:#bcd2b4;
  --amber:#c98f4b; --amber-soft:#e0b483;
  --spotify:#1DB954;
  --line:rgba(47,63,71,.12); --line2:rgba(59,116,148,.28);
  --serif:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --maxw:1120px;
}
*{box-sizing:border-box; margin:0; padding:0}
html{scroll-behavior:smooth; background:var(--paper); overflow-x:clip}
body{overflow-x:clip} /* iOS Safari ignores overflow-x set only on html; clip preserves the sticky header */
body{background:transparent; color:var(--ink); font-family:var(--sans); line-height:1.6; -webkit-font-smoothing:antialiased; min-height:100vh}
a{color:inherit; text-decoration:none}
img{max-width:100%; height:auto}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 clamp(18px,4vw,44px)}

/* ---------- HEADER ---------- */
.ts-header{position:sticky; top:0; z-index:30; background:rgba(244,248,249,.86); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); border-bottom:1px solid var(--line)}
.bar{display:flex; align-items:center; gap:18px; height:74px}
.brand{display:flex; align-items:center; gap:11px; cursor:pointer; flex:0 0 auto}
.brand img{height:92px; width:auto; display:block}
.brand .name{font-family:var(--serif); font-weight:500; font-size:22px; letter-spacing:.06em; color:var(--teal-soft); white-space:nowrap}
nav{display:flex; gap:4px; margin-left:auto; align-items:center}
nav .navlink{font-family:var(--sans); font-size:12px; letter-spacing:.16em; color:var(--ink2); background:none; border:0; cursor:pointer; padding:9px 12px; transition:.2s; text-transform:uppercase; font-weight:500; border-bottom:2px solid transparent}
nav .navlink:hover{color:var(--teal)}
nav .navlink.active{color:var(--teal); border-bottom-color:var(--teal)}
.followbtn{display:inline-flex; align-items:center; gap:8px; font-family:var(--sans); font-weight:600; font-size:12.5px; letter-spacing:.02em; color:#fff; background:var(--spotify); border:0; border-radius:999px; padding:10px 17px; cursor:pointer; transition:.2s; white-space:nowrap; margin-left:8px; box-shadow:0 6px 16px -8px rgba(29,185,84,.6)}
.followbtn:hover{transform:translateY(-1px); box-shadow:0 10px 22px -8px rgba(29,185,84,.7)}
.followbtn svg{width:15px; height:15px; display:block}
@media (max-width:820px){
  nav .navlink{padding:8px 7px; font-size:11px; letter-spacing:.1em}
  .brand img{height:64px}
  .followbtn span.lbl{display:none} .followbtn{padding:10px 12px}
}
/* Cap the header row so the nav (Follow/Spotify pill) can't exceed the viewport even before the 600px wrap applies; min-width:0 lets the flex row actually shrink. */
.bar{ max-width:100% }
nav{ max-width:100%; min-width:0 }
@media (max-width:600px){
  /* stack the header on phones so the nav + Follow button never overflow the viewport */
  .bar{flex-wrap:wrap; height:auto; min-height:58px; padding:8px 0; gap:6px 12px}
  .brand{margin:0 auto}
  .brand img{height:54px}
  nav{margin-left:0; width:100%; justify-content:center; flex-wrap:wrap; gap:2px}
  .followbtn{margin-left:4px}
}

/* ---------- TYPE ---------- */
section{padding:clamp(48px,7vw,90px) 0}
.eyebrow{font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--teal); font-weight:600}
h1{font-family:var(--serif); font-weight:300; line-height:1.05; font-size:clamp(40px,7vw,82px); letter-spacing:.01em; color:var(--teal-soft)}
h2{font-family:var(--serif); font-weight:400; line-height:1.12; font-size:clamp(28px,4.2vw,46px); letter-spacing:.01em; color:var(--teal-soft)}
h3{font-family:var(--serif); font-weight:500; font-size:clamp(19px,2.1vw,24px); letter-spacing:.01em; color:var(--ink)}
p.lead{font-size:clamp(16px,1.75vw,20px); color:var(--ink2); max-width:44ch}
p.body{color:var(--ink2); max-width:62ch}
.masthead{font-family:var(--serif); font-style:italic; font-weight:400; color:var(--ink2); font-size:clamp(17px,2.2vw,24px); letter-spacing:.05em}
.divider{height:1px; background:linear-gradient(90deg, transparent, var(--line2), transparent); max-width:var(--maxw); margin:0 auto}

/* ---------- FIXED DRIFTING-GLOW BACKGROUND ---------- */
.page-bg{position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden}
.page-bg .glow{position:absolute; border-radius:50%; filter:blur(64px); will-change:transform}
.page-bg .g1{width:95vw; height:95vw; left:-12vw; top:-32vw; background:radial-gradient(circle, rgba(59,116,148,.64), transparent 60%); animation:drift1 12s ease-in-out infinite}
.page-bg .g2{width:82vw; height:82vw; right:-22vw; top:24vh; background:radial-gradient(circle, rgba(121,179,200,.48), transparent 60%); animation:drift2 15s ease-in-out infinite}
.page-bg .g3{width:72vw; height:72vw; left:-16vw; bottom:-28vw; background:radial-gradient(circle, rgba(169,195,160,.44), transparent 60%); animation:drift3 18s ease-in-out infinite}
@keyframes drift1{0%,100%{transform:translate(0,0)} 50%{transform:translate(38vw,26vh)}}
@keyframes drift2{0%,100%{transform:translate(0,0)} 50%{transform:translate(-34vw,20vh)}}
@keyframes drift3{0%,100%{transform:translate(0,0)} 50%{transform:translate(32vw,-22vh)}}
@media (prefers-reduced-motion:reduce){ .page-bg .glow{animation:none} }
/* content sits above the glow layer; the dark hero covers it up top */
#page, main, footer.site{position:relative; z-index:1}

/* ---------- HERO (image-led, dark cinematic) ---------- */
.hero{position:relative; min-height:clamp(520px,84vh,720px); display:flex; align-items:center; overflow:hidden; isolation:isolate; clip-path:url(#heroWaveClip); background:#06080a; background-image:radial-gradient(130% 100% at 72% 45%, #15191b 0%, #0a0c0e 55%, #060708 100%)}
.hero-photo{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:62% 48%; z-index:0; will-change:transform}
.hero.no-photo::before{content:""; position:absolute; inset:0; z-index:0; background:radial-gradient(58% 92% at 70% 58%, rgba(120,150,165,.20), transparent 62%)}
.hero-scrim{position:absolute; inset:0; z-index:2; background:radial-gradient(82% 92% at 44% 52%, transparent 30%, rgba(5,7,8,.58) 100%), linear-gradient(180deg, rgba(5,7,8,.5) 0%, transparent 30%, transparent 58%, rgba(5,7,8,.9) 100%)}
.hero-inner{position:relative; z-index:3; max-width:var(--maxw); width:100%; margin:0 auto; padding:0 clamp(18px,4vw,44px)}
.hero-head{position:relative; max-width:min(560px,64%); margin-left:auto; text-align:right}
.hero-head::before{content:""; position:absolute; inset:-22% -14% -28% -6%; pointer-events:none; background:radial-gradient(72% 72% at 62% 50%, rgba(4,6,8,1), rgba(4,6,8,.6) 48%, transparent 80%); filter:blur(28px)}
.hero-head > *{position:relative}
.hero .name-lg{font-family:var(--serif); font-weight:300; font-size:clamp(42px,7.6vw,86px); color:#f3f8f9; letter-spacing:.04em; line-height:1.01}
.hero h1.sub{font-family:var(--serif); font-size:clamp(22px,3.2vw,36px); margin-top:.45em; color:rgba(235,244,246,.82); font-weight:300; max-width:24ch; margin-left:auto}
.hero .cta-row{justify-content:flex-start; margin-top:clamp(22px,3.6vh,38px)}
.hero .btn-ghost{color:#fff; border-color:rgba(255,255,255,.55)}
.hero .btn-ghost:hover{background:rgba(255,255,255,.12); border-color:#fff}
/* entrance (staggered, motion-safe; .hero-in added on load) */
.hero-head .name-lg, .hero-head h1.sub, .hero-inner .cta-row{opacity:0; transform:translateY(16px); transition:opacity 1s ease, transform 1s ease}
.hero.hero-in .name-lg{opacity:1; transform:none; transition-delay:.08s}
.hero.hero-in h1.sub{opacity:1; transform:none; transition-delay:.24s}
.hero.hero-in .cta-row{opacity:1; transform:none; transition-delay:.40s}
@media (prefers-reduced-motion:reduce){
  .hero-head .name-lg, .hero-head h1.sub, .hero-inner .cta-row{opacity:1; transform:none; transition:none}
}
@media (max-width:680px){
  .hero-head{max-width:none; margin:0 auto; text-align:center}
  .hero h1.sub{margin-left:auto; margin-right:auto; max-width:26ch}
  .hero .cta-row{justify-content:center}
  .hero-photo{object-position:58% 45%}
  .hero-scrim{background:linear-gradient(180deg, rgba(5,7,8,.5) 0%, rgba(5,7,8,.28) 40%, rgba(5,7,8,.92) 100%)}
}
.cta-row{display:flex; gap:13px; justify-content:center; flex-wrap:wrap; margin-top:clamp(24px,3.2vh,36px)}
.btn{display:inline-flex; align-items:center; gap:9px; font-family:var(--sans); font-weight:600; font-size:14px; letter-spacing:.02em; border-radius:999px; padding:13px 24px; cursor:pointer; transition:.2s; border:1.5px solid transparent}
.btn-spotify{color:#fff; background:var(--spotify); box-shadow:0 8px 20px -9px rgba(29,185,84,.6)}
.btn-spotify:hover{transform:translateY(-2px); box-shadow:0 14px 28px -10px rgba(29,185,84,.72)}
.btn-ghost{color:var(--teal); background:transparent; border-color:var(--line2)}
.btn-ghost:hover{background:rgba(59,116,148,.07); border-color:var(--teal)}
.btn svg{width:16px; height:16px}

/* ---------- RECOGNITION + EMBEDS ---------- */
.recog{text-align:center}
.recog h2{max-width:20ch; margin:14px auto .4em}
.recog p.body{margin:0 auto; text-align:center}
.chiprow{display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:30px}
.chip{display:inline-flex; align-items:center; gap:9px; font-family:var(--serif); font-weight:500; font-size:clamp(16px,1.9vw,20px); color:var(--teal-soft); background:var(--paper2); border:1px solid var(--line2); border-radius:999px; padding:10px 20px; cursor:pointer; transition:.22s}
.chip:hover{border-color:var(--teal); color:var(--teal); box-shadow:0 6px 18px -10px rgba(59,116,148,.5)}
.chip.active{background:var(--teal); color:#fff; border-color:var(--teal)}
.chip .play{display:inline-flex; width:18px; height:18px; align-items:center; justify-content:center; border-radius:50%; background:rgba(59,116,148,.12); font-size:9px; color:var(--teal)}
.chip.active .play{background:rgba(255,255,255,.25); color:#fff}
.embed-wrap{max-height:0; overflow:hidden; transition:max-height .5s ease, margin .5s ease, opacity .4s ease; opacity:0; margin-top:0}
.embed-wrap.open{max-height:640px; opacity:1; margin-top:34px}
.embed-frame{max-width:760px; margin:0 auto; aspect-ratio:16/9; border-radius:16px; overflow:hidden; border:1px solid var(--line2); box-shadow:0 24px 60px -28px rgba(47,63,71,.4); background:#000}
.embed-frame iframe{width:100%; height:100%; border:0; display:block}
.embed-ph{max-width:760px; margin:0 auto; aspect-ratio:16/9; border-radius:16px; border:1px dashed var(--line2); background:linear-gradient(160deg,var(--mist),var(--mist2)); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px}
.embed-ph .pbtn{width:62px; height:62px; border-radius:50%; background:var(--paper2); border:1px solid var(--line2); display:flex; align-items:center; justify-content:center; color:var(--teal); font-size:20px; box-shadow:0 10px 24px -14px rgba(47,63,71,.4)}
.embed-ph .pt{font-size:13.5px; color:var(--ink2)} .embed-ph .pt b{color:var(--ink)}
.embed-cap{font-size:12.5px; color:var(--dim); margin-top:12px}

/* ---------- SAGE PHOTO CARDS (playlists) ---------- */
.cards3{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,40px)}
@media (max-width:760px){ .cards3{grid-template-columns:1fr; max-width:380px; margin:0 auto} }
.pcard{position:relative; cursor:pointer; display:block; color:inherit}
.pcard .frame{position:absolute; left:-14px; top:-14px; right:22px; bottom:22px; background:var(--sage-bg); border-radius:4px; z-index:0; transition:.3s}
.pcard:hover .frame{left:-18px; top:-18px}
.pcard .photo{position:relative; z-index:1; aspect-ratio:3/4; border-radius:3px; overflow:hidden; display:flex; align-items:flex-start; justify-content:center; text-align:center; padding:30px 22px 0; color:#fff; font-family:var(--serif); font-weight:400; font-size:clamp(20px,2.4vw,28px); letter-spacing:.04em; box-shadow:0 18px 40px -22px rgba(47,63,71,.5)}
.pcard .photo.p1{background:linear-gradient(180deg,#9fc6d6,#5f8aa0)}
.pcard .photo.p2{background:linear-gradient(180deg,#a9bf9e,#5f7f63)}
.pcard .photo.p3{background:linear-gradient(180deg,#d7a878,#7c5a48)}
.pcard .plabel{position:absolute; top:13px; right:13px; z-index:2; font-family:var(--sans); font-weight:600; font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:#fff; background:rgba(20,30,34,.34); border:1px solid rgba(255,255,255,.45); border-radius:999px; padding:4px 10px; backdrop-filter:blur(2px)}
.pcard .photo::after{content:attr(data-note); position:absolute; left:0; right:0; bottom:0; padding:14px 16px; font-family:var(--sans); font-weight:500; font-size:12px; letter-spacing:.02em; line-height:1.4; background:linear-gradient(180deg,transparent,rgba(0,0,0,.42)); text-transform:none}
.pcard .platbtn{position:absolute; left:50%; top:46%; transform:translate(-50%,-50%); z-index:2; filter:drop-shadow(0 6px 16px rgba(0,0,0,.45)); transition:transform .22s}
.pcard:hover .platbtn{transform:translate(-50%,-50%) scale(1.08)}
.pcard .platbtn svg{display:block}
.cards-note{text-align:center; font-size:12.5px; color:var(--dim); margin-top:26px}

/* ---------- RELEASE CARD ---------- */
.release{display:grid; grid-template-columns:220px 1fr; gap:clamp(22px,3.5vw,44px); align-items:center; background:var(--paper2); border:1px solid var(--line); border-radius:20px; padding:clamp(24px,3vw,36px); box-shadow:0 24px 60px -34px rgba(47,63,71,.32)}
@media (max-width:680px){ .release{grid-template-columns:1fr; text-align:center} }
.cover{aspect-ratio:1; border-radius:12px; background:radial-gradient(120% 100% at 70% 18%, rgba(224,180,131,.6), transparent 55%), linear-gradient(150deg,#caa279,#7c5a48); display:flex; align-items:center; justify-content:center; color:#fff; font-family:var(--serif); font-weight:400; font-size:clamp(18px,2vw,24px); letter-spacing:.08em; text-align:center; box-shadow:0 16px 40px -22px rgba(47,63,71,.5)}
.release .meta .eyebrow{display:block; margin-bottom:9px}
.release h2{margin-bottom:6px}
.release .sub{color:var(--ink2); font-size:15px; margin-bottom:20px; max-width:46ch}
@media (max-width:680px){ .release .sub{margin-left:auto; margin-right:auto} }
.listrow{display:flex; gap:10px; flex-wrap:wrap}
@media (max-width:680px){ .listrow{justify-content:center} }
.pill{display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:500; letter-spacing:.01em; color:var(--ink); background:var(--paper); border:1px solid var(--line2); border-radius:999px; padding:9px 16px; cursor:pointer; transition:.2s}
.pill:hover{border-color:var(--teal); color:var(--teal)}
.pill.primary{color:#fff; background:var(--spotify); border-color:var(--spotify); font-weight:600}
.pill.primary:hover{color:#fff; filter:brightness(1.05)}

/* ---------- NEWSLETTER ---------- */
.news{text-align:center; background:linear-gradient(180deg,var(--mist2),var(--mist)); border:1px solid var(--line); border-radius:22px; padding:clamp(32px,4.5vw,56px)}
.news h2{margin-bottom:10px}
.news p{color:var(--ink2); max-width:46ch; margin:0 auto 22px}
.news form{display:flex; gap:10px; justify-content:center; flex-wrap:wrap; max-width:470px; margin:0 auto}
.news input{flex:1; min-width:200px; background:var(--paper2); border:1px solid var(--line2); border-radius:999px; padding:13px 20px; color:var(--ink); font-family:var(--sans); font-size:14px}
.news input::placeholder{color:var(--dim)}
.news button{background:var(--teal); color:#fff; border:0; border-radius:999px; padding:13px 26px; font-family:var(--sans); font-weight:600; font-size:14px; cursor:pointer; transition:.2s}
.news button:hover{background:var(--teal-soft)}

/* ---------- LISTEN PAGE ---------- */
.listen-hero{text-align:center}
.platforms{display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:12px}
.plat{display:flex; align-items:center; justify-content:space-between; gap:10px; background:var(--paper2); border:1px solid var(--line); border-radius:14px; padding:15px 18px; cursor:pointer; transition:.25s}
.plat:hover{border-color:var(--line2); transform:translateY(-2px); box-shadow:0 14px 30px -22px rgba(47,63,71,.4)}
.plat .pn{font-weight:500; font-size:14px}
.plat .go{font-size:11px; color:var(--teal); letter-spacing:.1em; text-transform:uppercase}
.reltable{display:flex; flex-direction:column; gap:1px; border:1px solid var(--line); border-radius:14px; overflow:hidden; background:var(--line)}
.reltable .r{display:grid; grid-template-columns:1fr auto auto; gap:14px; align-items:center; padding:16px 20px; background:var(--paper2); transition:.2s; cursor:pointer}
.reltable .r:hover{background:var(--mist2)}
.reltable .r .t{font-family:var(--serif); font-weight:500; font-size:18px; color:var(--ink)}
.reltable .r .d{font-size:12px; color:var(--dim)}
.reltable .r .tag{font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--amber)}
.reltable .r .go{font-size:12px; color:var(--teal); letter-spacing:.04em}

/* ---------- STORY ---------- */
.story{max-width:680px; margin:0 auto}
.story .masthead{display:block; margin-bottom:1.3em; text-align:center; letter-spacing:.2em; text-transform:uppercase; font-style:normal; font-family:var(--sans); font-weight:500; font-size:12px; color:var(--teal)}
.story h1{text-align:center; margin-bottom:.55em; font-size:clamp(34px,5.4vw,58px)}
.story p{font-family:var(--serif); font-size:clamp(19px,2vw,23px); color:var(--ink); margin-bottom:1.15em; line-height:1.62; font-weight:400}
.story p:first-of-type::first-letter{font-size:3em; float:left; line-height:.8; padding:.04em .1em 0 0; color:var(--amber); font-weight:500}
.story .cta-row{justify-content:center; margin-top:18px}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(24px,4vw,52px); align-items:start}
@media (max-width:760px){ .contact-grid{grid-template-columns:1fr} }
.field{margin-bottom:16px}
.field label{display:block; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink2); margin-bottom:7px}
.field input,.field textarea{width:100%; background:var(--paper2); border:1px solid var(--line2); border-radius:12px; padding:13px 16px; color:var(--ink); font-family:var(--sans); font-size:14px}
.field textarea{min-height:120px; resize:vertical}
.contact-aside{background:var(--paper2); border:1px solid var(--line); border-radius:18px; padding:clamp(22px,3vw,30px); box-shadow:0 20px 50px -34px rgba(47,63,71,.3)}
.contact-aside h3{margin-bottom:6px}
.contact-aside p{font-size:14px; color:var(--ink2); margin-bottom:16px}
.contact-aside .em{color:var(--teal); font-size:14px; font-weight:500}
.synctag{margin-top:20px; padding-top:18px; border-top:1px solid var(--line)}
.synctag .eyebrow{display:block; margin-bottom:7px}

/* ---------- FOOTER ---------- */
footer.site{border-top:1px solid var(--line); margin-top:30px; padding:clamp(36px,5vw,58px) 0 42px; background:var(--mist2)}
.foot{display:flex; flex-wrap:wrap; gap:28px; justify-content:space-between; align-items:flex-start}
.foot .col h4{font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); margin-bottom:12px; font-weight:600}
.foot .col a{display:block; color:var(--ink2); font-size:13.5px; padding:4px 0; transition:.15s; cursor:pointer}
.foot .col a:hover{color:var(--teal)}
.foot .socials{display:flex; gap:9px; flex-wrap:wrap}
.foot .socials a{display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border:1px solid var(--line2); border-radius:50%; color:var(--ink2); font-size:11px; font-weight:600}
.foot .socials a:hover{border-color:var(--teal); color:var(--teal)}
.foot .brandcol{max-width:280px}
.foot .brandcol .brand{display:flex; align-items:center; gap:9px}
.foot .brandcol .name{font-family:var(--serif); font-size:20px; color:var(--teal-soft); letter-spacing:.05em}
.foot .brandcol .masthead{display:block; margin:8px 0 4px; font-size:15px}
.foot .brandcol p{font-size:12px; color:var(--dim)}
.copyright{text-align:center; color:var(--dim); font-size:12px; margin-top:34px}
.foot-news{display:flex; flex-wrap:wrap; gap:16px 30px; align-items:center; justify-content:space-between; padding-bottom:28px; margin-bottom:30px; border-bottom:1px solid var(--line)}
.foot-news .fn-text h4{font-family:var(--serif); font-weight:500; font-size:16px; color:var(--teal-soft); letter-spacing:.02em; margin-bottom:3px}
.foot-news .fn-text span{font-size:13px; color:var(--ink2)}
.foot-news .fn-form{display:flex; gap:9px; flex:0 1 430px; min-width:260px}
.foot-news .fn-form input{flex:1; background:var(--paper2); border:1px solid var(--line2); border-radius:999px; padding:11px 18px; color:var(--ink); font-family:var(--sans); font-size:14px}
.foot-news .fn-form input::placeholder{color:var(--dim)}
.foot-news .fn-form button{background:var(--teal); color:#fff; border:0; border-radius:999px; padding:11px 24px; font-family:var(--sans); font-weight:600; font-size:14px; cursor:pointer; transition:.2s}
.foot-news .fn-form button:hover{background:var(--teal-soft)}
@media (max-width:600px){ .foot-news .fn-form{flex-basis:100%} }

/* ---------- SHEET MUSIC ---------- */
.sm-intro{text-align:center}
.sm-intro h1{font-size:clamp(34px,5.4vw,58px); margin:14px 0 .35em}
.sm-intro p.lead{margin:0 auto}
.sm-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(232px,1fr)); gap:clamp(16px,2.2vw,26px)}
.sm-card{display:flex; flex-direction:column; background:var(--paper2); border:1px solid var(--line); border-radius:16px; overflow:hidden; cursor:pointer; transition:.25s}
.sm-card:hover{border-color:var(--line2); transform:translateY(-3px); box-shadow:0 20px 44px -28px rgba(47,63,71,.4)}
.sm-cover{aspect-ratio:1; display:flex; align-items:flex-end; padding:15px; color:#fff; font-family:var(--serif); font-weight:400; font-size:clamp(17px,2vw,21px); letter-spacing:.03em; line-height:1.18}
.sm-cover.c1{background:linear-gradient(160deg,#9fc6d6,#5f8aa0)}
.sm-cover.c2{background:linear-gradient(160deg,#a9bf9e,#5f7f63)}
.sm-cover.c3{background:linear-gradient(160deg,#d7a878,#7c5a48)}
.sm-cover.c4{background:linear-gradient(160deg,#b6a9cf,#6b5f87)}
.sm-body{padding:14px 15px 17px; display:flex; flex-direction:column; gap:3px; flex:1}
.sm-body .meta{font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--dim)}
.sm-body .price{font-size:15px; font-weight:600; color:var(--ink); margin-top:2px}
.sm-buy{margin-top:auto; padding-top:11px; display:flex; flex-direction:column; gap:6px}
.btn-buy{display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:var(--sans); font-weight:600; font-size:13px; color:#fff; background:var(--teal); border:0; border-radius:999px; padding:9px 16px; cursor:pointer; transition:.2s}
.btn-buy:hover{background:var(--teal-soft)}
.studio-link{font-size:12px; color:var(--ink2); text-align:center}
.studio-link b{color:var(--teal)}
.sm-tiers{display:grid; grid-template-columns:1fr 1fr; gap:clamp(16px,2.4vw,28px)}
@media (max-width:680px){ .sm-tiers{grid-template-columns:1fr} }
.tier{background:var(--paper2); border:1px solid var(--line); border-radius:18px; padding:clamp(22px,3vw,30px)}
.tier.studio{border-color:var(--line2); box-shadow:0 20px 50px -34px rgba(59,116,148,.4)}
.tier .tag{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--teal); font-weight:600}
.tier h3{margin:8px 0 6px}
.tier .amt{font-family:var(--serif); font-size:clamp(28px,4vw,38px); color:var(--teal-soft); line-height:1}
.tier .amt span{font-family:var(--sans); font-size:13px; color:var(--dim); letter-spacing:.02em}
.tier ul{list-style:none; margin:16px 0 0; display:flex; flex-direction:column; gap:9px}
.tier li{position:relative; padding-left:22px; font-size:14px; color:var(--ink2); line-height:1.45}
.tier li::before{content:"\266A"; position:absolute; left:0; top:1px; color:var(--teal); font-size:13px}
.tier li b{color:var(--ink)}
.sm-bundle{display:grid; grid-template-columns:1fr auto; gap:clamp(18px,3vw,36px); align-items:center; background:linear-gradient(180deg,var(--mist2),var(--mist)); border:1px solid var(--line); border-radius:20px; padding:clamp(24px,3.4vw,40px)}
@media (max-width:680px){ .sm-bundle{grid-template-columns:1fr; text-align:center} }
.sm-bundle h2{margin-bottom:6px}
.sm-bundle p{color:var(--ink2); font-size:14.5px; max-width:48ch}
@media (max-width:680px){ .sm-bundle p{margin:0 auto} }

/* ---------- FULL-BLEED OVERRIDE (neutralizes GeneratePress's container/sidebar on bespoke pages) ---------- */
/* body.ts-fullbleed is added in functions.php for the homepage + the four pages. */
.ts-fullbleed #page, .ts-fullbleed .site-content, .ts-fullbleed #content,
.ts-fullbleed #primary, .ts-fullbleed .content-area, .ts-fullbleed .grid-container{
  max-width:100% !important; width:100% !important; padding:0 !important; margin:0 !important; float:none !important;
}
.ts-fullbleed .site-content{ display:block !important; }
.ts-fullbleed .ts-page{ width:100% }
