@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&family=Playfair+Display:ital,wght@0,700;1,700&display=swap');

:root {
  --navy-950:#020D1A;--navy-900:#04101E;--navy-800:#071828;--navy-700:#0B2440;
  --navy-600:#0F3058;--navy-500:#1A4A7A;--navy-400:#215E98;--navy-300:#3A7BBF;
  --navy-200:#6FA3D4;--navy-100:#A8C8E8;--navy-50:#EBF4FB;

  --gold-900:#3D2400;--gold-800:#6B3F00;--gold-700:#9A5D00;
  --gold-600:#C98200;--gold-500:#E09A00;--gold-400:#F5B800;
  --gold-300:#FFCF3D;--gold-200:#FFE08A;--gold-100:#FFF0C0;--gold-50:#FFFAE8;

  --teal-700:#0A5240;--teal-600:#0F6E56;--teal-400:#1D9E75;--teal-200:#8FD5BE;--teal-50:#E1F5EE;
  --coral-700:#8B1A1A;--coral-600:#C0392B;--coral-400:#E74C3C;--coral-100:#F9C6C2;--coral-50:#FEF0EF;
  --green-600:#1E7E34;--green-400:#28A745;--green-50:#EDF7EF;
  --purple-600:#5B21B6;--purple-400:#7C3AED;--purple-50:#F3EDFF;
  --amber-600:#B45309;--amber-400:#D97706;--amber-50:#FFFBEB;

  --white:#FFFFFF;--gray-50:#F7F8FA;--gray-100:#EDEEF2;
  --gray-200:#D8DBE3;--gray-300:#B8BDC9;--gray-400:#8892A4;
  --gray-500:#6B7280;--gray-600:#5A6378;--gray-700:#404659;
  --gray-800:#252B3B;--gray-900:#12172A;

  --sidebar-w:264px;--header-h:64px;
  --font:'Sora',sans-serif;--font-display:'Playfair Display',serif;
  --r-xs:4px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-2xl:32px;
  --sh-xs:0 1px 3px rgba(4,16,30,0.06);
  --sh-sm:0 2px 8px rgba(4,16,30,0.08);
  --sh-md:0 4px 20px rgba(4,16,30,0.12);
  --sh-lg:0 8px 40px rgba(4,16,30,0.16);
  --sh-gold:0 4px 24px rgba(229,154,0,0.3);
  --sh-navy:0 4px 24px rgba(4,16,30,0.4);
  --tr:all 0.2s cubic-bezier(0.4,0,0.2,1);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font);background:var(--gray-50);color:var(--gray-800);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;}
a{text-decoration:none;color:inherit;}
button,input,select,textarea{font-family:var(--font);}

/* ════ SCROLLBAR ════ */
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:4px;}

/* ════ LAYOUT ════ */
.app{display:flex;min-height:100vh;}
.main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;}

/* ════ SIDEBAR ════ */
.sidebar{
  width:var(--sidebar-w);min-height:100vh;
  background:linear-gradient(180deg,var(--navy-900) 0%,var(--navy-950) 100%);
  position:fixed;left:0;top:0;bottom:0;z-index:300;
  display:flex;flex-direction:column;
  border-right:1px solid rgba(255,255,255,0.04);
  transition:transform 0.28s cubic-bezier(0.4,0,0.2,1);
  overflow:hidden;
}
.sidebar::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold-600),var(--gold-300),var(--gold-600));
}
.sidebar::after{
  content:'';position:absolute;bottom:0;right:-60px;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,184,0,0.04),transparent 70%);
  pointer-events:none;
}

.sb-brand{padding:22px 20px 14px;position:relative;}
.sb-logo-row{display:flex;align-items:center;gap:12px;}
.sb-logo-icon{
  width:40px;height:40px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,var(--gold-400),var(--gold-600));
  display:flex;align-items:center;justify-content:center;
  font-size:15px;font-weight:800;color:var(--navy-900);
  box-shadow:var(--sh-gold);letter-spacing:-1px;
}
.sb-logo-name{font-family:var(--font-display);color:var(--white);font-size:17px;}
.sb-logo-sub{color:var(--gold-400);font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-top:1px;}
.sb-school{
  margin:0 14px 6px;padding:10px 12px;
  background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.07);
  border-radius:var(--r-md);display:flex;align-items:center;gap:10px;
}
.sb-school-av{
  width:30px;height:30px;border-radius:7px;flex-shrink:0;
  background:linear-gradient(135deg,var(--navy-500),var(--navy-400));
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:800;color:var(--gold-300);
}
.sb-school-name{color:rgba(255,255,255,0.8);font-size:11px;font-weight:600;line-height:1.3;}
.sb-school-role{color:var(--gold-400);font-size:9px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;}

