/* ============================================================
   Raka Ashok — portfolio
   Swiss / International Typographic system · black & white · Inter
   ============================================================ */

:root{
  --bg:#ffffff;
  --bg-soft:#f5f5f5;
  --ink:#0a0a0a;
  --ink-2:#222222;
  --muted:#8b8b8b;
  --muted-2:#6a6a6a;
  --line:#e9e9e9;
  --fill:#f3f3f3;
  --fill-2:#eaeaea;
  --black:#0a0a0a;
  --btn-bg:#0a0a0a;
  --btn-fg:#ffffff;
  --raised:#ffffff;
  --glass-rgb:255,255,255;
  color-scheme:light;

  --container:1280px;
  --gutter:clamp(20px, 5vw, 64px);
  --radius:999px;

  --ease:cubic-bezier(.22,.61,.36,1);

  --fs-display:clamp(2.8rem, 9vw, 6.5rem);
  --fs-h1:clamp(2.2rem, 6.2vw, 4.4rem);
  --fs-h2:clamp(1.5rem, 3.4vw, 2.4rem);
  --fs-lead:clamp(1.1rem, 2.3vw, 1.6rem);
  --fs-body:1.0625rem;
  --fs-cap:0.84rem;
  --fs-label:0.72rem;
}

[data-theme="dark"]{
  --bg:#0b0b0b;
  --bg-soft:#161616;
  --ink:#f4f4f4;
  --ink-2:#dcdcdc;
  --muted:#8f8f8f;
  --muted-2:#b2b2b2;
  --line:#272727;
  --fill:#1a1a1a;
  --fill-2:#262626;
  --btn-bg:#f4f4f4;
  --btn-fg:#0a0a0a;
  --raised:#2c2c2c;
  --glass-rgb:14,14,14;
  color-scheme:dark;
}

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

html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}

body{
  font-family:"Inter","Inter Placeholder",system-ui,-apple-system,sans-serif;
  font-feature-settings:"cv11","ss01","liga","calt";
  background:var(--bg);
  color:var(--ink);
  font-size:var(--fs-body);
  line-height:1.55;
  letter-spacing:-0.011em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background-color .35s var(--ease), color .35s var(--ease);
}

img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}

.container{max-width:var(--container);margin:0 auto;padding-inline:var(--gutter)}

