/* =====================================================================
   RILO, audience test site
   ===================================================================== */

:root{
  --bg:#08080b;
  --bg-2:#101017;
  --panel:#15151d;
  --panel-2:#1c1c26;
  --ink:#ffffff;
  --text:#d8d8de;
  --muted:#8f8f9a;
  --line:rgba(255,255,255,.10);

  --coral:#ef9f95;          /* soft pink, buttons / labels */
  --coral-strong:#f7907b;   /* brand peach */
  --coral-ink:#2a1411;

  --rilo-blue:#519acf;
  --rilo-yellow:#fbcb48;
  --rilo-teal:#62bdb1;
  --rilo-peach:#f7907b;

  --font-display:"Playfair Display",Georgia,"Times New Roman",serif;
  --font-body:"Spectral",Georgia,serif;

  --maxw:1480px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img,svg{display:block;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 48px;}

/* ============================ TOP NAV ============================ */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:40;
  display:flex;align-items:center;gap:32px;
  padding:22px 48px;
  background:linear-gradient(180deg,rgba(0,0,0,.75) 0%,rgba(0,0,0,0) 100%);
  transition:background .3s ease;
}
.topbar.solid{background:rgba(8,8,11,.92);backdrop-filter:blur(8px);}

.brand-logo{height:26px;width:auto;flex:0 0 auto;
  /* turn the dark PNG pure white */
  filter:brightness(0) invert(1);
  cursor:pointer;transition:opacity .2s ease,transform .2s ease;}
.brand-logo:hover{opacity:.82;transform:translateY(-1px);}
.nav-rilo{width:30px;height:auto;flex:0 0 auto;margin-right:-18px;visibility:hidden;}

.nav{display:flex;gap:26px;align-items:center;flex:1 1 auto;justify-content:center;}
.nav a{
  color:var(--muted);font-size:16px;letter-spacing:.2px;
  padding:6px 2px;border-bottom:2px solid transparent;
  transition:color .18s ease,border-color .18s ease;
  cursor:pointer;user-select:none;
}
.nav a:hover{color:var(--ink);border-bottom-color:var(--coral);}
.nav a.is-home{color:var(--coral);}

