/* =====================================================================
   Commons by Frothley — styles
   Frothley identity: deep navy, neon cyan + magenta bubble glow.
   The signature stays: an audience lens dial that re-tints the UI so
   you always know who's listening — now in neon.
   ===================================================================== */
:root{
  --bg:#0F172A; --bg-2:#0B1120; --surface:#1E2937; --surface-2:#243244;
  --border:rgba(255,255,255,.07); --border-2:rgba(255,255,255,.12);
  --text:#FFFFFF; --text-2:#CBD5E1; --muted:#94A3B8; --muted-2:#64748B;
  --family:#E040FB; --neighbors:#2DE2A6; --public:#00F0FF; --news:#FFC24B;
  --accent:#00F0FF; --accent-rgb:0,240,255;
  --accent-soft:rgba(var(--accent-rgb),.14);
  --glow:0 0 22px rgba(var(--accent-rgb),.45);
  --on-accent:#0B1120;
  --radius:16px;
  --shadow:0 1px 2px rgba(0,0,0,.4), 0 10px 34px rgba(0,0,0,.42);
  --maxw:1180px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  min-height:100vh;
  background:
    radial-gradient(900px 620px at 10% -8%, rgba(0,240,255,.12), transparent 58%),
    radial-gradient(820px 600px at 102% -2%, rgba(224,64,251,.12), transparent 55%),
    var(--bg);
  background-attachment:fixed;
  color:var(--text);
  font-family:'Inter',system-ui,sans-serif;
  font-size:15px; line-height:1.5; -webkit-font-smoothing:antialiased;
}
body[data-lens="family"]{--accent:#E040FB;--accent-rgb:224,64,251}
body[data-lens="neighbors"]{--accent:#2DE2A6;--accent-rgb:45,226,166}
body[data-lens="public"]{--accent:#00F0FF;--accent-rgb:0,240,255}
body[data-lens="news"]{--accent:#FFC24B;--accent-rgb:255,194,75}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea{font-family:inherit;color:var(--text)}
::selection{background:rgba(var(--accent-rgb),.3)}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
.hidden{display:none!important}

/* ---------- bubble brand mark ---------- */
.brand-mark{position:relative;width:34px;height:34px;border-radius:50%;flex:0 0 auto;
  background:linear-gradient(140deg,#00F0FF,#7C5CFF 55%,#E040FB);
  box-shadow:0 0 16px rgba(0,240,255,.55), 0 0 26px rgba(224,64,251,.4);
  display:grid;place-items:center}
.brand-mark::after{content:"";position:absolute;top:16%;left:20%;width:30%;height:30%;
  border-radius:50%;background:rgba(255,255,255,.78);filter:blur(.6px)}
.brand-mark span{display:none}
.brand-name{font-family:'Space Grotesk',sans-serif;font-size:23px;font-weight:700;letter-spacing:-.02em;
  background:linear-gradient(90deg,#67E8F9,#FFFFFF 60%);-webkit-background-clip:text;
  background-clip:text;color:transparent}

/* ---------- AUTH SCREEN ---------- */
.auth{min-height:100vh;display:grid;place-items:center;padding:24px}
.auth-card{width:100%;max-width:410px;background:rgba(30,41,55,.72);border:1px solid var(--border-2);
  border-radius:22px;box-shadow:var(--shadow);padding:0 0 30px;overflow:hidden;
  backdrop-filter:blur(8px);animation:rise .4s ease both}
.auth-hero{height:172px;width:100%;overflow:hidden;position:relative;border-bottom:1px solid var(--border)}
.auth-hero img{width:100%;height:100%;object-fit:cover;object-position:center 46%}
.auth-pad{padding:22px 30px 0}
.auth-brand{display:flex;align-items:center;gap:11px;margin-bottom:6px}
.auth-name{font-family:'Space Grotesk',sans-serif;font-size:24px;font-weight:700;letter-spacing:-.02em;
  background:linear-gradient(90deg,#67E8F9,#FFFFFF 60%);-webkit-background-clip:text;background-clip:text;color:transparent}
.auth-tag{color:var(--text-2);font-size:14px;margin:2px 0 22px}
.auth h2{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:20px;margin:0 0 16px}
.field{margin-bottom:13px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--muted);margin-bottom:5px}
.field input{width:100%;border:1px solid var(--border-2);border-radius:11px;padding:11px 13px;
  font-size:15px;background:var(--surface-2);transition:.15s}
.field input::placeholder{color:var(--muted-2)}
.field input:focus{outline:none;border-color:var(--accent);box-shadow:var(--glow);background:#1b2636}
.auth-btn{width:100%;background:var(--accent);color:var(--on-accent);font-weight:700;font-size:15px;
  padding:12px;border-radius:12px;margin-top:6px;transition:.15s;box-shadow:var(--glow)}
.auth-btn:hover{filter:brightness(1.08)}
.auth-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}
.auth-switch{text-align:center;margin-top:16px;font-size:13.5px;color:var(--muted)}
.auth-switch button{color:var(--accent);font-weight:600}
.auth-err{background:rgba(224,64,251,.14);color:#F4A8FF;font-size:13px;font-weight:500;
  padding:10px 13px;border-radius:10px;margin-bottom:14px;border:1px solid rgba(224,64,251,.3)}
.hint{font-size:11.5px;color:var(--muted-2);margin-top:4px}

/* ---------- APP LAYOUT ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:248px minmax(0,1fr) 308px;gap:26px;padding:0 22px}

.rail{position:sticky;top:0;height:100vh;padding:22px 0;display:flex;flex-direction:column;gap:22px}
.brand{display:flex;align-items:center;gap:10px;padding:0 6px}

.dial{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:7px;box-shadow:var(--shadow)}
.dial-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-2);
  padding:6px 8px 8px;font-weight:600}
.lens-btn{display:flex;align-items:center;gap:11px;width:100%;padding:9px 10px;border-radius:11px;
  font-size:14.5px;font-weight:500;color:var(--text-2);transition:.18s ease}
.lens-btn .dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.lens-btn[data-l="family"] .dot{background:var(--family);box-shadow:0 0 8px var(--family)}
.lens-btn[data-l="neighbors"] .dot{background:var(--neighbors);box-shadow:0 0 8px var(--neighbors)}
.lens-btn[data-l="public"] .dot{background:var(--public);box-shadow:0 0 8px var(--public)}
.lens-btn[data-l="news"] .dot{background:var(--news);box-shadow:0 0 8px var(--news)}
.lens-btn .meta{margin-left:auto;font-size:11px;color:var(--muted-2);font-weight:600}
.lens-btn:hover{background:var(--surface-2);color:var(--text)}
.lens-btn.active{background:var(--accent);color:var(--on-accent);box-shadow:var(--glow)}
.lens-btn.active .dot{background:var(--on-accent);box-shadow:none}
.lens-btn.active .meta{color:rgba(11,17,32,.7)}

.nav{display:flex;flex-direction:column;gap:2px}
.nav-btn{display:flex;align-items:center;gap:13px;padding:10px 12px;border-radius:11px;
  font-size:15px;font-weight:500;color:var(--text);transition:.15s}
.nav-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8}
.nav-btn:hover{background:var(--surface-2)}
.nav-btn.on{color:var(--accent);font-weight:600}
.compose-cta{margin-top:4px;background:var(--accent);color:var(--on-accent);font-weight:700;font-size:15px;
  padding:12px;border-radius:13px;transition:.18s;box-shadow:var(--glow)}
.compose-cta:hover{filter:brightness(1.08)}
.me{margin-top:auto;display:flex;align-items:center;gap:11px;padding:8px 6px}
.avatar{border-radius:50%;flex:0 0 auto;display:grid;place-items:center;color:#fff;
  font-weight:600;font-size:13px;background:#334155;overflow:hidden}
.me .avatar{width:38px;height:38px}
.me .name{font-weight:600;font-size:14px}
.me .handle{font-size:12.5px;color:var(--muted)}
.logout{font-size:11px;color:var(--muted-2);font-weight:600;margin-left:auto}
.logout:hover{color:var(--family)}

/* center */
.feed{padding:22px 0;min-height:100vh}
.ctx{position:sticky;top:0;z-index:20;
  background:linear-gradient(var(--bg) 76%,transparent);padding-bottom:14px;margin-bottom:4px}
.ctx-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.ctx-bar::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(420px 120px at 0% 0%, rgba(var(--accent-rgb),.10), transparent 70%)}
.ctx-eyebrow{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);
  font-weight:700;display:flex;align-items:center;gap:7px}
.ctx-eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}
.ctx-title{font-family:'Space Grotesk',sans-serif;font-size:24px;font-weight:600;margin:5px 0 2px;letter-spacing:-.015em}
.ctx-sub{color:var(--muted);font-size:13.5px}
.ctx-tools{display:flex;gap:10px;margin-top:13px;align-items:center}
.search{flex:1;display:flex;align-items:center;gap:9px;background:var(--surface-2);border-radius:11px;padding:9px 13px;border:1px solid var(--border)}
.search svg{width:17px;height:17px;stroke:var(--muted);fill:none;stroke-width:1.8}
.search input{border:none;background:none;flex:1;font-size:14px}
.search input::placeholder{color:var(--muted-2)}
.search input:focus{outline:none}
.view-toggle{display:flex;background:var(--surface-2);border-radius:10px;padding:3px;border:1px solid var(--border)}
.view-toggle button{padding:7px 10px;border-radius:8px;font-size:12px;font-weight:600;color:var(--muted)}
.view-toggle button.on{background:var(--accent);color:var(--on-accent)}

.composer{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow);margin-bottom:16px}
.composer-top{display:flex;gap:12px}
.composer textarea{flex:1;border:none;resize:none;font-size:16px;line-height:1.45;min-height:46px;background:none}
.composer textarea:focus{outline:none}
.composer textarea::placeholder{color:var(--muted-2)}
.composer-bar{display:flex;align-items:center;gap:8px;margin-top:10px;padding-top:12px;border-top:1px solid var(--border)}
.icon-btn{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;color:var(--accent);transition:.15s}
.icon-btn svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:1.8}
.icon-btn:hover{background:var(--accent-soft)}
.aud-pick{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--accent);
  background:var(--accent-soft);padding:7px 11px;border-radius:20px;border:1px solid rgba(var(--accent-rgb),.3)}
.aud-pick .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent)}
.post-btn{margin-left:auto;background:var(--accent);color:var(--on-accent);font-weight:700;font-size:14px;
  padding:9px 20px;border-radius:11px;transition:.15s;box-shadow:var(--glow)}