/* ---------- type ---------- */
.eyebrow{
  font-size:var(--fs-label);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:600;
  color:var(--muted);
}
.display{font-size:var(--fs-display);font-weight:700;line-height:.96;letter-spacing:-.035em}
h1,.h1{font-size:var(--fs-h1);font-weight:700;line-height:1.02;letter-spacing:-.03em}
h2,.h2{font-size:var(--fs-h2);font-weight:650;line-height:1.08;letter-spacing:-.02em}
.lead{font-size:var(--fs-lead);line-height:1.32;color:var(--muted-2);font-weight:420;letter-spacing:-.015em;max-width:30ch}
.muted{color:var(--muted)}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  background:rgba(var(--glass-rgb),.72);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.nav.is-scrolled{border-color:var(--line)}
.nav__inner{
  max-width:var(--container);margin:0 auto;
  padding:14px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
}
.nav__brand{
  display:inline-flex;align-items:center;gap:.5em;
  padding:9px 18px;border-radius:var(--radius);
  background:var(--fill);
  font-weight:600;letter-spacing:-.02em;
  transition:background .25s var(--ease), transform .25s var(--ease);
}
.nav__brand:hover{background:var(--fill-2)}
.nav__brand .dot{width:7px;height:7px;border-radius:50%;background:var(--ink);display:inline-block}
.nav__links{display:flex;gap:8px;flex-wrap:wrap}
.pill{
  padding:9px 16px;border-radius:var(--radius);
  background:var(--fill);color:var(--ink-2);
  font-size:.92rem;font-weight:500;
  transition:background .22s var(--ease),color .22s var(--ease),transform .22s var(--ease);
  white-space:nowrap;
}
.pill:hover{background:var(--fill-2);transform:translateY(-1px)}
.pill.is-active{background:var(--btn-bg);color:var(--btn-fg)}
.pill--icon{padding:0;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center}
.pill--icon svg{display:block;width:17px;height:17px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  padding:15px 26px;border-radius:var(--radius);
  background:var(--btn-bg);color:var(--btn-fg);font-weight:550;font-size:.98rem;
  letter-spacing:-.01em;
  transition:transform .25s var(--ease),opacity .25s var(--ease),background .25s var(--ease);
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn .arr{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn--ghost:hover{background:var(--fill)}

/* ---------- sections / rhythm ---------- */
.section{padding-block:clamp(56px,9vw,130px)}
.page-head{padding-top:clamp(48px,9vw,120px);padding-bottom:clamp(28px,5vw,60px)}
.page-head .lead{margin-top:clamp(18px,2.4vw,30px)}

/* ---------- work / index rows ---------- */
.rows{display:flex;flex-direction:column;gap:10px}
.row{
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:16px;
  padding:clamp(18px,2.6vw,30px) clamp(20px,2.6vw,30px);
  background:var(--fill);border-radius:18px;
  transition:background .28s var(--ease),transform .28s var(--ease);
}
.row:hover{background:var(--fill-2);transform:translateX(4px)}
.row__title{font-size:clamp(1.15rem,2.4vw,1.7rem);font-weight:600;letter-spacing:-.02em}
.row__meta{display:flex;gap:18px;align-items:baseline;color:var(--muted-2);font-size:.95rem}
.row__meta .yr{color:var(--muted)}
.row .arr{color:var(--muted);transition:transform .3s var(--ease),color .3s var(--ease)}
.row:hover .arr{transform:translateX(5px);color:var(--ink)}
.row__role{display:none}
@media(min-width:720px){.row__role{display:inline}}

/* ---------- project article ---------- */
.back{display:inline-flex;align-items:center;gap:.5em;color:var(--muted-2);font-size:.92rem;
  transition:color .2s var(--ease),gap .2s var(--ease)}
.back:hover{color:var(--ink);gap:.7em}
.proj-head{padding-top:clamp(30px,5vw,60px);padding-bottom:clamp(34px,6vw,72px)}
.proj-head .display{margin:.18em 0 .35em}
.proj-meta{display:flex;flex-wrap:wrap;gap:10px 26px;color:var(--muted-2);font-size:.95rem;
  border-top:1px solid var(--line);padding-top:22px;margin-top:30px}
.proj-meta span b{font-weight:600;color:var(--ink)}
.proj-intro{font-size:clamp(1.15rem,2.3vw,1.7rem);line-height:1.4;font-weight:420;
  letter-spacing:-.018em;max-width:32ch;color:var(--ink-2)}

.slides{display:flex;flex-direction:column;gap:clamp(46px,8vw,110px);padding-bottom:clamp(40px,7vw,90px)}
.slide{}
.slide__img{
  border-radius:14px;overflow:hidden;background:var(--bg-soft);
  border:1px solid var(--line);
  box-shadow:0 1px 2px rgba(0,0,0,.02);
}
.slide__img img{width:100%}
.slide__cap{
  display:flex;gap:14px;margin-top:18px;max-width:62ch;
  color:var(--muted-2);font-size:var(--fs-cap);line-height:1.5;letter-spacing:0;
}
.slide__cap .n{flex:none;color:var(--muted);font-variant-numeric:tabular-nums;
  font-weight:500;padding-top:.05em}
.slide--divider .slide__img{border:none;background:none;box-shadow:none}
.slide--divider{text-align:center}

.proj-next{border-top:1px solid var(--line);padding-block:clamp(40px,6vw,80px);
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px}

/* ---------- posters ---------- */
.posters-bar{
  position:sticky;top:64px;z-index:20;
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding-block:14px;margin-bottom:8px;
  background:rgba(var(--glass-rgb),.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.posters-bar .count{color:var(--muted);font-size:.9rem;font-variant-numeric:tabular-nums}
.seg{display:inline-flex;gap:4px;background:var(--fill);padding:4px;border-radius:var(--radius)}
.seg button{
  display:inline-flex;align-items:center;gap:.4em;
  padding:8px 14px;border-radius:var(--radius);font-size:.85rem;font-weight:500;color:var(--muted-2);
  transition:background .2s var(--ease),color .2s var(--ease);
}
.seg button svg{display:block}
.seg button.is-active{background:var(--raised);color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.12)}

.grid{display:grid;gap:clamp(10px,1.4vw,18px)}
.grid[data-view="all"]{grid-template-columns:repeat(2,1fr)}
.grid[data-view="two"]{grid-template-columns:1fr}
@media(min-width:640px){
  .grid[data-view="all"]{grid-template-columns:repeat(3,1fr)}
  .grid[data-view="two"]{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:980px){.grid[data-view="all"]{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1240px){.grid[data-view="all"]{grid-template-columns:repeat(5,1fr)}}

.card{
  position:relative;border-radius:12px;overflow:hidden;cursor:pointer;
  background:var(--bg-soft);border:1px solid var(--line);
  aspect-ratio:3/4;
}
.grid[data-view="two"] .card{aspect-ratio:auto}
.card__img{width:100%;height:100%;object-fit:cover;
  transition:transform .7s var(--ease);
}
.grid[data-view="two"] .card__img{height:auto;object-fit:contain;background:var(--bg-soft)}
.card:hover .card__img{transform:scale(1.035)}

.card__overlay{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:16px;
  background:linear-gradient(to top,rgba(8,8,8,.82) 0%,rgba(8,8,8,.35) 42%,rgba(8,8,8,0) 72%);
  opacity:0;transition:opacity .35s var(--ease);
  color:#fff;
}
.card:hover .card__overlay,.card:focus-within .card__overlay{opacity:1}
.card__plus{
  position:absolute;top:12px;right:12px;width:26px;height:26px;border-radius:50%;
  background:rgba(255,255,255,.18);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;line-height:1;
  transform:scale(.6) rotate(-90deg);opacity:0;transition:transform .4s var(--ease),opacity .35s var(--ease);
}
.card:hover .card__plus{transform:scale(1) rotate(0);opacity:1}
.card__title{
  font-size:.95rem;font-weight:600;letter-spacing:-.01em;
  transform:translateY(12px);opacity:0;transition:transform .45s var(--ease) .04s,opacity .4s var(--ease) .04s;
}
.card__cap{
  font-size:.8rem;line-height:1.45;color:rgba(255,255,255,.78);margin-top:5px;
  transform:translateY(14px);opacity:0;
  transition:transform .5s var(--ease) .12s,opacity .45s var(--ease) .12s;
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;
}
.card:hover .card__title,.card:focus-within .card__title,
.card:hover .card__cap,.card:focus-within .card__cap{transform:translateY(0);opacity:1}
.card.is-tapped .card__overlay{opacity:1}
.card.is-tapped .card__title,.card.is-tapped .card__cap{transform:translateY(0);opacity:1}
.card.is-tapped .card__plus{transform:scale(1) rotate(0);opacity:1}

/* ---------- mobile poster stack (≤767px only) ---------- */
.pstack{display:none}
@media(max-width:767px){
  .pstack{display:block}
  .posters-bar{display:none}
  #grid{display:none}
}
.pstack{touch-action:pan-y;outline:none;overflow-x:clip;
  -webkit-user-select:none;user-select:none}
.pstack__stage{position:relative;height:clamp(450px,76vh,720px);margin:6px auto 0}
.pcard{position:absolute;left:50%;top:50%;will-change:transform,opacity;
  transition:transform .62s cubic-bezier(.22,1,.36,1), opacity .45s ease}
.pstack__stage.no-anim .pcard,.pstack__stage.is-dragging .pcard{transition:none}
.pcard img{display:block;height:clamp(360px,58vh,560px);width:auto;max-width:90vw;
  border-radius:5px;background:var(--bg-soft);
  box-shadow:0 1px 2px rgba(0,0,0,.05), 0 16px 34px rgba(0,0,0,.16);
  -webkit-user-drag:none;user-drag:none}
[data-theme="dark"] .pcard img{box-shadow:0 1px 2px rgba(0,0,0,.45), 0 18px 40px rgba(0,0,0,.6)}
.pstack__meta{display:flex;align-items:center;justify-content:space-between;gap:16px;
  max-width:90vw;margin:16px auto 0;color:var(--muted-2)}
.pstack__cap{font-size:.92rem;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pstack__count{font-size:.8rem;color:var(--muted);font-variant-numeric:tabular-nums;flex:none}
.pstack__hint{display:block;text-align:center;color:var(--muted);font-size:.78rem;margin-top:8px}
@media(prefers-reduced-motion:reduce){.pcard{transition:opacity .3s ease}}

/* ---------- lightbox ---------- */
.lb{
  position:fixed;inset:0;z-index:100;display:none;
  background:rgba(8,8,8,.97);
  flex-direction:column;
  opacity:0;transition:opacity .35s var(--ease);
}
.lb.is-open{display:flex;opacity:1}
.lb__top{display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(16px,4vw,40px);color:rgba(255,255,255,.7);font-size:.85rem;
  font-variant-numeric:tabular-nums;flex:none}
.lb__close{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;color:#fff;
  transition:background .2s var(--ease),transform .2s var(--ease)}
.lb__close:hover{background:rgba(255,255,255,.22);transform:rotate(90deg)}
.lb__stage{flex:1;display:flex;align-items:center;justify-content:center;
  position:relative;padding:0 clamp(8px,5vw,80px);min-height:0}
.lb__img{max-width:100%;max-height:100%;object-fit:contain;border-radius:6px;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  opacity:0;transform:scale(.97);transition:opacity .45s var(--ease),transform .55s var(--ease)}
.lb__img.is-in{opacity:1;transform:scale(1)}
.lb__nav{position:absolute;top:50%;transform:translateY(-50%);
  width:clamp(40px,6vw,54px);height:clamp(40px,6vw,54px);border-radius:50%;
  background:rgba(255,255,255,.1);color:#fff;display:flex;align-items:center;justify-content:center;
  transition:background .2s var(--ease)}
.lb__nav:hover{background:rgba(255,255,255,.24)}
.lb__nav--prev{left:clamp(8px,2vw,26px)}
.lb__nav--next{right:clamp(8px,2vw,26px)}
.lb__cap{flex:none;text-align:center;color:#fff;padding:20px clamp(16px,5vw,40px) 34px;
  max-width:64ch;margin:0 auto}
.lb__cap h3{font-size:1.05rem;font-weight:600;letter-spacing:-.01em;
  opacity:0;transform:translateY(10px);transition:all .5s var(--ease) .1s}
.lb__cap p{font-size:.9rem;color:rgba(255,255,255,.72);line-height:1.5;margin-top:6px;
  opacity:0;transform:translateY(12px);transition:all .55s var(--ease) .2s}
.lb.cap-in .lb__cap h3,.lb.cap-in .lb__cap p{opacity:1;transform:translateY(0)}

/* ---------- about ---------- */
.about-grid{display:grid;gap:clamp(34px,5vw,64px);grid-template-columns:1fr}
@media(min-width:900px){.about-grid{grid-template-columns:1.4fr .9fr}}
.about-body p{font-size:clamp(1.15rem,2.2vw,1.6rem);line-height:1.42;letter-spacing:-.018em;
  color:var(--ink-2);font-weight:420;max-width:34ch}
.about-body p+p{margin-top:1.1em}
.facts{border-top:1px solid var(--line)}
.fact{display:grid;grid-template-columns:1fr 1.4fr;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.fact dt{font-size:var(--fs-label);text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600}
.fact dd{font-size:.98rem;color:var(--ink-2)}
.fact dd a{border-bottom:1px solid var(--line);transition:border-color .2s}
.fact dd a:hover{border-color:var(--ink)}

/* ---------- form ---------- */
.form{display:grid;gap:22px;max-width:620px}
.field{display:flex;flex-direction:column;gap:9px}
.field label{font-size:var(--fs-label);text-transform:uppercase;letter-spacing:.12em;color:var(--muted-2);font-weight:600}
.field input,.field textarea,.field select{
  font:inherit;color:var(--ink);background:var(--fill);border:1px solid transparent;
  border-radius:14px;padding:15px 18px;transition:border-color .2s var(--ease),background .2s var(--ease);
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--ink);background:var(--bg)}
.field textarea{resize:vertical;min-height:130px}
.field--row{display:grid;gap:22px}
@media(min-width:620px){.field--row{grid-template-columns:1fr 1fr}}
.form__note{color:var(--muted);font-size:.9rem}
.form__ok{display:none;padding:18px 20px;border-radius:14px;background:var(--btn-bg);color:var(--btn-fg);font-size:.95rem}
.form__ok.show{display:block;animation:rise .5s var(--ease)}

/* ---------- featured strip (home) ---------- */
.strip{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(190px,1fr);gap:14px;
  overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px;
  scrollbar-width:none}
.strip::-webkit-scrollbar{display:none}
.strip .card{scroll-snap-align:start}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);margin-top:clamp(40px,8vw,120px)}
.footer__inner{padding-block:clamp(48px,7vw,90px);display:grid;gap:40px}
.footer__cta{display:flex;flex-wrap:wrap;align-items:end;justify-content:space-between;gap:28px}
.footer__cta h2{max-width:14ch}
.footer__bottom{display:flex;flex-wrap:wrap;gap:14px 28px;justify-content:space-between;
  align-items:center;border-top:1px solid var(--line);padding-top:28px;color:var(--muted);font-size:.88rem}
.footer__links{display:flex;gap:20px;flex-wrap:wrap}
.footer__links a{color:var(--muted-2);transition:color .2s}
.footer__links a:hover{color:var(--ink)}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto!important}
}

@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---------- misc ---------- */
.hero{padding-top:clamp(46px,11vw,140px);padding-bottom:clamp(40px,8vw,90px)}
.hero .lead{margin-top:clamp(20px,3vw,38px);max-width:36ch}
.link-line{display:inline-flex;align-items:center;gap:.45em;font-weight:550;
  border-bottom:1px solid var(--ink);padding-bottom:2px;transition:gap .25s var(--ease)}
.link-line:hover{gap:.75em}
.divider-rule{height:1px;background:var(--line);border:0;margin:0}
.stack-sm{display:flex;flex-direction:column;gap:6px}

/* ---------- about: listen / soundcloud ---------- */
.listen{padding-top:clamp(40px,6vw,80px)}
.sc-embed{border-radius:14px;overflow:hidden;border:1px solid var(--line);
  background:var(--bg-soft);margin:16px 0 16px}
.sc-embed iframe{display:block;width:100%;height:420px;border:0}

/* ---------- about hero (a photo, seen first) ---------- */
.about-hero{margin-top:clamp(18px,2.6vw,30px)}
.about-hero img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:16px;
  border:1px solid var(--line);background:var(--bg-soft);display:block}

/* ---------- client belt (auto-scroll wordmark marquee, fading edges) ---------- */
.belt-section{padding-top:clamp(40px,6vw,80px)}
.belt{position:relative;overflow:hidden;margin-top:14px;padding-block:6px;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%)}
.belt__track{display:flex;width:max-content;animation:belt 55s linear infinite}
.belt:hover .belt__track{animation-play-state:paused}
.belt__item{display:inline-flex;align-items:center;white-space:nowrap;
  font-size:clamp(1.05rem,2.4vw,1.7rem);font-weight:600;letter-spacing:-.022em;color:var(--ink)}
