/* ============================================================
   Columbia VIP — single responsive stylesheet (mobile-first)
   Desktop <-> mobile switch is pure CSS (dual-nav + chat panes).
   ============================================================ */
:root{
  --columbia:#1D4F91; --columbia-600:#18406F; --columbia-050:#EAF1F9; --accent-pale:#9BCBEB;
  --ink:#14181F; --ink-2:#4A5360; --ink-3:#7A828D; --line:#E2E6EB;
  --bg:#FBFCFD; --surface:#FFFFFF; --surface-2:#F4F6F9;
  --ok:#1E7F4F; --warn:#B7791F; --danger:#C0392B; --vip:#8A6D1F; --prof:#5B3A8C;
  --font-sans:ui-sans-serif,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-serif:Georgia,"Times New Roman",serif;
  --t-xs:.75rem; --t-sm:.875rem; --t-base:1rem; --t-md:1.125rem; --t-lg:1.375rem; --t-xl:1.75rem;
  --lh:1.55;
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px; --s-7:48px;
  --r-sm:6px; --r:10px; --r-lg:16px; --r-pill:999px;
  --shadow-1:0 1px 2px rgba(20,24,31,.06),0 1px 1px rgba(20,24,31,.04);
  --shadow-2:0 4px 16px rgba(20,24,31,.10);
  --max:1120px; --topbar-h:56px; --tabbar-h:56px; --tap:44px;
  --focus:0 0 0 3px var(--columbia-050),0 0 0 1px var(--columbia);
}
@media (prefers-color-scheme:dark){
  :root{
    --columbia:#6FA8DC; --columbia-600:#8FBEE6; --columbia-050:#14233A;
    --ink:#E8ECF1; --ink-2:#AEB6C2; --ink-3:#79828F; --line:#2A313B;
    --bg:#0E1217; --surface:#161B22; --surface-2:#1C232C;
    --vip:#D8B65A; --prof:#B79BE0;
    --shadow-1:0 1px 2px rgba(0,0,0,.5); --shadow-2:0 6px 20px rgba(0,0,0,.55);
    --focus:0 0 0 3px rgba(111,168,220,.35),0 0 0 1px var(--columbia);
  }
}
*{box-sizing:border-box}
html{scroll-padding-top:calc(var(--topbar-h) + 8px);-webkit-text-size-adjust:100%}
html,body{max-width:100%;overflow-x:hidden}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-sans);
  font-size:var(--t-base);line-height:var(--lh);-webkit-font-smoothing:antialiased}
img,svg,video{max-width:100%}
a{color:var(--columbia);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,p{margin:0}
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--s-4)}
.muted{color:var(--ink-3)}
.small{font-size:var(--t-sm)}
.skip{position:absolute;left:-999px;top:0;background:var(--columbia);color:#fff;padding:8px 14px;border-radius:0 0 var(--r-sm) 0;z-index:80}
.skip:focus{left:0}

/* ---- top bar ---- */
.topbar{position:sticky;top:0;z-index:50;background:var(--surface);
  border-bottom:1px solid var(--line);height:var(--topbar-h)}
.topbar__inner{display:flex;align-items:center;gap:var(--s-4);height:var(--topbar-h)}
.brand{display:flex;align-items:baseline;font-weight:800;letter-spacing:.3px;
  color:var(--ink);font-size:var(--t-md)}
.brand:hover{text-decoration:none}
.brand__mark{color:var(--columbia)} .brand__dot{color:var(--ink-3);margin:0 1px}
.brand__vip{color:var(--ink)}
.topbar__nav{display:none}
.topbar__right{margin-left:auto;display:flex;align-items:center;gap:var(--s-3)}
.counters{display:flex;gap:var(--s-3);font-size:var(--t-sm)}
.counter{display:inline-flex;align-items:center;color:var(--ink-2);white-space:nowrap}
.counter b{color:var(--ink);margin:0 2px}
.counter__lbl{display:none;color:var(--ink-3)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:5px}
.dot--total{background:var(--ink-3)}
.dot--live{background:var(--ok);box-shadow:0 0 0 0 rgba(30,127,79,.5);animation:pulse 2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 6px transparent}100%{box-shadow:0 0 0 0 transparent}}
@media (prefers-reduced-motion:reduce){.dot--live{animation:none}}

/* account menu */
.menu{position:relative}
.menu__btn{list-style:none;cursor:pointer;display:flex;align-items:center}
.menu__btn::-webkit-details-marker{display:none}
.menu__pop{position:absolute;right:0;top:calc(100% + 8px);background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-2);
  min-width:210px;padding:6px;z-index:60;display:flex;flex-direction:column}
