/* ============================================================
   MOTIF — motionsites.ai design system
   System sans EVERYWHERE · near-pure black · coral + signature gradient accent.
   Dark-only, clean & minimal (Linear/Vercel/motionsites vibe).
   ============================================================ */

:root{
  --bg:#0a0a0a;
  --bg-deep:#000;
  --bg-soft:#161616;
  --panel:#242424;
  --surface:#242424;
  --surface-2:rgba(255,255,255,.05);
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.15);
  --ink:#FFFFFF;
  --ink-dim:#ABABAB;
  --ink-faint:#6b6b6b;
  --accent:#ff5a43;                /* solid coral — active states / small highlights */
  --accent-hi:#ff8266;
  --accent-deep:#e0432e;
  --accent-soft:rgba(255,90,67,.14);
  /* signature brand gradient — Most Popular badge, primary CTA, tasteful glows */
  --grad:linear-gradient(135deg, #FF6535 0%, #415FFF 50%, #D898FF 100%);
  --ember:rgba(255,90,67,.12);
  --bar:rgba(10,10,10,.72);
  --radius:16px;
  --radius-lg:20px;
  --maxw:1400px;
  --ease:cubic-bezier(.19,1,.22,1);
  --ease-soft:cubic-bezier(.2,.7,.2,1);
  --shadow-card:0 30px 70px -34px rgba(0,0,0,.95), 0 8px 24px -16px rgba(0,0,0,.8);
  --shadow-lift:0 50px 110px -36px rgba(0,0,0,1), 0 0 0 1px var(--line-2);
  /* bottom-weighted only — top two-thirds of every poster stays crisp & bright so the product shows at rest */
  --scrim:linear-gradient(transparent 0%, transparent 45%, rgba(0,0,0,.55) 74%, rgba(0,0,0,.85) 100%);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;
  letter-spacing:0;overflow-x:hidden;
}
em{font-family:inherit;font-style:normal;font-weight:inherit}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}

/* graceful global scrollbar */
*{scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}
body::-webkit-scrollbar{width:11px}
body::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px;border:3px solid var(--bg)}

/* ---------- ATMOSPHERE ---------- */
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.glow{position:fixed;top:-34vh;left:50%;transform:translateX(-50%);width:135vw;height:90vh;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(65,95,255,.08),transparent 60%);
  will-change:transform;}
/* slow drifting faint-gradient aurora for subtle depth */
/* PERF: no filter:blur() (radial gradients are already soft); cheap transform-only drift, no will-change */
.aurora{position:fixed;inset:-20% -10% auto -10%;height:120vh;z-index:0;pointer-events:none;opacity:.55;
  background:
    radial-gradient(40% 50% at 18% 12%, rgba(255,101,53,.08), transparent 70%),
    radial-gradient(46% 55% at 84% 4%, rgba(65,95,255,.08), transparent 72%),
    radial-gradient(38% 44% at 60% 30%, rgba(216,152,255,.06), transparent 70%);
  animation:drift 28s ease-in-out infinite alternate}
.vignette{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse 130% 90% at 50% 4%,transparent 52%,rgba(0,0,0,.55))}
@keyframes drift{
  0%{transform:translate3d(-2%,0,0) scale(1)}
  100%{transform:translate3d(3%,3%,0) scale(1.12)}
}

/* slim scroll-progress hairline pinned to the very top */
.scrollprog{position:fixed;top:0;left:0;right:0;height:2px;z-index:80;transform-origin:0 50%;transform:scaleX(0);
  background:var(--grad);
  box-shadow:0 0 14px -2px rgba(65,95,255,.5);pointer-events:none}

/* ---------- TOP BAR ---------- */
.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding-block:14px;
  padding-inline:calc(max(0px, (100% - var(--maxw)) / 2) + clamp(20px,5vw,56px));
  background:var(--bar);backdrop-filter:blur(22px) saturate(1.4);-webkit-backdrop-filter:blur(22px) saturate(1.4);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset, 0 18px 40px -34px rgba(0,0,0,.9);}