.belt__item::before{content:"·";color:var(--muted);font-weight:400;
  margin:0 clamp(18px,2.6vw,38px)}
.belt__logo{height:26px;width:auto;max-width:96px;object-fit:contain;margin-right:11px;flex:none;
  opacity:.85}
.belt__name{white-space:nowrap}
@keyframes belt{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.belt__track{animation:none}}

/* ---------- music tiles ---------- */
.music-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(12px,1.6vw,20px);margin:18px 0 18px}
@media(min-width:640px){.music-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:980px){.music-grid{grid-template-columns:repeat(4,1fr)}}
.mtile{cursor:pointer;text-align:left;display:block;width:100%}
.mtile__art{position:relative;display:block;aspect-ratio:1/1;border-radius:12px;overflow:hidden;
  background:var(--bg-soft);border:1px solid var(--line)}
.mtile__art img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.mtile:hover .mtile__art img{transform:scale(1.05)}
.mtile__play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(8,8,8,.26);opacity:0;transition:opacity .3s var(--ease)}
.mtile:hover .mtile__play,.mtile:focus-visible .mtile__play,.mtile.is-playing .mtile__play{opacity:1}
.mtile__play>span{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.94);
  color:#0a0a0a;display:flex;align-items:center;justify-content:center;padding-left:3px;
  transform:scale(.8);transition:transform .3s var(--ease)}
