/* ============================================================
   ClassLink Community — recreated design system
   Captured from www.classlinkcommunity.com
   ============================================================ */
:root{
  /* ── Frost contract: slate neutrals + ClassLink-blue primary ── */
  --bg:#f8fafc;              /* --app: content canvas + header */
  --card:#ffffff;
  --surface:#ffffff;         /* white surface (cards, inputs, popovers) */
  --accent:#0a4d7f;          /* ClassLink Blue — primary fill / active indicator (8.82:1) */
  --accent-deep:#0a4d7f;     /* primary blue — links/text */
  --accent-blue:#4e95cc;     /* secondary blue */
  --ink:#0f172a;             /* slate-900 foreground */
  --ink-soft:#334155;        /* slate-700 — author name */
  --muted:#5b6675;           /* muted-foreground (AA on white) */
  --muted-2:#5b6675;
  --line:#d6dee8;            /* border */
  --line-soft:#e8edf3;
  --danger:#c62e2e;          /* destructive */
  --muted-3:#6b7689;         /* light meta / placeholders */
  --tint-teal:#e7f0f7;       /* brand soft-blue tint surfaces */
  --avatar-bg:#d6dee8;
  --field-bg:#f1f5f9;        /* secondary slate fill (inputs / hovers) */
  --toast-bg:#0f1b2d;        /* deep slate toast */
  --grp-fallback:#64748b;    /* letter-avatar fallback */
  --on-accent:#ffffff;       /* text on primary-blue buttons */
  --info-tint:#e5f1f9;  --info-ink:#0a4d7f;
  --warn-tint:#fff1db;  --warn-ink:#7d5310;
  --ok-tint:#e4f6ec;    --ok-ink:#137a48;
  --danger-tint:#fdeae8; --danger-ink:#c62e2e;
  --radius-xs:6px;
  /* brand-blue-tinted elevation */
  --shadow:0 1px 2px rgba(10,77,127,.08),0 2px 6px rgba(10,77,127,.10);
  --header-h:56px;
  --banner-h:40px;
  --chrome-h:var(--header-h);            /* header height, +banner when shown */
  --sidebar-w:256px;
  --main-w:885px;
  --card-w:760px;
  --radius:10px;             /* Frost base ~10px (rounded-lg) */
}
*{box-sizing:border-box;}

/* ============================================================
   DARK THEME — re-maps the semantic tokens. Because surfaces,
   text, lines and tints all flow through these tokens, the whole
   app re-themes from this one block.
   ============================================================ */
html.dark{
  color-scheme:dark;
  --bg:#0b1220;              /* --app dark canvas (215 34% 7%) */
  --surface:#161d2b;         /* card (215 28% 13%) */
  --card:#161d2b;
  --ink:#eef2f8;             /* foreground (210 40% 96%) */
  --ink-soft:#cdd6e3;
  --muted:#94a1b5;           /* muted-foreground (215 18% 64%) */
  --muted-2:#94a1b5;
  --muted-3:#8593aa;
  --line:#2c3647;            /* border (217 24% 24%) */
  --line-soft:#222b39;
  --field-bg:#1c2433;        /* secondary (217 30% 18%) */
  --avatar-bg:#2c3647;
  --grp-fallback:#7c8aa3;
  --accent:#7cc0ee;          /* primary lifted for dark (205 75% 70%) */
  --accent-deep:#7cc0ee;
  --accent-blue:#4e95cc;
  --on-accent:#0e1f32;       /* primary-foreground on light-blue (215 45% 12%) */
  --tint-teal:#16324a;       /* brand soft tint on dark */
  --info-tint:#173049;  --info-ink:#8fc8ee;
  --warn-tint:#3a2f17;  --warn-ink:#e6bd6e;
  --ok-tint:#14321f;    --ok-ink:#7cd3a0;
  --danger-tint:#3a1f1f; --danger-ink:#ec8a82;
  --danger:#ec8a82;
  --toast-bg:#0a1422;
  --shadow:0 1px 2px rgba(0,0,0,.5),0 2px 10px rgba(0,0,0,.4);
  --nav-bg:#0e2238;
  --nav-pill:#1c3a52;
}
body.has-banner{--chrome-h:calc(var(--header-h) + var(--banner-h));}

/* ── Lucide icons reuse the legacy icon classes; font-size drives the box,
      currentColor drives the stroke (Frost §10) ── */
.material-icons-outlined,.material-icons{display:inline-flex;align-items:center;justify-content:center;
  width:1em;height:1em;font-size:20px;line-height:1;vertical-align:-.14em;flex:none;font-family:inherit;}
svg.material-icons-outlined,svg.material-icons{width:1em;height:1em;stroke:currentColor;}
i[data-lucide]{width:1em;height:1em;}

html,body{margin:0;padding:0;}
body{
  font-family:"Open Sans",sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-size:14px;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;}