.menu__head{padding:8px 10px 10px;border-bottom:1px solid var(--line);margin-bottom:4px;display:flex;flex-direction:column}
.menu__email{color:var(--ink-3);font-size:var(--t-xs);overflow-wrap:anywhere}
.menu__pop a{padding:9px 10px;border-radius:var(--r-sm);color:var(--ink)}
.menu__pop a:hover{background:var(--surface-2);text-decoration:none}
.menu__signout{width:100%;text-align:left;padding:9px 10px;border:0;background:none;
  color:var(--danger);font:inherit;cursor:pointer;border-radius:var(--r-sm)}
.menu__signout:hover{background:var(--surface-2)}

/* ---- bottom tab bar (mobile only) ---- */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;
  background:var(--surface);border-top:1px solid var(--line);
  padding-bottom:env(safe-area-inset-bottom);height:calc(var(--tabbar-h) + env(safe-area-inset-bottom))}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;color:var(--ink-3);font-size:10px;font-weight:600;position:relative;min-height:var(--tap)}
.tab:hover{text-decoration:none}
.tab__ic{width:24px;height:24px;fill:currentColor}
.tab[aria-current=page]{color:var(--columbia)}
.tabbadge{position:absolute;top:6px;left:calc(50% + 6px);min-width:16px;height:16px;
  background:var(--danger);color:#fff;border-radius:var(--r-pill);font-size:10px;
  display:flex;align-items:center;justify-content:center;padding:0 4px}
.navbadge{display:inline-flex;min-width:16px;height:16px;background:var(--danger);color:#fff;
  border-radius:var(--r-pill);font-size:10px;align-items:center;justify-content:center;padding:0 4px;margin-left:3px}
.navbadge--show{display:inline-flex}

.is-auth .main{padding-bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom) + var(--s-4))}
.main{padding-top:var(--s-5);padding-bottom:var(--s-6)}

/* ---- flashes / toasts ---- */
.flashes{display:flex;flex-direction:column;gap:var(--s-2);margin-bottom:var(--s-4)}
.flash{padding:10px 14px;border-radius:var(--r-sm);font-size:var(--t-sm);border:1px solid transparent}
.flash--success{background:rgba(30,127,79,.10);color:var(--ok);border-color:rgba(30,127,79,.25)}
.flash--error{background:rgba(192,57,43,.10);color:var(--danger);border-color:rgba(192,57,43,.25)}
.flash--warning{background:rgba(183,121,31,.12);color:var(--warn);border-color:rgba(183,121,31,.3)}
.toasts{position:fixed;left:50%;transform:translateX(-50%);z-index:70;
  bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom) + 12px);display:flex;flex-direction:column;gap:8px}
.toast{background:var(--ink);color:var(--bg);padding:10px 16px;border-radius:var(--r);box-shadow:var(--shadow-2);font-size:var(--t-sm)}

/* ---- primitives ---- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow-1);padding:var(--s-4)}
.avatar{display:inline-flex;width:var(--av,40px);height:var(--av,40px);border-radius:50%;
  overflow:hidden;background:var(--columbia-050);flex:0 0 auto;vertical-align:middle}
.avatar img{width:100%;height:100%;object-fit:cover}
.avatar__i{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-weight:700;color:var(--columbia);font-size:calc(var(--av,40px)*.38)}
.odot{width:9px;height:9px;border-radius:50%;background:var(--ok);display:inline-block;border:2px solid var(--surface)}
.odot--card{position:absolute;right:-2px;bottom:-2px}
.odot--lg{width:14px;height:14px;position:absolute;right:4px;bottom:4px}
.badge{display:inline-flex;align-items:center;gap:4px;height:20px;padding:0 8px;border-radius:var(--r-pill);
  font-size:var(--t-xs);font-weight:700;border:1px solid currentColor;white-space:nowrap}
.badge--prof{color:var(--prof)} .badge--vip{color:var(--vip)} .badge--admin{color:var(--columbia)}
.chip{display:inline-flex;align-items:center;height:20px;padding:0 8px;border-radius:var(--r-pill);
  background:var(--surface-2);color:var(--ink-2);font-size:var(--t-xs);font-weight:600}
.chip--offer{background:rgba(30,127,79,.14);color:var(--ok)}
.chip--seek{background:rgba(29,79,145,.12);color:var(--columbia)}
.dot-sep{color:var(--ink-3);margin:0 2px}

.btn{min-height:var(--tap);padding:0 var(--s-4);border-radius:var(--r-sm);font:600 var(--t-sm)/1 var(--font-sans);
  display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;border:1px solid transparent;text-decoration:none}
.btn:hover{text-decoration:none}
.btn--primary{background:var(--columbia);color:#fff}.btn--primary:hover{background:var(--columbia-600)}
.btn--secondary{background:var(--surface);color:var(--ink);border-color:var(--line)}.btn--secondary:hover{background:var(--surface-2)}
.btn--ghost{background:transparent;color:var(--columbia)}
.btn--danger{background:var(--danger);color:#fff}
.btn--danger-ghost{color:var(--danger)}
.btn--sm{min-height:34px;padding:0 12px;font-size:var(--t-xs)}
.btn--block{width:100%}
.btn:focus-visible,a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible{outline:none;box-shadow:var(--focus)}
.link-btn{background:none;border:0;color:var(--columbia);cursor:pointer;font:inherit;font-size:var(--t-sm);padding:0}
.link-btn--danger{color:var(--danger)}
form{margin:0}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--s-4)}
.label{font-size:var(--t-sm);font-weight:600;color:var(--ink-2)}
.input,.textarea,.select{width:100%;min-height:var(--tap);font-size:var(--t-base);
  padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);
  background:var(--surface);color:var(--ink);font-family:inherit}
.textarea{min-height:auto;resize:vertical;line-height:var(--lh)}
.input--sm,.select--sm{min-height:36px;padding:6px 10px;font-size:var(--t-base)}/* 16px: no iOS zoom */
.input:focus-visible,.textarea:focus-visible,.select:focus-visible{border-color:var(--columbia)}
.hint{font-size:var(--t-xs);color:var(--ink-3)}
.grid2{display:grid;grid-template-columns:1fr;gap:0 var(--s-4)}
.checkrow{display:flex;align-items:center;gap:8px;font-size:var(--t-sm);color:var(--ink-2)}
.form-actions{display:flex;gap:var(--s-3);justify-content:flex-end;margin-top:var(--s-2)}
@media (min-width:600px){.grid2{grid-template-columns:1fr 1fr}}

