/* ThugBible Laravel rebuild — CSS additions layered on top of the verbatim global.css
   port. Keep minimal; prefer reusing global.css classes. */

/* Comment up/down votes reuse .def-vote inside .c-foot. The comment context has its own
   `.c-foot span{display:flex}` (breaks the count's text-align:center → number sits left)
   and `.c-foot .lucide{14px}` (shrinks the chevrons). Neutralise both so the count
   centres and the chevrons keep their normal size. */
.c-foot .def-vote .dv-count { display: block; cursor: default; }
.c-foot .def-vote .lucide { width: 16px; height: 16px; }

/* ── /account hub (ported from account.astro <style is:global>) ── */
.acct-wrap{max-width:920px}
.acct-head{display:flex;align-items:center;justify-content:space-between;gap:24px;background:linear-gradient(135deg,#16161C,#0E0E13);border:1px solid var(--border);border-radius:18px;padding:26px 28px;margin-bottom:22px;flex-wrap:wrap}
.acct-head-main{display:flex;align-items:center;gap:18px;min-width:0;flex:1}
.acct-av{width:68px;height:68px;border-radius:50%;color:#15110a;display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-weight:700;font-size:30px;flex:none}
.acct-id{min-width:0}
.acct-id h1{font-family:var(--disp);font-weight:700;font-size:26px;text-transform:uppercase;letter-spacing:-.01em;margin:0;word-break:break-word}
.acct-email{color:var(--muted);font-size:14px;margin-top:3px;word-break:break-word}
.acct-since{color:var(--muted-2);font-size:12.5px;margin-top:4px}
.acct-stats{display:flex;gap:30px;flex:none}
.acct-stat{text-align:center}
.acct-stat span{display:block;font-family:var(--disp);font-weight:700;font-size:26px;color:var(--gold)}
.acct-stat label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2)}
@media(max-width:600px){.acct-stats{width:100%;justify-content:flex-start;gap:38px;border-top:1px solid var(--border);padding-top:18px}}
.acct-btn{flex:none;background:linear-gradient(180deg,var(--gold-hi,#FFC73F),var(--gold));color:#15110a;font-family:var(--body);font-weight:700;font-size:13px;border:none;border-radius:10px;padding:0 20px;cursor:pointer;transition:.13s}
.acct-btn:hover{filter:brightness(1.07)}
.acct-tabs{display:flex;gap:6px;border-bottom:1px solid var(--border);margin-bottom:22px;flex-wrap:wrap}
.acct-tab{display:inline-flex;align-items:center;gap:8px;background:none;border:none;color:var(--muted);font-family:var(--body);font-weight:700;font-size:14px;padding:13px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:.13s}
.acct-tab:hover{color:var(--text)}
.acct-tab.on{color:var(--gold);border-bottom-color:var(--gold)}
.acct-tab .lucide{width:16px;height:16px}
@media(max-width:440px){.acct-tabs{gap:2px}.acct-tab{padding:12px 11px;font-size:13px}.acct-tab .lucide{width:15px;height:15px}}
.acct-settings{max-width:480px}
.acct-field{margin-bottom:22px}
.acct-field>label{display:block;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2);margin-bottom:8px}
.acct-row{display:flex;gap:9px}
.acct-input{flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;color:var(--text);font-family:var(--body);font-size:14px;padding:12px 14px;outline:none}
.acct-input:focus{border-color:var(--gold)}
.acct-input:disabled{color:var(--muted);opacity:.7}
.acct-hint{font-size:12px;color:var(--muted-2);margin:7px 0 0}
.acct-msg{font-size:13px;font-weight:700;min-height:18px;margin:4px 0 0}
.acct-divider{height:1px;background:var(--border);margin:28px 0}
.acct-logout{display:inline-flex;align-items:center;gap:8px;background:none;border:1px solid var(--border);border-radius:11px;color:var(--muted);font-family:var(--body);font-weight:700;font-size:13px;padding:12px 20px;cursor:pointer;transition:.13s}
.acct-logout:hover{border-color:var(--heat);color:var(--heat)}
.acct-logout .lucide{width:16px;height:16px}
.dict-status{font-size:9.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;border-radius:5px;padding:1px 6px}
.dict-status.pending{color:#F4C04E;border:1px solid rgba(242,174,38,.4)}
.dict-status.approved{color:#5BD66B;border:1px solid rgba(91,214,107,.4)}

/* Generated-avatar initials in the brand display font (Clash) for more bold impact —
   header chip + comment avatars were body-font; unify all on Clash, heavy. */
.avatar, .c-av, .acct-av { font-family: var(--disp); font-weight: 800; letter-spacing: -.01em; }

/* icon glyphs click-transparent so the whole control is the click target */
svg.lucide,i[data-lucide]{pointer-events:none}

/* sidebar NSFW 18+ pill: smaller + gap from the word (Gray: pill touching word + too large) */
.sb-w .sb-18{margin-left:8px;padding:2px 7px;font-size:9px;letter-spacing:.04em;vertical-align:1px}


/* Welcome page (magic-link first-time username picker) */
.welcome-page{max-width:520px;margin:54px auto;padding:0 16px}
.welcome-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:32px 30px 28px}
.welcome-h1{font-family:var(--disp);font-weight:700;font-size:30px;text-transform:uppercase;letter-spacing:-.01em;margin:16px 0 6px}
.welcome-sub{color:var(--muted);font-size:14px;line-height:1.55;margin:0 0 18px}
.welcome-hint{display:block;color:var(--muted-2);font-size:11.5px;margin-top:7px}
.welcome-msg{display:block;font-size:11.5px;font-weight:600;margin-top:7px}
.welcome-msg.ok{color:#5BD66B}
.welcome-msg.bad{color:var(--heat)}
.welcome-submit{width:100%;margin-top:8px;padding:13px;font-size:14px;border-radius:10px}
.welcome-skip{display:block;margin:10px auto 0;background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;text-decoration:underline}
.welcome-skip:hover{color:var(--text)}
.welcome-fine{color:var(--muted-2);font-size:11.5px;line-height:1.55;text-align:center;margin:14px 0 0}

/* Site-wide banner when logged in with a placeholder username */
.pickname-banner{background:linear-gradient(180deg,rgba(242,174,38,.16),rgba(242,174,38,.08));border-bottom:1px solid rgba(242,174,38,.35);color:var(--gold);font-size:13px;font-weight:600;padding:9px 16px;text-align:center}
.pickname-banner a{color:var(--gold);text-decoration:underline}
.pickname-banner a:hover{text-decoration:none}

/* Auth modal: quiet text-link to swap between magic-link and password modes (Substack-style) */
.auth-altmode{margin:10px auto 0;display:block;background:none;border:none;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;padding:6px 8px;font-family:inherit}
.auth-altmode:hover{color:var(--gold);text-decoration:underline}

/* Cookie consent banner (self-hosted CMP — TCF 2.2 + Consent Mode v2 compatible) */
.cc-banner{position:fixed;left:50%;bottom:16px;transform:translateX(-50%) translateY(20px);width:calc(100% - 32px);max-width:540px;z-index:90;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none}
.cc-banner.cc-show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.cc-card{background:linear-gradient(180deg,#16161c,#101014);border:1px solid var(--border);border-radius:16px;padding:20px 20px 16px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.cc-h{font-family:var(--disp);font-weight:700;font-size:22px;letter-spacing:-.01em;margin:0 0 6px;text-transform:uppercase}
.cc-body{font-size:13.5px;line-height:1.55;color:var(--muted);margin:0 0 14px}
.cc-body a{color:var(--gold);text-decoration:underline;text-underline-offset:2px}
.cc-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}
.cc-row-end{margin-top:18px;margin-bottom:0}
.cc-btn{font-family:var(--body);font-weight:700;font-size:13px;letter-spacing:.03em;text-transform:uppercase;border-radius:10px;padding:12px 14px;cursor:pointer;border:1px solid transparent;transition:.13s;line-height:1.1}
.cc-btn-gold{background:linear-gradient(180deg,var(--gold-hi),var(--gold));color:#1a1407;border-color:var(--gold)}
.cc-btn-gold:hover{filter:brightness(1.06)}
.cc-btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}
.cc-btn-ghost:hover{border-color:var(--muted)}
.cc-link{display:block;margin:0 auto;background:none;border:none;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;padding:6px;font-family:inherit;text-decoration:underline;text-underline-offset:2px}
.cc-link:hover{color:var(--gold)}

/* Customize modal (second layer) */
.cc-overlay{position:fixed;inset:0;z-index:95;background:rgba(6,6,8,.72);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .18s}
.cc-overlay.cc-show{opacity:1}
.cc-modal{width:100%;max-width:520px;background:linear-gradient(180deg,#16161c,#101014);border:1px solid var(--border);border-radius:20px;padding:28px 28px 24px;position:relative;box-shadow:0 30px 90px rgba(0,0,0,.6)}
.cc-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--muted);cursor:pointer;padding:6px}
.cc-close:hover{color:var(--text)}
.cc-close .lucide{width:20px;height:20px;pointer-events:none}
.cc-brand{display:flex;align-items:center;gap:8px;font-family:var(--body);font-weight:800;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.cc-brand .lucide{width:16px;height:16px;color:var(--gold)}
.cc-modal-h{font-family:var(--disp);font-weight:700;font-size:22px;letter-spacing:-.01em;margin:14px 0 18px;text-transform:uppercase}
.cc-cat{padding:14px 0;border-top:1px solid var(--border)}
.cc-cat:first-of-type{border-top:none}
.cc-cat-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:5px}
.cc-cat-head h4{margin:0;font-size:14px;font-weight:700;color:var(--text)}
.cc-cat p{font-size:12.5px;color:var(--muted);margin:0;line-height:1.5}
.cc-always{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#5BD66B;border:1px solid rgba(91,214,107,.4);background:rgba(91,214,107,.08);padding:4px 9px;border-radius:999px}
.cc-not-used{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2);border:1px solid var(--border);padding:4px 9px;border-radius:999px}
.cc-cat-off{opacity:.6}

/* Toggle switch */
.cc-toggle{position:relative;display:inline-block;width:42px;height:24px;flex:none;cursor:pointer}
.cc-toggle input{position:absolute;opacity:0;width:0;height:0}
.cc-toggle-track{position:absolute;inset:0;background:#2a2a30;border-radius:999px;transition:.2s}
.cc-toggle-track::before{content:'';position:absolute;left:3px;top:3px;width:18px;height:18px;background:var(--text);border-radius:50%;transition:.2s}
.cc-toggle input:checked + .cc-toggle-track{background:linear-gradient(180deg,var(--gold-hi),var(--gold))}
.cc-toggle input:checked + .cc-toggle-track::before{transform:translateX(18px);background:#1a1407}

@media (max-width:560px){
  .cc-banner{bottom:8px;width:calc(100% - 16px)}
  .cc-card{padding:18px 16px 14px;border-radius:14px}
  .cc-h{font-size:20px}
}