.tabs{display:flex;gap:3px;padding:4px;border:1px solid var(--line);border-radius:999px;
  background:var(--surface-2)}
.tab{position:relative;border:0;background:transparent;color:var(--ink-dim);padding:8px 19px;border-radius:999px;
  font-size:13px;font-weight:600;letter-spacing:0;transition:color .3s,background .35s var(--ease)}
.tab:hover{color:var(--ink)}
.tab.is-active{background:var(--ink);color:var(--bg-deep)}
.topright{display:flex;align-items:center;gap:16px}
.topmeta{font-size:10.5px;color:var(--ink-faint);text-transform:uppercase;
  letter-spacing:.12em;display:flex;align-items:center;gap:8px;white-space:nowrap}
.dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);
  animation:pulse 2.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 10px var(--accent)}50%{opacity:.45;box-shadow:0 0 4px var(--accent)}}

/* ---------- HERO (cinematic, overlapping type) ---------- */
main{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px)}
.hero{position:relative;padding:clamp(40px,7vh,92px) 0 clamp(14px,2vh,26px);overflow:visible}
/* cinematic hero film — dark motion backgrounds crossfading behind the headline */
.hero-film{position:absolute;z-index:-2;pointer-events:none;
  top:calc(-1 * clamp(16px,4vw,40px));left:50%;transform:translateX(-50%);
  width:100vw;height:calc(100% + clamp(40px,8vw,120px));overflow:hidden;
  -webkit-mask-image:radial-gradient(130% 100% at 62% 45%,#000 38%,transparent 86%);
          mask-image:radial-gradient(130% 100% at 62% 45%,#000 38%,transparent 86%)}
.hero-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
  opacity:0;transform:scale(1.04);transition:opacity 1.6s var(--ease-soft),transform 9s linear;
  filter:saturate(.92) contrast(1.02)}
.hero-vid.is-on{opacity:.5;transform:scale(1.1)}
/* darken so the headline always dominates the footage */
.hero-filmscrim{position:absolute;inset:0;
  background:
    linear-gradient(180deg,var(--bg) 0%,rgba(10,10,10,.42) 34%,rgba(10,10,10,.66) 70%,var(--bg) 100%),
    linear-gradient(90deg,var(--bg) 0%,transparent 30%,transparent 72%,var(--bg) 100%)}
.hero-ghost{position:absolute;left:-2vw;top:clamp(20px,5vw,70px);z-index:-1;pointer-events:none;
  font-weight:800;font-style:normal;font-size:clamp(180px,32vw,520px);line-height:.7;
  letter-spacing:-.04em;color:transparent;-webkit-text-stroke:1px var(--line);
  opacity:.5;user-select:none;white-space:nowrap}
.kicker{display:flex;align-items:center;gap:11px;font-size:12px;
  text-transform:uppercase;letter-spacing:.2em;color:var(--accent);margin:0 0 clamp(14px,2vh,22px);font-weight:600;
  animation:reveal .9s var(--ease) both}
.kicker::before{content:"";width:34px;height:1px;background:linear-gradient(90deg,var(--accent),transparent)}
.display{font-weight:800;font-style:normal;
  font-size:clamp(38px,min(7.6vw,9.5vh),104px);line-height:.92;letter-spacing:-.035em;margin:0;max-width:15ch;
  text-transform:uppercase;
  animation:reveal 1s var(--ease) .06s both}
.display br + em,.display em{
  background:var(--grad);
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  color:transparent;animation:sheen 7s ease-in-out infinite}
@keyframes sheen{0%,100%{background-position:140% 0}50%{background-position:-40% 0}}
.lede{max-width:56ch;margin:clamp(16px,2.1vh,26px) 0 0;color:var(--ink-dim);font-size:clamp(15px,1.45vw,20px);line-height:1.55;
  animation:reveal 1s var(--ease) .16s both}
.hero-stats{display:flex;flex-wrap:wrap;gap:clamp(22px,4.2vw,52px);margin-top:clamp(20px,2.8vh,34px);
  animation:reveal 1s var(--ease) .26s both}
.hero-stats .stat{display:flex;flex-direction:column;gap:2px}
.hero-stats .num{font-weight:800;font-size:clamp(30px,3.9vw,52px);line-height:1;color:var(--ink);
  letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.hero-stats .num span{color:var(--accent)}
.hero-stats .lab{font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:500}
@keyframes reveal{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* ---------- FEATURED REEL (cinematic) ---------- */
/* The reel reserves its vertical space up front (tile height = tile width / aspect),
   so the page NEVER reflows when the real tiles arrive. A dim skeleton row paints
   immediately on boot; the real reel fades in via .is-ready (no hard pop-in). */
.reel{position:relative;margin:clamp(14px,2.4vh,28px) 0 6px;overflow:hidden;
  /* reserve height = tile width(clamp 248–316) / (16/10 aspect) + a hair for the tile border */
  min-height:calc(clamp(248px,24vw,316px) / 1.6 + 2px);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.reel::after{content:"";position:absolute;left:0;right:0;bottom:-30px;height:60px;pointer-events:none;
  background:radial-gradient(ellipse 60% 100% at 50% 0,rgba(65,95,255,.07),transparent 70%)}
.reel-track{display:flex;gap:16px;width:max-content;
  opacity:0;transition:opacity .35s var(--ease)}      /* fade the reel in once populated */
.reel-track.is-ready{opacity:1}
.reel-track.is-real{animation:marquee 72s linear infinite}  /* marquee only runs on the real (looping) track */
.reel:hover .reel-track.is-real{animation-play-state:paused}
.reel-tile{position:relative;flex:0 0 auto;width:clamp(248px,24vw,316px);aspect-ratio:16/10;border-radius:13px;
  overflow:hidden;border:1px solid var(--line);cursor:pointer;background:#161616;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s}
.reel-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s var(--ease),filter .5s}
.reel-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 45%,rgba(0,0,0,.72))}
.reel-tile span{position:absolute;left:13px;bottom:11px;right:13px;z-index:2;font-weight:700;letter-spacing:-.01em;
  font-size:17px;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.9)}
.reel-tile:hover{transform:translateY(-6px) scale(1.015);border-color:var(--line-2);
  box-shadow:0 30px 60px -28px rgba(0,0,0,.95)}
.reel-tile:hover img{transform:scale(1.08);filter:saturate(1.1) contrast(1.04)}
/* dim, non-interactive placeholder tiles shown until the real reel is built */
.reel-tile.is-skel{cursor:default;background:var(--bg-soft);pointer-events:none}
.reel-tile.is-skel::before{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,#141414 30%,#202020 50%,#141414 70%);background-size:200% 100%;
  animation:shimmer 1.6s infinite;opacity:.6}
.reel-tile.is-skel::after{display:none}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- CONTROLS ---------- */
.controls{position:sticky;top:67px;z-index:40;display:flex;flex-direction:column;gap:14px;
  padding:18px 0 14px;margin-bottom:10px;
  background:linear-gradient(var(--bg),var(--bg) 74%,transparent);}
.ctl-row{display:flex;flex-wrap:wrap;align-items:center;gap:13px}
.bulk{display:flex;gap:7px}
.seg{display:flex;gap:3px;padding:4px;border:1px solid var(--line);border-radius:999px;background:var(--surface-2)}
.seg button{border:0;background:transparent;color:var(--ink-dim);padding:6px 15px;border-radius:999px;
  font-size:12.5px;font-weight:600;transition:all .25s var(--ease)}
.seg button:hover{color:var(--ink)}
.seg button.is-active{background:var(--accent-soft);color:var(--accent);box-shadow:inset 0 0 0 1px rgba(255,90,67,.3)}
.sortwrap{position:relative;display:flex}
.sortwrap::after{content:"▾";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--ink-faint);
  pointer-events:none;font-size:11px}
#sort{appearance:none;-webkit-appearance:none;border:1px solid var(--line);background:var(--surface-2);
  color:var(--ink);border-radius:999px;padding:9px 34px 9px 17px;font-family:inherit;font-size:12.5px;
  font-weight:600;cursor:pointer;outline:0;transition:border-color .25s}