.page-head{display:flex;flex-wrap:wrap;gap:var(--s-3);align-items:center;justify-content:space-between;margin-bottom:var(--s-4)}
.page-head__actions{display:flex;gap:var(--s-2);flex-wrap:wrap}
.page__title{font-size:var(--t-xl);font-weight:800;letter-spacing:-.01em}
.section__title{font-size:var(--t-lg);font-weight:700;margin-bottom:var(--s-3)}
.section__title--mt{margin-top:var(--s-6)}
.back-link{display:inline-block;margin-bottom:var(--s-3);color:var(--ink-2);font-size:var(--t-sm)}
.prose{white-space:normal;overflow-wrap:anywhere;color:var(--ink);line-height:1.65}
.reading{max-width:760px;margin:0 auto}
.form-card{max-width:680px;margin:0 auto}

.empty{text-align:center;padding:var(--s-7) var(--s-4);color:var(--ink-3)}
.empty__art{font-size:40px;margin-bottom:var(--s-2)}
.empty__title{font-size:var(--t-md);font-weight:700;color:var(--ink-2);margin-bottom:4px}
.empty__sub{font-size:var(--t-sm);margin-bottom:var(--s-4)}

/* ---- auth ---- */
.auth{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:var(--s-5) 0}
.auth__card{width:100%;max-width:420px;text-align:center}
.auth__card form{text-align:left;margin-top:var(--s-4)}
.auth__title{font-size:var(--t-xl);font-weight:800}
.auth__sub{color:var(--ink-3);font-size:var(--t-sm);margin-top:6px}
.auth__links{display:flex;justify-content:space-between;margin-top:var(--s-4);font-size:var(--t-sm);flex-wrap:wrap;gap:8px}

/* ---- feed ---- */
.feed{display:grid;grid-template-columns:1fr;gap:var(--s-4)}
.feed__rail{display:none}
.feed__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s-3)}
.post-card{display:flex;gap:var(--s-3);margin-bottom:var(--s-3)}
.post-card__av{flex:0 0 auto}
.post-card__body{min-width:0;flex:1}
.post-card__meta{font-size:var(--t-sm);color:var(--ink-3);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.post-card__meta a{color:var(--ink);font-weight:600}
.post-card__title{display:block;font-size:var(--t-md);font-weight:700;color:var(--ink);margin:4px 0;overflow-wrap:anywhere}
.post-card__title:hover{color:var(--columbia);text-decoration:none}
.post-card__excerpt{color:var(--ink-2);font-size:var(--t-sm);overflow-wrap:anywhere}
.post-card__foot{display:flex;gap:var(--s-4);margin-top:var(--s-2);font-size:var(--t-sm);color:var(--ink-3)}
.metric{color:var(--ink-3)} .metric.is-liked{color:var(--danger)}
.rail__title{font-size:var(--t-sm);font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);margin-bottom:var(--s-2)}
.rail__card{margin-bottom:var(--s-4)}
.catlink{display:block;padding:8px 10px;border-radius:var(--r-sm);color:var(--ink-2);font-size:var(--t-sm)}
.catlink:hover{background:var(--surface-2);text-decoration:none}
.catlink.is-active{background:var(--columbia-050);color:var(--columbia);font-weight:600}
.online-list{display:flex;flex-direction:column;gap:4px}
.online-list__item{display:flex;align-items:center;gap:8px;padding:4px;border-radius:var(--r-sm);color:var(--ink-2);font-size:var(--t-sm);position:relative}
.online-list__item:hover{background:var(--surface-2);text-decoration:none}
.online-list__item .odot{position:absolute;left:26px;bottom:4px}
.online-list__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mini-event{display:flex;gap:8px;padding:6px 0;border-bottom:1px solid var(--line);color:var(--ink-2);font-size:var(--t-sm)}
.mini-event:last-of-type{border-bottom:0}
.mini-event:hover{text-decoration:none;color:var(--columbia)}
.mini-event__date{font-weight:700;color:var(--columbia);flex:0 0 auto}
.rail__more{display:inline-block;margin-top:8px;font-size:var(--t-sm)}

