/* ============================================================
   OKOMMERCE COMMUNITY — forum prototype styles
   Builds on styles.css tokens (loaded first).
   ============================================================ */

:root {
  --c-bg: #f7f9fc;
  --green: #1F8A5B;
  --green-soft: rgba(31,138,91,.10);
  --amber: #B7791F;
  --amber-soft: rgba(183,121,31,.12);
}
body.community { background: var(--c-bg); }

/* active nav link in the shared home-style header */
.nav__links a.active { color: var(--ink); }
.nav__links a.active::after { right: 0; }

/* search inside the feed toolbar */
.feedbar__search { position:relative; display:flex; align-items:center; }
.feedbar__search svg { position:absolute; left:11px; width:16px; height:16px; color: var(--ink-3); pointer-events:none; }
.feedbar__search input { width: 210px; padding: 9px 12px 9px 34px; border-radius: 9px; border:1px solid var(--line);
  background: var(--mist); font-family: inherit; font-size: 13.5px; color: var(--ink); transition:.15s; }
.feedbar__search input:focus { outline:none; border-color: var(--blue); background:#fff; box-shadow:0 0 0 3px rgba(31,119,192,.12); }

/* ---------- Community header ---------- */
.chead { position: sticky; top: 0; z-index: 90; background: rgba(255,255,255,.9);
  backdrop-filter: blur(14px); border-bottom: 1px solid var(--line); }
.chead__in { display:flex; align-items:center; gap: 22px; height: 70px; }
.chead__logo img { height: 27px; display:block; }
.chead__badge { font-family: var(--font-display); font-weight:700; font-size:12px; letter-spacing:.04em;
  color: var(--blue); background: rgba(31,119,192,.10); padding:4px 9px; border-radius:7px; }
.chead__nav { display:flex; gap: 4px; margin-left: 6px; }
.chead__nav a { display:flex; align-items:center; gap:7px; font-weight:600; font-size:14.5px; color: var(--ink-2);
  padding: 8px 13px; border-radius: 9px; transition:.18s; cursor:pointer; }
.chead__nav a svg { width:16px; height:16px; opacity:.7; }
.chead__nav a:hover { background: var(--mist); color: var(--ink); }
.chead__nav a.active { background: rgba(31,119,192,.10); color: var(--blue); }
.chead__nav a.active svg { opacity:1; }
.chead__search { margin-left: auto; position:relative; width: 250px; }
.chead__search input { width:100%; padding: 10px 14px 10px 38px; border-radius: 10px; border:1px solid var(--line);
  background: var(--mist); font-family: inherit; font-size: 14px; color: var(--ink); transition:.18s; }
.chead__search input:focus { outline:none; border-color: var(--blue); background:#fff; box-shadow:0 0 0 3px rgba(31,119,192,.12); }
.chead__search svg { position:absolute; left:12px; top:50%; transform:translateY(-50%); width:17px; height:17px; color: var(--ink-3); }
.chead__auth { display:flex; align-items:center; gap: 10px; }
.chead__burger { display:none; }

/* user chip */
.uchip { display:flex; align-items:center; gap:9px; padding:5px 6px 5px 5px; border-radius:999px; border:1px solid var(--line);
  background:#fff; cursor:pointer; transition:.18s; }
.uchip:hover { border-color: var(--blue); box-shadow: var(--shadow-sm); }
.uchip__name { font-weight:600; font-size:13.5px; padding-right:4px; }
.uchip svg { width:15px; height:15px; color: var(--ink-3); }

/* avatar */
.av { border-radius:50%; display:grid; place-items:center; color:#fff; font-weight:700; font-family: var(--font-display);
  flex:none; letter-spacing:-0.02em; overflow:hidden; }
.av-28 { width:28px; height:28px; font-size:12px; }
.av-36 { width:36px; height:36px; font-size:14px; }
.av-44 { width:44px; height:44px; font-size:16px; }
.av-56 { width:56px; height:56px; font-size:21px; }

/* ---------- Page wrap ---------- */
.cwrap { max-width: 1340px; margin: 0 auto; padding: 0 40px; }
.croot { min-height: 70vh; }

/* community hero */
.chero { background:
    radial-gradient(900px 420px at 8% -20%, rgba(46,147,230,.22), transparent 60%),
    radial-gradient(700px 460px at 100% 0%, rgba(242,100,30,.12), transparent 55%),
    var(--navy);
  color: var(--d-fg); position:relative; overflow:hidden; padding: 52px 0 120px; }
.chero::after { content:""; position:absolute; inset:0; background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 56px 56px; -webkit-mask-image: radial-gradient(ellipse 80% 100% at 30% 0%, #000, transparent 75%);
  mask-image: radial-gradient(ellipse 80% 100% at 30% 0%, #000, transparent 75%); }
.chero__in { position:relative; z-index:2; display:flex; justify-content:space-between; align-items:flex-end; gap: 30px; flex-wrap:wrap; }
.chero h1 { font-size: clamp(30px, 3.6vw, 44px); color:#fff; letter-spacing:-0.03em; }
.chero h1 .o { color: var(--orange-soft); }
.chero p { color: var(--d-fg-2); font-size: 17px; margin-top: 12px; max-width: 540px; }
.chero__stats { display:flex; gap: 28px; }
.chero__stat b { font-family: var(--font-display); font-size: 26px; color:#fff; display:block; letter-spacing:-0.02em; }
.chero__stat span { font-size: 13px; color: var(--d-fg-2); }

/* feed layout — pull up over hero */
.feedwrap { display:grid; grid-template-columns: 1fr 320px; gap: 28px; margin-top: -76px; position:relative; z-index:3; padding-bottom: 80px; }
.feedmain { min-width:0; }

/* toolbar */
.feedbar { background:#fff; border:1px solid var(--line); border-radius: 14px; padding: 10px; display:flex; align-items:center; gap:10px;
  box-shadow: var(--shadow-sm); margin-bottom: 16px; flex-wrap:wrap; }
.cats { display:flex; gap:6px; flex-wrap:wrap; }
.cat { display:inline-flex; align-items:center; gap:7px; padding:8px 13px; border-radius:9px; font-weight:600; font-size:13.5px;
  color: var(--ink-2); cursor:pointer; transition:.15s; border:1px solid transparent; white-space:nowrap; }
.cat svg { width:15px; height:15px; }
.cat:hover { background: var(--mist); }
.cat.active { background: var(--charcoal); color:#fff; }
.cat.active svg { color:#fff !important; }
.feedbar__right { margin-left:auto; display:flex; align-items:center; gap:8px; }
.sortsel { display:flex; gap:2px; background: var(--mist); border-radius:9px; padding:3px; }
.sortsel button { border:none; background:none; padding:7px 12px; border-radius:7px; font-family:inherit; font-weight:600;
  font-size:13px; color: var(--ink-3); cursor:pointer; transition:.15s; }
.sortsel button.active { background:#fff; color: var(--ink); box-shadow: var(--shadow-sm); }

/* thread row */
.tlist { display:flex; flex-direction:column; gap: 12px; }
.trow { background:#fff; border:1px solid var(--line); border-radius: 14px; padding: 18px 20px; display:flex; gap: 16px;
  transition: .18s; cursor:pointer; position:relative; }
.trow:hover { border-color: rgba(31,119,192,.4); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.trow__vote { display:flex; flex-direction:column; align-items:center; gap:3px; flex:none; width:46px; padding-top:2px; }
.vbtn { width:38px; height:30px; border-radius:8px; border:1px solid var(--line); background:#fff; display:grid; place-items:center;
  cursor:pointer; color: var(--ink-3); transition:.15s; }
.vbtn svg { width:17px; height:17px; }
.vbtn:hover { border-color: var(--blue); color: var(--blue); background: rgba(31,119,192,.06); }
.vbtn.on { border-color: var(--orange); color: var(--orange); background: rgba(242,100,30,.08); }
.vcount { font-family: var(--font-display); font-weight:700; font-size:15px; color: var(--ink); }
.trow__body { flex:1; min-width:0; }
.trow__meta { display:flex; align-items:center; gap:9px; margin-bottom: 7px; flex-wrap:wrap; }
.trow__title { font-family: var(--font-display); font-weight:700; font-size: 18px; letter-spacing:-0.01em; color: var(--ink);
  line-height:1.3; margin-bottom: 6px; }
.trow:hover .trow__title { color: var(--blue); }
.trow__excerpt { color: var(--ink-3); font-size: 14.5px; line-height:1.5; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.trow__foot { display:flex; align-items:center; gap: 16px; margin-top: 12px; flex-wrap:wrap; }
.trow__author { display:flex; align-items:center; gap:8px; font-size: 13px; color: var(--ink-2); }
.trow__author b { font-weight:600; color: var(--ink); }
.tstat { display:flex; align-items:center; gap:6px; font-size:13px; color: var(--ink-3); font-weight:500; }
.tstat svg { width:15px; height:15px; }
.trow__tags { display:flex; gap:6px; margin-left:auto; flex-wrap:wrap; }

/* category badge / tag chips */
.cbadge { display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:700; padding:4px 9px; border-radius:7px; letter-spacing:.01em; }
.cbadge svg { width:13px; height:13px; }
.tagchip { font-size:12px; font-weight:600; color: var(--ink-3); background: var(--mist); border:1px solid var(--line); padding:3px 9px; border-radius:7px; }
.rolebadge { font-size:10.5px; font-weight:800; letter-spacing:.04em; padding:2px 7px; border-radius:6px; text-transform:uppercase; }
.role-team { background: rgba(242,100,30,.12); color: var(--orange); }
.role-mod { background: rgba(31,119,192,.12); color: var(--blue); }
.role-member { background: var(--mist); color: var(--ink-3); }
.pin-badge { display:inline-flex; align-items:center; gap:5px; font-size:11.5px; font-weight:700; color: var(--green); }
.pin-badge svg { width:13px; height:13px; }
.status-pill { display:inline-flex; align-items:center; gap:6px; font-size:11.5px; font-weight:700; padding:3px 9px; border-radius:999px; }
.status-pending { background: var(--amber-soft); color: var(--amber); }
.status-live { background: var(--green-soft); color: var(--green); }

/* ---------- Sidebar ---------- */
.side { display:flex; flex-direction:column; gap: 16px; position:sticky; top: 86px; align-self:start; }
.scard { background:#fff; border:1px solid var(--line); border-radius: 14px; padding: 20px; }
.scard__h { font-family: var(--font-display); font-weight:700; font-size: 14px; letter-spacing:.02em; color: var(--ink);
  display:flex; align-items:center; gap:8px; margin-bottom: 14px; }
.scard__h svg { width:16px; height:16px; color: var(--blue); }
.scard--cta { background: linear-gradient(165deg,#0e2233,#0b1822); border-color:transparent; color:#fff; }
.scard--cta h4 { font-family: var(--font-display); color:#fff; font-size:18px; margin-bottom:8px; }
.scard--cta p { color: var(--d-fg-2); font-size:13.5px; margin-bottom:16px; line-height:1.5; }
.scard--cta .btn { width:100%; justify-content:center; }

.catlist { display:flex; flex-direction:column; gap:3px; }
.catlist a { display:flex; align-items:center; gap:11px; padding:9px 10px; border-radius:9px; cursor:pointer; transition:.15s; }
.catlist a:hover { background: var(--mist); }
.catlist .ci { width:30px; height:30px; border-radius:8px; display:grid; place-items:center; flex:none; }
.catlist .ci svg { width:16px; height:16px; }
.catlist .cn { font-weight:600; font-size:14px; color: var(--ink); }
.catlist .cc { margin-left:auto; font-size:12.5px; color: var(--ink-3); font-weight:600; background: var(--mist); padding:2px 8px; border-radius:999px; }

.contrib { display:flex; align-items:center; gap:11px; padding:8px 0; }
.contrib + .contrib { border-top:1px solid var(--line-soft); }
.contrib__n { font-weight:600; font-size:13.5px; color: var(--ink); }
.contrib__r { font-size:12px; color: var(--ink-3); }
.contrib__pts { margin-left:auto; text-align:right; }
.contrib__pts b { font-family: var(--font-display); font-size:14px; color: var(--orange); }
.contrib__pts span { display:block; font-size:10.5px; color: var(--ink-3); }

.about-row { display:flex; align-items:center; gap:10px; font-size:13.5px; color: var(--ink-2); padding:6px 0; }
.about-row svg { width:16px; height:16px; color: var(--blue); flex:none; }

/* guideline list */
.guide { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.guide li { display:flex; gap:10px; font-size:13.5px; color: var(--ink-2); line-height:1.45; }
.guide li svg { width:16px; height:16px; color: var(--green); flex:none; margin-top:2px; }

/* ---------- Thread detail ---------- */
.tdwrap { display:grid; grid-template-columns: 1fr 300px; gap: 28px; padding: 32px 0 80px; }
.backlink { display:inline-flex; align-items:center; gap:7px; font-weight:600; font-size:14px; color: var(--ink-3); cursor:pointer; margin-bottom: 18px; transition:.15s; }
.backlink:hover { color: var(--blue); }
.backlink svg { width:16px; height:16px; }
.post { background:#fff; border:1px solid var(--line); border-radius: 16px; padding: 28px; }
.post__cat { margin-bottom: 14px; display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.post__title { font-family: var(--font-display); font-weight:700; font-size: clamp(24px,3vw,32px); letter-spacing:-0.02em; line-height:1.15; color: var(--ink); }
.post__byline { display:flex; align-items:center; gap:11px; margin: 18px 0 22px; padding-bottom: 22px; border-bottom:1px solid var(--line); }
.post__byline .nm { font-weight:700; font-size:14.5px; color: var(--ink); display:flex; align-items:center; gap:8px; }
.post__byline .meta { font-size:13px; color: var(--ink-3); }
.post__content { font-size: 16px; line-height: 1.7; color: var(--ink-2); }
.post__content p { margin-bottom: 16px; }
.post__content p:last-child { margin-bottom:0; }
.post__content code { background: var(--mist); border:1px solid var(--line); border-radius:6px; padding:2px 6px; font-family: ui-monospace,monospace; font-size:14px; color: var(--blue-700); }
.post__content pre { background: #0a141d; color:#dbe7f1; border-radius:12px; padding:16px 18px; overflow-x:auto; font-family: ui-monospace,monospace; font-size:13.5px; line-height:1.7; margin-bottom:16px; }
.post__actions { display:flex; align-items:center; gap: 10px; margin-top: 24px; padding-top: 20px; border-top:1px solid var(--line); flex-wrap:wrap; }
.actbtn { display:inline-flex; align-items:center; gap:8px; padding:9px 15px; border-radius:10px; border:1px solid var(--line);
  background:#fff; font-family:inherit; font-weight:600; font-size:14px; color: var(--ink-2); cursor:pointer; transition:.15s; }
.actbtn svg { width:16px; height:16px; }
.actbtn:hover { border-color: var(--blue); color: var(--blue); }
.actbtn.on { background: rgba(242,100,30,.08); border-color: var(--orange); color: var(--orange); }

/* comments */
.cmt-head { font-family: var(--font-display); font-weight:700; font-size: 18px; margin: 34px 0 16px; display:flex; align-items:center; gap:10px; }
.cmt-head .n { color: var(--ink-3); font-weight:600; font-size:15px; }
.cmts { display:flex; flex-direction:column; gap: 14px; }
.cmt { background:#fff; border:1px solid var(--line); border-radius: 14px; padding: 18px 20px; display:flex; gap:14px; }
.cmt--accept { border-color: rgba(31,138,91,.4); background: linear-gradient(0deg, rgba(31,138,91,.03), rgba(31,138,91,.03)), #fff; }
.cmt__main { flex:1; min-width:0; }
.cmt__top { display:flex; align-items:center; gap:9px; margin-bottom:8px; flex-wrap:wrap; }
.cmt__top .nm { font-weight:700; font-size:14px; color: var(--ink); }
.cmt__top .t { font-size:12.5px; color: var(--ink-3); }
.cmt__body { font-size:14.5px; line-height:1.6; color: var(--ink-2); }
.cmt__foot { display:flex; align-items:center; gap: 16px; margin-top:11px; }
.cmt__vote { display:flex; align-items:center; gap:6px; font-size:13px; font-weight:600; color: var(--ink-3); cursor:pointer; }
.cmt__vote svg { width:15px; height:15px; }
.cmt__vote:hover { color: var(--orange); }
.cmt__reply { font-size:13px; font-weight:600; color: var(--ink-3); cursor:pointer; display:flex; align-items:center; gap:6px; }
.cmt__reply svg { width:15px; height:15px; }
.cmt__reply:hover { color: var(--blue); }
.accept-tag { display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:800; letter-spacing:.03em; text-transform:uppercase;
  color: var(--green); background: var(--green-soft); padding:3px 8px; border-radius:6px; }
.accept-tag svg { width:12px; height:12px; }

/* composer */
.composer { background:#fff; border:1px solid var(--line); border-radius: 14px; padding: 18px; margin-top: 18px; }
.composer__top { display:flex; gap:13px; align-items:flex-start; }
.composer textarea { width:100%; border:1px solid var(--line); border-radius:11px; padding:13px 15px; font-family:inherit; font-size:14.5px;
  color: var(--ink); resize:vertical; min-height: 90px; transition:.15s; }
.composer textarea:focus { outline:none; border-color: var(--blue); box-shadow:0 0 0 3px rgba(31,119,192,.10); }
.composer__foot { display:flex; align-items:center; justify-content:space-between; margin-top:12px; gap:12px; flex-wrap:wrap; }
.composer__hint { font-size:12.5px; color: var(--ink-3); display:flex; align-items:center; gap:7px; }
.composer__hint svg { width:15px; height:15px; color: var(--amber); }

/* login-gate inline */
.gate { background: linear-gradient(0deg, rgba(31,119,192,.04), rgba(31,119,192,.04)), #fff; border:1.5px dashed rgba(31,119,192,.4);
  border-radius:14px; padding: 26px; text-align:center; margin-top:18px; }
.gate h4 { font-family: var(--font-display); font-size:18px; margin-bottom:6px; }
.gate p { color: var(--ink-3); font-size:14.5px; margin-bottom:16px; }
.gate__cta { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }

/* ---------- Auth pages ---------- */
.authpage { display:flex; min-height: calc(100vh - 70px); }
.authpage__aside { flex:1; background:
    radial-gradient(700px 380px at 20% 10%, rgba(46,147,230,.28), transparent 60%),
    radial-gradient(600px 400px at 90% 90%, rgba(242,100,30,.16), transparent 55%),
    var(--navy); color: var(--d-fg); padding: 60px; display:flex; flex-direction:column; justify-content:center; position:relative; overflow:hidden; }
.authpage__aside::after { content:""; position:absolute; inset:0; background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 52px 52px; -webkit-mask-image: radial-gradient(ellipse 90% 70% at 30% 40%, #000, transparent 80%); mask-image: radial-gradient(ellipse 90% 70% at 30% 40%, #000, transparent 80%); }
.authpage__aside .in { position:relative; z-index:2; max-width: 460px; }
.authpage__aside h2 { font-size: clamp(28px,3vw,40px); color:#fff; letter-spacing:-0.03em; line-height:1.1; }
.authpage__aside h2 .o { color: var(--orange-soft); }
.authpage__aside p { color: var(--d-fg-2); font-size:16px; margin-top: 16px; line-height:1.6; }
.authpage__pts { list-style:none; padding:0; margin: 28px 0 0; display:flex; flex-direction:column; gap:16px; }
.authpage__pts li { display:flex; gap:14px; align-items:flex-start; }
.authpage__pts .ic { width:40px; height:40px; border-radius:11px; background: rgba(255,255,255,.06); border:1px solid var(--d-line);
  display:grid; place-items:center; flex:none; color: var(--blue-bright); }
.authpage__pts .ic svg { width:20px; height:20px; }
.authpage__pts b { color:#fff; font-size:15px; display:block; font-weight:700; }
.authpage__pts span { color: var(--d-fg-2); font-size:13.5px; }
.authpage__main { width: 540px; max-width: 46%; display:flex; align-items:center; justify-content:center; padding: 50px; }
.authcard { width: 100%; max-width: 400px; }
.authcard__eye { font-weight:700; font-size:12.5px; letter-spacing:.12em; text-transform:uppercase; color: var(--blue); }
.authcard h1 { font-family: var(--font-display); font-size: 28px; letter-spacing:-0.02em; margin: 10px 0 6px; }
.authcard__sub { color: var(--ink-3); font-size:15px; margin-bottom: 26px; }

.field { margin-bottom: 16px; }
.field label { display:block; font-weight:600; font-size:13.5px; color: var(--ink); margin-bottom:7px; }
.field input, .field textarea, .field select { width:100%; padding: 12px 14px; border-radius: 11px; border:1px solid var(--line);
  font-family:inherit; font-size: 14.5px; color: var(--ink); background:#fff; transition:.15s; }
.field textarea { resize:vertical; min-height: 120px; line-height:1.6; }
.field input:focus, .field textarea:focus, .field select:focus { outline:none; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(31,119,192,.12); }
.field input::placeholder, .field textarea::placeholder { color: var(--ink-3); }
.field__hint { font-size:12.5px; color: var(--ink-3); margin-top:6px; }
.field__err { font-size:12.5px; color: #d23f3f; margin-top:6px; display:none; }
.field.invalid input, .field.invalid textarea { border-color:#e7a3a3; box-shadow:0 0 0 3px rgba(210,63,63,.10); }
.field.invalid .field__err { display:block; }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.fullbtn { width:100%; justify-content:center; }
.authmeta { text-align:center; font-size:14px; color: var(--ink-3); margin-top: 20px; }
.authmeta a { color: var(--blue); font-weight:600; cursor:pointer; }
.legalnote { font-size:12px; color: var(--ink-3); margin-top:16px; line-height:1.5; text-align:center; }

/* steps indicator */
.steps-ind { display:flex; align-items:center; gap:8px; margin-bottom: 26px; }
.steps-ind .si { display:flex; align-items:center; gap:8px; }
.steps-ind .dot { width:26px; height:26px; border-radius:50%; display:grid; place-items:center; font-weight:700; font-size:12.5px;
  background: var(--mist); color: var(--ink-3); border:1px solid var(--line); flex:none; }
.steps-ind .si.done .dot { background: var(--green); color:#fff; border-color: var(--green); }
.steps-ind .si.active .dot { background: var(--blue); color:#fff; border-color: var(--blue); }
.steps-ind .lbl { font-size:12.5px; font-weight:600; color: var(--ink-3); }
.steps-ind .si.active .lbl, .steps-ind .si.done .lbl { color: var(--ink); }
.steps-ind .bar { width:24px; height:2px; background: var(--line); }

/* status panel (verify / pending) */
.statepanel { text-align:center; padding: 8px 0; }
.statepanel__ic { width: 76px; height:76px; border-radius:20px; display:grid; place-items:center; margin: 0 auto 22px; }
.statepanel__ic svg { width:38px; height:38px; }
.ic-blue { background: rgba(31,119,192,.1); color: var(--blue); }
.ic-amber { background: var(--amber-soft); color: var(--amber); }
.ic-green { background: var(--green-soft); color: var(--green); }
.statepanel h1 { font-family: var(--font-display); font-size:25px; letter-spacing:-0.02em; margin-bottom:10px; }
.statepanel p { color: var(--ink-3); font-size:15px; line-height:1.6; margin-bottom:8px; }
.statepanel .email-pill { display:inline-block; font-weight:700; color: var(--ink); background: var(--mist); border:1px solid var(--line);
  padding:6px 14px; border-radius:999px; margin: 6px 0 20px; font-size:14px; }

/* demo helper */
.demo-hint { margin-top: 22px; padding: 14px 16px; border:1.5px dashed rgba(242,100,30,.5); border-radius:12px;
  background: rgba(242,100,30,.05); }
.demo-hint .lbl { display:flex; align-items:center; gap:7px; font-size:11px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color: var(--orange); margin-bottom:8px; }
.demo-hint .lbl svg { width:14px; height:14px; }
.demo-hint p { font-size:13px; color: var(--ink-2); margin-bottom:10px; line-height:1.45; }

/* ---------- Compose page ---------- */
.composepage { max-width: 820px; margin: 0 auto; padding: 36px 0 80px; }
.composepage h1 { font-family: var(--font-display); font-size: 30px; letter-spacing:-0.02em; margin-bottom: 8px; }
.composepage__sub { color: var(--ink-3); font-size:15.5px; margin-bottom: 28px; }
.cardform { background:#fff; border:1px solid var(--line); border-radius: 16px; padding: 28px; }
.catpick { display:flex; gap:10px; flex-wrap:wrap; }
.catpick label { cursor:pointer; }
.catpick input { position:absolute; opacity:0; pointer-events:none; }
.catpick .opt { display:flex; align-items:center; gap:9px; padding:11px 15px; border-radius:11px; border:1.5px solid var(--line);
  font-weight:600; font-size:14px; color: var(--ink-2); transition:.15s; }
.catpick .opt svg { width:17px; height:17px; }
.catpick input:checked + .opt { border-color: var(--blue); background: rgba(31,119,192,.06); color: var(--blue); }
.catpick .opt:hover { border-color: var(--ink-3); }
.toolbar-fake { display:flex; gap:4px; padding:8px; background: var(--mist); border:1px solid var(--line); border-bottom:none; border-radius:11px 11px 0 0; }
.toolbar-fake button { width:32px; height:32px; border-radius:7px; border:none; background:none; cursor:pointer; color: var(--ink-3); display:grid; place-items:center; }
.toolbar-fake button:hover { background:#fff; color: var(--ink); }
.toolbar-fake button svg { width:16px; height:16px; }
.composebody { border-radius: 0 0 11px 11px !important; border-top:none !important; }
.approval-note { display:flex; gap:13px; padding:16px 18px; border-radius:13px; background: var(--amber-soft); border:1px solid rgba(183,121,31,.25); margin-top:20px; }
.approval-note svg { width:22px; height:22px; color: var(--amber); flex:none; }
.approval-note b { color: var(--ink); font-weight:700; font-size:14.5px; }
.approval-note p { color: var(--ink-2); font-size:13.5px; margin-top:3px; line-height:1.5; }

/* ---------- Account / dashboard ---------- */
.acctpage { padding: 36px 0 80px; }
.acct-head { display:flex; align-items:center; gap: 20px; margin-bottom: 30px; }
.acct-head .meta h1 { font-family: var(--font-display); font-size: 26px; letter-spacing:-0.02em; }
.acct-head .meta .e { color: var(--ink-3); font-size:14.5px; margin-top:3px; display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.acct-tabs { display:flex; gap:4px; border-bottom:1px solid var(--line); margin-bottom: 24px; }
.acct-tabs button { border:none; background:none; padding:12px 16px; font-family:inherit; font-weight:600; font-size:14.5px;
  color: var(--ink-3); cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-1px; transition:.15s; }
.acct-tabs button.active { color: var(--blue); border-bottom-color: var(--blue); }
.acct-tabs button .cnt { background: var(--mist); border-radius:999px; padding:1px 8px; font-size:12px; margin-left:6px; }

.empty { text-align:center; padding: 60px 20px; color: var(--ink-3); }
.empty svg { width:46px; height:46px; color: var(--line); margin:0 auto 14px; display:block; }
.empty p { font-size:15px; }

/* ---------- Moderation queue ---------- */
.modqueue .modrow { background:#fff; border:1px solid var(--line); border-radius:14px; padding:18px 20px; margin-bottom:12px; }
.modrow__top { display:flex; align-items:center; gap:10px; margin-bottom:10px; flex-wrap:wrap; }
.modrow__title { font-family: var(--font-display); font-weight:700; font-size:17px; }
.modrow__excerpt { color: var(--ink-3); font-size:14px; line-height:1.5; margin-bottom:14px; }
.modrow__actions { display:flex; gap:10px; }

/* ---------- Toast ---------- */
.toasts { position: fixed; bottom: 24px; left:50%; transform:translateX(-50%); z-index: 200; display:flex; flex-direction:column; gap:10px; align-items:center; }
.toast { background: var(--charcoal); color:#fff; padding: 13px 18px; border-radius: 12px; box-shadow: var(--shadow-lg);
  display:flex; align-items:center; gap:11px; font-weight:600; font-size:14px; animation: toastin .3s cubic-bezier(.2,.8,.2,1); max-width: 460px; }
.toast svg { width:18px; height:18px; flex:none; }
.toast.ok svg { color:#5fe39a; } .toast.info svg { color: var(--blue-bright); } .toast.warn svg { color:#ffc46b; }
@keyframes toastin { from { opacity:0; transform: translateY(14px); } }

/* fade-in for views (transform-only so captures never catch a blank frame) */
.viewfade { animation: vf .35s ease; }
@keyframes vf { from { transform: translateY(8px); } }

/* ---------- Responsive ---------- */
@media (max-width: 940px) {
  .feedwrap, .tdwrap { grid-template-columns: 1fr; }
  .side, .tdwrap .side { position:static; }
  .tdwrap .side { order:-1; }
  .feedbar__search input { width: 150px; }
  .authpage__aside { display:none; }
  .authpage__main { width:100%; max-width:100%; }
}
@media (max-width: 920px) {
  body.community .nav__links { display:none; }
  body.community.nav-open .nav__links { display:flex; position:absolute; top:76px; left:0; right:0; flex-direction:column; gap:2px;
    background:#fff; padding: 14px 22px 18px; border-bottom:1px solid var(--line); box-shadow: var(--shadow-md); }
  body.community.nav-open .nav__links a { padding: 11px 0; font-size:15.5px; }
}
@media (max-width: 620px) {
  .cwrap { padding: 0 18px; }
  .chero__stats { gap:18px; }
  .trow__vote { width:38px; }
  .field-row { grid-template-columns:1fr; }
  .acct-head { flex-direction:column; align-items:flex-start; }
}