#sort:hover{border-color:var(--line-2)}
#sort option{background:var(--panel);color:var(--ink)}
.search{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:999px;
  padding:10px 18px;min-width:250px;color:var(--ink-faint);background:var(--surface-2);
  transition:border-color .3s,box-shadow .3s}
.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.search input{border:0;background:transparent;color:var(--ink);outline:0;font-size:14px;width:100%}
.search input::placeholder{color:var(--ink-faint)}
.count{margin-left:auto;font-size:11px;color:var(--ink-faint);font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;white-space:nowrap}
.filters{display:flex;gap:8px;flex:1;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.filters::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;border:1px solid var(--line);background:transparent;color:var(--ink-dim);
  padding:7px 15px;border-radius:999px;font-size:12.5px;font-weight:600;white-space:nowrap;
  transition:all .25s var(--ease)}
.chip:hover{color:var(--ink);border-color:var(--line-2);transform:translateY(-1px)}
.chip.is-active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}
.chip small{opacity:.55;margin-left:6px;font-variant-numeric:tabular-nums}

/* ---------- GRID + POSTER CARDS ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(322px,1fr));gap:clamp(16px,1.7vw,24px);
  padding-bottom:90px}
/* template link row inside the lightbox (built by app.js fillTemplate) */
.tpl-links{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;justify-content:center}
/* data-load failure notice (built by app.js when the catalog fetch rejects) */
.grid-loaderr{color:#9b988f}
.card{position:relative;aspect-ratio:16/10;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;background:var(--bg-soft);box-shadow:var(--shadow-card);cursor:pointer;
  opacity:0;transform:translateY(26px) scale(.985);
  transition:opacity .7s var(--ease),transform .7s var(--ease),box-shadow .5s var(--ease),border-color .4s}
.card.in{opacity:1;transform:none}
/* hairline edge-glow ring that lights up on hover (sits above media, below meta) */
.card::before{content:"";position:absolute;inset:0;z-index:6;border-radius:inherit;pointer-events:none;
  box-shadow:inset 0 0 0 1px transparent;
  opacity:0;transition:opacity .45s var(--ease)}
.card:hover::before{opacity:1;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.22)}
/* staggered cascade for the opening screen */
.card:nth-child(1){transition-delay:.02s}.card:nth-child(2){transition-delay:.06s}
.card:nth-child(3){transition-delay:.10s}.card:nth-child(4){transition-delay:.14s}
.card:nth-child(5){transition-delay:.18s}.card:nth-child(6){transition-delay:.22s}
.card:nth-child(7){transition-delay:.26s}.card:nth-child(8){transition-delay:.30s}
.card:nth-child(9){transition-delay:.34s}.card:nth-child(10){transition-delay:.38s}
.card:nth-child(11){transition-delay:.42s}.card:nth-child(12){transition-delay:.46s}
.card:hover{border-color:var(--line-2);box-shadow:var(--shadow-lift);transform:translateY(-7px)}
.thumb{position:absolute;inset:0;overflow:hidden;background:#161616}
.thumb img,.thumb video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .8s var(--ease),filter .5s}
/* the product shows bright at rest — a touch of life without interaction */
.thumb img.poster{filter:saturate(1.05) brightness(1.04)}
.card:hover .thumb img.poster{transform:scale(1.07);filter:saturate(1.12) brightness(1.06) contrast(1.03)}
.thumb .anim{opacity:0;transition:opacity .5s var(--ease)}
.card:hover .thumb .anim{opacity:1}
/* bottom-weighted scrim only — top two-thirds of the poster stays crisp at rest, ramps on hover for title legibility */
.thumb::after{content:"";position:absolute;inset:0;background:var(--scrim);opacity:.78;transition:opacity .45s var(--ease)}
.card:hover .thumb::after{opacity:1}
/* faint inner keyline at rest for separation against near-black (must-fix depth) */
.thumb::before{content:"";position:absolute;inset:0;z-index:3;border-radius:inherit;pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)}
.badge{position:absolute;top:13px;left:13px;z-index:4;font-size:9px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;padding:5px 9px;border-radius:7px;color:var(--ink);
  background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.14)}
