/* ═══════════════════════════════════════════════════════════
   academics.life — Global Stylesheet
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,600;0,9..144,700;1,9..144,400&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');

/* ── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:15px}
body{font-family:'DM Sans',sans-serif;background:#eef0f7;color:#1a1d2e;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit}
input,select,textarea{font-family:inherit;font-size:inherit}
ul{list-style:none}
.hidden{display:none!important}
.inline{display:inline}
.ml-auto{margin-left:auto}
.mt-1{margin-top:1rem}

/* ── VARIABLES ──────────────────────────────────────────────── */
:root{
  --navy:#0d1f3c;
  --brand:#1a4a8a;
  --brand-mid:#2563c4;
  --brand-light:#e8f0fb;
  --brand-xlight:#f2f6fd;
  --accent:#e85d2f;
  --accent-light:#fef0eb;
  --teal:#0a7a65;
  --teal-light:#e5f5f2;
  --gold:#b07d10;
  --gold-light:#fdf4df;
  --green:#1a7a3a;
  --green-light:#e6f5eb;
  --purple:#5b35b5;
  --purple-light:#f0ebfd;
  --text:#1a1d2e;
  --text-mid:#4a4d65;
  --text-muted:#8a8da5;
  --border:#dde3f0;
  --card:#ffffff;
  --surface:#f0f2f7;
  --nav-h:60px;
  --radius:12px;
  --radius-sm:8px;
  --sidebar-w:230px;
  --right-w:280px;
  --shadow:0 1px 8px rgba(13,31,60,0.07);
  --shadow-hover:0 6px 28px rgba(13,31,60,0.13);
}

/* ── NAVBAR ─────────────────────────────────────────────────── */
.navbar{
  position:fixed;inset:0 0 auto 0;height:var(--nav-h);
  background:var(--navy);z-index:1000;
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.nav-inner{
  max-width:1220px;margin:0 auto;height:100%;
  display:flex;align-items:center;gap:0;padding:0 1.25rem;
}
.nav-logo{display:flex;align-items:center;gap:9px;margin-right:1.25rem;flex-shrink:0}
.nav-logo-img{height:45px;width:auto;object-fit:contain;display:block}
.nav-search{flex:1;max-width:440px;position:relative}
.nav-search input{width:100%;height:36px;border-radius:18px;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.12);color:#fff;font-size:13.5px;padding:0 1rem 0 2.5rem;outline:none;transition:.2s}
.nav-search input::placeholder{color:rgba(255,255,255,0.4)}
.nav-search input:focus{background:rgba(255,255,255,0.16);border-color:rgba(255,255,255,0.25)}
.nav-search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:rgba(255,255,255,0.4);width:15px;height:15px}
.nav-search-icon svg{width:15px;height:15px}
.nav-links{display:flex;align-items:center;gap:.15rem;margin-left:auto}
.nav-link{display:flex;flex-direction:column;align-items:center;gap:2px;padding:.4rem .8rem;border-radius:7px;color:rgba(255,255,255,.55);font-size:11px;font-weight:500;transition:.15s;cursor:pointer;position:relative}
.nav-link svg{width:20px;height:20px;flex-shrink:0}
.nav-link:hover,.nav-link.active{color:#fff;background:rgba(255,255,255,.1)}
.nav-link.has-notif .notif-badge{position:absolute;top:4px;right:6px;min-width:16px;height:16px;border-radius:8px;background:var(--accent);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--navy)}
.nav-avatar-wrap{position:relative;margin-left:.5rem}
.nav-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#f5a47a);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;border:2px solid rgba(255,255,255,.2);cursor:pointer;overflow:hidden;transition:.2s}
.nav-avatar:hover{border-color:#fff}
.nav-avatar img{width:100%;height:100%;object-fit:cover}
.nav-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:200px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-hover);opacity:0;pointer-events:none;transform:translateY(-6px);transition:.2s;z-index:200}
.nav-dropdown.open{opacity:1;pointer-events:all;transform:translateY(0)}
.nd-item{display:block;padding:.55rem 1rem;font-size:13.5px;color:var(--text-mid);transition:.15s;width:100%;text-align:left}
.nd-item:hover{background:var(--surface);color:var(--brand)}
.nd-divider{border-top:1px solid var(--border);margin:.25rem 0}
.nd-logout{color:var(--accent)!important}

