@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;
  }
}
