:root{
  --bg:#060c14;--bg2:#080f1a;--bg3:#0c1628;--border:#0f2035;
  --text:#b8d0e8;--muted:#4a6278;
  --cyan:#46d5f9;--cyan2:#1ab8d4;--cyan-light:#a8edfc;
  --blue:#3b82f6;--purple:#8b5cf6;--gold:#f59e0b;
  --green:#22c55e;--red:#ef4444;--orange:#f97316;
  --sidebar-w:240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}
a{color:var(--cyan);text-decoration:none}

/* ── Boot Loader ────────────────────────────────────────────────── */
#boot-loader{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;gap:16px}
.boot-spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--cyan);border-radius:50%;animation:spin 0.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Auth Screen ────────────────────────────────────────────────── */
#auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 30% 50%,rgba(70,213,249,0.06),transparent 60%),var(--bg)}
.auth-wrap{width:100%;max-width:520px;padding:24px}
.auth-card{background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:36px}
.auth-logo{display:flex;align-items:center;gap:14px;margin-bottom:28px}
.auth-logo img{width:44px;height:44px;object-fit:contain}
.auth-logo h1{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;color:#fff}
.auth-logo p{font-size:13px;color:var(--muted);margin-top:2px}
.role-card{max-width:480px}
.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}
.role-btn{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:24px 16px;cursor:pointer;color:var(--text);display:flex;flex-direction:column;align-items:center;gap:10px;transition:all 0.2s;font-size:13px;font-weight:600}
.role-btn:hover{border-color:var(--cyan);background:rgba(70,213,249,0.06);color:var(--cyan)}
.role-icon{font-size:32px}
.auth-switch{text-align:center;font-size:13px;color:var(--muted);margin-top:16px}
.auth-switch a{color:var(--cyan);margin-left:4px}
.auth-err{background:rgba(239,68,68,0.12);border:1px solid rgba(239,68,68,0.3);border-radius:8px;padding:10px 14px;font-size:13px;color:#f87171;margin-bottom:16px}
.hidden{display:none!important}

/* ── Setup ──────────────────────────────────────────────────────── */
.setup-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.setup-card{background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:40px;max-width:700px;width:100%}
.setup-card h2{margin-bottom:8px;color:#fff;font-family:'Space Grotesk',sans-serif}
.setup-card>p{color:var(--muted);margin-bottom:24px;font-size:14px}

/* ── Shell Layout ───────────────────────────────────────────────── */
#shell{display:flex;min-height:100vh}
#sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;overflow-y:auto;transition:transform 0.3s}
#main{margin-left:var(--sidebar-w);flex:1;min-height:100vh;display:flex;flex-direction:column}
#topbar{height:56px;background:rgba(8,15,26,0.9);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:14px;position:sticky;top:0;z-index:40}
.topbar-menu-btn{background:none;border:none;color:var(--text);font-size:22px;cursor:pointer;display:none}
#menu-btn{background:none;border:none;color:var(--text);cursor:pointer;display:none;padding:4px}
.topbar-title{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:600;color:#fff;flex:1}
.topbar-right{position:relative;margin-left:auto}
.topbar-icon-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:8px;display:flex;align-items:center;transition:color 0.2s}
.topbar-icon-btn:hover{color:var(--cyan)}
.lang-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:var(--card);border:1px solid var(--border);border-radius:12px;padding:6px;min-width:160px;z-index:200;box-shadow:0 8px 32px rgba(0,0,0,0.4)}
.lang-opt{padding:8px 12px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--text);transition:background 0.15s}
.lang-opt:hover{background:rgba(255,255,255,0.06)}
.lang-opt.active{color:var(--cyan);font-weight:600}
#sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:148}
#sb-overlay.active{display:block}
#view{padding:24px;flex:1}