.mtile:hover .mtile__play>span,.mtile.is-playing .mtile__play>span{transform:scale(1)}
.mtile__title{display:block;margin-top:11px;font-weight:550;font-size:.95rem;
  letter-spacing:-.01em;line-height:1.28}
.mtile.is-playing .mtile__title{text-decoration:underline;text-underline-offset:3px}
.mtile__meta{display:block;color:var(--muted);font-size:.8rem;margin-top:3px;
  font-variant-numeric:tabular-nums}

/* ---------- sticky soundcloud player ---------- */
.player{position:fixed;left:0;right:0;bottom:0;z-index:90;transform:translateY(125%);
  transition:transform .45s var(--ease);background:rgba(var(--glass-rgb),.97);
  backdrop-filter:saturate(160%) blur(12px);-webkit-backdrop-filter:saturate(160%) blur(12px);
  border-top:1px solid var(--line);box-shadow:0 -10px 40px rgba(0,0,0,.08)}
.player.show{transform:none}
.player__inner{max-width:var(--container);margin:0 auto;padding:10px var(--gutter);
  display:flex;align-items:center;gap:14px}
.player__inner iframe{flex:1;display:block;height:120px;border:0;border-radius:10px;min-width:0}
.player__close{flex:none;width:38px;height:38px;border-radius:50%;background:var(--fill);
  display:flex;align-items:center;justify-content:center;color:var(--ink);
  transition:background .2s var(--ease),transform .2s var(--ease)}
