/* ============================================================================
   THE COMPANION RADAR — SITE LAYER (Midnight Rose)
   Builds on brand2/juice.css (tokens + components). Adds product layout.
   ========================================================================== */

/* age + trust bar */
.agebar{display:flex;align-items:center;justify-content:center;gap:16px;padding:7px 16px;background:#080406;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--grey-2);flex-wrap:wrap}
.agebar b{color:var(--pink-soft);font-weight:700}.agebar .sep{color:var(--grey-3)}
@media(max-width:620px){.agebar .hide-sm{display:none}}

/* nav extras (reuses .nav from juice) */
.nav__spacer{flex:1}
.nav__search{position:relative}
.nav__search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--grey-2)}
.nav__search input{width:190px;background:var(--surf);border:1px solid var(--line-2);border-radius:var(--r-pill);padding:9px 14px 9px 34px;color:#fff;font-family:var(--ui);font-size:13px;transition:all .2s}
.nav__search input:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 3px var(--pink-wash);width:220px}
.nav__burger{display:none;width:42px;height:42px;align-items:center;justify-content:center;background:var(--surf);border:1px solid var(--line-2);border-radius:var(--r-pill);color:#fff}
@media(max-width:1024px){.nav__search,.nav__signin{display:none}}
@media(max-width:980px){.nav__burger{display:flex}}
@media(max-width:560px){.nav__in{gap:10px;padding:0 16px}.nav__in .btn--pink{flex:none;white-space:nowrap;padding:8px 12px;font-size:12px}.nav__brand{font-size:15px;white-space:nowrap}.nav__brand .s{font-size:18px}.nav__brand svg{width:20px;height:20px;flex:none}.nav__burger{flex:none}}
.doc>main,.doc__side{min-width:0}
.nav__mobile{display:none;flex-direction:column;gap:2px;padding:14px 24px;border-bottom:1px solid var(--line);background:var(--bg-2)}
.nav__mobile.open{display:flex}
.nav__mobile a{padding:11px 12px;border-radius:var(--r-s);color:var(--grey);font-size:15px;font-weight:600}
.nav__mobile a:hover{background:var(--surf);color:var(--pink-soft)}

/* sections */
.sec{max-width:1300px;margin:0 auto;padding:clamp(48px,6vw,84px) 24px}
.sec--tight{padding:clamp(28px,4vw,48px) 24px}
.sechead{margin-bottom:32px}
.sechead h2{font-family:var(--disp);font-weight:800;font-size:clamp(1.7rem,1.2rem+1.8vw,2.6rem);line-height:1.05;letter-spacing:-.03em}
.sechead h2 .s{font-family:var(--script);font-weight:400;color:var(--pink);font-size:1.12em}
.sechead p{color:var(--grey);font-size:1.05rem;max-width:54ch;margin-top:10px}
.between{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap}

/* HERO */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);
  background:radial-gradient(70% 60% at 50% -5%,rgba(255,30,122,.16),transparent 60%),radial-gradient(55% 50% at 92% 6%,rgba(154,77,255,.18),transparent 60%),var(--bg)}