.material-icons,.material-icons-outlined{vertical-align:middle;user-select:none;}
.hidden{display:none !important;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:38px;padding:0 18px;border-radius:var(--radius-sm);border:1px solid transparent;
  font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:.15s;
}
.btn-primary{background:var(--accent);color:var(--on-accent);}
.btn-primary:hover{background:#23cabf;}
.btn-ghost{background:var(--surface);border-color:var(--line);color:var(--ink);}
.btn-ghost:hover{background:var(--field-bg);}
.btn-teal-outline{background:var(--tint-teal);color:var(--accent-deep);}
.btn-sm{height:32px;padding:0 14px;border-radius:var(--radius-xs);font-size:13px;}

/* ============================================================
   TOP HEADER
   ============================================================ */
header.topbar{
  position:fixed;top:0;left:0;right:0;height:var(--header-h);
  background:var(--surface);border-bottom:1px solid var(--line);
  display:flex;align-items:center;padding:0 12px;gap:10px;z-index:50;
}
.brand{display:flex;align-items:center;gap:8px;width:calc(var(--sidebar-w) - 12px);flex:none;cursor:pointer;}
.brand .logo{
  width:32px;height:32px;border-radius:7px;flex:none;
  object-fit:cover;background:var(--nav-bg);display:block;
}
.brand h3{font-size:16px;font-weight:600;margin:0;white-space:nowrap;color:var(--ink);}
.search{
  position:absolute;left:50%;transform:translateX(-50%);
  width:560px;max-width:44vw;height:34px;display:flex;align-items:center;gap:8px;
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);padding:0 16px;color:var(--muted-3);
}
.search .material-icons-outlined{font-size:20px;color:var(--muted-3);}
.search input{border:0;background:transparent;outline:none;flex:1;font-family:inherit;font-size:14px;color:var(--ink);}
.topbar .spacer{flex:1;}
.topbar .icons{display:flex;align-items:center;gap:6px;}
.icon-btn{
  width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--ink);cursor:pointer;position:relative;border:none;background:transparent;
}
.icon-btn:hover{background:var(--bg);}
.icon-btn .material-icons-outlined{font-size:23px;}
.badge{
  position:absolute;top:1px;right:1px;min-width:17px;height:15px;padding:0 3px;border-radius:var(--radius-xs);
  background:var(--danger);color:#fff;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;line-height:1;
}
/* small orange notification dot */
.icon-btn .dot{position:absolute;top:7px;right:7px;width:9px;height:9px;border-radius:50%;background:#ff8a00;border:2px solid var(--surface);}
.icon-btn .material-icons-outlined{color:var(--ink-soft);}
/* person-silhouette avatar in a light circle */
.avatar-icon{margin-left:4px;background:var(--line-soft);}
.avatar-icon:hover{background:#dfe1e7;}
.avatar-icon .material-icons-outlined{font-size:20px;color:var(--muted-3);}
.avatar-sm{width:33px;height:33px;border-radius:50%;object-fit:cover;margin-left:4px;cursor:pointer;}

/* ============================================================
   LAYOUT SHELL
   ============================================================ */
.shell{display:flex;padding-top:var(--chrome-h);}
aside.sidebar{
  width:var(--sidebar-w);flex:none;padding:14px 12px;
  position:sticky;top:var(--chrome-h);height:calc(100vh - var(--chrome-h));overflow-y:auto;
  display:flex;flex-direction:column;
}
main.content{flex:1;min-width:0;min-height:calc(100vh - var(--chrome-h));}

/* ---------- SIDEBAR (Frost gradient rail) ---------- */
:root{ --nav-bg:#0a4d7f; --nav-pill:rgba(255,255,255,.72); --rail-ink:#163a63; }
/* gradient contained to the rail only, under a thin white veil (Frost §7) */
aside.sidebar{
  background:linear-gradient(rgba(255,255,255,.40),rgba(255,255,255,.40)),
             linear-gradient(180deg,#4e92de,#46be89);
  color:var(--rail-ink);padding:10px 10px;
}
html.dark aside.sidebar{
  background:linear-gradient(rgba(18,24,36,.52),rgba(18,24,36,.52)),
             linear-gradient(180deg,#0e2238,#0e2e2a);
  color:#dbe6f3;
}
.nav-head{
  display:flex;align-items:center;gap:11px;height:42px;padding:0 12px;
  color:var(--rail-ink);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.08em;
}
html.dark .nav-head{color:#aebfd4;}
.nav-head .lead{font-size:21px;color:var(--rail-ink);}
html.dark .nav-head .lead{color:#dbe6f3;}
.nav-head .chevwrap{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;border-radius:6px;padding:2px;}
.nav-head .chevwrap:hover{background:rgba(255,255,255,.35);}
html.dark .nav-head .chevwrap:hover{background:rgba(255,255,255,.12);}
.nav-head .chev{font-size:23px;color:var(--rail-ink);opacity:.8;transition:transform .15s;}
.nav-head.collapsed .chev{transform:rotate(-90deg);}
.nav-section.collapsed{display:none;}
.nav-link{
  display:flex;align-items:center;gap:11px;height:40px;border-radius:var(--radius-md);padding:0 12px;
  color:var(--rail-ink);cursor:pointer;font-size:14px;font-weight:500;margin:1px 0;transition:background .12s,color .12s;
}
html.dark .nav-link{color:#dbe6f3;}
.nav-link .gicon{width:22px;height:22px;border-radius:6px;object-fit:cover;flex:none;background:var(--avatar-bg);}
.nav-link .micon{font-size:21px;width:22px;text-align:center;color:var(--rail-ink);}
html.dark .nav-link .micon{color:#cdd9ea;}
.nav-link .label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;}
.nav-link .chev{font-size:22px;color:var(--rail-ink);opacity:.75;}
.nav-link:hover{background:rgba(255,255,255,.45);}
html.dark .nav-link:hover{background:rgba(255,255,255,.08);}
/* active = soft frosted chip + primary-blue text (Frost: tint, never a hard bar) */
.nav-link.active{background:var(--nav-pill);color:var(--accent-deep);font-weight:600;}
.nav-link.active .micon,.nav-link.active .chev{color:var(--accent-deep);}
html.dark .nav-link.active{background:var(--nav-pill);color:#bfe0fb;}
html.dark .nav-link.active .micon,html.dark .nav-link.active .chev{color:#bfe0fb;}
.nav-link.child{padding-left:30px;}
.nav-link.child .gicon{width:20px;height:20px;}
.nav-gap{height:8px;}

/* ============================================================
   COVER / GROUP HEADER
   ============================================================ */
.cover{
  height:290px;position:relative;display:flex;align-items:flex-end;padding:20px 44px;
  background-size:cover;background-position:center;
}
.cover .ctitle{display:flex;flex-direction:column;gap:6px;padding-bottom:8px;}
.cover h1{margin:0;color:#fff;font-size:27px;font-weight:600;display:flex;align-items:center;gap:10px;}
.cover h1 .material-icons-outlined{font-size:22px;opacity:.95;}
.cover .members{color:#fff;font-size:14px;opacity:.95;display:flex;align-items:center;gap:6px;}
.cover .members .dot{opacity:.6;}
.cover .members a{text-decoration:underline;text-underline-offset:2px;cursor:pointer;}

/* ---------- TABS ---------- */
.tabs{display:flex;align-items:center;gap:0;background:var(--surface);border-bottom:1px solid var(--line);padding:0 44px;}
.tab{
  height:48px;display:flex;align-items:center;padding:0 14px;font-size:14px;font-weight:500;
  color:var(--ink-soft);cursor:pointer;position:relative;letter-spacing:.2px;
}
.tab:hover{color:var(--ink);}
.tab.active{color:var(--ink);}
.tab.active::after{content:"";position:absolute;left:8px;right:8px;bottom:0;height:3px;border-radius:3px;background:var(--accent-deep);}

/* ============================================================
   FEED + POST CARDS
   ============================================================ */
.page-pad{padding:18px 0 50px;}
.col{width:var(--card-w);margin:0 auto;}
.filterbar{
  width:var(--card-w);margin:0 auto 18px;display:flex;align-items:center;gap:16px;
}
.filter{display:flex;align-items:center;gap:8px;color:var(--ink);font-size:14px;cursor:pointer;font-weight:500;}
.filter .material-icons-outlined{font-size:20px;color:var(--ink-soft);}
.filter .caret{font-size:18px;color:var(--muted-3);}
.filterbar .spacer{flex:1;}

.card{
  width:var(--card-w);margin:0 auto 18px;background:var(--card);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:21px 32px 14px;
}
.post-head{display:flex;align-items:flex-start;gap:12px;}
.post-head .pavatar{width:48px;height:48px;border-radius:50%;object-fit:cover;flex:none;cursor:pointer;background:var(--avatar-bg);}
.post-head .who{display:flex;flex-direction:column;gap:2px;min-width:0;}
.post-head .name{font-size:16px;font-weight:600;color:var(--ink-soft);display:flex;align-items:center;gap:6px;cursor:pointer;}
.post-head .name .verified{color:#38b6a8;font-size:15px;}
.post-head .tags{font-size:12.8px;color:var(--muted);}
.post-head .tags b{font-weight:600;}
.post-head .right{margin-left:auto;display:flex;align-items:center;gap:10px;color:var(--muted-3);}
.post-head time{font-size:12px;color:var(--muted-3);white-space:nowrap;}
.post-head .more{font-size:22px;cursor:pointer;color:var(--ink-soft);}

.post-title{font-size:22.5px;font-weight:600;color:var(--ink);margin:16px 0 8px;line-height:1.2;cursor:pointer;}
.post-body{font-size:14px;line-height:1.36;color:var(--ink);}
.post-body p{margin:0 0 12px;}
.post-body .strong{font-weight:700;}
.post-body .cta{font-weight:700;color:var(--ink-soft);}
.post-img{display:block;margin:14px 0 4px;border-radius:12px;max-width:100%;object-fit:cover;background:var(--line-soft);}
/* post image with blurred backdrop filling the full card width */
.post-media{position:relative;margin:14px 0 4px;border-radius:12px;overflow:hidden;height:300px;
  display:flex;align-items:center;justify-content:center;background:var(--nav-bg);}
.post-media::before{content:"";position:absolute;inset:0;
  background-image:inherit;background-size:cover;background-position:center;
  filter:blur(26px) brightness(.95);transform:scale(1.25);}
.post-media img{position:relative;z-index:1;max-width:62%;max-height:100%;border-radius:4px;display:block;
  box-shadow:0 6px 26px rgba(0,0,0,.28);}

.post-foot{display:flex;align-items:center;gap:22px;margin-top:14px;}
.react{display:flex;align-items:center;gap:7px;color:var(--ink-soft);cursor:pointer;font-size:14px;border:none;background:none;}
.react:hover{color:var(--accent-deep);}
.react .material-icons-outlined{font-size:24px;}
.react.liked{color:#0e6f99;font-weight:600;}   /* AA-passing blue for the count text */
.post-foot .spacer{flex:1;}
.view-disc{font-weight:600;color:var(--ink);cursor:pointer;}
.view-disc:hover{color:var(--accent-deep);}

/* ---------- generic section card ---------- */
.section-label{width:var(--card-w);margin:0 auto 14px;font-weight:700;font-size:14px;color:var(--ink);}
.panel{
  width:var(--card-w);margin:0 auto 22px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 28px;
}
.panel h3{margin:0 0 18px;font-size:16px;font-weight:600;color:var(--ink);}
.empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  padding:48px 0;color:var(--muted);font-size:16px;text-align:center;
}
.empty .ill{width:90px;height:90px;border-radius:18px;background:var(--tint-teal);display:flex;align-items:center;justify-content:center;color:#9fd3ce;}
.empty .ill .material-icons-outlined{font-size:46px;}

/* ---------- quick links (column-major, chain icon, underlined) ---------- */
.qlinks{columns:3;column-gap:30px;}
.qlink{display:flex;align-items:flex-start;gap:10px;color:var(--ink-soft);font-weight:600;cursor:pointer;line-height:1.35;break-inside:avoid;margin-bottom:18px;}
.qlink .material-icons-outlined{font-size:20px;color:var(--accent);flex:none;transform:rotate(-45deg);margin-top:1px;}
.qlink span{text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;text-decoration-color:#c8ccd6;}
.qlink:hover span{color:var(--accent-deep);text-decoration-color:var(--accent-deep);}

/* ---------- folders ---------- */
.folder-chip{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:11px 14px;width:270px;max-width:100%;font-weight:600;color:var(--ink);font-size:14px;}
.folder-chip>.material-icons-outlined:first-child{color:var(--muted-3);font-size:21px;}
.folder-chip .info{color:var(--muted-3);font-size:20px;cursor:pointer;}
.files-drop{margin-top:18px;border:1px solid var(--line);border-radius:12px;min-height:250px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--muted);font-size:16px;}
.smiley{width:92px;height:92px;}
.btn-outline-teal{background:var(--surface);border:1.5px solid var(--accent);color:var(--ink);}
.btn-outline-teal:hover{background:var(--tint-teal);}

/* ---------- events ---------- */
.events-toolbar{width:var(--card-w);margin:0 auto 18px;display:flex;align-items:center;gap:14px;}
.month{font-size:18px;font-weight:600;min-width:140px;text-align:center;}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:16px;overflow:hidden;flex:none;}
.seg-btn{width:44px;height:32px;border:none;background:var(--surface);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;}
.seg-btn .material-icons-outlined{font-size:20px;}
.seg-btn+.seg-btn{border-left:1px solid var(--line);}
.seg-btn.active{background:var(--accent);color:var(--on-accent);}
.cal-monthnav{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px;}
.events-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:60px 0;color:var(--muted);font-size:16px;}
.events-empty .material-icons-outlined{font-size:46px;color:#b6bbc7;}
.calendar{width:var(--card-w);margin:0 auto 22px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
.cal-head{text-align:center;font-size:12px;font-weight:600;color:var(--muted);padding:6px 0;}
.cal-cell{aspect-ratio:1/1;border-radius:var(--radius-xs);padding:6px;font-size:13px;color:var(--ink-soft);position:relative;}
.cal-cell.muted{color:#c2c4cc;}
.cal-cell.today{background:var(--tint-teal);color:var(--accent-deep);font-weight:700;}
.cal-cell .ev-dot{position:absolute;bottom:6px;left:6px;width:7px;height:7px;border-radius:50%;background:var(--accent);}
.event-row{width:var(--card-w);margin:0 auto 12px;background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:14px 18px;display:flex;gap:16px;align-items:center;}
.event-date{flex:none;width:54px;text-align:center;}
.event-date .d{font-size:22px;font-weight:800;color:var(--accent-deep);line-height:1;}
.event-date .m{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;}
.event-info .et{font-weight:600;font-size:15px;}
.event-info .em{font-size:13px;color:var(--muted);margin-top:3px;}
/* monthly (no fixed date) badge */
.event-date.monthly{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--accent-deep);}
.event-date.monthly .material-icons-outlined{font-size:20px;}
/* type / location / format tags under an event */
.ev-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}
.ev-tag{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:600;color:var(--muted-2);background:var(--field-bg);border:1px solid var(--line);border-radius:999px;padding:3px 9px;}
.ev-tag .material-icons-outlined{font-size:14px;color:var(--muted-3);}
.ev-register{flex:none;text-decoration:none;display:inline-flex;align-items:center;gap:6px;}
.ev-register .material-icons-outlined{font-size:15px;}
/* Type / Location filter dropdowns in the events toolbar */
.ev-filter{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--ink-soft);}
.ev-filter>.material-icons-outlined{font-size:17px;color:var(--muted-3);}
.ev-filter select{height:34px;border:1px solid var(--line);border-radius:var(--radius-md);padding:0 8px;font:inherit;background:var(--field-bg);color:var(--ink);cursor:pointer;}
@media (max-width:640px){ .events-toolbar{flex-wrap:wrap;} .ev-filter span{display:none;} }

/* ---------- members ---------- */
.member-grid{width:var(--card-w);margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.member-card{background:var(--surface);border-radius:16px;box-shadow:var(--shadow);padding:18px;display:flex;align-items:center;gap:14px;cursor:pointer;}
.member-card:hover{box-shadow:0 4px 18px rgba(15,67,70,.12);}
.member-card img,.member-card .m-av{width:54px;height:54px;border-radius:50%;object-fit:cover;background:var(--avatar-bg);flex:none;}
.member-card .m-info{flex:1;min-width:0;}
.member-card .mname{font-weight:700;font-size:15px;color:var(--ink-soft);display:flex;align-items:center;gap:5px;}
.member-card .mname .verified{color:#38b6a8;font-size:14px;}
.member-card .mrole{font-size:12.8px;color:var(--muted);margin-top:2px;}
.m-line{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--muted);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.m-line .material-icons-outlined{font-size:16px;color:var(--muted-2);flex:none;}
.member-card .btn{margin-left:auto;flex:none;}

/* ---------- conversations ---------- */
.conv-layout{display:flex;height:calc(100vh - var(--chrome-h));}
.conv-list{width:340px;flex:none;border-right:1px solid var(--line);background:var(--surface);overflow-y:auto;}
.conv-list .ch{padding:16px 18px;font-size:18px;font-weight:700;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;}
.conv-item{display:flex;gap:12px;padding:13px 18px;cursor:pointer;border-bottom:1px solid var(--line-soft);align-items:center;}
.conv-item:hover{background:var(--field-bg);}
.conv-item.active{background:var(--tint-teal);}
.conv-item img{width:46px;height:46px;border-radius:50%;object-fit:cover;flex:none;background:var(--avatar-bg);}
.conv-item .ci-main{flex:1;min-width:0;}
.conv-item .ci-top{display:flex;justify-content:space-between;gap:8px;}
.conv-item .ci-name{font-weight:600;font-size:14px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.conv-item .ci-time{font-size:11px;color:var(--muted-2);flex:none;}
.conv-item .ci-prev{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.conv-item .ci-unread{width:9px;height:9px;border-radius:50%;background:var(--accent);flex:none;}
.conv-thread{flex:1;display:flex;flex-direction:column;background:var(--field-bg);}
.thread-head{height:64px;flex:none;background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;padding:0 22px;}
.thread-head img{width:40px;height:40px;border-radius:50%;object-fit:cover;background:var(--avatar-bg);}
.thread-head .tn{font-weight:600;color:var(--ink-soft);}
.thread-head .ts{font-size:12px;color:var(--muted);}
.thread-body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:12px;width:100%;max-width:860px;}
.bubble{max-width:74%;padding:11px 15px;border-radius:16px;font-size:14px;line-height:1.4;}
.bubble.them{background:var(--surface);color:var(--ink);align-self:flex-start;border-bottom-left-radius:5px;box-shadow:var(--shadow);}
.bubble.me{background:var(--accent-deep);color:#fff;align-self:flex-end;border-bottom-right-radius:5px;}
.bubble .bt{display:block;font-size:10.5px;opacity:.7;margin-top:5px;}
.thread-compose{flex:none;background:var(--surface);border-top:1px solid var(--line);padding:12px 18px;display:flex;gap:10px;align-items:center;width:100%;max-width:860px;}
.thread-compose input{flex:1;height:42px;border-radius:21px;border:1px solid var(--line);padding:0 18px;font-family:inherit;font-size:14px;outline:none;background:var(--field-bg);}
.thread-compose .send{width:42px;height:42px;border-radius:50%;border:none;background:var(--accent-deep);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;}

/* ---------- browse groups ---------- */
.browse-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1000px;margin:0 auto;}
.group-card{background:var(--surface);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;}
.group-card .gc-cover{height:90px;background-size:cover;background-position:center;background-color:#cfe9e6;}
.group-card .gc-body{padding:16px;flex:1;display:flex;flex-direction:column;gap:8px;}
.group-card .gc-logo{width:48px;height:48px;border-radius:12px;margin-top:-40px;border:3px solid var(--surface);background:var(--surface);object-fit:cover;}
.group-card .gc-name{font-weight:700;font-size:15px;color:var(--ink);}
.group-card .gc-meta{font-size:12.5px;color:var(--muted);}
.group-card .gc-desc{font-size:13px;color:#444;line-height:1.4;flex:1;}

/* ---------- profile ---------- */
.profile-hero{width:var(--main-w);position:relative;}
.profile-cover{height:200px;background-size:cover;background-position:center;background-color:var(--accent-blue);}
.profile-body{width:var(--card-w);margin:-60px auto 0;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:0 32px 28px;position:relative;}
.profile-body .pavatar{width:116px;height:116px;border-radius:50%;border:5px solid var(--surface);object-fit:cover;margin-top:-58px;background:var(--avatar-bg);}
.profile-body .pname{font-size:24px;font-weight:700;color:var(--ink);margin-top:10px;display:flex;align-items:center;gap:8px;}
.profile-body .prole{color:var(--muted);font-size:14px;margin-top:4px;}
.profile-body .pbio{margin-top:14px;font-size:14px;line-height:1.5;color:var(--ink-soft);}
.profile-stats{display:flex;gap:32px;margin-top:18px;}
.profile-stats .ps .n{font-size:20px;font-weight:800;color:var(--ink);}
.profile-stats .ps .l{font-size:12px;color:var(--muted);}

/* ---------- notifications ---------- */
.notif{width:var(--card-w);margin:0 auto;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;}
.notif-item{display:flex;gap:14px;padding:16px 22px;border-bottom:1px solid var(--line-soft);align-items:flex-start;cursor:pointer;}
.notif-item:hover{background:var(--field-bg);}
.notif-item.unread{background:var(--tint-teal);}
.notif-item img{width:44px;height:44px;border-radius:50%;object-fit:cover;flex:none;background:var(--avatar-bg);}
.notif-item .nt{font-size:14px;color:var(--ink);line-height:1.4;}
.notif-item .nt b{font-weight:700;}
.notif-item .ntime{font-size:12px;color:var(--muted-2);margin-top:4px;}

/* ---------- comments (post detail) ---------- */
.comment{display:flex;gap:12px;margin-bottom:18px;}
.comment img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex:none;background:var(--avatar-bg);}
.comment .cbubble{background:var(--bg);border-radius:var(--radius-md);padding:11px 15px;flex:1;}
.comment .cname{font-weight:600;font-size:14px;color:var(--ink-soft);}
.comment .ctext{font-size:14px;color:var(--ink);margin-top:3px;line-height:1.4;}
.comment .cmeta{font-size:12px;color:var(--muted-2);margin-top:7px;display:flex;gap:16px;}
.comment .cmeta span{cursor:pointer;}
.add-comment{display:flex;gap:12px;align-items:center;margin-top:8px;}
.add-comment img{width:40px;height:40px;border-radius:50%;flex:none;background:var(--avatar-bg);}
.add-comment input{flex:1;height:44px;border-radius:22px;border:1px solid var(--line);padding:0 18px;font-family:inherit;font-size:14px;outline:none;background:var(--field-bg);}

/* ---------- back link ---------- */
.back-link{width:var(--card-w);margin:0 auto 16px;display:flex;align-items:center;gap:6px;color:var(--accent-deep);font-weight:600;cursor:pointer;font-size:14px;}

/* ============================================================
   PUBLIC PAGES (marketing / auth / error)
   ============================================================ */
.public{min-height:100vh;background:var(--surface);}
.pub-nav{height:64px;display:flex;align-items:center;padding:0 40px;gap:14px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--surface);z-index:20;}
.pub-nav .brand{width:auto;}
.pub-nav .spacer{flex:1;}
.pub-nav a{color:var(--ink-soft);font-weight:600;font-size:14px;padding:8px 12px;cursor:pointer;}
.pub-nav a:hover{color:var(--accent-deep);}

.hero{
  padding:90px 40px;text-align:center;
  background:radial-gradient(900px 500px at 50% -10%, var(--tint-teal) 0%, rgba(231,250,248,0) 60%), #fff;
}
.hero h1{font-size:54px;font-weight:800;color:var(--ink);margin:0 auto 20px;max-width:820px;line-height:1.1;}
.hero h1 .grad{background:linear-gradient(90deg,var(--accent-deep),var(--accent-blue));-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero p{font-size:19px;color:var(--muted);max-width:620px;margin:0 auto 32px;line-height:1.5;}
.hero .cta-row{display:flex;gap:14px;justify-content:center;}
.hero .btn{height:48px;padding:0 26px;font-size:16px;border-radius:12px;}

.feature-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;max-width:1080px;margin:10px auto 80px;padding:0 40px;}
.feature{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:28px;}
.feature .fic{width:54px;height:54px;border-radius:var(--radius-md);background:var(--tint-teal);color:var(--accent-deep);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.feature .fic .material-icons-outlined{font-size:28px;}
.feature h3{margin:0 0 8px;font-size:18px;color:var(--ink);}
.feature p{margin:0;font-size:14px;color:var(--muted);line-height:1.5;}

.band{background:#0f3a47;color:#fff;padding:70px 40px;text-align:center;}
.band h2{font-size:34px;margin:0 0 14px;font-weight:800;}
.band p{font-size:17px;opacity:.85;max-width:560px;margin:0 auto 28px;}
.pub-footer{padding:36px 40px;text-align:center;color:var(--muted);font-size:13px;border-top:1px solid var(--line);}

/* auth */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(800px 600px at 50% 0%, var(--tint-teal), #f3f3f5);padding:40px 20px;}
.auth-card{width:420px;max-width:100%;background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 20px 60px rgba(15,67,70,.12);padding:36px 34px;}
.auth-card .brand{justify-content:center;width:auto;margin-bottom:8px;}
.auth-card h2{text-align:center;margin:6px 0 4px;font-size:22px;color:var(--ink);}
.auth-card .sub{text-align:center;color:var(--muted);font-size:14px;margin-bottom:24px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:6px;}
.field input{width:100%;height:44px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:0 14px;font-family:inherit;font-size:14px;outline:none;}
.field input:focus{border-color:var(--accent);}
.auth-card .btn{width:100%;height:46px;font-size:15px;border-radius:var(--radius-sm);margin-top:6px;}
.auth-alt{text-align:center;font-size:13.5px;color:var(--muted);margin-top:20px;}
.auth-alt a{color:var(--accent-deep);font-weight:600;cursor:pointer;}
.auth-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;margin-bottom:18px;}
.auth-row a{color:var(--accent-deep);cursor:pointer;}

/* 403 */
.errpage{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;background:var(--surface);}
.errpage h1{font-size:52px;font-weight:800;color:var(--ink);margin:0;}
.errpage h2{font-size:36px;font-weight:800;color:var(--ink);margin:8px 0 0;}
.errpage p{font-size:20px;color:var(--muted);max-width:520px;margin:18px 0 24px;line-height:1.4;}
.errpage a{font-size:20px;font-weight:600;color:var(--accent-deep);display:inline-flex;align-items:center;gap:8px;cursor:pointer;}

/* ============================================================
   DISCUSSION DRAWER (slides in from right)
   ============================================================ */
.drawer-backdrop{
  position:fixed;inset:0;background:rgba(15,28,68,.38);
  opacity:0;pointer-events:none;transition:opacity .25s;z-index:60;
}
.drawer-backdrop.open{opacity:1;pointer-events:auto;}
.drawer{
  position:fixed;top:0;right:0;height:100vh;width:560px;max-width:94vw;background:var(--surface);
  box-shadow:-8px 0 44px rgba(15,28,68,.20);
  transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
  z-index:61;display:flex;flex-direction:column;
}
.drawer.open{transform:translateX(0);}
.drawer-head{
  height:58px;flex:none;display:flex;align-items:center;gap:12px;padding:0 12px 0 22px;
  border-bottom:1px solid var(--line);font-weight:700;font-size:17px;color:var(--ink);
}
.drawer-head .x{margin-left:auto;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-soft);}
.drawer-head .x:hover{background:var(--bg);}
.drawer-body{flex:1;overflow-y:auto;padding:22px 24px;}
.drawer-body .post-head{margin-bottom:6px;}
.drawer-body .post-title{font-size:20px;margin:14px 0 8px;}
.drawer-body .post-img{width:100% !important;}
.drawer-sep{border:none;border-top:1px solid var(--line);margin:20px 0;}
.drawer-body h3.cc{margin:0 0 18px;font-size:15px;font-weight:700;color:var(--ink);}
.drawer-compose{flex:none;border-top:1px solid var(--line);padding:12px 18px;display:flex;gap:10px;align-items:center;background:var(--surface);}
.drawer-compose img{width:38px;height:38px;border-radius:50%;flex:none;background:var(--avatar-bg);}
.drawer-compose input{flex:1;height:42px;border-radius:21px;border:1px solid var(--line);padding:0 16px;font-family:inherit;font-size:14px;outline:none;background:var(--field-bg);}
.drawer-compose .send{width:42px;height:42px;border-radius:50%;border:none;background:var(--accent-deep);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex:none;}

/* ============================================================
   MESSENGER WIDGET (bottom-right)
   ============================================================ */
.chat-launcher{
  position:fixed;bottom:22px;right:22px;width:56px;height:56px;border-radius:50%;
  background:var(--accent-deep);color:#fff;border:none;cursor:pointer;z-index:71;
  box-shadow:0 6px 20px rgba(15,67,70,.32);display:flex;align-items:center;justify-content:center;transition:transform .12s;
}
.chat-launcher:hover{transform:scale(1.05);}
.chat-launcher .material-icons{font-size:27px;}
.chat-badge{
  position:absolute;top:-2px;right:-2px;min-width:20px;height:20px;padding:0 5px;border-radius:var(--radius-sm);
  background:var(--danger);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface);
}
.chat-window{
  position:fixed;bottom:22px;right:22px;width:328px;height:440px;max-height:72vh;background:var(--surface);
  border-radius:var(--radius-md) 14px 0 0;box-shadow:0 14px 44px rgba(15,28,68,.28);display:flex;flex-direction:column;overflow:hidden;z-index:71;
  animation:chatIn .2s ease;
}
@keyframes chatIn{from{transform:translateY(14px);opacity:0;}to{transform:translateY(0);opacity:1;}}
.chat-win-head{display:flex;align-items:center;gap:10px;padding:10px 10px 10px 12px;border-bottom:1px solid var(--line);cursor:pointer;}
.chat-win-head img{width:38px;height:38px;border-radius:50%;object-fit:cover;background:var(--avatar-bg);}
.cw-name{font-weight:700;font-size:14px;color:var(--ink-soft);}
.cw-status{font-size:11px;color:var(--ok-ink);display:flex;align-items:center;gap:4px;}
.cw-status::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--ok-ink);display:inline-block;}
.cw-x{margin-left:auto;border:none;background:none;cursor:pointer;color:var(--muted-3);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.cw-x:hover{background:var(--bg);}
.cw-x .material-icons{font-size:20px;}
.chat-win-body{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:8px;}
.cbubble{max-width:80%;padding:9px 13px;border-radius:16px;font-size:13.5px;line-height:1.35;}
.cbubble.them{background:var(--bg);color:var(--ink);align-self:flex-start;border-bottom-left-radius:5px;}
.cbubble.me{background:var(--accent-deep);color:#fff;align-self:flex-end;border-bottom-right-radius:5px;}
.chat-win-compose{display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid var(--line);}
.chat-win-compose input{flex:1;height:38px;border-radius:19px;border:1px solid var(--line);padding:0 14px;font-family:inherit;font-size:14px;outline:none;background:var(--field-bg);}
.chat-win-compose button{width:38px;height:38px;border-radius:50%;border:none;background:var(--accent-deep);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex:none;}
.chat-win-compose button .material-icons{font-size:18px;}
.chat-toast{
  position:fixed;bottom:88px;right:22px;width:308px;background:var(--surface);border-radius:12px;
  box-shadow:0 12px 34px rgba(15,28,68,.24);display:flex;gap:10px;align-items:center;padding:12px 12px 12px 14px;cursor:pointer;z-index:71;
  animation:chatIn .25s ease;
}
.chat-toast img{width:44px;height:44px;border-radius:50%;object-fit:cover;flex:none;background:var(--avatar-bg);}
.chat-toast .ct-main{flex:1;min-width:0;}
.ct-name{font-weight:700;font-size:13.5px;color:var(--ink-soft);}
.ct-prev{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ct-x{border:none;background:none;cursor:pointer;color:var(--muted-3);width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none;}
.ct-x:hover{background:var(--bg);}
.ct-x .material-icons{font-size:18px;}

/* ---------- collapsible sidebar → icon rail when minimized ---------- */
:root{ --rail:66px; }
body.nav-collapsed aside.sidebar{width:var(--rail);padding:10px 0;overflow-x:hidden;}
/* keep the "ClassLink Community" wordmark visible in both collapsed and expanded states */
body.nav-collapsed .brand{width:auto;}
/* rail: icons only, labels hidden */
body.nav-collapsed .nav-link{justify-content:center;width:46px;height:46px;padding:0;gap:0;margin:3px auto;}
body.nav-collapsed .nav-link .label,
body.nav-collapsed .nav-link .more{display:none;}
body.nav-collapsed .nav-link .micon,
body.nav-collapsed .nav-link .gicon{margin:0;}
body.nav-collapsed .nav-head{justify-content:center;width:46px;height:30px;padding:0;margin:6px auto 2px;}
body.nav-collapsed .nav-head>span:not(.lead):not(.chevwrap),
body.nav-collapsed .nav-head .chevwrap{display:none;}
body.nav-collapsed .nav-head .lead{margin:0;}
body.nav-collapsed .nav-gap{height:6px;}

.nav-toggle{
  position:fixed;top:62px;left:var(--sidebar-w);width:24px;height:44px;border:none;cursor:pointer;z-index:95;
  background:rgba(255,255,255,.9);color:var(--nav-bg);border-radius:0 10px 10px 0;box-shadow:0 2px 8px rgba(15,28,68,.15);
  display:flex;align-items:center;justify-content:center;transition:left .15s,background .15s;
}
.nav-toggle:hover{background:var(--surface);}
.nav-toggle .material-icons-outlined{font-size:22px;}
body.nav-collapsed .nav-toggle{left:var(--rail);}
body.has-banner .nav-toggle{top:calc(62px + var(--banner-h));}   /* clear the outage banner */

/* responsive-ish */
@media (max-width:1040px){
  :root{--main-w:calc(100vw - var(--sidebar-w));}
  .col,.filterbar,.card,.panel,.section-label,.events-toolbar,.calendar,.event-row,.member-grid,.notif,.back-link{max-width:760px;width:auto;margin-left:auto;margin-right:auto;}
}

/* ============================================================
   IDEAS (Feature Request system)
   ============================================================ */
.persona-bar{display:flex;align-items:center;gap:8px;background:var(--tint-teal);border:1px solid #d6ecea;border-radius:var(--radius-sm);padding:8px 12px;margin-bottom:16px;font-size:13px;color:var(--ink-soft);}
.persona-bar>.material-icons-outlined{font-size:18px;color:var(--accent-deep);}
.pb-label{font-weight:600;}
.pb-select{border:1px solid var(--line);border-radius:var(--radius-xs);padding:5px 9px;font-family:inherit;font-size:13px;background:var(--surface);cursor:pointer;color:var(--ink);}

.ibadge{display:inline-flex;align-items:center;height:22px;padding:0 10px;border-radius:11px;font-size:11.5px;font-weight:600;white-space:nowrap;line-height:1;}
.ibadge.neutral{background:var(--line-soft);color:var(--muted);}
.ibadge.attention{background:var(--warn-tint);color:var(--warn-ink);}
.ibadge.planned{background:var(--info-tint);color:var(--info-ink);}
.ibadge.success{background:var(--ok-tint);color:var(--ok-ink);}
.ibadge.critical{background:var(--danger-tint);color:var(--danger-ink);}
.ibadge.product{background:var(--line-soft);color:var(--muted);}

.ideas-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px;}
.ideas-h1{font-size:24px;font-weight:800;color:var(--ink);margin:0;}
.ideas-sub{font-size:14px;color:var(--muted);margin:6px 0 0;line-height:1.4;}
.section-label2{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted-3);margin:0 0 10px;}

.ideas-controls{display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:14px 16px;}
.ideas-controls select,.tr-status,.sc-status select{border:1px solid var(--line);border-radius:9px;padding:7px 10px;font-family:inherit;font-size:13px;background:var(--surface);cursor:pointer;color:var(--ink);}
.ic-search{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);padding:0 14px;height:38px;flex:1;min-width:180px;}
.ic-search .material-icons-outlined{font-size:18px;color:var(--muted-2);}
.ic-search input{border:none;background:none;outline:none;flex:1;font-family:inherit;font-size:14px;}

.segt{display:inline-flex;border:1px solid var(--line);border-radius:16px;overflow:hidden;flex:none;}
.segt button{padding:7px 14px;border:none;background:var(--surface);color:var(--ink-soft);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;}
.segt button+button{border-left:1px solid var(--line);}
.segt button.on{background:var(--nav-bg);color:#fff;}

.ideas-list{display:flex;flex-direction:column;gap:12px;}
.idea-row{background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:16px;display:flex;gap:16px;align-items:flex-start;}
.ir-main{flex:1;min-width:0;}
.ir-titlerow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.ir-title{font-weight:600;color:var(--ink);cursor:pointer;}
.ir-title:hover{color:var(--accent-deep);}
.ir-ex{font-size:13.5px;color:var(--muted);margin:6px 0 0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.ir-meta{font-size:12px;color:var(--muted-2);margin-top:8px;display:inline-flex;align-items:center;gap:6px;}
.ir-meta .material-icons-outlined{font-size:15px;}

.votebox{display:flex;flex-direction:column;align-items:center;justify-content:center;width:56px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:4px 0;background:var(--surface);flex:none;}
.vb-arrow{border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;width:34px;height:24px;border-radius:6px;padding:0;transition:.12s;}
.vb-arrow .material-icons-outlined{font-size:24px;}
.vb-arrow.up{color:#22a05a;}
.vb-arrow.down{color:#e05353;}
.vb-arrow.up:hover{background:var(--ok-tint);}
.vb-arrow.down:hover{background:var(--danger-tint);}
.vb-arrow.up.on{color:#15803d;background:#dcf5e6;}
.vb-arrow.down.on{color:#c81e1e;background:var(--danger-tint);}
.votebox .vc{font-size:14px;font-weight:700;color:var(--ink);line-height:1.1;}
.votebox.big{width:66px;padding:6px 0;}
.votebox.big .vb-arrow{height:28px;width:40px;}
.votebox.big .vb-arrow .material-icons-outlined{font-size:28px;}
.votebox.big .vc{font-size:18px;}
.votebox .vl{font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);}

.idea-detail .id-top{display:flex;gap:18px;}
.id-main{flex:1;min-width:0;}
.id-title{font-size:23px;font-weight:700;color:var(--ink);margin:8px 0 0;}
.id-byline{font-size:12.5px;color:var(--muted-2);margin:6px 0 0;}
.id-body{font-size:14.5px;color:var(--ink);line-height:1.5;margin:14px 0 0;white-space:pre-wrap;}
.staff-controls{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line-soft);}
.sc-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-3);}
.sc-status{font-size:13px;color:var(--muted);display:inline-flex;align-items:center;gap:8px;}
.sc-danger{color:var(--danger-ink);}
.sc-danger .material-icons-outlined{color:var(--danger-ink);}

.iavatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:#fff;font-weight:700;flex:none;}
.icomment{display:flex;gap:12px;margin-bottom:14px;}
.ic-bubble{background:var(--bg);border-radius:var(--radius-md);padding:10px 14px;flex:1;}
.ic-bubble.official{background:#e8f7f5;border:1px solid #bfe9e4;}
.ic-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted-2);margin-bottom:3px;}
.ic-name{font-weight:600;color:var(--ink-soft);}
.ic-body{font-size:14px;color:var(--ink);margin:0;line-height:1.4;}
.muted-note{font-size:13px;color:var(--muted);}
.ilink{color:var(--accent-deep);font-weight:600;cursor:pointer;}
.cc{font-size:15px;font-weight:700;color:var(--ink);margin:0 0 16px;}

.triage-panel{display:flex;flex-direction:column;}
.triage-row{display:flex;align-items:center;gap:14px;padding:13px 16px;border-bottom:1px solid var(--line-soft);}
.triage-row:last-child{border-bottom:none;}
.tr-votes{width:46px;text-align:center;flex:none;}
.trv-n{font-size:15px;font-weight:700;color:var(--ink);}
.trv-l{font-size:9px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-3);}
.tr-main{flex:1;min-width:0;}

.modal-backdrop{position:fixed;inset:0;background:rgba(15,28,68,.42);z-index:80;}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:520px;max-width:92vw;max-height:84vh;overflow:auto;background:var(--surface);border-radius:16px;box-shadow:0 24px 60px rgba(15,28,68,.3);z-index:81;padding:22px 24px;}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;}
.modal-head h2{font-size:18px;font-weight:700;color:var(--ink);margin:0;}
.modal-head .x{cursor:pointer;color:var(--muted-3);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.modal-head .x:hover{background:var(--bg);}
.modal-sub{font-size:13.5px;color:var(--muted);margin:6px 0 16px;line-height:1.45;}
.merge-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow:auto;}
.merge-cand{display:flex;align-items:center;gap:12px;padding:9px 11px;border:1px solid var(--line-soft);border-radius:var(--radius-sm);cursor:pointer;}
.merge-cand:hover{background:var(--field-bg);}
.mc-title{flex:1;font-size:14px;color:var(--ink);}
.mc-votes{font-size:12px;color:var(--muted);}
.modal-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:18px;}

/* ============================================================
   PROFILE DROPDOWN (top-right)
   ============================================================ */
.profile-wrap{position:relative;}
.profile-menu{position:absolute;top:calc(100% + 8px);right:0;width:266px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:0 14px 36px rgba(15,28,68,.2);padding:10px;z-index:60;display:none;}
.profile-menu.open{display:block;}
.pm-card{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px;cursor:pointer;}
.pm-card:hover{background:var(--field-bg);}
.pm-avatar{width:40px;height:40px;border-radius:50%;background:var(--line-soft);display:flex;align-items:center;justify-content:center;color:var(--muted-3);flex:none;}
.pm-avatar .material-icons-outlined{font-size:24px;}
.pm-name{font-weight:700;font-size:15px;color:var(--ink);}
.pm-sub{font-size:13px;color:var(--muted);}
.pm-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--radius-xs);cursor:pointer;font-weight:600;font-size:14px;color:var(--ink);margin-top:4px;}
.pm-item:hover{background:var(--bg);}
.pm-item .material-icons-outlined{font-size:20px;color:var(--ink-soft);}
.pm-check{margin-left:auto;display:inline-flex;align-items:center;}
.pm-check .material-icons-outlined{color:var(--accent-deep);font-size:19px;}

/* ============================================================
   SETTINGS / PREFERENCES PAGE
   ============================================================ */
.settings-wrap{max-width:1000px;margin:0 auto;}
.settings-title{font-size:24px;font-weight:800;color:var(--ink);margin:6px 0 18px;}
.settings-grid{display:flex;gap:26px;align-items:flex-start;}
.settings-side{width:262px;flex:none;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:12px;position:sticky;top:64px;}
.ss-card{display:flex;align-items:center;gap:12px;padding:4px 4px 14px;border-bottom:1px solid var(--line-soft);}
.ss-id{min-width:0;}
.ss-email{font-size:13px;color:var(--accent-deep);text-decoration:underline;text-underline-offset:2px;cursor:pointer;display:inline-block;}
.ss-link{padding:11px 4px;font-weight:600;font-size:14px;color:var(--ink);cursor:pointer;text-decoration:underline;text-underline-offset:2px;}
.ss-link:hover{color:var(--accent-deep);}
.ss-link.danger{color:var(--danger-ink);}
.ss-link.danger:hover{color:#a13226;}
.settings-main{flex:1;min-width:0;}
.set-block{background:var(--surface);border-radius:16px;box-shadow:var(--shadow);padding:22px 26px;margin-bottom:22px;}
.set-block-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:4px;}
.set-block h2{font-size:20px;font-weight:700;color:var(--ink);margin:0;}
.set-group-label{font-size:13px;color:var(--muted-3);margin:18px 0 6px;}
.set-lead{font-size:14.5px;color:var(--ink);margin:12px 0 2px;}
.set-row{display:flex;align-items:flex-start;gap:16px;padding:7px 0;}
.set-row.indent{padding-left:18px;}
.set-row .sr-text{flex:1;font-size:14.5px;color:var(--ink);line-height:1.5;}
.sr-sub{display:block;color:var(--muted);}
.set-p{font-size:14px;color:var(--ink);margin:8px 0 14px;line-height:1.5;}
.inline-drop{display:inline-flex;align-items:center;gap:1px;font-weight:700;color:var(--ink);cursor:pointer;}
.inline-drop .material-icons-outlined{font-size:18px;color:var(--muted-3);}
.toggle{position:relative;width:42px;height:24px;border-radius:12px;background:#cfd3da;cursor:pointer;flex:none;transition:background .15s;margin-top:2px;}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:var(--surface);transition:left .15s;box-shadow:0 1px 2px rgba(0,0,0,.2);}
.toggle.on{background:#4cc2a0;}
.toggle.on::after{left:21px;}

/* ============================================================
   ADMIN / USER role toggle + admin controls
   ============================================================ */
.role-toggle{position:fixed;left:18px;bottom:20px;z-index:58;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius-md);box-shadow:0 8px 24px rgba(15,28,68,.16);padding:8px 12px;display:flex;align-items:center;gap:10px;}
.role-toggle .rt-label{font-size:12px;font-weight:700;color:var(--muted-3);text-transform:uppercase;letter-spacing:.04em;}

/* feed composer (admin) */
.composer{width:var(--card-w);margin:0 auto 18px;background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow);
  padding:14px 18px;display:flex;align-items:center;gap:12px;cursor:pointer;}
.composer img{width:42px;height:42px;border-radius:50%;object-fit:cover;background:var(--avatar-bg);flex:none;}
.composer .composer-ph{flex:1;color:var(--muted);font-size:14.5px;}
.composer .btn .material-icons-outlined{font-size:16px;}

/* admin edit buttons on group header */
.cover-admin{position:absolute;top:14px;right:18px;z-index:2;display:flex;gap:8px;}
.cover-edit{display:inline-flex;align-items:center;gap:6px;
  height:34px;padding:0 14px;border-radius:9px;border:none;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;
  background:rgba(15,28,68,.55);color:#fff;backdrop-filter:blur(4px);}
.cover-edit:hover{background:rgba(15,28,68,.78);}
.cover-edit .material-icons-outlined{font-size:18px;}
/* edit button on browse cards */
.group-card{position:relative;}
.gc-edit{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:var(--radius-xs);border:none;cursor:pointer;z-index:2;
  background:rgba(15,28,68,.5);color:#fff;display:flex;align-items:center;justify-content:center;}
.gc-edit:hover{background:rgba(15,28,68,.8);}
.gc-edit .material-icons-outlined{font-size:18px;}
/* Zoom integration */
.zoom-connected{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink);margin:8px 0 14px;}
.zoom-check{color:var(--ok-ink);font-size:20px;}
.zoom-dc{margin-left:8px;cursor:pointer;}
.zoom-list{display:flex;flex-direction:column;gap:10px;margin-top:14px;}
.zoom-mtg{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:12px;padding:12px 14px;}
.zm-ic{width:38px;height:38px;border-radius:var(--radius-sm);background:#e7eefe;color:#2563eb;display:flex;align-items:center;justify-content:center;flex:none;}
.zm-main{flex:1;min-width:0;}
.zm-topic{font-weight:600;font-size:14px;color:var(--ink);}
.zm-when{font-size:12.5px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.zoom-oauth{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 0 4px;}
.zoom-logo{width:60px;height:60px;border-radius:16px;background:#2563eb;color:#fff;display:flex;align-items:center;justify-content:center;}
.zoom-logo .material-icons{font-size:34px;}
.zoom-perms{list-style:none;padding:0;margin:6px 0 4px;display:flex;flex-direction:column;gap:8px;width:100%;max-width:340px;}
.zoom-perms li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ink);}
.zoom-perms .material-icons-outlined{color:var(--ok-ink);font-size:19px;}

/* letter avatars for custom groups */
.gicon-letter{display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:12px;text-transform:uppercase;}
.gc-logo-letter{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:20px;text-transform:uppercase;}

/* browse header */
.browse-head{max-width:1000px;margin:8px auto 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.browse-head h1{font-size:26px;font-weight:800;color:var(--ink);margin:0;}

/* cover preset swatches */
.cover-swatches{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.cover-swatch{height:64px;border-radius:var(--radius-sm);border:2px solid var(--line);cursor:pointer;background-size:cover;background-position:center;}
.cover-swatch:hover{border-color:var(--accent);}

/* group color swatches */
.color-swatches{display:flex;flex-wrap:wrap;gap:10px;}
.color-swatch{width:34px;height:34px;border-radius:50%;border:2px solid transparent;cursor:pointer;box-shadow:0 0 0 1px var(--line);}
.color-swatch.on{border-color:#fff;box-shadow:0 0 0 2px var(--ink);}

/* ============================================================
   FROZEN GROUP HEADER (cover/tabs frozen, content scrolls)
   ============================================================ */
.group-page{height:calc(100vh - var(--chrome-h));display:flex;flex-direction:column;}
.group-frozen{flex:none;background:var(--bg);}
.gf-controls{padding-top:16px;}
.group-scroll{flex:1;overflow-y:auto;}
.group-scroll>.page-pad{padding-top:12px;}

/* ============================================================
   HOME / DASHBOARD
   ============================================================ */
.home-wrap{max-width:1080px;margin:0 auto;}
/* Page head — solid card on the neutral canvas (gradient stays on the rail) */
.home-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;overflow:hidden;
  background:var(--card);border:1px solid var(--line);color:var(--ink);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:26px 30px;margin-bottom:20px;}
.home-hero h1{margin:0;font-size:24px;font-weight:800;letter-spacing:-.01em;color:var(--ink);}
.home-hero p{margin:6px 0 0;font-size:15px;color:var(--muted);}
.home-hero .btn{flex:none;}
/* ClassLink cloud — recolour the white logo art to brand navy via an alpha mask
   (the figure stays a transparent cutout, so the card shows through it), wordmark
   cropped off by the cover/top geometry. Flips to a light fill in dark mode. */
.home-hero .hero-logo{
  width:178px;height:128px;flex:none;display:block;background:var(--accent);mix-blend-mode:normal;
  -webkit-mask:url(cllogo.png) center top / cover no-repeat;
          mask:url(cllogo.png) center top / cover no-repeat;
}
html.dark .home-hero .hero-logo{background:#dbe6f3;}
@media (max-width:640px){ .home-hero .hero-logo{width:124px;height:90px;} }
.home-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;}
.home-tile{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);
  box-shadow:var(--shadow);padding:16px;cursor:pointer;text-align:left;font-family:inherit;transition:.12s;}
.home-tile:hover{transform:translateY(-2px);border-color:var(--accent);}
.home-tile .ht-ic{width:42px;height:42px;border-radius:11px;background:var(--tint-teal);color:var(--accent-deep);display:flex;align-items:center;justify-content:center;flex:none;}
.home-tile .ht-ic .material-icons-outlined{font-size:24px;}
.ht-label{font-weight:700;font-size:14.5px;color:var(--ink);}
.ht-sub{font-size:12.5px;color:var(--muted);margin-top:2px;}
.home-grid{display:grid;grid-template-columns:1fr 340px;gap:22px;align-items:start;}
.home-sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.home-sec-head h2{font-size:17px;font-weight:700;color:var(--ink);margin:0;}
.ann-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.ann-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:16px;cursor:pointer;transition:.12s;}
.ann-card:hover{border-color:var(--accent);transform:translateY(-2px);}
.ann-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.ann-time{font-size:11.5px;color:var(--muted-2);}
.ann-title{font-weight:700;font-size:15px;color:var(--ink);line-height:1.3;}
.ann-ex{font-size:13px;color:var(--muted);line-height:1.45;margin:8px 0 12px;}
.ann-by{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);}
.ann-by img{width:24px;height:24px;border-radius:50%;object-fit:cover;background:var(--avatar-bg);}
.home-posts{display:flex;flex-direction:column;gap:10px;}
.home-post{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:12px 14px;cursor:pointer;}
.home-post:hover{border-color:var(--accent);}
.hp-av{width:40px;height:40px;border-radius:50%;object-fit:cover;flex:none;background:var(--avatar-bg);}
.hp-title{font-weight:600;font-size:14px;color:var(--ink);}
.hp-meta{font-size:12px;color:var(--muted-2);margin-top:3px;display:flex;align-items:center;gap:5px;}
.hp-meta .material-icons-outlined{font-size:14px;}
.home-side{display:flex;flex-direction:column;gap:18px;}
/* highlight card — soft info surface (no content gradient) */
.topidea{background:var(--info-tint);border:1px solid var(--line);color:var(--ink);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow);}
.ti-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--info-ink);}
.ti-label .material-icons-outlined{font-size:18px;}
.ti-title{font-size:17px;font-weight:700;margin:10px 0;cursor:pointer;line-height:1.3;color:var(--ink);}
.ti-badges{display:flex;gap:6px;flex-wrap:wrap;}
.ti-foot{display:flex;align-items:center;justify-content:space-between;margin-top:14px;}
.ti-votes{display:flex;align-items:baseline;gap:5px;}
.tiv-n{font-size:26px;font-weight:800;color:var(--accent-deep);}
.tiv-l{font-size:12px;color:var(--muted);}
.home-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:18px 20px;}
.home-event{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--line-soft);}
.home-event:last-child{border-bottom:none;}
.he-date{width:46px;text-align:center;flex:none;}
.he-d{font-size:19px;font-weight:800;color:var(--accent-deep);line-height:1;}
.he-m{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--muted);}
.he-t{font-weight:600;font-size:14px;color:var(--ink);}
.he-m2{font-size:12px;color:var(--muted);margin-top:2px;}
@media (max-width:980px){
  .home-grid{grid-template-columns:1fr;}
  .home-tiles{grid-template-columns:repeat(2,1fr);}
  .ann-grid{grid-template-columns:1fr;}
}

/* ============================================================
   PROFILE MODAL
   ============================================================ */
.modal.modal-wide{width:660px;}
.pf-head{display:flex;align-items:center;gap:14px;padding:4px 0 14px;}
.pf-avatar{width:56px;height:56px;}
.pf-avatar .material-icons-outlined{font-size:32px;}
.pf-name{font-size:22px;font-weight:700;color:var(--ink);margin:0;}
.pf-x{margin-left:auto;}
.pf-tabs{display:flex;gap:26px;border-bottom:1px solid var(--line);margin-bottom:18px;justify-content:center;}
.pf-tab{padding:10px 2px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;}
.pf-tab:hover{color:var(--ink);}
.pf-tab.active{color:var(--ink);border-bottom-color:var(--accent);}
.pf-card{background:var(--field-bg);border:1px solid var(--line);border-radius:12px;padding:16px 18px;}
.pf-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.pf-card-title{font-weight:700;font-size:15px;color:var(--ink);}
.pf-edit{color:var(--muted-2);cursor:pointer;font-size:20px;}
.pf-details{display:flex;flex-direction:column;gap:12px;}
.pf-drow{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.pf-k{display:inline-flex;align-items:center;gap:9px;font-size:14px;color:var(--ink);}
.pf-k .material-icons-outlined{font-size:19px;color:var(--muted-2);}
.pf-addk{color:var(--muted);}
.pf-addk a{color:var(--accent-deep);text-decoration:underline;text-underline-offset:2px;cursor:pointer;}
.pf-joined{font-size:14px;color:var(--ink);padding:16px 2px;border-bottom:1px solid var(--line-soft);}
.pf-field{padding:14px 2px;}
.pf-label{font-size:13px;font-weight:700;color:var(--ink-soft);display:flex;align-items:center;gap:6px;}
.pf-label .material-icons-outlined,.pf-inline-ic{font-size:15px;color:var(--accent-deep);}
.pf-val{font-size:14px;color:var(--ink);margin-top:5px;}
.pf-add-link{display:inline-block;margin-top:5px;font-size:14px;color:var(--accent-deep);text-decoration:underline;text-underline-offset:2px;cursor:pointer;}
.pf-badges{display:flex;flex-direction:column;gap:12px;}
.pf-badge{display:flex;align-items:center;gap:14px;background:var(--field-bg);border:1px solid var(--line);border-radius:12px;padding:14px 16px;}
.pf-badge-ic{width:42px;height:42px;border-radius:11px;background:var(--tint-teal);color:var(--accent-deep);display:flex;align-items:center;justify-content:center;flex:none;}
.pf-badge-name{font-weight:700;font-size:14.5px;color:var(--ink);}
.pf-badge-sub{font-size:12.5px;color:var(--muted);margin-top:2px;}
.pf-acts{display:flex;flex-direction:column;gap:4px;}
.pf-act{display:flex;align-items:flex-start;gap:12px;padding:11px 4px;border-bottom:1px solid var(--line-soft);}
.pf-act:last-child{border-bottom:none;}
.pf-act-ic{width:34px;height:34px;border-radius:50%;background:var(--bg);color:var(--ink-soft);display:flex;align-items:center;justify-content:center;flex:none;}
.pf-act-ic .material-icons-outlined{font-size:18px;}
.pf-act-txt{font-size:14px;color:var(--ink);}
.pf-act-when{font-size:12px;color:var(--muted-2);margin-top:2px;}

/* home: top-ideas ranked list */
.ti-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line-soft);cursor:pointer;}
.ti-row:last-child{border-bottom:none;}
.ti-row:hover .ti-row-title{color:var(--accent-deep);}
.ti-rank{width:22px;height:22px;border-radius:50%;background:var(--line-soft);color:var(--muted);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex:none;}
.ti-row-main{flex:1;min-width:0;}
.ti-row-title{font-weight:600;font-size:13.5px;color:var(--ink);line-height:1.3;}
.ti-row-sub{font-size:11.5px;color:var(--muted);margin-top:2px;}
.ti-row-votes{display:inline-flex;align-items:center;gap:1px;font-weight:700;font-size:13px;color:var(--accent-deep);flex:none;}
.ti-row-votes .material-icons-outlined{font-size:18px;}

/* ============================================================
   INVITE NEW USER
   ============================================================ */
.email-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center;border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 10px;min-height:46px;}
.email-chips input{border:none;outline:none;flex:1;min-width:170px;font-family:inherit;font-size:14px;padding:4px;}
.email-chip{display:inline-flex;align-items:center;gap:6px;background:var(--tint-teal);color:var(--accent-deep);border-radius:16px;padding:5px 6px 5px 12px;font-size:13px;font-weight:600;}
.ec-x{cursor:pointer;display:inline-flex;width:18px;height:18px;border-radius:50%;align-items:center;justify-content:center;background:rgba(15,125,119,.16);}
.ec-x .material-icons{font-size:13px;}
.join-link-row{display:flex;gap:10px;align-items:center;}
.join-link-row input{flex:1;height:42px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:0 14px;font-family:inherit;font-size:13px;color:var(--ink-soft);background:var(--field-bg);}
.invite-sent{text-align:center;padding:40px 28px;}
.invite-check{width:64px;height:64px;border-radius:50%;background:#e8f7ee;color:var(--ok-ink);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;}
.invite-check .material-icons-outlined{font-size:34px;}
.invite-sent h2{margin:0 0 6px;font-size:20px;color:var(--ink);}
.invite-sent p{color:var(--muted);margin:0 0 16px;}
.invite-sent-emails{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:20px;}

/* editable status select (admins/staff) on idea rows */
.released-on{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:700;color:var(--ok-ink);background:var(--ok-tint);border:1px solid var(--line);border-radius:999px;padding:2px 9px;white-space:nowrap;}
.released-on .material-icons-outlined{font-size:14px;}
.row-status{border:1px solid var(--line);border-radius:11px;height:22px;font-size:11.5px;font-weight:600;padding:0 6px;cursor:pointer;font-family:inherit;color:var(--muted);background:var(--surface);text-align:center;text-align-last:center;}
.row-status.neutral{background:var(--line-soft);color:var(--muted);border-color:var(--line);}
.row-status.attention{background:var(--warn-tint);color:var(--warn-ink);border-color:#f3e2c0;}
.row-status.planned{background:var(--info-tint);color:var(--info-ink);border-color:#cfe8f5;}
.row-status.success{background:var(--ok-tint);color:var(--ok-ink);border-color:#cdeed8;}
.row-status.critical{background:var(--danger-tint);color:var(--danger-ink);border-color:#f3d2d2;}

/* ============================================================
   GLOBAL TOOLTIP
   ============================================================ */
.tooltip{position:fixed;z-index:200;transform:translate(-50%,-100%) translateY(-9px);
  background:var(--ink);color:#fff;font-size:12px;font-weight:600;line-height:1.3;padding:6px 10px;border-radius:var(--radius-xs);
  max-width:240px;text-align:center;white-space:normal;pointer-events:none;opacity:0;transition:opacity .12s ease;
  box-shadow:0 6px 18px rgba(15,28,68,.28);}
.tooltip.show{opacity:1;}
.tooltip::after{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--ink);}
.tooltip.below{transform:translate(-50%,9px);}
.tooltip.below::after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:var(--ink);}

/* ============================================================
   SMALL SCREENS — force the sidebar to an icon rail so content fits
   ============================================================ */
@media (max-width:760px){
  aside.sidebar{width:var(--rail);padding:10px 0;overflow-x:hidden;}
  aside.sidebar .nav-link{justify-content:center;width:46px;height:46px;padding:0;gap:0;margin:3px auto;}
  aside.sidebar .nav-link .label,aside.sidebar .nav-link .more{display:none;}
  aside.sidebar .nav-head{justify-content:center;width:46px;height:30px;padding:0;margin:6px auto 2px;}
  aside.sidebar .nav-head>span:not(.lead):not(.chevwrap),aside.sidebar .nav-head .chevwrap{display:none;}
  aside.sidebar .nav-gap{height:6px;}
  .nav-toggle{display:none;}            /* always rail on small screens */
  .brand h3{display:none;}
  .brand{width:auto;}
  .search{width:auto;max-width:none;left:auto;right:96px;transform:none;position:absolute;}
  .topbar .icons{position:relative;z-index:2;}
  .home-tiles{grid-template-columns:1fr;}
  .conv-list{width:100%;}
  .conv-thread{display:none;}           /* mobile: show conversation list first */
}
@media (max-width:520px){
  .search{display:none;}
  .ann-grid{grid-template-columns:1fr;}
}

/* ============================================================
   JOIN COMMUNITY modal + community group cards
   ============================================================ */
.join-head{display:flex;align-items:center;gap:12px;padding:2px 0 4px;}
.join-head h2{font-size:20px;font-weight:700;color:var(--ink);margin:0;}
.join-logo{width:34px;height:34px;border-radius:9px;overflow:hidden;flex:none;display:flex;align-items:center;justify-content:center;background:var(--nav-bg);}
.join-logo img{width:100%;height:100%;object-fit:cover;}
.join-sep{border:none;border-top:1px solid var(--line);margin:8px 0 18px;}
.phone-row{display:flex;gap:8px;}
.phone-cc{flex:none;width:92px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:0 8px;font-family:inherit;font-size:14px;background:var(--surface);cursor:pointer;}
.phone-row input{flex:1;}
.gc-joined{color:var(--ok-ink);font-weight:700;display:inline-flex;align-items:center;gap:2px;}
.gc-joined .material-icons-outlined{font-size:15px;}

/* profile detail rows (read mode) */
.pf-frow{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--line-soft);}
.pf-frow:last-child{border-bottom:none;}
.pf-fk{display:inline-flex;align-items:center;gap:9px;font-size:13.5px;color:var(--muted);}
.pf-fk .material-icons-outlined{font-size:18px;color:var(--muted-2);}
.pf-fv{font-size:14px;color:var(--ink);font-weight:600;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%;}
.pf-edit .field{margin-bottom:14px;}

/* community join: pending + request-sent info */
.gc-pending{color:var(--warn-ink);font-weight:700;display:inline-flex;align-items:center;gap:2px;}
.gc-pending .material-icons-outlined{font-size:15px;}
.req-info{background:var(--field-bg);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:4px;}
.req-info>div{display:flex;justify-content:space-between;gap:12px;font-size:13.5px;color:var(--ink);padding:3px 0;}
.req-info>div span{color:var(--muted);}

/* community tag on home "Latest across your communities" */
.comm-tag{display:inline-flex;align-items:center;gap:4px;background:var(--tint-teal);color:var(--accent-deep);font-weight:700;font-size:11px;padding:2px 8px;border-radius:var(--radius-sm);}
.comm-tag .material-icons-outlined{font-size:13px;}
.hp-meta{flex-wrap:wrap;}

/* ============================================================
   SSO LOGIN + REGION PICKER
   ============================================================ */
.auth-sso{text-align:center;}
.auth-sso .brand{justify-content:center;width:auto;margin-bottom:6px;}
.sso-btn{width:100%;height:46px;margin-top:18px;font-size:15px;}
.auth-note{display:flex;align-items:center;justify-content:center;gap:7px;font-size:12.5px;color:var(--muted);margin-top:16px;}
.auth-note .material-icons-outlined{font-size:16px;color:var(--accent-deep);}
.region-card{width:520px;max-width:94vw;background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 20px 60px rgba(15,67,70,.12);padding:34px 34px 30px;text-align:center;}
.region-logo{width:48px;height:48px;border-radius:12px;margin:0 auto 12px;display:block;}
.region-card h2{font-size:22px;margin:0 0 6px;color:var(--ink);}
.region-card .sub{color:var(--muted);font-size:14px;margin-bottom:22px;line-height:1.5;}
.region-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:22px;}
.region-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:16px 8px;border:1.5px solid var(--line);border-radius:12px;background:var(--surface);cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;color:var(--ink);transition:.12s;}
.region-btn .material-icons-outlined{font-size:22px;color:var(--muted-2);}
.region-btn:hover{border-color:var(--accent);}
.region-btn.on{border-color:var(--accent);background:var(--tint-teal);color:var(--accent-deep);}
.region-btn.on .material-icons-outlined{color:var(--accent-deep);}
.region-continue{width:100%;height:46px;font-size:15px;}
@media (max-width:520px){ .region-grid{grid-template-columns:1fr 1fr;} }

/* ============================================================
   MODERATION + AUDIT
   ============================================================ */
.mod-row{display:flex;gap:16px;align-items:flex-start;padding:14px 18px;border-bottom:1px solid var(--line-soft);}
.mod-row:last-child{border-bottom:none;}
.mod-main{flex:1;min-width:0;}
.mod-meta{font-size:12.5px;color:var(--muted-2);margin-bottom:5px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.mod-text{font-size:14px;color:var(--ink);line-height:1.45;}
.mod-actions{display:flex;gap:8px;flex:none;}
.audit-row{display:flex;gap:14px;align-items:flex-start;padding:13px 18px;border-bottom:1px solid var(--line-soft);}
.audit-row:last-child{border-bottom:none;}
.audit-ic{width:34px;height:34px;border-radius:50%;background:var(--bg);color:var(--ink-soft);display:flex;align-items:center;justify-content:center;flex:none;}
.audit-ic .material-icons-outlined{font-size:18px;}
.audit-main{flex:1;min-width:0;}
.audit-line{font-size:14px;color:var(--ink);}
.audit-target{color:var(--accent-deep);font-weight:600;}
.audit-detail{font-size:12.5px;color:var(--muted);margin-top:2px;}
.audit-when{font-size:12px;color:var(--muted-2);flex:none;white-space:nowrap;}
.m-admin{display:flex;gap:6px;margin-left:auto;flex:none;}
.member-card.is-excluded{opacity:.6;}

/* ============================================================
   RICH-TEXT COMPOSER + POST MENU + BROADCAST
   ============================================================ */
.rt-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:2px;border:1px solid var(--line);border-bottom:none;border-radius:var(--radius-sm) 10px 0 0;padding:6px 8px;background:var(--field-bg);}
.rt-btn{width:32px;height:30px;border:none;background:none;border-radius:6px;cursor:pointer;color:var(--ink-soft);display:inline-flex;align-items:center;justify-content:center;font-size:15px;}
.rt-btn:hover{background:var(--line-soft);}
.rt-btn .material-icons-outlined{font-size:19px;}
.rt-emoji{font-size:16px;}
.rt-sep{width:1px;height:20px;background:var(--line);margin:0 4px;}
.rt-editor{border:1px solid var(--line);border-radius:0 0 10px 10px;padding:12px 14px;min-height:150px;font-size:14px;line-height:1.5;outline:none;overflow-y:auto;max-height:320px;}
.rt-editor:empty:before{content:attr(data-ph);color:var(--muted-3);}
.rt-editor h1{font-size:20px;margin:.4em 0;}
.rt-editor h2{font-size:17px;margin:.4em 0;}
.rt-editor img{max-width:100%;border-radius:var(--radius-xs);}
.bc-toggle{display:flex;align-items:center;gap:8px;font-weight:600;cursor:pointer;}
.bc-list{margin-top:10px;display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--field-bg);}
.bc-opt{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink);cursor:pointer;}
.bc-note{display:flex;align-items:center;gap:6px;}
.bc-note .material-icons-outlined{font-size:15px;color:var(--accent-deep);}
.menu-list{display:flex;flex-direction:column;gap:2px;margin-top:6px;}
.menu-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border:none;background:none;border-radius:var(--radius-xs);cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;color:var(--ink);text-align:left;width:100%;}
.menu-item:hover{background:var(--bg);}
.menu-item .material-icons-outlined{font-size:20px;color:var(--ink-soft);}
.menu-item.danger{color:var(--danger-ink);}
.menu-item.danger .material-icons-outlined{color:var(--danger-ink);}
.pin-badge{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;color:var(--accent-deep);background:var(--tint-teal);border-radius:var(--radius-sm);padding:2px 8px;margin-right:6px;}
.pin-badge .material-icons-outlined{font-size:14px;}