/* ---- post detail ---- */
.post__head{display:flex;gap:var(--s-3);align-items:flex-start}
.post__author a{color:var(--ink);font-weight:700}
.post__del{margin-left:auto}
.post__title{font-family:var(--font-serif);font-size:var(--t-xl);margin:var(--s-3) 0;line-height:1.2}
.post__body{margin-bottom:var(--s-4)}
.post__actions{display:flex;align-items:center;gap:var(--s-4);border-top:1px solid var(--line);padding-top:var(--s-3)}
.like-btn{display:inline-flex;align-items:center;gap:6px;min-height:38px;padding:0 14px;border:1px solid var(--line);
  border-radius:var(--r-pill);background:var(--surface);color:var(--ink-2);cursor:pointer;font:600 var(--t-sm)/1 var(--font-sans)}
.like-btn__heart{font-size:16px}
.like-btn.is-liked{color:var(--danger);border-color:var(--danger);background:rgba(192,57,43,.06)}
.comments{margin-top:var(--s-5)}
.comment-form{margin-bottom:var(--s-4)}
.comment-form__foot{display:flex;justify-content:flex-end;margin-top:var(--s-2)}
.comment{display:flex;gap:var(--s-3);padding:var(--s-3) 0;border-bottom:1px solid var(--line)}
.comment--reply{margin-left:var(--s-5)}
.comment__body{min-width:0;flex:1}
.comment__meta{font-size:var(--t-sm);color:var(--ink-3);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.comment__meta a{color:var(--ink);font-weight:600}
.comment__del{margin-left:auto}
.comment__text{margin-top:4px;overflow-wrap:anywhere}

/* ---- directory ---- */
.search{display:flex;gap:var(--s-2);flex:1;max-width:420px}
.search__input{flex:1}
.member-grid{display:grid;grid-template-columns:1fr;gap:var(--s-3);margin-top:var(--s-3)}
.member-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;padding:var(--s-4) var(--s-3);position:relative}
.member-card:hover{text-decoration:none;box-shadow:var(--shadow-2)}
.member-card__av{position:relative}
.member-card__name{font-weight:700;color:var(--ink);margin-top:6px;overflow-wrap:anywhere}
.member-card__sub{font-size:var(--t-sm);color:var(--ink-3)}
.member-card__title{font-size:var(--t-xs);color:var(--ink-3);overflow-wrap:anywhere}
.region{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);margin-bottom:var(--s-3);overflow:hidden}
.region__summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  padding:var(--s-3) var(--s-4);font-weight:700;font-size:var(--t-md)}
.region__summary::-webkit-details-marker{display:none}
.region__summary::before{content:"▸";color:var(--ink-3);margin-right:8px;transition:transform .15s}
.region[open] .region__summary::before{transform:rotate(90deg);display:inline-block}
.region__name{flex:1}
.region__count{background:var(--columbia-050);color:var(--columbia);font-size:var(--t-sm);padding:2px 10px;border-radius:var(--r-pill)}
.city{padding:0 var(--s-4) var(--s-4)}
.city__name{font-size:var(--t-sm);font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.03em;margin-top:var(--s-3)}
.city__count{color:var(--ink-3);font-weight:600}
.member-grid{content-visibility:auto}

/* ---- profile ---- */
.profile-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--s-3)}
.profile-head__av{position:relative}
.profile-head__name{font-size:var(--t-xl);font-weight:800;display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap}
.profile-head__sub{color:var(--ink-2)}
.profile-head__actions{display:flex;gap:var(--s-2);flex-wrap:wrap;justify-content:center;margin-top:var(--s-2)}
.profile-grid{display:grid;grid-template-columns:1fr;gap:var(--s-4);margin-top:var(--s-4)}
.profile-block{margin-top:var(--s-4)}
.mini-job,.mini-post{display:block;padding:8px 0;border-bottom:1px solid var(--line);color:var(--ink-2);font-size:var(--t-sm)}
.mini-job:last-child,.mini-post:last-child{border-bottom:0}
.mini-post{display:flex;flex-direction:column;gap:2px}
.mini-post__title{color:var(--ink);font-weight:600}
.avatar-edit{display:flex;gap:var(--s-4);align-items:center;margin-bottom:var(--s-4)}
.avatar-edit__controls{flex:1}