.hero__in{max-width:1300px;margin:0 auto;padding:clamp(40px,6vw,88px) 24px;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;position:relative;z-index:2}
@media(max-width:940px){.hero__in{grid-template-columns:1fr;gap:36px}}
.hero h1{font-family:var(--disp);font-weight:800;font-size:clamp(2.4rem,1.4rem+3.4vw,4.2rem);line-height:1.0;letter-spacing:-.035em}
.hero h1 .s{font-family:var(--script);font-weight:400;background:linear-gradient(120deg,var(--violet-soft),var(--pink));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-size:1.18em;letter-spacing:0}
.hero__sub{font-size:clamp(1.05rem,1rem+.5vw,1.3rem);color:var(--grey);max-width:46ch;margin-top:20px;line-height:1.55}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.hero__trust{display:flex;gap:22px;flex-wrap:wrap;margin-top:26px;font-size:13px;color:var(--grey-2)}
.hero__trust b{color:#fff;font-family:var(--mono)}
.hero__rail{display:flex;flex-direction:column;gap:16px}
.comm{border:1px solid var(--line-2);border-radius:var(--r-l);background:var(--card);padding:18px}
.comm__t{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--pink-soft);margin-bottom:12px}
.comm__row{display:flex;align-items:center;gap:13px}
.comm__sc{font-family:var(--disp);font-weight:800;font-size:2rem;line-height:1;background:linear-gradient(120deg,var(--violet-soft),var(--pink));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.comm__n{font-family:var(--disp);font-weight:800;font-size:1.1rem}

/* COMPANION PORTRAITS + PROFILE CARDS (the enticing imagery) */
.hero{--portrait:#1a0e16}
.spot__portrait{width:100%;height:auto;aspect-ratio:16/9;display:block;border-bottom:1px solid var(--line)}
image-slot{--is-bg:radial-gradient(120% 120% at 60% 0%,rgba(154,77,255,.5),transparent 55%),radial-gradient(100% 100% at 20% 100%,rgba(255,30,122,.55),transparent 55%),#150d14;background:var(--is-bg);color:rgba(255,255,255,.4)}
.cgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ccard{position:relative;border-radius:var(--r-m);overflow:hidden;border:1px solid var(--line-2);aspect-ratio:3/4;background:var(--portrait);cursor:pointer;transition:transform .18s var(--ease),box-shadow .18s,border-color .18s}
.ccard:hover{transform:translateY(-3px);border-color:var(--pink);box-shadow:var(--glow)}
.ccard image-slot{position:absolute;inset:0;width:100%;height:100%}
.ccard video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ccard__new{position:absolute;top:8px;left:8px;z-index:2;font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--pink);padding:3px 7px;border-radius:6px}
.ccard__grad{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(8,4,6,.92) 8%,rgba(8,4,6,.4) 38%,transparent 62%);pointer-events:none}
.ccard__info{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:12px;pointer-events:none}
.ccard__nm{display:flex;align-items:center;gap:6px;font-family:var(--disp);font-weight:800;font-size:15px;color:#fff}
.ccard__on{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.ccard__meta{font-size:11.5px;color:rgba(255,255,255,.75);margin-top:2px}
.ccard__stats{display:flex;gap:12px;margin-top:7px;font-family:var(--mono);font-size:10.5px;color:rgba(255,255,255,.85)}
.ccard__stats span{display:flex;align-items:center;gap:4px}
.ccard__stats svg{width:11px;height:11px;color:var(--pink-soft)}
.gallery-h{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:2px 0 2px}
.gallery-h b{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--pink-soft);display:flex;align-items:center;gap:7px}

/* TRUST 2-col (them vs us) */
.vs{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:680px){.vs{grid-template-columns:1fr}}
.vsrow{display:flex;gap:10px;font-size:14.5px;line-height:1.4;color:var(--grey)}
.vsrow .x{color:var(--red);font-weight:800;flex:none}
.vsrow svg{flex:none;color:var(--pink)}

/* marquee */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#080406;padding:13px 0}
.marquee__t{display:flex;gap:40px;white-space:nowrap;animation:mq 26s linear infinite;width:max-content;font-family:var(--mono);font-size:13px;color:var(--grey-2)}
.marquee__t b{color:var(--pink-soft);font-weight:700}
@keyframes mq{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee__t{animation:none}}

/* LEADERBOARD */
.lbpanel{border:1px solid var(--line-2);border-radius:var(--r-l);background:var(--card);overflow:hidden}
.blk .lbpanel{overflow-x:auto}
.filterbar{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.lbscroll{overflow-x:auto}
.lb{width:100%;border-collapse:collapse;font-size:14px;min-width:640px}
.lb thead th{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--grey-2);font-weight:700;text-align:left;padding:12px 16px;border-bottom:1px solid var(--line-2)}
.lb thead th.num,.lb td.num{text-align:right;font-variant-numeric:tabular-nums}
.lb tbody tr{border-bottom:1px solid var(--line);transition:background .15s;cursor:pointer}
.lb tbody tr:hover{background:var(--surf)}
.lb td{padding:14px 16px;vertical-align:middle}
.lb__rank{font-family:var(--disp);font-weight:800;font-size:1.1rem;color:var(--grey-2);width:30px}
.lb__rank.top{color:var(--pink)}
.lb__name{display:flex;align-items:center;gap:11px}.lb__name b{font-family:var(--disp);font-weight:700;font-size:15px;color:#fff}
.lb__logo{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-weight:800;font-size:13px;color:#fff;flex:none;border:1px solid var(--line-2)}
.lb__sc{font-family:var(--disp);font-weight:800;font-size:1.15rem;color:var(--pink)}
.lb__bar{height:6px;width:90px;border-radius:99px;background:var(--surf);overflow:hidden}
.lb__bar i{display:block;height:100%;background:linear-gradient(90deg,var(--violet),var(--pink));border-radius:99px}
.adrow{background:rgba(255,30,122,.06)}
.adtag{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--pink-soft);border:1px solid rgba(255,30,122,.35);border-radius:5px;padding:1px 6px}

/* matcher promo */
.matcher{border:1px solid var(--line-2);border-radius:var(--r-xl);overflow:hidden;display:grid;grid-template-columns:1.2fr 1fr;
  background:radial-gradient(70% 120% at 12% 50%,rgba(154,77,255,.18),transparent 60%),var(--card)}
@media(max-width:760px){.matcher{grid-template-columns:1fr}}
.matcher__l{padding:clamp(28px,4vw,48px)}
.matcher__r{border-left:1px solid var(--line);padding:30px;display:flex;flex-direction:column;justify-content:center;gap:11px;background:var(--bg-2)}
@media(max-width:760px){.matcher__r{border-left:none;border-top:1px solid var(--line)}}
.mopt{display:flex;align-items:center;gap:11px;padding:13px 15px;border:1px solid var(--line-2);border-radius:var(--r-m);background:var(--surf);cursor:pointer;transition:all .15s;font-size:14px}
.mopt:hover{border-color:var(--pink);background:var(--pink-wash)}
.mopt .k{font-family:var(--mono);font-size:13px;color:var(--grey-2);width:24px;height:24px;border:1px solid var(--line-2);border-radius:7px;display:flex;align-items:center;justify-content:center;flex:none}

/* stat band */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
@media(max-width:680px){.statband{grid-template-columns:repeat(2,1fr)}}
.statband .n{font-family:var(--disp);font-weight:800;font-size:clamp(1.8rem,1.2rem+2vw,2.8rem);background:linear-gradient(120deg,var(--violet-soft),var(--pink));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.statband .l{font-size:13px;color:var(--grey-2);margin-top:4px}

/* two col */
.twocol{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:start}
@media(max-width:880px){.twocol{grid-template-columns:1fr}}
.shamecard{border:1px solid rgba(255,77,94,.25);border-radius:var(--r-l);background:var(--card);overflow:hidden;margin-bottom:16px}
.shamecard__bar{height:4px;background:linear-gradient(90deg,#FFB23E,#FF6A3D,#FF4D5E)}
.shamecard__in{padding:20px}
.shamecard__h{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.shamecard__p{font-family:var(--disp);font-weight:800;font-size:1.15rem;margin-bottom:8px;line-height:1.2}
.shamecard__d{font-size:14px;color:var(--grey);line-height:1.55}
.shamecard__f{display:flex;gap:16px;align-items:center;font-family:var(--mono);font-size:12px;color:var(--grey-2);border-top:1px solid var(--line);padding-top:12px;margin-top:14px;flex-wrap:wrap}
.feedpanel{border:1px solid var(--line-2);border-radius:var(--r-l);background:var(--card);padding:14px 18px}

/* cta band */
.ctaband{border:1px solid rgba(255,30,122,.3);border-radius:var(--r-xl);padding:clamp(36px,6vw,72px) 24px;text-align:center;box-shadow:var(--glow);position:relative;overflow:hidden;
  background:radial-gradient(90% 130% at 50% 0%,rgba(255,30,122,.2),transparent 60%),radial-gradient(70% 100% at 80% 100%,rgba(154,77,255,.18),transparent 60%),var(--card)}
.ctaband h2{font-family:var(--disp);font-weight:800;font-size:clamp(1.8rem,1.2rem+2vw,3rem);letter-spacing:-.02em;margin-bottom:14px}
.ctaband h2 .s{font-family:var(--script);font-weight:400;color:var(--pink);font-size:1.15em}

/* site footer */
.sfoot{background:#080406;border-top:1px solid var(--line);padding:60px 0 32px}
.sfoot__g{max-width:1300px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}
@media(max-width:760px){.sfoot__g{grid-template-columns:1fr 1fr}}
.sfoot__b b{font-family:var(--disp);font-weight:800;font-size:18px;display:block;margin-bottom:8px}
.sfoot__c h4{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--grey-2);margin-bottom:14px}
.sfoot__c a{display:block;color:var(--grey);font-size:14px;padding:5px 0}.sfoot__c a:hover{color:var(--pink-soft)}
.sfoot__bot{max-width:1300px;margin:32px auto 0;padding:24px 24px 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;color:var(--grey-2)}

/* mobile: companion gallery 2-up instead of 4 (overrides inline grid) */
@media(max-width:640px){.cgrid{grid-template-columns:1fr 1fr!important}}
