/* ============================================================================
   AI Safety Directory: lightweight directory. Fast, clean, no canvas/animations.
   ========================================================================== */
@font-face{font-family:'Inter';font-weight:400;font-display:swap;src:url('../assets/fonts/inter-400.woff2') format('woff2')}
@font-face{font-family:'Inter';font-weight:500;font-display:swap;src:url('../assets/fonts/inter-500.woff2') format('woff2')}
@font-face{font-family:'Inter';font-weight:600;font-display:swap;src:url('../assets/fonts/inter-600.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-weight:400;font-display:swap;src:url('../assets/fonts/fraunces-400.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-weight:500;font-display:swap;src:url('../assets/fonts/fraunces-500.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-weight:600;font-display:swap;src:url('../assets/fonts/fraunces-600.woff2') format('woff2')}

:root{
  /* warm identity - bone paper, ink, clay accent */
  --bg:#F4F1EA; --panel:#ffffff; --ink:#1A1814; --muted:#857C6E; --faint:#A99F8E;
  --line:#E4DFD3; --line2:#EDE9DF; --accent:#C97B5A; --accent-ink:#B26343; --accent-soft:#F5E7DE;
  --gold:#B26343; --ok:#1a8f5a; --warn:#c2410c;
  --radius:12px; --shadow:0 1px 2px rgba(40,30,20,.04), 0 8px 30px -16px rgba(40,30,20,.20);
  --font:'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --serif:'Fraunces', Georgia, 'Times New Roman', serif;
}
*{box-sizing:border-box}
[hidden]{display:none !important}
html,body{margin:0}
body{font-family:var(--font);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:var(--accent-ink);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:inherit;cursor:pointer}
.btn{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 14px;border-radius:9px;border:1px solid var(--line);background:var(--panel);color:var(--ink);font-size:13.5px;font-weight:500;transition:background .12s,border-color .12s}
.btn:hover{border-color:#cdd2da}
.btn.ghost{background:transparent}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent-ink)}
.link{background:none;border:none;color:var(--accent-ink);padding:0;font:inherit;text-decoration:underline;cursor:pointer}

/* topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 26px;background:var(--panel);border-bottom:1px solid var(--line);flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:14px;color:var(--ink)}
.logo-asr{display:flex;flex-direction:column;gap:5px;flex:none;padding-right:15px;border-right:1px solid var(--line)}
.logo-asr .lt{font-family:var(--serif);font-weight:600;font-size:24px;letter-spacing:1.5px;line-height:.78;color:var(--ink)}
.logo-asr .ln{height:3px;border-radius:2px;background:var(--accent)}
.bt h1{margin:0;font-family:var(--serif);font-size:19px;font-weight:600;letter-spacing:-.005em;display:flex;align-items:center;gap:8px;color:var(--ink)}
.beta{font-family:var(--font);font-size:9.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:var(--accent);padding:2px 6px;border-radius:6px}
.tag{margin:3px 0 0;font-size:12.5px;color:var(--muted)}
/* editorial serif for the headline moments */
.fh h2,.dhead h2,.modal-card h2,.detailpage h1,.pagewrap h1{font-family:var(--serif);font-weight:600}
.actions{display:flex;align-items:center;gap:8px}
.acct{display:inline-flex;align-items:center;gap:8px}
.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:37px;height:37px;border-radius:10px;border:1px solid var(--line);background:var(--panel);color:var(--ink);cursor:pointer;transition:border-color .12s,color .12s,background .12s}
.iconbtn:hover{border-color:var(--accent);color:var(--accent-ink)}
.iconbtn.on{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-soft)}
.iconbtn svg{width:18px;height:18px}