.badge.free{color:var(--accent);border-color:rgba(255,90,67,.4)}
.badge.vid{left:auto;right:13px;display:flex;align-items:center;gap:5px}
/* meta overlaid at the bottom of the poster */
.meta{position:absolute;left:0;right:0;bottom:0;z-index:5;display:flex;align-items:flex-end;
  justify-content:space-between;gap:12px;padding:18px 18px 17px}
.meta h3{font-weight:700;font-size:19px;line-height:1.12;margin:0;letter-spacing:-.01em;
  color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.85);transition:color .3s}
.card:hover .meta h3{color:#fff}
.meta .cat{font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:500;
  color:rgba(255,255,255,.62);margin-top:7px;display:block}
.copy{flex:0 0 auto;border:1px solid rgba(255,255,255,.2);background:rgba(0,0,0,.62);color:#fff;
  border-radius:9px;padding:8px 13px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;
  opacity:0;transform:translateY(6px);
  transition:opacity .35s var(--ease),transform .35s var(--ease),border-color .25s,background .25s,color .25s}
.card:hover .copy,.card:focus-within .copy{opacity:1;transform:none}
.copy:hover{border-color:var(--accent);color:#fff;background:var(--accent)}
.copy.ok{border-color:var(--accent);color:#fff;background:var(--accent);opacity:1;transform:none}

/* ---------- SKELETON ---------- */
.skeleton{aspect-ratio:16/10;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  background:var(--bg-soft);position:relative}
.skeleton .sk-img{position:absolute;inset:0;background:linear-gradient(100deg,#141414 30%,#222222 50%,#141414 70%);
  background-size:200% 100%;animation:shimmer 1.5s infinite}
.skeleton .sk-line{position:absolute;left:18px;bottom:20px;height:14px;width:52%;border-radius:6px;
  background:linear-gradient(100deg,#1c1c1c 30%,#2a2a2a 50%,#1c1c1c 70%);background-size:200% 100%;
  animation:shimmer 1.5s infinite}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}

/* ---------- BUTTONS ----------
   primary  => signature gradient + white text (semibold)
   white    => solid white bg + dark text (free / secondary CTA)
   ghost    => transparent + hairline border + white text */
.btn{position:relative;border:1px solid var(--line-2);background:transparent;color:var(--ink);border-radius:12px;
  padding:9px 16px;font-size:13px;font-weight:600;overflow:hidden;transition:all .25s var(--ease)}
.btn::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(255,255,255,.16),transparent);
  transform:translateX(-130%);transition:transform .6s var(--ease)}
.btn:hover::before{transform:translateX(130%)}
.btn:hover{border-color:var(--ink)}
.btn.primary{background:var(--grad);color:#fff;border-color:transparent;background-size:140% 140%;
  background-position:0% 50%;transition:background-position .5s var(--ease),transform .25s var(--ease),box-shadow .25s}
.btn.primary:hover{background-position:100% 50%;transform:translateY(-1px);
  box-shadow:0 12px 30px -12px rgba(65,95,255,.6)}
.btn.primary.ok{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.white{background:#fff;color:var(--bg);border-color:#fff}
.btn.white:hover{background:#f0f0f0;border-color:#f0f0f0}
.btn.ghost{border-color:var(--line-2);background:transparent;color:var(--ink)}
.btn.ghost:hover{border-color:var(--ink);color:var(--ink)}
.btn.sm{padding:6px 12px;font-size:11.5px}
.btn.icon{padding:9px 13px;line-height:1}
.btn:disabled{opacity:.28;cursor:default}
.btn:disabled::before{display:none}

/* ---------- MODAL (cinematic lightbox) ---------- */
.modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:clamp(12px,3vw,42px)}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.92);animation:fade .35s}
.modal-card{position:relative;width:min(1120px,100%);max-height:92vh;display:flex;flex-direction:column;
  background:var(--panel);border:1px solid var(--line-2);border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 60px 160px -40px rgba(0,0,0,1);
  animation:rise .5s var(--ease)}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 24px;
  border-bottom:1px solid var(--line)}
.m-cat{font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  color:var(--accent);margin:0 0 6px}
.m-title{font-weight:700;font-size:clamp(22px,3vw,30px);line-height:1.1;letter-spacing:-.02em;margin:0}
.m-actions{display:flex;gap:9px;align-items:center}
.m-count{font-size:11px;color:var(--ink-faint);letter-spacing:.06em;font-weight:500;
  margin-right:4px;white-space:nowrap}
.modal-body{display:grid;grid-template-columns:1.18fr 1fr;min-height:0;flex:1}
.m-media{background:#000;display:grid;place-items:center;overflow:hidden;position:relative}
.m-media img,.m-media video{width:100%;height:100%;max-height:92vh;object-fit:contain;display:block}
.m-textwrap{display:flex;flex-direction:column;min-height:0;border-left:1px solid var(--line)}
.m-textbar{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;
  border-bottom:1px solid var(--line);font-size:10px;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
.m-text{margin:0;padding:22px 24px;overflow:auto;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12.5px;
  line-height:1.78;color:#cfcfcf;white-space:pre-wrap;word-break:break-word;flex:1}
.m-text::-webkit-scrollbar{width:10px}
.m-text::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px;border:3px solid var(--panel)}

/* ---------- MISC ---------- */
.empty{text-align:center;color:var(--ink-faint);padding:90px 0;font-weight:700;font-size:24px;letter-spacing:-.01em}
.foot{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;padding:44px 0 64px;
  border-top:1px solid var(--line);color:var(--ink-dim);font-size:13px}
.foot .muted{color:var(--ink-faint);font-size:11px;letter-spacing:.04em}
.foot em{font-size:15px;color:var(--ink);font-weight:600}
.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(22px);z-index:200;
  background:var(--ink);color:var(--bg-deep);padding:12px 22px;border-radius:999px;font-size:13px;font-weight:600;
  box-shadow:0 24px 60px -22px rgba(0,0,0,.9);opacity:0;transition:all .35s var(--ease);pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@keyframes fade{from{opacity:0}}
@keyframes rise{from{opacity:0;transform:translateY(28px) scale(.98)}}

/* focus visibility */
.btn:focus-visible,.chip:focus-visible,.tab:focus-visible,.copy:focus-visible,#sort:focus-visible,
.seg button:focus-visible,.reel-tile:focus-visible,.card:focus-visible{
  outline:2px solid var(--accent);outline-offset:3px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:860px){
  .modal-body{grid-template-columns:1fr;overflow:auto}
  .m-media{max-height:44vh}
  .m-media img,.m-media video{max-height:44vh}
  .m-textwrap{border-left:0;border-top:1px solid var(--line)}
}
@media(max-width:680px){
  .m-count,.m-actions #m-prev,.m-actions #m-next{display:none}
  .topmeta{display:none}
  .grid{grid-template-columns:1fr}
  .card{aspect-ratio:16/11}
  .hero-ghost{display:none}
  .copy{opacity:1;transform:none}
}
/* Modal header on phones: the long primary action ("Unlock with Unlimited" /
   "↓ Download") was clipping and pushing the ✕ off-screen. Drop the actions to
   their own full-width row under the title; the button flexes, the ✕ stays put. */
@media(max-width:600px){
  .modal-head{flex-wrap:wrap;gap:10px 12px;padding:14px 16px}
  .m-cat{font-size:9.5px}
  .m-title{font-size:19px}
  .m-actions{flex:1 1 100%;gap:10px;align-items:center}
  #m-copy{flex:1 1 auto;min-width:0;justify-content:center;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  #m-close{flex:0 0 auto}
}
/* keep the topbar tidy as the account controls are added */
@media(max-width:920px){
  .topright{gap:10px}
  .planchip{display:none}            /* plan still shown in the account menu / paywall */
}
@media(max-width:560px){
  .topbar{flex-wrap:wrap;gap:12px 14px}
  #upgradebtn{padding:6px 12px;font-size:11.5px}
}
/* very narrow phones (~360px): the eyebrow ("AN OPEN LIBRARY · COPY · PASTE ·
   LAUNCH") + leading rule is ~387px wide and was overflowing, dragging the clip
   edge in for the whole hero. Let it wrap + shrink, and keep the 3 stats on one
   row without clipping the third label. */
@media(max-width:400px){
  .kicker{flex-wrap:wrap;font-size:10.5px;letter-spacing:.1em;gap:8px}
  .hero-stats{gap:15px}
  .hero-stats .num{font-size:26px}
  .hero-stats .lab{font-size:9px;letter-spacing:.07em}
}
/* Defensive: nothing should ever cause a sideways scroll on a phone. */
html,body{overflow-x:hidden}
/* touch devices have no hover — keep the copy action reachable */
@media(hover:none){
  .copy{opacity:1;transform:none}
}
/* ---------- ACCOUNT (topbar: sign-in + avatar menu) ---------- */
.signin-btn{flex:0 0 auto;display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.signin-btn[hidden]{display:none}   /* author display:inline-flex above would otherwise beat the UA [hidden] rule, so the button stays visible when signed in */
.account{position:relative;flex:0 0 auto}
.account[hidden]{display:none}
/* signed-in pill: avatar + email inline (round when no email present) */
.acct-trigger{display:inline-flex;align-items:center;gap:8px;height:36px;max-width:230px;padding:4px 13px 4px 4px;
  border:1px solid var(--line-2);background:var(--surface-2);border-radius:999px;
  transition:border-color .25s,background .25s,transform .35s var(--ease)}
.acct-trigger:hover{border-color:var(--line-2);background:var(--accent-soft)}
.acct-trigger-email{font-size:12.5px;font-weight:600;color:var(--ink);
  max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct-trigger-email:empty{display:none}
.acct-avatar{display:grid;place-items:center;width:28px;height:28px;border-radius:50%;
  font-size:12px;font-weight:700;line-height:1;letter-spacing:0;
  color:#fff;background:var(--grad);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.3)}
.acct-avatar.lg{width:40px;height:40px;font-size:16px}
.acct-menu{position:absolute;top:calc(100% + 12px);right:0;z-index:60;width:min(280px,84vw);
  background:var(--panel);border:1px solid var(--line-2);border-radius:var(--radius);
  box-shadow:0 40px 90px -36px rgba(0,0,0,.95),0 0 0 1px var(--line);
  padding:14px;display:flex;flex-direction:column;gap:10px;animation:rise .32s var(--ease)}
.acct-menu[hidden]{display:none}
.acct-id{display:flex;align-items:center;gap:12px;padding:2px 2px 12px;border-bottom:1px solid var(--line)}
.acct-id-text{display:flex;flex-direction:column;gap:2px;min-width:0}
.acct-email{font-size:13.5px;color:var(--ink);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct-provider{font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;
  color:var(--ink-faint)}
.acct-provider[hidden]{display:none}
.acct-planrow{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:2px 4px}
.acct-plan-lab{font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  color:var(--ink-faint)}
.acct-plan{font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  color:var(--accent);padding:4px 10px;border-radius:999px;background:var(--accent-soft);
  border:1px solid rgba(255,90,67,.4)}
.acct-item{text-align:left;border:1px solid var(--line);background:var(--surface-2);color:var(--ink);
  border-radius:12px;padding:10px 13px;font-size:13px;font-weight:600;transition:border-color .25s,background .25s,color .25s}
.acct-item:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}
.acct-item.danger:hover{border-color:rgba(255,90,67,.6);background:rgba(255,90,67,.12);color:var(--ink)}

/* ---------- SIGN-IN MODAL ---------- */
.si-card{position:relative;width:min(440px,100%);background:var(--panel);border:1px solid var(--line-2);
  border-radius:var(--radius-lg);padding:clamp(28px,4vw,40px);text-align:center;
  box-shadow:0 60px 160px -40px rgba(0,0,0,1);animation:rise .5s var(--ease)}
.si-x{position:absolute;top:14px;right:14px}
.si-eyebrow{font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  color:var(--accent);margin:0 0 10px}
.si-title{font-weight:800;font-size:clamp(26px,4vw,34px);line-height:1.06;letter-spacing:-.02em;
  margin:0 0 12px}
.si-sub{color:var(--ink-dim);font-size:14px;line-height:1.55;margin:0 auto 26px;max-width:34ch}
.si-providers{display:flex;flex-direction:column;gap:11px}
.si-prov{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;
  border:1px solid var(--line-2);background:var(--surface-2);color:var(--ink);
  border-radius:12px;padding:14px 18px;font-size:14.5px;font-weight:600;
  transition:border-color .25s,background .25s,transform .25s var(--ease)}
.si-prov:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px)}
.si-prov:active{transform:translateY(0)}
.si-glyph{flex:0 0 auto;display:block}
.si-note{font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;
  color:var(--ink-faint);margin:22px 0 0}

/* ---------- PLAN CHIP + UPGRADE (topbar) ---------- */
.planchip{position:relative;display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line-2);
  background:var(--surface-2);color:var(--ink-dim);
  border-radius:999px;padding:7px 14px;font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;font-weight:600;line-height:1;
  transition:border-color .25s,color .25s,background .25s,transform .25s var(--ease)}
.planchip::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ink-faint);
  transition:background .25s,box-shadow .25s}
.planchip:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.planchip[data-plan="premium"],.planchip[data-plan="unlimited"]{color:var(--accent);
  border-color:rgba(255,90,67,.45);background:var(--accent-soft)}
.planchip[data-plan="premium"]::before,.planchip[data-plan="unlimited"]::before{
  background:var(--accent);box-shadow:0 0 8px var(--accent)}
#upgradebtn{flex:0 0 auto}
/* signature-gradient upgrade CTA — the most prominent element in the bar */
#upgradebtn.primary{background:var(--grad);background-size:140% 140%;background-position:0% 50%;
  border-color:transparent;color:#fff;font-weight:600;
  box-shadow:0 8px 26px -12px rgba(65,95,255,.55),0 1px 0 rgba(255,255,255,.18) inset}