.player__close:hover{background:var(--fill-2);transform:rotate(90deg)}
body.player-open{padding-bottom:148px}
@media(max-width:768px){
  .player{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--bg)}
  .player__inner iframe{height:110px}
  body.player-open{padding-bottom:138px}
}

/* dark mode: lift grayscale client logos so they read on dark bg */
[data-theme="dark"] .belt__logo{filter:invert(1) grayscale(1) brightness(1.7) contrast(1.1)}

/* ---------- about: live / on-stage gallery ---------- */
.live{padding-top:clamp(40px,6vw,80px)}
.live-hero{border-radius:14px;overflow:hidden;background:var(--bg-soft);
  aspect-ratio:16/9;margin:16px 0 6px;border:1px solid var(--line)}
.live-hero img{width:100%;height:100%;object-fit:cover}
.live-cap{color:var(--muted);font-size:var(--fs-cap);margin:0 0 18px}
.live-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(8px,1.1vw,14px)}
@media(min-width:760px){.live-grid{grid-template-columns:repeat(3,1fr)}}
.live-grid figure{overflow:hidden;border-radius:12px;background:var(--bg-soft);
  aspect-ratio:3/2;border:1px solid var(--line)}
.live-grid img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.live-grid figure:hover img{transform:scale(1.045)}

/* mobile: drop backdrop blur (cheap repaints = smoother scroll) */
@media(max-width:768px){
  .nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(var(--glass-rgb),.94)}
  .posters-bar{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--bg);top:58px}
}