.sb-nav{flex:1;padding:6px 0 12px;overflow-y:auto;}
.sb-nav::-webkit-scrollbar{width:2px;}
.sb-group-label{padding:10px 20px 3px;font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.2);}
.sb-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;margin:1px 10px;border-radius:var(--r-sm);
  color:rgba(255,255,255,0.5);font-size:13px;font-weight:500;
  cursor:pointer;transition:var(--tr);position:relative;
}
.sb-item i{font-size:17px;flex-shrink:0;}
.sb-item:hover{color:rgba(255,255,255,0.85);background:rgba(255,255,255,0.06);}
.sb-item.active{
  background:linear-gradient(90deg,var(--gold-300),var(--gold-400));
  color:var(--navy-900);font-weight:700;
  box-shadow:0 2px 14px rgba(245,184,0,0.28);
}
.sb-item.active i{color:var(--navy-900);}
.sb-badge{margin-left:auto;background:var(--coral-600);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:20px;min-width:18px;text-align:center;}
.sb-item.active .sb-badge{background:var(--navy-700);color:var(--gold-300);}

.sb-footer{
  padding:12px 14px;border-top:1px solid rgba(255,255,255,0.06);
  background:rgba(0,0,0,0.2);display:flex;align-items:center;gap:10px;
}
.sb-user-av{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--gold-400),var(--gold-600));
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;color:var(--navy-900);
}
.sb-user-name{color:rgba(255,255,255,0.85);font-size:12px;font-weight:600;}
.sb-user-role{color:var(--gold-400);font-size:10px;}
.sb-logout{margin-left:auto;background:none;border:none;color:rgba(255,255,255,0.3);font-size:16px;cursor:pointer;padding:4px;transition:var(--tr);}
.sb-logout:hover{color:var(--coral-400);}

/* ════ TOPBAR ════ */
.topbar{
  height:var(--header-h);background:var(--white);
  border-bottom:1px solid var(--gray-100);
  display:flex;align-items:center;padding:0 28px;gap:16px;
  position:sticky;top:0;z-index:200;box-shadow:var(--sh-xs);
}
.topbar-left{flex:1;}
.topbar-title{font-size:17px;font-weight:700;color:var(--gray-900);}
.topbar-sub{font-size:11px;color:var(--gray-400);margin-top:1px;}
.topbar-right{display:flex;align-items:center;gap:10px;}
.menu-btn{display:none;background:none;border:none;font-size:22px;color:var(--gray-600);cursor:pointer;}

.icon-btn{
  width:38px;height:38px;border-radius:var(--r-sm);
  background:var(--gray-50);border:1px solid var(--gray-200);
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-500);font-size:17px;cursor:pointer;
  position:relative;transition:var(--tr);
}
.icon-btn:hover{background:var(--navy-50);border-color:var(--navy-200);color:var(--navy-600);}
.icon-btn .dot{
  position:absolute;top:7px;right:7px;
  width:7px;height:7px;border-radius:50%;
  background:var(--coral-400);border:1.5px solid #fff;
}
.topbar-user{
  display:flex;align-items:center;gap:8px;
  padding:5px 10px;border-radius:var(--r-sm);
  cursor:pointer;transition:var(--tr);
}
.topbar-user:hover{background:var(--gray-50);}
.topbar-av{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-400),var(--gold-600));
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;color:var(--navy-900);
}
.topbar-name{font-size:12px;font-weight:700;color:var(--gray-700);}
.topbar-role{font-size:10px;color:var(--gray-400);}

/* ════ CONTENT ════ */
.content{padding:28px;flex:1;}