#upgradebtn.primary:hover{background-position:100% 50%;
  transform:translateY(-1px);box-shadow:0 12px 34px -12px rgba(65,95,255,.75),0 1px 0 rgba(255,255,255,.25) inset}
#upgradebtn.primary:active{transform:translateY(0)}

/* ---------- LOCKED PROMPT CARD (premium, not crude) ---------- */
.badge.premium{color:#fff;border-color:transparent;
  background:var(--grad)}
/* keep the locked poster a touch dimmer so the Premium badge + Unlock CTA read as the affordance */
.card.is-locked .thumb::after{opacity:.96}
.copy.locked{border-color:transparent;color:#fff;
  background:var(--grad)}
.copy.locked:hover{border-color:transparent;color:#fff;
  background:var(--grad);filter:brightness(1.08)}

/* notice state inside the lightbox text pane (premium fallback) */
.m-text.m-text-notice{color:var(--ink-dim);font-style:normal}

/* ---------- 404 page ---------- */
.notfound{min-height:calc(100svh - 66px);display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;gap:16px;padding:48px 22px}
.notfound .nf-logo{width:84px;height:84px;filter:drop-shadow(0 22px 50px rgba(0,0,0,.6))}
.notfound .display{font-size:clamp(44px,10vw,104px);margin:4px 0 0}
.notfound .lede{max-width:48ch;margin:0}
.notfound .nf-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:10px}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .card{opacity:1;transform:none}
  .reel-track{animation:none!important;opacity:1}  /* no marquee, no fade — show immediately */
  /* freeze the hero on its first poster frame; no crossfade/play (JS also bails out) */
  .hero-vid{opacity:0;transform:none}
  .hero-vid.is-on{opacity:.42;transform:none}
}