/* ============================================================
   ACCESSIBILITY & RESPONSIVE
   tokens · focus · skip-link · live region · toasts · validation ·
   touch targets · safe-area · mobile · reduced-motion · forced-colors
   ============================================================ */
:root{
  --radius-sm:6px; --radius-md:8px; --radius-lg:14px;
  --elev-1:0 1px 2px rgba(10,77,127,.08);
  --elev-2:0 4px 12px -2px rgba(10,77,127,.12);
  --elev-3:0 16px 38px -10px rgba(10,77,127,.22);
  --elev-4:0 24px 60px -12px rgba(10,77,127,.26);
  --danger:#d92d20;
}

/* visible keyboard focus on every interactive element (WCAG 2.4.7) */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible,
textarea:focus-visible, [tabindex]:focus-visible, [role="button"]:focus-visible,
.nav-link:focus-visible, .tab:focus-visible, .post-title:focus-visible{
  outline:3px solid var(--accent-deep); outline-offset:2px; border-radius:6px;
}
aside.sidebar .nav-link:focus-visible, aside.sidebar .nav-head:focus-visible{ outline-color:#0a3052; }
html.dark aside.sidebar .nav-link:focus-visible, html.dark aside.sidebar .nav-head:focus-visible{ outline-color:#bfe0fb; }

/* skip link */
.skip-link{position:fixed;left:8px;top:-56px;z-index:3000;background:var(--nav-bg,var(--nav-bg));color:#fff;padding:10px 16px;border-radius:var(--radius-xs);font-weight:700;text-decoration:none;transition:top .15s;}
.skip-link:focus{top:8px;}

/* keep focused content clear of the fixed top bar (WCAG 2.4.11).
   NB: not applied to .group-scroll — its frozen header is a separate stacked
   element, so padding there only yanks the scroll when a control is focused. */
html{scroll-padding-top:64px;}

/* placeholder text meets AA contrast */
input::placeholder,textarea::placeholder{color:var(--muted-3);opacity:1;}

/* screen-reader-only utility (live region) */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* toast / system-status feedback */
#toast-root{position:fixed;left:50%;bottom:calc(26px + env(safe-area-inset-bottom));transform:translateX(-50%);z-index:4000;display:flex;flex-direction:column;align-items:center;gap:10px;pointer-events:none;}
.toast{display:flex;align-items:center;gap:10px;background:var(--toast-bg);color:#fff;padding:12px 16px;border-radius:12px;box-shadow:var(--elev-3);font-size:14px;font-weight:600;max-width:90vw;opacity:0;transform:translateY(12px);transition:opacity .25s,transform .25s;pointer-events:auto;}
.toast.show{opacity:1;transform:translateY(0);}
.toast .material-icons,.toast .material-icons-outlined{font-size:20px;color:#5fe0d4;flex:none;}
.toast-undo{margin-left:6px;background:none;border:1px solid rgba(255,255,255,.4);color:#fff;font-weight:700;font-size:13px;border-radius:var(--radius-xs);padding:5px 12px;cursor:pointer;min-height:32px;}
.toast-undo:hover{background:rgba(255,255,255,.12);}

/* invalid form field */
.field input.invalid,.field textarea.invalid,input.invalid,textarea.invalid{border-color:var(--danger)!important;box-shadow:0 0 0 3px rgba(217,45,32,.14);}

/* danger button (confirm dialogs) */
.btn-danger{background:var(--danger);color:#fff;border:1px solid var(--danger);}
.btn-danger:hover{background:#b42318;}

/* profile completion meter */
.pf-meter{background:var(--info-tint);border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:14px;}
.pf-meter-top{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:700;color:var(--ink,var(--ink));margin-bottom:8px;}
.pf-meter-bar{height:8px;border-radius:6px;background:#e4e8ef;overflow:hidden;}
.pf-meter-bar span{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--accent-deep),var(--accent));transition:width .4s ease;}

/* touch targets — ≥44px hit area (WCAG 2.5.8 + HIG); icon glyphs stay visually small via padding */
.icon-btn{min-width:44px;min-height:44px;}
.btn-sm{min-height:40px;}
.seg-btn,.segt button{min-height:44px;}
.vb-arrow{min-height:40px;min-width:40px;}
.rt-btn{min-width:40px;min-height:40px;}
.row-status,.tr-status{min-height:36px;}
.drawer-head .x,.modal-head .x,.pf-x,.cw-x,.help-back,.help-x{min-width:44px;min-height:44px;}
.ct-x,.fs-clear{min-width:36px;min-height:36px;}
.ec-x{min-width:28px;min-height:28px;}
.crumb{display:inline-flex;align-items:center;min-height:32px;}
.pb-select,.ideas-controls select,.sc-status select{min-height:40px;}
.react{min-height:36px;}
.ss-link{min-height:44px;display:flex;align-items:center;}

/* fixed/sticky chrome respects the notch + home indicator */
header.topbar{padding-left:max(18px,env(safe-area-inset-left));padding-right:max(14px,env(safe-area-inset-right));}
.chat-launcher{bottom:max(22px,env(safe-area-inset-bottom));right:max(22px,env(safe-area-inset-right));}
.chat-window{bottom:max(22px,env(safe-area-inset-bottom));}
.chat-menu{bottom:calc(92px + env(safe-area-inset-bottom));}
.role-toggle{bottom:max(20px,env(safe-area-inset-bottom));left:max(18px,env(safe-area-inset-left));}

/* dynamic viewport height so mobile browser chrome doesn't clip */
.group-page{height:calc(100dvh - var(--header-h,64px));}
.conv-layout,.public,.auth-wrap,.errpage{min-height:100dvh;}

/* tablet / phone */
@media (max-width:768px){
  input,textarea,select{font-size:16px;}                 /* prevents iOS auto-zoom */
  .icon-btn,.btn,.btn-sm,.seg-btn,.segt button,.vb-arrow,.tab,.rt-btn,
  .row-status,.tr-status,.drawer-head .x,.modal-head .x,.cw-x,.nav-link{min-height:44px;}
  .icon-btn,.drawer-head .x,.modal-head .x,.cw-x{min-width:44px;}
  .topbar .icons{gap:8px;}
  .modal,.modal-wide{width:100%;max-width:none;height:100dvh;max-height:none;border-radius:0;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);}
  .drawer{width:100%;max-width:none;}
  .drawer-compose,.chat-win-compose{padding-bottom:calc(10px + env(safe-area-inset-bottom));}
  /* on phones, show only the most-recent chat window, full-screen */
  .chat-window{width:100vw;height:100dvh;max-height:none;inset:0;right:0!important;left:0!important;border-radius:0;}
  .chat-window:not(:first-of-type){display:none;}
  .chat-menu{right:12px!important;left:12px!important;width:auto;}
  .settings-grid{flex-direction:column;}
  .settings-side{width:auto;}
  .browse-grid{grid-template-columns:1fr;}
}

/* phone */
@media (max-width:480px){
  .home-tiles{grid-template-columns:1fr 1fr;}
  .home-grid,.browse-grid,.member-grid{grid-template-columns:1fr;}
  .cover{padding-left:20px;padding-right:20px;}
  .tabs{padding:0 12px;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .page-pad{padding-left:14px;padding-right:14px;}
}

/* respect reduced-motion (WCAG 2.3.3) */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important;}
}

/* Windows High Contrast / forced colors — non-color signifiers */
@media (forced-colors: active){
  a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,
  textarea:focus-visible,[tabindex]:focus-visible,[role="button"]:focus-visible{outline:3px solid Highlight;outline-offset:2px;}
  .nav-link.active,.tab.active,.vb-arrow.up.on,.vb-arrow.down.on{outline:2px solid Highlight;}
  .toggle,.btn-danger,.toast{border:1px solid CanvasText;}
  .ci-unread,.dot,.cw-status::before{outline:1px solid CanvasText;}
  .pf-meter-bar span{background:Highlight;}
}

/* ============================================================
   BREADCRUMBS + REACTIONS
   ============================================================ */
.crumbs{display:flex;align-items:center;flex-wrap:wrap;gap:2px;font-size:12.5px;margin:0 0 14px;}
.crumb{color:var(--muted-2);cursor:pointer;text-decoration:none;}
.crumb:hover{color:var(--accent-deep);text-decoration:underline;}
.crumb-sep{display:inline-flex;color:#9aa0ad;}
.crumb-sep .material-icons-outlined{font-size:16px;}
.crumb-current{color:var(--ink,var(--ink));font-weight:600;}
/* breadcrumb sits inside the frozen group header, above the cover */
.group-crumbs{padding:10px 44px 2px;}

/* filled thumb-up icon parity (Facebook/Teams-style like) */
.react .material-icons{font-size:24px;}
.react.liked .material-icons{color:var(--accent-blue);}

/* reaction footer in the discussion drawer */
.drawer-foot{display:flex;align-items:center;gap:18px;margin:8px 0 2px;}
.react-static{display:inline-flex;align-items:center;gap:7px;color:var(--muted-2);font-size:14px;}
.react-static .material-icons-outlined{font-size:22px;}

/* like a comment (visual toggle) */
.cmeta-act{display:inline-flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:inherit;font:inherit;padding:4px 2px;min-height:24px;}
.cmeta-act .material-icons,.cmeta-act .material-icons-outlined{font-size:15px;}
.cmeta-act:hover{color:var(--accent-deep);}
.cmeta-act.on{color:#0e6f99;font-weight:700;}

@media (max-width:480px){ .group-crumbs{padding-left:16px;padding-right:16px;} }

/* ============================================================
   MESSENGER — conversation picker (multi-window)
   ============================================================ */
.chat-menu{
  position:fixed;right:22px;bottom:92px;width:320px;max-height:60vh;background:var(--surface);z-index:72;
  border-radius:var(--radius-md);box-shadow:var(--elev-3);overflow:hidden;display:flex;flex-direction:column;
  animation:chatIn .18s ease;
}
.chat-menu-head{font-weight:800;font-size:16px;padding:14px 16px 10px;color:var(--ink,var(--ink));}
.chat-menu-list{overflow-y:auto;}
.chat-menu-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;}
.chat-menu-item:hover{background:var(--bg);}
.chat-menu-item.is-open{background:#eaf6fb;}
.chat-menu-item img{width:42px;height:42px;border-radius:50%;object-fit:cover;flex:none;background:var(--avatar-bg);}
.chat-menu-item .cm-main{flex:1;min-width:0;}
.chat-menu-item .cm-name{font-weight:600;font-size:14px;color:var(--ink-soft,var(--ink));}
.chat-menu-item .cm-prev{font-size:12.5px;color:var(--muted-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chat-menu-item .ci-unread{width:9px;height:9px;border-radius:50%;background:var(--accent-blue);flex:none;}

/* ============================================================
   GROUP FEED SEARCH
   ============================================================ */
.feed-search{display:flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);padding:0 6px 0 12px;height:38px;min-width:200px;max-width:280px;}
.feed-search .material-icons-outlined{font-size:18px;color:var(--muted-2);flex:none;}
.feed-search input{border:none;background:none;outline:none;font-family:inherit;font-size:14px;flex:1;min-width:0;}
.fs-clear{border:none;background:none;cursor:pointer;color:var(--muted-2);display:flex;align-items:center;justify-content:center;padding:0;width:24px;height:24px;border-radius:50%;flex:none;}
.fs-clear .material-icons{font-size:18px;}
.fs-clear:hover{background:var(--line-soft);}
@media (max-width:480px){ .feed-search{min-width:0;flex:1;} }

/* ============================================================
   HOME HERO — ClassLink cloud image (plain, non-interactive)
   ============================================================ */
/* mix-blend-mode:lighten keeps a transparent white cloud crisp AND, if the
   fallback navy-box logo loads, dissolves its dark box into the blue gradient */
/* crop off the "ClassLink" wordmark (bottom ~25%) and show just the cloud, larger */
.hero-logo{width:178px;height:128px;object-fit:cover;object-position:center top;display:block;flex:none;mix-blend-mode:lighten;}
@media (max-width:640px){ .hero-logo{width:124px;height:90px;} }

/* ============================================================
   PROFILE PHOTO (uploadable avatar)
   ============================================================ */
.pm-avatar{overflow:hidden;}
.pm-avatar.av-photo img,.av-photo img{width:100%;height:100%;object-fit:cover;display:block;}
.avatar-icon{overflow:hidden;padding:0;}
.av-btn-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block;}

/* camera overlay on the profile-modal avatar */
.pf-avatar-wrap{position:relative;display:inline-flex;cursor:pointer;flex:none;border-radius:50%;}
.pf-avatar-wrap input[type=file]{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;}
.pf-avatar-cam{position:absolute;right:-2px;bottom:-2px;width:24px;height:24px;border-radius:50%;background:var(--accent-deep);color:#fff;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface);}
.pf-avatar-cam .material-icons-outlined{font-size:14px;color:#fff;}
.pf-avatar-wrap:hover .pf-avatar-cam{background:var(--accent-blue);}

/* ============================================================
   SIDEBAR CONVERSATIONS UNREAD BADGE (mirrors the messenger count)
   ============================================================ */
.nav-count{background:var(--danger);color:#fff;font-size:11px;font-weight:700;min-width:18px;height:18px;border-radius:9px;padding:0 5px;display:inline-flex;align-items:center;justify-content:center;margin-left:8px;flex:none;}
.nav-count[hidden]{display:none;}
/* collapsed rail: show the unread count as a badge on the Messages icon */
body.nav-collapsed .nav-link{position:relative;}
body.nav-collapsed .nav-count:not([hidden]){display:flex;position:absolute;top:0;right:2px;margin:0;min-width:17px;height:17px;font-size:10px;padding:0 4px;border:2px solid var(--nav-bg);}

/* message picker — clean, readable stacked rows (matches the preview chip) */
.chat-menu-head{border-bottom:1px solid var(--line);}
.chat-menu-item + .chat-menu-item{border-top:1px solid #f0f1f4;}
.chat-menu-item .cm-name{font-weight:600;}

/* ============================================================
   HELP / SUPPORT CENTER (bottom-left)
   ============================================================ */
.role-toggle{bottom:84px;}   /* lifted so the Help button sits in the corner */

.help-launcher{position:fixed;left:18px;bottom:max(20px,env(safe-area-inset-bottom));width:52px;height:52px;border-radius:50%;
  background:var(--surface);color:var(--nav-bg);border:none;cursor:pointer;z-index:71;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(15,28,68,.28);transition:transform .12s;}
.help-launcher{padding:0;}
.help-launcher:hover{transform:scale(1.05);}
.help-launcher .help-icon{width:46px;height:46px;display:block;}

.help-panel{position:fixed;left:18px;bottom:calc(84px + env(safe-area-inset-bottom));width:320px;max-height:min(72vh,540px);
  background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--elev-3);overflow:hidden;display:flex;flex-direction:column;z-index:72;animation:chatIn .18s ease;}
.help-head{display:flex;align-items:center;gap:8px;padding:14px 14px;border-bottom:1px solid var(--line);flex:none;}
.help-title{font-weight:800;font-size:16px;color:var(--ink,var(--ink));flex:1;}
.help-back,.help-x{border:none;background:none;cursor:pointer;color:var(--muted-2);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none;}
.help-back:hover,.help-x:hover{background:var(--bg);}
.help-back .material-icons,.help-x .material-icons{font-size:20px;}
.help-body{overflow-y:auto;flex:1;}

.help-list{display:flex;flex-direction:column;}
.help-item{display:flex;align-items:center;gap:12px;padding:15px 16px;cursor:pointer;}
.help-item + .help-item{border-top:1px solid #f0f1f4;}
.help-item:hover{background:var(--bg);}
.help-item .material-icons-outlined{font-size:21px;color:var(--nav-bg);flex:none;}
.help-item .hi-label{flex:1;font-size:14px;font-weight:600;color:var(--ink-soft,var(--ink));}
.help-item .hi-chev{color:var(--muted-2);font-size:20px;}

.help-article{padding:16px 18px;}
.help-article h3{display:flex;align-items:center;gap:8px;margin:0 0 12px;font-size:15.5px;font-weight:800;color:var(--ink,var(--ink));}
.help-article h3 .material-icons-outlined{font-size:20px;color:var(--nav-bg);}
.help-article p{margin:0 0 11px;font-size:13.5px;line-height:1.55;color:var(--ink-soft);}

.help-onb{padding:20px 18px;text-align:center;}
.onb-illus{width:64px;height:64px;border-radius:50%;background:var(--info-tint);color:var(--nav-bg);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;}
.onb-illus .material-icons-outlined{font-size:32px;}
.onb-step{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted-2);}
.help-onb h3{margin:6px 0 6px;font-size:17px;font-weight:800;color:var(--ink,var(--ink));}
.help-onb p{margin:0 0 16px;font-size:13.5px;line-height:1.55;color:var(--ink-soft);}
.onb-dots{display:flex;justify-content:center;gap:6px;margin-bottom:16px;}
.onb-dots span{width:7px;height:7px;border-radius:50%;background:#d4d8e0;}
.onb-dots span.on{background:var(--accent-deep);}
.onb-actions{display:flex;justify-content:space-between;align-items:center;gap:8px;}

.help-contact{padding:16px 18px;}
.help-sub{margin:0 0 12px;font-size:13.5px;color:var(--ink-soft);line-height:1.5;}
.help-contact textarea{width:100%;min-height:120px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 14px;font-family:inherit;font-size:14px;outline:none;resize:vertical;}
.help-send{margin-top:12px;width:100%;justify-content:center;}
.help-sent{padding:26px 20px;text-align:center;}
.hs-check{width:60px;height:60px;border-radius:50%;background:var(--info-tint);color:var(--nav-bg);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;}
.hs-check .material-icons-outlined{font-size:30px;}
.help-sent h3{margin:0 0 6px;font-size:17px;font-weight:800;}
.help-sent p{margin:0 0 16px;font-size:13.5px;color:var(--ink-soft);line-height:1.5;}

@media (max-width:480px){ .help-panel{width:auto;left:12px;right:12px;} }

/* draggable "View as" toggle */
.role-toggle{cursor:grab;user-select:none;}
.role-toggle.dragging{cursor:grabbing;box-shadow:0 14px 36px rgba(15,28,68,.32);}
.role-toggle .rt-grip{font-size:16px;vertical-align:middle;margin-right:2px;color:#8a90a0;cursor:grab;}
.role-toggle .segt button{cursor:pointer;}

/* Help in the sidebar: hidden when expanded (floating launcher is used);
   shown as a rail "?" icon when collapsed, where the floating launcher is hidden */
.nav-help{display:none;}
body.nav-collapsed .nav-help{display:flex;margin-top:auto;}   /* pushed to the bottom of the rail */
body.nav-collapsed .help-launcher{display:none;}

/* ============================================================
   LOCK A POST + PINNED COMMENTS
   ============================================================ */
.lock-badge{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;color:var(--muted-3);background:var(--line-soft);border-radius:var(--radius-sm);padding:2px 8px;margin-right:6px;}
.lock-badge .material-icons-outlined{font-size:14px;}
.lock-badge.sm{margin:0 0 0 8px;background:rgba(255,255,255,.15);color:#fff;}

/* pinned comment surfaced under a feed post (no click needed) */
.pinned-comment{margin:2px 0 14px;background:var(--info-tint);border-radius:var(--radius-md);padding:10px 14px;}
.pc-label{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--info-ink);margin-bottom:6px;}
.pc-label .material-icons-outlined{font-size:15px;}
.pc-row{display:flex;align-items:flex-start;gap:9px;}
.pc-row img{width:30px;height:30px;border-radius:50%;object-fit:cover;flex:none;background:var(--avatar-bg);}
.pc-main{font-size:13.5px;line-height:1.45;color:var(--ink-soft);}
.pc-name{font-weight:700;margin-right:5px;}

/* pinned comment highlight inside the discussion */
.comment.is-pinned .cbubble{background:var(--info-tint);}
.pc-tag{display:flex;align-items:center;gap:4px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--info-ink);margin-bottom:4px;}
.pc-tag .material-icons-outlined{font-size:13px;}
.cmeta-pin.on{color:var(--info-ink);font-weight:700;}

/* closed-discussion notice (replaces the composer on a locked post) */
.drawer-closed{flex:none;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;border-top:1px solid var(--line);color:var(--muted);font-size:13.5px;font-weight:600;background:var(--line-soft);}
.drawer-closed .material-icons-outlined{font-size:18px;}

/* ============================================================
   OUTAGE BANNER (LaunchPad-style, dismissible, below header)
   ============================================================ */
.outage-banner{position:fixed;top:var(--header-h);left:0;right:0;height:var(--banner-h);z-index:90;
  display:flex;align-items:center;gap:10px;padding:0 16px;
  background:var(--info-tint);border-bottom:1px solid var(--line);color:var(--info-ink);}
.outage-banner .material-icons-outlined{font-size:20px;flex:none;}
.ob-text{flex:1;min-width:0;font-size:13px;line-height:1.3;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ob-text b{color:var(--info-ink);font-weight:700;}
.ob-x{flex:none;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:50%;cursor:pointer;color:var(--muted);}
.ob-x:hover{background:rgba(0,0,0,.06);color:var(--ink);}
.ob-x .material-icons,.ob-x .material-icons-outlined{font-size:18px;}
/* alert tones */
.outage-banner.info{background:var(--info-tint);color:var(--info-ink);}
.outage-banner.info .ob-text b{color:var(--info-ink);}
.outage-banner.warning{background:var(--warn-tint);color:var(--warn-ink);}
.outage-banner.warning .ob-text b{color:var(--warn-ink);}
.outage-banner.critical{background:var(--danger-tint);color:var(--danger-ink);}
.outage-banner.critical .ob-text b{color:var(--danger-ink);}
/* admin alert history (in the Post-alert modal) */
.alert-hist{border:1px solid var(--line);border-radius:var(--radius-md);max-height:200px;overflow-y:auto;}
.ah-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid var(--line-soft);}
.ah-row:last-child{border-bottom:none;}
.ah-dot{width:9px;height:9px;border-radius:50%;flex:none;background:var(--info-ink);}
.ah-dot.warning{background:var(--warn-ink);} .ah-dot.critical{background:var(--danger-ink);}
.ah-main{flex:1;min-width:0;}
.ah-text{font-size:13px;color:var(--ink-soft);line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ah-meta{font-size:11.5px;color:var(--muted);margin-top:2px;}
.ah-repost{flex:none;}
/* two-column field row in modals */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 14px;}
@media (max-width:520px){ .grid2{grid-template-columns:1fr;} }

/* ============================================================
   COMMENT UP/DOWN VOTING
   ============================================================ */
.cvote{display:inline-flex;align-items:center;gap:1px;}
.cv-arrow{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;background:transparent;border-radius:50%;cursor:pointer;color:var(--muted-3);padding:0;}
.cv-arrow:hover{background:rgba(0,0,0,.05);color:var(--ink);}
.cv-arrow .material-icons{font-size:20px;}
.cv-arrow.up.on{color:var(--accent-deep);}
.cv-arrow.down.on{color:var(--danger);}
.cv-score{min-width:16px;text-align:center;font-size:12.5px;font-weight:700;color:var(--ink-soft);}

/* ============================================================
   MY POSTS + ANALYTICS
   ============================================================ */
.an-stats{display:flex;gap:14px;margin:18px 0 8px;flex-wrap:wrap;}
.an-stat{flex:1;min-width:150px;display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-md);padding:16px 18px;box-shadow:var(--shadow);}
.an-ic{width:42px;height:42px;flex:none;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--tint-teal);color:var(--accent-deep);}
.an-ic .material-icons{font-size:22px;}
.an-n{font-size:24px;font-weight:800;color:var(--ink);line-height:1.1;}
.an-l{font-size:12.5px;color:var(--muted);font-weight:600;}
.an-filter{display:inline-flex;align-items:center;font-size:13px;font-weight:600;color:var(--ink-soft);}
.an-filter select{height:36px;border:1px solid var(--line);border-radius:var(--radius-xs);padding:0 10px;font:inherit;background:var(--field-bg);color:var(--ink);}
.an-row{display:flex;align-items:center;gap:14px;padding:13px 18px;border-bottom:1px solid var(--line-soft);}
.an-row:last-child{border-bottom:none;}
.an-row-main{flex:1;min-width:0;}
.an-title{font-size:14.5px;font-weight:700;color:var(--ink);cursor:pointer;display:block;}
.an-title:hover{color:var(--accent-deep);text-decoration:underline;}
.an-meta{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);margin-top:3px;}
.an-meta .material-icons-outlined{font-size:14px;}
.an-closed{display:inline-flex;align-items:center;gap:3px;color:var(--warn-ink);font-weight:600;}
.an-closed .material-icons-outlined{font-size:13px;}
.an-metrics{display:flex;gap:16px;flex:none;}
.an-metrics span{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--muted-2);}
.an-metrics .material-icons-outlined{font-size:17px;color:var(--muted-3);}

/* ============================================================
   GROUP CHATS
   ============================================================ */
.conv-grp-av{flex:none;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--tint-teal);color:var(--accent-deep);}
.conv-grp-av .material-icons-outlined{font-size:60%;}
.cm-grp-tag{display:inline-flex;align-items:center;color:var(--muted-3);vertical-align:middle;}
.cm-grp-tag .material-icons-outlined{font-size:15px;}
.cb-who{display:block;font-size:11px;font-weight:700;color:var(--accent-deep);margin-bottom:2px;}
.bubble.them .cb-who{color:var(--accent-deep);}
.cw-grp{font-size:11px;}
.cm-newgrp{display:inline-flex;align-items:center;gap:6px;border:none;background:var(--tint-teal);color:var(--accent-deep);font-weight:700;font-size:12.5px;height:32px;padding:0 12px;border-radius:var(--radius-xs);cursor:pointer;}
.cm-newgrp:hover{filter:brightness(.97);}
.cm-newgrp .material-icons{font-size:17px;}