/* ── Sidebar ────────────────────────────────────────────────────── */
.sidebar-logo{display:flex;align-items:center;gap:10px;padding:18px 16px;border-bottom:1px solid var(--border)}
.sidebar-logo img{width:32px;height:32px;object-fit:contain}
.sidebar-app-name{font-family:'Space Grotesk',sans-serif;font-size:16px;font-weight:700;color:var(--cyan)}
.sidebar-school-name{font-size:10px;color:var(--muted);margin-top:1px}
.sidebar-user{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}
.su-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--cyan2));display:flex;align-items:center;justify-content:center;font-weight:700;color:#000;font-size:14px;flex-shrink:0}
.su-name{font-size:13px;font-weight:600;color:#fff}
.su-role{font-size:10px;color:var(--cyan);text-transform:capitalize}
.sidebar-nav{flex:1;padding:10px 8px}
.sn-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;color:var(--muted);text-decoration:none;font-size:13px;font-weight:500;transition:all 0.18s;margin-bottom:2px}
.sn-item:hover{background:rgba(70,213,249,0.08);color:var(--cyan)}
.sn-item.active{background:rgba(70,213,249,0.12);color:var(--cyan)}
.sn-icon{font-size:16px;width:20px;text-align:center}
.sidebar-footer{padding:12px 8px;border-top:1px solid var(--border)}
.lang-selector select{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:6px 10px;color:var(--text);font-size:12px;margin-bottom:8px}
.sn-logout,.sn-db-export{width:100%;background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;padding:6px 10px;border-radius:8px;text-align:left;transition:all 0.2s;display:flex;align-items:center;gap:6px}
.sn-logout:hover{color:#f87171;background:rgba(239,68,68,0.08)}
.sn-db-export:hover{color:var(--cyan);background:rgba(70,213,249,0.08)}

/* ── Page Layout ────────────────────────────────────────────────── */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.page-header h2{font-family:'Space Grotesk',sans-serif;font-size:22px;color:#fff;font-weight:700}
.page-sub{font-size:12px;color:var(--muted);margin-top:2px}
.header-actions{display:flex;gap:10px;flex-wrap:wrap}

/* ── Buttons ────────────────────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:linear-gradient(135deg,var(--cyan),var(--cyan2));color:#000;border:none;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;transition:all 0.2s;font-family:'Inter',sans-serif}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(70,213,249,0.3)}
.btn-outline{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s;font-family:'Inter',sans-serif}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan)}
.full-btn{width:100%;justify-content:center;margin-top:4px}
.btn-sm-primary{padding:5px 12px;background:rgba(70,213,249,0.15);color:var(--cyan);border:1px solid rgba(70,213,249,0.3);border-radius:7px;font-size:11px;font-weight:600;cursor:pointer;transition:all 0.2s}
.btn-sm-primary:hover{background:var(--cyan);color:#000}
.btn-sm-danger{padding:5px 12px;background:rgba(239,68,68,0.12);color:#f87171;border:1px solid rgba(239,68,68,0.25);border-radius:7px;font-size:11px;font-weight:600;cursor:pointer}
.btn-sm-danger:hover{background:var(--red);color:#fff}
.btn-sm-green{padding:5px 12px;background:rgba(34,197,94,0.12);color:var(--green);border:1px solid rgba(34,197,94,0.25);border-radius:7px;font-size:11px;font-weight:600;cursor:pointer}
.btn-sm-green:hover{background:var(--green);color:#fff}
.btn-sm-outline{padding:5px 12px;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:7px;font-size:11px;cursor:pointer}
.btn-sm-outline:hover{border-color:var(--cyan);color:var(--cyan)}
.btn-sm{padding:5px 12px;font-size:11px;border-radius:7px;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--text)}
.btn-submit{width:100%;padding:14px;background:linear-gradient(135deg,var(--cyan),var(--cyan2));color:#000;font-size:14px;font-weight:700;border:none;border-radius:10px;cursor:pointer;font-family:'Inter',sans-serif;transition:all 0.2s}
.btn-submit:hover{box-shadow:0 4px 20px rgba(70,213,249,0.35)}

/* ── Forms ──────────────────────────────────────────────────────── */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:11px;font-weight:600;color:var(--cyan);letter-spacing:0.05em;text-transform:uppercase;margin-bottom:6px}
.form-control{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:10px 14px;color:var(--text);font-family:'Inter',sans-serif;font-size:13px;transition:all 0.2s;outline:none}
.form-control:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(70,213,249,0.1)}
.form-control option{background:var(--bg2)}
textarea.form-control{resize:vertical;min-height:80px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-section-label{font-size:11px;font-weight:700;color:var(--cyan);text-transform:uppercase;letter-spacing:0.1em;margin:20px 0 12px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.form-card{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:24px}
.form-card h3{font-family:'Space Grotesk',sans-serif;font-size:16px;color:#fff;margin-bottom:18px}
.checkbox-row{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--muted);margin-bottom:14px;cursor:pointer}
.checkbox-row input{accent-color:var(--cyan);margin-top:2px}
.pw-wrap{position:relative}
.pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:16px;color:var(--muted)}
.hint{font-size:11px;color:var(--muted);line-height:1.5}
.color-inp{height:40px;padding:4px 8px;cursor:pointer}
.field-checklist{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.check-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text);cursor:pointer;padding:4px 10px;background:var(--bg);border:1px solid var(--border);border-radius:8px}
.check-item input{accent-color:var(--cyan)}

