﻿@font-face{font-family:VazirmatnLocal;src:url('Vazirmatn-Regular.ttf') format('truetype');font-display:swap}
:root{--st-bg:#071424;--st-panel:rgba(15,31,52,.92);--st-card:rgba(255,255,255,.08);--st-line:rgba(255,255,255,.14);--st-text:#f7fbff;--st-muted:#b8c8dc;--st-gold:#f4c35b;--st-blue:#38bdf8;--st-green:#35d08a;--st-red:#ff6b6b;--st-violet:#8b5cf6;--st-shadow:0 22px 60px rgba(0,0,0,.35)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:VazirmatnLocal,Tahoma,Arial,sans-serif;background:radial-gradient(circle at 20% 10%,rgba(56,189,248,.18),transparent 30%),radial-gradient(circle at 80% 5%,rgba(244,195,91,.14),transparent 28%),linear-gradient(135deg,#071424,#0b1830 52%,#08111f);color:var(--st-text);direction:rtl;min-height:100vh}.student-login-page,.student-panel-page{overflow-x:hidden}.student-login-bg span{position:fixed;border-radius:999px;filter:blur(12px);opacity:.55;pointer-events:none}.student-login-bg span:nth-child(1){width:320px;height:320px;background:#38bdf8;right:-80px;top:-80px}.student-login-bg span:nth-child(2){width:260px;height:260px;background:#f4c35b;left:8%;top:12%}.student-login-bg span:nth-child(3){width:240px;height:240px;background:#8b5cf6;left:16%;bottom:5%}.student-login-shell{min-height:100vh;display:grid;place-items:center;padding:28px}.student-login-card{width:min(520px,100%);background:linear-gradient(160deg,rgba(255,255,255,.13),rgba(255,255,255,.055));border:1px solid var(--st-line);box-shadow:var(--st-shadow);border-radius:32px;padding:30px;backdrop-filter:blur(18px)}.student-login-brand{display:flex;align-items:center;gap:14px;margin-bottom:20px}.student-login-brand img{width:74px;height:74px;object-fit:contain;background:rgba(255,255,255,.08);border-radius:22px;padding:8px}.student-login-brand b{display:block;font-size:18px}.student-login-brand small{display:block;color:var(--st-muted);margin-top:4px}.student-login-card h1{margin:8px 0 10px;font-size:32px}.student-login-lead{color:var(--st-muted);line-height:2;margin:0 0 22px}.student-alert{background:rgba(255,107,107,.14);border:1px solid rgba(255,107,107,.35);color:#ffe0e0;border-radius:18px;padding:12px 14px;margin:12px 0;line-height:1.8}.student-login-form label{display:block;color:var(--st-muted);margin-bottom:8px}.student-login-form input,.student-profile-form input,.student-profile-form textarea,.student-filter-bar input,.student-filter-bar select{width:100%;border:1px solid rgba(255,255,255,.14);background:rgba(5,14,27,.75);color:var(--st-text);border-radius:16px;padding:13px 14px;font:inherit;outline:none}.student-login-form input:focus,.student-profile-form input:focus,.student-profile-form textarea:focus,.student-filter-bar input:focus,.student-filter-bar select:focus{border-color:rgba(56,189,248,.75);box-shadow:0 0 0 4px rgba(56,189,248,.14)}.student-login-form button,.student-main-btn{width:100%;margin-top:16px;border:0;border-radius:18px;padding:14px 18px;background:linear-gradient(135deg,var(--st-gold),#ffdf89);color:#1d1605;font-weight:900;font:inherit;cursor:pointer;box-shadow:0 14px 34px rgba(244,195,91,.2)}.student-main-btn.ghost{width:auto;background:linear-gradient(135deg,rgba(56,189,248,.22),rgba(139,92,246,.2));color:#eaf7ff;border:1px solid rgba(56,189,248,.25);box-shadow:none}.student-login-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:18px}.student-login-actions a{color:#d8eeff;text-decoration:none;background:rgba(255,255,255,.08);border:1px solid var(--st-line);padding:9px 13px;border-radius:14px}.student-topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px clamp(14px,3vw,34px);background:rgba(7,20,36,.84);border-bottom:1px solid var(--st-line);backdrop-filter:blur(16px)}.student-brand{display:flex;align-items:center;gap:12px}.student-brand img{width:56px;height:56px;object-fit:contain;border-radius:18px;background:rgba(255,255,255,.08);padding:6px}.student-brand strong{display:block;font-size:18px}.student-brand span{display:block;color:var(--st-muted);font-size:13px}.student-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.student-nav a{color:var(--st-text);text-decoration:none;background:rgba(255,255,255,.08);border:1px solid var(--st-line);padding:10px 14px;border-radius:16px}.student-nav a.danger{background:rgba(255,107,107,.14);border-color:rgba(255,107,107,.25)}.student-shell{width:min(1220px,calc(100% - 28px));margin:24px auto 80px}.student-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;background:linear-gradient(135deg,rgba(56,189,248,.16),rgba(244,195,91,.1));border:1px solid var(--st-line);border-radius:30px;padding:26px;box-shadow:var(--st-shadow)}.student-hero h1{margin:0 0 10px;font-size:30px}.student-hero p{margin:0;color:var(--st-muted);line-height:1.9}.student-hero-badge{min-width:230px;background:rgba(255,255,255,.08);border:1px solid var(--st-line);border-radius:22px;padding:16px;text-align:center}.student-hero-badge span{display:block;color:var(--st-muted);font-size:13px}.student-hero-badge b{display:block;margin-top:8px;font-size:20px;color:var(--st-gold)}.student-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:16px 0}.student-summary-grid article{background:var(--st-card);border:1px solid var(--st-line);border-radius:24px;padding:18px;box-shadow:0 14px 34px rgba(0,0,0,.16)}.student-summary-grid span{display:block;color:var(--st-muted);font-size:13px}.student-summary-grid b{display:block;margin-top:8px;font-size:24px;color:#fff}.student-card{background:var(--st-panel);border:1px solid var(--st-line);border-radius:28px;padding:20px;margin:18px 0;box-shadow:var(--st-shadow);overflow:hidden}.student-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}.student-section-head h2{margin:0 0 8px;font-size:22px}.student-section-head p{margin:0;color:var(--st-muted);line-height:1.8}.student-soft-btn{border:1px solid rgba(56,189,248,.28);background:rgba(56,189,248,.12);color:#e6f7ff;border-radius:16px;padding:11px 16px;font:inherit;cursor:pointer}.student-profile-form.collapsed{display:none}.student-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.student-form-grid label{display:grid;gap:8px;color:var(--st-muted)}.student-form-grid .wide{grid-column:1/-1}.student-profile-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.student-profile-actions .student-main-btn{width:auto;margin:0}.student-form-message{margin-top:12px;min-height:28px;line-height:1.8}.student-form-message.ok{color:#9ff0c8}.student-form-message.error{color:#ffb4b4}.student-form-message.warn{color:#ffe1a3}.student-filter-bar{display:grid;grid-template-columns:220px 220px minmax(260px,1fr);gap:12px;align-items:end;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:14px;margin-bottom:14px}.student-filter-bar label{display:grid;gap:7px;color:var(--st-muted);font-size:13px}.student-filter-bar .wide{min-width:0}.student-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid rgba(255,255,255,.1);border-radius:22px;background:rgba(0,0,0,.13)}.student-table{width:100%;min-width:880px;border-collapse:collapse}.student-table th,.student-table td{padding:13px 12px;border-bottom:1px solid rgba(255,255,255,.09);text-align:right;vertical-align:middle;white-space:nowrap}.student-table th{color:#dff4ff;background:rgba(56,189,248,.09);font-weight:900;position:sticky;top:0}.student-table td small{display:block;color:var(--st-muted);font-size:12px;margin-top:4px}.student-table .empty{text-align:center;color:var(--st-muted);padding:28px!important}.status-pill{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900;border:1px solid transparent}.status-pill.held,.status-pill.clear{background:rgba(53,208,138,.14);color:#9ff0c8;border-color:rgba(53,208,138,.22)}.status-pill.cancelled,.status-pill.debt{background:rgba(255,107,107,.14);color:#ffb9b9;border-color:rgba(255,107,107,.24)}.status-pill.scheduled,.status-pill.credit{background:rgba(56,189,248,.14);color:#bdeeff;border-color:rgba(56,189,248,.24)}.student-finance-total{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}.student-finance-total span{background:rgba(255,255,255,.075);border:1px solid var(--st-line);border-radius:16px;padding:10px 13px}.student-finance-total b{color:var(--st-gold)}.student-pay-soon{margin-top:14px;background:rgba(244,195,91,.1);border:1px solid rgba(244,195,91,.22);color:#ffe7ab;border-radius:18px;padding:12px 14px;line-height:1.8}.student-quick-nav{position:fixed;left:18px;top:118px;z-index:30;width:190px;background:rgba(7,20,36,.9);border:1px solid var(--st-line);border-radius:22px;padding:12px;box-shadow:var(--st-shadow);backdrop-filter:blur(14px);display:grid;gap:8px}.student-quick-nav.hidden{display:none}.student-quick-nav b{color:var(--st-gold);padding:4px 6px}.student-quick-nav a,.student-quick-nav button,.student-quick-show{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.075);color:var(--st-text);text-decoration:none;border-radius:14px;padding:9px 10px;font:inherit;cursor:pointer;text-align:center}.student-quick-nav .sqn-hide{background:rgba(255,107,107,.13);color:#ffd6d6}.student-quick-show{position:fixed;left:18px;top:118px;z-index:29;display:none;background:rgba(56,189,248,.22)}.student-quick-show.visible{display:block}@media print{body{background:#fff;color:#111}.student-topbar,.student-quick-nav,.student-quick-show,.student-filter-bar,.student-profile-card,.student-pay-soon,.student-main-btn{display:none!important}.student-card,.student-hero,.student-summary-grid article{box-shadow:none;border:1px solid #ddd;background:#fff;color:#111}.student-table th,.student-table td{color:#111;border-color:#ddd}.student-table-wrap{overflow:visible}.student-table{min-width:0}}
@media (max-width:980px){.student-nav{display:none}.student-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.student-filter-bar{grid-template-columns:1fr 1fr}.student-filter-bar .wide{grid-column:1/-1}.student-quick-nav{top:auto;bottom:18px;left:14px;width:170px}.student-quick-show{top:auto;bottom:18px;left:14px}.student-hero{align-items:stretch;flex-direction:column}.student-hero-badge{min-width:0}}
@media (max-width:680px){body{background:#071424}.student-login-shell{padding:14px}.student-login-card{border-radius:24px;padding:22px}.student-topbar{position:relative;align-items:flex-start}.student-shell{width:calc(100% - 18px);margin-top:12px}.student-hero{padding:18px;border-radius:22px}.student-hero h1{font-size:23px}.student-summary-grid{grid-template-columns:1fr 1fr;gap:10px}.student-summary-grid article{border-radius:18px;padding:14px}.student-card{border-radius:22px;padding:14px}.student-section-head{flex-direction:column}.student-form-grid,.student-filter-bar{grid-template-columns:1fr}.student-table-wrap{border:0;background:transparent;overflow:visible}.student-table{min-width:0;border-collapse:separate;border-spacing:0 10px}.student-table thead{display:none}.student-table tr{display:block;background:rgba(255,255,255,.065);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:10px;margin-bottom:10px}.student-table td{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;border:0;padding:8px 6px;white-space:normal;text-align:left;direction:rtl}.student-table td::before{content:attr(data-label);color:var(--st-muted);font-size:12px;min-width:96px;text-align:right}.student-table td small{text-align:left}.student-table .empty{display:block;text-align:center}.student-finance-total{display:grid}.student-profile-actions{display:grid}.student-profile-actions .student-main-btn,.student-profile-actions .student-soft-btn,.student-main-btn.ghost{width:100%}.student-quick-nav{right:10px;left:auto;bottom:10px;width:min(190px,calc(100% - 20px))}.student-quick-show{right:10px;left:auto;bottom:10px}}

/* v234 - student dashboard header/hero polish only */
.student-topbar-v234{
  position:sticky;
  top:0;
  z-index:45;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:12px clamp(14px,3vw,34px);
  background:linear-gradient(180deg,rgba(8,20,37,.94),rgba(8,20,37,.82));
  border-bottom:1px solid rgba(56,189,248,.18);
  box-shadow:0 14px 36px rgba(0,0,0,.22);
}
.student-brand-v234{
  min-width:260px;
  padding:8px 10px;
  border-radius:24px;
  background:linear-gradient(135deg,rgba(255,255,255,.09),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);
}
.student-brand-v234 img{
  width:62px;
  height:62px;
  border-radius:22px;
  background:radial-gradient(circle at 30% 20%,rgba(244,195,91,.25),rgba(255,255,255,.07));
  box-shadow:0 12px 30px rgba(244,195,91,.12);
}
.student-brand-v234 strong{font-size:20px;color:#fff;letter-spacing:-.3px}
.student-brand-v234 span{font-size:13px;color:#cfe2f6;margin-top:3px}
.student-nav-v234{gap:8px;justify-content:flex-end}
.student-nav-v234 a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 14px;
  border-radius:999px;
  background:linear-gradient(135deg,rgba(255,255,255,.095),rgba(255,255,255,.045));
  border:1px solid rgba(255,255,255,.13);
  color:#edf8ff;
  font-weight:800;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.student-nav-v234 a:hover{border-color:rgba(56,189,248,.45);background:rgba(56,189,248,.14)}
.student-nav-v234 a.danger{background:linear-gradient(135deg,rgba(255,107,107,.24),rgba(255,107,107,.1));border-color:rgba(255,107,107,.28);color:#ffe8e8}
.student-hero-v234{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-columns:108px minmax(0,1fr) minmax(220px,300px);
  align-items:center;
  gap:22px;
  padding:30px;
  background:
    radial-gradient(circle at 10% 10%,rgba(244,195,91,.18),transparent 26%),
    radial-gradient(circle at 82% 20%,rgba(56,189,248,.24),transparent 34%),
    linear-gradient(135deg,rgba(20,40,70,.95),rgba(10,24,43,.93));
  border-color:rgba(56,189,248,.22);
}
.student-hero-v234:before{
  content:"";
  position:absolute;
  inset:auto -10% -55% 20%;
  height:180px;
  background:linear-gradient(90deg,transparent,rgba(56,189,248,.17),transparent);
  transform:rotate(-7deg);
  pointer-events:none;
}
.student-hero-logo-v234{
  width:98px;
  height:98px;
  border-radius:30px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,rgba(244,195,91,.22),rgba(255,255,255,.07));
  border:1px solid rgba(244,195,91,.26);
  box-shadow:0 18px 42px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.12);
}
.student-hero-logo-v234 img{width:82px;height:82px;object-fit:contain}
.student-dash-chip-v234{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:12px;
  padding:8px 13px;
  border-radius:999px;
  color:#dff5ff;
  background:rgba(56,189,248,.12);
  border:1px solid rgba(56,189,248,.25);
  font-weight:900;
  font-size:13px;
}
.student-hero-copy-v234 h1{font-size:clamp(30px,4.2vw,54px);line-height:1.35;margin:0 0 10px;color:#fff;letter-spacing:-1px}
.student-hero-copy-v234 p{max-width:760px;color:#d3e2f1;font-size:16px}
.student-hero-actions-v234{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.student-hero-actions-v234 a{
  text-decoration:none;
  color:#081421;
  background:linear-gradient(135deg,#38bdf8,#8b5cf6);
  color:#fff;
  border:1px solid rgba(255,255,255,.16);
  border-radius:18px;
  padding:11px 16px;
  font-weight:900;
  box-shadow:0 14px 36px rgba(56,189,248,.16);
}
.student-hero-actions-v234 a:nth-child(2){background:linear-gradient(135deg,rgba(255,255,255,.14),rgba(255,255,255,.06));color:#fff}
.student-hero-badge-v234{
  min-width:0;
  background:linear-gradient(180deg,rgba(5,17,32,.56),rgba(255,255,255,.07));
  border-color:rgba(244,195,91,.22);
}
.student-hero-badge-v234 small{display:block;margin-top:8px;color:#9fb5cb;font-size:12px;direction:ltr;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.student-floating-top-v234{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:60;
  width:54px;
  height:54px;
  border:0;
  border-radius:18px;
  cursor:pointer;
  display:none;
  align-items:center;
  justify-content:center;
  font:900 28px/1 VazirmatnLocal,Tahoma,Arial,sans-serif;
  color:#fff;
  background:linear-gradient(135deg,#38bdf8,#8b5cf6);
  box-shadow:0 18px 42px rgba(56,189,248,.25);
}
.student-floating-top-v234.visible{display:flex}
.student-main-btn,.student-soft-btn,.student-nav-v234 a,.student-hero-actions-v234 a,.student-quick-nav a,.student-quick-nav button,.student-quick-show{transition:transform .16s ease,border-color .16s ease,background .16s ease}
.student-main-btn:hover,.student-soft-btn:hover,.student-nav-v234 a:hover,.student-hero-actions-v234 a:hover,.student-quick-nav a:hover,.student-quick-nav button:hover,.student-quick-show:hover{transform:translateY(-1px)}

@media (max-width:1100px){
  .student-topbar-v234{align-items:stretch;flex-direction:column}
  .student-brand-v234{width:100%;min-width:0;justify-content:center}
  .student-nav-v234{justify-content:center}
  .student-hero-v234{grid-template-columns:92px minmax(0,1fr);}
  .student-hero-badge-v234{grid-column:1/-1;width:100%}
}
@media (max-width:680px){
  .student-topbar-v234{position:relative;padding:10px 10px 12px;border-radius:0 0 22px 22px}
  .student-brand-v234{justify-content:flex-start;border-radius:20px;padding:8px}
  .student-brand-v234 img{width:52px;height:52px;border-radius:18px}
  .student-brand-v234 strong{font-size:17px}
  .student-nav-v234{display:grid!important;grid-template-columns:1fr 1fr;gap:8px;width:100%}
  .student-nav-v234 a{min-height:40px;padding:9px 8px;font-size:12px;border-radius:15px}
  .student-nav-v234 a.danger{grid-column:auto}
  .student-hero-v234{grid-template-columns:1fr;text-align:center;padding:18px;gap:14px}
  .student-hero-logo-v234{margin:0 auto;width:86px;height:86px;border-radius:26px}
  .student-hero-logo-v234 img{width:72px;height:72px}
  .student-hero-copy-v234 h1{font-size:29px}
  .student-hero-copy-v234 p{font-size:14px}
  .student-hero-actions-v234{display:grid;grid-template-columns:1fr;gap:9px}
  .student-hero-actions-v234 a{padding:12px 14px;border-radius:16px}
  .student-hero-badge-v234{text-align:center;border-radius:18px}
  .student-floating-top-v234{right:14px;bottom:14px;width:50px;height:50px;border-radius:17px}
}

/* v235 - student photo in dashboard/profile only */
.student-hero-photo-v235{
  width:108px;
  height:108px;
  border-radius:34px;
  display:grid;
  place-items:center;
  overflow:hidden;
  background:
    radial-gradient(circle at 35% 20%,rgba(56,189,248,.26),transparent 42%),
    linear-gradient(135deg,rgba(244,195,91,.2),rgba(255,255,255,.07));
  border:1px solid rgba(244,195,91,.28);
  box-shadow:0 18px 42px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.12);
}
.student-hero-photo-v235 img,
.student-profile-photo-preview-v235 img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.student-hero-photo-v235 span,
.student-profile-photo-preview-v235 span{
  display:grid;
  place-items:center;
  width:100%;
  height:100%;
  font-weight:950;
  color:#fff;
  font-size:44px;
  background:linear-gradient(135deg,rgba(56,189,248,.28),rgba(139,92,246,.22));
  text-shadow:0 6px 18px rgba(0,0,0,.35);
}
.student-profile-photo-editor-v235{
  display:flex;
  align-items:center;
  gap:18px;
  padding:16px;
  margin-bottom:16px;
  border-radius:24px;
  background:linear-gradient(135deg,rgba(56,189,248,.11),rgba(255,255,255,.045));
  border:1px solid rgba(56,189,248,.18);
}
.student-profile-photo-preview-v235{
  flex:0 0 112px;
  width:112px;
  height:112px;
  border-radius:34px;
  overflow:hidden;
  display:grid;
  place-items:center;
  background:rgba(5,14,27,.72);
  border:1px solid rgba(244,195,91,.28);
  box-shadow:0 14px 34px rgba(0,0,0,.18);
}
.student-profile-photo-tools-v235{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  flex:1;
}
.student-profile-photo-tools-v235 strong{
  flex-basis:100%;
  color:#fff;
  font-size:18px;
}
.student-profile-photo-tools-v235 p{
  flex-basis:100%;
  margin:0;
  color:var(--st-muted);
  line-height:1.8;
  font-size:13px;
}
.student-photo-pick-btn-v235{
  position:relative;
  overflow:hidden;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:11px 18px;
  border-radius:16px;
  cursor:pointer;
  font-weight:900;
  color:#fff;
  background:linear-gradient(135deg,#38bdf8,#8b5cf6);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 14px 34px rgba(56,189,248,.14);
}
.student-photo-pick-btn-v235 input{
  position:absolute;
  inset:0;
  opacity:0;
  cursor:pointer;
}
@media (max-width:1100px){
  .student-hero-photo-v235{width:96px;height:96px;border-radius:30px}
}
@media (max-width:680px){
  .student-hero-photo-v235{margin:0 auto;width:94px;height:94px;border-radius:30px}
  .student-hero-photo-v235 span{font-size:36px}
  .student-profile-photo-editor-v235{flex-direction:column;text-align:center;border-radius:20px;padding:14px}
  .student-profile-photo-tools-v235{justify-content:center}
  .student-profile-photo-preview-v235{width:104px;height:104px;flex-basis:104px;border-radius:30px}
  .student-photo-pick-btn-v235,.student-profile-photo-tools-v235 .student-soft-btn{width:100%}
}

/* v236 - Student panel phase 2A: schedule + finance polish only */
.student-alerts-card-v236{border-color:rgba(56,189,248,.35);background:linear-gradient(135deg,rgba(14,31,53,.96),rgba(7,16,31,.98));}
.student-alerts-list-v236{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px;transition:max-height .25s ease,opacity .2s ease;overflow:hidden;}
.student-alerts-list-v236.collapsed{max-height:0;opacity:0;margin-top:0;}
.student-alert-item-v236,.student-mini-loading-v236{border:1px solid rgba(56,189,248,.25);background:rgba(8,24,44,.72);border-radius:18px;padding:13px 15px;color:#e8f6ff;font-weight:800;line-height:1.9;box-shadow:0 12px 30px rgba(0,0,0,.18) inset;}
.student-alert-item-v236.info{border-color:rgba(56,189,248,.35);}
.student-alert-item-v236.warn{border-color:rgba(245,158,11,.45);background:rgba(78,52,10,.20);}
.student-alert-item-v236.danger{border-color:rgba(248,113,113,.55);background:rgba(89,20,35,.25);}
.student-alert-item-v236.ok{border-color:rgba(34,197,94,.45);background:rgba(16,90,53,.22);}
.student-filter-bar-v236{align-items:end;grid-template-columns:repeat(4,minmax(130px,1fr)) minmax(220px,1.4fr);}
.student-filter-bar-v236 input[type="text"]{direction:ltr;text-align:center;font-weight:900;letter-spacing:.3px;}
.student-finance-cards-v236{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:14px 0;}
.student-finance-cards-v236 article{border:1px solid rgba(56,189,248,.26);background:linear-gradient(180deg,rgba(14,46,76,.74),rgba(6,20,37,.76));border-radius:18px;padding:14px;text-align:center;box-shadow:0 16px 30px rgba(0,0,0,.14);}
.student-finance-cards-v236 span{display:block;color:#a7c8db;font-size:.9rem;font-weight:900;margin-bottom:6px;}
.student-finance-cards-v236 b{display:block;color:#f8fbff;font-size:1.05rem;font-weight:1000;white-space:nowrap;}
.student-finance-cards-v236 small{display:block;color:#a7f3d0;font-weight:900;margin-top:4px;}
.student-table td small{display:block;margin-top:4px;color:#9ecce4;font-size:.78rem;font-weight:800;}
.student-table tr.finance-debt td[data-label="مانده"] b{color:#fecaca;}
.student-table tr.finance-credit td[data-label="مانده"] b{color:#bbf7d0;}
.student-pay-soon{border:1px dashed rgba(59,130,246,.45);background:rgba(37,99,235,.10);border-radius:16px;padding:13px 15px;color:#bfdbfe;font-weight:900;text-align:center;margin-top:14px;}
@media (max-width: 1100px){
  .student-filter-bar-v236{grid-template-columns:repeat(2,minmax(0,1fr));}
  .student-filter-bar-v236 .wide{grid-column:1/-1;}
  .student-alerts-list-v236,.student-finance-cards-v236{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 720px){
  .student-filter-bar-v236,.student-alerts-list-v236,.student-finance-cards-v236{grid-template-columns:1fr;}
  .student-alert-item-v236{font-size:.92rem;}
  .student-finance-cards-v236 b{white-space:normal;}
  .student-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .student-table{min-width:760px;}
}
@media print{
  .student-alerts-card-v236,.student-quick-nav,.student-quick-show,.student-floating-top-v234,.student-nav{display:none!important;}
}

/* v237 - final mobile/PWA table cards for student schedule + finance only */
@media (max-width: 720px){
  .student-card#studentSchedule,
  .student-card#studentFinance{
    overflow: visible !important;
  }

  #studentSchedule .student-table-wrap,
  #studentFinance .student-table-wrap{
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
    border: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
  }

  #studentScheduleTable.student-table,
  #studentFinanceTable.student-table{
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    table-layout: auto !important;
    background: transparent !important;
  }

  #studentScheduleTable thead,
  #studentFinanceTable thead{
    display: none !important;
  }

  #studentScheduleTable tbody,
  #studentFinanceTable tbody{
    display: grid !important;
    width: 100% !important;
    gap: 12px !important;
  }

  #studentScheduleTable tr,
  #studentFinanceTable tr{
    display: grid !important;
    width: 100% !important;
    grid-template-columns: 1fr !important;
    margin: 0 !important;
    padding: 12px !important;
    border-radius: 22px !important;
    border: 1px solid rgba(56,189,248,.22) !important;
    background: linear-gradient(180deg,rgba(14,40,67,.82),rgba(7,18,34,.92)) !important;
    box-shadow: 0 14px 32px rgba(0,0,0,.18) !important;
    overflow: hidden !important;
  }

  #studentScheduleTable td,
  #studentFinanceTable td{
    display: grid !important;
    grid-template-columns: 108px minmax(0,1fr) !important;
    align-items: center !important;
    gap: 10px !important;
    width: 100% !important;
    min-width: 0 !important;
    padding: 10px 6px !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,.075) !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
    text-align: right !important;
    direction: rtl !important;
    color: #f5fbff !important;
    line-height: 1.75 !important;
  }

  #studentScheduleTable td:last-child,
  #studentFinanceTable td:last-child{
    border-bottom: 0 !important;
  }

  #studentScheduleTable td::before,
  #studentFinanceTable td::before{
    content: attr(data-label) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 0 !important;
    width: auto !important;
    height: 32px !important;
    padding: 4px 8px !important;
    border-radius: 999px !important;
    background: rgba(56,189,248,.13) !important;
    border: 1px solid rgba(56,189,248,.22) !important;
    color: #bfeaff !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    text-align: center !important;
    white-space: nowrap !important;
  }

  #studentScheduleTable td small,
  #studentFinanceTable td small{
    display: block !important;
    margin-top: 3px !important;
    color: #9ecce4 !important;
    font-size: 12px !important;
    line-height: 1.6 !important;
    text-align: right !important;
  }

  #studentScheduleTable .status-pill,
  #studentFinanceTable .status-pill{
    width: fit-content !important;
    max-width: 100% !important;
    white-space: normal !important;
    line-height: 1.6 !important;
  }

  #studentScheduleTable td.empty,
  #studentFinanceTable td.empty{
    display: block !important;
    text-align: center !important;
    padding: 22px 12px !important;
    color: #cfe2f6 !important;
  }

  #studentScheduleTable td.empty::before,
  #studentFinanceTable td.empty::before{
    content: none !important;
  }
}

@media (max-width: 430px){
  #studentScheduleTable td,
  #studentFinanceTable td{
    grid-template-columns: 92px minmax(0,1fr) !important;
    gap: 8px !important;
    font-size: 13px !important;
  }
  #studentScheduleTable td::before,
  #studentFinanceTable td::before{
    font-size: 11px !important;
    padding-inline: 6px !important;
  }
}


/* v276 - two column elegant student login page only */
.student-login-shell-v276{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:clamp(18px,3vw,42px);
}
.student-login-layout-v276{
  width:min(1120px,calc(100vw - 36px));
  display:grid;
  grid-template-columns:minmax(420px,520px) minmax(360px,1fr);
  gap:24px;
  align-items:stretch;
  direction:rtl;
}
.student-login-card-v276{
  width:100%;
  min-height:560px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:
    linear-gradient(160deg,rgba(255,255,255,.145),rgba(255,255,255,.055)),
    radial-gradient(circle at 8% 12%,rgba(56,189,248,.12),transparent 28%);
  border-color:rgba(255,255,255,.16);
}
.student-login-card-v276 .student-login-brand{
  padding:10px;
  border-radius:24px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.09);
}
.student-login-card-v276 h1{
  font-size:clamp(34px,4vw,46px);
  letter-spacing:-.8px;
}
.student-login-card-v276 .student-login-lead{
  font-size:15.5px;
  color:#d3e2f1;
}
.student-login-card-v276 .student-login-form input{
  min-height:58px;
  border-radius:20px;
  font-size:18px;
  background:rgba(3,12,24,.82);
}
.student-login-card-v276 .student-login-form button{
  min-height:58px;
  border-radius:20px;
  background:linear-gradient(135deg,#ffd875,#f4c35b 46%,#ffb347);
  box-shadow:0 18px 40px rgba(244,195,91,.24);
}
.student-login-card-v276 .student-login-actions a{
  min-height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding-inline:16px;
}
.student-login-visual-v276{
  position:relative;
  overflow:hidden;
  min-height:560px;
  border-radius:34px;
  padding:28px;
  background:
    radial-gradient(circle at 20% 18%,rgba(244,195,91,.26),transparent 28%),
    radial-gradient(circle at 78% 30%,rgba(56,189,248,.28),transparent 34%),
    linear-gradient(145deg,rgba(8,24,45,.95),rgba(11,18,36,.9));
  border:1px solid rgba(255,255,255,.15);
  box-shadow:0 28px 80px rgba(0,0,0,.36),inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  isolation:isolate;
}
.student-login-visual-v276:before{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.08);
  pointer-events:none;
  z-index:-1;
}
.visual-glow{
  position:absolute;
  border-radius:999px;
  filter:blur(10px);
  opacity:.55;
  pointer-events:none;
  z-index:-2;
}
.visual-glow-one{width:220px;height:220px;background:#38bdf8;left:-70px;top:42px;}
.visual-glow-two{width:260px;height:260px;background:#8b5cf6;right:-96px;bottom:-86px;}
.visual-topline-v276{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:#eaf7ff;
  font-weight:900;
}
.visual-topline-v276 span{
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
}
.visual-topline-v276 b{
  direction:ltr;
  color:#081421;
  background:linear-gradient(135deg,#38bdf8,#f4c35b);
  border-radius:16px;
  padding:9px 13px;
  box-shadow:0 12px 28px rgba(56,189,248,.18);
}
.visual-illustration-v276{
  position:relative;
  min-height:330px;
  margin:18px 0;
}
.visual-board-v276{
  position:absolute;
  inset:34px 34px auto auto;
  width:min(360px,74%);
  min-height:150px;
  border-radius:28px;
  padding:24px 24px 22px;
  background:linear-gradient(145deg,rgba(255,255,255,.14),rgba(255,255,255,.055));
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 22px 54px rgba(0,0,0,.24);
}
.visual-board-v276 span{
  display:block;
  height:8px;
  border-radius:999px;
  margin:10px 0;
  background:linear-gradient(90deg,rgba(56,189,248,.1),rgba(56,189,248,.85),rgba(244,195,91,.7));
}
.visual-board-v276 span:nth-child(1){width:78%;}
.visual-board-v276 span:nth-child(2){width:58%;}
.visual-board-v276 span:nth-child(3){width:68%;}
.visual-board-v276 strong{
  display:block;
  margin-top:14px;
  color:#fff;
  font-size:22px;
}
.visual-board-v276 small{
  display:block;
  margin-top:8px;
  color:#bfd2e7;
  line-height:1.8;
}
.visual-book-v276{
  position:absolute;
  right:22px;
  bottom:42px;
  width:170px;
  height:104px;
  border-radius:24px;
  background:linear-gradient(135deg,#f4c35b,#ffdc7a);
  transform:rotate(-6deg);
  box-shadow:0 22px 46px rgba(244,195,91,.2);
}
.visual-book-v276:before{
  content:"";
  position:absolute;
  right:50%;
  top:12px;
  bottom:12px;
  width:2px;
  background:rgba(80,50,10,.3);
}
.visual-book-v276 i{
  position:absolute;
  top:22px;
  width:54px;
  height:8px;
  border-radius:999px;
  background:rgba(93,62,10,.32);
}
.visual-book-v276 i:nth-child(1){right:22px;}
.visual-book-v276 i:nth-child(2){left:22px;}
.visual-student-v276{
  position:absolute;
  left:50px;
  bottom:44px;
  width:124px;
  height:154px;
  border-radius:38px 38px 30px 30px;
  background:linear-gradient(180deg,#38bdf8,#2563eb);
  box-shadow:0 22px 48px rgba(37,99,235,.26);
}
.visual-student-v276:before{
  content:"";
  position:absolute;
  top:-42px;
  left:26px;
  width:72px;
  height:72px;
  border-radius:50%;
  background:linear-gradient(135deg,#ffe2ac,#f4c35b);
  box-shadow:0 14px 30px rgba(0,0,0,.18);
}
.visual-student-v276:after{
  content:"";
  position:absolute;
  top:-54px;
  left:16px;
  width:92px;
  height:34px;
  border-radius:22px 22px 10px 10px;
  background:#13233c;
  transform:rotate(2deg);
}
.visual-student-v276 em{
  position:absolute;
  inset:28px 20px auto;
  height:12px;
  border-radius:999px;
  background:rgba(255,255,255,.72);
  box-shadow:0 22px 0 rgba(255,255,255,.45),0 44px 0 rgba(255,255,255,.25);
}
.visual-card-v276{
  position:absolute;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:10px 16px;
  border-radius:18px;
  color:#eaf7ff;
  font-weight:950;
  background:rgba(5,14,27,.74);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 18px 38px rgba(0,0,0,.22);
}
.visual-card-v276.card-one{right:48px;top:202px;}
.visual-card-v276.card-two{left:44px;top:66px;}
.visual-copy-v276{
  padding:20px;
  border-radius:26px;
  background:linear-gradient(135deg,rgba(255,255,255,.09),rgba(255,255,255,.045));
  border:1px solid rgba(255,255,255,.1);
}
.visual-copy-v276 h2{
  margin:0 0 10px;
  font-size:28px;
  color:#fff;
}
.visual-copy-v276 p{
  margin:0;
  color:#cfe0f2;
  line-height:2;
}
@media (max-width:980px){
  .student-login-layout-v276{grid-template-columns:1fr;width:min(560px,calc(100vw - 28px));}
  .student-login-visual-v276{min-height:430px;order:-1;}
  .student-login-card-v276{min-height:auto;}
}
@media (max-width:680px){
  .student-login-shell-v276{padding:14px;place-items:start center;}
  .student-login-layout-v276{width:100%;gap:14px;}
  .student-login-visual-v276{display:none;}
  .student-login-card-v276{border-radius:26px;padding:22px;}
  .student-login-card-v276 h1{font-size:32px;}
}

/* v277 - redesigned student login visual with library/student image only */
.student-login-shell-v277{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:clamp(18px,3vw,42px);
}
.student-login-layout-v277{
  width:min(1180px,calc(100vw - 36px));
  display:grid;
  grid-template-columns:minmax(410px,510px) minmax(430px,1fr);
  gap:26px;
  align-items:stretch;
  direction:rtl;
}
.student-login-card-v277{
  width:100%;
  min-height:590px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:
    linear-gradient(160deg,rgba(255,255,255,.15),rgba(255,255,255,.052)),
    radial-gradient(circle at 8% 12%,rgba(56,189,248,.12),transparent 28%);
  border-color:rgba(255,255,255,.16);
}
.student-login-card-v277 .student-login-brand{
  padding:10px;
  border-radius:24px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.09);
}
.student-login-card-v277 h1{
  font-size:clamp(34px,4vw,46px);
  letter-spacing:-.8px;
}
.student-login-card-v277 .student-login-lead{
  font-size:15.5px;
  color:#d3e2f1;
}
.student-login-card-v277 .student-login-form input{
  min-height:58px;
  border-radius:20px;
  font-size:18px;
  background:rgba(3,12,24,.82);
}
.student-login-card-v277 .student-login-form button{
  min-height:58px;
  border-radius:20px;
  background:linear-gradient(135deg,#ffd875,#f4c35b 46%,#ffb347);
  box-shadow:0 18px 40px rgba(244,195,91,.24);
}
.student-login-card-v277 .student-login-actions a{
  min-height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding-inline:16px;
}
.student-login-visual-v277{
  position:relative;
  overflow:hidden;
  min-height:590px;
  border-radius:38px;
  padding:26px;
  background:
    radial-gradient(circle at 18% 16%,rgba(244,195,91,.26),transparent 28%),
    radial-gradient(circle at 80% 28%,rgba(56,189,248,.32),transparent 34%),
    linear-gradient(145deg,rgba(8,24,45,.96),rgba(9,16,32,.92));
  border:1px solid rgba(255,255,255,.15);
  box-shadow:0 32px 90px rgba(0,0,0,.38),inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  isolation:isolate;
}
.student-login-visual-v277:before{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:31px;
  border:1px solid rgba(255,255,255,.08);
  pointer-events:none;
  z-index:-1;
}
.visual-photo-head-v277{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:#eaf7ff;
  font-weight:950;
  margin-bottom:16px;
}
.visual-photo-head-v277 span{
  padding:10px 15px;
  border-radius:999px;
  background:rgba(255,255,255,.085);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.visual-photo-head-v277 b{
  color:#071421;
  background:linear-gradient(135deg,#38bdf8,#f4c35b);
  border-radius:16px;
  padding:9px 14px;
  box-shadow:0 12px 28px rgba(56,189,248,.18);
}
.student-library-photo-v277{
  position:relative;
  margin:0;
  min-height:355px;
  border-radius:32px;
  overflow:hidden;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 24px 60px rgba(0,0,0,.28);
}
.student-library-photo-v277 img{
  display:block;
  width:100%;
  height:100%;
  min-height:355px;
  object-fit:cover;
  transform:scale(1.01);
}
.student-library-photo-v277:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(5,14,27,0) 42%,rgba(5,14,27,.68) 100%);
  pointer-events:none;
}
.student-library-photo-v277 figcaption{
  position:absolute;
  right:18px;
  left:18px;
  bottom:18px;
  z-index:2;
  padding:16px 18px;
  border-radius:24px;
  background:rgba(7,20,36,.72);
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(12px);
}
.student-library-photo-v277 figcaption strong{
  display:block;
  color:#fff;
  font-size:23px;
  font-weight:950;
  margin-bottom:6px;
}
.student-library-photo-v277 figcaption small{
  display:block;
  color:#cfe0f2;
  line-height:1.9;
  font-weight:700;
}
.visual-copy-v277{
  margin-top:18px;
  padding:20px;
  border-radius:28px;
  background:linear-gradient(135deg,rgba(255,255,255,.095),rgba(255,255,255,.045));
  border:1px solid rgba(255,255,255,.1);
}
.visual-copy-v277 h2{
  margin:0 0 9px;
  font-size:28px;
  color:#fff;
}
.visual-copy-v277 p{
  margin:0;
  color:#cfe0f2;
  line-height:2;
}
.student-login-visual-v277 .visual-glow{z-index:-2;}
.student-login-visual-v277 .visual-glow-one{width:250px;height:250px;background:#38bdf8;left:-80px;top:70px;}
.student-login-visual-v277 .visual-glow-two{width:300px;height:300px;background:#8b5cf6;right:-105px;bottom:-95px;}
@media (max-width:980px){
  .student-login-layout-v277{grid-template-columns:1fr;width:min(590px,calc(100vw - 28px));}
  .student-login-visual-v277{min-height:520px;order:-1;}
  .student-login-card-v277{min-height:auto;}
}
@media (max-width:680px){
  .student-login-shell-v277{padding:14px;place-items:start center;}
  .student-login-layout-v277{width:100%;gap:14px;}
  .student-login-visual-v277{display:none;}
  .student-login-card-v277{border-radius:26px;padding:22px;}
  .student-login-card-v277 h1{font-size:32px;}
}


/* Student login real-photo redesign v278 */
.student-login-shell-v278{
  width:100%;
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:44px 22px;
}
.student-login-layout-v278{
  width:min(1180px,calc(100vw - 44px));
  display:grid;
  grid-template-columns:minmax(420px,520px) minmax(470px,1fr);
  gap:22px;
  align-items:stretch;
}
.student-login-card-v278{
  min-height:650px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  box-shadow:0 34px 90px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.08);
}
.student-login-visual-v278{
  position:relative;
  min-height:650px;
  padding:24px;
  border-radius:36px;
  overflow:hidden;
  background:linear-gradient(145deg,rgba(16,31,50,.92),rgba(7,18,33,.96));
  border:1px solid rgba(148,163,184,.20);
  box-shadow:0 34px 90px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  isolation:isolate;
}
.student-login-visual-v278:before{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:31px;
  border:1px solid rgba(255,255,255,.08);
  pointer-events:none;
  z-index:-1;
}
.visual-photo-head-v278{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:#eaf7ff;
  font-weight:950;
  margin-bottom:16px;
}
.visual-photo-head-v278 span{
  padding:10px 15px;
  border-radius:999px;
  background:rgba(255,255,255,.085);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.visual-photo-head-v278 b{
  color:#071421;
  background:linear-gradient(135deg,#38bdf8,#f4c35b);
  border-radius:16px;
  padding:9px 14px;
  box-shadow:0 12px 28px rgba(56,189,248,.18);
}
.student-library-photo-v278{
  position:relative;
  margin:0;
  min-height:405px;
  border-radius:32px;
  overflow:hidden;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 24px 60px rgba(0,0,0,.30);
}
.student-library-photo-v278 img{
  display:block;
  width:100%;
  height:100%;
  min-height:405px;
  object-fit:cover;
  object-position:center center;
  transform:scale(1.03);
  filter:saturate(1.02) contrast(1.03) brightness(.92);
}
.student-library-photo-v278:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg,rgba(6,16,31,.40) 0%,rgba(6,16,31,.03) 46%,rgba(6,16,31,.34) 100%),
    radial-gradient(circle at 85% 12%,rgba(56,189,248,.24),transparent 34%);
  pointer-events:none;
}
.student-library-photo-v278:after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(180deg,rgba(5,14,27,0) 35%,rgba(5,14,27,.76) 100%);
  pointer-events:none;
}
.student-library-photo-v278 figcaption{
  position:absolute;
  right:18px;
  left:18px;
  bottom:18px;
  z-index:2;
  padding:16px 18px;
  border-radius:24px;
  background:rgba(7,20,36,.74);
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(12px);
}
.student-library-photo-v278 figcaption strong{
  display:block;
  color:#fff;
  font-size:23px;
  font-weight:950;
  margin-bottom:6px;
}
.student-library-photo-v278 figcaption small{
  display:block;
  color:#cfe0f2;
  line-height:1.9;
  font-weight:700;
}
.visual-copy-v278{
  margin-top:18px;
  padding:20px;
  border-radius:28px;
  background:linear-gradient(135deg,rgba(255,255,255,.095),rgba(255,255,255,.045));
  border:1px solid rgba(255,255,255,.1);
}
.visual-copy-v278 h2{
  margin:0 0 9px;
  font-size:28px;
  color:#fff;
}
.visual-copy-v278 p{
  margin:0;
  color:#cfe0f2;
  line-height:2;
}
.student-login-visual-v278 .visual-glow{z-index:-2;}
.student-login-visual-v278 .visual-glow-one{width:250px;height:250px;background:#38bdf8;left:-80px;top:70px;}
.student-login-visual-v278 .visual-glow-two{width:300px;height:300px;background:#8b5cf6;right:-105px;bottom:-95px;}
@media (max-width:980px){
  .student-login-layout-v278{grid-template-columns:1fr;width:min(590px,calc(100vw - 28px));}
  .student-login-visual-v278{min-height:560px;order:-1;}
  .student-login-card-v278{min-height:auto;}
}
@media (max-width:680px){
  .student-login-shell-v278{padding:14px;place-items:start center;}
  .student-login-layout-v278{width:100%;gap:14px;}
  .student-login-visual-v278{display:none;}
  .student-login-card-v278{border-radius:26px;padding:22px;}
  .student-login-card-v278 h1{font-size:32px;}
}



/* Student login real-photo premium redesign v279 */
.student-login-shell-v279{
  width:100%;
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:44px 22px;
}
.student-login-layout-v279{
  width:min(1200px,calc(100vw - 44px));
  display:grid;
  grid-template-columns:minmax(420px,510px) minmax(520px,1fr);
  gap:24px;
  align-items:stretch;
}
.student-login-card-v279{
  min-height:660px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  border-radius:34px;
  background:
    radial-gradient(circle at 20% 0%,rgba(56,189,248,.18),transparent 38%),
    linear-gradient(160deg,rgba(255,255,255,.14),rgba(255,255,255,.055));
  border:1px solid rgba(255,255,255,.13);
  box-shadow:0 34px 90px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.09);
}
.student-login-card-v279 .student-login-brand img{
  box-shadow:0 16px 32px rgba(244,195,91,.16);
}
.student-login-card-v279 h1{
  font-size:36px;
  letter-spacing:-.04em;
}
.student-login-card-v279 .student-login-lead{
  color:#c9d7ea;
}
.student-login-card-v279 .student-login-form input{
  min-height:58px;
  border-radius:18px;
  background:rgba(2,10,22,.78);
}
.student-login-card-v279 .student-login-form button{
  min-height:58px;
  border-radius:20px;
  background:linear-gradient(135deg,#f4c35b,#ffe09a 55%,#ffb84d);
}
.student-login-visual-v279{
  position:relative;
  min-height:660px;
  padding:24px;
  border-radius:38px;
  overflow:hidden;
  background:
    linear-gradient(145deg,rgba(7,20,36,.94),rgba(11,24,48,.96)),
    radial-gradient(circle at 20% 15%,rgba(56,189,248,.16),transparent 34%);
  border:1px solid rgba(148,163,184,.20);
  box-shadow:0 34px 90px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  isolation:isolate;
}
.student-login-visual-v279:before{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:32px;
  border:1px solid rgba(255,255,255,.08);
  pointer-events:none;
  z-index:-1;
}
.student-login-visual-v279:after{
  content:"";
  position:absolute;
  width:420px;
  height:420px;
  right:-160px;
  top:-170px;
  background:radial-gradient(circle,rgba(244,195,91,.22),transparent 62%);
  z-index:-2;
  pointer-events:none;
}
.visual-photo-head-v279{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:#eaf7ff;
  font-weight:950;
  margin-bottom:16px;
  position:relative;
  z-index:2;
}
.visual-photo-head-v279 span{
  padding:10px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.13);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.visual-photo-head-v279 b{
  color:#071421;
  background:linear-gradient(135deg,#38bdf8,#f4c35b);
  border-radius:18px;
  padding:10px 15px;
  box-shadow:0 14px 30px rgba(56,189,248,.18);
}
.student-library-photo-v279{
  position:relative;
  flex:1;
  min-height:475px;
  margin:0;
  border-radius:34px;
  overflow:hidden;
  background:#071424;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 28px 68px rgba(0,0,0,.34);
}
.student-library-photo-v279 img{
  display:block;
  width:100%;
  height:100%;
  min-height:475px;
  object-fit:cover;
  object-position:center center;
  transform:scale(1.035);
  filter:saturate(1.06) contrast(1.05) brightness(.9);
}
.student-library-photo-v279:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg,rgba(7,20,36,.84) 0%,rgba(7,20,36,.38) 37%,rgba(7,20,36,.10) 62%,rgba(7,20,36,.50) 100%),
    radial-gradient(circle at 17% 18%,rgba(56,189,248,.28),transparent 34%),
    radial-gradient(circle at 88% 7%,rgba(244,195,91,.20),transparent 30%);
  pointer-events:none;
}
.student-library-photo-v279:after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(180deg,rgba(5,14,27,.02) 28%,rgba(5,14,27,.86) 100%);
  pointer-events:none;
}
.student-library-photo-v279 figcaption{
  position:absolute;
  right:22px;
  left:22px;
  bottom:22px;
  z-index:3;
  padding:20px 22px;
  border-radius:28px;
  background:linear-gradient(135deg,rgba(7,20,36,.84),rgba(12,27,50,.68));
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(14px);
  box-shadow:0 20px 44px rgba(0,0,0,.25);
}
.student-library-photo-v279 .caption-kicker{
  display:inline-flex;
  align-items:center;
  margin-bottom:9px;
  padding:6px 12px;
  border-radius:999px;
  color:#071421;
  background:linear-gradient(135deg,#f4c35b,#ffe3a2);
  font-size:13px;
  font-weight:950;
}
.student-library-photo-v279 figcaption strong{
  display:block;
  color:#fff;
  font-size:27px;
  font-weight:950;
  margin-bottom:7px;
  letter-spacing:-.035em;
}
.student-library-photo-v279 figcaption small{
  display:block;
  color:#d8e6f7;
  line-height:1.9;
  font-weight:750;
}
.visual-feature-grid-v279{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-top:16px;
  position:relative;
  z-index:2;
}
.visual-feature-grid-v279 span{
  min-height:54px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  border-radius:20px;
  color:#eaf7ff;
  background:rgba(255,255,255,.075);
  border:1px solid rgba(255,255,255,.11);
  font-weight:900;
}
.student-login-visual-v279 .visual-glow{z-index:-3;filter:blur(20px);opacity:.55;position:absolute;border-radius:999px;}
.student-login-visual-v279 .visual-glow-one{width:280px;height:280px;background:#38bdf8;left:-100px;top:90px;}
.student-login-visual-v279 .visual-glow-two{width:330px;height:330px;background:#8b5cf6;right:-120px;bottom:-105px;}
@media (max-width:980px){
  .student-login-layout-v279{grid-template-columns:1fr;width:min(620px,calc(100vw - 28px));}
  .student-login-visual-v279{min-height:580px;order:-1;}
  .student-login-card-v279{min-height:auto;}
}
@media (max-width:680px){
  .student-login-shell-v279{padding:14px;place-items:start center;}
  .student-login-layout-v279{width:100%;gap:14px;}
  .student-login-visual-v279{display:none;}
  .student-login-card-v279{border-radius:26px;padding:22px;}
  .student-login-card-v279 h1{font-size:32px;}
}


/* Student login cinematic split redesign v280 - real WebP image + theme matched form */
.student-login-shell-v280{
  width:100%;
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:34px 22px;
  position:relative;
}
.student-login-shell-v280:before{
  content:"";
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at 13% 15%,rgba(56,189,248,.18),transparent 30%),
    radial-gradient(circle at 84% 15%,rgba(244,195,91,.12),transparent 30%),
    linear-gradient(135deg,#061120 0%,#07182d 44%,#08111f 100%);
  pointer-events:none;
  z-index:-3;
}
.student-login-layout-v280{
  width:min(1260px,calc(100vw - 44px));
  min-height:720px;
  display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(430px,560px);
  grid-template-areas:"visual login";
  gap:0;
  direction:ltr;
  align-items:stretch;
  overflow:hidden;
  border-radius:46px;
  background:linear-gradient(135deg,rgba(7,20,36,.72),rgba(8,17,31,.92));
  border:1px solid rgba(148,163,184,.20);
  box-shadow:0 42px 110px rgba(0,0,0,.48), inset 0 1px 0 rgba(255,255,255,.08);
  isolation:isolate;
  position:relative;
}
.student-login-layout-v280:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(90deg,rgba(7,20,36,.05) 0%,rgba(7,20,36,.28) 50%,rgba(7,20,36,.88) 100%);
  z-index:1;
}
.student-login-card-v280{
  grid-area:login;
  direction:rtl;
  width:auto;
  min-height:720px;
  margin:34px 34px 34px 0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  position:relative;
  z-index:3;
  border-radius:38px;
  padding:44px 42px;
  background:
    radial-gradient(circle at 18% 0%,rgba(56,189,248,.18),transparent 37%),
    linear-gradient(165deg,rgba(9,25,47,.86),rgba(5,15,30,.76));
  border:1px solid rgba(56,189,248,.28);
  box-shadow:0 32px 86px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.10);
  backdrop-filter:blur(20px);
}
.student-login-card-v280:before{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.055);
  pointer-events:none;
}
.student-login-card-v280 .student-login-brand{
  justify-content:center;
  text-align:center;
  margin-bottom:28px;
}
.student-login-card-v280 .student-login-brand img{
  width:78px;
  height:78px;
  border-radius:26px;
  background:linear-gradient(135deg,rgba(244,195,91,.18),rgba(255,255,255,.07));
  box-shadow:0 18px 42px rgba(244,195,91,.18);
}
.student-login-card-v280 .student-login-brand b{font-size:20px;color:#fff;}
.student-login-card-v280 .student-login-brand small{color:#cfe0f3;font-weight:800;}
.student-login-card-v280 h1{
  margin:8px 0 12px;
  text-align:center;
  font-size:clamp(34px,4vw,48px);
  line-height:1.25;
  letter-spacing:-.055em;
  color:#fff;
}
.student-login-card-v280 h1::first-letter{color:#38bdf8;}
.student-login-card-v280 .student-login-lead{
  max-width:440px;
  margin:0 auto 26px;
  text-align:center;
  color:#d2dfef;
  line-height:2.15;
  font-weight:750;
}
.student-login-card-v280 .otp-status,
.student-login-card-v280 .otp-timer{
  position:relative;
  z-index:2;
}
.student-login-card-v280 .student-login-form{
  position:relative;
  z-index:2;
  max-width:440px;
  width:100%;
  margin-inline:auto;
}
.student-login-card-v280 .student-login-form label{
  color:#d9e7f7;
  font-weight:900;
  margin-bottom:10px;
}
.student-login-card-v280 .student-login-form input{
  min-height:64px;
  border-radius:20px;
  padding:15px 18px;
  background:rgba(2,10,22,.72);
  border:1px solid rgba(148,163,184,.24);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  font-weight:850;
}
.student-login-card-v280 .student-login-form input:focus{
  border-color:rgba(56,189,248,.88);
  box-shadow:0 0 0 5px rgba(56,189,248,.15), inset 0 1px 0 rgba(255,255,255,.06);
}
.student-login-card-v280 .student-login-form button{
  min-height:64px;
  border-radius:21px;
  margin-top:18px;
  background:linear-gradient(135deg,#ffe08a 0%,#f4c35b 50%,#fb9718 100%);
  color:#061120;
  box-shadow:0 18px 46px rgba(244,195,91,.25), inset 0 1px 0 rgba(255,255,255,.34);
}
.student-login-card-v280 .student-login-form button:hover{transform:translateY(-1px);}
.student-login-card-v280 .otp-mini{
  color:#b9c9dd;
  text-align:center;
}
.student-login-card-v280 .student-login-actions{
  position:relative;
  z-index:2;
  margin-top:24px;
}
.student-login-card-v280 .student-login-actions a{
  min-width:150px;
  text-align:center;
  padding:12px 15px;
  border-radius:18px;
  color:#eaf7ff;
  background:rgba(255,255,255,.075);
  border:1px solid rgba(255,255,255,.12);
}
.student-login-card-v280 .student-login-actions a:hover{
  border-color:rgba(56,189,248,.40);
  background:rgba(56,189,248,.12);
}
.student-login-visual-v280{
  grid-area:visual;
  direction:rtl;
  position:relative;
  min-height:720px;
  padding:0;
  overflow:hidden;
  background:#071424;
  isolation:isolate;
}
.student-login-visual-v280 .visual-glow{display:none;}
.visual-photo-head-v280,
.visual-feature-grid-v280{display:none;}
.student-library-photo-v280{
  position:absolute;
  inset:0;
  margin:0;
  border:0;
  border-radius:0;
  overflow:hidden;
  background:#071424;
}
.student-library-photo-v280 img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center center;
  filter:saturate(1.06) contrast(1.08) brightness(.82);
  transform:scale(1.02);
}
.student-library-photo-v280:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg,rgba(7,20,36,.18) 0%,rgba(7,20,36,.04) 45%,rgba(7,20,36,.80) 100%),
    radial-gradient(circle at 14% 12%,rgba(56,189,248,.20),transparent 34%),
    radial-gradient(circle at 56% 78%,rgba(244,195,91,.14),transparent 30%);
  pointer-events:none;
}
.student-library-photo-v280:after{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  background:linear-gradient(180deg,rgba(5,14,27,.02) 35%,rgba(5,14,27,.74) 100%);
  pointer-events:none;
}
.student-library-photo-v280 figcaption{
  position:absolute;
  z-index:4;
  left:36px;
  right:36px;
  bottom:34px;
  max-width:520px;
  padding:24px 26px;
  border-radius:30px;
  background:linear-gradient(135deg,rgba(6,18,35,.76),rgba(9,28,54,.50));
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(16px);
  box-shadow:0 24px 54px rgba(0,0,0,.34);
}
.student-library-photo-v280 .caption-kicker{
  display:inline-flex;
  align-items:center;
  margin-bottom:10px;
  padding:7px 13px;
  border-radius:999px;
  color:#061120;
  background:linear-gradient(135deg,#ffe08a,#f4c35b);
  font-size:13px;
  font-weight:950;
}
.student-library-photo-v280 figcaption strong{
  display:block;
  color:#fff;
  font-size:clamp(25px,3vw,36px);
  font-weight:950;
  margin-bottom:8px;
  letter-spacing:-.045em;
}
.student-library-photo-v280 figcaption small{
  display:block;
  color:#dbeafe;
  line-height:1.9;
  font-weight:800;
}
.student-login-card-v280 .otp-change{
  background:rgba(255,255,255,.075)!important;
  border:1px solid rgba(255,255,255,.14)!important;
  color:#eaf7ff!important;
}
@media (max-width:1050px){
  .student-login-layout-v280{
    width:min(660px,calc(100vw - 28px));
    min-height:auto;
    grid-template-columns:1fr;
    grid-template-areas:"login";
    border-radius:34px;
  }
  .student-login-layout-v280:before{display:none;}
  .student-login-visual-v280{display:none;}
  .student-login-card-v280{
    margin:0;
    min-height:auto;
    border-radius:34px;
  }
}
@media (max-width:680px){
  .student-login-shell-v280{padding:14px;place-items:start center;}
  .student-login-layout-v280{width:100%;border-radius:28px;}
  .student-login-card-v280{border-radius:28px;padding:24px 20px;}
  .student-login-card-v280 .student-login-brand{align-items:center;}
  .student-login-card-v280 h1{font-size:34px;}
  .student-login-card-v280 .student-login-actions{display:grid;grid-template-columns:1fr;}
  .student-login-card-v280 .student-login-actions a{width:100%;}
}
