@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

.sms-public-wrap * { box-sizing:border-box; font-family:'Plus Jakarta Sans',sans-serif; }
.sms-public-wrap { max-width:1180px; margin:0 auto; padding:20px; color:#d9e4ff; }
.sms-portal-wrap { padding-top:24px; }
.sms-kicker { display:inline-block; padding:6px 12px; border-radius:999px; background:rgba(125,92,255,.14); border:1px solid rgba(125,92,255,.35); color:#c9bbff; font-size:.78rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.sms-hero-card,.sms-public-section,.sms-login-prompt,.sms-login-card,.sms-login-brand { background:linear-gradient(180deg,rgba(9,15,30,.96),rgba(17,24,39,.98)); border:1px solid rgba(107,124,255,.18); box-shadow:0 16px 40px rgba(2,6,23,.28); border-radius:24px; }
.sms-hero-card { padding:28px; display:grid; grid-template-columns:1.4fr 1fr; gap:18px; margin-bottom:22px; }
.sms-hero-card h2,.sms-login-brand h2 { margin:12px 0 10px; color:#fff; font-size:clamp(1.6rem,3vw,2.4rem); line-height:1.1; }
.sms-hero-card p,.sms-login-brand p,.sms-muted { color:#9fb0d7; }
.sms-cta-row,.sms-quick-links,.sms-form-row { display:flex; flex-wrap:wrap; gap:12px; align-items:center; margin-top:18px; }
.sms-mini-grid,.sms-doc-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; }
.sms-mini-card,.sms-doc-card,.sms-price-card { background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); border-radius:18px; padding:18px; }
.sms-mini-card strong,.sms-doc-card h4,.sms-price-card strong { display:block; color:#fff; margin-bottom:6px; }
.sms-mini-card span,.sms-doc-card p,.sms-price-card span { color:#9fb0d7; }
.sms-price-card strong { font-size:2rem; }
.sms-public-section { padding:24px; margin-bottom:20px; }
.sms-public-section h3 { margin:0 0 18px; color:#fff; font-size:1.2rem; }
.sms-stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:16px; margin-bottom:20px; }
.sms-stats-grid-xl { grid-template-columns:repeat(4,minmax(0,1fr)); }
.sms-stat-card { border-radius:18px; padding:20px 16px; text-align:center; color:#fff; box-shadow:inset 0 1px 0 rgba(255,255,255,.1); }
.sms-stat-number { font-size:2rem; font-weight:800; line-height:1; }
.sms-stat-label { font-size:.82rem; opacity:.92; margin-top:8px; }
.sms-green{background:linear-gradient(135deg,#0ea574,#0b7a58)} .sms-blue{background:linear-gradient(135deg,#3451ff,#2038d7)} .sms-orange{background:linear-gradient(135deg,#f59e0b,#d97706)} .sms-red{background:linear-gradient(135deg,#ef4444,#dc2626)} .sms-purple{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}
.sms-btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:11px 18px; border-radius:12px; border:1px solid transparent; font-size:.92rem; font-weight:700; cursor:pointer; text-decoration:none; transition:transform .18s ease,opacity .18s ease,box-shadow .18s ease; }
.sms-btn:hover { transform:translateY(-1px); opacity:.96; text-decoration:none; }
.sms-btn-primary { background:linear-gradient(135deg,#4f68ff,#6d4dff); color:#fff; box-shadow:0 12px 22px rgba(79,104,255,.25); }
.sms-btn-secondary { background:rgba(255,255,255,.04); color:#fff; border-color:rgba(255,255,255,.12); }
.sms-btn-lg { padding:14px 20px; }
.sms-full { width:100%; }
.sms-input,.sms-input-sm,textarea.sms-input,select.sms-input { width:100%; background:rgba(8,14,29,.9); color:#fff; border:1px solid rgba(255,255,255,.12); border-radius:14px; padding:13px 14px; outline:none; }
.sms-input-sm { padding:10px 12px; border-radius:10px; }
.sms-input::placeholder,textarea.sms-input::placeholder { color:#8ea2d1; }
.sms-grid-2 { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px; }
.sms-table-wrap { overflow:auto; border:1px solid rgba(255,255,255,.08); border-radius:16px; }
.sms-table { width:100%; border-collapse:collapse; min-width:680px; }
.sms-table th,.sms-table td { padding:14px 12px; border-bottom:1px solid rgba(255,255,255,.06); text-align:left; color:#dce7ff; }
.sms-table th { background:rgba(255,255,255,.04); color:#fff; font-size:.86rem; }
.sms-badge { display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; font-size:.75rem; font-weight:700; }
.sms-badge-pending { background:rgba(245,158,11,.14); color:#ffcc73; }
.sms-badge-graded { background:rgba(34,197,94,.14); color:#8df4b4; }
.sms-badge-submitted { background:rgba(79,104,255,.18); color:#bdd1ff; }
.sms-badge-present { background:rgba(34,197,94,.14); color:#8df4b4; }
.sms-badge-absent { background:rgba(239,68,68,.16); color:#ffb3b3; }
.sms-badge-late { background:rgba(245,158,11,.16); color:#ffd38d; }
.sms-badge-excused { background:rgba(139,92,246,.16); color:#d7c2ff; }
.sms-assignment-card { background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); border-radius:18px; padding:18px; margin-bottom:16px; }
.sms-assignment-header { display:flex; justify-content:space-between; gap:12px; align-items:center; margin-bottom:8px; }
.sms-assignment-meta { display:flex; flex-wrap:wrap; gap:10px 18px; color:#97abd9; font-size:.88rem; margin-bottom:10px; }
.sms-upload-form { display:grid; gap:10px; margin-top:12px; }
.sms-submitted-msg,.sms-grade-result,.sms-inline-success { background:rgba(34,197,94,.12); border:1px solid rgba(34,197,94,.25); color:#b8f7ce; padding:14px 16px; border-radius:14px; }
.sms-loading { padding:18px; text-align:center; color:#cdd8f8; }
.sms-notice { position:fixed; right:18px; bottom:18px; z-index:99999; min-width:280px; max-width:420px; padding:14px 16px; border-radius:16px; color:#fff; box-shadow:0 18px 38px rgba(2,6,23,.34); }
.sms-notice.success { background:linear-gradient(135deg,#0ea574,#0b7a58); }
.sms-notice.error { background:linear-gradient(135deg,#ef4444,#dc2626); }

.sms-login-page { max-width:1280px; }
.sms-login-shell { display:grid; grid-template-columns:1.1fr .9fr; gap:22px; }
.sms-login-brand,.sms-login-card { padding:28px; }
.sms-login-head h3 { margin:0 0 6px; color:#fff; font-size:1.6rem; }
.sms-login-head p,.sms-login-footnote { color:#9fb0d7; }

.sms-inline-notice { margin:14px 0 16px; padding:12px 14px; border-radius:14px; font-weight:600; }
.sms-inline-notice-success { background:rgba(34,197,94,.12); border:1px solid rgba(34,197,94,.28); color:#b8f7ce; }
.sms-inline-notice-error { background:rgba(239,68,68,.12); border:1px solid rgba(239,68,68,.28); color:#ffc0c0; }
.sms-role-pills { display:flex; flex-wrap:wrap; gap:10px; margin:16px 0; }
.sms-role-pills span,.sms-social-btn { padding:10px 14px; border-radius:999px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); color:#fff; font-weight:600; }
.sms-social-btn-link { display:flex; align-items:center; justify-content:center; text-decoration:none; opacity:1; }
.sms-social-btn-link:hover { text-decoration:none; transform:translateY(-1px); }
.sms-login-form { display:grid; gap:10px; }
.sms-login-form label { color:#cfdcff; font-size:.92rem; }
.sms-login-actions { display:flex; justify-content:space-between; gap:10px; align-items:center; font-size:.9rem; color:#aec0e6; margin:4px 0 8px; }
.sms-login-actions a { color:#b8c8ff; }
.sms-remember { display:flex; align-items:center; gap:8px; }
.sms-social-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:14px 0 10px; }
.sms-social-btn { text-align:center; opacity:.65; }

@media (max-width: 991px) {
  .sms-hero-card,.sms-login-shell,.sms-grid-2,.sms-stats-grid-xl { grid-template-columns:1fr; }
  .sms-mini-grid,.sms-doc-grid { grid-template-columns:1fr; }
}

@media (max-width: 767px) {
  .sms-public-wrap { padding:14px; }
  .sms-hero-card,.sms-public-section,.sms-login-card,.sms-login-brand { padding:20px; border-radius:20px; }
  .sms-cta-row,.sms-quick-links,.sms-form-row,.sms-login-actions,.sms-social-row { flex-direction:column; align-items:stretch; }
  .sms-social-row { display:grid; grid-template-columns:1fr; }
  .sms-btn,.sms-role-pills span { width:100%; }
  .sms-assignment-header { flex-direction:column; align-items:flex-start; }
  .sms-table { min-width:620px; }
}


.sms-auth-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0 16px;}
.sms-auth-tab{border:1px solid rgba(99,102,241,.25);background:rgba(15,23,42,.65);color:#e5e7eb;border-radius:14px;padding:10px 12px;font-weight:600;cursor:pointer;transition:.2s ease;}
.sms-auth-tab.is-active{background:linear-gradient(135deg,#2563eb,#7c3aed);border-color:transparent;color:#fff;box-shadow:0 14px 34px rgba(37,99,235,.22);}
.sms-auth-panel{display:none;}
.sms-auth-panel.is-active{display:block;}

.sms-otp-verify-form{border-top:1px solid rgba(255,255,255,.08);padding-top:14px;}
.sms-login-form .sms-input[readonly]{opacity:.9;background:rgba(255,255,255,.06);}
.sms-login-head p{max-width:560px;}

.sms-service-link{display:block;text-decoration:none;color:inherit;transition:transform .18s ease, box-shadow .18s ease;}
.sms-service-link:hover{transform:translateY(-2px);}
.sms-service-grid-wrap .sms-mini-grid{margin-top:12px;}


.sms-mini-grid-5{grid-template-columns:repeat(5,minmax(0,1fr));}
.sms-service-muted{opacity:.82; cursor:default;}
.sms-service-muted:hover{transform:none;}

@media (max-width: 1199px) {
  .sms-mini-grid-5{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media (max-width: 767px) {
  .sms-mini-grid-5{grid-template-columns:1fr;}
}

.sms-admission-paper-wrap{color:#e8efff;}
.sms-paper-form{display:grid;gap:18px;}
.sms-paper-header{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:16px;}
.sms-paper-header h3{margin:0 0 8px;font-size:1.45rem;}
.sms-paper-header p{margin:0;color:#9fb0d7;max-width:760px;}
.sms-paper-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:14px;min-width:min(100%,420px);}
.sms-form-section{border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:18px;background:rgba(255,255,255,.025);}
.sms-form-section-title{font-size:1rem;font-weight:800;color:#fff;margin-bottom:14px;letter-spacing:.01em;}
.sms-grid-3,.sms-grid-4{display:grid;gap:16px;}
.sms-grid-3{grid-template-columns:repeat(3,minmax(0,1fr));}
.sms-grid-4{grid-template-columns:repeat(4,minmax(0,1fr));}
.sms-paper-form label{display:block;color:#dce7ff;font-size:.9rem;font-weight:600;margin-bottom:8px;}
.sms-file-input{width:100%;background:rgba(8,14,29,.65);color:#dce7ff;border:1px dashed rgba(255,255,255,.18);border-radius:14px;padding:12px;}
@media (max-width: 991px){.sms-grid-3,.sms-grid-4,.sms-paper-header,.sms-paper-meta-grid{grid-template-columns:1fr;display:grid;min-width:0;}.sms-paper-header{display:grid;}}


/* ===== v3.2 universal premium frontend refresh ===== */
.sms-public-wrap{
  width:min(1180px,100%);
  padding:24px clamp(14px,2vw,26px) 34px;
}
.sms-login-page,
.sms-admission-wrap{
  position:relative;
}
.sms-login-shell{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(340px,.9fr);
  gap:22px;
  align-items:stretch;
}
.sms-login-brand,
.sms-login-card{
  min-height:100%;
  position:relative;
  overflow:hidden;
}
.sms-login-brand::before,
.sms-login-card::before,
.sms-hero-card::before,
.sms-public-section::before{
  content:"";
  position:absolute;
  inset:auto auto 0 0;
  width:220px;
  height:220px;
  background:radial-gradient(circle, rgba(109,77,255,.18), rgba(109,77,255,0) 68%);
  pointer-events:none;
}
.sms-login-brand,
.sms-login-card{
  padding:28px;
}
.sms-login-head h3{
  margin:0 0 8px;
  color:#fff;
  font-size:clamp(1.4rem,2vw,2rem);
}
.sms-login-head p{
  margin:0 0 16px;
}
.sms-login-form{
  display:grid;
  gap:14px;
  margin-top:16px;
}
.sms-login-form label{
  color:#e7efff;
  font-weight:700;
  font-size:.92rem;
  margin:0;
}
.sms-role-pills{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:0 0 18px;
}
.sms-role-pills span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  color:#fff;
  font-weight:700;
}
.sms-remember{
  display:flex;
  gap:10px;
  align-items:center;
  color:#dbe5ff;
  font-weight:600;
}
.sms-remember input{
  width:18px;
  height:18px;
}
.sms-login-footnote{
  color:#9fb0d7;
  margin:14px 0 0;
  line-height:1.7;
}
.sms-login-card .sms-btn-secondary{
  margin-top:14px;
  padding-top:14px;
  padding-bottom:14px;
}
.sms-mini-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.sms-mini-card{
  min-height:176px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:8px;
}
.sms-admission-hero{
  grid-template-columns:minmax(0,1.35fr) minmax(270px,.65fr);
  align-items:stretch;
}
.sms-price-card{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:10px;
}
.sms-paper-form{
  gap:22px;
}
.sms-paper-header{
  align-items:flex-start;
}
.sms-form-section{
  backdrop-filter:blur(4px);
}
.sms-form-section-title{
  display:flex;
  align-items:center;
  gap:10px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.sms-grid-3{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.sms-grid-4{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.sms-paper-form .sms-input,
.sms-paper-form select.sms-input{
  background:rgba(7,12,26,.92);
}
.sms-paper-form textarea.sms-input{
  min-height:110px;
}
.sms-inline-notice{
  border-radius:14px;
  padding:12px 14px;
  margin:0 0 16px;
  font-weight:700;
}
.sms-inline-notice-error{
  background:rgba(239,68,68,.12);
  border:1px solid rgba(239,68,68,.26);
  color:#fecaca;
}
.sms-inline-notice-success{
  background:rgba(16,185,129,.12);
  border:1px solid rgba(16,185,129,.28);
  color:#bbf7d0;
}
@media (max-width: 1100px){
  .sms-login-shell,
  .sms-admission-hero{
    grid-template-columns:1fr;
  }
}
@media (max-width: 900px){
  .sms-public-wrap{
    padding:18px 14px 28px;
  }
  .sms-login-brand,
  .sms-login-card,
  .sms-hero-card,
  .sms-public-section{
    padding:20px;
    border-radius:20px;
  }
  .sms-mini-grid{
    grid-template-columns:1fr 1fr;
  }
}
@media (max-width: 700px){
  .sms-mini-grid,
  .sms-grid-2,
  .sms-grid-3,
  .sms-grid-4,
  .sms-paper-meta-grid{
    grid-template-columns:1fr !important;
  }
  .sms-role-pills,
  .sms-cta-row,
  .sms-form-row{
    flex-direction:column;
    align-items:stretch;
  }
  .sms-role-pills span,
  .sms-btn{
    width:100%;
  }
  .sms-login-brand h2{
    font-size:2.2rem;
  }
  .sms-mini-card{
    min-height:auto;
  }
  .sms-table{
    min-width:620px;
  }
}

.sms-badge-half_day { background:rgba(59,130,246,.16); color:#9bd2ff; }
.sms-badge-open { background:rgba(148,163,184,.18); color:#e2e8f0; }
.sms-badge-on_leave { background:rgba(148,163,184,.16); color:#cbd5e1; }


.sms-attendance-compact{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:18px;margin-bottom:16px;}
.sms-attendance-line{display:flex;flex-wrap:wrap;gap:8px;align-items:center;color:#e8efff;margin-bottom:8px;}
.sms-attendance-sep{opacity:.7;}

.sms-stat-meta{margin-top:8px;font-size:12px;line-height:1.45;color:#64748b;}
.sms-stat-card .sms-stat-meta{display:block;}


/* Fee ledger readability */
#sms-fees,
#sms-fees h3,
#sms-fees .sms-stat-label,
#sms-fees .sms-stat-meta,
#sms-fees .sms-muted,
#sms-fees p,
#sms-fees .sms-table th,
#sms-fees .sms-table td,
#sms-fees .sms-table td a,
#sms-fees .sms-table td span {
  color:#ffffff !important;
}
#sms-fees .sms-table td a { text-decoration:none; }
#sms-fees .sms-table td a:hover { opacity:.92; }
#sms-fees .sms-table-wrap { border-color:rgba(255,255,255,.14); }
#sms-fees .sms-table th { background:rgba(255,255,255,.08); }
#sms-fees .sms-stat-meta { opacity:.95; }

/* ===== v3.8.6 mobile UI upgrade: login + dashboards only ===== */
.sms-mini-grid-6{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;}
.sms-portal-wrap .sms-hero-card{align-items:center;}
.sms-portal-wrap .sms-quick-links{justify-content:flex-end;align-content:flex-start;}
.sms-portal-wrap .sms-quick-links .sms-btn{min-width:148px;}
.sms-portal-wrap .sms-public-section{overflow:hidden;}
.sms-portal-wrap .sms-stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
.sms-portal-wrap .sms-stat-card{min-height:132px;display:flex;flex-direction:column;justify-content:center;align-items:center;}
.sms-portal-wrap .sms-doc-card,.sms-portal-wrap .sms-mini-card,.sms-portal-wrap .sms-assignment-card{height:100%;}
.sms-portal-wrap .sms-cta-row .sms-btn{min-height:46px;}
.sms-login-page{padding-top:8px;}
.sms-login-shell{gap:24px;}
.sms-login-brand,.sms-login-card{backdrop-filter:blur(10px);}
.sms-login-brand{display:flex;flex-direction:column;justify-content:center;}
.sms-login-card{max-width:100%;}
.sms-login-head{margin-bottom:6px;}
.sms-login-form .sms-input{min-height:52px;font-size:16px;}
.sms-login-form .sms-btn{min-height:52px;font-size:1rem;}
.sms-login-actions{padding:4px 0 2px;}
.sms-table-wrap{-webkit-overflow-scrolling:touch;}

@media (max-width: 1100px){
  .sms-mini-grid-6{grid-template-columns:repeat(2,minmax(0,1fr));}
  .sms-portal-wrap .sms-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media (max-width: 767px){
  .sms-public-wrap.sms-portal-wrap,
  .sms-public-wrap.sms-login-page{padding:12px 12px 24px;}
  .sms-portal-wrap{padding-top:12px;}
  .sms-login-shell,
  .sms-portal-wrap .sms-hero-card,
  .sms-portal-wrap .sms-doc-grid,
  .sms-portal-wrap .sms-stats-grid,
  .sms-mini-grid-6{grid-template-columns:1fr !important;}
  .sms-login-brand,
  .sms-login-card,
  .sms-portal-wrap .sms-hero-card,
  .sms-portal-wrap .sms-public-section,
  .sms-portal-wrap .sms-assignment-card,
  .sms-portal-wrap .sms-mini-card,
  .sms-portal-wrap .sms-doc-card,
  .sms-portal-wrap .sms-stat-card{border-radius:18px;}
  .sms-login-brand,
  .sms-login-card,
  .sms-portal-wrap .sms-hero-card,
  .sms-portal-wrap .sms-public-section{padding:16px;}
  .sms-login-brand h2,
  .sms-hero-card h2{font-size:clamp(1.55rem,7vw,2.1rem);line-height:1.15;}
  .sms-login-head h3,
  .sms-portal-wrap .sms-public-section h3{font-size:1.2rem;}
  .sms-role-pills span,
  .sms-btn,
  .sms-portal-wrap .sms-quick-links .sms-btn,
  .sms-portal-wrap .sms-cta-row .sms-btn{width:100%;min-width:0;}
  .sms-login-actions,
  .sms-cta-row,
  .sms-quick-links,
  .sms-form-row,
  .sms-assignment-header,
  .sms-assignment-meta{display:flex;flex-direction:column;align-items:stretch;gap:10px;}
  .sms-remember{justify-content:flex-start;}
  .sms-login-form{gap:12px;}
  .sms-login-form label{font-size:.9rem;}
  .sms-login-form .sms-input{padding:14px 15px;}
  .sms-mini-card,
  .sms-doc-card,
  .sms-assignment-card{padding:16px;}
  .sms-stat-card{min-height:auto;padding:18px 14px;align-items:flex-start;text-align:left;}
  .sms-stat-number{font-size:1.7rem;}
  .sms-stat-label{margin-top:6px;}
  .sms-stat-meta{font-size:11.5px;line-height:1.45;}
  .sms-table-wrap{margin:0 -4px;overflow-x:auto;}
  .sms-table{min-width:640px;}
}

@media (max-width: 480px){
  .sms-public-wrap.sms-portal-wrap,
  .sms-public-wrap.sms-login-page{padding:10px 10px 22px;}
  .sms-login-brand,
  .sms-login-card,
  .sms-portal-wrap .sms-hero-card,
  .sms-portal-wrap .sms-public-section{padding:14px;}
  .sms-kicker{font-size:.7rem;padding:5px 10px;}
  .sms-login-brand h2,
  .sms-hero-card h2{font-size:1.42rem;}
  .sms-login-head h3{font-size:1.12rem;}
  .sms-mini-card strong,
  .sms-doc-card h4{font-size:1rem;}
  .sms-btn{padding:12px 14px;font-size:.93rem;}
  .sms-login-form .sms-input,
  .sms-input,
  textarea.sms-input,
  select.sms-input{border-radius:12px;}
}


/* ===== v3.8.7 final login layout refinement ===== */
.sms-public-wrap.sms-login-page{
  width:100%;
  max-width:none;
  padding:18px 24px 32px;
}
.sms-login-page .sms-login-shell{
  width:min(1400px,100%);
  margin:0 auto;
  grid-template-columns:minmax(0,1.2fr) minmax(380px,.8fr);
  gap:28px;
  align-items:stretch;
}
.sms-login-page .sms-login-brand,
.sms-login-page .sms-login-card{
  min-height:540px;
}
.sms-login-page .sms-login-brand{
  padding:34px;
}
.sms-login-page .sms-login-card{
  padding:34px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.sms-login-page .sms-login-head{
  margin-bottom:10px;
}
.sms-login-page .sms-login-head p{
  max-width:420px;
}
.sms-login-page .sms-login-form{
  gap:16px;
}
.sms-login-page .sms-login-form .sms-input{
  min-height:56px;
  padding:15px 16px;
}
.sms-login-page .sms-btn.sms-full{
  min-height:54px;
}
@media (max-width: 900px){
  .sms-public-wrap.sms-login-page{
    padding:12px 12px 24px;
  }
  .sms-login-page .sms-login-shell{
    width:100%;
    grid-template-columns:1fr;
    gap:16px;
  }
  .sms-login-page .sms-login-brand,
  .sms-login-page .sms-login-card{
    min-height:auto;
    padding:18px;
  }
}
@media (max-width: 480px){
  .sms-public-wrap.sms-login-page{
    padding:10px 10px 20px;
  }
  .sms-login-page .sms-login-brand,
  .sms-login-page .sms-login-card{
    padding:14px;
    border-radius:16px;
  }
  .sms-login-page .sms-login-form .sms-input,
  .sms-login-page .sms-btn.sms-full{
    min-height:50px;
  }
}


/* ===== v3.8.8 mobile login card only refinement ===== */
.sms-login-page{
  min-height:calc(100vh - 32px);
  display:flex;
  align-items:center;
}
.sms-login-page .sms-login-shell{
  width:min(1500px,100%);
  grid-template-columns:minmax(0,1.35fr) minmax(420px,.65fr);
  gap:32px;
}
.sms-login-page .sms-login-brand{
  justify-content:center;
}
.sms-login-page .sms-login-card{
  max-width:520px;
  width:100%;
  justify-self:end;
}
@media (max-width: 767px){
  .sms-public-wrap.sms-login-page{
    min-height:100vh;
    padding:12px;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .sms-login-page .sms-login-shell{
    display:block;
    width:100%;
    max-width:420px;
  }
  .sms-login-page .sms-login-brand,
  .sms-login-page .sms-login-card + .sms-btn,
  .sms-login-page .sms-login-card > .sms-btn.sms-btn-secondary,
  .sms-login-page #sms-notice{
    display:none !important;
  }
  .sms-login-page .sms-login-card{
    max-width:100%;
    min-height:auto;
    margin:0;
    padding:18px 16px;
    border-radius:18px;
  }
  .sms-login-page .sms-login-head{
    margin-bottom:8px;
    text-align:center;
  }
  .sms-login-page .sms-login-head p{
    margin:0 auto;
  }
  .sms-login-page .sms-login-form{
    gap:12px;
  }
}
@media (max-width: 480px){
  .sms-public-wrap.sms-login-page{
    padding:10px;
  }
  .sms-login-page .sms-login-shell{
    max-width:100%;
  }
  .sms-login-page .sms-login-card{
    padding:16px 14px;
    border-radius:16px;
  }
  .sms-login-page .sms-login-head h3{
    font-size:1.05rem;
  }
  .sms-login-page .sms-login-head p{
    font-size:.88rem;
  }
  .sms-login-page .sms-login-form .sms-input,
  .sms-login-page .sms-btn.sms-full{
    min-height:48px;
  }
}


/* ===== v10.3.4 login page wide desktop + mobile login-only ===== */
.sms-public-wrap.sms-login-page{
  width:min(1600px,96vw);
  max-width:min(1600px,96vw);
  padding:18px 18px 28px;
}
.sms-login-page{
  min-height:auto;
  display:block;
}
.sms-login-page .sms-login-shell{
  width:100%;
  max-width:none;
  grid-template-columns:minmax(0,1.35fr) minmax(460px,.95fr);
  gap:18px;
  align-items:stretch;
}
.sms-login-page .sms-login-brand,
.sms-login-page .sms-login-card{
  min-height:auto;
  padding:24px;
}
.sms-login-page .sms-login-brand{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.sms-login-page .sms-login-brand h2{
  font-size:clamp(2.4rem,3.4vw,4rem);
  line-height:1.02;
  max-width:12ch;
  margin:12px 0 12px;
}
.sms-login-page .sms-login-brand p{
  max-width:720px;
  font-size:1.06rem;
  line-height:1.7;
  margin-bottom:16px;
}
.sms-login-page .sms-mini-grid{
  grid-template-columns:repeat(2,minmax(220px,1fr));
  gap:12px;
  margin-top:14px;
}
.sms-login-page .sms-mini-card{
  min-height:132px;
  padding:18px;
  gap:8px;
}
.sms-login-page .sms-mini-card strong{
  font-size:1.02rem;
  line-height:1.35;
}
.sms-login-page .sms-mini-card span{
  font-size:.98rem;
  line-height:1.55;
}
.sms-login-page .sms-login-card{
  max-width:none;
  width:100%;
  justify-self:stretch;
  justify-content:center;
}
.sms-login-page .sms-login-head h3{
  font-size:clamp(2rem,2.8vw,3rem);
}
.sms-login-page .sms-login-head p{
  max-width:none;
  font-size:1.04rem;
}
.sms-login-page .sms-login-form .sms-input{
  min-height:58px;
}
.sms-login-page .sms-btn.sms-full{
  min-height:56px;
}
@media (max-width: 1199px){
  .sms-public-wrap.sms-login-page{
    width:min(1400px,98vw);
    max-width:min(1400px,98vw);
    padding:16px 14px 24px;
  }
  .sms-login-page .sms-login-shell{
    grid-template-columns:minmax(0,1.15fr) minmax(420px,.95fr);
    gap:16px;
  }
  .sms-login-page .sms-login-brand h2{
    font-size:clamp(2rem,3vw,3rem);
  }
  .sms-login-page .sms-mini-card{
    min-height:120px;
    padding:16px;
  }
}
@media (max-width: 900px){
  .sms-public-wrap.sms-login-page{
    min-height:100vh;
    width:100%;
    max-width:100%;
    padding:12px;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .sms-login-page .sms-login-shell{
    display:block;
    width:100%;
    max-width:460px;
  }
  .sms-login-page .sms-login-brand{
    display:none !important;
  }
  .sms-login-page .sms-login-card{
    max-width:100%;
    min-height:auto;
    padding:20px 18px;
    border-radius:20px;
  }
  .sms-login-page .sms-login-head{
    text-align:center;
  }
  .sms-login-page .sms-login-head h3{
    font-size:1.9rem;
  }
  .sms-login-page .sms-login-head p{
    font-size:.95rem;
  }
  .sms-login-page .sms-login-card > .sms-btn.sms-btn-secondary,
  .sms-login-page #sms-notice{
    display:none !important;
  }
}
@media (max-width: 480px){
  .sms-login-page .sms-login-card{
    padding:16px 14px;
    border-radius:16px;
  }
  .sms-login-page .sms-login-head h3{
    font-size:1.35rem;
  }
  .sms-login-page .sms-login-head p{
    font-size:.88rem;
  }
  .sms-login-page .sms-login-form .sms-input,
  .sms-login-page .sms-btn.sms-full{
    min-height:50px;
  }
}

/* ===== v10.3.6 login page hard center + hide theme sidebar ===== */
body:has(.sms-login-page) .sms-public-wrap.sms-login-page{
  width:100% !important;
  max-width:none !important;
  margin-left:auto !important;
  margin-right:auto !important;
}
body:has(.sms-login-page) .sms-login-page .sms-login-shell{
  width:min(1500px, calc(100vw - 48px)) !important;
  margin-left:auto !important;
  margin-right:auto !important;
  justify-content:center !important;
}
body:has(.sms-login-page) #secondary,
body:has(.sms-login-page) .widget-area,
body:has(.sms-login-page) aside,
body:has(.sms-login-page) .sidebar,
body:has(.sms-login-page) .course-sidebar,
body:has(.sms-login-page) .learn-press-sidebar,
body:has(.sms-login-page) .popular-courses,
body:has(.sms-login-page) .lp-list-courses,
body:has(.sms-login-page) .widget.widget_lp_course,
body:has(.sms-login-page) .widget.widget_learn_press_courses{
  display:none !important;
}
body:has(.sms-login-page) .container,
body:has(.sms-login-page) .container-fluid,
body:has(.sms-login-page) .wrap,
body:has(.sms-login-page) .content-area,
body:has(.sms-login-page) .site-content,
body:has(.sms-login-page) .site-main,
body:has(.sms-login-page) .page-content,
body:has(.sms-login-page) .entry-content,
body:has(.sms-login-page) .post-content,
body:has(.sms-login-page) .fl-row-content-wrap,
body:has(.sms-login-page) .fl-row-content,
body:has(.sms-login-page) .elementor-section,
body:has(.sms-login-page) .elementor-container,
body:has(.sms-login-page) .elementor-widget-wrap,
body:has(.sms-login-page) .vc_row,
body:has(.sms-login-page) .vc_column_container,
body:has(.sms-login-page) .vc_column-inner{
  max-width:100% !important;
  width:100% !important;
}
body:has(.sms-login-page) .content-area,
body:has(.sms-login-page) .site-main,
body:has(.sms-login-page) .page-content,
body:has(.sms-login-page) .entry-content,
body:has(.sms-login-page) .post-content{
  margin-left:auto !important;
  margin-right:auto !important;
  float:none !important;
}
@media (max-width: 767px){
  body:has(.sms-login-page) .sms-login-page .sms-login-shell{
    width:min(100%, 420px) !important;
  }
}

/* ===== v14.0.8 Parent/Student Portal Upgrade ===== */
.sms-portal-v1408{max-width:1180px;margin:0 auto;}
.sms-portal-hero{position:relative;overflow:hidden;display:flex;justify-content:space-between;gap:18px;align-items:center;padding:28px;border-radius:26px;background:linear-gradient(135deg,rgba(14,32,75,.96),rgba(62,42,150,.9));border:1px solid rgba(255,255,255,.12);box-shadow:0 24px 60px rgba(2,6,23,.28);margin-bottom:18px;}
.sms-portal-hero:before{content:"";position:absolute;right:-80px;top:-90px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.2),rgba(255,255,255,0) 68%);pointer-events:none;}
.sms-portal-hero h2{margin:6px 0 8px;color:#fff;font-size:clamp(1.55rem,3vw,2.35rem);line-height:1.08;}
.sms-portal-hero p{margin:0;color:#d7e3ff;max-width:680px;}
.sms-portal-actions{display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:1;}
.sms-portal-child-pill{position:relative;z-index:1;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:#fff;border-radius:999px;padding:12px 16px;font-weight:800;white-space:nowrap;}
.sms-portal-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:18px 0;}
.sms-portal-kpi{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:18px;box-shadow:0 18px 40px rgba(2,6,23,.18);}
.sms-portal-kpi span{display:block;color:#9fb4e6;font-size:.82rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;}
.sms-portal-kpi strong{display:block;color:#fff;font-size:1.65rem;margin:8px 0 2px;line-height:1;}
.sms-portal-kpi small{color:#b9c8ef;}
.sms-portal-grid-main{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:16px;align-items:start;}
.sms-portal-panel{position:relative;overflow:hidden;}
.sms-section-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:16px;}
.sms-section-head h3{margin:0;color:#fff;}
.sms-section-head span{color:#98addc;font-weight:700;font-size:.86rem;}
.sms-attendance-mini-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px;}
.sms-attendance-mini-stats div{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:12px;}
.sms-attendance-mini-stats strong{display:block;color:#fff;font-size:1.2rem;}
.sms-attendance-mini-stats span{display:block;color:#9fb4e6;font-size:.78rem;margin-top:3px;}
.sms-portal-calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;}
.sms-cal-day{min-height:54px;border-radius:14px;padding:8px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;justify-content:space-between;}
.sms-cal-day b{color:#fff;font-size:.88rem;}
.sms-cal-day span{font-size:.68rem;color:#aabce8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sms-cal-present{background:rgba(34,197,94,.16);border-color:rgba(34,197,94,.28);}
.sms-cal-absent{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.28);}
.sms-cal-late,.sms-cal-half_day{background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.3);}
.sms-cal-on_leave,.sms-cal-excused{background:rgba(139,92,246,.14);border-color:rgba(139,92,246,.3);}
.sms-notice-list{display:grid;gap:10px;}
.sms-notice-item{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:13px;}
.sms-notice-item strong{display:block;color:#fff;line-height:1.25;}
.sms-notice-item small{display:block;color:#9fb4e6;margin:5px 0;}
.sms-notice-item p{margin:0;color:#d6e1ff;font-size:.9rem;}
.sms-download-strip .sms-mini-card{min-height:104px;}
@media (max-width: 991px){.sms-portal-hero,.sms-portal-grid-main{grid-template-columns:1fr;display:grid;}.sms-portal-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.sms-attendance-mini-stats{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width: 767px){.sms-portal-hero{padding:22px;border-radius:22px;}.sms-portal-actions{width:100%;}.sms-portal-kpi-grid{grid-template-columns:1fr;}.sms-portal-calendar{grid-template-columns:repeat(3,minmax(0,1fr));}.sms-section-head{align-items:flex-start;flex-direction:column;}.sms-attendance-mini-stats{grid-template-columns:1fr 1fr;}}

/* ===== v14.2.5 Admission payment button visibility fix ===== */
.sms-admission-wrap .sms-cta-row{
  position:relative;
  z-index:3;
  display:flex !important;
  align-items:center !important;
  gap:14px !important;
  overflow:visible !important;
}
.sms-admission-wrap .sms-cta-row .sms-btn-secondary{
  display:inline-flex !important;
  visibility:visible !important;
  opacity:1 !important;
  color:#ffffff !important;
  background:linear-gradient(135deg,var(--sms-ui-primary,#14532d),var(--sms-ui-button,#2563eb)) !important;
  border:1px solid rgba(255,255,255,.18) !important;
  box-shadow:0 12px 24px rgba(2,6,23,.22) !important;
  min-height:52px !important;
  padding:14px 20px !important;
  white-space:nowrap !important;
  text-decoration:none !important;
}
.sms-admission-wrap .sms-cta-row .sms-btn-secondary:hover,
.sms-admission-wrap .sms-cta-row .sms-btn-secondary:focus{
  color:#ffffff !important;
  opacity:1 !important;
  filter:brightness(1.06);
}
@media (max-width:700px){
  .sms-admission-wrap .sms-cta-row .sms-btn-secondary{width:100% !important;white-space:normal !important;}
}


/* ===== v14.2.6 Application form bottom-left green overlay fix ===== */
.sms-admission-wrap .sms-hero-card::before,
.sms-admission-wrap .sms-public-section::before,
.sms-admission-wrap .sms-cta-row::before,
.sms-admission-wrap .sms-cta-row::after{
  display:none !important;
  content:none !important;
}
.sms-admission-wrap .sms-hero-card,
.sms-admission-wrap .sms-public-section{
  overflow:hidden !important;
}
.sms-admission-wrap .sms-cta-row{
  background:transparent !important;
}
.sms-admission-wrap #sms-admission-form.sms-public-section{
  background:var(--sms-registration-form-bg, rgba(255,255,255,0.03)) !important;
}

/* ===== v14.2.7 Universal client theme safety ===== */
.sms-admission-wrap,
.sms-login-page,
.sms-portal-wrap{
  color-scheme:auto;
}
.sms-admission-wrap .sms-hero-card::before,
.sms-admission-wrap .sms-public-section::before,
.sms-admission-wrap .sms-cta-row::before,
.sms-admission-wrap .sms-cta-row::after{
  display:none !important;
  content:none !important;
}
.sms-admission-wrap #sms-admission-form.sms-public-section{
  background:var(--sms-registration-form-bg, rgba(255,255,255,0.03)) !important;
}
.sms-admission-wrap #sms-admission-form .sms-form-section,
.sms-admission-wrap #sms-admission-form .sms-paper-header{
  background:var(--sms-form-section-bg, rgba(255,255,255,0.035)) !important;
}
.sms-admission-wrap #sms-admission-form input,
.sms-admission-wrap #sms-admission-form select,
.sms-admission-wrap #sms-admission-form textarea{
  background:var(--sms-form-input-bg, rgba(255,255,255,0.96)) !important;
  color:var(--sms-form-input-text, #0f172a) !important;
}
.sms-admission-wrap #sms-admission-form label,
.sms-admission-wrap #sms-admission-form .sms-form-section-title,
.sms-admission-wrap #sms-admission-form h3{
  color:#ffffff;
}


/* ===== v2.4.2 Login page UI fix: card overflow + cropped text ===== */
.sms-login-page,
.sms-login-page .sms-login-shell,
.sms-login-page .sms-login-brand,
.sms-login-page .sms-login-card{
  overflow:visible !important;
}
.sms-login-page .sms-login-brand,
.sms-login-page .sms-login-card{
  isolation:isolate;
}
.sms-login-page .sms-login-brand::before,
.sms-login-page .sms-login-card::before{
  display:none !important;
  content:none !important;
}
.sms-login-page .sms-login-brand{
  justify-content:flex-start !important;
}
.sms-login-page .sms-mini-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:14px !important;
  align-items:stretch !important;
  grid-auto-rows:minmax(132px,auto) !important;
  margin-top:28px !important;
}
.sms-login-page .sms-mini-card{
  position:relative !important;
  min-height:132px !important;
  height:auto !important;
  overflow:visible !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  gap:8px !important;
  padding:20px !important;
  background:rgba(255,255,255,.045) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  border-radius:18px !important;
}
.sms-login-page .sms-mini-card strong,
.sms-login-page .sms-mini-card span{
  display:block !important;
  position:relative !important;
  z-index:2 !important;
  max-width:100% !important;
  white-space:normal !important;
  overflow:visible !important;
  text-overflow:clip !important;
  word-break:normal !important;
}
.sms-login-page .sms-mini-card strong{
  color:#ffffff !important;
  line-height:1.25 !important;
  margin:0 !important;
}
.sms-login-page .sms-mini-card span{
  color:#b8c7ea !important;
  line-height:1.55 !important;
}
.sms-login-page .sms-login-brand h2{
  max-width:760px !important;
}
@media (max-width:900px){
  .sms-login-page .sms-mini-grid{
    grid-template-columns:1fr !important;
    grid-auto-rows:auto !important;
  }
  .sms-login-page .sms-mini-card{
    min-height:auto !important;
    justify-content:flex-start !important;
  }
}


/* ===== v2.4.3 Dashboard landing UI fix: visible buttons + clean portal card layout ===== */
.sms-portal-wrap,
.sms-portal-wrap .sms-hero-card,
.sms-portal-wrap .sms-landing-card,
.sms-portal-wrap .sms-cta-row,
.sms-portal-wrap .sms-mini-grid,
.sms-portal-wrap .sms-mini-card{
  overflow:visible !important;
}
.sms-portal-wrap .sms-hero-card::before,
.sms-portal-wrap .sms-public-section::before,
.sms-portal-wrap .sms-cta-row::before,
.sms-portal-wrap .sms-cta-row::after{
  display:none !important;
  content:none !important;
}
.sms-portal-wrap .sms-landing-card{
  position:relative !important;
  display:grid !important;
  grid-template-columns:minmax(0,1.35fr) minmax(360px,.8fr) !important;
  gap:28px !important;
  align-items:center !important;
  min-height:auto !important;
  height:auto !important;
  padding:28px !important;
  isolation:isolate !important;
}
.sms-portal-wrap .sms-landing-card > *{
  position:relative !important;
  z-index:2 !important;
  min-width:0 !important;
}
.sms-portal-wrap .sms-landing-card h2,
.sms-portal-wrap .sms-landing-card p,
.sms-portal-wrap .sms-kicker{
  position:relative !important;
  z-index:2 !important;
  overflow:visible !important;
  white-space:normal !important;
}
.sms-portal-wrap .sms-landing-card .sms-cta-row{
  position:relative !important;
  z-index:5 !important;
  display:flex !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  gap:14px !important;
  margin-top:28px !important;
  background:transparent !important;
  clear:both !important;
}
.sms-portal-wrap .sms-landing-card .sms-cta-row .sms-btn{
  position:relative !important;
  z-index:6 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:56px !important;
  height:auto !important;
  min-width:176px !important;
  padding:14px 24px !important;
  opacity:1 !important;
  visibility:visible !important;
  transform:none !important;
  clip-path:none !important;
}
.sms-portal-wrap .sms-mini-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:14px !important;
  align-items:stretch !important;
  grid-auto-rows:minmax(174px,auto) !important;
  margin:0 !important;
}
.sms-portal-wrap .sms-mini-card{
  position:relative !important;
  z-index:2 !important;
  min-height:174px !important;
  height:auto !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  gap:10px !important;
  padding:20px !important;
  background:rgba(255,255,255,.045) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  border-radius:18px !important;
}
.sms-portal-wrap .sms-mini-card strong,
.sms-portal-wrap .sms-mini-card span{
  display:block !important;
  position:relative !important;
  z-index:3 !important;
  max-width:100% !important;
  white-space:normal !important;
  overflow:visible !important;
  text-overflow:clip !important;
  word-break:normal !important;
}
.sms-portal-wrap .sms-mini-card strong{
  color:#ffffff !important;
  line-height:1.25 !important;
  margin:0 !important;
}
.sms-portal-wrap .sms-mini-card span{
  color:#b8c7ea !important;
  line-height:1.55 !important;
}
@media (max-width: 980px){
  .sms-portal-wrap .sms-landing-card{
    grid-template-columns:1fr !important;
    align-items:start !important;
  }
  .sms-portal-wrap .sms-mini-grid{
    grid-auto-rows:auto !important;
  }
}
@media (max-width: 700px){
  .sms-portal-wrap .sms-landing-card{
    padding:20px !important;
    gap:20px !important;
  }
  .sms-portal-wrap .sms-mini-grid{
    grid-template-columns:1fr !important;
  }
  .sms-portal-wrap .sms-mini-card{
    min-height:auto !important;
    justify-content:flex-start !important;
  }
  .sms-portal-wrap .sms-landing-card .sms-cta-row .sms-btn{
    width:100% !important;
    min-width:0 !important;
  }
}

/* v2.9.4 Teacher Frontend Attendance Panel */
.sms-teacher-attendance-panel .sms-section-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px;}
.sms-premium-filter{display:grid;grid-template-columns:1fr 1fr auto;gap:14px;align-items:end;margin:18px 0;padding:16px;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:rgba(255,255,255,.04);}
.sms-premium-filter label{display:flex;flex-direction:column;gap:7px;font-weight:800;color:#eaf1ff;font-size:13px;letter-spacing:.02em;}
.sms-premium-filter select,.sms-premium-filter input,.sms-time-input,.sms-remarks-input{width:100%;border:1px solid rgba(255,255,255,.16);border-radius:14px;background:rgba(255,255,255,.95);color:#0f172a;padding:11px 12px;outline:none;}
.sms-attendance-toolbar{display:flex;justify-content:space-between;gap:14px;align-items:center;margin:16px 0;padding:16px;border-radius:18px;background:linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.12);}
.sms-attendance-toolbar strong{display:block;color:#fff;font-size:18px;}
.sms-attendance-toolbar span{display:block;color:var(--sms-ui-muted);font-size:13px;margin-top:3px;}
.sms-attendance-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:flex-end;}
.sms-frontend-attendance-list{display:flex;flex-direction:column;gap:12px;margin-top:14px;}
.sms-attendance-student-row{display:grid;grid-template-columns:minmax(180px,1.1fr) minmax(280px,1.4fr) 120px minmax(160px,.8fr);gap:12px;align-items:center;padding:14px;border-radius:18px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.11);box-shadow:0 12px 24px rgba(0,0,0,.12);}
.sms-student-main strong{display:block;color:#fff;font-size:15px;}
.sms-student-main span{display:block;color:var(--sms-ui-muted);font-size:12px;margin-top:3px;word-break:break-word;}
.sms-status-pills{display:flex;gap:8px;flex-wrap:wrap;}
.sms-status-pill{position:relative;display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.16);color:#dbeafe;background:rgba(255,255,255,.05);font-size:12px;font-weight:800;cursor:pointer;transition:.2s ease;}
.sms-status-pill input{position:absolute;opacity:0;pointer-events:none;}
.sms-status-pill.is-active{background:linear-gradient(135deg,var(--sms-ui-button),var(--sms-ui-secondary));color:#fff;border-color:transparent;box-shadow:0 10px 20px color-mix(in srgb, var(--sms-ui-button) 24%, transparent);}
.sms-attendance-bottom-actions{margin-top:16px;}
.sms-inline-notice-error{border-color:rgba(239,68,68,.35)!important;background:rgba(239,68,68,.10)!important;color:#fecaca!important;}
@media(max-width:900px){.sms-premium-filter{grid-template-columns:1fr}.sms-attendance-toolbar{align-items:flex-start;flex-direction:column}.sms-attendance-actions{justify-content:flex-start}.sms-attendance-student-row{grid-template-columns:1fr}.sms-time-input,.sms-remarks-input{max-width:100%;}.sms-status-pills{gap:7px}}

/* v2.9.6 Teacher Frontend Attendance: close, preview, routine/homework mobile upgrade */
.sms-attendance-close-card{
  margin-top:16px;
  display:grid;
  grid-template-columns:1fr 180px auto;
  gap:14px;
  align-items:end;
  padding:16px;
  border-radius:18px;
  background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(59,130,246,.08));
  border:1px solid rgba(45,212,191,.18);
}
.sms-attendance-close-card strong{display:block;color:#fff;font-size:16px;}
.sms-attendance-close-card span{display:block;color:var(--sms-ui-muted);font-size:13px;margin-top:4px;line-height:1.5;}
.sms-attendance-close-card label{display:flex;flex-direction:column;gap:7px;color:#eaf1ff;font-weight:800;font-size:13px;}
.sms-teacher-plan-card{padding:16px;border-radius:18px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.10);}
.sms-teacher-plan-card h4{margin:0 0 12px;color:#fff;font-size:17px;}
.sms-routine-mobile-list{display:flex;flex-direction:column;gap:10px;}
.sms-routine-chip,.sms-homework-chip{padding:12px 14px;border-radius:15px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.10);}
.sms-routine-chip{border-left:4px solid var(--routine-color,#0f766e);}
.sms-routine-chip strong,.sms-homework-chip strong{display:block;color:#fff;font-size:14px;line-height:1.35;}
.sms-routine-chip span,.sms-homework-chip span{display:block;color:var(--sms-ui-muted);font-size:12px;margin-top:4px;line-height:1.45;}
.sms-homework-chip p{margin:8px 0 0;color:#cbd5e1;font-size:12px;line-height:1.55;}
@media(max-width:900px){
  .sms-attendance-close-card{grid-template-columns:1fr;align-items:stretch;}
  .sms-attendance-close-card .sms-btn{width:100%;}
  .sms-teacher-mobile-stack{grid-template-columns:1fr!important;}
  .sms-frontend-attendance-list .sms-attendance-student-row{gap:10px;padding:12px;}
  .sms-status-pill{padding:9px 11px;font-size:12px;}
  .sms-attendance-actions .sms-btn{width:100%;justify-content:center;text-align:center;}
}
@media(max-width:520px){
  .sms-premium-filter,.sms-attendance-toolbar,.sms-attendance-close-card,.sms-teacher-plan-card{border-radius:16px;padding:13px;}
  .sms-status-pills{display:grid;grid-template-columns:1fr 1fr;}
  .sms-status-pill{justify-content:center;}
}

/* v2.9.7 Teacher frontend selected attendance + editable homework */
.sms-select-all-attendance{display:flex!important;align-items:center;gap:8px;margin-top:8px;color:#dbeafe!important;font-size:13px!important;font-weight:800!important;}
.sms-select-all-attendance input,.sms-attendance-row-check input{width:18px;height:18px;accent-color:var(--sms-ui-button);}
.sms-attendance-student-row{grid-template-columns:78px minmax(170px,1.05fr) minmax(270px,1.35fr) 120px minmax(150px,.8fr)!important;}
.sms-attendance-row-check{display:flex;align-items:center;gap:7px;color:#cbd5e1;font-size:12px;font-weight:800;}
.sms-homework-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px;}
.sms-homework-form-grid label{display:flex;flex-direction:column;gap:7px;color:#eaf1ff;font-weight:800;font-size:13px;}
.sms-homework-form-grid input,.sms-homework-form-grid select,.sms-homework-form-grid textarea{width:100%;border:1px solid rgba(255,255,255,.16);border-radius:14px;background:rgba(255,255,255,.96);color:#0f172a;padding:11px 12px;outline:none;}
.sms-homework-full{grid-column:1/-1;}
.sms-homework-actions{justify-content:flex-start;margin-top:12px;}
.sms-homework-list-title{margin-top:22px!important;}
.sms-homework-chip-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;align-items:center;}
.sms-homework-chip-actions form{margin:0;}
.sms-btn-danger{border-color:rgba(248,113,113,.35)!important;color:#fecaca!important;}
@media(max-width:900px){.sms-attendance-student-row{grid-template-columns:1fr!important}.sms-attendance-row-check{justify-content:flex-start}.sms-homework-form-grid{grid-template-columns:1fr}.sms-homework-actions .sms-btn,.sms-homework-chip-actions .sms-btn{width:100%;justify-content:center;text-align:center}.sms-homework-chip-actions form{width:100%;}}

/* v2.9.8 Homework parent notification + frontend accountant panel */
.sms-homework-whatsapp-toggle{display:flex!important;flex-direction:row!important;align-items:center;gap:10px;color:#dbeafe!important;background:rgba(34,197,94,.10);border:1px solid rgba(34,197,94,.18);border-radius:14px;padding:11px 12px;}
.sms-homework-whatsapp-toggle input{width:18px!important;height:18px!important;accent-color:#22c55e;}
.sms-accountant-dashboard .sms-accountant-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;}
.sms-accounting-ledger-list{display:flex;flex-direction:column;gap:10px;}
.sms-accounting-ledger-list div{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:12px 14px;border-radius:14px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.10);}
.sms-accounting-ledger-list span{color:var(--sms-ui-muted);font-size:13px;}
.sms-accounting-ledger-list strong{color:#fff;font-size:14px;text-align:right;}
.sms-accounting-table-wrap{overflow:auto;border-radius:18px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.035);}
.sms-accounting-table{width:100%;border-collapse:collapse;min-width:900px;}
.sms-accounting-table th,.sms-accounting-table td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left;color:#dbeafe;font-size:13px;}
.sms-accounting-table th{color:#fff;background:rgba(255,255,255,.06);font-weight:900;}
.sms-accounting-table td{color:#cbd5e1;}
.sms-accounting-month-filter{grid-template-columns:1fr auto;max-width:520px;}
@media(max-width:900px){.sms-accountant-dashboard .sms-accountant-grid{grid-template-columns:1fr}.sms-accounting-month-filter{grid-template-columns:1fr}.sms-accounting-table{min-width:760px}.sms-accountant-dashboard .sms-quick-links .sms-btn{width:100%;justify-content:center;text-align:center}}


/* ===== v3.0.7 Universal frontend branding final override =====
   Uses the simple Branding colors from backend settings. Targets actual login/dashboard classes. */
.sms-public-wrap,
.sms-login-page,
.sms-portal-wrap,
.sms-admission-wrap{
  --sms-ui-primary:var(--sms-ui-primary, #2563eb);
  --sms-ui-secondary:var(--sms-ui-secondary, #1d4ed8);
  --sms-ui-accent:var(--sms-ui-accent, #06b6d4);
  --sms-ui-button:var(--sms-ui-button, #2563eb);
  --sms-ui-card-bg:var(--sms-ui-card-bg, rgba(9,15,30,.96));
  --sms-ui-muted:var(--sms-ui-muted, #9fb0d7);
  --sms-ui-gradient:linear-gradient(135deg,var(--sms-ui-primary),var(--sms-ui-secondary));
}
.sms-login-page.sms-public-wrap,
.sms-portal-wrap.sms-public-wrap,
.sms-admission-wrap.sms-public-wrap{
  background:radial-gradient(circle at 18% 8%,rgba(255,255,255,.12),transparent 28%),var(--sms-ui-gradient)!important;
}
.sms-login-page .sms-login-brand,
.sms-login-page .sms-login-card,
.sms-login-page .sms-login-prompt,
.sms-portal-wrap .sms-portal-hero,
.sms-portal-wrap .sms-hero-card,
.sms-portal-wrap .sms-public-section,
.sms-portal-wrap .sms-portal-panel,
.sms-portal-wrap .sms-portal-kpi,
.sms-portal-wrap .sms-mini-card,
.sms-portal-wrap .sms-doc-card,
.sms-admission-wrap .sms-hero-card,
.sms-admission-wrap .sms-public-section{
  background:linear-gradient(180deg,var(--sms-ui-card-bg),rgba(17,24,39,.98))!important;
  border-color:color-mix(in srgb,var(--sms-ui-primary) 38%,#ffffff 10%)!important;
}
.sms-login-page .sms-login-brand,
.sms-portal-wrap .sms-portal-hero,
.sms-portal-wrap .sms-hero-card,
.sms-admission-wrap .sms-hero-card{
  background:radial-gradient(circle at 18% 8%,rgba(255,255,255,.16),transparent 30%),var(--sms-ui-gradient)!important;
}
.sms-login-page .sms-btn-primary,
.sms-login-page button[type=submit],
.sms-login-page .sms-auth-tab.is-active,
.sms-portal-wrap .sms-btn-primary,
.sms-portal-wrap button[type=submit],
.sms-portal-wrap .sms-auth-tab.is-active,
.sms-admission-wrap .sms-btn-primary,
.sms-admission-wrap button[type=submit],
.sms-role-pills span{
  background:linear-gradient(135deg,var(--sms-ui-button),var(--sms-ui-secondary))!important;
  color:#fff!important;
  border-color:transparent!important;
}
.sms-login-page .sms-btn-secondary,
.sms-portal-wrap .sms-btn-secondary,
.sms-admission-wrap .sms-btn-secondary{
  background:rgba(255,255,255,.08)!important;
  color:#fff!important;
  border-color:color-mix(in srgb,var(--sms-ui-primary) 42%,#ffffff 14%)!important;
}
.sms-stat-card.sms-green,
.sms-green,
.sms-notice.success,
.sms-cal-present{
  background:linear-gradient(135deg,var(--sms-ui-primary),var(--sms-ui-secondary))!important;
  color:#fff!important;
}
.sms-portal-wrap .sms-kicker,
.sms-login-page .sms-kicker,
.sms-admission-wrap .sms-kicker,
.sms-portal-kpi span,
.sms-section-head span,
.sms-mini-card span,
.sms-doc-card span,
.sms-login-head p,
.sms-login-footnote,
.sms-muted{
  color:var(--sms-ui-muted)!important;
}
.sms-login-page input:focus,
.sms-portal-wrap input:focus,
.sms-portal-wrap select:focus,
.sms-portal-wrap textarea:focus,
.sms-admission-wrap input:focus,
.sms-admission-wrap select:focus,
.sms-admission-wrap textarea:focus{
  border-color:var(--sms-ui-primary)!important;
  box-shadow:0 0 0 3px color-mix(in srgb,var(--sms-ui-primary) 22%,transparent)!important;
}


/* ===== v3.2.1 Frontend Full Width Dashboard Fix ===== */
body .sms-public-wrap,
body .sms-portal-wrap,
body .sms-login-page,
body .sms-admission-wrap,
body .eduprompt-frontend-wrap,
body .eduprompt-dashboard,
body .sms-frontend-dashboard {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding-left: clamp(12px, 3vw, 32px) !important;
  padding-right: clamp(12px, 3vw, 32px) !important;
}
body .sms-public-wrap > *,
body .sms-portal-wrap > *,
body .sms-login-page > *,
body .sms-admission-wrap > * {
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
}
body .sms-public-wrap .sms-full-bleed,
body .sms-portal-wrap .sms-full-bleed {
  max-width: none;
}
@media (max-width: 767px) {
  body .sms-public-wrap,
  body .sms-portal-wrap,
  body .sms-login-page,
  body .sms-admission-wrap {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
}

/* ===== v3.2.3 Frontend Admin Backend-Style Dashboard ===== */
body .sms-fadmin-shell{display:grid!important;grid-template-columns:180px minmax(0,1fr)!important;gap:0!important;align-items:stretch!important;min-height:100vh!important;background:#f3f7fb!important;color:#101828!important;padding:0!important;max-width:100vw!important;margin-left:calc(50% - 50vw)!important;margin-right:calc(50% - 50vw)!important;}
body .sms-fadmin-shell > *{max-width:none!important;margin:0!important;}
.sms-fadmin-sidebar{position:sticky;top:0;height:100vh;overflow:auto;background:#2f3a40;color:#d9e2ea;padding:0 0 22px;z-index:3;box-shadow:14px 0 28px rgba(15,23,42,.08)}
.sms-fadmin-brand{height:36px;display:flex;align-items:center;gap:8px;padding:0 12px;background:linear-gradient(135deg,var(--sms-ui-primary,#2b7bbb),var(--sms-ui-secondary,#3aa981));color:#fff;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sms-fadmin-logo{font-size:15px}.sms-fadmin-menu{display:flex;flex-direction:column;padding:8px 0}.sms-fadmin-menu a{display:flex;align-items:center;gap:8px;padding:6px 12px;color:#d9e2ea!important;text-decoration:none!important;font-size:13px;font-weight:600;border-left:3px solid transparent;min-height:25px}.sms-fadmin-menu a span{width:16px;text-align:center;opacity:.92}.sms-fadmin-menu a:hover,.sms-fadmin-menu a.is-active{background:rgba(255,255,255,.08);color:#fff!important;border-left-color:var(--sms-ui-primary,#21a36b)}
.sms-fadmin-main{padding:22px 26px 34px!important;min-width:0;background:linear-gradient(180deg,#f8fbff 0,#eef4f8 100%)!important}.sms-fadmin-topbar{display:flex;justify-content:space-between;gap:18px;align-items:center;margin-bottom:20px}.sms-fadmin-topbar h2{margin:4px 0 4px;color:#101828;font-size:26px}.sms-fadmin-topbar p{margin:0;color:#667085}.sms-fadmin-user{background:#fff;border:1px solid #dbe7ef;border-radius:16px;padding:12px 16px;box-shadow:0 14px 30px rgba(15,23,42,.06);min-width:190px}.sms-fadmin-user span{display:block;color:#667085;font-size:12px}.sms-fadmin-user strong{color:#101828}.sms-fadmin-kpis{display:grid;grid-template-columns:repeat(6,minmax(150px,1fr));gap:16px;margin-bottom:24px}.sms-fadmin-kpi{min-height:132px;border-radius:18px;padding:18px;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 18px 40px rgba(15,23,42,.12)}.sms-fadmin-kpi span{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:14px;background:rgba(255,255,255,.18);font-size:24px;margin-bottom:8px}.sms-fadmin-kpi strong{font-size:34px;line-height:1;font-weight:900;color:#fff}.sms-fadmin-kpi small{font-size:14px;color:#fff;opacity:.95}.kpi-blue{background:linear-gradient(135deg,#aac4e6,#4762f5)}.kpi-indigo{background:linear-gradient(135deg,#3e5bf8,#4458e8)}.kpi-orange{background:linear-gradient(135deg,#f59f3a,#dc7528)}.kpi-purple{background:linear-gradient(135deg,#9b5df5,#6f42d8)}.kpi-red{background:linear-gradient(135deg,#ef4444,#e11d48)}
.sms-fadmin-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(340px,.75fr);gap:22px;margin-bottom:24px}.sms-fadmin-card{background:#fff;border:1px solid #c8dfeb;border-radius:20px;padding:24px;box-shadow:0 18px 42px rgba(15,23,42,.08);min-width:0}.sms-fadmin-card-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}.sms-fadmin-card-head h3{position:relative;margin:0;color:#101828;font-size:20px;padding-left:18px}.sms-fadmin-card-head h3:before{content:'';position:absolute;left:0;top:4px;width:8px;height:25px;border-radius:999px;background:linear-gradient(180deg,#f59e0b,var(--sms-ui-primary,#2d7d58))}.sms-fadmin-card-head a{display:inline-flex;padding:10px 16px;border-radius:999px;background:#e9fbf2;color:#17643f!important;text-decoration:none!important;font-weight:800;font-size:13px;border:1px solid #c6efd9}.sms-meter-row{display:flex;align-items:center;gap:12px;margin:12px 0 18px}.sms-meter{height:12px;background:#e5e7eb;border-radius:999px;flex:1;overflow:hidden}.sms-meter span{display:block;height:100%;background:linear-gradient(90deg,var(--sms-ui-primary,#2d7d58),var(--sms-ui-secondary,#20b486));border-radius:999px}.sms-fadmin-mini-grid{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:10px;margin:14px 0 20px}.sms-fadmin-mini-grid.two{grid-template-columns:repeat(2,minmax(130px,1fr))}.sms-fadmin-mini-grid div{background:#f8fafc;border:1px solid #dbe4ed;border-radius:12px;padding:14px 16px;color:#475467;font-weight:800}.sms-fadmin-mini-grid strong{display:block;margin-top:6px;color:#101828;font-size:22px}.sms-fadmin-money{font-size:36px;font-weight:900;line-height:1;color:var(--sms-ui-primary,#226a4b);margin:8px 0 14px}.sms-fadmin-money span{display:block;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:#667085;margin-top:4px}.sms-fadmin-card h4{margin:12px 0 10px;color:#15563d;background:#ecfbf4;border:1px solid #cbeedd;border-radius:14px;padding:12px 14px}.sms-fadmin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden}.sms-fadmin-table th{background:linear-gradient(135deg,var(--sms-ui-primary,#2d7d58),#27684c);color:#fff;text-align:left;padding:10px;font-size:13px}.sms-fadmin-table td{padding:12px 10px;border-bottom:1px solid #edf2f7;color:#344054;font-size:13px}.sms-table-scroll{overflow:auto}.sms-fadmin-modules{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:16px;margin-bottom:24px}.sms-fadmin-module{background:#fff;border:1px solid #d9e7ef;border-radius:18px;padding:18px;box-shadow:0 14px 30px rgba(15,23,42,.06);scroll-margin-top:18px}.sms-fadmin-module span{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 9px;border-radius:12px;background:linear-gradient(135deg,var(--sms-ui-primary,#2d7d58),var(--sms-ui-secondary,#20b486));color:#fff;font-weight:900;margin-bottom:12px}.sms-fadmin-module h4{margin:0 0 6px;color:#101828}.sms-fadmin-module p{margin:0;color:#667085;font-size:13px}.small-panels{grid-template-columns:repeat(2,minmax(0,1fr))}
@media(max-width:1200px){.sms-fadmin-kpis{grid-template-columns:repeat(3,1fr)}.sms-fadmin-modules{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){body .sms-fadmin-shell{grid-template-columns:1fr!important}.sms-fadmin-sidebar{position:relative;height:auto;max-height:260px}.sms-fadmin-menu{display:grid;grid-template-columns:repeat(2,1fr)}.sms-fadmin-main{padding:16px!important}.sms-fadmin-grid,.small-panels{grid-template-columns:1fr}.sms-fadmin-kpis{grid-template-columns:repeat(2,1fr)}.sms-fadmin-modules{grid-template-columns:repeat(2,1fr)}.sms-fadmin-topbar{flex-direction:column;align-items:stretch}}@media(max-width:560px){.sms-fadmin-kpis,.sms-fadmin-modules,.sms-fadmin-mini-grid,.sms-fadmin-mini-grid.two{grid-template-columns:1fr}.sms-fadmin-menu{grid-template-columns:1fr}.sms-fadmin-kpi{min-height:112px}.sms-fadmin-topbar h2{font-size:21px}}

/* ===== v3.2.4 Real Frontend ERP Routing ===== */
.sms-fadmin-routed .sms-fadmin-menu a{cursor:pointer;}
.sms-fadmin-routed .sms-fadmin-menu a[href*="license"],
.sms-fadmin-routed .sms-fadmin-menu a[href*="demo"],
.sms-fadmin-routed .sms-fadmin-menu a[href*="permission"]{display:none!important;}
.sms-fadmin-module-head{display:flex;align-items:center;justify-content:space-between;gap:18px;margin:0 0 22px;padding:26px 28px;border-radius:26px;background:linear-gradient(135deg,var(--sms-ui-primary),#0f172a);border:1px solid rgba(255,255,255,.12);box-shadow:0 22px 50px rgba(15,23,42,.16);color:#fff;}
.sms-fadmin-module-head h2{margin:6px 0 4px;font-size:clamp(26px,3vw,42px);color:#fff;line-height:1.05;}
.sms-fadmin-module-head p{margin:0;color:rgba(255,255,255,.78)!important;}
.sms-fadmin-module-page{background:#fff;border:1px solid #dbe7f3;border-radius:24px;box-shadow:0 18px 50px rgba(15,23,42,.08);padding:22px;overflow:hidden;}
.sms-fadmin-module-page .wrap{margin:0!important;max-width:none!important;}
.sms-fadmin-module-page .wrap h1{margin-top:0!important;}
.sms-fadmin-module-page .sms-card{max-width:none!important;}
.sms-fadmin-modules a.sms-fadmin-module{text-decoration:none;color:inherit;display:block;}
.sms-fadmin-modules a.sms-fadmin-module:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--sms-ui-primary) 42%,#ffffff 20%);}
@media(max-width:900px){.sms-fadmin-module-head{flex-direction:column;align-items:flex-start;padding:22px}.sms-fadmin-module-head .sms-btn{width:100%;text-align:center}.sms-fadmin-module-page{padding:14px;border-radius:18px}}


/* v3.2.5 Frontend Admin Stability + Mobile Fix */
.sms-fadmin-dashboard-clone{margin:0!important;max-width:none!important;padding:0!important;background:transparent!important;}
.sms-fadmin-dashboard-clone .sms-dashboard-hero,.sms-fadmin-dashboard-clone .sms-premium-insights,.sms-fadmin-dashboard-clone .sms-stats-grid,.sms-fadmin-dashboard-clone .sms-dashboard-grid,.sms-fadmin-dashboard-clone .sms-card{max-width:none!important;}
.sms-fadmin-dashboard-clone .sms-hero-actions a[href*="wp-admin"],.sms-fadmin-dashboard-clone .sms-btn-grid a[href*="wp-admin"]{pointer-events:auto;}
.sms-fadmin-module-page .sms-table,.sms-fadmin-module-page table{width:100%;}
.sms-fadmin-module-page form{max-width:100%;}
.sms-fadmin-sidebar::-webkit-scrollbar{width:6px}.sms-fadmin-sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.22);border-radius:999px}
@media(max-width:900px){
 body .sms-fadmin-shell{display:block!important;min-height:100vh!important;}
 .sms-fadmin-sidebar{position:sticky!important;top:0!important;height:auto!important;max-height:none!important;width:100%!important;z-index:50!important;padding-bottom:8px!important;}
 .sms-fadmin-brand{height:48px!important;font-size:15px!important;}
 .sms-fadmin-menu{display:flex!important;flex-direction:row!important;gap:8px!important;overflow-x:auto!important;padding:10px 12px!important;scroll-snap-type:x mandatory!important;}
 .sms-fadmin-menu a{min-width:max-content!important;border-left:0!important;border-bottom:3px solid transparent!important;border-radius:12px!important;background:rgba(255,255,255,.06)!important;padding:10px 12px!important;scroll-snap-align:start!important;}
 .sms-fadmin-menu a.is-active{border-bottom-color:var(--sms-ui-primary,#21a36b)!important;}
 .sms-fadmin-main{padding:14px!important;}
 .sms-fadmin-dashboard-clone .sms-dashboard-hero{display:block!important;padding:22px!important;border-radius:22px!important;}
 .sms-fadmin-dashboard-clone .sms-hero-actions{display:grid!important;grid-template-columns:1fr!important;gap:10px!important;margin-top:16px!important;}
 .sms-fadmin-dashboard-clone .sms-premium-insights,.sms-fadmin-dashboard-clone .sms-premium-kpis,.sms-fadmin-dashboard-clone .sms-dashboard-grid,.sms-fadmin-dashboard-clone .sms-dashboard-grid-2,.sms-fadmin-dashboard-clone .sms-dashboard-grid-3{display:grid!important;grid-template-columns:1fr!important;gap:14px!important;}
 .sms-fadmin-dashboard-clone .sms-stats-grid{grid-template-columns:1fr 1fr!important;}
 .sms-fadmin-dashboard-clone .sms-card{padding:16px!important;border-radius:18px!important;overflow:auto!important;}
 .sms-fadmin-dashboard-clone .sms-mini-grid,.sms-fadmin-dashboard-clone .sms-mini-grid-2{grid-template-columns:1fr 1fr!important;}
 .sms-fadmin-module-page{padding:12px!important;overflow:auto!important;}
 .sms-fadmin-module-page .sms-form-grid,.sms-fadmin-module-page .sms-grid,.sms-fadmin-module-page .sms-two-col,.sms-fadmin-module-page .sms-admin-two-col{grid-template-columns:1fr!important;}
}
@media(max-width:560px){
 .sms-fadmin-dashboard-clone .sms-stats-grid,.sms-fadmin-dashboard-clone .sms-mini-grid,.sms-fadmin-dashboard-clone .sms-mini-grid-2{grid-template-columns:1fr!important;}
 .sms-fadmin-dashboard-clone .sms-dashboard-hero h1{font-size:28px!important;}
 .sms-fadmin-menu a{font-size:12px!important;}
}


/* v3.2.8 Frontend topbar + logout */
.sms-frontend-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 0 18px;padding:14px 16px;border:1px solid rgba(148,163,184,.24);border-radius:18px;background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(248,250,252,.92));box-shadow:0 14px 34px rgba(15,23,42,.08);position:relative;z-index:6;}
.sms-fadmin-main>.sms-frontend-topbar{position:sticky;top:10px;z-index:60;}
.sms-frontend-topbar-left{display:flex;flex-direction:column;gap:2px;min-width:0}.sms-frontend-topbar-left strong{font-size:18px;color:#101828;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sms-frontend-topbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.sms-frontend-user-pill{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:999px;background:#fff;border:1px solid #e5e7eb;color:#111827;font-weight:800;box-shadow:0 10px 20px rgba(15,23,42,.05)}.sms-frontend-user-pill small{font-size:11px;color:#64748b;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.sms-topbar-logout{min-width:94px;text-align:center}.sms-topbar-settings{min-width:96px;text-align:center}
@media(max-width:720px){.sms-frontend-topbar{align-items:stretch;flex-direction:column;padding:12px;border-radius:16px}.sms-frontend-topbar-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}.sms-frontend-user-pill{grid-column:1/-1;justify-content:center}.sms-topbar-logout{width:100%!important}.sms-fadmin-main>.sms-frontend-topbar{position:relative;top:auto}}


/* v3.2.9 stability: frontend attendance filter should stay on same portal page and mobile rows remain usable */
.sms-frontend-attendance-form,.sms-frontend-close-attendance-form{scroll-margin-top:90px}.sms-attendance-student-row{contain:layout paint}.sms-frontend-attendance-list{content-visibility:auto;contain-intrinsic-size:900px}@media(max-width:760px){.sms-attendance-student-row{grid-template-columns:1fr!important;gap:10px}.sms-attendance-actions{display:grid!important;grid-template-columns:1fr 1fr;width:100%}.sms-attendance-actions .sms-btn{width:100%;justify-content:center}.sms-premium-filter{display:grid!important;grid-template-columns:1fr!important}.sms-time-input,.sms-remarks-input{width:100%!important}.sms-frontend-topbar{position:relative!important}}

/* ===== v3.3.3 REAL login layout visibility fix ===== */
body .sms-public-wrap.sms-login-page,
body:has(.sms-login-page) .sms-public-wrap.sms-login-page{
  width:100% !important;
  max-width:1200px !important;
  margin:0 auto !important;
  padding:18px 16px 32px !important;
  overflow:visible !important;
  display:block !important;
  box-sizing:border-box !important;
}
body .sms-login-page .sms-login-shell,
body:has(.sms-login-page) .sms-login-page .sms-login-shell{
  width:100% !important;
  max-width:100% !important;
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:minmax(0, .95fr) minmax(330px, .55fr) !important;
  gap:18px !important;
  align-items:stretch !important;
  justify-content:center !important;
  box-sizing:border-box !important;
  overflow:visible !important;
}
body .sms-login-page .sms-login-brand,
body .sms-login-page .sms-login-card{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  min-height:auto !important;
  box-sizing:border-box !important;
  padding:24px !important;
}
body .sms-login-page .sms-login-card{
  justify-self:stretch !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
}
body .sms-login-page .sms-login-brand h2{
  font-size:clamp(2rem,3vw,3.2rem) !important;
  max-width:none !important;
}
body .sms-login-page .sms-login-brand p{
  max-width:620px !important;
  font-size:1rem !important;
}
body .sms-login-page .sms-mini-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:12px !important;
}
body .sms-login-page .sms-mini-card{
  min-height:112px !important;
  padding:16px !important;
}
body .sms-login-page .sms-login-head h3{
  font-size:clamp(1.8rem,2.4vw,2.5rem) !important;
  line-height:1.08 !important;
}
body .sms-login-page .sms-login-form .sms-input,
body .sms-login-page .sms-btn.sms-full{
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box !important;
}
body:has(.sms-login-page) .entry-content,
body:has(.sms-login-page) .page-content,
body:has(.sms-login-page) .site-main,
body:has(.sms-login-page) .content-area,
body:has(.sms-login-page) article,
body:has(.sms-login-page) .hentry{
  overflow:visible !important;
}
@media (max-width: 1100px){
  body .sms-public-wrap.sms-login-page,
  body:has(.sms-login-page) .sms-public-wrap.sms-login-page{
    max-width:980px !important;
    padding:14px 12px 28px !important;
  }
  body .sms-login-page .sms-login-shell,
  body:has(.sms-login-page) .sms-login-page .sms-login-shell{
    grid-template-columns:minmax(0, .9fr) minmax(320px, .6fr) !important;
    gap:14px !important;
  }
  body .sms-login-page .sms-login-brand,
  body .sms-login-page .sms-login-card{
    padding:20px !important;
  }
  body .sms-login-page .sms-mini-card{
    min-height:98px !important;
  }
}
@media (max-width: 900px){
  body .sms-public-wrap.sms-login-page,
  body:has(.sms-login-page) .sms-public-wrap.sms-login-page{
    max-width:520px !important;
    min-height:auto !important;
    display:block !important;
  }
  body .sms-login-page .sms-login-shell,
  body:has(.sms-login-page) .sms-login-page .sms-login-shell{
    display:block !important;
    width:100% !important;
  }
  body .sms-login-page .sms-login-brand{
    display:none !important;
  }
  body .sms-login-page .sms-login-card{
    padding:20px 18px !important;
  }
}
@media (max-width: 480px){
  body .sms-public-wrap.sms-login-page,
  body:has(.sms-login-page) .sms-public-wrap.sms-login-page{
    max-width:100% !important;
    padding:10px !important;
  }
  body .sms-login-page .sms-login-card{
    padding:16px 14px !important;
    border-radius:16px !important;
  }
}


/* ===== v3.3.4 frontend admin final polish: no frontend settings, dynamic module colors, document preview route ===== */
.sms-fadmin-menu a[href*="sms_fadmin=settings"],
.sms-topbar-settings{display:none!important;}
.sms-fadmin-module-page .sms-page-header,
.sms-fadmin-module-page .sms-accounting-hero,
.sms-fadmin-module-page .sms-report-hero,
.sms-fadmin-module-page .sms-document-preview-wrap>.sms-page-header,
.sms-fadmin-module-page .sms-wrap>h1{
  background:linear-gradient(135deg,var(--sms-ui-primary,#2563eb),var(--sms-ui-secondary,#7c3aed))!important;
  color:#fff!important;
  border-radius:24px!important;
  box-shadow:0 20px 48px color-mix(in srgb,var(--sms-ui-primary,#2563eb) 24%, transparent)!important;
  border:1px solid rgba(255,255,255,.16)!important;
}
.sms-fadmin-module-page .sms-page-header h1,
.sms-fadmin-module-page .sms-page-header p,
.sms-fadmin-module-page .sms-accounting-hero h1,
.sms-fadmin-module-page .sms-accounting-hero p,
.sms-fadmin-module-page .sms-report-hero h1,
.sms-fadmin-module-page .sms-report-hero p{
  color:#fff!important;
}
.sms-fadmin-module-page .sms-accounting-tabs a,
.sms-fadmin-module-page .sms-fadmin-card-head a,
.sms-fadmin-module-page .sms-wrap h3,
.sms-fadmin-module-page .sms-card h3{
  background:color-mix(in srgb,var(--sms-ui-primary,#2563eb) 10%, #ffffff)!important;
  color:var(--sms-ui-primary,#2563eb)!important;
  border-color:color-mix(in srgb,var(--sms-ui-primary,#2563eb) 22%, #ffffff)!important;
}
.sms-fadmin-module-page .sms-table th,
.sms-fadmin-module-page table th,
.sms-fadmin-module-page .sms-btn-primary,
.sms-fadmin-module-page .button-primary,
.sms-fadmin-module-page .sms-tab.active,
.sms-fadmin-module-page .sms-preview-actions .sms-btn-primary,
.sms-fadmin-module-page .sms-template-preview-card.is-selected .sms-template-check{
  background:linear-gradient(135deg,var(--sms-ui-primary,#2563eb),var(--sms-ui-secondary,#7c3aed))!important;
  color:#fff!important;
}
.sms-fadmin-module-page .sms-input:focus,
.sms-fadmin-module-page input:focus,
.sms-fadmin-module-page select:focus,
.sms-fadmin-module-page textarea:focus{
  border-color:var(--sms-ui-primary,#2563eb)!important;
  box-shadow:0 0 0 4px color-mix(in srgb,var(--sms-ui-primary,#2563eb) 16%, transparent)!important;
}
.sms-fadmin-module-page .sms-document-preview-wrap{max-width:none!important;margin:0!important;}
.sms-fadmin-module-page .sms-live-preview-card{overflow:hidden!important;}
.sms-fadmin-module-page .sms-document-preview-frame{width:100%!important;min-height:720px!important;border:1px solid #dbe7f3!important;border-radius:18px!important;background:#fff!important;}
@media(max-width:760px){.sms-fadmin-module-page .sms-document-preview-frame{min-height:560px!important}.sms-fadmin-module-page .sms-page-header{display:block!important;padding:22px!important}}


/* v3.3.5 Student/Parent portal final fixes */
.sms-portal-wrap #sms-fees,
.sms-portal-wrap #sms-fees h3,
.sms-portal-wrap #sms-fees p,
.sms-portal-wrap #sms-fees .sms-stat-label,
.sms-portal-wrap #sms-fees .sms-stat-number,
.sms-portal-wrap #sms-fees .sms-muted{color:#0f172a!important;}
.sms-portal-wrap #sms-fees .sms-table-wrap{background:#ffffff!important;border:1px solid #e2e8f0!important;box-shadow:0 14px 35px rgba(15,23,42,.08);}
.sms-portal-wrap #sms-fees .sms-table th{background:linear-gradient(135deg,var(--sms-ui-primary),var(--sms-ui-secondary))!important;color:#fff!important;}
.sms-portal-wrap #sms-fees .sms-table td{background:#fff!important;color:#111827!important;border-bottom:1px solid #eef2f7!important;}
.sms-portal-wrap #sms-fees .sms-table td a,.sms-portal-wrap #sms-fees .sms-table td span{color:inherit!important;}
.sms-portal-wrap #sms-fees .sms-table td .sms-btn{color:#fff!important;}
.sms-portal-wrap #sms-fees .sms-table tr:hover td{background:#f8fafc!important;}
.sms-portal-wrap #sms-fees .sms-badge{color:#0f172a!important;background:#e5e7eb!important;}
.sms-portal-wrap #sms-fees .sms-badge-graded{background:#dcfce7!important;color:#166534!important;}
.sms-portal-wrap #sms-fees .sms-badge-pending{background:#fef3c7!important;color:#92400e!important;}
.sms-portal-wrap #sms-fees .sms-section-head span{color:#475569!important;}
.sms-portal-wrap .sms-frontend-topbar{margin-bottom:18px;}
@media(max-width:760px){.sms-portal-wrap #sms-fees .sms-table{min-width:760px}.sms-portal-wrap #sms-fees .sms-table-wrap{border-radius:18px;}}