/* ── Tab Bar ────────────────────────────────────────────────────── */
.tab-bar{display:flex;gap:4px;margin-bottom:20px;flex-wrap:wrap;border-bottom:1px solid var(--border);padding-bottom:1px}
.tab-btn{padding:8px 18px;background:transparent;border:none;color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all 0.2s;font-family:'Inter',sans-serif}
.tab-btn.active{color:var(--cyan);border-bottom-color:var(--cyan)}
.tab-btn:hover{color:var(--text)}
.filter-btn{padding:6px 16px;border-radius:8px;background:var(--bg3);border:1px solid var(--border);color:var(--muted);font-size:12px;cursor:pointer;transition:all 0.2s}
.filter-btn.active{background:rgba(70,213,249,0.1);border-color:rgba(70,213,249,0.3);color:var(--cyan)}

/* ── Dashboard Stats ────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:24px}
.stat-card{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:20px 16px;position:relative;overflow:hidden;transition:all 0.2s}
.stat-card:hover{transform:translateY(-2px)}
.sc-icon{font-size:24px;margin-bottom:8px}
.sc-val{font-family:'Space Grotesk',sans-serif;font-size:28px;font-weight:700;margin-bottom:4px}
.sc-label{font-size:11px;color:var(--muted)}
.stat-card.cyan  .sc-val{color:var(--cyan)}
.stat-card.green .sc-val{color:var(--green)}
.stat-card.red   .sc-val{color:var(--red)}
.stat-card.blue  .sc-val{color:var(--blue)}
.stat-card.purple.sc-val{color:var(--purple)}
.stat-card.orange.sc-val{color:var(--orange)}
.stat-card.yellow.sc-val{color:var(--gold)}
.stat-card.teal  .sc-val{color:var(--cyan2)}
.stats-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.mini-stat{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px 18px;text-align:center;min-width:100px}
.mini-stat strong{display:block;font-size:20px;font-weight:700}
.mini-stat span{font-size:11px;color:var(--muted)}
.mini-stat.cyan strong{color:var(--cyan)}
.mini-stat.green strong{color:var(--green)}
.mini-stat.red strong{color:var(--red)}
.mini-stat.blue strong{color:var(--blue)}
.mini-stat.orange strong{color:var(--orange)}
.mini-stat.yellow strong{color:var(--gold)}

/* ── Dashboard Panels ───────────────────────────────────────────── */
.dash-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.dash-panel{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:20px}
.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.panel-header h3{font-size:14px;color:#fff;font-weight:600}
.see-all{font-size:12px;color:var(--cyan)}
.empty-msg{text-align:center;color:var(--muted);font-size:13px;padding:20px 0}
.notice-item{padding:10px 0;border-bottom:1px solid var(--border)}
.notice-item.pinned .ni-title{color:var(--cyan)}
.ni-title{font-size:13px;color:#fff;font-weight:500}
.ni-meta{font-size:11px;color:var(--muted);margin-top:2px}
.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:11px;font-weight:700}
.rank-1{background:#f59e0b;color:#000}.rank-2{background:#94a3b8;color:#000}.rank-3{background:#b45309;color:#fff}
.rank-4,.rank-5{background:var(--bg);color:var(--muted);border:1px solid var(--border)}
.score-badge{background:rgba(70,213,249,0.1);color:var(--cyan);padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}
.grade-badge{font-weight:700;color:var(--cyan)}

/* ── Tables ─────────────────────────────────────────────────────── */
.data-table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--border)}
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{background:var(--bg2);color:var(--cyan);padding:11px 14px;font-size:11px;font-weight:600;text-align:left;border-bottom:1px solid var(--border)}
.data-table td{padding:11px 14px;border-bottom:1px solid rgba(15,32,53,0.6);vertical-align:middle}
.data-table tr:hover td{background:rgba(70,213,249,0.03)}
.data-table tr:last-child td{border-bottom:none}
.mini-table{width:100%;border-collapse:collapse;font-size:12px}
.mini-table th{color:var(--muted);padding:6px 8px;font-weight:600;font-size:10px;border-bottom:1px solid var(--border)}
.mini-table td{padding:8px 8px;border-bottom:1px solid rgba(15,32,53,0.5)}
.list-toolbar{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.search-box{max-width:280px}

/* ── Badges & Tags ──────────────────────────────────────────────── */
.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;background:rgba(70,213,249,0.1);color:var(--cyan)}
.badge-green{background:rgba(34,197,94,0.12);color:var(--green)}
.badge-gray{background:var(--bg);color:var(--muted);border:1px solid var(--border)}
.badge-red{background:rgba(239,68,68,0.12);color:#f87171}
.role-tag{display:inline-block;padding:2px 10px;border-radius:10px;font-size:10px;font-weight:700;background:rgba(70,213,249,0.1);color:var(--cyan);text-transform:capitalize}
.status-badge{display:inline-block;padding:3px 10px;border-radius:10px;font-size:11px;font-weight:600}
.status-approved{background:rgba(34,197,94,0.12);color:var(--green)}
.status-rejected{background:rgba(239,68,68,0.12);color:#f87171}
.status-pending{background:rgba(249,115,22,0.12);color:var(--orange)}
.exam-type-badge{display:inline-block;padding:2px 8px;border-radius:8px;font-size:10px;font-weight:700;text-transform:uppercase}
.etype-classtest{background:rgba(59,130,246,0.12);color:var(--blue)}
.etype-midterm{background:rgba(249,115,22,0.12);color:var(--orange)}
.etype-final{background:rgba(239,68,68,0.12);color:var(--red)}
.etype-unitTest{background:rgba(139,92,246,0.12);color:var(--purple)}
.vehicle-badge{padding:2px 8px;border-radius:8px;font-size:10px;font-weight:700;text-transform:uppercase}
.vtype-bus{background:rgba(59,130,246,0.12);color:var(--blue)}
.vtype-van,.vtype-minivan{background:rgba(34,197,94,0.12);color:var(--green)}
.vtype-auto,.vtype-cab{background:rgba(249,115,22,0.12);color:var(--orange)}
.hr-type-badge{padding:2px 8px;border-radius:8px;font-size:10px;font-weight:700}
.hrtype-hiring{background:rgba(34,197,94,0.12);color:var(--green)}
.hrtype-termination{background:rgba(239,68,68,0.12);color:var(--red)}
.hrtype-promotion,.hrtype-increment,.hrtype-bonus{background:rgba(70,213,249,0.1);color:var(--cyan)}
.hrtype-warning{background:rgba(249,115,22,0.12);color:var(--orange)}

/* ── Hierarchy Tree ─────────────────────────────────────────────── */
.hierarchy-tree{margin-top:20px}
.hier-group{margin-bottom:20px}
.hier-role-label{font-size:11px;font-weight:700;color:var(--cyan);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:8px}
.hier-members{display:flex;flex-wrap:wrap;gap:8px}
.hier-member{display:flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:8px 12px;font-size:12px}
.hm-avatar{width:28px;height:28px;border-radius:50%;background:var(--cyan2);display:flex;align-items:center;justify-content:center;font-weight:700;color:#000;font-size:12px}

/* ── Permissions Table ──────────────────────────────────────────── */
.perm-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:12px}
.perm-table th{background:var(--bg2);color:var(--cyan);padding:8px 12px;font-size:11px;border-bottom:1px solid var(--border)}
.perm-table td{padding:8px 12px;border-bottom:1px solid var(--border);text-align:center}
.perm-table td:first-child{text-align:left;font-weight:500}
.perm-table input{accent-color:var(--cyan);width:16px;height:16px}

/* ── Calendar ───────────────────────────────────────────────────── */
.calendar-list{display:flex;flex-direction:column;gap:8px}
.cal-event{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg3);border-radius:10px;border-left:3px solid var(--border)}
.cal-event.cal-holiday{border-left-color:var(--red)}
.cal-event.cal-exam,.cal-event.cal-midterm,.cal-event.cal-final{border-left-color:var(--orange)}
.cal-event.cal-event{border-left-color:var(--blue)}
.cal-date{font-size:12px;color:var(--muted);min-width:90px}
.cal-title{font-size:13px;color:#fff;flex:1}
.cal-type-badge{font-size:10px;padding:2px 8px;border-radius:8px;background:var(--bg);color:var(--muted);border:1px solid var(--border)}

/* ── Notice Board ───────────────────────────────────────────────── */
.notice-filter-bar{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.notices-list{display:flex;flex-direction:column;gap:14px}
.notice-card{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:20px;transition:all 0.2s}
.notice-card.pinned{border-color:rgba(70,213,249,0.35);background:rgba(70,213,249,0.04)}
.nc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.nc-type-badge{padding:2px 10px;border-radius:8px;font-size:10px;font-weight:700;text-transform:uppercase}
.nc-general{background:rgba(59,130,246,0.1);color:var(--blue)}
.nc-urgent{background:rgba(239,68,68,0.1);color:var(--red)}
.nc-event{background:rgba(34,197,94,0.1);color:var(--green)}
.nc-exam{background:rgba(249,115,22,0.1);color:var(--orange)}
.nc-fee{background:rgba(245,158,11,0.1);color:var(--gold)}
.nc-holiday{background:rgba(139,92,246,0.1);color:var(--purple)}
.nc-pinned{font-size:11px;color:var(--cyan);margin-left:8px}
.nc-title{font-size:16px;color:#fff;font-weight:600;margin-bottom:8px}
.nc-content{font-size:13px;color:var(--text);line-height:1.6;margin-bottom:12px}
.nc-footer{display:flex;justify-content:space-between;font-size:11px;color:var(--muted)}

/* ── Clubs ──────────────────────────────────────────────────────── */
.clubs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.club-card{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:20px;position:relative;transition:all 0.2s}
.club-card:hover{transform:translateY(-3px);border-color:rgba(70,213,249,0.3)}
.cc-type-badge{display:inline-block;padding:2px 10px;border-radius:8px;font-size:10px;font-weight:700;margin-bottom:10px}
.cc-sports{background:rgba(34,197,94,0.12);color:var(--green)}
.cc-quiz,.cc-coding{background:rgba(59,130,246,0.12);color:var(--blue)}
.cc-debate,.cc-drama{background:rgba(249,115,22,0.12);color:var(--orange)}
.cc-singing,.cc-music,.cc-dance{background:rgba(139,92,246,0.12);color:var(--purple)}
.cc-science,.cc-nature{background:rgba(70,213,249,0.12);color:var(--cyan)}
.cc-type-badge:not([class*="cc-"]){background:rgba(74,98,120,0.3);color:var(--muted)}
.club-card h3{font-size:16px;color:#fff;margin-bottom:6px}
.club-card p{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:4px}
.cc-meta{font-size:11px;color:var(--muted)!important}
.cc-footer{display:flex;align-items:center;justify-content:space-between;margin-top:14px;gap:8px;flex-wrap:wrap}
.cc-footer span{font-size:11px;color:var(--muted)}

/* ── Admissions ─────────────────────────────────────────────────── */
.adm-view-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.adm-field{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 14px}
.adm-field span{display:block;font-size:10px;color:var(--muted);text-transform:uppercase;margin-bottom:3px}
.adm-field strong{font-size:13px;color:#fff}

/* ── ID Card ────────────────────────────────────────────────────── */
.template-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:10px;margin-bottom:8px}
.template-item.locked{opacity:0.7}
.idc-preview-area{margin-top:16px}
.id-card-preview{width:260px;border-radius:8px;overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,0.4)}
.icp-header{display:flex;align-items:center;gap:8px;padding:6px 10px}
.icp-body{display:flex;gap:10px;padding:10px}
.icp-photo{width:60px;height:60px;overflow:hidden;background:#333;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:20px}
.icp-details{flex:1;font-size:10px;line-height:1.6}
.icp-name{font-weight:700;font-size:12px;margin-bottom:3px}
.icp-field{opacity:0.85}
.icp-footer{display:flex;justify-content:space-between;padding:6px 10px;align-items:center;font-size:9px}
.icp-sig{font-size:9px;text-align:right}
.idc-print-sheet{display:flex;gap:20px;flex-wrap:wrap;margin-top:16px}
.id-card-full{width:285px;min-height:180px;border-radius:8px;overflow:hidden;box-shadow:0 6px 24px rgba(0,0,0,0.4)}
.icp-photo-full{width:70px;height:70px;overflow:hidden;background:#333;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.idc-actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.id-card-mini{width:160px;height:100px;border-radius:6px;overflow:hidden;box-shadow:0 4px 14px rgba(0,0,0,0.3)}
.id-tools{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0}
.id-tools input[type="range"]{width:100%;accent-color:var(--cyan)}

/* ── Attendance ─────────────────────────────────────────────────── */
.att-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.att-bulk{display:flex;gap:8px}
.res-marks{width:90px;padding:6px 8px!important;text-align:center}

/* ── Routes & Transport ─────────────────────────────────────────── */
.route-card{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px}
.rc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.stops-list{display:flex;flex-direction:column;gap:6px}
.stop-item{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;background:var(--bg);border-radius:8px;font-size:12px}
.stop-name{color:#fff;font-weight:500}
.stop-time{color:var(--muted)}
.transport-board{max-width:500px}
.my-transport-card{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:14px}
.mtc-vehicle{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.mtc-vehicle strong{font-size:18px;color:#fff}
.mtc-details{display:flex;flex-direction:column;gap:6px;font-size:13px}

/* ── Fee / Receipts ─────────────────────────────────────────────── */
.receipts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.receipt-card{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center}
.rc-no{font-size:11px;color:var(--muted);margin-bottom:4px}
.rc-name{font-size:14px;color:#fff;font-weight:600;margin-bottom:4px}
.rc-amount{font-size:20px;font-weight:700;color:var(--green);margin-bottom:4px}
.rc-date{font-size:11px;color:var(--muted);margin-bottom:10px}
.fee-summary{display:flex;justify-content:space-between;padding:10px 14px;background:rgba(70,213,249,0.05);border:1px solid rgba(70,213,249,0.15);border-radius:8px;font-size:13px;margin-bottom:16px}

/* ── Layout helpers ─────────────────────────────────────────────── */
.split-layout{display:grid;grid-template-columns:340px 1fr;gap:20px;align-items:start}
.logo-upload-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.logo-preview{width:80px;height:60px;background:var(--bg);border:1px dashed var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--muted);overflow:hidden}
.logo-preview img{width:100%;height:100%;object-fit:contain}

/* ── Modal ──────────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.75);z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}
.modal-box{background:var(--bg3);border:1px solid var(--border);border-radius:18px;width:100%;max-width:680px;max-height:90vh;overflow-y:auto}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}
.modal-header h3{font-size:16px;color:#fff;font-weight:600}
.modal-header button{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer}
.modal-header button:hover{color:#fff}
.modal-body{padding:24px}

/* ── Toast ──────────────────────────────────────────────────────── */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px 20px;font-size:13px;color:var(--text);transform:translateX(120%);opacity:0;transition:all 0.3s;pointer-events:none;min-width:220px;max-width:320px}
.toast.show{transform:translateX(0);opacity:1}
.toast-success{border-color:rgba(34,197,94,0.4);color:var(--green)}
.toast-error{border-color:rgba(239,68,68,0.4);color:#f87171}
.toast-info{border-color:rgba(70,213,249,0.4);color:var(--cyan)}
.toast-warn{border-color:rgba(245,158,11,0.4);color:var(--gold)}

/* ── Responsive ─────────────────────────────────────────────────── */
@media(max-width:900px){
  #sidebar{transform:translateX(-100%)}
  #sidebar.open{transform:translateX(0)}
  #main{margin-left:0}
  .topbar-menu-btn{display:block}
  #menu-btn{display:flex}
  .form-row{grid-template-columns:1fr}
  .split-layout{grid-template-columns:1fr}
  .dash-cols{grid-template-columns:1fr}
  .adm-view-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:540px){
  #view{padding:16px}
  .role-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
}

/* ── Notification Bell ──────────────────────────────────────────── */
.notif-bell-wrap{position:relative}
.notif-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;border-radius:999px;font-size:9px;font-weight:700;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid var(--bg2)}
.notif-panel{position:absolute;right:0;top:calc(100% + 10px);width:340px;background:var(--bg3);border:1px solid var(--border);border-radius:16px;z-index:500;box-shadow:0 12px 48px rgba(0,0,0,0.5);overflow:hidden}
.np-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}
.np-header span{font-size:14px;font-weight:600;color:#fff}
.np-mark-all{background:none;border:none;color:var(--cyan);font-size:11px;cursor:pointer}
.np-list{max-height:360px;overflow-y:auto}
.np-item{display:flex;gap:12px;padding:12px 18px;border-bottom:1px solid rgba(15,32,53,0.5);cursor:pointer;transition:background 0.15s}
.np-item:hover{background:rgba(70,213,249,0.04)}
.np-item.unread{background:rgba(70,213,249,0.04)}
.np-item.unread .np-title{color:#fff}
.np-icon{font-size:20px;flex-shrink:0;width:32px;text-align:center}
.np-body{flex:1;min-width:0}
.np-title{font-size:13px;color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.np-text{font-size:11px;color:var(--muted);margin-top:2px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.np-time{font-size:10px;color:var(--muted);margin-top:4px}
.np-empty{text-align:center;padding:32px;font-size:13px;color:var(--muted)}
.np-footer{padding:12px 18px;border-top:1px solid var(--border);text-align:center}
.np-footer a{font-size:12px;color:var(--cyan)}

/* Notification Center */
.notif-center{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.nc-notif{display:flex;gap:14px;padding:16px 20px;background:var(--bg3);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all 0.18s}
.nc-notif:hover{border-color:rgba(70,213,249,0.2)}
.nc-notif.unread{border-left:3px solid var(--cyan);background:rgba(70,213,249,0.03)}
.ncn-icon{font-size:24px;flex-shrink:0;width:36px;text-align:center}
.ncn-body{flex:1}
.ncn-title{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}
.ncn-text{font-size:13px;color:var(--text);line-height:1.5;margin-bottom:8px}
.ncn-meta{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--muted);flex-wrap:wrap}

/* ── Dashboard Hero ─────────────────────────────────────────────── */
.dash-root{display:flex;flex-direction:column;gap:20px}
.dash-hero{background:linear-gradient(135deg,rgba(70,213,249,0.06),rgba(26,184,212,0.04));border:1px solid rgba(70,213,249,0.15);border-radius:20px;padding:32px;position:relative;overflow:hidden}
.dash-hero-glow{position:absolute;top:-40px;left:-40px;width:300px;height:300px;background:radial-gradient(circle,rgba(70,213,249,0.1),transparent 70%);pointer-events:none}
.dash-hero-content{display:flex;align-items:center;justify-content:space-between;gap:24px;position:relative;z-index:1}
.dash-hero-left{flex:1}
.dash-greeting-chip{display:inline-block;font-size:11px;color:var(--cyan);background:rgba(70,213,249,0.1);border:1px solid rgba(70,213,249,0.2);border-radius:20px;padding:4px 14px;margin-bottom:12px;letter-spacing:0.02em}
.dash-hero-title{font-family:'Space Grotesk',sans-serif;font-size:28px;font-weight:700;color:#fff;line-height:1.2;margin-bottom:8px}
.grad-name{background:linear-gradient(135deg,var(--cyan),var(--cyan2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.dash-hero-sub{font-size:13px;color:var(--muted);margin-bottom:20px}
.dash-quick-actions{display:flex;gap:10px;flex-wrap:wrap}
.qa-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;font-size:12px;font-weight:600;text-decoration:none;transition:all 0.2s;border:1px solid}
.qa-cyan{background:rgba(70,213,249,0.12);color:var(--cyan);border-color:rgba(70,213,249,0.25)}
.qa-cyan:hover{background:rgba(70,213,249,0.22)}
.qa-green{background:rgba(34,197,94,0.1);color:var(--green);border-color:rgba(34,197,94,0.25)}
.qa-green:hover{background:rgba(34,197,94,0.2)}
.qa-purple{background:rgba(139,92,246,0.1);color:var(--purple);border-color:rgba(139,92,246,0.25)}
.qa-purple:hover{background:rgba(139,92,246,0.2)}
.qa-orange{background:rgba(249,115,22,0.1);color:var(--orange);border-color:rgba(249,115,22,0.25)}
.qa-orange:hover{background:rgba(249,115,22,0.2)}

/* Today's Attendance Ring */
.dash-hero-right{flex-shrink:0}
.dash-today-card{background:rgba(8,15,26,0.6);border:1px solid rgba(70,213,249,0.15);border-radius:16px;padding:20px;text-align:center;min-width:150px}
.dtc-label{font-size:11px;color:var(--muted);margin-bottom:12px;text-transform:uppercase;letter-spacing:0.05em}
.dtc-ring{position:relative;display:inline-block;width:80px;height:80px}
.dtc-ring svg{width:80px;height:80px;transform:rotate(-90deg)}
.ring-arc{transition:stroke-dasharray 1s ease}
.dtc-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:700;color:#fff}
.dtc-sub{font-size:11px;color:var(--muted);margin-top:8px}

/* Stat card enhancements */
.sc-icon-wrap{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:12px}
.cyan-bg{background:rgba(70,213,249,0.12)}
.green-bg{background:rgba(34,197,94,0.12)}
.red-bg{background:rgba(239,68,68,0.12)}
.blue-bg{background:rgba(59,130,246,0.12)}
.purple-bg{background:rgba(139,92,246,0.12)}
.orange-bg{background:rgba(249,115,22,0.12)}
.yellow-bg{background:rgba(245,158,11,0.12)}
.teal-bg{background:rgba(26,184,212,0.12)}
.sc-bar{height:3px;background:var(--border);border-radius:2px;margin-top:10px;overflow:hidden}
.sc-bar-fill{height:100%;border-radius:2px;transition:width 1s ease}
.cyan-fill{background:var(--cyan)}.green-fill{background:var(--green)}.red-fill{background:var(--red)}
.blue-fill{background:var(--blue)}.purple-fill{background:var(--purple)}.orange-fill{background:var(--orange)}
.yellow-fill{background:var(--gold)}.teal-fill{background:var(--cyan2)}

/* Panel header */
.ph-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#fff}
.ph-icon{font-size:16px}
.ph-sub{font-size:11px;color:var(--muted)}

/* Performers */
.performers-list{display:flex;flex-direction:column;gap:10px}
.performer-row{display:flex;align-items:center;gap:12px}
.perf-rank{font-size:18px;width:28px;text-align:center;flex-shrink:0}
.perf-info{flex:1}
.perf-name{font-size:13px;color:#fff;font-weight:500;margin-bottom:4px}
.perf-bar-wrap{height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.perf-bar{height:100%;background:linear-gradient(90deg,var(--cyan),var(--cyan2));border-radius:2px;transition:width 1.2s ease}
.perf-score{font-size:13px;font-weight:700;color:var(--cyan);min-width:44px;text-align:right}

/* Notices feed */
.notices-feed{display:flex;flex-direction:column;gap:10px}
.nf-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:10px;background:var(--bg);border:1px solid var(--border);transition:all 0.2s}
.nf-item.pinned{border-color:rgba(70,213,249,0.2);background:rgba(70,213,249,0.03)}
.nf-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}
.type-general .nf-dot,.nf-dot.type-general{background:var(--blue)}
.type-urgent .nf-dot,.nf-dot.type-urgent{background:var(--red)}
.type-event .nf-dot,.nf-dot.type-event{background:var(--green)}
.type-exam .nf-dot,.nf-dot.type-exam{background:var(--orange)}
.type-fee .nf-dot,.nf-dot.type-fee{background:var(--gold)}
.type-holiday .nf-dot,.nf-dot.type-holiday{background:var(--purple)}
.nf-body{flex:1}
.nf-title{font-size:13px;color:#fff;font-weight:500;margin-bottom:3px}
.nf-meta{font-size:11px;color:var(--muted)}
.nf-badge{font-size:9px;font-weight:700;padding:2px 7px;border-radius:6px;background:var(--bg3);color:var(--muted);border:1px solid var(--border);white-space:nowrap;flex-shrink:0;align-self:flex-start;text-transform:uppercase}

/* Chart */
.chart-panel{margin-top:0}
.chart-wrap{padding:8px 0}
.chart-wrap canvas{display:block;width:100%}

/* Empty state */
.empty-state{text-align:center;padding:28px 16px}
.es-icon{font-size:36px;margin-bottom:10px;opacity:0.5}
.empty-state p{font-size:13px;color:var(--muted);margin-bottom:14px}

/* Setup card enhancements */
.setup-header{display:flex;align-items:center;gap:14px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.setup-header h2{font-family:'Space Grotesk',sans-serif;font-size:20px;color:#fff;margin-bottom:4px}
.setup-header p{font-size:13px;color:var(--muted)}
.sb-footer-btns{display:flex;flex-direction:column;gap:4px}

/* Boot logo */
.boot-logo{width:60px;height:60px;object-fit:contain;animation:bootPulse 1.5s ease-in-out infinite}
@keyframes bootPulse{0%,100%{opacity:0.7;transform:scale(0.97)}50%{opacity:1;transform:scale(1.03)}}
.boot-text{font-size:12px;color:var(--muted);font-family:'Space Grotesk',sans-serif;letter-spacing:0.05em}

/* ── 2-Step Signup Wizard ────────────────────────────────────────── */
.signup-steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:28px}
.ss-step{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--muted);transition:all 0.3s;flex-shrink:0}
.ss-step.active{border-color:var(--cyan);background:rgba(70,213,249,0.12);color:var(--cyan)}
.ss-step.done{border-color:var(--green);background:rgba(34,197,94,0.12);color:var(--green)}
.ss-line{flex:1;height:2px;background:var(--border);max-width:60px;transition:background 0.3s}
.ss-line.done{background:var(--green)}
.signup-step-label{text-align:center;font-size:11px;color:var(--muted);margin-bottom:20px}

/* Live email check */
.email-check-msg{font-size:12px;margin-top:5px;padding:4px 8px;border-radius:6px;display:none}
.email-check-msg.visible{display:block}
.ecm-taken{color:#f87171;background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.2)}
.ecm-free{color:#4ade80;background:rgba(34,197,94,0.1);border:1px solid rgba(34,197,94,0.2)}

/* Password strength */
.pw-strength-bar{height:4px;border-radius:2px;margin-top:6px;transition:all 0.4s;background:var(--border)}

/* FTPEN info box */
.ftpen-info-box{background:rgba(70,213,249,0.07);border:1px solid rgba(70,213,249,0.2);border-radius:12px;padding:16px;margin-bottom:20px;display:flex;gap:12px;align-items:flex-start}
.ftpen-icon{font-size:24px;flex-shrink:0;margin-top:2px}
.ftpen-title{font-size:13px;font-weight:700;color:var(--cyan);margin-bottom:4px}
.ftpen-desc{font-size:12px;color:var(--muted);line-height:1.6}
.ftpen-sample{display:inline-block;margin-top:6px;font-family:'Space Grotesk',monospace;font-size:12px;font-weight:700;color:#fff;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:3px 10px;letter-spacing:0.05em}

@media(max-width:768px){
  .dash-hero-content{flex-direction:column;align-items:flex-start}
  .dash-hero-right{width:100%}
  .dash-today-card{display:flex;align-items:center;gap:16px;text-align:left;min-width:unset}
  .dash-hero-title{font-size:22px}
}
@media(max-width:900px){
  .dash-cols{grid-template-columns:1fr}
}
