/* Content Hub UI, layered on the shared Boostify hub styles.css
   (tokens: --ink --orange --orange-deep --gold --gray --line --soft --disp --body). */

.wrap{max-width:1180px;margin:0 auto;padding:0 clamp(18px,4vw,40px)}
.muted{color:var(--gray)}
.mono{font-variant-numeric:tabular-nums}
.hidden{display:none!important}

/* ---------- top bar ---------- */
.appbar{display:flex;align-items:center;justify-content:space-between;gap:16px;position:sticky;top:0;z-index:20;
  padding:14px clamp(18px,4vw,40px);border-bottom:1px solid var(--line);background:rgba(255,255,255,.92);backdrop-filter:blur(8px)}
.appbar .brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}
.appbar .brand img{height:22px;display:block}
.appbar .brand b{font-family:var(--disp);font-weight:800;font-size:15px;letter-spacing:-.01em}
.appbar .brand .tag{font-family:var(--disp);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--orange-deep);background:rgba(232,89,12,.10);border-radius:999px;padding:4px 10px}
.appbar .who{display:flex;align-items:center;gap:14px;font-size:13.5px;color:var(--gray)}
.appbar .who b{color:var(--ink);font-weight:700}
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray);padding:14px clamp(18px,4vw,40px) 0}
.crumbs a{color:var(--gray);text-decoration:none}
.crumbs a:hover{color:var(--orange)}
.crumbs .sep{opacity:.5}

/* ---------- login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative;overflow:hidden}
.login-wrap .topo{position:absolute;inset:0;background:url('/assets/topo.webp') center/cover no-repeat;opacity:.35}
.login-wrap .topo::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 55% at 50% 42%,rgba(255,255,255,.95),rgba(255,255,255,.75) 45%,rgba(255,255,255,0))}
.login-card{position:relative;width:100%;max-width:400px;background:var(--paper);border:1px solid var(--line);border-radius:16px;
  padding:34px 30px;box-shadow:0 30px 70px -30px rgba(0,0,0,.35)}
.login-card img{height:26px;margin-bottom:22px}
.login-card h1{font-size:26px;margin-bottom:6px}
.login-card p{color:var(--gray);font-size:14px;margin:0 0 22px}
.field{margin-bottom:14px}
.field label{display:block;font-family:var(--disp);font-weight:700;font-size:12.5px;letter-spacing:.02em;margin-bottom:6px}
.field input{width:100%;font:inherit;font-size:15px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:var(--paper)}
.field input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,89,12,.15)}
.login-card .btn{width:100%;margin-top:6px}
.login-card .err{color:var(--red);font-size:13.5px;font-weight:600;margin-top:12px;min-height:1em}
.login-alt{margin-top:16px;text-align:center;font-size:13.5px}
.login-alt a{color:var(--gray);text-decoration:none;font-weight:600}
.login-alt a:hover{color:var(--orange)}

/* ---------- section header ---------- */
.pagehead{padding:clamp(26px,4vw,42px) clamp(18px,4vw,40px) 8px}
.pagehead .kicker{margin-bottom:10px}
.pagehead h1{font-size:clamp(30px,4.6vw,46px)}
.pagehead .sub{color:var(--gray);margin-top:10px;max-width:70ch}

/* ---------- project cards ---------- */
.projects{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;padding:20px clamp(18px,4vw,40px) 60px}
.proj-card{display:block;text-decoration:none;color:inherit;background:var(--paper);border:1px solid var(--line);border-radius:14px;
  padding:22px;box-shadow:var(--shadow-card);transition:transform .15s var(--ease),border-color .15s var(--ease)}
