@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@300;400;500;600;700&display=swap');
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#0D1B3E;--navy2:#152347;--navy3:#1E3160;
  --blue:#2563EB;--bluel:#3B82F6;--bluep:#EFF6FF;
  --gold:#F5A623;--goldl:#FEF3C7;
  --green:#059669;--greenb:#D1FAE5;
  --red:#DC2626;--redb:#FEE2E2;
  --amber:#D97706;--amberb:#FEF3C7;
  --purple:#7C3AED;--purpleb:#EDE9FE;
  --surface:#F0F5FF;--border:#DBEAFE;
  --t1:#0D1B3E;--t2:#4B5563;--t3:#9CA3AF;
  --sb:215px;
}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
html,body{height:100%;font-family:'Fredoka',sans-serif;background:var(--surface);color:var(--t1);font-size:16px}
body{overflow-x:hidden}
img,svg{max-width:100%}

/* ── APP SHELL ── */
#app{display:flex;height:100vh;height:100dvh;overflow:hidden;position:relative}

/* SIDEBAR */
#sb{width:var(--sb);min-width:var(--sb);background:var(--navy);display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0;transition:transform .25s ease;z-index:300}
#sb::-webkit-scrollbar{width:3px}
.sb-logo{padding:15px 14px 11px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;gap:8px}
.sb-logo-name{font-size:18px;font-weight:700;color:var(--gold)}
.sb-logo-sub{font-size:11px;color:rgba(255,255,255,.3);letter-spacing:1px;text-transform:uppercase;margin-top:2px}
#sb-close{display:none;background:rgba(255,255,255,.1);border:none;color:#fff;width:30px;height:30px;border-radius:7px;align-items:center;justify-content:center;cursor:pointer;font-size:16px;flex-shrink:0}
.branch-sel{margin:9px 9px 5px;background:rgba(37,99,235,.25);border:1px solid rgba(59,130,246,.4);border-radius:8px;padding:8px 10px;color:#fff;font-family:'Fredoka',sans-serif;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:7px;transition:background .15s}
.branch-sel:hover{background:rgba(37,99,235,.4)}
.branch-sel i:first-child{color:var(--gold);font-size:15px}
.ns{font-size:11px;color:rgba(255,255,255,.25);letter-spacing:1.5px;text-transform:uppercase;padding:9px 13px 3px;font-weight:500}
.ni{display:flex;align-items:center;gap:9px;padding:8px 13px;cursor:pointer;color:rgba(255,255,255,.6);border-left:3px solid transparent;font-size:14px;transition:all .12s;user-select:none}
.ni:hover{color:rgba(255,255,255,.9);background:rgba(59,130,246,.1)}
.ni.on{color:#fff;background:rgba(59,130,246,.18);border-left-color:var(--bluel)}
.ni i{font-size:16px;min-width:18px;opacity:.8}
.nb{margin-left:auto;background:var(--gold);color:var(--navy);font-size:11px;border-radius:10px;padding:1px 6px;font-weight:700}
.sb-foot{margin-top:auto;padding:10px 12px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:8px}
.av{border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}

/* Overlay backdrop for mobile sidebar */
#sb-backdrop{display:none;position:fixed;inset:0;background:rgba(13,27,62,.5);z-index:299}
#sb-backdrop.show{display:block}

/* MAIN */
#main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
#topbar{background:var(--navy);padding:10px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--blue);flex-shrink:0;gap:10px}
#hamburger{display:none;background:rgba(255,255,255,.1);border:none;color:#fff;width:34px;height:34px;border-radius:8px;align-items:center;justify-content:center;cursor:pointer;font-size:18px;flex-shrink:0}
.tb-title{font-size:19px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
#content{flex:1;padding:16px;overflow-y:auto;background:var(--surface)}
#content::-webkit-scrollbar{width:5px}
#content::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px}

/* ── BUTTONS ── */
.btn{font-family:'Fredoka',sans-serif;border:none;cursor:pointer;border-radius:8px;font-size:15px;font-weight:500;padding:7px 14px;display:inline-flex;align-items:center;gap:6px;transition:all .12s;line-height:1.2;white-space:nowrap}
.b-primary{background:var(--blue);color:#fff}.b-primary:hover{background:#1D4ED8}
.b-gold{background:var(--gold);color:var(--navy);font-weight:600}.b-gold:hover{background:#E59400}
.b-ghost{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.15)}.b-ghost:hover{background:rgba(255,255,255,.2)}
.b-outline{background:#fff;color:var(--t1);border:1px solid var(--border)}.b-outline:hover{background:var(--bluep)}
.b-danger{background:var(--redb);color:var(--red)}.b-green{background:var(--greenb);color:var(--green)}.b-green:hover{background:#A7F3D0}
.b-wa{background:#25D366;color:#fff}.b-wa:hover{background:#1DAA55}
.b-sm{font-size:13px;padding:6px 10px}.b-xs{font-size:12px;padding:4px 8px}
.btn:focus-visible,.ni:focus-visible,.qi:focus-visible,.day-pill:focus-visible,.tab:focus-visible,.m-tab:focus-visible{outline:2px solid var(--blue);outline-offset:2px}

/* ── CARDS ── */
.card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:12px}
.card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px;flex-wrap:wrap;gap:8px}
.card-ttl{font-size:15px;font-weight:600;color:var(--t1)}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(135px,1fr));gap:9px;margin-bottom:12px}
.sc{background:#fff;border:1px solid var(--border);border-radius:11px;padding:11px 12px}
.sc .v{font-size:23px;font-weight:700;color:var(--navy)}.sc .l{font-size:12px;color:var(--t3);margin-top:1px}.sc .tr{font-size:12px;margin-top:3px}
.ic{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:16px;margin-bottom:5px}
.ic-b{background:var(--bluep);color:var(--blue)}.ic-g{background:var(--goldl);color:var(--amber)}.ic-gr{background:var(--greenb);color:var(--green)}.ic-r{background:var(--redb);color:var(--red)}

/* ── TABLE — horizontally scrollable on small screens ── */
.tbl-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tbl{width:100%;border-collapse:collapse;min-width:560px}
.tbl th{font-size:12px;color:var(--t3);text-transform:uppercase;letter-spacing:.4px;padding:7px 9px;text-align:left;border-bottom:1px solid var(--border);font-weight:500;white-space:nowrap}
.tbl td{padding:7px 9px;border-bottom:1px solid #F0F7FF;font-size:14px;vertical-align:middle}
.tbl tr:last-child td{border:none}.tbl tr:hover td{background:#F8FAFF}
.card>.tbl{min-width:560px}

/* ── BADGES ── */
.bdg{display:inline-flex;align-items:center;gap:2px;padding:2px 7px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}
.dg{background:var(--greenb);color:#065F46}.db{background:var(--bluep);color:#1E40AF}
.da{background:var(--amberb);color:#92400E}.dr{background:var(--redb);color:#991B1B}
.dp{background:var(--purpleb);color:#5B21B6}.dn{background:#F3F4F6;color:#6B7280}

/* ── GRID HELPERS ── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:11px}
@media(max-width:900px){.three-col{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.two-col,.three-col{grid-template-columns:1fr}}

.ri{display:flex;align-items:center;gap:8px;padding:7px;background:var(--bluep);border-radius:8px;border:1px solid var(--border);margin-bottom:5px;flex-wrap:wrap}
.fb-row{display:flex;align-items:center;gap:8px;margin-bottom:7px;flex-wrap:wrap}
.fb-lbl{width:82px;color:var(--t2);font-size:13px;flex-shrink:0}
.fb-wrap{flex:1;min-width:60px;background:#EFF6FF;border-radius:3px;height:7px;overflow:hidden}
.fb-bar{height:100%;border-radius:3px;transition:width .5s}
.fb-val{width:60px;text-align:right;font-weight:600;font-size:13px;flex-shrink:0}
.qa{display:grid;grid-template-columns:repeat(auto-fit,minmax(95px,1fr));gap:8px;margin-bottom:12px}
.qi{background:#fff;border:1px solid var(--border);border-radius:10px;padding:11px;cursor:pointer;text-align:center;transition:all .12s}
.qi:hover{border-color:var(--blue);background:var(--bluep);transform:translateY(-1px)}
.qi i{font-size:20px;color:var(--blue);display:block;margin-bottom:4px}.qi span{font-size:12px;color:var(--t2);font-weight:500}

/* ── MODAL ── */
#overlay{position:fixed;inset:0;background:rgba(13,27,62,.6);display:none;align-items:center;justify-content:center;z-index:200;padding:12px}
#overlay.show{display:flex}
.modal{background:#fff;border-radius:13px;padding:0;width:100%;max-width:640px;max-height:94vh;overflow:hidden;position:relative;box-shadow:0 16px 50px rgba(13,27,62,.3);display:flex;flex-direction:column}
.modal-header{padding:15px 17px 0;flex-shrink:0}
.modal-scroll{flex:1;overflow-y:auto;padding:0 17px 17px}
.modal-scroll::-webkit-scrollbar{width:3px}
.m-ttl{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:0;display:flex;align-items:center;gap:8px;padding-bottom:11px;border-bottom:1px solid var(--border)}
.m-close{position:absolute;top:12px;right:12px;background:var(--bluep);border:none;border-radius:7px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t2);font-size:15px;z-index:10}
.m-foot{display:flex;gap:7px;justify-content:flex-end;flex-wrap:wrap;flex-shrink:0;padding:11px 17px;background:#fff;border-top:1px solid var(--border)}
.f-row{display:flex;gap:9px;margin-bottom:9px;flex-wrap:wrap}
.fg{flex:1;min-width:140px;display:flex;flex-direction:column;gap:4px}
.fg label{font-size:12px;color:var(--t3);letter-spacing:.3px;font-weight:500}
.fg input,.fg select,.fg textarea{font-family:'Fredoka',sans-serif;padding:7px 10px;border:1px solid #CBD5E1;border-radius:8px;font-size:14px;background:#fff;color:var(--t1);outline:none;transition:border .12s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--blue)}

/* MODAL TABS */
.m-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:14px;overflow-x:auto}
.m-tab{padding:8px 15px;cursor:pointer;font-size:14px;color:var(--t3);border-bottom:2px solid transparent;transition:all .12s;font-weight:500;white-space:nowrap}
.m-tab.on{color:var(--blue);border-bottom-color:var(--blue);font-weight:600}
.m-tab-panel{display:none}.m-tab-panel.on{display:block}

/* PAGE TABS */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:12px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tab{padding:7px 13px;cursor:pointer;font-size:14px;color:var(--t3);border-bottom:2px solid transparent;transition:all .12s;border-radius:6px 6px 0 0;white-space:nowrap;flex-shrink:0}
.tab.on{color:var(--blue);border-bottom-color:var(--blue);font-weight:600;background:var(--bluep)}

/* TOAST */
#toast{position:fixed;bottom:16px;right:16px;left:16px;margin:0 auto;background:var(--navy);color:#fff;padding:9px 14px;border-radius:10px;font-size:14px;font-family:'Fredoka',sans-serif;display:none;border-left:3px solid var(--gold);z-index:999;box-shadow:0 4px 20px rgba(0,0,0,.3);max-width:300px}

/* SLOT GRID */
.slot-grid{display:grid;grid-template-columns:65px repeat(6,1fr);gap:3px;font-size:13px}
.slot-head{font-weight:600;text-align:center;padding:5px;color:var(--t3);font-size:12px}
.slot-cell{border-radius:7px;padding:6px 3px;text-align:center;cursor:pointer;transition:transform .1s}
.slot-cell:hover{transform:scale(1.05)}
.s-open{background:#D1FAE5;color:#065F46}.s-fill{background:#FEF3C7;color:#92400E}.s-full{background:#FEE2E2;color:#991B1B}
.s-sel{background:var(--blue)!important;color:#fff!important;box-shadow:0 0 0 2px var(--navy)}
.slot-time{font-size:12px;color:var(--t3);display:flex;align-items:center;font-weight:500;padding:2px 0}
.att-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.aday{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;cursor:pointer}
.a-p{background:var(--greenb);color:#065F46}.a-a{background:var(--redb);color:#991B1B}.a-t{background:var(--blue);color:#fff}.a-f{background:#F3F4F6;color:#D1D5DB}
.chart-wrap{position:relative;width:100%}
.info-box{border-radius:8px;padding:8px 10px;font-size:13px;display:flex;align-items:flex-start;gap:7px;margin-bottom:9px}
.info-blue{background:var(--bluep);color:#1E40AF;border:1px solid var(--border)}
.info-green{background:var(--greenb);color:#065F46;border:1px solid #A7F3D0}
.info-gold{background:var(--goldl);color:#92400E;border:1px solid #FDE68A}
.cert-preview{border:2px solid var(--gold);border-radius:11px;padding:22px;background:#FFFDF5;text-align:center;min-height:260px;display:flex;flex-direction:column;justify-content:center;align-items:center}
.cert-div{width:38px;height:2px;background:var(--gold);margin:8px auto}

/* SCHEDULE PICKER */
.day-pill{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;border:2px solid var(--border);cursor:pointer;font-size:13px;font-weight:600;color:var(--t3);transition:all .15s;user-select:none}
.day-pill:hover{border-color:var(--blue);color:var(--blue)}
.day-pill.sel{background:var(--blue);border-color:var(--blue);color:#fff}

/* FEE MATRIX TABLE */
.fee-table{width:100%;border-collapse:collapse;font-size:14px;min-width:520px}
.fee-table th{background:var(--navy);color:#fff;padding:8px 10px;font-weight:500;font-size:13px;text-align:left}
.fee-table td{padding:7px 9px;border-bottom:1px solid var(--border);vertical-align:middle}
.fee-table tr:last-child td{border:none}
.fee-table tr:hover td{background:#F8FAFF}
.fee-input{font-family:'Fredoka',sans-serif;padding:5px 8px;border:1px solid #CBD5E1;border-radius:7px;font-size:14px;width:92px;outline:none;text-align:right}
.fee-input:focus{border-color:var(--blue)}

/* CAPACITY TABLE */
.cap-table{width:100%;border-collapse:collapse;font-size:14px;min-width:560px}
.cap-table th{background:var(--navy3);color:#fff;padding:8px 10px;font-weight:500;font-size:13px;text-align:left}
.cap-table td{padding:8px 9px;border-bottom:1px solid var(--border);vertical-align:middle}
.cap-table tr:last-child td{border:none}
.cap-table tr:hover td{background:#F8FAFF}
.cap-input{font-family:'Fredoka',sans-serif;padding:5px 8px;border:1px solid #CBD5E1;border-radius:7px;font-size:14px;width:72px;outline:none;text-align:center}
.cap-input:focus{border-color:var(--blue)}

/* SLOT AVAILABILITY MINI GRID */
.sa-grid{display:grid;grid-template-columns:55px repeat(6,1fr);gap:2px;font-size:12px;margin-top:8px}
.sa-head{text-align:center;font-weight:600;color:var(--t3);padding:3px;font-size:11px}
.sa-cell{border-radius:6px;padding:4px 2px;text-align:center;font-size:11px;font-weight:600;cursor:pointer;transition:all .12s}
.sa-cell.clickable:hover{transform:scale(1.06)}
.sa-open{background:#D1FAE5;color:#065F46}.sa-fill{background:#FEF3C7;color:#92400E}.sa-full{background:#FEE2E2;color:#991B1B}
.sa-picked{background:var(--blue)!important;color:#fff!important;box-shadow:0 0 0 2px #0D1B3E}
.sa-disabled{background:#F3F4F6;color:#D1D5DB;cursor:default}

/* ── HELP MANUAL ── */
.help-toc{list-style:none}
.help-toc li{margin-bottom:4px}
.help-toc a{color:var(--blue);font-size:14px;text-decoration:none;display:inline-flex;align-items:center;gap:5px}
.help-toc a:hover{text-decoration:underline}
.help-section h3{font-size:15px;color:var(--navy);margin:14px 0 6px;display:flex;align-items:center;gap:7px}
.help-section p{font-size:14px;color:var(--t2);line-height:1.7;margin-bottom:8px}
.help-section ul{padding-left:20px;margin-bottom:8px}
.help-section li{font-size:14px;color:var(--t2);line-height:1.7}

/* ── RESPONSIVE BREAKPOINTS ── */

/* Tablet & small laptop */
@media(max-width:1024px){
  :root{--sb:195px}
  #content{padding:14px}
}

/* Tablet portrait / large phone landscape — sidebar becomes a drawer */
@media(max-width:860px){
  :root{--sb:250px}
  #sb{position:fixed;top:0;left:0;bottom:0;transform:translateX(-100%);box-shadow:4px 0 24px rgba(0,0,0,.25)}
  #sb.open{transform:translateX(0)}
  #sb-close{display:flex}
  #hamburger{display:flex}
  .two-col{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
}

/* Phones */
@media(max-width:640px){
  html,body{font-size:15px}
  #topbar{padding:9px 12px}
  .tb-title{font-size:17px}
  #content{padding:11px}
  .card{padding:12px;border-radius:11px}
  .modal{max-width:100%;width:100%;max-height:100%;height:100%;border-radius:0}
  #overlay{padding:0}
  .stat-grid{grid-template-columns:1fr 1fr;gap:7px}
  .qa{grid-template-columns:repeat(3,1fr)}
  .f-row{flex-direction:column;gap:0}
  .fg{min-width:0}
  .m-tabs{gap:0}
  .day-pill{width:34px;height:34px;font-size:12px}
  .btn{padding:7px 11px}
  #toast{left:10px;right:10px;bottom:10px;max-width:none}
}

/* Very small phones */
@media(max-width:380px){
  .stat-grid{grid-template-columns:1fr 1fr}
  .qa{grid-template-columns:repeat(2,1fr)}
  .tb-title{font-size:15px}
}

/* Print: certificates etc */
@media print{
  #sb,#topbar,#toast,#overlay .m-close,.m-foot{display:none!important}
}

/* ── THEME SYSTEM ── */
/* Themes are applied by overriding :root via JS */
body.dark-mode {
  background: var(--navy) !important;
  color: #e2e8f0 !important;
}
body.dark-mode #content { background: #0f172a !important; }
body.dark-mode .card { background: #1e293b !important; border-color: #334155 !important; color: #e2e8f0; }
body.dark-mode .tbl th { color: #94a3b8; border-color: #334155; }
body.dark-mode .tbl td { border-color: #1e293b; color: #e2e8f0; }
body.dark-mode .tbl tr:hover td { background: #273447; }
body.dark-mode .sc { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .sc .l,.dark-mode .sc .tr { color: #94a3b8; }
body.dark-mode .fg input,.dark-mode .fg select,.dark-mode .fg textarea { background: #0f172a; border-color: #334155; color: #e2e8f0; }
body.dark-mode .modal { background: #1e293b; }
body.dark-mode .modal-header { background: #1e293b; }
body.dark-mode .m-foot { background: #1e293b; border-color: #334155; }
body.dark-mode .btn.b-outline { background: #273447; color: #e2e8f0; border-color: #334155; }
body.dark-mode .info-blue { background: #1e3a5f; border-color: #1d4ed8; color: #93c5fd; }
body.dark-mode .info-gold { background: #3d2a00; border-color: #d97706; color: #fcd34d; }
body.dark-mode .info-green { background: #052e16; border-color: #065f46; color: #86efac; }
body.dark-mode .ri { background: #1e293b; border-color: #334155; }
body.dark-mode .tab { color: #64748b; }
body.dark-mode .tab.on { background: #1e3a5f; color: #60a5fa; }
body.dark-mode .tabs { border-color: #334155; }
body.dark-mode .m-ttl { color: #e2e8f0; border-color: #334155; }
body.dark-mode .card-ttl { color: #f1f5f9; }
body.dark-mode .m-close { background: #273447; color: #94a3b8; }
body.dark-mode .bdg.dn { background: #374151; color: #d1d5db; }
body.dark-mode #overlay { background: rgba(0,0,0,.75); }
body.dark-mode .m-tab { color: #64748b; }
body.dark-mode .m-tab.on { color: #60a5fa; border-color: #60a5fa; }
body.dark-mode .m-tabs { border-color: #334155; }
body.dark-mode .qi { background: #1e293b; border-color: #334155; }
body.dark-mode .qi:hover { background: #273447; border-color: var(--blue); }
body.dark-mode .qi span { color: #94a3b8; }
body.dark-mode .help-section p,.dark-mode .help-section li { color: #94a3b8; }

/* Theme toggle in settings */
.theme-toggle-bar { display:flex; align-items:center; justify-content:space-between; padding:10px 13px; background:var(--bluep); border:1px solid var(--border); border-radius:9px; margin-bottom:12px; }
.theme-cards { display:grid; grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:9px; }
.theme-card { border:2px solid var(--border); border-radius:10px; padding:11px; cursor:pointer; text-align:center; transition:all .15s; position:relative; }
.theme-card:hover { border-color:var(--blue); transform:translateY(-1px); }
.theme-card.active { border-color:var(--blue); box-shadow:0 0 0 3px rgba(37,99,235,.15); }
.theme-swatch { display:flex; gap:3px; justify-content:center; margin-bottom:6px; }
.theme-swatch-dot { width:14px; height:14px; border-radius:50%; }
.theme-card-name { font-size:12px; font-weight:600; color:var(--t1); }

/* Toggle switch */
.toggle-sw { position:relative; display:inline-block; width:42px; height:24px; flex-shrink:0; }
.toggle-sw input { opacity:0; width:0; height:0; }
.toggle-track { position:absolute; cursor:pointer; inset:0; background:#D1D5DB; border-radius:24px; transition:.2s; }
.toggle-track:before { position:absolute; content:''; height:18px; width:18px; left:3px; bottom:3px; background:#fff; border-radius:50%; transition:.2s; }
input:checked + .toggle-track { background:var(--blue); }
input:checked + .toggle-track:before { transform:translateX(18px); }

/* ── LOGIN SCREEN ── */
#login-screen { position:fixed; inset:0; z-index:9999; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg, var(--navy) 0%, var(--navy3) 60%, #1a2f6b 100%); overflow:hidden; }
.login-bg-notes { position:absolute; inset:0; opacity:.04; font-size:80px; display:flex; flex-wrap:wrap; gap:40px; padding:20px; pointer-events:none; user-select:none; overflow:hidden; }
.login-box { background:rgba(255,255,255,.97); border-radius:16px; padding:36px 32px; width:100%; max-width:400px; box-shadow:0 24px 60px rgba(0,0,0,.4); position:relative; z-index:1; }
.login-logo { text-align:center; margin-bottom:24px; }
.login-logo-name { font-size:26px; font-weight:700; color:var(--navy); }
.login-logo-sub { font-size:13px; color:var(--t3); letter-spacing:1px; text-transform:uppercase; margin-top:3px; }
.login-title { font-size:18px; font-weight:700; color:var(--navy); text-align:center; margin-bottom:4px; }
.login-sub { font-size:13px; color:var(--t3); text-align:center; margin-bottom:22px; }
.login-field { margin-bottom:14px; }
.login-field label { font-size:12px; color:var(--t3); font-weight:500; display:block; margin-bottom:4px; }
.login-field input { width:100%; font-family:'Fredoka',sans-serif; padding:10px 13px; border:1.5px solid var(--border); border-radius:9px; font-size:14px; outline:none; transition:border .12s; color:var(--t1); background:#fff; }
.login-field input:focus { border-color:var(--blue); }
.login-btn { width:100%; font-family:'Fredoka',sans-serif; background:var(--blue); color:#fff; border:none; border-radius:9px; padding:11px; font-size:16px; font-weight:600; cursor:pointer; transition:background .12s; margin-top:4px; }
.login-btn:hover { background:#1D4ED8; }
.login-forgot { text-align:center; margin-top:12px; font-size:13px; color:var(--blue); cursor:pointer; }
.login-forgot:hover { text-decoration:underline; }
.login-divider { text-align:center; color:var(--t3); font-size:12px; margin:12px 0; }
.login-role-badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:12px; font-weight:600; margin:3px; cursor:pointer; border:1.5px solid transparent; transition:all .12s; }
.login-role-badge.sel { border-color:var(--blue); background:var(--bluep); color:var(--blue); }
.login-role-badge:not(.sel) { background:#F3F4F6; color:var(--t3); }
@media(max-width:440px){ .login-box { padding:24px 16px; border-radius:0; max-width:none; height:100%; display:flex; flex-direction:column; justify-content:center; } }

/* ── STUDENT SEARCH BOX (for repertoire send) ── */
.stu-search-box { position:relative; }
.stu-search-input { width:100%; font-family:'Fredoka',sans-serif; padding:7px 10px 7px 32px; border:1px solid #CBD5E1; border-radius:8px; font-size:14px; outline:none; transition:border .12s; }
.stu-search-input:focus { border-color:var(--blue); }
.stu-search-icon { position:absolute; left:9px; top:50%; transform:translateY(-50%); color:var(--t3); font-size:14px; pointer-events:none; }
.stu-search-results { position:absolute; top:100%; left:0; right:0; background:#fff; border:1px solid var(--border); border-radius:8px; box-shadow:0 4px 16px rgba(0,0,0,.1); z-index:50; max-height:200px; overflow-y:auto; margin-top:2px; display:none; }
.stu-search-results.open { display:block; }
.stu-search-result-item { display:flex; align-items:center; gap:8px; padding:8px 10px; cursor:pointer; transition:background .1s; font-size:13px; }
.stu-search-result-item:hover { background:var(--bluep); }
.stu-search-selected { margin-top:6px; padding:7px 10px; background:var(--bluep); border-radius:7px; font-size:12px; font-weight:600; display:flex; align-items:center; gap:6px; border:1px solid var(--border); }

/* ── RESIGNATION STYLES ── */
.resign-badge-notice { background:#FEF3C7; color:#92400E; border:1px solid #FDE68A; border-radius:8px; padding:8px 12px; font-size:12px; display:flex; align-items:center; gap:8px; margin-bottom:9px; }