/* ════ PAGE HERO ════ */
.hero{
  background:linear-gradient(135deg,var(--navy-800) 0%,var(--navy-600) 55%,var(--navy-500) 100%);
  border-radius:var(--r-xl);padding:28px 32px;margin-bottom:24px;
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.hero::before{content:'';position:absolute;top:-50px;right:-50px;width:240px;height:240px;border-radius:50%;background:rgba(245,184,0,0.05);}
.hero::after{content:'';position:absolute;bottom:-70px;right:100px;width:180px;height:180px;border-radius:50%;background:rgba(245,184,0,0.03);}
.hero-text h1{font-family:var(--font-display);font-size:24px;color:#fff;line-height:1.25;margin-bottom:5px;}
.hero-text h1 em{color:var(--gold-300);font-style:normal;}
.hero-text p{font-size:12px;color:rgba(255,255,255,0.55);}
.hero-kpis{display:flex;gap:28px;position:relative;z-index:1;flex-shrink:0;}
.hero-kpi{text-align:center;}
.hero-kpi-val{font-size:26px;font-weight:800;color:var(--gold-300);line-height:1;}
.hero-kpi-label{font-size:9px;color:rgba(255,255,255,0.45);text-transform:uppercase;letter-spacing:0.8px;margin-top:3px;}

/* ════ STAT CARDS ════ */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
.scard{
  background:var(--white);border-radius:var(--r-lg);
  border:1px solid var(--gray-100);padding:20px;
  display:flex;align-items:flex-start;gap:14px;
  transition:var(--tr);position:relative;overflow:hidden;
}
.scard::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;}
.scard.c1::after{background:linear-gradient(90deg,var(--navy-600),var(--navy-400));}
.scard.c2::after{background:linear-gradient(90deg,var(--gold-600),var(--gold-300));}
.scard.c3::after{background:linear-gradient(90deg,var(--teal-600),var(--teal-400));}
.scard.c4::after{background:linear-gradient(90deg,var(--coral-600),var(--coral-400));}
.scard.c5::after{background:linear-gradient(90deg,var(--purple-600),var(--purple-400));}
.scard:hover{box-shadow:var(--sh-md);transform:translateY(-2px);}
.scard-ico{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
.scard.c1 .scard-ico{background:var(--navy-50);color:var(--navy-600);}
.scard.c2 .scard-ico{background:var(--gold-50);color:var(--gold-700);}
.scard.c3 .scard-ico{background:var(--teal-50);color:var(--teal-600);}
.scard.c4 .scard-ico{background:var(--coral-50);color:var(--coral-600);}
.scard.c5 .scard-ico{background:var(--purple-50);color:var(--purple-600);}
.scard-val{font-size:26px;font-weight:800;color:var(--gray-900);line-height:1;}
.scard-label{font-size:12px;color:var(--gray-400);margin-top:4px;}
.scard-trend{font-size:11px;margin-top:5px;display:flex;align-items:center;gap:3px;}
.scard-trend.up{color:var(--green-600);}
.scard-trend.dn{color:var(--coral-400);}

/* ════ CARDS ════ */
.card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--gray-100);box-shadow:var(--sh-xs);}
.card-head{padding:17px 22px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.card-title{font-size:14px;font-weight:700;color:var(--gray-800);display:flex;align-items:center;gap:8px;}
.card-title i{color:var(--gold-600);font-size:18px;}
.card-body{padding:22px;}

/* ════ COLORED BANNER CARDS ════ */
.banner-card{border-radius:var(--r-lg);padding:20px 22px;color:#fff;position:relative;overflow:hidden;}
.banner-card.navy{background:linear-gradient(135deg,var(--navy-700),var(--navy-500));}
.banner-card.gold{background:linear-gradient(135deg,var(--gold-700),var(--gold-500));color:var(--navy-900);}
.banner-card.teal{background:linear-gradient(135deg,var(--teal-700),var(--teal-400));}
.banner-card.coral{background:linear-gradient(135deg,var(--coral-700),var(--coral-400));}
.banner-card.purple{background:linear-gradient(135deg,var(--purple-600),var(--purple-400));}
.banner-card::before{content:'';position:absolute;top:-20px;right:-20px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,0.06);}

/* ════ QUICK ACTIONS ════ */
.qa-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:24px;}
.qa-btn{
  border-radius:var(--r-lg);padding:16px 12px;
  display:flex;flex-direction:column;align-items:center;gap:7px;
  cursor:pointer;transition:var(--tr);border:none;
  text-align:center;font-family:var(--font);
}
.qa-btn i{font-size:24px;}
.qa-btn span{font-size:11px;font-weight:700;}
.qa-btn:hover{transform:translateY(-3px);box-shadow:var(--sh-md);}
.qa-btn.navy{background:linear-gradient(135deg,var(--navy-700),var(--navy-500));color:#fff;}
.qa-btn.gold{background:linear-gradient(135deg,var(--gold-500),var(--gold-300));color:var(--navy-900);}
.qa-btn.teal{background:linear-gradient(135deg,var(--teal-600),var(--teal-400));color:#fff;}
.qa-btn.coral{background:linear-gradient(135deg,var(--coral-600),var(--coral-400));color:#fff;}
.qa-btn.purple{background:linear-gradient(135deg,var(--purple-600),var(--purple-400));color:#fff;}

/* ════ FORMS ════ */
.fg{display:flex;flex-direction:column;gap:5px;}
.fl{font-size:11px;font-weight:700;color:var(--gray-500);letter-spacing:0.3px;text-transform:uppercase;}
.req{color:var(--coral-400);}
.fc{
  padding:9px 13px;font-size:13px;font-weight:500;
  border:1.5px solid var(--gray-200);border-radius:var(--r-sm);
  background:var(--white);color:var(--gray-800);
  transition:var(--tr);width:100%;
}
.fc:focus{outline:none;border-color:var(--gold-500);box-shadow:0 0 0 3px rgba(229,154,0,0.1);}
.fc:hover:not(:focus){border-color:var(--navy-300);}
select.fc{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%238892A4' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;}
textarea.fc{resize:vertical;min-height:80px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-grid.g3{grid-template-columns:1fr 1fr 1fr;}
.form-grid.g4{grid-template-columns:1fr 1fr 1fr 1fr;}
.form-grid.g1{grid-template-columns:1fr;}

/* ════ BUTTONS ════ */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--r-sm);font-size:13px;font-weight:700;border:none;transition:var(--tr);cursor:pointer;font-family:var(--font);white-space:nowrap;}
.btn-navy{background:var(--navy-700);color:#fff;} .btn-navy:hover{background:var(--navy-900);box-shadow:var(--sh-md);}
.btn-gold{background:linear-gradient(135deg,var(--gold-500),var(--gold-400));color:var(--navy-900);} .btn-gold:hover{box-shadow:var(--sh-gold);}
.btn-teal{background:var(--teal-600);color:#fff;} .btn-teal:hover{background:var(--teal-700);}
.btn-coral{background:var(--coral-400);color:#fff;} .btn-coral:hover{background:var(--coral-600);}
.btn-green{background:var(--green-600);color:#fff;} .btn-green:hover{background:var(--green-400);}
.btn-purple{background:var(--purple-600);color:#fff;} .btn-purple:hover{background:var(--purple-400);}
.btn-ghost{background:transparent;color:var(--gray-600);border:1.5px solid var(--gray-200);} .btn-ghost:hover{background:var(--gray-50);}
.btn-sm{padding:6px 13px;font-size:12px;}
.btn-xs{padding:4px 9px;font-size:11px;}
.btn-icon{width:34px;height:34px;padding:0;justify-content:center;}

/* ════ BADGES ════ */
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;}
.b-navy{background:var(--navy-50);color:var(--navy-700);}
.b-gold{background:var(--gold-50);color:var(--gold-800);}
.b-teal{background:var(--teal-50);color:var(--teal-600);}
.b-coral{background:var(--coral-50);color:var(--coral-600);}
.b-green{background:var(--green-50);color:var(--green-600);}
.b-purple{background:var(--purple-50);color:var(--purple-600);}
.b-gray{background:var(--gray-100);color:var(--gray-600);}
.b-amber{background:var(--amber-50);color:var(--amber-600);}

/* ════ TABLES ════ */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
thead th{background:var(--navy-900);color:rgba(255,255,255,0.7);padding:11px 16px;text-align:left;font-size:10px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;}
tbody td{padding:13px 16px;border-bottom:1px solid var(--gray-100);font-size:13px;color:var(--gray-700);}
tbody tr:hover td{background:var(--gold-50);}
tbody tr:last-child td{border-bottom:none;}
.td-avatar{display:flex;align-items:center;gap:10px;}
.td-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--navy-500),var(--navy-700));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:var(--gold-300);flex-shrink:0;}

/* ════ SEARCH ════ */
.search{display:flex;align-items:center;gap:8px;background:var(--gray-50);border:1.5px solid var(--gray-200);border-radius:var(--r-sm);padding:8px 12px;max-width:300px;}
.search:focus-within{border-color:var(--gold-400);background:#fff;}
.search i{color:var(--gray-400);font-size:15px;}
.search input{border:none;background:transparent;font-size:13px;color:var(--gray-800);width:100%;font-family:var(--font);}
.search input:focus{outline:none;}
.search input::placeholder{color:var(--gray-300);}

/* ════ TABS ════ */
.tabs{display:flex;gap:2px;border-bottom:2px solid var(--gray-100);margin-bottom:20px;}
.tab{padding:10px 18px;font-size:13px;font-weight:600;color:var(--gray-400);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:var(--tr);border-radius:var(--r-sm) var(--r-sm) 0 0;}
.tab:hover{color:var(--navy-600);background:var(--navy-50);}
.tab.active{color:var(--navy-700);border-bottom-color:var(--gold-400);background:var(--gold-50);}

/* ════ WIZARD ════ */
.wiz-bar{display:flex;align-items:center;padding:18px 24px;background:linear-gradient(135deg,var(--navy-800),var(--navy-700));border-radius:var(--r-lg) var(--r-lg) 0 0;}
.ws{display:flex;align-items:center;gap:7px;flex:1;cursor:pointer;}
.ws-num{width:26px;height:26px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;border:2px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.4);transition:var(--tr);}
.ws.active .ws-num{background:var(--gold-400);border-color:var(--gold-400);color:var(--navy-900);}
.ws.done .ws-num{background:var(--teal-400);border-color:var(--teal-400);color:#fff;}
.ws-label{font-size:11px;color:rgba(255,255,255,0.4);font-weight:500;}
.ws.active .ws-label{color:var(--gold-300);font-weight:700;}
.ws.done .ws-label{color:var(--teal-200);}
.ws-line{flex:1;height:1px;background:rgba(255,255,255,0.1);margin:0 5px;}
.ws-line.done{background:var(--teal-400);}
.wiz-pane{display:none;padding:24px;animation:fadeUp 0.2s ease;}
.wiz-pane.active{display:block;}
.wiz-foot{padding:16px 24px;border-top:1px solid var(--gray-100);background:var(--gray-50);border-radius:0 0 var(--r-lg) var(--r-lg);display:flex;justify-content:space-between;align-items:center;}

/* ════ SECTION LABELS ════ */
.slabel{font-size:10px;font-weight:700;color:var(--gold-700);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.slabel::after{content:'';flex:1;height:1px;background:var(--gold-100);}
.divider{height:1px;background:var(--gray-100);margin:18px 0;}

/* ════ INFO BOX ════ */
.info-box{display:flex;gap:10px;align-items:flex-start;border-radius:var(--r-sm);padding:11px 14px;margin-bottom:16px;}
.info-box.blue{background:var(--navy-50);border:1px solid var(--navy-100);border-left:3px solid var(--navy-500);}
.info-box.blue i{color:var(--navy-600);}
.info-box.gold{background:var(--gold-50);border:1px solid var(--gold-200);border-left:3px solid var(--gold-500);}
.info-box.gold i{color:var(--gold-700);}
.info-box.green{background:var(--green-50);border:1px solid var(--green-400);border-left:3px solid var(--green-600);}
.info-box.green i{color:var(--green-600);}
.info-box i{font-size:16px;margin-top:1px;flex-shrink:0;}
.info-box p{font-size:12px;line-height:1.5;}
.info-box.blue p{color:var(--navy-700);}
.info-box.gold p{color:var(--gold-900);}
.info-box.green p{color:var(--green-600);}

/* ════ TOAST ════ */
.toast-wrap{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;}
.toast{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-md);padding:12px 16px;display:flex;align-items:center;gap:10px;box-shadow:var(--sh-lg);min-width:300px;animation:toastIn 0.25s cubic-bezier(0.4,0,0.2,1);}
.toast.success{border-left:3px solid var(--teal-400);}
.toast.error{border-left:3px solid var(--coral-400);}
.toast.info{border-left:3px solid var(--gold-500);}
.toast.warning{border-left:3px solid var(--amber-400);}
.toast i{font-size:18px;}
.toast.success i{color:var(--teal-600);}
.toast.error i{color:var(--coral-400);}
.toast.info i{color:var(--gold-600);}
.toast.warning i{color:var(--amber-600);}
.toast-msg{font-size:13px;color:var(--gray-700);font-weight:500;flex:1;}
@keyframes toastIn{from{transform:translateX(24px);opacity:0}to{transform:translateX(0);opacity:1}}

/* ════ MODAL ════ */
.modal-overlay{position:fixed;inset:0;background:rgba(2,13,26,0.65);z-index:500;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(3px);}
.modal-overlay.open{display:flex;}
.modal{background:var(--white);border-radius:var(--r-xl);width:100%;max-width:580px;max-height:92vh;overflow-y:auto;box-shadow:var(--sh-lg);animation:modalIn 0.22s cubic-bezier(0.4,0,0.2,1);}
.modal-lg{max-width:780px;}
@keyframes modalIn{from{transform:scale(0.95);opacity:0}to{transform:scale(1);opacity:1}}
.modal-head{background:linear-gradient(135deg,var(--navy-800),var(--navy-700));border-radius:var(--r-xl) var(--r-xl) 0 0;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;}
.modal-head-title{color:#fff;font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;}
.modal-head-title i{color:var(--gold-400);}
.modal-close{background:none;border:none;color:rgba(255,255,255,0.4);font-size:20px;cursor:pointer;transition:var(--tr);}
.modal-close:hover{color:#fff;}
.modal-body{padding:22px;}
.modal-foot{padding:14px 22px;border-top:1px solid var(--gray-100);display:flex;justify-content:flex-end;gap:10px;}

/* ════ PROGRESS BARS ════ */
.progress-wrap{background:var(--gray-100);border-radius:20px;overflow:hidden;}
.progress-bar{height:100%;border-radius:20px;transition:width 0.6s ease;}
.progress-bar.navy{background:linear-gradient(90deg,var(--navy-600),var(--navy-400));}
.progress-bar.gold{background:linear-gradient(90deg,var(--gold-600),var(--gold-400));}
.progress-bar.teal{background:linear-gradient(90deg,var(--teal-600),var(--teal-400));}
.progress-bar.coral{background:linear-gradient(90deg,var(--coral-600),var(--coral-400));}

/* ════ FIREBASE CONFIG BOX ════ */
.firebase-box{
  background:linear-gradient(135deg,#1A1A2E,#16213E,#0F3460);
  border-radius:var(--r-lg);padding:24px;color:#fff;
  border:1px solid rgba(255,255,255,0.1);position:relative;overflow:hidden;
}
.firebase-box::before{content:'🔥';position:absolute;top:16px;right:20px;font-size:40px;opacity:0.15;}
.firebase-label{font-size:10px;font-weight:700;color:#F5A623;letter-spacing:1px;text-transform:uppercase;margin-bottom:6px;}
.firebase-input{
  width:100%;background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:var(--r-sm);padding:9px 12px;
  color:#fff;font-size:12px;font-family:monospace;
  transition:var(--tr);margin-bottom:12px;
}
.firebase-input:focus{outline:none;border-color:#F5A623;box-shadow:0 0 0 3px rgba(245,166,35,0.15);}
.firebase-input::placeholder{color:rgba(255,255,255,0.3);}
.firebase-status{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;
}
.firebase-status.connected{background:rgba(29,158,117,0.2);color:#4ECCA3;border:1px solid rgba(29,158,117,0.3);}
.firebase-status.offline{background:rgba(231,76,60,0.2);color:#FF8A80;border:1px solid rgba(231,76,60,0.3);}
.firebase-status.testing{background:rgba(245,184,0,0.2);color:#FFD54F;border:1px solid rgba(245,184,0,0.3);}

/* ════ REPORT CARD ════ */
.rc-wrap{background:#fff;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg);max-width:680px;margin:0 auto;}
.rc-header{background:linear-gradient(135deg,var(--navy-800),var(--navy-600));padding:24px 28px;border-bottom:4px solid var(--gold-400);}
.rc-school{color:var(--gold-300);font-size:16px;font-weight:700;letter-spacing:0.5px;}
.rc-title{color:rgba(255,255,255,0.5);font-size:10px;letter-spacing:1px;text-transform:uppercase;margin-top:2px;}
.rc-student{display:flex;align-items:center;gap:16px;margin-top:16px;}
.rc-photo{width:64px;height:80px;border-radius:8px;background:var(--navy-600);border:2px solid var(--gold-400);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--gold-300);}
.rc-name{font-size:18px;font-weight:800;color:#fff;}
.rc-meta{font-size:12px;color:rgba(255,255,255,0.55);margin-top:3px;}
.rc-body{padding:24px 28px;}
.marks-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:20px;}
.marks-table th{background:var(--navy-900);color:rgba(255,255,255,0.7);padding:10px 14px;text-align:left;font-size:10px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;}
.marks-table td{padding:11px 14px;border-bottom:1px solid var(--gray-100);}
.marks-table tr:hover td{background:var(--gold-50);}
.marks-table tr:last-child td{border-bottom:none;}
.grade-chip{display:inline-block;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:700;}
.grade-chip.A1{background:#e8f5e9;color:#2e7d32;}
.grade-chip.A2{background:#f1f8e9;color:#558b2f;}
.grade-chip.B1{background:#fff8e1;color:#f57f17;}
.grade-chip.B2{background:#fff3e0;color:#e65100;}
.grade-chip.C{background:#fce4ec;color:#c62828;}
.rc-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px;}
.rc-sum-item{background:var(--gray-50);border-radius:var(--r-md);padding:14px;text-align:center;border:1px solid var(--gray-100);}
.rc-sum-val{font-size:22px;font-weight:800;color:var(--navy-700);}
.rc-sum-label{font-size:10px;color:var(--gray-400);text-transform:uppercase;letter-spacing:0.5px;margin-top:3px;}
.rc-footer{background:var(--gray-50);padding:14px 28px;border-top:1px solid var(--gray-100);display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--gray-400);}

/* ════ NOTIFICATION CENTER ════ */
.notif-channel{
  border:1.5px solid var(--gray-200);border-radius:var(--r-md);
  padding:16px;margin-bottom:12px;transition:var(--tr);cursor:pointer;
}
.notif-channel:hover{border-color:var(--gold-400);background:var(--gold-50);}
.notif-channel.selected{border-color:var(--navy-500);background:var(--navy-50);}
.notif-channel-head{display:flex;align-items:center;gap:12px;}
.notif-channel-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.nc-wa{background:#DCF8C6;} .nc-sms{background:#E3F2FD;} .nc-email{background:#FFF3E0;}
.notif-channel-name{font-size:13px;font-weight:700;color:var(--gray-800);}
.notif-channel-desc{font-size:11px;color:var(--gray-400);}
.notif-toggle{margin-left:auto;}

/* ════ RAZORPAY MOCK ════ */
.payment-widget{
  border:2px solid var(--gray-200);border-radius:var(--r-xl);
  overflow:hidden;max-width:420px;margin:0 auto;
  box-shadow:var(--sh-lg);
}
.pw-head{
  background:linear-gradient(135deg,#0E3D7B,#1B63C5);
  padding:20px 24px;color:#fff;display:flex;align-items:center;gap:12px;
}
.pw-logo{width:36px;height:36px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;}
.pw-school{font-size:14px;font-weight:700;}
.pw-amount{font-size:12px;color:rgba(255,255,255,0.65);}
.pw-body{padding:20px 24px;background:#fff;}
.pw-methods{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px;}
.pw-method{border:1.5px solid var(--gray-200);border-radius:var(--r-sm);padding:10px;text-align:center;cursor:pointer;font-size:12px;font-weight:600;color:var(--gray-600);transition:var(--tr);}
.pw-method.active{border-color:#1B63C5;background:#EBF4FF;color:#1B63C5;}
.pw-method:hover{border-color:#1B63C5;}
.pw-method i{display:block;font-size:20px;margin-bottom:4px;}

/* ════ SUPER ADMIN ════ */
.school-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;}
.school-tile{
  background:var(--white);border-radius:var(--r-lg);
  border:1px solid var(--gray-100);padding:18px;
  transition:var(--tr);cursor:pointer;position:relative;overflow:hidden;
}
.school-tile::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;}
.school-tile.st1::before{background:linear-gradient(90deg,var(--navy-600),var(--navy-400));}
.school-tile.st2::before{background:linear-gradient(90deg,var(--teal-600),var(--teal-400));}
.school-tile.st3::before{background:linear-gradient(90deg,var(--gold-600),var(--gold-400));}
.school-tile.st4::before{background:linear-gradient(90deg,var(--purple-600),var(--purple-400));}
.school-tile.st5::before{background:linear-gradient(90deg,var(--coral-600),var(--coral-400));}
.school-tile:hover{box-shadow:var(--sh-md);transform:translateY(-2px);}
.school-tile-name{font-size:14px;font-weight:700;color:var(--gray-800);margin-bottom:4px;}
.school-tile-loc{font-size:12px;color:var(--gray-400);margin-bottom:12px;}
.school-tile-stats{display:flex;gap:14px;}
.school-tile-stat{font-size:12px;color:var(--gray-600);}
.school-tile-stat strong{display:block;font-size:16px;font-weight:800;color:var(--gray-800);}
.school-tile-badge{position:absolute;top:14px;right:14px;}

/* ════ CHART ════ */
.chart-container{position:relative;padding:16px 0;}
.chart-bars{display:flex;align-items:flex-end;gap:8px;height:140px;padding:0 8px;}
.chart-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;}
.chart-bar{width:100%;border-radius:var(--r-sm) var(--r-sm) 0 0;transition:height 0.5s ease;cursor:pointer;position:relative;}
.chart-bar:hover::after{content:attr(data-val);position:absolute;top:-22px;left:50%;transform:translateX(-50%);background:var(--navy-800);color:var(--gold-300);font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;white-space:nowrap;}
.chart-label{font-size:9px;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:0.5px;}

/* ════ DOC GRID ════ */
.doc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.doc-item{border:1.5px solid var(--gray-200);border-radius:var(--r-sm);padding:11px 13px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:var(--tr);position:relative;overflow:hidden;}
.doc-item:hover{border-color:var(--gold-400);background:var(--gold-50);}
.doc-item input{position:absolute;inset:0;opacity:0;cursor:pointer;}
.doc-item i{font-size:20px;color:var(--navy-400);flex-shrink:0;}
.doc-item-name{font-size:12px;font-weight:700;color:var(--gray-700);}
.doc-item-status{font-size:11px;color:var(--gray-400);}
.doc-item.uploaded{border-color:var(--teal-400);background:var(--teal-50);}
.doc-item.uploaded i{color:var(--teal-600);}

/* ════ PHOTO UPLOAD ════ */
.photo-upload{border:2px dashed var(--gray-200);border-radius:var(--r-md);padding:18px;text-align:center;cursor:pointer;transition:var(--tr);background:var(--gray-50);position:relative;}
.photo-upload:hover{border-color:var(--gold-400);background:var(--gold-50);}
.photo-upload input{position:absolute;inset:0;opacity:0;cursor:pointer;}
.photo-frame{width:80px;height:96px;border-radius:8px;background:var(--navy-100);margin:0 auto 10px;display:flex;align-items:center;justify-content:center;overflow:hidden;border:2px solid var(--navy-200);}
.photo-frame img{width:100%;height:100%;object-fit:cover;display:none;}
.photo-frame i{font-size:30px;color:var(--navy-400);}

/* ════ ID CARD ════ */
.id-card{width:320px;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);margin:0 auto;}
.id-card-top{background:linear-gradient(135deg,var(--navy-800),var(--navy-600));padding:16px 20px;text-align:center;border-bottom:4px solid var(--gold-400);}
.id-card-school{color:var(--gold-300);font-size:13px;font-weight:700;letter-spacing:0.5px;}
.id-card-body{background:#fff;padding:20px;text-align:center;}
.id-card-photo{width:80px;height:96px;border-radius:8px;background:var(--navy-100);border:3px solid var(--gold-400);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:32px;color:var(--navy-400);}
.id-card-name{font-size:16px;font-weight:800;color:var(--navy-900);}
.id-card-class{font-size:11px;color:var(--gray-400);}
.id-card-tbl{width:100%;margin-top:10px;font-size:11px;text-align:left;}
.id-card-tbl td{padding:3px 0;color:var(--gray-600);}
.id-card-tbl td:first-child{font-weight:700;color:var(--gray-400);width:38%;}
.id-card-foot{background:linear-gradient(135deg,var(--gold-500),var(--gold-400));padding:10px;text-align:center;font-size:13px;font-weight:800;color:var(--navy-900);letter-spacing:1px;}

/* ════ SUCCESS SCREEN ════ */
.success-screen{text-align:center;padding:40px 24px;}
.success-ico{width:68px;height:68px;border-radius:50%;background:linear-gradient(135deg,var(--teal-400),var(--teal-600));display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:30px;color:#fff;box-shadow:0 4px 24px rgba(29,158,117,0.35);}
.adm-chip{display:inline-block;background:linear-gradient(135deg,var(--navy-50),var(--gold-50));border:2px dashed var(--gold-400);border-radius:var(--r-md);padding:12px 28px;margin:14px 0;}
.adm-chip-label{font-size:9px;color:var(--gold-700);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;}
.adm-chip-val{font-size:22px;font-weight:800;color:var(--navy-800);letter-spacing:3px;}

/* ════ PAGE TRANSITIONS ════ */
.page{display:none;animation:fadeUp 0.22s ease;}
.page.active{display:block;}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ════ RESPONSIVE ════ */
@media(max-width:1200px){.stat-row{grid-template-columns:repeat(2,1fr);}.school-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:900px){.qa-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);}.sidebar.open{transform:translateX(0);}
  .main{margin-left:0;}.menu-btn{display:block;}
  .stat-row{grid-template-columns:1fr 1fr;}.qa-grid{grid-template-columns:repeat(2,1fr);}
  .form-grid{grid-template-columns:1fr;}.form-grid.g3{grid-template-columns:1fr;}.form-grid.g4{grid-template-columns:1fr 1fr;}
  .school-grid{grid-template-columns:1fr;}.hero-kpis{display:none;}
  .doc-grid{grid-template-columns:1fr;}
}
@media(max-width:480px){.stat-row{grid-template-columns:1fr;}.qa-grid{grid-template-columns:1fr 1fr;}}