.proj-card:hover{transform:translateY(-2px);border-color:var(--orange)}
.proj-card h3{font-family:var(--disp);font-weight:800;font-size:20px;letter-spacing:-.02em;margin:0 0 4px}
.proj-card .meta{color:var(--gray);font-size:13.5px}
.proj-card .stats{display:flex;gap:16px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.proj-card .stat b{font-family:var(--disp);font-weight:800;font-size:22px;display:block;line-height:1}
.proj-card .stat span{font-size:11.5px;color:var(--gray);text-transform:uppercase;letter-spacing:.06em}
.proj-card .stat.flag b{color:var(--orange)}

/* ---------- calendar ---------- */
.calbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:0 clamp(18px,4vw,40px) 6px}
.legend{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--gray)}
.legend span{display:inline-flex;align-items:center;gap:6px}
.legend i{width:9px;height:9px;border-radius:50%;display:inline-block}
.st-planned{background:#C7CDD6}.st-drafting{background:var(--gold)}.st-in-review{background:var(--orange)}
.st-approved{background:var(--green)}.st-published{background:var(--ink)}

.month{padding:8px clamp(18px,4vw,40px)}
.month h4{font-family:var(--disp);font-weight:800;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);
  margin:24px 0 10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.cal-item{display:grid;grid-template-columns:76px 1fr auto;gap:16px;align-items:center;padding:14px 8px;border-bottom:1px solid var(--line);
  border-radius:10px;transition:background .12s var(--ease)}
.cal-item:hover{background:var(--soft)}
.cal-item .date{font-family:var(--disp);font-weight:800;font-size:13px;color:var(--gray);text-align:center;line-height:1.15}
.cal-item .date .d{font-size:22px;color:var(--ink);display:block}
.cal-item .body{min-width:0}
.cal-item .body .t{font-family:var(--disp);font-weight:700;font-size:16.5px;letter-spacing:-.01em;color:var(--ink);
  text-decoration:none;display:inline-block}
.cal-item .body a.t:hover{color:var(--orange)}
.cal-item .body .kw{font-size:12.5px;color:var(--gray);margin-top:3px}
.cal-item .body .kw .type{font-family:var(--disp);font-weight:700;color:var(--orange-deep);text-transform:uppercase;letter-spacing:.05em;font-size:11px}
.cal-item .act{display:flex;align-items:center;gap:8px;white-space:nowrap}
.statpill{font-family:var(--disp);font-weight:700;font-size:11px;letter-spacing:.05em;text-transform:uppercase;padding:5px 11px;border-radius:999px;color:#fff}
.statpill.planned{background:#8b95a3}.statpill.drafting{background:var(--gold);color:#5b4a00}
.statpill.in-review{background:var(--orange)}.statpill.approved{background:var(--green)}.statpill.published{background:var(--ink)}
.mini{appearance:none;border:1px solid var(--line);background:var(--paper);color:var(--ink);font-family:var(--disp);font-weight:700;
  font-size:12.5px;padding:7px 13px;border-radius:8px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:all .12s var(--ease)}
.mini:hover{border-color:var(--orange);color:var(--orange)}
.mini.solid{background:var(--orange);color:#fff;border-color:var(--orange)}
.mini.solid:hover{background:var(--orange-deep);color:#fff}

/* ---------- post reading + proofing ---------- */
.post-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:36px;align-items:start;
  max-width:1180px;margin:0 auto;padding:18px clamp(18px,4vw,40px) 80px}
@media (max-width:900px){.post-layout{grid-template-columns:1fr}.cmt-rail{position:static!important}}
.article{min-width:0}
.article .hero-img{width:100%;border-radius:14px;border:1px solid var(--line);margin:6px 0 26px;display:block}
.article .ptitle{font-size:clamp(30px,4.4vw,46px);margin:0 0 12px}
.article .pmeta{display:flex;gap:14px;flex-wrap:wrap;color:var(--gray);font-size:13px;margin-bottom:26px;align-items:center}
.article .pmeta .chip{background:var(--soft);border-radius:999px;padding:4px 11px;font-weight:600}
.post-body{font-size:17.5px;line-height:1.75;color:#1c1c1c}
.post-body h1{font-size:30px;margin:34px 0 12px}
.post-body h2{font-size:26px;margin:34px 0 12px}
.post-body h3{font-family:var(--disp);font-weight:700;font-size:20px;letter-spacing:-.01em;margin:26px 0 10px}
.post-body p{margin:0 0 18px}
.post-body ul,.post-body ol{margin:0 0 18px;padding-left:22px}
.post-body li{margin:6px 0}
.post-body a{color:var(--orange-deep);text-underline-offset:2px}
.post-body blockquote{margin:20px 0;padding:8px 20px;border-left:3px solid var(--orange);color:#333;font-style:italic}
.post-body table{width:100%;border-collapse:collapse;margin:20px 0;font-size:15px}
.post-body th,.post-body td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.post-body th{background:var(--soft);font-family:var(--disp);font-weight:700}
.post-body .callout{background:var(--soft);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:8px;padding:14px 16px;margin:20px 0}
.post-body [data-block-id]{scroll-margin-top:80px;border-radius:4px}
.post-body [data-block-id].focus{background:rgba(232,89,12,.06);box-shadow:0 0 0 6px rgba(232,89,12,.06)}
mark.hl{background:rgba(251,197,61,.45);border-radius:2px;padding:.02em 0;cursor:pointer;transition:background .12s}
mark.hl:hover{background:rgba(251,197,61,.75)}
mark.hl.resolved{background:rgba(22,163,74,.16)}
mark.hl.active{background:rgba(232,89,12,.35)}

/* floating "add comment" button on selection */
.sel-btn{position:absolute;z-index:40;transform:translate(-50%,-115%);background:var(--ink);color:#fff;border:0;cursor:pointer;
  font-family:var(--disp);font-weight:700;font-size:12.5px;padding:8px 13px;border-radius:8px;box-shadow:0 8px 20px -6px rgba(0,0,0,.5);
  display:inline-flex;align-items:center;gap:7px}
.sel-btn:hover{background:var(--orange)}

/* comment rail */
.cmt-rail{position:sticky;top:74px}
.railhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.railhead h3{font-family:var(--disp);font-weight:800;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:var(--gray);margin:0}
.railhead .count{font-family:var(--disp);font-weight:800;font-size:13px;color:var(--orange);background:rgba(232,89,12,.1);border-radius:999px;padding:2px 9px}
.cmt{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:13px 14px;margin-bottom:10px;transition:border-color .12s}
.cmt.active{border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,89,12,.1)}
.cmt.resolved{opacity:.6}
.cmt .q{font-size:12.5px;color:var(--gray);border-left:2px solid var(--gold);padding-left:8px;margin-bottom:7px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cmt .body{font-size:14px;color:var(--ink);line-height:1.5}
.cmt .who{font-size:11.5px;color:var(--gray);margin-top:8px;display:flex;justify-content:space-between;align-items:center;gap:8px}
.cmt .who .tools{display:flex;gap:8px}
.cmt .who button{appearance:none;border:0;background:none;color:var(--orange-deep);font-weight:700;font-size:11.5px;cursor:pointer;padding:0}
.cmt .who button:hover{text-decoration:underline}
.cmt .tag{font-family:var(--disp);font-weight:700;font-size:10px;letter-spacing:.05em;text-transform:uppercase;border-radius:4px;padding:2px 6px}
.cmt .tag.suggestion{background:rgba(232,89,12,.12);color:var(--orange-deep)}
.cmt .tag.resolved{background:var(--green-soft);color:var(--green-deep)}
.cmt .tag.stale{background:#FEF3C7;color:#92400E}
.cmt.moved{border-style:dashed}
.post-body pre{background:#0f172a;color:#e2e8f0;border-radius:8px;padding:14px 16px;overflow:auto;font-size:14px;margin:18px 0}
.post-body pre code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.rail-empty{color:var(--gray);font-size:13.5px;border:1px dashed var(--line);border-radius:10px;padding:18px;text-align:center}

/* toolbar above article */
.post-tools{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:0 0 20px}
.post-tools .grow{flex:1}
.verdict-live{font-size:12.5px;color:var(--green-deep);font-weight:700}

/* composer sheet */
.scrim2{position:fixed;inset:0;background:rgba(17,17,17,.5);backdrop-filter:blur(3px);display:grid;place-items:end center;z-index:60;
  opacity:0;pointer-events:none;transition:opacity .2s var(--ease)}
.scrim2.in{opacity:1;pointer-events:auto}
.sheet{width:100%;max-width:560px;background:var(--paper);border-radius:16px 16px 0 0;padding:22px 22px 26px;
  transform:translateY(20px);transition:transform .22s var(--ease);margin-bottom:0}
.scrim2.in .sheet{transform:none}
@media(min-width:640px){.scrim2{place-items:center}.sheet{border-radius:16px;margin-bottom:0}}
.sheet h4{font-family:var(--disp);font-weight:800;font-size:18px;margin:0 0 4px}
.sheet .q{font-size:13px;color:var(--gray);border-left:2px solid var(--gold);padding-left:10px;margin:8px 0 14px}
.sheet textarea{width:100%;min-height:88px;resize:vertical;font:inherit;font-size:14.5px;padding:12px 14px;border:1px solid var(--line);border-radius:10px}
.sheet textarea:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,89,12,.15)}
.sheet .opts{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0 4px;font-size:13px}
.sheet .opts label{display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.sheet .row{display:flex;gap:10px;margin-top:16px}
.sheet .row .btn{flex:1}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;
  font-family:var(--disp);font-weight:700;font-size:13.5px;padding:11px 18px;border-radius:10px;z-index:80;opacity:0;
  transition:all .2s var(--ease);pointer-events:none}
.toast.in{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- profile / keys ---------- */
.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px;padding:20px clamp(18px,4vw,40px) 70px;align-items:start}
.prof-card h3{font-family:var(--disp);font-weight:800;font-size:16px;letter-spacing:-.01em;margin:0 0 16px;text-transform:none;color:var(--ink)}
.prof-card.wide{grid-column:1 / -1}
.prof-msg{font-size:13.5px;font-weight:600;margin-top:12px;min-height:1em}
.prof-msg.ok{color:var(--green-deep)}
.prof-msg.err{color:var(--red)}
.keynew{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.keynew input{flex:1;min-width:220px;font:inherit;font-size:14.5px;padding:11px 14px;border:1px solid var(--line);border-radius:10px}
.keynew input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,89,12,.15)}
.keytable{width:100%;border-collapse:collapse;margin-top:8px;font-size:14px}
.keytable th,.keytable td{text-align:left;padding:10px 10px;border-bottom:1px solid var(--line)}
.keytable th{font-family:var(--disp);font-weight:700;font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--gray)}
.keytable tr.revoked{opacity:.55}
.keytable .revoke{color:var(--red);font-weight:700}
.keyreveal{background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin:6px 0 14px}
.keyreveal .kr-top{font-size:13.5px;color:var(--orange-deep);margin-bottom:10px}
.keyreveal .kr-key{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.keyreveal .kr-key code{flex:1;min-width:240px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px 12px;font-size:13px;word-break:break-all}
.keyreveal .kr-mcp{margin-top:12px;font-size:13px}
.keyreveal .kr-mcp summary{cursor:pointer;font-weight:700;color:var(--orange-deep)}
.keyreveal pre{background:#0f172a;color:#e2e8f0;border-radius:8px;padding:12px 14px;overflow:auto;font-size:12.5px;margin:10px 0 0}