.post-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}
.post-btn:not(:disabled):hover{filter:brightness(1.08)}
.photo-preview{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.photo-preview .tile{width:84px;height:84px;border-radius:12px;position:relative;
  display:grid;place-items:center;font-size:26px;overflow:hidden}
.photo-preview .tile img{width:100%;height:100%;object-fit:cover}
.photo-preview .tile button{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.6);color:#fff;
  width:20px;height:20px;border-radius:50%;font-size:12px;line-height:1;display:grid;place-items:center}

.stream{display:flex;flex-direction:column;gap:14px}
.empty{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:30px;text-align:center;color:var(--muted);box-shadow:var(--shadow)}
.post{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow);animation:rise .35s ease both}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.repost-tag{font-size:12.5px;color:var(--muted);font-weight:500;margin-bottom:10px;display:flex;align-items:center;gap:7px}
.repost-tag svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.8}
.p-head{display:flex;align-items:center;gap:11px}
.p-head .avatar{width:42px;height:42px;font-size:14px}
.p-meta{flex:1;min-width:0}
.p-name{font-weight:600;font-size:14.5px;display:flex;align-items:center;gap:6px}
.p-name .verif{color:var(--accent);display:inline-flex}
.p-name .verif svg{width:14px;height:14px}
.p-sub{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.chip{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:20px}
.chip[data-l="family"]{background:rgba(224,64,251,.16);color:#EE9BFF}
.chip[data-l="neighbors"]{background:rgba(45,226,166,.16);color:#7FF0CE}
.chip[data-l="public"]{background:rgba(0,240,255,.15);color:#7DF3FF}
.chip[data-l="news"]{background:rgba(255,194,75,.16);color:#FFD98A}
.p-body{margin:11px 0 0;font-size:15px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word;color:var(--text-2)}
.p-photos{display:grid;gap:6px;margin-top:12px;border-radius:13px;overflow:hidden}
.p-photos.n1{grid-template-columns:1fr}
.p-photos.n2{grid-template-columns:1fr 1fr}
.p-photos.n3,.p-photos.n4{grid-template-columns:1fr 1fr}
.ph{height:220px;display:grid;place-items:center;font-size:46px;overflow:hidden}
.p-photos.n2 .ph,.p-photos.n3 .ph,.p-photos.n4 .ph{height:165px}
.ph img{width:100%;height:100%;object-fit:cover;display:block}
.p-actions{display:flex;align-items:center;gap:4px;margin-top:13px}
.act{display:flex;align-items:center;gap:7px;padding:7px 11px;border-radius:10px;font-size:13px;font-weight:500;color:var(--muted);transition:.15s}
.act svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.7}
.act:hover{background:var(--surface-2);color:var(--text)}
.act.liked{color:var(--family)}
.act.liked svg{fill:var(--family);stroke:var(--family)}
.act.reposted{color:var(--neighbors)}
.act.shared{margin-left:auto}
.comments{margin-top:13px;padding-top:13px;border-top:1px solid var(--border);display:none}
.comments.open{display:block}
.comment{display:flex;gap:10px;margin-bottom:11px}
.comment .avatar{width:30px;height:30px;font-size:11px}
.comment .c-body{background:var(--surface-2);border-radius:13px;padding:8px 13px;flex:1;min-width:0}
.comment .c-name{font-weight:600;font-size:13px}
.comment .c-text{font-size:13.5px;white-space:pre-wrap;word-wrap:break-word;color:var(--text-2)}
.comment-box{display:flex;gap:10px;align-items:center;margin-top:6px}
.comment-box input{flex:1;border:1px solid var(--border-2);border-radius:20px;padding:9px 15px;font-size:13.5px;background:var(--surface-2)}
.comment-box input::placeholder{color:var(--muted-2)}
.comment-box input:focus{outline:none;border-color:var(--accent)}
.comment-box button{color:var(--accent);font-weight:600;font-size:13px;padding:6px 8px}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.grid .cell{aspect-ratio:1;border-radius:10px;display:grid;place-items:center;font-size:38px;
  position:relative;overflow:hidden;cursor:pointer;animation:rise .3s ease both}
.grid .cell img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.grid .cell .ov{position:absolute;inset:0;background:rgba(8,12,22,.55);color:#fff;display:flex;
  align-items:center;justify-content:center;gap:16px;font-weight:600;font-size:13px;opacity:0;transition:.18s}
.grid .cell:hover .ov{opacity:1}
.grid .cell .ov span{display:flex;align-items:center;gap:5px}
.grid .cell .ov svg{width:16px;height:16px;stroke:#fff;fill:#fff}

/* right rail */
.side{position:sticky;top:0;height:100vh;padding:22px 0;display:flex;flex-direction:column;gap:16px;overflow:auto}
.side::-webkit-scrollbar{width:0}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.card h3{font-family:'Space Grotesk',sans-serif;font-size:16px;font-weight:600;margin:0 0 12px;letter-spacing:-.01em}
.trend{padding:9px 0;border-bottom:1px solid var(--border)}
.trend:last-child{border:none;padding-bottom:0}.trend:first-of-type{padding-top:0}
.trend .t-cat{font-size:11px;color:var(--muted-2);font-weight:600}
.trend .t-tag{font-weight:600;font-size:14.5px;margin:1px 0}
.trend .t-count{font-size:12px;color:var(--muted)}
.trend:hover .t-tag{color:var(--accent)}
.nbr{display:flex;align-items:center;gap:11px;padding:8px 0}
.nbr .avatar{width:36px;height:36px;font-size:13px}
.nbr .n-name{font-weight:600;font-size:13.5px}
.nbr .n-sub{font-size:12px;color:var(--muted)}
.nbr .act-btn{margin-left:auto;font-size:12px;font-weight:600;color:var(--accent);
  border:1px solid rgba(var(--accent-rgb),.5);padding:5px 13px;border-radius:18px;transition:.15s}
.nbr .act-btn:hover{background:var(--accent);color:var(--on-accent);box-shadow:var(--glow)}
.nbr .act-btn.on{background:var(--accent);color:var(--on-accent)}
.newsitem{display:flex;gap:11px;padding:10px 0;border-bottom:1px solid var(--border)}
.newsitem:last-child{border:none}
.newsitem .thumb{width:54px;height:54px;border-radius:10px;flex:0 0 auto;display:grid;place-items:center;font-size:22px}
.newsitem .n-src{font-size:11px;color:var(--muted-2);font-weight:600}
.newsitem .n-head{font-size:13.5px;font-weight:600;line-height:1.3}
.newsitem:hover .n-head{color:var(--accent)}
.add-fam{display:flex;gap:8px;margin-top:6px}
.add-fam input{flex:1;border:1px solid var(--border-2);border-radius:10px;padding:8px 11px;font-size:13px;background:var(--surface-2)}
.add-fam input::placeholder{color:var(--muted-2)}
.add-fam input:focus{outline:none;border-color:var(--accent)}
.add-fam button{background:var(--accent);color:var(--on-accent);font-weight:700;font-size:13px;padding:8px 14px;border-radius:10px}
.side-foot{font-size:11.5px;color:var(--muted-2);line-height:1.7;padding:4px 8px}

.mobile-top,.mobile-nav{display:none}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:#0B1120;border:1px solid var(--border-2);color:#fff;padding:12px 20px;border-radius:30px;
  font-size:13.5px;font-weight:500;box-shadow:0 8px 30px rgba(0,0,0,.5);opacity:0;pointer-events:none;
  transition:.25s;z-index:100;max-width:90%}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{border-color:rgba(224,64,251,.5);color:#F4A8FF}

@media (max-width:980px){
  .wrap{grid-template-columns:1fr;padding:0;gap:0}
  .rail,.side{display:none}
  .feed{padding:0 0 90px}
  .mobile-top{display:block;position:sticky;top:0;z-index:30;background:rgba(15,23,42,.92);
    backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
  .mt-brand{display:flex;align-items:center;justify-content:space-between;padding:13px 16px}
  .mt-brand .brand-name{font-size:21px}
  .mt-lenses{display:flex;gap:6px;padding:0 12px 11px;overflow-x:auto}
  .mt-lens{flex:0 0 auto;display:flex;align-items:center;gap:7px;padding:8px 14px;border-radius:20px;
    font-size:13px;font-weight:600;color:var(--muted);background:var(--surface-2);white-space:nowrap;border:1px solid var(--border)}
  .mt-lens.active{background:var(--accent);color:var(--on-accent);box-shadow:var(--glow)}
  .mt-lens.active .dot{background:var(--on-accent)}
  .mt-lens .dot{width:8px;height:8px;border-radius:50%}
  .mt-lens[data-l="family"] .dot{background:var(--family)}
  .mt-lens[data-l="neighbors"] .dot{background:var(--neighbors)}
  .mt-lens[data-l="public"] .dot{background:var(--public)}
  .mt-lens[data-l="news"] .dot{background:var(--news)}
  .ctx{padding:14px 14px 12px}
  .ctx-bar{border-radius:14px}
  .composer,.stream,.grid{margin-left:14px;margin-right:14px}
  .ctx .search input{font-size:16px}
  .mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:rgba(15,23,42,.95);
    backdrop-filter:blur(8px);border-top:1px solid var(--border);padding:8px 0 max(8px,env(safe-area-inset-bottom));z-index:40;justify-content:space-around}
  .mobile-nav button{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);font-size:10px;font-weight:600}
  .mobile-nav button svg{width:23px;height:23px;stroke:currentColor;fill:none;stroke-width:1.8}
  .mobile-nav button.on{color:var(--accent)}
  .mobile-nav .fab{margin-top:-26px;background:var(--accent);width:50px;height:50px;border-radius:50%;
    display:grid;place-items:center;box-shadow:var(--glow)}
  .mobile-nav .fab svg{stroke:var(--on-accent);width:24px;height:24px}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- ADMIN / MODERATION ---------- */
.admin-wrap{max-width:880px;margin:0 auto;padding:26px 22px 80px}
.admin-head{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.admin-title{font-family:'Space Grotesk',sans-serif;font-size:26px;font-weight:700;letter-spacing:-.01em}
.admin-sub{color:var(--muted);font-size:14px;margin-bottom:22px}
.admin-back{margin-left:auto;font-size:13px;font-weight:600;color:var(--accent)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:26px}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px;box-shadow:var(--shadow)}
.stat .num{font-family:'Space Grotesk',sans-serif;font-size:30px;font-weight:700;line-height:1}
.stat .lbl{font-size:12px;color:var(--muted);font-weight:600;margin-top:5px;text-transform:uppercase;letter-spacing:.05em}
.stat.alert .num{color:var(--family)}
.admin-sec{margin-bottom:30px}
.admin-sec h2{font-family:'Space Grotesk',sans-serif;font-size:19px;font-weight:600;margin:0 0 13px}
.rep{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:15px 16px;box-shadow:var(--shadow);margin-bottom:11px}
.rep-top{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--muted);margin-bottom:9px;flex-wrap:wrap}
.rep-post{background:var(--surface-2);border-radius:11px;padding:11px 13px;font-size:14px;white-space:pre-wrap;word-wrap:break-word;color:var(--text-2)}
.rep-reason{font-size:13px;margin:9px 0;color:var(--text-2)}
.rep-reason b{color:var(--family)}
.rep-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.btn{font-size:13px;font-weight:600;padding:8px 14px;border-radius:10px;transition:.15s}
.btn-danger{background:var(--family);color:#fff}
.btn-danger:hover{filter:brightness(1.08)}
.btn-ghost{background:var(--surface-2);color:var(--text)}
.btn-ghost:hover{background:var(--border-2)}
.btn-warn{background:rgba(255,194,75,.16);color:var(--news);border:1px solid rgba(255,194,75,.3)}
.btn-warn:hover{background:rgba(255,194,75,.26)}
.urow{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);
  border-radius:13px;padding:11px 14px;box-shadow:var(--shadow);margin-bottom:9px}
.urow .u-name{font-weight:600;font-size:14px;display:flex;align-items:center;gap:7px}
.urow .u-sub{font-size:12.5px;color:var(--muted)}
.urow .u-tag{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:20px}
.urow .u-tag.banned{background:rgba(224,64,251,.16);color:#EE9BFF}
.urow .u-tag.admin{background:rgba(0,240,255,.15);color:#7DF3FF}
.urow .spacer{margin-left:auto}
.admin-search{display:flex;gap:9px;margin-bottom:14px}
.admin-search input{flex:1;border:1px solid var(--border-2);border-radius:11px;padding:10px 14px;font-size:14px;background:var(--surface)}
.admin-search input::placeholder{color:var(--muted-2)}
.admin-search input:focus{outline:none;border-color:var(--accent)}
.admin-empty{color:var(--muted);font-size:14px;padding:14px;text-align:center;background:var(--surface);border:1px dashed var(--border-2);border-radius:13px}
.admin-lock{max-width:420px;margin:80px auto;text-align:center}
.admin-lock h1{font-family:'Space Grotesk',sans-serif;font-size:24px;margin-bottom:8px}
.admin-lock p{color:var(--muted)}
.admin-lock a{color:var(--accent);font-weight:600}
@media (max-width:680px){.stats{grid-template-columns:repeat(2,1fr)}}

/* ---------- email verification banner ---------- */
.verify-banner{display:flex;align-items:center;gap:12px;margin:18px 0 0;
  background:rgba(255,194,75,.12);border:1px solid rgba(255,194,75,.35);
  color:#FFD98A;border-radius:13px;padding:11px 15px;font-size:13.5px;font-weight:500}
.verify-banner span{flex:1}
.verify-banner button{background:#FFC24B;color:#0B1120;font-weight:700;font-size:12.5px;
  padding:7px 14px;border-radius:9px;white-space:nowrap}
.verify-banner button:disabled{opacity:.6;cursor:default}
@media (max-width:980px){.verify-banner{margin:14px 14px 0}}

/* ---------- LEGAL PAGES (privacy / terms) ---------- */
.legal-top{position:sticky;top:0;z-index:10;background:rgba(15,23,42,.85);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border)}
.legal-top-in{max-width:760px;margin:0 auto;display:flex;align-items:center;gap:11px;padding:14px 22px}
.legal-top .brand-name{font-size:21px}
.legal-top .back{margin-left:auto;font-size:13px;font-weight:600;color:var(--accent)}
.legal-wrap{max-width:760px;margin:0 auto;padding:34px 22px 90px}
.legal-wrap h1{font-family:'Space Grotesk',sans-serif;font-size:32px;font-weight:700;letter-spacing:-.02em;margin:0 0 6px}
.legal-updated{color:var(--muted);font-size:13px;margin-bottom:30px}
.legal-wrap h2{font-family:'Space Grotesk',sans-serif;font-size:19px;font-weight:600;margin:30px 0 10px;color:#fff}
.legal-wrap p,.legal-wrap li{color:var(--text-2);font-size:15px;line-height:1.7}
.legal-wrap ul{padding-left:20px;margin:8px 0}
.legal-wrap li{margin-bottom:6px}
.legal-wrap a{color:var(--accent);font-weight:500}
.legal-wrap strong{color:#fff;font-weight:600}
.legal-lead{font-size:16px!important;color:#fff!important}
.legal-note{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);
  border-radius:10px;padding:13px 16px;margin:18px 0}
.legal-note p{margin:0;font-size:14px}
.legal-foot{margin-top:40px;padding-top:20px;border-top:1px solid var(--border);color:var(--muted);font-size:13px}

/* footer links (auth + rail) */
.auth-foot{text-align:center;margin-top:18px;font-size:12.5px;color:var(--muted)}
.auth-foot a{color:var(--text-2);font-weight:500}
.side-foot a{color:var(--text-2);font-weight:500}

/* consent checkbox */
.consent{display:flex;align-items:flex-start;gap:9px;margin:4px 0 14px;font-size:12.5px;color:var(--text-2);line-height:1.5}
.consent input{margin-top:2px;width:16px;height:16px;accent-color:var(--accent);flex:0 0 auto}
.consent a{color:var(--accent);font-weight:600}

/* ---------- news cards (Frothier feed in the News lens) ---------- */
a.newscard{display:block;text-decoration:none;border-left:3px solid var(--news)}
a.newscard:hover{border-color:var(--news);box-shadow:0 0 0 1px rgba(255,194,75,.25), var(--shadow)}
.news-src{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--news)}
.news-title{font-family:'Space Grotesk',sans-serif;font-size:16px;font-weight:600;color:#fff;line-height:1.3;margin:4px 0 0}
a.newscard:hover .news-title{color:var(--news)}
.news-sum{font-size:13.5px;color:var(--text-2);line-height:1.5;margin-top:6px}

.urow .u-tag.news{background:rgba(255,194,75,.16);color:#FFD98A}