/* searchbar */
.searchbar{position:relative;max-width:760px;margin:22px auto 0;padding:0 26px;display:flex;align-items:center}
.searchbar .si{position:absolute;left:42px;width:18px;height:18px;color:var(--faint);pointer-events:none}
.searchbar input{width:100%;height:50px;padding:0 44px;border-radius:13px;border:1px solid var(--line);background:var(--panel);font-size:15.5px;color:var(--ink);box-shadow:var(--shadow);outline:none;transition:border-color .15s,box-shadow .15s}
.searchbar input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.searchbar input::placeholder{color:var(--faint)}
.qclear{position:absolute;right:40px;width:26px;height:26px;border-radius:50%;border:none;background:#ECE7DC;color:var(--muted);font-size:18px;line-height:1}
.qclear:hover{background:#E2DCCF}

/* tabs */
.tabs{display:flex;align-items:center;gap:4px;max-width:1180px;margin:18px auto 0;padding:0 26px}
.tab{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 14px;border:none;background:none;color:var(--muted);font-size:14px;font-weight:500;border-bottom:2px solid transparent;border-radius:0}
.tab:hover{color:var(--ink)}
.tab.on{color:var(--ink);border-bottom-color:var(--accent)}
.tab .c{font-size:11.5px;font-weight:600;color:var(--accent-ink);background:var(--accent-soft);border-radius:20px;padding:1px 7px}
.tabs .spacer{flex:1}
.sortwrap{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:7px}
.sortwrap select{height:32px;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--ink);font:inherit;font-size:13px;padding:0 8px}

/* layout */
.layout{max-width:1180px;margin:14px auto 40px;padding:0 26px;display:grid;grid-template-columns:236px 1fr;gap:24px;align-items:start}
@media(max-width:820px){.layout{grid-template-columns:1fr}.facets{position:static !important}}

/* facets */
.facets{position:sticky;top:14px;display:flex;flex-direction:column;gap:18px}
.facet h3{margin:0 0 9px;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);font-weight:600}
.facet .opts{display:flex;flex-direction:column;gap:1px}
.fopt{display:flex;align-items:center;gap:9px;padding:5px 8px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--ink);border:none;background:none;text-align:left;width:100%}
.fopt:hover{background:#EFEAE0}
.fopt.on{background:var(--accent-soft);color:var(--accent-ink);font-weight:500}
.fopt .dot{width:9px;height:9px;border-radius:50%;flex:none;background:var(--c,#cbd0d8)}
.fopt .fc{margin-left:auto;font-size:11px;color:var(--faint);font-variant-numeric:tabular-nums}
.fopt.on .fc{color:var(--accent-ink)}

/* meta + results */
.metarow{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.count{font-size:13px;color:var(--muted)}
.clearf{font-size:12.5px;color:var(--accent-ink);background:none;border:none;text-decoration:underline}
.results{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}

/* row (people/org) */
.row{display:grid;grid-template-columns:34px minmax(0,1fr) auto auto;gap:13px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line2);cursor:pointer;transition:background .1s}
.row .nmcell{min-width:0}
.row:last-child{border-bottom:none}
.row:hover{background:#FBF8F2}
.row .av{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:600;color:#fff;background:var(--av,#8a93a6)}
.av,.obadge,.dp-avatar{position:relative;overflow:hidden}
.avimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.row .nm{font-weight:600;font-size:14px;color:var(--ink)}
.row .sub{font-size:12px;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .org{font-size:13px;color:var(--ink);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .focus{display:flex;flex-wrap:wrap;gap:5px}
.row .loc{font-size:12.5px;color:var(--muted);white-space:nowrap}
.row .links{display:flex;gap:7px;color:var(--faint)}
.row .links a{display:inline-flex;color:var(--faint)}
.row .links a:hover{color:var(--accent-ink)}
.row .links svg{width:15px;height:15px}
.row .rfocus{display:flex;align-items:center;gap:6px;justify-content:flex-end}
.row .rfocus .chip{font-size:11px;padding:2px 9px;white-space:nowrap}
@media(max-width:860px){.row,.row.orgrow{grid-template-columns:34px minmax(0,1fr) auto}.row .rfocus{display:none}}
@media(max-width:720px){.row{grid-template-columns:30px 1fr auto}.row .org,.row .loc{display:none}}

/* focus chip */
.chip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:#3c4150;background:#f1f3f7;border:1px solid #e7eaf0;border-radius:20px;padding:2px 9px}
.chip .d{width:7px;height:7px;border-radius:50%;background:var(--c,#cbd0d8)}
.row .focus .chip{font-size:11px;padding:1px 8px}

/* org row variant */
.row.orgrow{grid-template-columns:34px minmax(0,1fr) auto auto}
.row .otype{display:inline-block;font-size:11px;color:var(--muted);text-transform:capitalize}
.row .obadge{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;font-weight:600;font-size:14px;color:#fff;background:var(--av,#5b647a)}

.more{padding:16px;text-align:center}
.more button{height:36px;padding:0 20px;border-radius:9px;border:1px solid var(--line);background:var(--panel);font-weight:500}
.more button:hover{border-color:#cdd2da}
.empty{padding:50px;text-align:center;color:var(--muted)}
.empty b{color:var(--ink)}
.tab .soon{font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);background:#f1f3f7;border-radius:20px;padding:1px 7px}
.placeholder{padding:64px 40px}
.placeholder .ph-ic{width:46px;height:46px;margin:0 auto 14px;color:var(--faint);opacity:.85}
.placeholder .ph-ic svg{width:46px;height:46px}
.placeholder b{display:block;font-size:18px;color:var(--ink);margin-bottom:8px}
.ph-tag{display:inline-block;font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-ink);background:var(--accent-soft);border-radius:20px;padding:2px 10px;margin-bottom:10px}
.ph-sub{font-size:13.5px;color:var(--muted)}

/* drawer */
.scrim{position:fixed;inset:0;background:rgba(20,24,40,.42);z-index:50;animation:fadein .15s ease}
@keyframes fadein{from{opacity:0}}
.drawer{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:min(440px,94vw);max-height:88vh;background:var(--panel);border-radius:16px;box-shadow:0 30px 80px -20px rgba(20,24,40,.5);z-index:51;overflow:auto;padding:0 24px 26px;animation:popin .2s cubic-bezier(.22,1,.36,1)}
@keyframes popin{from{opacity:0;transform:translate(-50%,-47%) scale(.97)}}
.drawer .dx{position:absolute;right:14px;top:14px;width:30px;height:30px;border-radius:8px;border:1px solid rgba(255,255,255,.45);background:rgba(255,255,255,.18);color:#fff;font-size:18px;z-index:2}
.drawer .dx:hover{background:rgba(255,255,255,.32)}
.dbanner{height:86px;margin:0 -24px 0;border-radius:16px 16px 0 0;background:radial-gradient(130% 150% at 12% -20%,rgba(255,255,255,.38),transparent 55%),linear-gradient(120deg,var(--av,#8a93a6),#2b3450)}
.dhead{display:block;margin-top:-40px;margin-bottom:2px}
.dhead .av{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;font-size:21px;font-weight:600;color:#fff;background:var(--av,#8a93a6);border:3px solid var(--panel);box-shadow:0 6px 16px -6px rgba(20,24,40,.45);margin-bottom:11px}
.dhead .av.sq{border-radius:16px}
.dh-t{min-width:0}
.dhead h2{margin:0;font-size:20px;font-weight:600;letter-spacing:-.01em;line-height:1.25}
.dhead .drole{font-size:13px;color:var(--muted);margin-top:3px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.dloc{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--muted);margin-top:5px}
.dloc svg{width:14px;height:14px;color:var(--faint);flex:none}
.dsec{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);font-weight:600;margin:20px 0 9px}
.dchips{display:flex;flex-wrap:wrap;gap:6px}
.dblurb{font-size:14px;color:#33394a;line-height:1.6}
.dlinks{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.dlinks a{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 13px;border-radius:9px;border:1px solid var(--line);font-size:12.5px;color:var(--ink);text-transform:capitalize;background:var(--panel)}
.dlinks a:hover{border-color:var(--accent);color:var(--accent-ink);text-decoration:none;background:var(--accent-soft)}
.dlinks a svg{width:14px;height:14px}
.dsource{margin-top:22px;padding-top:16px;border-top:1px solid var(--line2);font-size:12px;color:var(--muted)}
.dsource a{word-break:break-all}
.dactions{display:flex;gap:8px;margin-top:16px}

/* footer */
.foot{max-width:1180px;margin:20px auto 40px;padding:20px 26px;border-top:1px solid var(--line);color:var(--muted);font-size:12.5px;display:flex;flex-direction:column;gap:8px}
.foot strong{color:var(--ink)}
.foot-meta{color:var(--faint)}

/* modal */
.modal{position:fixed;inset:0;z-index:50;display:grid;place-items:center}
.modal[hidden]{display:none}
.modal-back{position:absolute;inset:0;background:rgba(20,24,40,.4)}
.modal-card{position:relative;width:min(480px,94vw);background:var(--panel);border-radius:16px;box-shadow:0 30px 70px -25px rgba(20,24,40,.5);padding:26px}
.modal-x{position:absolute;right:16px;top:14px;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:var(--panel);color:var(--muted);font-size:18px}
.modal-card h2{margin:0 0 6px;font-size:19px}
.modal-sub{margin:0 0 18px;font-size:13px;color:var(--muted)}
#fbForm{display:flex;flex-direction:column;gap:14px}
#fbForm label{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--muted);font-weight:500}
.opt{color:var(--faint);font-weight:400}
#fbForm select,#fbForm input,#fbForm textarea{font-family:inherit;font-size:14px;color:var(--ink);border:1px solid var(--line);border-radius:9px;padding:10px 12px;background:var(--panel);outline:none}
#fbForm select:focus,#fbForm input:focus,#fbForm textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
#fbForm textarea{resize:vertical}
.fb-actions{display:flex;align-items:center;justify-content:flex-end;gap:14px;margin-top:4px}
.fb-status{font-size:12.5px;margin-right:auto}
.fb-status.ok{color:var(--ok)}
.fb-status.err{color:var(--warn)}

/* feedback redesign */
.fb-card{padding:24px}
.fb-head{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}
.fb-ico{flex:none;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-ink)}
.fb-ico svg{width:21px;height:21px}
.fb-head h2{margin:0;font-size:19px}
.fb-head .modal-sub{margin:4px 0 0}
.fb-field{display:flex;flex-direction:column;gap:7px}
.fb-label{font-size:12.5px;color:var(--muted);font-weight:500}
.seg{display:flex;gap:6px;flex-wrap:wrap}
.seg-b{flex:1 1 72px;height:34px;padding:0 10px;border:1px solid var(--line);border-radius:9px;background:var(--panel);color:var(--muted);font-size:13px;font-weight:500;transition:background .12s,border-color .12s,color .12s}
.seg-b:hover{border-color:#cdd2da;color:var(--ink)}
.seg-b.on{background:var(--accent-soft);border-color:#c5cef7;color:var(--accent-ink)}

/* roaming feedback button */
.fab{position:fixed;right:22px;bottom:22px;z-index:45;display:inline-flex;align-items:center;gap:9px;height:48px;padding:0 20px 0 17px;border:none;border-radius:26px;background:var(--accent);color:#fff;font-family:inherit;font-size:14px;font-weight:600;box-shadow:0 8px 24px -6px rgba(58,91,217,.5),0 2px 6px rgba(20,24,40,.16);transition:transform .14s,box-shadow .14s,background .14s}
.fab:hover{background:var(--accent-ink);transform:translateY(-2px);box-shadow:0 13px 30px -6px rgba(58,91,217,.6),0 2px 6px rgba(20,24,40,.18)}
.fab:active{transform:translateY(0)}
.fab svg{width:19px;height:19px}
@media(max-width:560px){.fab{right:16px;bottom:16px;padding:0;width:52px;height:52px;justify-content:center;border-radius:50%}.fab span{display:none}}

/* ---- Finder / matcher (primary directory search + AI match) ---- */
.finder{max-width:940px;margin:22px auto 0;padding:20px 22px;background:linear-gradient(180deg,#fffdf8,#f6f1e7);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
.finder-head{display:flex;gap:13px;align-items:flex-start;margin-bottom:15px}
.finder-ic{width:40px;height:40px;border-radius:12px;background:var(--accent-soft);color:var(--accent-ink);display:grid;place-items:center;flex:none}
.finder-ic svg{width:21px;height:21px}
.finder-ht h2{margin:0;font-family:var(--serif);font-size:20px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.finder-ht p{margin:4px 0 0;font-size:13px;color:var(--muted);line-height:1.55;max-width:760px}
.finder-ht p strong{color:var(--accent-ink);font-weight:600}
.finder-box{display:flex;gap:11px;align-items:stretch}
.finder-box textarea{flex:1;resize:vertical;min-height:52px;border:1px solid var(--line);border-radius:12px;padding:13px 15px;font-family:inherit;font-size:14.5px;line-height:1.5;color:var(--ink);outline:none;background:var(--panel)}
.finder-box textarea::placeholder{color:var(--faint)}
.finder-box textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.finder-box .btn{align-self:stretch;min-height:52px;padding:0 26px;white-space:nowrap;font-size:14.5px;font-weight:600}
@media(max-width:560px){.finder-box{flex-direction:column}.finder-box .btn{min-height:46px}}

.findbanner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:var(--accent-soft);border-bottom:1px solid var(--line2);font-size:13px;color:var(--ink)}
.findbanner em{color:var(--muted);font-style:italic}
.row.findrow{grid-template-columns:30px 1.7fr 1.3fr 1.2fr 92px}
.row .why{font-size:12px;color:var(--muted)}
.row .fit{display:flex;align-items:center}
.row .fit .bar{display:block;width:84px;height:6px;border-radius:4px;background:#eef0f4;overflow:hidden}
.row .fit .bar span{display:block;height:100%;background:linear-gradient(90deg,var(--accent-ink),var(--accent));border-radius:4px}
@media(max-width:720px){.row.findrow{grid-template-columns:30px 1fr 70px}.row .why,.row.findrow .focus{display:none}}

/* ---- API docs / login modal ---- */
.api-ep{display:flex;align-items:center;gap:10px;margin:8px 0;font-size:13px}
.api-ep .m{font-size:10px;font-weight:700;color:#fff;background:var(--ok);padding:2px 6px;border-radius:5px}
.api-ep code{background:#f1f3f7;padding:3px 7px;border-radius:6px;font-size:12.5px;font-family:ui-monospace,Menlo,monospace}
.api-pre{background:#1a1d29;color:#dfe3ec;padding:12px 14px;border-radius:10px;font-family:ui-monospace,Menlo,monospace;font-size:12px;overflow:auto;line-height:1.5;margin:0}
.modal-card .dsec{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);font-weight:600;margin:16px 0 8px}
.modal-card code{font-family:ui-monospace,Menlo,monospace;background:#f1f3f7;padding:1px 5px;border-radius:5px;font-size:12.5px}
#infoCard{position:relative}
#loginForm label{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--muted);font-weight:500;margin-bottom:14px}
#loginForm input{font-family:inherit;font-size:14px;border:1px solid var(--line);border-radius:9px;padding:10px 12px;outline:none}
#loginForm input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.modal-sub em{font-style:italic;color:var(--faint)}

/* ============================ accounts · profiles · posts ============================ */
.acct{display:inline-flex;gap:6px}
.brand{user-select:none}

/* sub-pages */
.page{max-width:760px;margin:24px auto 60px;padding:0 26px}
.pagewrap h1{font-size:24px;font-weight:600;letter-spacing:-.01em;margin:6px 0 6px}
.backlink{background:none;border:none;color:var(--accent-ink);font:inherit;font-size:13.5px;padding:6px 0;cursor:pointer;margin-bottom:6px}
.backlink:hover{text-decoration:underline}
.detailpage .pc-type{margin-bottom:10px}
.dp-meta{font-size:13.5px;color:var(--muted)}

/* projects/jobs lists */
.posthead{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 16px;border-bottom:1px solid var(--line2)}
.posthead .count{font-size:13px;color:var(--muted)}
.postcard{padding:14px 16px;border-bottom:1px solid var(--line2);cursor:pointer;transition:background .1s}
.postcard:last-child{border-bottom:none}
.postcard:hover{background:#FBF8F2}
.pc-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.pc-type{display:inline-block;font-size:11px;font-weight:600;color:var(--accent-ink);background:var(--accent-soft);border-radius:20px;padding:2px 10px}
.pc-author{font-size:12px;color:var(--faint)}
.pc-title{font-weight:600;font-size:15px;color:var(--ink);margin:8px 0 3px}
.pc-sum{font-size:13px;color:var(--muted);line-height:1.5}
.pc-meta{font-size:12.5px;color:var(--muted);margin-top:2px}
.pc-focus{display:flex;flex-wrap:wrap;gap:5px;margin-top:9px}

/* drawer: looking-for + claimed */
.dlooking{font-size:14px;color:#246b45;background:#eef7f1;border:1px solid #d3e9da;border-radius:10px;padding:11px 13px;line-height:1.55}
.claimed-badge{display:inline-flex;align-items:center;height:36px;font-size:13px;color:var(--ok);font-weight:600}
.vmark{font-size:14px;color:var(--ok);vertical-align:middle}

/* forms (account + info-modal forms) */
.bigform label,#infoCard form label{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;font-size:12.5px;color:var(--muted);font-weight:500;min-width:0}
.bigform input,.bigform textarea,.bigform select,#infoCard form input,#infoCard form textarea,#infoCard form select{width:100%;min-width:0;font-family:inherit;font-size:14px;color:var(--ink);border:1px solid var(--line);border-radius:9px;padding:10px 12px;background:var(--panel);outline:none}
.bigform input:focus,.bigform textarea:focus,.bigform select:focus,#infoCard form input:focus,#infoCard form textarea:focus,#infoCard form select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.bigform textarea,#infoCard form textarea{resize:vertical}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
@media(max-width:560px){.formgrid{grid-template-columns:1fr}}
/* redesigned wizard forms (collaborate / support) */
#infoCard form.wform{margin-top:2px}
.stepbar{display:flex;align-items:center;gap:12px;margin:6px 0 20px}
.stepbar .sb{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--faint)}
.stepbar .sb i{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-style:normal;font-size:12px;background:#ECE7DC;color:var(--muted)}
.stepbar .sb.on{color:var(--ink)}
.stepbar .sb.on i{background:var(--accent);color:#fff}
.optsel{display:flex;flex-direction:column;gap:9px;margin-bottom:6px}
.optcard{display:flex;align-items:center;gap:12px;width:100%;text-align:left;font:inherit;color:var(--ink);background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:13px 14px;cursor:pointer;transition:border-color .12s,background .12s}
.optcard:hover{border-color:#cdb8ac}
.optcard.on{border-color:var(--accent);background:var(--accent-soft)}
.optcard .oc-check{width:20px;height:20px;border-radius:6px;border:1.6px solid var(--line);flex:none;display:grid;place-items:center;color:#fff;font-size:12px;line-height:1;background:transparent}
.optcard .oc-check.oc-radio{border-radius:50%}
.optcard.on .oc-check{background:var(--accent);border-color:var(--accent)}
.optcard .oc-x{display:flex;flex-direction:column;gap:2px;min-width:0}
.optcard .oc-t{font-weight:600;font-size:13.5px;color:var(--ink)}
.optcard .oc-d{font-size:12px;color:var(--muted)}
.wform .attachrow{display:flex;align-items:center;gap:10px}
.wform .wiznav{display:flex;align-items:center;justify-content:space-between;margin-top:8px}
.checkrow{flex-direction:row !important;align-items:center;gap:9px;color:var(--ink) !important;font-weight:400 !important}
.checkrow input{width:16px;height:16px}

/* admin: claim moderation */
.cc-section{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);font-weight:600;margin:22px 0 10px}
.claimcard{border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin-bottom:12px;background:var(--panel)}
.cc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.cc-name{font-weight:600;font-size:15px;color:var(--ink)}
.cc-email{font-size:13px}
.cc-status{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:20px;padding:2px 9px;white-space:nowrap}
.cc-pending{color:var(--warn);background:#fdf0e6}
.cc-verified{color:var(--ok);background:#e7f5ee}
.cc-rejected{color:#9aa1ae;background:#f1f3f7}
.cc-msg{margin-top:10px;font-size:14px;color:#33394a;background:#f7f8fa;border:1px solid #eef0f3;border-radius:9px;padding:10px 12px;line-height:1.5}
.cc-profile{margin-top:10px;border:1px solid var(--line);border-radius:10px;padding:11px 13px;background:#faf8f3}
.cc-pf-h{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--faint);font-weight:600;margin-bottom:8px}
.cc-profile .pf-row{display:flex;gap:8px;font-size:13px;margin:4px 0}
.cc-profile .pf-row .k{color:var(--muted);width:96px;flex:none}
.cc-nomatch{color:var(--muted);font-size:13px;line-height:1.5}
.cc-effect{margin-top:9px;font-size:12.5px;color:#7a4631;line-height:1.55;background:var(--accent-soft);border:1px solid #ecd5c8;border-radius:9px;padding:9px 11px}
.cc-meta{margin-top:9px;font-size:12px;color:var(--faint)}
.cc-actions{margin-top:13px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}

/* profile photo + wizard + detail polish */
.ac-photo{display:flex;align-items:center;gap:18px;margin-bottom:20px;padding:16px;border:1px solid var(--line);border-radius:13px;background:#FBF8F2}
.ac-av{width:76px;height:76px;border-radius:50%;position:relative;overflow:hidden;background:#8a93a6;display:grid;place-items:center;color:#fff;font-weight:600;font-size:24px;flex:none;border:2px solid var(--panel);box-shadow:0 4px 12px -5px rgba(20,24,40,.4)}
.ac-photo-r{display:flex;flex-direction:column;gap:8px}
.bigform label.ac-uploadbtn{flex-direction:row;align-items:center;gap:7px;align-self:flex-start;width:auto;height:38px;margin:0;cursor:pointer}
.ac-uploadbtn svg{width:16px;height:16px;flex:none}
.ac-photo-r .opt{margin:0}
.wizsteps{display:flex;align-items:center;gap:10px;margin:2px 0 18px}
.ws{font-size:12px;font-weight:600;color:var(--faint);background:#f1f3f7;border-radius:20px;padding:4px 11px}
.ws.on{color:var(--accent-ink);background:var(--accent-soft)}
.ws-line{flex:1;height:1px;background:var(--line)}
.wiznav{display:flex;align-items:center;justify-content:space-between;margin-top:6px}
.attachrow{display:flex;align-items:center;gap:10px}
.detailpage .dp-hero{padding:20px 22px 18px;background:var(--panel);border:1px solid var(--line);border-radius:14px;margin-top:4px}
.dp-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.dp-head-l{min-width:0}
.dp-kind{display:inline-block;font-size:11px;font-weight:600;color:var(--accent-ink);background:var(--accent-soft);border-radius:20px;padding:3px 11px;margin-bottom:12px}
.detailpage h1{font-size:26px;margin:0 0 8px}
.dp-byline{font-size:13.5px;color:var(--muted)}
.dp-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.dp-focus{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.dp-chip{font-size:12.5px;color:#33394a;background:#f1f3f7;border:1px solid #e7eaf0;border-radius:20px;padding:3px 11px}
.dp-avatar{width:52px;height:52px;border-radius:50%;background:var(--av,#8a93a6);color:#fff;display:grid;place-items:center;font-weight:600;font-size:17px;flex:none;border:2px solid var(--line);box-shadow:0 3px 10px -4px rgba(20,24,40,.25)}
.dp-avatar.clickable{cursor:pointer;transition:transform .1s,box-shadow .1s}
.dp-avatar.clickable:hover{transform:translateY(-1px);box-shadow:0 5px 14px -4px rgba(40,30,20,.4)}
.dp-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}
.btn.danger{background:#fff;border-color:#e3b9ab;color:#b23a2a}
.btn.danger:hover{background:#fbeee9;border-color:#d99a86}
.prose{font-size:14.5px;line-height:1.62;color:#3a342c;max-width:680px}
.prose ul{margin:6px 0 4px;padding-left:20px}
.prose li{margin:5px 0}
.prose p{margin:8px 0}
.prose .lead{font-size:16px;color:var(--ink);margin:4px 0 10px}
.prose code{background:#f1f3f7;padding:2px 6px;border-radius:5px;font-family:ui-monospace,Menlo,monospace;font-size:12.5px}
.prose .api-pre{margin:8px 0 12px}
.cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:14px 0 6px}
@media(max-width:620px){.cards{grid-template-columns:1fr}}
.card{display:block;text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;cursor:pointer;transition:border-color .12s,box-shadow .12s,transform .1s;font:inherit;color:var(--ink)}
.card:hover{border-color:var(--accent);box-shadow:0 8px 20px -12px rgba(40,30,20,.35);transform:translateY(-1px)}
.card .ic{font-size:20px;display:block}
.card h3{font-family:var(--serif);font-size:16px;font-weight:600;margin:9px 0 4px}
.card p{font-size:13px;color:var(--muted);margin:0;line-height:1.5}
.goals,.nongoals{padding-left:20px}
.goals li{margin:7px 0}
.nongoals li{margin:7px 0;color:var(--muted)}
.foot-meta{display:flex;align-items:center;gap:14px}
.dedupe-hint{background:var(--accent-soft);border:1px solid #ecd5c8;border-radius:9px;padding:9px 11px;font-size:12.5px;color:#7a4631;line-height:1.5;margin:-2px 0 2px}
.dp-cta{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.dp-body{font-size:15px;line-height:1.65;color:#33394a;white-space:pre-wrap;margin-bottom:8px}
@media(max-width:560px){.detailpage .dp-hero{padding:16px}.detailpage h1{font-size:21px}.dp-avatar{width:42px;height:42px;font-size:14px}}

/* post chips, rich editor, redesigned cards */
.chipsel{display:flex;flex-wrap:wrap;gap:7px}
.chipopt{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink);background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:5px 12px;cursor:pointer}
.chipopt:hover{border-color:#cdd2da}
.chipopt.on{background:var(--accent-soft);border-color:#c5cef7;color:var(--accent-ink);font-weight:500}
.chipopt .cdot{width:8px;height:8px;border-radius:50%}
.rte{border:1px solid var(--line);border-radius:10px;overflow:hidden}
.rte-bar{display:flex;gap:2px;padding:6px;border-bottom:1px solid var(--line2);background:#fafbfc}
.rte-bar button{height:30px;min-width:32px;padding:0 9px;border:none;background:none;border-radius:7px;font-size:13px;color:var(--ink);cursor:pointer}
.rte-bar button:hover{background:#EFEAE0}
.rte-body{min-height:120px;max-height:280px;overflow:auto;padding:11px 13px;font-size:14px;line-height:1.6;color:var(--ink);outline:none}
.rte-body:empty:before{content:attr(data-ph);color:var(--faint)}
.rte-body h3{font-size:15px;margin:10px 0 4px}.rte-body ul,.rte-body ol{margin:6px 0 6px 22px}
.postcard{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.pc-main{min-width:0;flex:1}
.pc-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pc-stipend{font-size:11.5px;font-weight:600;color:#246b45;background:#eef7f1;border:1px solid #d3e9da;border-radius:20px;padding:1px 9px}
.pc-av{width:40px;height:40px;border-radius:50%;background:var(--av,#8a93a6);color:#fff;display:grid;place-items:center;font-weight:600;font-size:14px;flex:none}
.rich h2,.rich h3{font-size:17px;font-weight:600;margin:16px 0 6px;color:var(--ink)}
.rich ul,.rich ol{margin:8px 0 8px 22px}.rich li{margin:3px 0}
.rich a{color:var(--accent-ink);text-decoration:underline}.rich p{margin:0 0 10px}

.pc-loc{font-size:11.5px;color:var(--muted);background:#f1f3f7;border:1px solid #e7eaf0;border-radius:20px;padding:1px 9px}

/* ===== rich profile page (/person/:name) ===== */
.personpage{max-width:760px}
.pp-header{background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:18px}
.pp-banner{height:96px;background:radial-gradient(130% 150% at 12% -20%,rgba(255,255,255,.38),transparent 55%),linear-gradient(120deg,var(--av,#8a93a6),#2b3450)}
.pp-id{display:flex;align-items:flex-start;gap:16px;padding:16px 22px}
.pp-av{position:relative;width:78px;height:78px;border-radius:50%;display:grid;place-items:center;font-size:26px;font-weight:600;color:#fff;background:var(--av,#8a93a6);border:3px solid var(--panel);box-shadow:0 6px 16px -6px rgba(20,24,40,.45);flex:none;overflow:hidden;margin-top:-52px}
.pp-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.pp-meta{flex:1;min-width:0;padding-bottom:2px}
.pp-meta h1{margin:0;font-family:var(--serif);font-size:23px;font-weight:600;letter-spacing:-.01em;line-height:1.2}
.pp-role{font-size:14px;color:var(--muted);margin-top:3px}
.pp-loc{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--muted);margin-top:5px}
.pp-loc svg{width:14px;height:14px;color:var(--faint);flex:none}
.pp-links{margin-top:12px}
.pp-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;flex:none;padding-bottom:2px}
.pp-looking{margin:0 22px 18px;padding:11px 14px;background:var(--accent-soft);border-radius:10px;font-size:13.5px;color:var(--ink)}
.pp-looking-l{font-weight:600;color:var(--accent-ink);margin-right:6px}
.pp-tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:18px;flex-wrap:wrap}
.pp-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font:inherit;font-size:14px;font-weight:500;padding:9px 12px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;margin-bottom:-1px}
.pp-tab:hover{color:var(--ink)}
.pp-tab.on{color:var(--ink);border-bottom-color:var(--accent)}
.pp-tabn{font-size:11.5px;font-weight:600;color:var(--accent-ink);background:var(--accent-soft);border-radius:20px;padding:1px 7px}
.pp-body{min-height:120px}
.pp-prose{font-size:14.5px;line-height:1.65;color:var(--ink);white-space:normal}
.pp-sec{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);font-weight:600;margin:20px 0 9px}
.pp-empty{padding:26px 20px;text-align:center;color:var(--muted);font-size:13.5px;background:var(--panel);border:1px dashed var(--line);border-radius:12px}
.pp-source{margin-top:26px}
/* papers */
.pp-scholar{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--accent-ink);margin-bottom:14px}
.pp-scholar svg{width:16px;height:16px}
.papers{display:flex;flex-direction:column;gap:10px}
.papercard{display:block;padding:13px 15px;border:1px solid var(--line);border-radius:11px;background:var(--panel);transition:border-color .12s,background .12s}
.papercard:hover{border-color:var(--accent);background:#FBF8F2}
.pap-t{font-size:14px;font-weight:600;color:var(--ink);line-height:1.4}
.pap-go{color:var(--faint);font-weight:400}
.pap-d{font-size:12.5px;color:var(--muted);margin-top:4px}
.pp-projects{display:flex;flex-direction:column;gap:0;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--panel)}
/* fund my research */
.fund-goal{font-size:14px;color:var(--ink);margin:16px 0 4px}
.fund-btn{margin-top:16px}
/* profile builder: papers manager */
.pap-import{display:flex;gap:8px}
.pap-import input{flex:1;min-width:0;font-family:inherit;font-size:14px;color:var(--ink);border:1px solid var(--line);border-radius:9px;padding:10px 12px;background:var(--panel);outline:none}
.pap-import input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.pap-import .btn{flex:none}
#ac_papers{display:flex;flex-direction:column;gap:8px;margin:4px 0 10px}
.paprow{display:grid;grid-template-columns:1.4fr 1fr 1.1fr auto;gap:8px;align-items:center}
.paprow input{width:100%;min-width:0;font-family:inherit;font-size:13px;color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:8px 10px;background:var(--panel);outline:none}
.paprow input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.pap-del{width:30px;height:30px;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--muted);font-size:18px;line-height:1;cursor:pointer;flex:none}
.pap-del:hover{border-color:var(--accent);color:var(--accent-ink)}
@media(max-width:600px){.pp-id{flex-wrap:wrap}.pp-actions{width:100%}.paprow{grid-template-columns:1fr auto}.paprow .pap-desc{grid-column:1 / -1}}

.ac-tabs{margin-top:22px}
.personpage .pp-body .pp-panel label{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}

/* fund-my-research: viewer cards + editor rows */
.fundlist{display:flex;flex-direction:column;gap:14px}
.fundcard{padding:16px 18px;border:1px solid var(--line);border-radius:13px;background:var(--panel);box-shadow:var(--shadow)}
.fund-t{font-family:var(--serif);font-size:17px;font-weight:600;color:var(--ink);margin-bottom:7px}
.fundcard .fund-btn{margin-top:14px}
.fundrow{padding:14px;border:1px solid var(--line);border-radius:12px;background:#FBF8F2;margin-bottom:12px;display:flex;flex-direction:column;gap:9px}
.fundrow-top{display:flex;gap:8px;align-items:center}
.fundrow-top .fund-title{flex:1;min-width:0;font-family:inherit;font-size:14px;font-weight:600;color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:9px 11px;background:var(--panel);outline:none}
.fundrow .fund-pitch{width:100%;font-family:inherit;font-size:13.5px;color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:9px 11px;background:var(--panel);outline:none;resize:vertical}
.fundrow .fund-link,.fundrow .fund-goal{width:100%;min-width:0;font-family:inherit;font-size:13px;color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:8px 10px;background:var(--panel);outline:none}
.fundrow input:focus,.fundrow textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* profile header: icon-only contact links */
.pp-links{gap:9px}
.pp-links a{width:40px;height:40px;padding:0;justify-content:center;border-radius:10px}
.pp-links a svg{width:18px;height:18px}

/* activity badge (display-only) */
.actb{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.02em;padding:1px 7px;border-radius:20px;vertical-align:middle;margin-left:6px;line-height:1.5}
.actb.on{background:#e4f5ec;color:#1a8f5a}
.actb.on::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:#1a8f5a;margin-right:5px;vertical-align:middle}
.actb.idle{background:#eef0f3;color:#6b7280}
.actb.off{background:transparent;color:var(--faint);border:1px solid var(--line);font-weight:500}
/* AI match results */
.matchrow{display:grid;grid-template-columns:40px minmax(0,1fr) 88px auto;gap:14px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line2);cursor:pointer;transition:background .1s}
.matchrow:last-child{border-bottom:none}
.matchrow:hover{background:#FBF8F2}
.matchrow .av{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-size:14px;font-weight:600;color:#fff;background:var(--av,#8a93a6)}
.mr-id{min-width:0}
.mr-id .nm{font-weight:600;font-size:14.5px;color:var(--ink)}
.mr-id .sub{font-size:12.5px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mr-focus{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px}
.mr-score{text-align:center}
.mr-pct{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--accent-ink);line-height:1}
.mr-pct span{font-size:11px;color:var(--faint);margin-left:1px}
.mr-bar{display:block;height:5px;border-radius:3px;background:#ECE7DC;margin-top:5px;overflow:hidden}
.mr-bar span{display:block;height:100%;background:var(--accent);border-radius:3px}
.mr-actions{display:flex;flex-direction:column;gap:6px;align-items:stretch}
.mr-actions .btn{height:32px;padding:0 12px;font-size:12.5px;white-space:nowrap}
@media(max-width:600px){.matchrow{grid-template-columns:40px minmax(0,1fr) auto}.mr-score{display:none}.mr-actions{flex-direction:row}}

/* match-mode tag + invite templates */
.match-mode{display:inline-block;font-size:11px;font-weight:600;padding:1px 8px;border-radius:20px;margin-left:8px;vertical-align:middle}
.match-mode.ai{background:#e4f5ec;color:#1a8f5a}
.match-mode.kw{background:#fbeee6;color:var(--accent-ink)}
.tmpl-row{display:flex;flex-wrap:wrap;gap:7px}
.tmpl-chip{height:30px;padding:0 13px;border-radius:20px;border:1px solid var(--line);background:var(--panel);font:inherit;font-size:12.5px;color:var(--muted);cursor:pointer}
.tmpl-chip:hover{border-color:var(--accent)}
.tmpl-chip.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-ink);font-weight:600}

/* manual list-search (inside a section sub-page) */
.listsearch{position:relative;display:flex;align-items:center;margin-bottom:16px}
.listsearch .si{position:absolute;left:14px;width:17px;height:17px;color:var(--faint);pointer-events:none}
.listsearch input{width:100%;height:46px;padding:0 42px;border-radius:12px;border:1px solid var(--line);background:var(--panel);font-size:14.5px;color:var(--ink);outline:none;box-shadow:var(--shadow)}
.listsearch input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.listsearch .qclear{position:absolute;right:12px;left:auto}

/* Manual search tab (distinct from the entity tabs) */
.tab-manual{border:1px solid var(--line);border-radius:9px;height:32px;padding:0 13px;background:var(--panel);color:var(--accent-ink);font-weight:600;border-bottom:1px solid var(--line)}
.tab-manual:hover{background:var(--accent-soft);border-color:var(--accent);border-bottom-color:var(--accent)}
.tab-manual.on{background:var(--accent-soft);border-color:var(--accent);border-bottom-color:var(--accent);color:var(--accent-ink)}

/* manual-search advanced filter panel (full width; replaces the sidebar on /search) */
.manualfilters{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:16px 18px;margin-bottom:16px;display:flex;flex-direction:column;gap:14px}
.mf-group{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px}
.mf-title{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);font-weight:600;width:130px;flex:none;padding-top:5px}
.mf-chips{display:flex;flex-wrap:wrap;gap:7px;flex:1;min-width:0}
.mf-chip{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border-radius:20px;border:1px solid var(--line);background:var(--panel);font:inherit;font-size:12.5px;color:var(--ink);cursor:pointer;transition:border-color .12s,background .12s}
.mf-chip:hover{border-color:var(--accent)}
.mf-chip.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-ink);font-weight:600}
.mf-chip .mf-n{font-size:11px;color:var(--faint);font-variant-numeric:tabular-nums}
.mf-chip.on .mf-n{color:var(--accent-ink)}
@media(max-width:700px){.mf-title{width:100%}}
/* on the manual page the content spans full width (sidebar hidden) */
.layout:has(#manualfilters:not([hidden])){grid-template-columns:1fr}

/* wider invite modal + scroll within instead of touching screen edges */
.modal-card{max-height:90vh;overflow:auto}
.modal-card.wide{width:min(640px,94vw)}

/* admin page */
.adstats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:8px 0 10px}
.adstat{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow)}
.adstat .adn{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--ink)}
.adstat .adl{font-size:12px;color:var(--muted);margin-top:2px}
.adh{font-family:var(--serif);font-size:18px;font-weight:600;margin:8px 0 4px;color:var(--ink)}
.adtabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin:8px 0 12px;flex-wrap:wrap}
.adtab{background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font:inherit;font-size:13.5px;font-weight:500;padding:8px 12px;cursor:pointer;margin-bottom:-1px}
.adtab:hover{color:var(--ink)}
.adtab.on{color:var(--ink);border-bottom-color:var(--accent)}
.adsearch{width:100%;height:42px;border:1px solid var(--line);border-radius:11px;padding:0 14px;font:inherit;font-size:14px;color:var(--ink);background:var(--panel);outline:none;margin-bottom:12px}
.adsearch:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.adlist{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.adrow{display:flex;align-items:center;gap:12px;padding:11px 14px;border-bottom:1px solid var(--line2)}
.adrow:last-child{border-bottom:none}
.adav{width:34px;height:34px;border-radius:50%;flex:none;display:grid;place-items:center;font-size:12px;font-weight:600;color:#fff;background:var(--av,#8a93a6);position:relative;overflow:hidden}
.adinfo{flex:1;min-width:0}
.adname{font-weight:600;font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adsub{font-size:12.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adremove{flex:none;height:32px;padding:0 13px;font-size:12.5px;color:var(--warn);border-color:var(--line)}
.adremove:hover{border-color:var(--warn);background:#fdf3ee}
@media(max-width:700px){.adstats{grid-template-columns:repeat(2,1fr)}}

/* ===== admin dashboard (sidebar + cards + tables) ===== */
.page:has(.admin2){max-width:min(1640px,96vw)}
.admin2{display:grid;grid-template-columns:204px 1fr;gap:26px;align-items:start}
.adside{display:flex;flex-direction:column;gap:2px;position:sticky;top:14px}
.adside .backlink{margin:0 0 10px}
.adside-t{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);margin:2px 8px 8px}
.adnav{display:flex;align-items:center;gap:9px;text-align:left;background:none;border:none;border-radius:9px;padding:9px 11px;font:inherit;font-size:13.5px;color:var(--muted);cursor:pointer}
.adnav:hover{background:#EFEAE0;color:var(--ink)}
.adnav.on{background:var(--accent-soft);color:var(--accent-ink);font-weight:600}
.adic{width:16px;text-align:center;opacity:.85;font-size:12px}
.admain{min-width:0}
.adhead{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.adhead h2{font-family:var(--serif);font-size:22px;font-weight:600;margin:0;color:var(--ink)}
.adcount{font-size:12.5px;font-weight:600;color:var(--accent-ink);background:var(--accent-soft);border-radius:20px;padding:2px 10px;margin-left:6px}
.adhead .adsearch{width:auto;flex:1;max-width:320px;margin:0;height:40px}
.adcards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.adcard{text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px;cursor:pointer;box-shadow:var(--shadow);transition:border-color .12s,transform .08s}
.adcard:hover{border-color:var(--accent);transform:translateY(-1px)}
.adcard-n{font-family:var(--serif);font-size:27px;font-weight:600;color:var(--ink);line-height:1}
.adcard-l{font-size:12.5px;color:var(--muted);margin-top:6px}
.adcard.good .adcard-n{color:var(--ok)}
.adcard.alert{border-color:var(--accent);background:var(--accent-soft)}
.adcard.alert .adcard-n{color:var(--accent-ink)}
.adpanel{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:6px 12px 10px}
.adpanel-h{display:flex;justify-content:space-between;align-items:center;padding:12px 4px 8px}
.adpanel-h h3{font-size:14px;margin:0;color:var(--ink)}
.adrecent{display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:none;border:none;border-top:1px solid var(--line2);padding:10px 4px;cursor:pointer}
.adrecent:hover{background:#FBF8F2}
.adav.sm{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:600;color:#fff;background:var(--av,#8a93a6);flex:none;position:relative;overflow:hidden}
.adav.sm.sq{border-radius:8px}
.adinfo{flex:1;min-width:0}
.adname{font-weight:600;font-size:13.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adsub{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adtable-w{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow-x:auto;box-shadow:var(--shadow)}
.adtable{width:100%;border-collapse:collapse;font-size:13.5px}
.adtable th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);font-weight:600;padding:11px 14px;border-bottom:1px solid var(--line);background:#FBF8F2}
.adtable td{padding:10px 14px;border-bottom:1px solid var(--line2);vertical-align:middle}
.adtable tr:last-child td{border-bottom:none}
.adtable tbody tr:hover{background:#FBF8F2}
.adcell-id{display:flex;align-items:center;gap:10px;min-width:0}
.adact{text-align:right;width:1%;white-space:nowrap}
.adrm{height:30px;padding:0 12px;font-size:12.5px;color:var(--warn);border-color:var(--line)}
.adrm:hover{border-color:var(--warn);background:#fdf3ee}
.admuted{color:var(--faint)}
.pill{display:inline-block;font-size:11px;font-weight:600;padding:2px 9px;border-radius:20px;background:#eef0f3;color:var(--muted)}
.pill.on,.pill.live{background:#e4f5ec;color:var(--ok)}
.pill.warn{background:#fbeee6;color:var(--accent-ink)}
@media(max-width:820px){.admin2{grid-template-columns:1fr}.adside{flex-direction:row;flex-wrap:wrap;position:static;gap:6px}.adcards{grid-template-columns:repeat(2,1fr)}}
.adcell-id{max-width:480px}
.adtable td:not(.adcell-id) .adname,.adtable td .adsub{max-width:460px}
.adtable th:first-child,.adtable td:first-child{max-width:480px}

.admin2.flat{display:block}
.admin2.flat .admain{width:100%}