/* Mobile nav elements (hidden on desktop) */
.nav-mob-right{display:none;align-items:center;gap:.4rem;margin-left:auto;flex-shrink:0}
.nav-mob-btn{width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.12);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:background .15s;flex-shrink:0;text-decoration:none;position:relative}
.nav-mob-btn:hover{background:rgba(255,255,255,.22)}
.nav-mob-btn svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round}
.nav-mob-notif{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:#e85d2f;border:1.5px solid var(--navy)}

/* Mobile drawer */
.nav-drawer{display:none;position:fixed;top:54px;left:0;right:0;bottom:0;z-index:1500;background:var(--navy);flex-direction:column;padding:.5rem 1.25rem 2rem;overflow-y:auto;animation:navDrawerIn .2s ease}
.nav-drawer.open{display:flex}
@keyframes navDrawerIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.nav-drawer-ol{display:none;position:fixed;inset:0;top:54px;z-index:1499;background:rgba(0,0,0,.45)}
.nav-drawer-ol.open{display:block}
.drawer-prof{display:flex;align-items:center;gap:.85rem;padding:.85rem 0 1rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:.4rem}
.drawer-prof-av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#e85d2f,#f5a47a);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;color:#fff;overflow:hidden;flex-shrink:0;border:2px solid rgba(255,255,255,.2)}
.drawer-prof-av img{width:100%;height:100%;object-fit:cover}
.drawer-prof-name{font-weight:600;font-size:14px;color:#fff}
.drawer-prof-role{font-size:12px;color:rgba(255,255,255,.5);margin-top:2px}
.drawer-lnk{display:flex;align-items:center;gap:.75rem;padding:.7rem .85rem;font-size:14px;font-weight:500;color:rgba(255,255,255,.8);text-decoration:none;border-radius:8px;transition:background .15s}
.drawer-lnk:hover,.drawer-lnk.active{background:rgba(255,255,255,.1);color:#fff}
.drawer-lnk svg{width:18px;height:18px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2}
.drawer-div{height:1px;background:rgba(255,255,255,.1);margin:.4rem 0}
.drawer-logout{display:flex;align-items:center;gap:.75rem;padding:.7rem .85rem;font-size:14px;font-weight:500;color:#f87171;border-radius:8px;transition:background .15s;width:100%;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left}
.drawer-logout:hover{background:rgba(255,255,255,.08)}
.drawer-logout svg{width:18px;height:18px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2}

/* Mobile bottom tab bar */
.mob-tabbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1400;height:56px;background:#fff;border-top:1px solid #dde3f0;box-shadow:0 -2px 12px rgba(13,31,60,.08);padding-bottom:env(safe-area-inset-bottom,0px)}
.mob-tabbar-row{display:flex;height:56px;align-items:stretch}
.tab-lnk{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:#8a8da5;font-size:10px;font-weight:500;text-decoration:none;border:none;background:none;cursor:pointer;font-family:'DM Sans',sans-serif;position:relative;padding:5px 4px 6px;transition:color .15s}
.tab-lnk svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:2}
.tab-lnk.active,.tab-lnk:hover{color:#2563c4}
.tab-badge{position:absolute;top:4px;left:50%;margin-left:4px;background:#e85d2f;color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:8px;line-height:1.4;min-width:15px;text-align:center}

/* ── FLASH ──────────────────────────────────────────────────── */
.flash{position:fixed;top:calc(var(--nav-h) + 12px);left:50%;transform:translateX(-50%);z-index:999;padding:.65rem 1.5rem;border-radius:8px;font-size:13.5px;font-weight:500;box-shadow:var(--shadow-hover);transition:opacity .5s}
.flash-success{background:#e6f5eb;color:#1a7a3a;border:1px solid rgba(26,122,58,.2)}
.flash-error{background:#fef0eb;color:var(--accent);border:1px solid rgba(232,93,47,.2)}
.flash-info{background:var(--brand-light);color:var(--brand);border:1px solid rgba(37,99,196,.2)}

/* ── MAIN CONTENT ───────────────────────────────────────────── */
.main-content{margin-top:var(--nav-h);min-height:calc(100vh - var(--nav-h))}

/* ── LAYOUT ─────────────────────────────────────────────────── */
.layout-3col{max-width:1220px;margin:0 auto;display:grid;grid-template-columns:var(--sidebar-w) 1fr var(--right-w);gap:1.1rem;padding:1.25rem 1rem;box-sizing:border-box}

/* ── CARD ───────────────────────────────────────────────────── */
.card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}
.card+.card{margin-top:1rem}
.card-pad{padding:1.25rem}

/* ── SIDEBAR ────────────────────────────────────────────────── */
.mini-profile{overflow:hidden}
.mini-cover{height:56px;background:linear-gradient(135deg,var(--navy),var(--brand-mid));background-size:cover;background-position:center}
.mini-avatar-wrap{display:flex;justify-content:center;margin:-24px 0 0}
.mini-avatar,.mini-avatar-img{width:48px;height:48px;border-radius:50%;border:3px solid #fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:#fff;object-fit:cover}
.mini-info{padding:.6rem 1rem 1rem;text-align:center}
.mini-name{font-weight:600;font-size:19px;margin-bottom:2px}
.mini-meta{font-size:14px;color:var(--text-muted);line-height:1.4}
.mini-tagline{font-size:12px;color:var(--text-mid);margin-top:4px}
.mini-stats{display:flex;margin:.65rem -1rem 0;border-top:1px solid var(--border);padding:.55rem 1rem 0}
.ms{flex:1;text-align:center}
.ms-num{font-weight:700;font-size:13px;color:var(--brand)}
.ms-lbl{font-size:10px;color:var(--text-muted)}
.sidebar-nav{padding:.4rem 0;overflow:hidden}
.sn-item{display:flex;align-items:center;gap:9px;padding:.55rem .85rem;font-size:13.5px;font-weight:500;color:var(--text-mid);transition:.15s;border-radius:6px;margin:0 .25rem}
.sn-item:hover{background:var(--surface);color:var(--brand)}
.sn-item.active{color:var(--brand);background:var(--brand-xlight)}
.sn-item svg{width:16px;height:16px;flex-shrink:0}

/* ── AVATAR COLOURS ─────────────────────────────────────────── */
.av-blue{background:linear-gradient(135deg,#1a4a8a,#2563c4)}
.av-orange{background:linear-gradient(135deg,#e85d2f,#f5a47a)}
.av-teal{background:linear-gradient(135deg,#0a7a65,#1ab89a)}
.av-purple{background:linear-gradient(135deg,#5b35b5,#9b6dde)}

/* ── POST COMPOSER ──────────────────────────────────────────── */
.post-composer{padding:1rem;margin-bottom:1rem}
.composer-top{display:flex;align-items:flex-start;gap:.75rem}
.ca{width:40px;height:40px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff}
.composer-input{flex:1;border:1.5px solid var(--border);border-radius:20px;background:var(--surface);padding:.6rem 1rem;font-size:14px;resize:none;outline:none;overflow:hidden;min-height:42px;transition:.2s}
.composer-input:focus{border-color:var(--brand-mid);background:#fff}
.composer-actions{display:flex;align-items:center;gap:.4rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}
.ca-btn{display:flex;align-items:center;gap:5px;padding:.38rem .8rem;border-radius:6px;font-size:12.5px;font-weight:500;color:var(--text-mid);transition:.15s}
.ca-btn:hover,.ca-btn.active-type{background:var(--surface);color:var(--brand)}
.ca-btn svg{width:15px;height:15px}
.btn-post{margin-left:auto;background:var(--brand-mid);color:#fff;padding:.4rem 1.1rem;border-radius:20px;font-size:13.5px;font-weight:600;transition:.2s}
.btn-post:hover{background:var(--brand)}

/* ── POST CARD ──────────────────────────────────────────────── */
.post{margin-bottom:1rem;overflow:hidden}
.post-header{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1rem 0}
.post-avatar-link{flex-shrink:0}
.post-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;color:#fff;flex-shrink:0;overflow:hidden}
.post-avatar img{width:100%;height:100%;object-fit:cover}
.post-avatar-school{border-radius:10px!important;font-size:20px;background:linear-gradient(135deg,var(--teal),#1ab89a)}
.post-meta{flex:1}
.post-author{font-weight:600;font-size:14px;color:var(--text);display:flex;align-items:center;gap:6px}
.post-author a:hover{color:var(--brand)}
.verified-sm{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--brand-mid);color:#fff;font-size:9px}
.post-type-badge{font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:12px}
.post-type-achievement{background:var(--gold-light);color:var(--gold)}
.post-type-admission{background:var(--brand-light);color:var(--brand)}
.post-type-certification{background:var(--purple-light);color:var(--purple)}
.post-type-event{background:var(--teal-light);color:var(--teal)}
.post-submeta{font-size:12px;color:var(--text-muted);margin-top:1px}
.post-body{padding:.75rem 1rem 0;font-size:14px;color:var(--text-mid);line-height:1.65}
.post-body strong,.post-body b{color:var(--text)}
.post-media{margin-top:.75rem}
.post-media img{width:100%;max-height:400px;object-fit:cover}
.post-engagement{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;border-top:1px solid var(--border);margin-top:.75rem;font-size:12.5px;color:var(--text-muted)}
.pe-reactions{display:flex;align-items:center;gap:4px}
.post-btns{display:flex;border-top:1px solid var(--border)}
.post-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:.55rem .5rem;font-size:13px;font-weight:500;color:var(--text-mid);transition:.15s;white-space:nowrap}
.post-btn:hover{background:var(--surface);color:var(--brand)}
.post-btn svg{width:16px;height:16px}
.post-btn.liked{color:var(--brand-mid)}
.post-btn.post-btn-interest{color:var(--teal);flex:1.5}
.post-btn.post-btn-interest:hover{color:var(--teal);background:var(--teal-light)}
.post-btn.post-btn-del:hover{color:var(--accent);background:var(--accent-light)}
.btn-connect-sm{border:1.5px solid var(--brand-mid);color:var(--brand-mid);padding:.28rem .75rem;border-radius:20px;font-size:12px;font-weight:600;transition:.2s;flex-shrink:0}
.btn-connect-sm:hover{background:var(--brand-mid);color:#fff}
.comments-section{padding:.75rem 1rem;background:var(--surface);border-top:1px solid var(--border)}
.comment{display:flex;gap:.6rem;margin-bottom:.6rem}
.comment-avatar{width:32px;height:32px;border-radius:50%;font-size:11px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.comment-body{background:#fff;border-radius:12px;padding:.5rem .85rem;font-size:13px;color:var(--text-mid);line-height:1.55;flex:1}
.comment-author{font-weight:600;color:var(--text);margin-right:5px}
.comment-time{font-size:11px;color:var(--text-muted);margin-top:2px}
.comment-form{display:flex;gap:.6rem;margin-top:.6rem;align-items:center}
.comment-input{flex:1;border:1px solid var(--border);border-radius:20px;padding:.45rem 1rem;font-size:13px;outline:none;transition:.2s}
.comment-input:focus{border-color:var(--brand-mid)}
.comment-submit{background:var(--brand-mid);color:#fff;padding:.4rem .9rem;border-radius:20px;font-size:12.5px;font-weight:600;transition:.2s}
.comment-submit:hover{background:var(--brand)}

/* ── WIDGETS ────────────────────────────────────────────────── */
.widget{padding:1rem;margin-bottom:1rem}
.widget-title{font-weight:700;font-size:14px;color:var(--text);margin-bottom:.75rem;display:flex;justify-content:space-between;align-items:center}
.widget-title a{font-size:12px;font-weight:500;color:var(--brand-mid)}
.suggestion{display:flex;align-items:center;gap:.65rem;padding:.45rem 0;border-bottom:1px solid var(--surface)}
.suggestion:last-child{border-bottom:none}
.sug-avatar{width:38px;height:38px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;overflow:hidden}
.sug-avatar img{width:100%;height:100%;object-fit:cover}
.sug-school{border-radius:9px!important;background:linear-gradient(135deg,var(--teal),#1ab89a);font-size:18px}
.sug-name{font-weight:600;font-size:13px;color:var(--text)}
.sug-name:hover{color:var(--brand)}
.sug-meta{font-size:11.5px;color:var(--text-muted)}
.sug-info{flex:1;min-width:0}
.btn-connect{border:1.5px solid var(--brand-mid);color:var(--brand-mid);padding:.28rem .75rem;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap;transition:.2s}
.btn-connect:hover{background:var(--brand-mid);color:#fff}
.trending{display:flex;gap:.55rem;padding:.4rem 0;border-bottom:1px solid var(--surface)}
.trending:last-child{border-bottom:none}
.tr-num{font-size:11px;color:var(--text-muted);min-width:14px;margin-top:2px}
.tr-tag{font-size:13px;font-weight:500;color:var(--text)}
.tr-count{font-size:11px;color:var(--text-muted)}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;gap:5px;background:var(--brand-mid);color:#fff;padding:.5rem 1.2rem;border-radius:8px;font-size:13.5px;font-weight:600;transition:.2s;box-shadow:0 2px 8px rgba(37,99,196,.25);cursor:pointer}
.btn-primary:hover{background:var(--brand);transform:translateY(-1px);box-shadow:0 4px 16px rgba(37,99,196,.35)}
.btn-primary.btn-interested{background:var(--teal);box-shadow:0 2px 8px rgba(10,122,101,.25)}
.btn-primary.btn-interested:hover{background:#086b58}
.btn-secondary{display:inline-flex;align-items:center;gap:5px;background:var(--card);color:var(--brand-mid);padding:.5rem 1.2rem;border-radius:8px;font-size:13.5px;font-weight:600;border:1.5px solid var(--brand-mid);transition:.2s;cursor:pointer}
.btn-secondary:hover{background:var(--brand-xlight)}
.btn-outline{display:inline-flex;align-items:center;gap:5px;background:var(--card);color:var(--text-mid);padding:.5rem 1rem;border-radius:8px;font-size:13px;font-weight:500;border:1.5px solid var(--border);transition:.2s;cursor:pointer}
.btn-outline:hover{border-color:var(--text-mid);background:var(--surface)}
.btn-icon{width:15px;height:15px}

/* ── PROFILE PAGE ───────────────────────────────────────────── */
.profile-page{max-width:960px;margin:0 auto}
.profile-cover{height:220px;background:linear-gradient(135deg,var(--navy) 0%,var(--brand) 55%,var(--brand-mid) 100%);background-size:cover;background-position:center;position:relative;overflow:hidden}
.profile-cover-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,.15))}
.school-cover{height:240px;background:linear-gradient(135deg,#0a1a35,#0d4a3a 60%,var(--teal));background-size:cover;background-position:center;position:relative;overflow:hidden}
.school-cover-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.4))}
.school-cover-text{position:absolute;bottom:1.5rem;left:1.75rem;z-index:1}
.school-cover-badge{display:inline-block;background:rgba(255,255,255,.15);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:11.5px;font-weight:600;padding:3px 12px;border-radius:20px;margin-bottom:.45rem}
.school-cover-name{font-family:'Fraunces',serif;font-size:1.55rem;font-weight:700;color:#fff;letter-spacing:-.02em;text-shadow:0 2px 8px rgba(0,0,0,.3)}
.cover-edit-btn{position:absolute;right:1rem;bottom:1rem;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.28);color:#fff;padding:.38rem .85rem;border-radius:6px;font-size:12.5px;font-weight:500;display:flex;align-items:center;gap:5px;cursor:pointer;z-index:2;transition:.2s}
.cover-edit-btn:hover{background:rgba(255,255,255,.28)}
.cover-edit-btn svg{width:13px;height:13px}
.cover-edit-form{position:absolute;right:1rem;bottom:1rem;z-index:2}
.profile-container{margin:0 auto;}
.profile-header{padding:0 1.75rem 1.25rem;position:relative;border-radius:0 0 var(--radius) var(--radius)}
.school-header{padding:0 1.75rem 1.25rem;position:relative;border-radius:0 0 var(--radius) var(--radius)}
.profile-avatar-wrap{position:absolute;top:-52px;left:1.75rem}
.avatar-label{position:relative;cursor:pointer;display:block}
.avatar-edit-overlay{position:absolute;inset:0;border-radius:50%;background:rgba(0,0,0,.4);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;opacity:0;transition:.2s;border:4px solid transparent}
.avatar-label:hover .avatar-edit-overlay{opacity:1}
.profile-avatar{width:110px;height:110px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:36px;font-weight:700;color:#fff;border:4px solid #fff;box-shadow:0 4px 16px rgba(0,0,0,.14);overflow:hidden}
.profile-avatar img{width:100%;height:100%;object-fit:cover}
.school-logo{width:110px;height:110px;border-radius:16px;background:linear-gradient(135deg,var(--navy),var(--brand));display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:28px;font-weight:700;color:#fff;border:4px solid #fff;box-shadow:0 4px 16px rgba(0,0,0,.14)}
.profile-actions{display:flex;justify-content:flex-end;align-items:flex-end;padding-top:.85rem;margin-bottom:.85rem;gap:.75rem;min-height:66px}
.profile-name{font-family:'Fraunces',serif;font-size:1.6rem;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1.2;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.verified-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--brand-mid);color:#fff;font-size:11px;flex-shrink:0}
.verified-teal{background:var(--teal)!important}
.pronouns{font-size:14px;font-weight:400;color:var(--text-muted);font-family:'DM Sans',sans-serif}
.profile-tagline{font-size:14.5px;color:var(--text-mid);margin:.25rem 0 .65rem;line-height:1.55;max-width:600px}
.profile-meta-row{display:flex;flex-wrap:wrap;gap:.45rem 1.1rem;font-size:13px;color:var(--text-muted);margin-bottom:.85rem}
.pm-item{display:flex;align-items:center;gap:5px}
.pm-item svg{width:13px;height:13px;flex-shrink:0}
.pm-item a{color:var(--brand-mid);font-weight:500}
.pm-highlight{color:var(--teal)!important;font-weight:600}
.profile-stats-row{display:flex;gap:1.5rem;padding-top:.75rem;border-top:1px solid var(--border)}
.pstat{display:flex;flex-direction:column}
.pstat-num{font-weight:700;font-size:16px;color:var(--brand);line-height:1}
.pstat-lbl{font-size:11.5px;color:var(--text-muted);margin-top:1px}
.school-stats-row{display:flex;gap:2rem;padding-top:.85rem;border-top:1px solid var(--border);margin-top:.75rem}
.ss-num{font-family:'Fraunces',serif;font-size:1.35rem;font-weight:700;color:var(--teal);line-height:1}
.ss-lbl{font-size:11.5px;color:var(--text-muted);margin-top:2px}
.interests-strip{display:flex;flex-wrap:wrap;gap:6px;margin-top:1rem;padding:.85rem 1.25rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.profile-2col{display:grid;grid-template-columns:1fr;gap:0;margin-top:1rem}
.school-2col{display:grid;grid-template-columns:1fr 300px;gap:1rem;margin-top:1rem}
.school-main-col,.school-side-col{display:flex;flex-direction:column;gap:1rem}

/* ── SECTION CARDS ──────────────────────────────────────────── */
.section-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;margin-bottom:1rem}
.sec-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.25rem;border-bottom:1px solid var(--border)}
.sec-title{font-family:'Fraunces',serif;font-size:1rem;font-weight:600;color:var(--text);letter-spacing:-.01em}
.sec-edit{font-size:12.5px;color:var(--text-muted);cursor:pointer;padding:.28rem .65rem;border-radius:6px;transition:.15s;background:none;border:none}
.sec-edit:hover{background:var(--surface);color:var(--brand)}
.sec-body{padding:1rem 1.25rem}
.sec-body.p0{padding:0}
.bio-text{font-size:14px;color:var(--text-mid);line-height:1.7}
.empty-section{font-size:13.5px;color:var(--text-muted);padding:.5rem 0}
.empty-section a{color:var(--brand-mid)}

/* ── TIMELINE ───────────────────────────────────────────────── */
.timeline{position:relative;padding-left:1.5rem}
.timeline::before{content:'';position:absolute;left:8px;top:4px;bottom:4px;width:2px;background:var(--brand-light);border-radius:1px}
.tl-item{position:relative;margin-bottom:1.3rem}
.tl-item:last-child{margin-bottom:0}
.tl-dot{position:absolute;left:-1.5rem;top:5px;width:16px;height:16px;border-radius:50%;border:2.5px solid #fff;background:var(--brand-mid);box-shadow:0 0 0 2px var(--brand-mid)}
.tl-dot.tl-school{background:var(--teal);box-shadow:0 0 0 2px var(--teal)}
.tl-dot.tl-univ{background:var(--purple);box-shadow:0 0 0 2px var(--purple)}
.tl-dot.tl-cert{background:var(--gold);box-shadow:0 0 0 2px var(--gold)}
.tl-inst-row{display:flex;align-items:center;gap:.55rem;margin-bottom:3px}
.tl-icon{width:36px;height:36px;border-radius:8px;background:var(--brand-light);display:flex;align-items:center;justify-content:center;font-size:18px;border:1px solid var(--border);flex-shrink:0}
.tl-name{font-weight:600;font-size:14px;color:var(--text)}
.tl-period{font-size:12px;color:var(--text-muted);margin-bottom:3px}
.tl-desc{font-size:13px;color:var(--text-mid);line-height:1.5;margin-bottom:.35rem}
.chip-row{display:flex;flex-wrap:wrap;gap:5px;margin-top:.35rem}
.del-btn{font-size:11.5px;color:var(--accent);background:none;border:none;cursor:pointer;margin-top:4px;padding:0}
.del-btn:hover{text-decoration:underline}
.cert-link{font-size:12.5px;color:var(--brand-mid);font-weight:500;display:inline-block;margin-top:.3rem}

/* ── CHIPS ──────────────────────────────────────────────────── */
.chip{display:inline-block;font-size:11.5px;padding:2px 9px;border-radius:20px;background:var(--surface);color:var(--text-mid);border:1px solid var(--border);font-weight:500;white-space:nowrap}
.chip-blue{background:var(--brand-light);color:var(--brand);border-color:rgba(37,99,196,.2)}
.chip-teal{background:var(--teal-light);color:var(--teal);border-color:rgba(10,122,101,.2)}
.chip-gold{background:var(--gold-light);color:var(--gold);border-color:rgba(176,125,16,.2)}
.chip-purple{background:var(--purple-light);color:var(--purple);border-color:rgba(91,53,181,.2)}
.chip-accent{background:var(--accent-light);color:var(--accent);border-color:rgba(232,93,47,.2)}

/* ── ACHIEVEMENTS ───────────────────────────────────────────── */
.ach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}
.ach-card{background:var(--surface);border-radius:10px;padding:.85rem;border:1px solid var(--border);text-align:center;transition:.2s}
.ach-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.ach-icon{font-size:26px;margin-bottom:.3rem}
.ach-name{font-weight:600;font-size:13px;color:var(--text);margin-bottom:2px}
.ach-meta{font-size:11.5px;color:var(--text-muted)}
.ach-badge{display:inline-block;margin-top:5px;font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:12px;background:var(--gold-light);color:var(--gold)}

/* ── SKILLS ─────────────────────────────────────────────────── */
.skills-cloud{display:flex;flex-wrap:wrap;gap:7px}
.skill-tag{display:flex;align-items:center;gap:6px;padding:.4rem .85rem;border-radius:20px;background:var(--surface);border:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text-mid);transition:.2s}
.skill-tag:hover{background:var(--brand-xlight);border-color:rgba(37,99,196,.25);color:var(--brand)}
.skill-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.skill-del{font-size:13px;color:var(--text-muted);cursor:pointer;padding:0;line-height:1;background:none;border:none}
.skill-del:hover{color:var(--accent)}

/* ── ENDORSEMENTS ───────────────────────────────────────────── */
.endorsement{display:flex;gap:.85rem;padding:.85rem 0;border-bottom:1px solid var(--surface)}
.endorsement:last-child{border-bottom:none}
.end-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff}
.end-name{font-weight:600;font-size:13.5px;color:var(--text);margin-bottom:1px}
.end-role{font-size:12px;color:var(--text-muted);margin-bottom:4px}
.end-quote{font-size:13px;color:var(--text-mid);line-height:1.55;font-style:italic;margin-top:.35rem}

/* ── INTEREST ITEMS ─────────────────────────────────────────── */
.interest-item{display:flex;align-items:center;gap:.85rem;padding:.85rem;background:var(--brand-xlight);border:1.5px solid rgba(37,99,196,.15);border-radius:10px;margin-bottom:.6rem;transition:.2s}
.interest-item:hover{border-color:var(--brand-mid)}
.int-icon{font-size:22px;flex-shrink:0}
.int-info{flex:1;min-width:0}
.int-name{font-weight:600;font-size:13.5px;color:var(--text);display:block}
.int-name:hover{color:var(--brand)}
.int-meta{font-size:12px;color:var(--text-muted)}
.int-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;background:var(--brand-light);color:var(--brand);flex-shrink:0}

/* ── ADMISSION BANNER ───────────────────────────────────────── */
.admission-banner{background:linear-gradient(135deg,var(--navy),var(--brand));border-radius:var(--radius);padding:1.1rem 1.25rem;display:flex;align-items:center;gap:1rem;margin:1rem 0;border:1px solid rgba(37,99,196,.3)}
.adm-icon{font-size:30px;flex-shrink:0}
.adm-title{font-weight:700;font-size:15px;color:#fff;margin-bottom:2px}
.adm-meta{font-size:12.5px;color:rgba(255,255,255,.7)}
.btn-admit{background:#fff;color:var(--brand);padding:.5rem 1.25rem;border-radius:8px;font-size:13px;font-weight:700;flex-shrink:0;transition:.2s;cursor:pointer;border:none}
.btn-admit:hover{background:var(--brand-xlight)}
.btn-admit.btn-admit-done{background:var(--teal-light);color:var(--teal)}

/* ── INTEREST POOL ──────────────────────────────────────────── */
.interest-pool-card{background:linear-gradient(135deg,#f0f9f6,var(--teal-light));border:1.5px solid rgba(10,122,101,.2);border-radius:var(--radius);padding:1.1rem 1.25rem;margin:1rem 0}
.ipool-title{font-weight:700;font-size:14px;color:var(--teal);margin-bottom:.75rem;display:flex;align-items:center;gap:6px}
.ipool-title svg{width:15px;height:15px}
.ipool-link{margin-left:auto;font-size:12px;color:var(--teal);font-weight:600}
.ipool-stats{display:flex;gap:1rem;margin-bottom:.85rem}
.ips{flex:1;background:#fff;border-radius:8px;padding:.7rem;border:1px solid rgba(10,122,101,.15);text-align:center}
.ips-big{font-family:'Fraunces',serif;font-size:1.5rem;font-weight:700;color:var(--teal);line-height:1}
.ips-lbl{font-size:11px;color:var(--text-muted);margin-top:2px}
.ipool-chips{display:flex;flex-wrap:wrap;gap:5px}
.ipool-chip{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);padding:3px 10px 3px 3px;border-radius:20px;font-size:12px;color:var(--text-mid)}
.ipc-avatar{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff}
.ipool-more{font-size:12px;color:var(--teal);font-weight:600;padding:4px 10px;cursor:pointer}

/* ── SCHOOL POSTS ───────────────────────────────────────────── */
.school-post{padding:.8rem 0;border-bottom:1px solid var(--surface)}
.school-post:last-child{border-bottom:none}
.sp-type-badge{display:inline-block;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:12px;margin-bottom:.35rem}
.sp-text{background:var(--surface);color:var(--text-muted)}
.sp-admission{background:var(--brand-light);color:var(--brand)}
.sp-event{background:var(--teal-light);color:var(--teal)}
.sp-achievement{background:var(--gold-light);color:var(--gold)}
.sp-body{font-size:13.5px;color:var(--text-mid);line-height:1.6}
.sp-meta{font-size:11.5px;color:var(--text-muted);margin-top:.3rem}

/* ── PROGRAMMES TABLE ───────────────────────────────────────── */
.prog-table{width:100%;border-collapse:collapse}
.prog-table th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:.55rem .85rem;border-bottom:1.5px solid var(--border);text-align:left;white-space:nowrap}
.prog-table td{font-size:13px;color:var(--text-mid);padding:.65rem .85rem;border-bottom:1px solid var(--surface);vertical-align:middle}
.prog-table tr:last-child td{border-bottom:none}
.prog-table tr:hover td{background:var(--surface)}
.prog-name{font-weight:600;color:var(--text)!important;font-size:13.5px!important}
.prog-badge{display:inline-block;font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:12px}
.prog-senior_secondary,.prog-ug{background:var(--brand-light);color:var(--brand)}
.prog-secondary,.prog-primary{background:var(--teal-light);color:var(--teal)}
.prog-pg,.prog-diploma{background:var(--gold-light);color:var(--gold)}

/* ── QUICK INFO ─────────────────────────────────────────────── */
.qi-row{display:flex;justify-content:space-between;font-size:13px;padding:.5rem 0;border-bottom:1px solid var(--surface)}
.qi-row:last-child{border-bottom:none}
.qi-lbl{color:var(--text-muted)}
.qi-val{font-weight:600;color:var(--text)}

/* ── EVENTS ─────────────────────────────────────────────────── */
.event-item{display:flex;gap:.9rem;padding:.75rem 0;border-bottom:1px solid var(--surface)}
.event-item:last-child{border-bottom:none}
.ev-date{width:50px;height:50px;border-radius:10px;background:linear-gradient(135deg,var(--teal),#0d4a3a);display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;color:#fff}
.ev-day{font-weight:700;font-size:18px;line-height:1}
.ev-mon{font-size:10px;text-transform:uppercase;letter-spacing:.05em;opacity:.85}
.ev-title{font-weight:600;font-size:13.5px;color:var(--text);margin-bottom:2px}
.ev-meta{font-size:12px;color:var(--text-muted);margin-bottom:4px}
.ev-type{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:12px;background:var(--teal-light);color:var(--teal)}

/* ── GALLERY ────────────────────────────────────────────────── */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}
.gallery-item{aspect-ratio:1;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:32px;background:var(--surface)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.2s}
.gallery-item img:hover{transform:scale(1.05)}

/* ── MODALS ─────────────────────────────────────────────────── */
.modal-backdrop{position:fixed;inset:0;background:rgba(13,31,60,.45);z-index:500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:.25s}
.modal-backdrop.open{opacity:1;pointer-events:all}
.modal{background:var(--card);border-radius:16px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(13,31,60,.25);transform:scale(.96) translateY(12px);transition:.25s}
.modal-backdrop.open .modal{transform:scale(1) translateY(0)}
.modal-sm{max-width:360px}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.25rem;border-bottom:1px solid var(--border)}
.modal-header h3{font-family:'Fraunces',serif;font-size:1.05rem;font-weight:600;color:var(--text)}
.modal-close{width:28px;height:28px;border-radius:50%;background:var(--surface);color:var(--text-muted);font-size:16px;display:flex;align-items:center;justify-content:center;transition:.15s}
.modal-close:hover{background:var(--accent-light);color:var(--accent)}
.modal-body{padding:1.25rem}
.modal-footer{display:flex;justify-content:flex-end;gap:.65rem;padding:.85rem 1.25rem;border-top:1px solid var(--border)}

/* ── FORMS ──────────────────────────────────────────────────── */
.form-group{margin-bottom:.85rem}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-mid);margin-bottom:.3rem}
.form-input{width:100%;padding:.55rem .85rem;border:1.5px solid var(--border);border-radius:8px;font-size:14px;color:var(--text);background:var(--card);outline:none;transition:.2s}
.form-input:focus{border-color:var(--brand-mid);box-shadow:0 0 0 3px rgba(37,99,196,.1)}
.form-textarea{min-height:90px;resize:vertical}
.form-color{height:42px;padding:.3rem .6rem;cursor:pointer}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.checkbox-label{display:flex;align-items:center;gap:7px;font-size:13.5px;color:var(--text-mid);cursor:pointer}
.checkbox-label input{width:15px;height:15px}
.alert{padding:.7rem 1rem;border-radius:8px;font-size:13.5px;margin-bottom:.85rem}
.alert-error{background:var(--accent-light);color:var(--accent);border:1px solid rgba(232,93,47,.2)}

/* ── EMPTY STATE ────────────────────────────────────────────── */
.empty-state{text-align:center;padding:3rem 2rem;margin-top:1rem}
.es-icon{font-size:48px;margin-bottom:.85rem}
.es-title{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:600;color:var(--text);margin-bottom:.4rem}
.es-desc{font-size:14px;color:var(--text-muted);margin-bottom:1.25rem}

/* ── AUTH PAGES ─────────────────────────────────────────────── */
.auth-body{background:var(--surface);min-height:100vh;display:flex;margin:0;padding:0;overflow-x:hidden}
.auth-split{display:flex;min-height:100vh;width:100%;margin:0;padding:0;gap:0}
.auth-brand{width:45%;position:relative;display:flex;align-items:center;justify-content:center;padding:3rem 2.5rem;overflow:hidden;min-height:100vh;flex-shrink:0}
.auth-brand::before{content:'';position:absolute;inset:0;background-image:url('/images/lucid-register.webp');background-size:cover;background-position:center top;z-index:0}
.auth-brand::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(13,31,60,0.88) 0%,rgba(26,74,138,0.82) 60%,rgba(37,99,196,0.78) 100%);z-index:1}
.auth-brand-inner{max-width:380px;width:100%;position:relative;z-index:2}
.auth-logo{margin-bottom:1.25rem}
.auth-brand-name{font-family:'Fraunces',serif;font-size:2.2rem;font-weight:700;color:#fff;letter-spacing:-.02em;margin-bottom:.5rem}
.auth-brand-name span{color:#7bb3f7}
.auth-brand-tagline{font-size:15px;color:rgba(255,255,255,0.85);margin-bottom:1.5rem;line-height:1.65;font-weight:500}
.auth-features{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.5rem}
.af{font-size:13.5px;color:rgba(255,255,255,0.8);line-height:1.55}
.auth-brand-stats{display:flex;gap:1.5rem;margin-top:1.75rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,0.2)}
.abs-num{font-family:'Fraunces',serif;font-size:1.5rem;font-weight:700;color:#fff;line-height:1}
.abs-lbl{font-size:11px;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:0.06em;margin-top:3px}
.auth-form-side{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;min-height:100vh;background:var(--surface)}
.auth-center{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;min-height:100vh;background:var(--surface)}
.auth-form-card{background:var(--card);border-radius:18px;padding:2.5rem;width:100%;max-width:520px;box-shadow:var(--shadow-hover);border:1px solid var(--border)}
.auth-wide{max-width:580px}
.auth-title{font-family:'Fraunces',serif;font-size:1.65rem;font-weight:700;color:var(--text);margin-bottom:.25rem}
.auth-sub{font-size:14px;color:var(--text-muted);margin-bottom:1.5rem}
.auth-form{display:flex;flex-direction:column;gap:0}
.btn-auth{width:100%;background:var(--brand-mid);color:#fff;padding:.7rem;border-radius:8px;font-size:15px;font-weight:600;margin-top:.25rem;transition:.2s;border:none;cursor:pointer;font-family:'DM Sans',sans-serif}
.btn-auth:hover{background:var(--brand)}
.auth-divider{text-align:center;margin:1rem 0;position:relative;font-size:12.5px;color:var(--text-muted)}
.auth-divider::before,.auth-divider::after{content:'';position:absolute;top:50%;width:44%;height:1px;background:var(--border)}
.auth-divider::before{left:0}.auth-divider::after{right:0}
.auth-divider span{background:var(--card);padding:0 .75rem;position:relative;z-index:1}
.btn-google{display:flex;align-items:center;justify-content:center;gap:.65rem;width:100%;padding:.6rem;border-radius:8px;border:1.5px solid var(--border);background:var(--card);color:var(--text);font-size:14px;font-weight:500;transition:.2s;cursor:pointer}
.btn-google:hover{border-color:var(--brand-mid);background:var(--brand-xlight)}
.auth-footer{text-align:center;font-size:13.5px;color:var(--text-muted);margin-top:1.25rem}
.auth-footer a{color:var(--brand-mid);font-weight:600}
.auth-terms{font-size:12px;color:var(--text-muted);text-align:center;margin-top:.75rem}
.auth-terms a{color:var(--brand-mid)}
.auth-back-logo{display:flex;align-items:center;gap:8px;margin-bottom:1.5rem}
.auth-logo-sm{font-size:24px}
.auth-brand-sm{font-family:'Fraunces',serif;font-size:1.1rem;color:var(--text)}
.auth-brand-sm b{color:var(--brand-mid)}
.role-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}
.role-card{background:var(--surface);border:2px solid var(--border);border-radius:12px;padding:1.25rem;text-align:center;cursor:pointer;transition:.2s;text-decoration:none;display:block}
.role-card:hover,.role-selected{border-color:var(--brand-mid);background:var(--brand-xlight);transform:translateY(-2px)}
.role-icon{font-size:36px;margin-bottom:.5rem}
.role-name{font-weight:700;font-size:14px;color:var(--text);margin-bottom:.35rem}
.role-desc{font-size:12.5px;color:var(--text-muted);line-height:1.5}
.reg-form-wrap{border-top:1px solid var(--border);padding-top:1.5rem;margin-top:1rem}
.form-check-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:13.5px;color:var(--text-muted)}
.big-logo-img{max-width:200px;width:100%;height:auto;object-fit:contain;display:block;margin:0 auto 1.25rem auto}
.subject-checkboxes{display:grid;grid-template-columns:repeat(3,1fr);gap:.45rem;margin-top:.35rem}
.subject-check-label{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--text-mid);background:var(--surface);border:1.5px solid var(--border);padding:.3rem .65rem;border-radius:20px;cursor:pointer;transition:.2s;user-select:none;justify-content:center}
.subject-check-label:hover{border-color:var(--brand-mid);background:var(--brand-xlight);color:var(--brand)}
.subject-check-label input{display:none}
.subject-check-label:has(input:checked){border-color:var(--brand-mid);background:var(--brand-xlight);color:var(--brand);font-weight:600}

/* ── PAGINATION ─────────────────────────────────────────────── */
nav[aria-label="pagination"]{margin-top:1rem;display:flex;justify-content:center}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — single clean block, no duplicates
══════════════════════════════════════════════════════════════ */

/* Tablet 601–960px */
@media (max-width: 960px) {
  .ach-grid      { grid-template-columns: 1fr 1fr; }
  .auth-brand    { display: none; }
  .auth-form-side{ width: 100%; }
  .school-2col, .form-row { grid-template-columns: 1fr; }
  .role-grid     { grid-template-columns: 1fr; }
  .profile-stats-row { flex-wrap: wrap; gap: .75rem; }
  .school-stats-row  { flex-wrap: wrap; gap: 1rem; }
}

@media (max-width: 600px) {
  .ach-grid { grid-template-columns: 1fr; }
}

/* Mobile ≤767px — single authoritative block */
@media (max-width: 767px) {

  /* Navbar: hide desktop items, show mobile icons */
  .nav-links        { display: none !important; }
  .nav-search       { display: none !important; }
  .nav-mob-right    { display: flex !important; }
  .navbar           { height: 54px !important; }
  .nav-inner        { padding: 0 1rem !important; }
  .nav-logo-img     { height: 34px !important; }

  /* Content: push below fixed navbar, pad above bottom tabbar */
  .main-content {
    margin-top: 54px !important;
    padding-bottom: calc(56px + env(safe-area-inset-bottom, 0px));
  }

  /* Flash: position below mobile navbar */
  .flash { top: calc(54px + 8px) !important; }

  /* Layout: full-width single column, no sidebars */
  .layout-3col {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: .85rem !important;
    box-sizing: border-box !important;
  }
  .sidebar       { display: none !important; }
  .right-sidebar { display: none !important; }
  .feed-main     { width: 100% !important; }

  /* Cards and posts: full width, no overflow */
  .post, .card, .widget {
    width: 100% !important;
    box-sizing: border-box !important;
  }
  .post-header { padding: .85rem .85rem 0 !important; }
  .post-body   { padding: .6rem .85rem 0 !important; }
  .post-btn    { font-size: 12.5px !important; padding: .5rem .35rem !important; }

  /* Composer: scrollable action row */
  .post-composer { padding: .85rem !important; }
  .composer-actions {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .composer-actions::-webkit-scrollbar { display: none; }
  .ca-btn { white-space: nowrap; flex-shrink: 0; }

  /* Bottom tab bar */
  .mob-tabbar { display: block !important; }
}