/* ---- chat ---- */
.chat{display:block}
.chat__listhead{display:flex;align-items:center;justify-content:space-between}
.newch{position:relative}
.newch__btn{list-style:none;cursor:pointer;width:30px;height:30px;border-radius:var(--r-sm);
  background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--columbia)}
.newch__btn::-webkit-details-marker{display:none}
.newch__form{position:absolute;right:0;top:36px;z-index:20;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);box-shadow:var(--shadow-2);padding:var(--s-3);width:240px;display:flex;flex-direction:column;gap:8px}
.chan-list{display:flex;flex-direction:column;gap:2px;margin-bottom:var(--s-4)}
.chan{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:var(--r-sm);color:var(--ink-2)}
.chan:hover{background:var(--surface-2);text-decoration:none}
.chan.is-sel{background:var(--columbia-050);color:var(--columbia)}
.chan__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:6px}
.unread{background:var(--danger);color:#fff;border-radius:var(--r-pill);font-size:var(--t-xs);font-weight:700;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.rail__title--dm{margin-top:var(--s-3)}
.dm-empty{padding:0 4px}
.chat__conv{position:fixed;top:var(--topbar-h);left:0;right:0;
  bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom));background:var(--bg);z-index:30;
  transform:translateX(100%);transition:transform .22s ease;display:flex;flex-direction:column}
.chat__conv.is-open{transform:translateX(0)}
@media (prefers-reduced-motion:reduce){.chat__conv{transition:none}}
.chat__empty{margin:auto;text-align:center;color:var(--ink-3);padding:var(--s-5)}
.conv__head{display:flex;align-items:center;gap:var(--s-2);padding:var(--s-3) var(--s-4);
  border-bottom:1px solid var(--line);background:var(--surface)}