.nav-right{display:flex;align-items:center;gap:20px;flex:0 0 auto;}
.nav-right .ico{color:#cfcfd6;opacity:.85;transition:opacity .18s ease,transform .18s ease;cursor:pointer;}
.nav-right .ico:hover{opacity:1;transform:scale(1.08);color:#fff;}
.nav-right .kids{font-size:15px;color:var(--muted);transition:color .18s ease;cursor:pointer;}
.nav-right .kids:hover{color:#fff;}
.avatar{width:32px;height:32px;border-radius:7px;background:radial-gradient(circle at 50% 40%,#f7a39a,#ef8e83);
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .18s ease;}
.avatar:hover{transform:scale(1.06);}
.avatar svg{width:22px;height:22px;}
.chev{color:#cfcfd6;opacity:.8;}
.makers-r{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;
  border-radius:8px;margin-left:6px;opacity:.5;transition:.18s ease;}
.makers-r img{width:24px;height:auto;}
.makers-r:hover{opacity:1;transform:translateY(-1px);background:rgba(255,255,255,.07);}

/* ============================ HERO ============================ */
.hero{
  position:relative;width:100%;aspect-ratio:16/9;min-height:460px;max-height:92vh;
  display:flex;align-items:center;
  padding-top:80px;
  background:transparent;   /* image is 16:9, so it fills the hero with no crop */
  overflow:hidden;
}
.stars{position:absolute;inset:0;z-index:0;pointer-events:none;}
.moon{
  position:absolute;right:7%;top:8%;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle at 38% 34%,#f3f1ea 0%,#d8d6cd 45%,#a9a79e 78%,#8a887f 100%);
  box-shadow:0 0 120px 30px rgba(220,220,210,.18),inset -28px -22px 60px rgba(0,0,0,.25);
  z-index:0;opacity:.92;
}
.moon::after{content:"";position:absolute;inset:0;border-radius:50%;
  background:
    radial-gradient(circle at 62% 30%,rgba(0,0,0,.10) 0 8px,transparent 9px),
    radial-gradient(circle at 40% 62%,rgba(0,0,0,.09) 0 14px,transparent 15px),
    radial-gradient(circle at 70% 66%,rgba(0,0,0,.07) 0 10px,transparent 11px),
    radial-gradient(circle at 30% 30%,rgba(0,0,0,.06) 0 6px,transparent 7px);
  mix-blend-mode:multiply;}
.hero-skyline{position:absolute;left:0;right:0;bottom:0;height:230px;z-index:0;
  background:linear-gradient(180deg,rgba(7,7,10,0),#070709 82%);}
.hero-rilo-mark{position:absolute;right:13%;top:30%;width:150px;z-index:0;opacity:.95;
  filter:drop-shadow(0 8px 30px rgba(81,154,207,.35));animation:floaty 6s ease-in-out infinite;}
/* home-screen illustration, drops in once assets/home-ladder.jpg exists, gradient shows until then */
.hero-photo{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg,rgba(6,7,12,.72) 0%,rgba(6,7,12,.25) 36%,rgba(6,7,12,0) 62%),
    url(../assets/home-ladder.jpg) center/cover no-repeat;
  /* skyline stays visible at the bottom; only the very edge softens into the boxes */
  -webkit-mask-image:linear-gradient(180deg,#000 92%,transparent 100%);
          mask-image:linear-gradient(180deg,#000 92%,transparent 100%);}

/* blurred, darker version of the scene sitting behind the whole page */
.page-bg{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:url(../assets/home-ladder.jpg) center/cover no-repeat;
  filter:blur(26px) brightness(.3) saturate(1.05);transform:scale(1.16);}
#app{position:relative;z-index:1;}

/* twinkling stars over the hero */
.hero-sparkle{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden;}
.hero-sparkle .twinkle{position:absolute;border-radius:50%;background:#fff;
  box-shadow:0 0 6px 1px rgba(255,255,255,.55);animation:twinkle 3s ease-in-out infinite;}
@keyframes twinkle{0%,100%{opacity:.12;transform:scale(.6)}50%{opacity:1;transform:scale(1.15)}}

/* soft moon glow */
.moon-glow{position:absolute;z-index:1;top:10%;left:62%;width:min(30vw,320px);height:min(30vw,320px);
  transform:translate(-50%,0);border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(255,248,224,.22),rgba(255,248,224,.07) 45%,transparent 70%);
  animation:moonPulse 6s ease-in-out infinite;}
@keyframes moonPulse{0%,100%{opacity:.65}50%{opacity:1}}

/* background-music toggle */
.music-btn{position:fixed;right:22px;bottom:22px;z-index:50;width:52px;height:52px;border-radius:50%;
  background:var(--coral);color:var(--coral-ink);display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 26px rgba(0,0,0,.4);transition:transform .18s ease,filter .18s ease;}
.music-btn:hover{transform:translateY(-2px);filter:brightness(1.05);}
.music-btn[hidden]{display:none;}
.music-btn .ic-note{width:24px;height:24px;}
.music-btn .eq{display:none;align-items:flex-end;gap:3px;height:20px;}
.music-btn .eq i{width:3px;background:var(--coral-ink);border-radius:2px;animation:eq 1s ease-in-out infinite;}
.music-btn .eq i:nth-child(1){height:8px;animation-delay:0s}
.music-btn .eq i:nth-child(2){height:16px;animation-delay:.18s}
.music-btn .eq i:nth-child(3){height:11px;animation-delay:.36s}
.music-btn.playing .ic-note{display:none}
.music-btn.playing .eq{display:flex}
@keyframes eq{0%,100%{transform:scaleY(.4)}50%{transform:scaleY(1)}}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-14px) rotate(-2deg)}}

.hero-inner{position:relative;z-index:2;max-width:560px;}
.eyebrow{color:var(--coral);font-family:var(--font-body);font-weight:600;
  letter-spacing:.28em;font-size:12.5px;text-transform:uppercase;margin:0 0 14px;}
.hero-wordmark{width:340px;max-width:62vw;margin:0 0 18px;transform-origin:left center;
  animation:logoPulse 4.5s ease-in-out infinite;}
@keyframes logoPulse{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.035)}}
.hero h1{font-family:var(--font-display);font-weight:700;color:var(--ink);
  font-size:clamp(40px,5.2vw,62px);line-height:1.04;margin:0 0 20px;letter-spacing:.2px;}
.hero p.lede{color:#e7e7ec;font-size:clamp(17px,1.5vw,21px);line-height:1.55;margin:0 0 30px;max-width:500px;}
.hero-cta{display:flex;gap:16px;align-items:center;}

.btn{display:inline-flex;align-items:center;gap:10px;border-radius:8px;
  padding:13px 26px;font-size:16px;font-weight:600;font-family:var(--font-body);
  transition:transform .15s ease,filter .15s ease,background .2s ease;}
.btn:hover{transform:translateY(-1px);}
.btn-primary{background:var(--coral);color:var(--coral-ink);}
.btn-primary:hover{filter:brightness(1.06);}
.btn-ghost{background:rgba(120,120,135,.32);color:#fff;backdrop-filter:blur(4px);}
.btn-ghost:hover{background:rgba(120,120,135,.46);}
.btn svg{width:20px;height:20px;}

/* ====================== STORIES ROW ====================== */
.section{padding:6px 0 16px;position:relative;z-index:5;margin-top:0;}
.section-label{color:var(--coral);font-weight:600;letter-spacing:.26em;
  font-size:12.5px;text-transform:uppercase;margin:0 0 18px;padding-left:2px;}

.row-shell{position:relative;}
.cards{
  display:grid;grid-auto-flow:column;grid-auto-columns:minmax(288px,1fr);
  gap:22px;overflow-x:auto;scroll-behavior:smooth;padding:6px 2px 20px;
  scrollbar-width:none;
}
.cards::-webkit-scrollbar{display:none;}

.card{
  position:relative;border-radius:12px;overflow:hidden;aspect-ratio:4/3;
  border:1px solid var(--line);cursor:pointer;
  transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;
  background:#14141c;
}
.card:hover{transform:translateY(-6px) scale(1.03);
  box-shadow:0 18px 40px rgba(0,0,0,.55);border-color:var(--coral);z-index:3;}
.card .art{position:absolute;inset:0;}
.card .num{position:absolute;left:18px;top:12px;font-family:var(--font-display);
  font-weight:700;font-size:84px;line-height:1;color:rgba(255,255,255,.10);z-index:1;}
.card .ttl{position:absolute;left:0;right:0;top:18px;text-align:center;z-index:2;
  color:#f3f3f6;font-family:var(--font-display);font-size:22px;font-weight:600;
  padding:0 16px;text-shadow:0 2px 10px rgba(0,0,0,.6);}
.card .mark{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);
  width:64px;opacity:.9;z-index:2;}
.card .rate-hint{position:absolute;left:0;right:0;bottom:0;z-index:3;
  padding:8px 0;text-align:center;font-size:12.5px;letter-spacing:.04em;
  color:#fff;background:linear-gradient(0deg,rgba(0,0,0,.78),rgba(0,0,0,0));
  opacity:0;transform:translateY(6px);transition:.22s ease;}
.card:hover .rate-hint{opacity:1;transform:translateY(0);}
.card.voted .badge{position:absolute;right:12px;top:12px;z-index:4;
  width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--rilo-teal);color:#06231f;font-size:21px;font-weight:700;line-height:1;
  box-shadow:0 4px 14px rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.9);}

/* per-card art tints */
.art-1{background:radial-gradient(120% 120% at 30% 20%,#243247,#0e1320);}
.art-2{background:radial-gradient(120% 120% at 70% 30%,#1f3b3b,#0c1718);}
.art-3{background:radial-gradient(120% 120% at 40% 70%,#3a2c1c,#160f08);}
.art-4{background:radial-gradient(120% 120% at 60% 30%,#2a3550,#0c1018);}
.art-5{background:radial-gradient(120% 120% at 30% 60%,#3a2433,#140b12);}
.art-6{background:radial-gradient(120% 120% at 60% 40%,#1d2740,#0a0d16);}
.art-7{background:radial-gradient(120% 120% at 40% 30%,#33271b,#130d07);}
.art-8{background:radial-gradient(120% 120% at 60% 30%,#2c3322,#0f1409);}
.art-9{background:radial-gradient(120% 120% at 35% 35%,#2a2436,#110c18);}
.art-10{background:radial-gradient(120% 120% at 60% 60%,#1f3340,#0a141a);}

/* real-content thumbnails on a card */
.card .art-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.card.has-thumb .art::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.6),rgba(0,0,0,0) 40%,rgba(0,0,0,0) 60%,rgba(0,0,0,.5));}

.row-arrow{position:absolute;top:42%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;
  z-index:6;border:none;display:flex;align-items:center;justify-content:center;color:#fff;
  background:rgba(8,8,11,.72);opacity:.95;transition:.18s ease;box-shadow:0 6px 18px rgba(0,0,0,.45);cursor:pointer;}
.row-arrow:hover{background:var(--coral);color:var(--coral-ink);transform:translateY(-50%) scale(1.08);}
.row-arrow.left{left:-12px;}
.row-arrow.right{right:-12px;}
.row-arrow svg{width:24px;height:24px;}

/* ====================== NOTE BLOCK ====================== */
.note-block{max-width:940px;margin:34px auto 12px;background:var(--panel);
  border:1px solid var(--line);border-radius:18px;padding:34px 38px 34px;
  box-shadow:0 20px 50px rgba(0,0,0,.35);}
.note-head{display:flex;align-items:center;gap:20px;margin-bottom:22px;}
.note-icon{width:64px;height:64px;border:2px solid var(--coral);border-radius:14px 14px 14px 4px;
  display:flex;align-items:center;justify-content:center;color:var(--coral);flex:0 0 auto;}
.note-icon svg{width:30px;height:30px;}
.note-copy h3{color:var(--coral);font-family:var(--font-body);font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;font-size:17px;margin:0 0 6px;}
.note-copy p{margin:0;color:var(--text);font-size:16px;line-height:1.5;}
.note-block textarea{display:block;width:100%;min-height:180px;resize:vertical;
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px;color:#fff;
  font-family:var(--font-body);font-size:18px;line-height:1.5;padding:20px 22px;margin-bottom:18px;}
.note-block textarea::placeholder{color:#73737d;}
.note-block textarea:focus{outline:none;border-color:var(--coral);background:rgba(255,255,255,.06);}
.note-send{font-size:17px;padding:15px 32px;}

/* ============================ FOOTER ============================ */
.footer{border-top:1px solid var(--line);margin-top:24px;padding:34px 0 60px;}
.footer .tagline{display:flex;justify-content:center;align-items:center;gap:18px;
  flex-wrap:wrap;color:var(--coral);font-size:15px;text-align:center;margin-bottom:22px;}
.footer .tagline .laa{font-weight:700;}
.footer .legal{max-width:880px;margin:0 auto;text-align:center;color:#6b6b76;
  font-size:12.5px;line-height:1.7;}
.footer .legal strong{color:#9a9aa4;font-weight:600;}

/* ============================ MODAL ============================ */
.modal-backdrop{position:fixed;inset:0;z-index:60;background:rgba(4,4,7,.78);
  backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:24px;}
.modal-backdrop.open{display:flex;animation:fade .2s ease;}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{width:min(560px,100%);background:var(--panel);border:1px solid var(--line);
  border-radius:16px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.6);
  animation:pop .25s cubic-bezier(.2,.9,.3,1.2);}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}
.modal-hero{position:relative;display:flex;align-items:center;padding:15px 22px;}
.modal-hero h2{position:relative;z-index:2;margin:0;color:#fff;font-family:var(--font-display);
  font-size:23px;font-weight:700;text-shadow:0 2px 12px rgba(0,0,0,.6);}
.modal-body{padding:22px 24px 26px;}
.placeholder-tag{display:inline-block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);border:1px dashed var(--line);border-radius:20px;padding:4px 12px;margin-bottom:14px;}
.modal-body p.blurb{color:var(--text);font-size:16px;margin:0 0 22px;line-height:1.55;}
.vote-q{color:#fff;font-family:var(--font-display);font-size:20px;margin:0 0 16px;}

.thumbs{display:flex;gap:14px;margin-bottom:20px;}
.thumb{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:18px 10px;border:1.5px solid var(--line);border-radius:12px;
  background:rgba(255,255,255,.02);transition:.18s ease;color:var(--text);}
.thumb svg{width:34px;height:34px;}
.thumb span{font-size:14px;}
.thumb:hover{border-color:#fff;transform:translateY(-2px);color:#fff;}
.thumb.sel-up{border-color:var(--rilo-teal);background:rgba(98,189,177,.16);color:#fff;}
.thumb.sel-down{border-color:var(--coral-strong);background:rgba(247,144,123,.16);color:#fff;}

.comment-wrap label{display:block;color:var(--muted);font-size:13px;margin:0 0 8px;}
.comment-wrap textarea{width:100%;min-height:84px;resize:vertical;background:rgba(255,255,255,.04);
  border:1px solid var(--line);border-radius:10px;color:#fff;font-family:var(--font-body);
  font-size:15px;padding:12px 14px;}
.comment-wrap textarea:focus{outline:none;border-color:var(--coral);}
.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:22px;}
.modal-close{position:absolute;right:14px;top:14px;z-index:5;width:36px;height:36px;border-radius:50%;
  background:rgba(0,0,0,.45);color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:20px;transition:.18s ease;}
.modal-close:hover{background:rgba(0,0,0,.75);transform:rotate(90deg);}

.thanks{text-align:center;padding:30px 10px 6px;}
.thanks .check{width:64px;height:64px;border-radius:50%;background:var(--rilo-teal);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:#06231f;}
.thanks .check svg{width:34px;height:34px;}
.thanks h3{font-family:var(--font-display);color:#fff;font-size:24px;margin:0 0 8px;}
.thanks p{color:var(--text);margin:0 0 20px;}
.hidden{display:none !important;}

/* hero hugs the left edge on every width */
.hero-wrap{width:100%;padding:0 40px 0 clamp(40px,6vw,110px);}

/* modal can grow tall (zine pages) then scroll */
.modal{max-height:94vh;}
.modal>div{display:flex;flex-direction:column;max-height:94vh;}
.modal-body{overflow-y:auto;}

/* media area inside the popup */
.m-media:empty{display:none;}
.m-media{margin:0 0 18px;border-radius:12px;overflow:hidden;}
.m-video{display:block;max-width:100%;max-height:80vh;width:auto;height:auto;margin:0 auto;border-radius:12px;}
.m-image{display:block;width:100%;max-height:84vh;object-fit:contain;background:#0c0c12;border-radius:10px;}
.m-zoomhint{text-align:center;color:var(--muted);font-size:12.5px;margin-top:8px;letter-spacing:.03em;}
.modal-zine{width:min(820px,100%);}
.modal-wide{width:min(1280px,96vw);}

/* fullscreen image viewer */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(4,4,7,.95);overflow:auto;
  display:flex;align-items:flex-start;justify-content:center;padding:24px;cursor:zoom-out;animation:fade .2s ease;}
.lightbox img{max-width:100%;height:auto;border-radius:8px;cursor:zoom-in;margin:auto;}
.lightbox img.zoomed{max-width:none;width:auto;cursor:zoom-out;}
.lb-close{position:fixed;top:14px;right:16px;z-index:2;width:46px;height:46px;border-radius:50%;
  background:rgba(255,255,255,.14);color:#fff;font-size:26px;line-height:1;
  display:flex;align-items:center;justify-content:center;cursor:pointer;}
.lb-close:hover{background:rgba(255,255,255,.26);}

/* zine, e-book page turn */
.flip{position:relative;display:flex;align-items:center;justify-content:center;
  background:#0c0c12;border-radius:12px;padding:16px 6px 22px;}
.flip-book{position:relative;flex:1;min-width:0;max-width:680px;margin:0 auto;min-height:72vh;
  display:flex;align-items:center;justify-content:center;}
.flip-book-wide{max-width:1120px;}

/* magic dust on page turn */
.dust-layer{position:absolute;left:50%;top:50%;width:0;height:0;pointer-events:none;z-index:6;}
.dust{position:absolute;left:0;top:0;border-radius:50%;
  background:radial-gradient(circle,#fff,#ffe6a3 55%,rgba(255,200,110,0));
  box-shadow:0 0 7px 1px rgba(255,225,150,.85);transform:translate(-50%,-50%) scale(.3);
  opacity:0;animation:dust 950ms ease-out forwards;}
@keyframes dust{
  0%{opacity:0;transform:translate(-50%,-50%) scale(.3)}
  18%{opacity:1}
  100%{opacity:0;transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(1)}
}
.flip-page-simple{max-height:60vh;max-width:100%;width:auto;border-radius:3px;background:#fff;
  box-shadow:0 18px 50px rgba(0,0,0,.6);}
.flip-nav{flex:0 0 auto;width:42px;height:42px;border-radius:50%;margin:0 4px;z-index:3;
  background:rgba(255,255,255,.08);color:#fff;display:flex;align-items:center;justify-content:center;
  transition:.18s ease;}
.flip-nav:hover{background:var(--coral);color:var(--coral-ink);}
.flip-nav:disabled{opacity:.25;cursor:default;background:rgba(255,255,255,.05);color:#fff;}
.flip-nav svg{width:22px;height:22px;}
.flip-meta{position:absolute;bottom:6px;left:0;right:0;text-align:center;pointer-events:none;}
.flip-count{display:inline-block;font-size:12.5px;color:var(--muted);background:rgba(0,0,0,.45);
  padding:3px 12px;border-radius:20px;}
.flip-hint{display:block;margin-top:5px;font-size:10.5px;color:var(--muted);opacity:.6;letter-spacing:.04em;}

/* online gallery */
.gal{display:flex;flex-direction:column;gap:12px;}
.gal-stage{position:relative;display:flex;align-items:center;justify-content:center;
  background:transparent;border-radius:12px;min-height:240px;padding:6px;}
.gal-main{max-height:80vh;max-width:100%;width:auto;height:auto;object-fit:contain;
  border-radius:8px;box-shadow:0 14px 40px rgba(0,0,0,.5);}
@keyframes galFade{from{opacity:.25}to{opacity:1}}
.gal-nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;
  background:rgba(0,0,0,.5);color:#fff;display:flex;align-items:center;justify-content:center;z-index:2;transition:.18s;}
.gal-nav:hover{background:var(--coral);color:var(--coral-ink);}
.gal-nav.prev{left:10px;}
.gal-nav.next{right:10px;}
.gal-nav svg{width:22px;height:22px;}
.gal-count{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);font-size:12.5px;color:#fff;
  background:rgba(0,0,0,.5);padding:3px 12px;border-radius:20px;}
.gal-thumbs{display:flex;gap:8px;overflow-x:auto;padding:4px 2px 8px;scrollbar-width:thin;}
.gal-thumb{height:56px;width:auto;border-radius:6px;cursor:pointer;opacity:.5;flex:0 0 auto;
  border:2px solid transparent;transition:.18s;}
.gal-thumb:hover{opacity:.85;}
.gal-thumb.active{opacity:1;border-color:var(--coral);}

/* ============================ GATE + INTRO ============================ */
.overlay{position:fixed;inset:0;z-index:90;background:#060608;
  display:flex;align-items:center;justify-content:center;}
.overlay.gone{display:none;}

/* password gate, terminal style */
#gate{justify-content:flex-start;}
.gate-laa{position:absolute;top:26px;left:clamp(28px,8vw,130px);height:22px;
  filter:brightness(0) invert(1);opacity:.92;}
.termgate{position:relative;width:min(680px,92vw);text-align:left;padding-left:clamp(28px,8vw,130px);}
.term-line{display:inline-flex;align-items:center;justify-content:flex-start;gap:14px;
  font-family:"Spectral",Georgia,serif;}
.term-text{font-size:clamp(19px,3.2vw,30px);color:#5d5d66;letter-spacing:.02em;white-space:nowrap;}
.term-text.typed{color:#fff;letter-spacing:.3em;}
.term-caret{display:inline-block;width:2px;height:1.05em;background:#fff;transform:translateY(2px);
  animation:blink 1.05s steps(1) infinite;}
@keyframes blink{0%,49%{opacity:1}50%,100%{opacity:0}}
.term-arrow{font-size:30px;line-height:1;color:#73737c;background:none;border:none;padding:0 4px;
  transition:color .18s ease,transform .18s ease;}
.term-arrow:hover{color:var(--coral);transform:translateX(3px);}
.term-err{color:var(--coral-strong);font-size:14px;min-height:18px;margin:20px 0 0;letter-spacing:.02em;}
/* real field captures typing but is invisible, only on the terminal-style main gate */
.termgate #gate-input{position:absolute;opacity:0;left:0;top:0;width:1px;height:1px;border:0;padding:0;}

/* dashboard / admin login card (uses the .gate markup) */
.gate{max-width:420px;width:100%;padding:30px;text-align:center;}
.gate .g-sym{width:84px;height:auto;margin:0 auto 22px;display:block;}
.gate h2{font-family:var(--font-display);color:#fff;font-size:26px;margin:0 0 6px;}
.gate p.sub{color:var(--muted);font-size:15px;margin:0 0 24px;}
.gate form{display:flex;flex-direction:column;gap:12px;}
.gate input{background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:9px;color:#fff;
  font-family:var(--font-body);font-size:16px;padding:14px 16px;text-align:center;letter-spacing:.04em;}
.gate input:focus{outline:none;border-color:var(--coral);}
.gate .err{color:var(--coral-strong);font-size:14px;min-height:18px;margin:2px 0 0;}

/* intro animation (driven by JS) */
.intro{background:#060608;}
.intro-sym{width:clamp(180px,32vw,340px);opacity:0;will-change:transform,opacity;
  filter:drop-shadow(0 14px 55px rgba(81,154,207,.45));}
.app-hidden{opacity:0;}
.app-reveal{animation:appIn 1s ease .1s both;}
@keyframes appIn{from{opacity:0;transform:scale(1.02)}to{opacity:1;transform:none}}

/* welcome / disclaimer popup */
.welcome-backdrop{position:fixed;inset:0;z-index:80;background:rgba(4,4,7,.82);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:24px;}
.welcome-backdrop.open{display:flex;animation:fade .25s ease;}
.welcome-card{max-width:540px;width:100%;background:var(--panel);border:1px solid var(--line);
  border-radius:18px;padding:38px 36px 34px;text-align:center;box-shadow:0 30px 80px rgba(0,0,0,.6);
  animation:pop .3s cubic-bezier(.2,.9,.3,1.2);}
.welcome-card .w-sym{width:74px;margin:0 auto 20px;}
.welcome-card .w-copy{color:var(--text);font-size:17px;line-height:1.62;margin:0 0 26px;}

/* ============================ DASHBOARD ============================ */
.dash{min-height:100vh;background:linear-gradient(180deg,#0c0e15,#070709);}
.dash-head{display:flex;align-items:center;justify-content:space-between;
  padding:22px 0;border-bottom:1px solid var(--line);margin-bottom:30px;}
.dash-head .left{display:flex;align-items:center;gap:16px;}
.dash-head .g-sym{width:40px;}
.dash-head h1{font-family:var(--font-display);color:#fff;font-size:24px;margin:0;}
.dash-mode{font-size:12px;color:var(--muted);border:1px solid var(--line);border-radius:20px;padding:5px 12px;}
.dash-mode b{color:var(--coral);}
.dash-refresh{background:var(--panel-2);border:1px solid var(--line);border-radius:8px;
  padding:9px 16px;color:#fff;font-size:14px;}
.dash-refresh:hover{border-color:var(--coral);}

.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:30px;}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px 22px;}
.kpi .v{font-family:var(--font-display);font-size:38px;color:#fff;line-height:1;}
.kpi .l{color:var(--muted);font-size:13px;margin-top:8px;letter-spacing:.04em;}

.story-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-bottom:36px;}
.story-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px 22px;}
.story-card h3{font-family:var(--font-display);color:#fff;font-size:19px;margin:0 0 14px;
  display:flex;align-items:center;gap:10px;}
.story-card h3 .n{color:var(--muted);font-size:15px;}
.bar{height:12px;border-radius:6px;background:var(--panel-2);overflow:hidden;display:flex;margin:6px 0 10px;}
.bar .up{background:var(--rilo-teal);}
.bar .down{background:var(--coral-strong);}
.tallies{display:flex;justify-content:space-between;font-size:14px;color:var(--text);}
.tallies .u{color:var(--rilo-teal);}
.tallies .d{color:var(--coral-strong);}
.story-card .none{color:var(--muted);font-size:14px;font-style:italic;}

.comments h2,.notes h2{font-family:var(--font-display);color:#fff;font-size:22px;margin:0 0 16px;}
.cmt{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin-bottom:12px;}
.cmt .meta{display:flex;gap:10px;align-items:center;margin-bottom:6px;font-size:13px;color:var(--muted);}
.cmt .meta .pill{padding:2px 10px;border-radius:20px;font-size:12px;}
.cmt .meta .pill.up{background:rgba(98,189,177,.18);color:var(--rilo-teal);}
.cmt .meta .pill.down{background:rgba(247,144,123,.18);color:var(--coral-strong);}
.cmt .meta .pill.note{background:rgba(239,159,149,.16);color:var(--coral);}
.cmt .txt{color:#e7e7ec;font-size:15px;line-height:1.5;}
.dash-empty{text-align:center;color:var(--muted);padding:60px 0;font-size:16px;}
.dash-refresh.danger{color:var(--coral-strong);border-color:rgba(247,144,123,.5);}
.dash-refresh.danger:hover{border-color:var(--coral-strong);background:rgba(247,144,123,.12);}

/* ============================ RESPONSIVE ============================ */
@media (max-width:980px){
  .wrap{padding:0 22px;}
  .topbar{padding:14px 20px;gap:14px;}
  .nav{display:none;}
  .nav-right{gap:14px;}
  /* tall full-bleed hero on small screens (the 16:9 image is cropped to fit) */
  .hero{aspect-ratio:auto;min-height:86vh;max-height:none;padding-top:84px;}
  .hero-wrap{padding:0 22px;}
  .hero-inner{max-width:none;}
  .hero h1{font-size:clamp(30px,8vw,42px);}
  .hero p.lede{font-size:16px;}
  .hero-wordmark{width:240px;}
  .moon,.hero-rilo-mark{display:none;}
  .cards{grid-auto-columns:minmax(240px,1fr);gap:14px;}
  .card .ttl{font-size:19px;}
  .note-block{padding:24px 20px;}
  .note-send{width:100%;justify-content:center;}
  .kpis{grid-template-columns:repeat(2,1fr);}
  .story-grid{grid-template-columns:1fr;}
  .dash-head{flex-direction:column;align-items:flex-start;gap:14px;}
  .dash-head .left{flex-wrap:wrap;}
  .modal-hero h2{font-size:20px;}
}
@media (max-width:560px){
  .topbar{gap:10px;padding:12px 16px;}
  .nav-right{gap:10px;}
  .nav-right .kids,.chev{display:none;}
  .brand-logo{height:22px;}
  .nav-rilo{width:26px;margin-right:-14px;}
  .hero h1{font-size:clamp(26px,7.5vw,34px);}
  .hero-wordmark{width:190px;}
  .eyebrow{font-size:11px;}
  .hero-cta{flex-wrap:wrap;gap:10px;}
  .btn{padding:11px 18px;font-size:15px;}
  .cards{grid-auto-columns:minmax(78vw,1fr);}
  .row-arrow{width:40px;height:40px;}
  .row-arrow.left{left:-6px;}
  .row-arrow.right{right:-6px;}
  .modal-body{padding:18px 16px 20px;}
  .thumbs{gap:10px;}
  .thumb{padding:14px 8px;}
  .note-icon{width:52px;height:52px;}
  .kpis{grid-template-columns:1fr 1fr;gap:12px;}
  .kpi .v{font-size:30px;}
  .kpi{padding:16px 16px;}
  .welcome-card{padding:28px 22px;}
  .welcome-card .w-copy{font-size:16px;}
  .gate-laa{top:18px;left:20px;height:18px;}
  .termgate{padding-left:20px;}
  .term-text{font-size:clamp(17px,5vw,22px);}
}