.conv__back{font-size:22px;color:var(--ink-2);line-height:1;padding:4px 8px;margin-left:-8px}
.conv__back:hover{text-decoration:none}
.conv__title{font-weight:700;display:flex;flex-direction:column}
.conv__desc{font-size:var(--t-xs);color:var(--ink-3);font-weight:400}
.conv__msgs{flex:1;overflow-y:auto;padding:var(--s-4);display:flex;flex-direction:column;gap:var(--s-3)}
.msg{display:flex;gap:8px;max-width:85%}
.msg--mine{margin-left:auto;flex-direction:row-reverse}
.msg__bubble{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:8px 12px;min-width:0}
.msg--mine .msg__bubble{background:var(--columbia);color:#fff;border-color:var(--columbia)}
.msg__author{font-size:var(--t-xs);font-weight:700;color:var(--columbia);margin-bottom:2px;display:flex;gap:6px;align-items:center}
.msg__text{overflow-wrap:anywhere;white-space:normal}
.msg__time{display:block;font-size:10px;color:var(--ink-3);margin-top:3px}
.msg--mine .msg__time{color:rgba(255,255,255,.75)}
.composer{display:flex;gap:8px;padding:var(--s-3);border-top:1px solid var(--line);
  background:var(--surface);align-items:flex-end}
.composer__input{flex:1;font-size:var(--t-base);padding:10px 12px;border:1px solid var(--line);
  border-radius:var(--r-lg);background:var(--bg);color:var(--ink);resize:none;max-height:120px;font-family:inherit;line-height:1.4}
.composer__send{flex:0 0 auto;width:44px;height:44px;border-radius:50%;border:0;background:var(--columbia);
  color:#fff;font-size:18px;cursor:pointer}

/* ---- jobs ---- */
.filters{display:flex;gap:var(--s-2);flex-wrap:wrap;margin-bottom:var(--s-4)}
.filters .select{flex:1;min-width:140px}
.jobs-cols{display:grid;grid-template-columns:1fr;gap:var(--s-5)}
.job{margin-bottom:var(--s-3)}
.job__top{display:flex;flex-direction:column;gap:4px}
.job__title{font-size:var(--t-md);font-weight:700;margin-top:2px;overflow-wrap:anywhere}
.job__org{color:var(--ink-2);font-size:var(--t-sm)}
.job__desc{color:var(--ink-2);font-size:var(--t-sm);margin:var(--s-2) 0;overflow-wrap:anywhere}
.job__tags{display:flex;flex-wrap:wrap;gap:6px}
.tag{background:var(--surface-2);color:var(--ink-2);font-size:var(--t-xs);padding:3px 9px;border-radius:var(--r-pill)}
.job__foot{display:flex;align-items:center;justify-content:space-between;margin-top:var(--s-3);gap:8px}
.job__poster{display:flex;align-items:center;gap:6px;color:var(--ink-2);font-size:var(--t-sm);min-width:0}
.job__poster span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.job__contact{margin-top:var(--s-2);font-size:var(--t-sm);color:var(--ink-2)}
.job__admin{display:flex;gap:var(--s-3);margin-top:var(--s-2)}
.seg{display:flex;gap:var(--s-2)}
.seg__opt{flex:1;display:flex;align-items:center;gap:6px;padding:10px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:var(--t-sm);cursor:pointer}

/* ---- events ---- */
.event-row{display:flex;gap:var(--s-3);align-items:center;margin-bottom:var(--s-3)}
.event-row__date{flex:0 0 auto;width:52px;text-align:center;background:var(--columbia-050);border-radius:var(--r-sm);padding:6px 0}
.event-row__mon{display:block;font-size:var(--t-xs);font-weight:700;color:var(--columbia);text-transform:uppercase}
.event-row__day{display:block;font-size:var(--t-md);font-weight:800;color:var(--ink)}
.event-row__main{flex:1;min-width:0}
.event-row__title{font-weight:700;color:var(--ink);display:block;overflow-wrap:anywhere}
.event-row__rsvp{display:flex;gap:6px;flex:0 0 auto;flex-wrap:wrap;justify-content:flex-end}
.rsvp-btn{min-height:40px;padding:0 14px;border-radius:var(--r-pill);border:1px solid var(--columbia);
  background:var(--columbia);color:#fff;font:600 var(--t-xs)/1 var(--font-sans);cursor:pointer}
.rsvp-btn--ghost{background:var(--surface);color:var(--columbia)}
.rsvp-btn.is-on{background:var(--ok);border-color:var(--ok);color:#fff}
.rsvp-bar{display:flex;gap:8px;margin-top:var(--s-4);flex-wrap:wrap}
.event-row--past{opacity:.7}
.event-detail__meta{display:flex;flex-direction:column;gap:4px;margin:var(--s-3) 0;color:var(--ink-2)}
.event-detail__desc{margin-top:var(--s-3)}
.event-detail__del{margin-top:var(--s-4)}
.member-grid--compact{grid-template-columns:repeat(2,1fr)}

/* ---- admin ---- */
.admin-nav{display:flex;gap:var(--s-2);flex-wrap:wrap;margin-bottom:var(--s-4);overflow-x:auto;-webkit-overflow-scrolling:touch}
.admin-nav a{padding:8px 12px;border-radius:var(--r-pill);background:var(--surface-2);color:var(--ink-2);font-size:var(--t-sm);font-weight:600;white-space:nowrap}
.admin-nav a:hover{text-decoration:none}
.admin-nav a.is-active{background:var(--columbia);color:#fff}
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-3);margin-bottom:var(--s-5)}
.stat{display:flex;flex-direction:column;gap:2px;align-items:flex-start}
.stat:hover{text-decoration:none;box-shadow:var(--shadow-2)}
.stat__n{font-size:var(--t-xl);font-weight:800;color:var(--ink)}
.stat__l{font-size:var(--t-sm);color:var(--ink-3)}
.stat--alert{border-color:var(--warn)}.stat--alert .stat__n{color:var(--warn)}
.data-table{width:100%;border-collapse:collapse;font-size:var(--t-sm)}
.data-table th{text-align:left;color:var(--ink-3);font-weight:600;padding:8px;border-bottom:1px solid var(--line)}
.data-table td{padding:10px 8px;border-bottom:1px solid var(--line);vertical-align:top}
.table-scroll{overflow-x:auto}
.row-actions{display:flex;gap:var(--s-3);flex-wrap:wrap;white-space:nowrap}
.status{font-size:var(--t-xs);font-weight:700;padding:2px 8px;border-radius:var(--r-pill)}
.status--active{background:rgba(30,127,79,.14);color:var(--ok)}
.status--pending{background:rgba(183,121,31,.14);color:var(--warn)}
.status--suspended{background:rgba(192,57,43,.14);color:var(--danger)}
.approval{display:flex;flex-direction:column;gap:var(--s-3);margin-bottom:var(--s-3)}
.approval__who{display:flex;gap:var(--s-3);align-items:flex-start}
.approval__name{font-weight:700}
.approval__actions{display:flex;gap:var(--s-2)}

/* =====================  >= 600px  ===================== */
@media (min-width:600px){
  .counter__lbl{display:inline}
  .member-grid{grid-template-columns:repeat(2,1fr)}
  .member-grid--compact{grid-template-columns:repeat(3,1fr)}
  .approval{flex-direction:row;align-items:center;justify-content:space-between}
  .approval__actions{flex:0 0 auto}
}

/* =====================  >= 900px : desktop  ===================== */
@media (min-width:900px){
  .topbar__nav{display:flex;gap:var(--s-1);margin-left:var(--s-4)}
  .topbar__nav a{padding:8px 12px;border-radius:var(--r-sm);color:var(--ink-2);font-weight:600;font-size:var(--t-sm)}
  .topbar__nav a:hover{background:var(--surface-2);text-decoration:none}
  .topbar__nav a[aria-current=page]{color:var(--columbia);background:var(--columbia-050)}
  .tabbar{display:none}
  .input--sm,.select--sm{font-size:var(--t-sm)}/* desktop: no zoom risk, restore compact */
  .is-auth .main{padding-bottom:var(--s-6)}
  .feed{grid-template-columns:200px 1fr}
  .feed__cats{display:block}
  .feed__side{display:none}
  .member-grid{grid-template-columns:repeat(3,1fr)}
  .profile-head{flex-direction:row;text-align:left;align-items:flex-start}
  .profile-head__name,.profile-head__actions{justify-content:flex-start}
  .profile-grid{grid-template-columns:1fr 1fr}
  .jobs-cols{grid-template-columns:1fr 1fr}
  .stat-grid{grid-template-columns:repeat(4,1fr)}
  /* chat becomes two panes */
  .body--chat .main{padding-bottom:0}
  .chat{display:grid;grid-template-columns:300px 1fr;gap:var(--s-4);
    height:calc(100dvh - var(--topbar-h) - var(--s-5) - var(--s-6))}
  .chat__list{overflow-y:auto;padding-right:4px}
  .chat__conv{position:static;transform:none;height:100%;border:1px solid var(--line);
    border-radius:var(--r);background:var(--surface);overflow:hidden;z-index:auto}
  .conv__back{display:none}
  .conv__head{border-radius:var(--r) var(--r) 0 0}
}

/* =====================  >= 1200px  ===================== */
@media (min-width:1200px){
  .feed{grid-template-columns:220px minmax(0,1fr) 300px;justify-content:center}
  .feed__side{display:block}
  .member-grid{grid-template-columns:repeat(4,1fr)}
}

/* ---- password reveal toggle (JS-injected) ---- */
.pw-wrap{position:relative;display:block}
.pw-wrap__input{padding-right:46px}
.pw-toggle{position:absolute;top:0;right:0;width:var(--tap);height:100%;display:flex;
  align-items:center;justify-content:center;background:none;border:0;cursor:pointer;color:var(--ink-3);padding:0}
.pw-toggle:hover{color:var(--ink-2)}
.pw-toggle svg{width:20px;height:20px;fill:currentColor}
.pw-toggle:focus-visible{outline:none;box-shadow:var(--focus)}
.pw-toggle .pw-eye-off{display:none}
.pw-toggle.is-shown .pw-eye{display:none}
.pw-toggle.is-shown .pw-eye-off{display:inline}

/* ---- online-members dropdown ---- */
.menu--online .menu__btn{min-height:var(--tap);padding:0 2px;cursor:pointer}
.menu__pop--online{min-width:248px;max-width:min(86vw,300px);max-height:min(60vh,360px);
  overflow-y:auto;overscroll-behavior:contain}
.online-list--pop{gap:2px}
.online-list__item--row{display:flex;align-items:center;gap:8px;padding:4px;border-radius:var(--r-sm)}
.online-list__item--row:hover{background:var(--surface-2)}
.online-list__link{position:relative;display:flex;align-items:center;gap:8px;flex:1;min-width:0;color:var(--ink-2);padding:2px}
.online-list__link:hover{text-decoration:none}
.online-list__msg{flex:0 0 auto;white-space:nowrap}
.online-list__solo{padding:6px 8px 2px}

/* ---- mobile "More" tab sheet ---- */
.tab--more{flex:1;position:relative;display:flex}
.tab--more>summary{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;min-height:var(--tap);list-style:none;cursor:pointer;color:var(--ink-3);font-size:10px;font-weight:600}
.tab--more>summary::-webkit-details-marker{display:none}
.tab--more[open]>summary,.tab--more>summary[aria-current=page]{color:var(--columbia)}
.tab__sheet{position:absolute;right:6px;bottom:calc(100% + 8px);min-width:172px;z-index:45;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-2);
  padding:6px;display:flex;flex-direction:column}
.tab__sheet a{padding:11px 12px;border-radius:var(--r-sm);color:var(--ink);min-height:var(--tap);display:flex;align-items:center}
.tab__sheet a:hover{background:var(--surface-2);text-decoration:none}

/* ---- pitches ---- */
.ticker{font-weight:800;letter-spacing:.02em;background:var(--surface-2);color:var(--ink);
  padding:2px 9px;border-radius:var(--r-sm);font-size:var(--t-sm);font-family:var(--font-sans)}
.chip--long{background:rgba(30,127,79,.14);color:var(--ok)}
.chip--short{background:rgba(183,121,31,.16);color:var(--warn)}
.chip--closed{background:var(--surface-2);color:var(--ink-3)}
.ret--pos{color:var(--ok)} .ret--neg{color:var(--danger)} .ret--flat{color:var(--ink-3)}
.stars{color:var(--vip);letter-spacing:1px;white-space:nowrap}
.stars .off{color:var(--line)}
.like-btn--up.is-liked{color:var(--columbia);border-color:var(--columbia);background:rgba(29,79,145,.07)}
.pitch{display:block;margin-bottom:var(--s-3)}
.pitch:hover{box-shadow:var(--shadow-2)}
.pitch__head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pitch__ret{font-weight:800;font-size:var(--t-md);margin-left:auto}
.pitch__company{display:block;font-weight:700;font-size:var(--t-md);margin:6px 0 2px;color:var(--ink);overflow-wrap:anywhere}
.pitch:hover .pitch__company{color:var(--columbia)}
.pitch__thesis{color:var(--ink-2);font-size:var(--t-sm);overflow-wrap:anywhere}
.pitch__meta{font-size:var(--t-sm);color:var(--ink-3);margin-top:8px;display:flex;flex-wrap:wrap;gap:4px 14px}
.pitch__foot{display:flex;align-items:center;gap:var(--s-4);margin-top:var(--s-3);font-size:var(--t-sm);color:var(--ink-3);flex-wrap:wrap}
.pitch__author{display:flex;align-items:center;gap:6px;color:var(--ink-2)}
.pitch-stats{display:flex;gap:var(--s-5);flex-wrap:wrap;margin:var(--s-3) 0;padding:var(--s-3) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pitch-stat{display:flex;flex-direction:column;gap:2px}
.pitch-stat__l{font-size:var(--t-xs);color:var(--ink-3);text-transform:uppercase;letter-spacing:.03em}
.pitch-stat__v{font-size:var(--t-lg);font-weight:800}
.ret--big{font-size:var(--t-xl)}

/* ---- leaderboard ---- */
.seg-toggle{display:inline-flex;border:1px solid var(--line);border-radius:var(--r-pill);overflow:hidden}
.seg-toggle a{padding:9px 18px;font-size:var(--t-sm);font-weight:600;color:var(--ink-2);background:var(--surface)}
.seg-toggle a:hover{text-decoration:none;background:var(--surface-2)}
.seg-toggle a.is-active{background:var(--columbia);color:#fff}
.lb{padding:0}
.lb-row{display:flex;align-items:center;gap:var(--s-3);padding:10px var(--s-2);border-bottom:1px solid var(--line)}
.lb-row:last-child{border-bottom:0}
.lb-rank{flex:0 0 auto;width:30px;text-align:center;font-weight:800;color:var(--ink-3);font-size:var(--t-md)}
.lb-row--top .lb-rank{color:var(--vip)}
.lb-who{display:flex;align-items:center;gap:8px;min-width:0;flex:1}
.lb-who__name{font-weight:700;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-who:hover{text-decoration:none}
.lb-metrics{flex:0 0 auto;display:flex;gap:var(--s-4);text-align:right}
.lb-metric{display:flex;flex-direction:column;gap:1px}
.lb-metric__v{font-weight:800}
.lb-metric__l{font-size:var(--t-xs);color:var(--ink-3)}
.lb-metric--sec{display:none}
@media (min-width:600px){.lb-metric--sec{display:flex}}

/* dark mode: lift semantic data-text colors to AA contrast on dark surfaces
   (targeted to text uses; solid-green buttons keep their white-on-ok contrast) */
@media (prefers-color-scheme:dark){
  .ret--pos,.chip--long{color:#46c884}
  .ret--neg{color:#f0716a}
  .chip--short{color:#e0a93f}
}

/* ---- modal / popup ---- */
.modal{position:fixed;inset:0;z-index:90;background:rgba(8,12,18,.5);
  display:flex;align-items:center;justify-content:center;padding:var(--s-4)}
.modal__card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-2);max-width:420px;width:100%;padding:var(--s-5)}
.modal__title{font-size:var(--t-lg);font-weight:800;margin-bottom:var(--s-2)}
.modal__body{color:var(--ink-2);margin-bottom:var(--s-4);line-height:1.5}
.modal__actions{display:flex;gap:var(--s-2);justify-content:flex-end;flex-wrap:wrap}

/* ticker auto-fill status line */
.ticker-status{min-height:1.2em}
.ticker-status--ok{color:var(--ok)}
.ticker-status--err{color:var(--warn)}
