/* School Management System - Admin Styles */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

.sms-wrap * { box-sizing: border-box; font-family: 'Plus Jakarta Sans', sans-serif; }

.sms-wrap h1 { font-size: 1.8rem; font-weight: 700; color: #1e293b; margin-bottom: 24px; }
.sms-wrap h2 { font-size: 1.2rem; font-weight: 600; color: #334155; margin: 0 0 16px; }
.sms-wrap h3 { font-size: 1rem; font-weight: 600; color: #475569; margin: 0 0 12px; }

/* Cards */
.sms-card {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 20px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}

/* Stats Grid */
.sms-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.sms-stat-card {
    border-radius: 12px;
    padding: 20px;
    text-align: center;
    color: #fff;
}
.sms-stat-card .sms-stat-icon { font-size: 2rem; margin-bottom: 8px; }
.sms-stat-card .sms-stat-number { font-size: 2rem; font-weight: 700; line-height: 1; }
.sms-stat-card .sms-stat-label { font-size: 0.8rem; opacity: 0.9; margin-top: 4px; }
.sms-green  { background: linear-gradient(135deg, #10b981, #059669); }
.sms-blue   { background: linear-gradient(135deg, #3b82f6, #2563eb); }
.sms-orange { background: linear-gradient(135deg, #f59e0b, #d97706); }
.sms-purple { background: linear-gradient(135deg, #8b5cf6, #7c3aed); }
.sms-red    { background: linear-gradient(135deg, #ef4444, #dc2626); }

/* Buttons */
.sms-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 9px 18px;
    border-radius: 8px;
    border: none;
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    transition: all 0.15s ease;
    font-family: 'Plus Jakarta Sans', sans-serif;
}
.sms-btn:hover { opacity: 0.88; transform: translateY(-1px); text-decoration: none; }
.sms-btn-primary   { background: #3b82f6; color: #fff; }
.sms-btn-secondary { background: #64748b; color: #fff; }
.sms-btn-success   { background: #10b981; color: #fff; }
.sms-btn-info      { background: #06b6d4; color: #fff; }
.sms-btn-danger    { background: #ef4444; color: #fff; }
.sms-btn-sm        { padding: 5px 12px; font-size: 0.8rem; }
.sms-btn-lg        { padding: 12px 28px; font-size: 1rem; }

.sms-btn-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 12px;
    margin-top: 8px;
}

/* Forms */
.sms-form-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: flex-end;
}
.sms-form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    margin-bottom: 12px;
}

.sms-input {
    padding: 9px 13px;
    border: 1.5px solid #d1d5db;
    border-radius: 8px;
    font-size: 0.875rem;
    font-family: 'Plus Jakarta Sans', sans-serif;
    color: #1e293b;
    transition: border-color 0.15s;
    background: #fff;
    min-width: 160px;
}
.sms-input:focus { outline: none; border-color: #3b82f6; box-shadow: 0 0 0 3px rgba(59,130,246,0.1); }

.sms-input-sm {
    padding: 5px 9px;
    border: 1.5px solid #d1d5db;
    border-radius: 6px;
    font-size: 0.8rem;
    font-family: 'Plus Jakarta Sans', sans-serif;
}
.sms-input-sm:focus { outline: none; border-color: #3b82f6; }

/* Tables */
.sms-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}
.sms-table th {
    background: #f8fafc;
    padding: 11px 14px;
    text-align: left;
    font-weight: 600;
    color: #475569;
    border-bottom: 2px solid #e2e8f0;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.sms-table td {
    padding: 11px 14px;
    border-bottom: 1px solid #f1f5f9;
    color: #334155;
    vertical-align: middle;
}
.sms-table tr:last-child td { border-bottom: none; }
.sms-table tr:hover td { background: #f8fafc; }
.sms-center { text-align: center; }

/* Badges */
.sms-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
}
.sms-badge-present  { background: #dcfce7; color: #15803d; }
.sms-badge-absent   { background: #fee2e2; color: #dc2626; }
.sms-badge-late     { background: #fef3c7; color: #d97706; }
.sms-badge-excused  { background: #e0f2fe; color: #0369a1; }
.sms-badge-submitted{ background: #ede9fe; color: #7c3aed; }
.sms-badge-graded   { background: #dcfce7; color: #15803d; }
.sms-badge-pending  { background: #fef3c7; color: #d97706; }
.sms-badge-on_leave { background: #f3f4f6; color: #6b7280; }

/* Notice */
.sms-notice {
    padding: 12px 18px;
    border-radius: 8px;
    margin-top: 16px;
    font-weight: 500;
    font-size: 0.875rem;
}
.sms-notice.success { background: #dcfce7; color: #15803d; border-left: 4px solid #22c55e; }
.sms-notice.error   { background: #fee2e2; color: #dc2626; border-left: 4px solid #ef4444; }

/* Tabs */
.sms-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 20px;
    border-bottom: 2px solid #e2e8f0;
    padding-bottom: 0;
}
.sms-tab {
    padding: 10px 20px;
    border: none;
    background: none;
    font-weight: 600;
    color: #64748b;
    cursor: pointer;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 0.875rem;
    transition: all 0.15s;
}
.sms-tab:hover  { color: #3b82f6; }
.sms-tab.active { color: #3b82f6; border-bottom-color: #3b82f6; }
.sms-tab-content { display: none; }
.sms-tab-content.active { display: block; }

/* Quick links */
.sms-quick-links { margin-top: 8px; }

/* Grade form */
.sms-grade-form { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }

/* Responsive */
@media (max-width: 768px) {
    .sms-stats-grid { grid-template-columns: repeat(2, 1fr); }
    .sms-form-row { flex-direction: column; }
    .sms-btn-grid { grid-template-columns: 1fr; }
}

.sms-mini-stat {
    background:#f8fafc;
    border:1px solid #e2e8f0;
    border-radius:12px;
    padding:14px 16px;
}

.sms-split-card {
    display:grid;
    grid-template-columns:minmax(0, 2fr) minmax(260px, 1fr);
    gap:20px;
}
.sms-form-grid-2col { grid-template-columns: repeat(2, minmax(220px,1fr)); }
.sms-toolbar { display:flex; justify-content:space-between; gap:16px; align-items:flex-end; margin-bottom:16px; }
.sms-inline-search { display:flex; gap:10px; align-items:center; }
.sms-action-row { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.sms-side-note {
    background:linear-gradient(180deg,#f8fbff,#eef5ff);
    border:1px solid #dbeafe;
    border-radius:14px;
    padding:18px;
}
.sms-side-note ul { margin:10px 0 0 18px; }
.sms-side-note li { margin:0 0 10px; color:#475569; }
.sms-muted { color:#64748b; }
.sms-form-actions { display:flex; gap:10px; flex-wrap:wrap; }
@media (max-width: 900px) {
    .sms-split-card { grid-template-columns:1fr; }
    .sms-toolbar { flex-direction:column; align-items:stretch; }
    .sms-inline-search { flex-direction:column; align-items:stretch; }
    .sms-form-grid-2col { grid-template-columns:1fr; }
}

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

/* ERP-style dashboard upgrade */
.sms-erp-dashboard .sms-dashboard-hero {
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
    padding:26px;
    border-radius:20px;
    margin-bottom:22px;
    color:#fff;
    background:linear-gradient(135deg,#064e3b,#0f766e 55%,#1d4ed8);
    box-shadow:0 18px 45px rgba(15,23,42,.18);
    overflow:hidden;
    position:relative;
}
.sms-erp-dashboard .sms-dashboard-hero:after {
    content:"";
    position:absolute;
    width:280px;
    height:280px;
    right:-90px;
    top:-120px;
    background:rgba(255,255,255,.12);
    border-radius:999px;
}
.sms-erp-dashboard .sms-dashboard-hero h1 { color:#fff; margin:4px 0 6px; font-size:2rem; }
.sms-erp-dashboard .sms-dashboard-hero p { color:rgba(255,255,255,.86); margin:0; max-width:720px; }
.sms-kicker { text-transform:uppercase; letter-spacing:.12em; font-weight:800; font-size:.72rem; opacity:.86; }
.sms-hero-actions { display:flex; flex-wrap:wrap; gap:10px; position:relative; z-index:1; }
.sms-kpi-grid { grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); }
.sms-dashboard-grid { display:grid; grid-template-columns:minmax(0,1.35fr) minmax(320px,.85fr); gap:20px; margin-bottom:20px; }
.sms-dashboard-grid-3 { grid-template-columns:repeat(3,minmax(0,1fr)); }
.sms-dashboard-panel { min-height:100%; }
.sms-mini-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:10px; margin:14px 0 18px; }
.sms-mini-grid-2 { grid-template-columns:repeat(2,minmax(0,1fr)); }
.sms-meter-row { display:flex; gap:12px; align-items:center; margin-bottom:14px; }
.sms-meter { flex:1; height:12px; background:#e5e7eb; border-radius:999px; overflow:hidden; }
.sms-meter span { display:block; height:100%; background:linear-gradient(90deg,#16a34a,#22c55e); border-radius:999px; }
.sms-finance-big { font-size:2rem; font-weight:800; color:#064e3b; margin-bottom:14px; }
.sms-finance-big span { display:block; font-size:.82rem; font-weight:700; color:#64748b; text-transform:uppercase; letter-spacing:.08em; margin-top:2px; }
.sms-compact-table th, .sms-compact-table td { padding:8px 10px; font-size:.8rem; }
.sms-badge-paid { background:#dcfce7; color:#15803d; }
.sms-badge-partial { background:#e0f2fe; color:#0369a1; }
.sms-badge-overdue { background:#fee2e2; color:#dc2626; }
@media (max-width: 1100px) {
    .sms-dashboard-grid, .sms-dashboard-grid-3 { grid-template-columns:1fr; }
    .sms-erp-dashboard .sms-dashboard-hero { flex-direction:column; align-items:flex-start; }
}
@media (max-width: 640px) {
    .sms-erp-dashboard .sms-dashboard-hero { padding:20px; border-radius:16px; }
    .sms-erp-dashboard .sms-dashboard-hero h1 { font-size:1.45rem; }
    .sms-hero-actions, .sms-hero-actions .sms-btn { width:100%; justify-content:center; }
    .sms-mini-grid-2 { grid-template-columns:1fr; }
}

/* v14.0.5 Premium Dashboard UI */
.sms-premium-dashboard {
    --erp-navy:#0f172a;
    --erp-green:#065f46;
    --erp-mint:#10b981;
    --erp-blue:#2563eb;
    --erp-purple:#7c3aed;
    --erp-orange:#f59e0b;
    --erp-red:#ef4444;
}
.sms-premium-dashboard .sms-card {
    border:1px solid rgba(148,163,184,.22);
    border-radius:22px;
    background:linear-gradient(180deg,#ffffff,#fbfdff);
    box-shadow:0 16px 38px rgba(15,23,42,.08);
}
.sms-premium-hero {
    padding:30px 32px !important;
    border-radius:28px !important;
    background:
        radial-gradient(circle at 90% 15%, rgba(16,185,129,.34), transparent 28%),
        radial-gradient(circle at 12% 5%, rgba(59,130,246,.24), transparent 30%),
        linear-gradient(135deg,#052e2b,#064e3b 45%,#0f172a) !important;
    border:1px solid rgba(255,255,255,.16);
    box-shadow:0 24px 60px rgba(6,78,59,.28) !important;
}
.sms-premium-hero:before {
    content:"";
    position:absolute;
    inset:14px;
    border-radius:22px;
    border:1px solid rgba(255,255,255,.10);
    pointer-events:none;
}
.sms-hero-copy { position:relative; z-index:1; }
.sms-hero-pills { display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
.sms-hero-pills span {
    display:inline-flex;
    align-items:center;
    padding:7px 11px;
    border-radius:999px;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.18);
    color:#ecfeff;
    font-size:.78rem;
    font-weight:800;
}
.sms-premium-actions .sms-btn {
    border-radius:999px;
    padding:11px 17px;
    box-shadow:0 12px 24px rgba(0,0,0,.12);
}
.sms-premium-insights {
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:16px;
    margin:0 0 20px;
}
.sms-insight-card {
    border-radius:22px;
    padding:18px;
    color:#0f172a;
    background:#fff;
    border:1px solid rgba(148,163,184,.22);
    box-shadow:0 12px 30px rgba(15,23,42,.07);
    overflow:hidden;
    position:relative;
}
.sms-insight-card:after {
    content:"";
    position:absolute;
    width:110px;
    height:110px;
    right:-38px;
    top:-48px;
    border-radius:999px;
    opacity:.13;
    background:currentColor;
}
.sms-insight-top { display:flex; justify-content:space-between; gap:14px; align-items:flex-start; }
.sms-insight-top span { font-weight:800; color:#475569; font-size:.82rem; }
.sms-insight-top strong { font-size:1.65rem; line-height:1; color:#0f172a; }
.sms-insight-card small { display:block; color:#64748b; margin-top:10px; font-weight:700; font-size:.76rem; }
.sms-insight-green { color:#059669; }
.sms-insight-blue { color:#2563eb; }
.sms-insight-purple { color:#7c3aed; }
.sms-insight-orange { color:#d97706; }
.sms-progress { height:9px; background:#e5e7eb; border-radius:999px; overflow:hidden; margin-top:14px; }
.sms-progress i { display:block; height:100%; border-radius:999px; background:linear-gradient(90deg,currentColor,rgba(15,23,42,.55)); }
.sms-premium-kpis .sms-stat-card {
    display:flex;
    align-items:center;
    gap:14px;
    text-align:left;
    border-radius:22px;
    padding:20px;
    min-height:110px;
    box-shadow:0 16px 36px rgba(15,23,42,.11);
}
.sms-premium-kpis .sms-stat-icon {
    width:48px;
    height:48px;
    display:grid;
    place-items:center;
    border-radius:16px;
    margin:0;
    background:rgba(255,255,255,.16);
}
.sms-panel-heading {
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    margin-bottom:16px;
}
.sms-panel-heading h2 { margin:0; }
.sms-panel-heading span {
    display:inline-flex;
    padding:5px 10px;
    border-radius:999px;
    background:#ecfdf5;
    color:#047857;
    font-size:.74rem;
    font-weight:900;
    white-space:nowrap;
}
.sms-premium-dashboard .sms-mini-stat {
    background:linear-gradient(180deg,#f8fafc,#ffffff);
    border:1px solid rgba(148,163,184,.24);
    box-shadow:0 8px 18px rgba(15,23,42,.045);
    color:#475569;
    font-weight:800;
}
.sms-premium-dashboard .sms-mini-stat strong {
    display:block;
    margin-top:4px;
    color:#0f172a;
    font-size:1.05rem;
}
.sms-dashboard-grid-2 { grid-template-columns:repeat(2,minmax(0,1fr)); }
.sms-checklist { display:grid; gap:10px; }
.sms-check-item {
    display:flex;
    align-items:center;
    gap:10px;
    padding:12px 14px;
    border-radius:14px;
    text-decoration:none;
    font-weight:800;
    border:1px solid rgba(148,163,184,.22);
    background:#fff;
    color:#334155;
}
.sms-check-item:hover { transform:translateY(-1px); text-decoration:none; }
.sms-check-item span {
    display:grid;
    place-items:center;
    width:24px;
    height:24px;
    border-radius:999px;
    font-weight:900;
}
.sms-check-item.done span { background:#dcfce7; color:#15803d; }
.sms-check-item.pending span { background:#fef3c7; color:#d97706; }
.sms-management-grid {
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
}
.sms-management-grid div {
    padding:16px;
    border-radius:18px;
    background:linear-gradient(180deg,#f8fafc,#fff);
    border:1px solid rgba(148,163,184,.22);
}
.sms-management-grid strong { display:block; font-size:1.55rem; color:#0f172a; line-height:1; }
.sms-management-grid span { display:block; color:#64748b; margin-top:6px; font-weight:800; font-size:.78rem; }
.sms-quick-panel .sms-btn-grid { grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); }
.sms-quick-panel .sms-btn {
    justify-content:center;
    border-radius:14px;
    padding:12px 14px;
}
@media (max-width: 1180px) {
    .sms-premium-insights { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width: 760px) {
    .sms-premium-insights, .sms-dashboard-grid-2 { grid-template-columns:1fr; }
    .sms-management-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
    .sms-premium-kpis .sms-stat-card { min-height:auto; }
}
@media (max-width: 480px) {
    .sms-management-grid { grid-template-columns:1fr; }
    .sms-hero-pills span { width:100%; justify-content:center; }
}

/* EduPrompt ERP v14.2.0 - Premium Backend UI Upgrade */
:root{--ep-primary:#064e3b;--ep-primary-2:#047857;--ep-accent:#f59e0b;--ep-bg:#f4f7fb;--ep-card:#fff;--ep-border:rgba(15,23,42,.09);--ep-text:#0f172a;--ep-muted:#64748b}
body.toplevel_page_school-management,body[class*="school-management"],body[class*="sms_"]{background:var(--ep-bg)}
.sms-wrap{max-width:1320px;margin:22px 20px 0 0;color:var(--ep-text)}
.sms-wrap>h1{position:relative;margin:0 0 22px;padding:24px 28px;border-radius:24px;color:#fff;letter-spacing:-.03em;background:radial-gradient(circle at top left,rgba(245,158,11,.34),transparent 32%),linear-gradient(135deg,#052e25 0%,#065f46 52%,#047857 100%);box-shadow:0 20px 50px rgba(6,78,59,.22);overflow:hidden}
.sms-wrap>h1:after{content:"EduPrompt ERP";position:absolute;right:24px;top:22px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;opacity:.72;font-weight:800}
.sms-card{background:rgba(255,255,255,.94);border:1px solid var(--ep-border);border-radius:22px;padding:26px;margin-bottom:22px;box-shadow:0 16px 44px rgba(15,23,42,.07);backdrop-filter:blur(10px)}
.sms-card h2,.sms-wrap h2{display:flex;align-items:center;gap:10px;color:#0f172a;font-size:1.08rem;letter-spacing:-.015em}.sms-card h2:before,.sms-wrap h2:before{content:"";width:9px;height:24px;border-radius:999px;background:linear-gradient(180deg,var(--ep-accent),var(--ep-primary-2));box-shadow:0 8px 18px rgba(4,120,87,.25)}
.sms-wrap h3{margin-top:24px!important;padding:12px 14px;border-radius:16px;color:#064e3b;background:linear-gradient(135deg,#ecfdf5,#f8fafc);border:1px solid rgba(4,120,87,.14)}
.sms-wrap h3+.sms-form-grid{padding:18px;border-radius:20px;border:1px solid rgba(15,23,42,.08);background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:0 10px 28px rgba(15,23,42,.045)}
.sms-form-grid{gap:16px}.sms-form-grid>div,.sms-form-row>div{min-width:0}.sms-wrap label{display:block;margin:0 0 7px;color:#334155;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.035em}
.sms-input,.sms-input-sm,.sms-wrap input[type="text"],.sms-wrap input[type="email"],.sms-wrap input[type="url"],.sms-wrap input[type="number"],.sms-wrap input[type="password"],.sms-wrap input[type="date"],.sms-wrap select,.sms-wrap textarea{width:100%;min-height:42px;border:1px solid #dbe5ef;border-radius:14px;background:#fff;color:#0f172a;box-shadow:inset 0 1px 0 rgba(255,255,255,.7),0 1px 2px rgba(15,23,42,.03);transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.sms-wrap textarea{min-height:84px}
.sms-input:focus,.sms-input-sm:focus,.sms-wrap input:focus,.sms-wrap select:focus,.sms-wrap textarea:focus{border-color:#10b981!important;box-shadow:0 0 0 4px rgba(16,185,129,.13)!important;outline:none!important}.sms-btn,.sms-wrap .button,.sms-wrap button{border-radius:14px!important;font-weight:800!important;border:0!important;box-shadow:0 10px 24px rgba(15,23,42,.10)}
.sms-btn-primary,.sms-wrap .button-primary{background:linear-gradient(135deg,#065f46,#10b981)!important;color:#fff!important}.sms-btn-secondary{background:linear-gradient(135deg,#334155,#64748b);color:#fff}.sms-btn-success{background:linear-gradient(135deg,#047857,#22c55e);color:#fff}.sms-btn-danger{background:linear-gradient(135deg,#b91c1c,#ef4444);color:#fff}
.sms-table{overflow:hidden;border-radius:18px;border:1px solid var(--ep-border);background:#fff;box-shadow:0 10px 30px rgba(15,23,42,.05)}.sms-table th{background:linear-gradient(135deg,#064e3b,#047857);color:#fff;border-bottom:0}.sms-table td{background:#fff}.sms-table tr:hover td{background:#f0fdf4}.sms-badge{border-radius:999px;padding:5px 11px;font-size:.72rem;letter-spacing:.02em}.sms-notice{border-radius:16px;box-shadow:0 10px 26px rgba(15,23,42,.06)}
.sms-tabs{border:0;gap:10px;padding:8px;background:#fff;border-radius:18px;box-shadow:0 10px 26px rgba(15,23,42,.05)}.sms-tab{border-radius:14px;margin:0;border:0}.sms-tab.active{color:#fff;background:linear-gradient(135deg,#065f46,#10b981);box-shadow:0 10px 22px rgba(6,95,70,.20)}.sms-wrap hr{border:0;height:1px;background:linear-gradient(90deg,transparent,rgba(4,120,87,.22),transparent)}
.sms-wrap .description{color:#64748b;font-size:.84rem;margin-top:7px}.sms-wrap code{border-radius:9px;padding:4px 8px;background:#ecfdf5;color:#065f46}.sms-stat-card{border-radius:22px;box-shadow:0 16px 35px rgba(15,23,42,.10);min-height:126px;display:flex;flex-direction:column;justify-content:center}
.sms-form-grid:has(select[name="sms_payment_gateway"]){padding:18px;border-radius:22px;background:linear-gradient(135deg,#052e25,#065f46);box-shadow:0 18px 44px rgba(6,78,59,.20)}.sms-form-grid:has(select[name="sms_payment_gateway"]) label,.sms-form-grid:has(select[name="sms_payment_gateway"]) .description{color:#dcfce7}.sms-form-grid:has(select[name="sms_payment_gateway"]) .sms-input{border-color:rgba(255,255,255,.25)}
@media(max-width:782px){.sms-wrap{margin-right:10px}.sms-wrap>h1{padding:20px;font-size:1.35rem}.sms-wrap>h1:after{position:static;display:block;margin-top:8px}.sms-card{padding:18px;border-radius:18px}.sms-form-grid,.sms-form-grid-2col{grid-template-columns:1fr!important}.sms-table{display:block;overflow-x:auto;white-space:nowrap}}

/* EduPrompt ERP v14.2.0 - Dropdown-only Payment Gateway UI */
.sms-payment-premium-wrap{display:grid;gap:18px;margin-top:16px}.sms-payment-selector-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;padding:22px;border-radius:24px;background:radial-gradient(circle at top left,rgba(245,158,11,.32),transparent 32%),linear-gradient(135deg,#052e25,#065f46 56%,#047857);box-shadow:0 22px 54px rgba(6,78,59,.22);border:1px solid rgba(255,255,255,.16);color:#fff}.sms-payment-selector-card label{color:#d1fae5!important}.sms-payment-selector-card .description{color:#bbf7d0!important}.sms-payment-selector-card .sms-input{border-color:rgba(255,255,255,.28)!important;background:rgba(255,255,255,.96)!important;color:#0f172a!important}.sms-payment-active-pill{min-width:210px;padding:16px 18px;border-radius:20px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}.sms-payment-active-pill span{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.16em;font-weight:900;color:#bbf7d0}.sms-payment-active-pill strong{display:block;margin-top:5px;font-size:1rem;color:#fff}.sms-gateway-panel{padding:22px;border-radius:24px;background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid rgba(15,23,42,.08);box-shadow:0 16px 38px rgba(15,23,42,.07)}.sms-gateway-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid rgba(4,120,87,.12)}.sms-gateway-panel-head h3{margin:0!important;padding:0!important;background:transparent!important;border:0!important;color:#064e3b!important}.sms-gateway-panel-head p{margin:3px 0 0;color:#64748b;font-weight:600}.sms-gateway-panel .sms-form-grid{padding:0!important;border:0!important;box-shadow:none!important;background:transparent!important}.sms-gateway-panel code{word-break:break-all}@media(max-width:782px){.sms-payment-selector-card{grid-template-columns:1fr}.sms-payment-active-pill{min-width:0}.sms-gateway-panel-head{display:block}}

/* v14.3.0 Premium Attendance UI */
.sms-attendance-premium .sms-att-hero{display:flex;justify-content:space-between;gap:18px;align-items:stretch;background:linear-gradient(135deg,var(--sms-admin-primary,#006633),var(--sms-admin-secondary,#0f766e));border-radius:24px;padding:26px;margin:18px 0;color:#fff;box-shadow:0 18px 45px rgba(2,6,23,.18);overflow:hidden;position:relative}.sms-attendance-premium .sms-att-hero:after{content:"";position:absolute;right:-70px;bottom:-70px;width:220px;height:220px;border-radius:999px;background:rgba(255,255,255,.11)}.sms-attendance-premium .sms-att-hero h1{color:#fff;margin:8px 0;font-size:34px;line-height:1.05}.sms-attendance-premium .sms-att-hero p{color:rgba(255,255,255,.86);max-width:760px;font-size:15px}.sms-att-pill{display:inline-flex;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);font-weight:700}.sms-att-clock{min-width:210px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.25);border-radius:20px;padding:18px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1}.sms-att-clock span,.sms-att-clock small{opacity:.85}.sms-att-clock strong{font-size:26px;color:#fff}.sms-att-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:16px;margin-bottom:16px}.sms-att-panel{border-radius:20px!important}.sms-att-close-box p{margin-top:0;color:#64748b}.sms-att-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin:16px 0}.sms-att-stats>div{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:16px;box-shadow:0 12px 28px rgba(15,23,42,.07)}.sms-att-stats span{display:block;color:#64748b;font-weight:700;text-transform:uppercase;font-size:11px;letter-spacing:.06em}.sms-att-stats strong{font-size:26px;line-height:1.2;color:#0f172a}.sms-att-table-card{border-radius:22px!important;overflow:hidden}.sms-att-toolbar{display:flex;justify-content:space-between;gap:15px;align-items:center;margin-bottom:14px}.sms-att-toolbar h2{margin:0}.sms-att-toolbar p{margin:5px 0 0;color:#64748b}.sms-att-actions{display:flex;gap:10px;flex-wrap:wrap}.sms-att-view-table th{background:#f8fafc!important;color:#334155!important;font-weight:800}.sms-att-view-table td{vertical-align:middle}.sms-att-view-table tbody tr{transition:.18s ease}.sms-att-view-table tbody tr:hover{background:#f8fafc}.sms-att-badge{display:inline-flex;border-radius:999px;padding:5px 10px;font-size:11px;font-weight:800;text-transform:capitalize;background:#e2e8f0;color:#334155}.sms-att-present{background:#dcfce7;color:#166534}.sms-att-absent{background:#fee2e2;color:#991b1b}.sms-att-open{background:#fef3c7;color:#92400e}.sms-att-late,.sms-att-half_day{background:#ffedd5;color:#9a3412}@media(max-width:900px){.sms-attendance-premium .sms-att-hero,.sms-att-toolbar{flex-direction:column;align-items:stretch}.sms-att-grid{grid-template-columns:1fr}.sms-attendance-premium .sms-att-hero h1{font-size:26px}.sms-att-clock{min-width:0}}

/* v14.3.2 Attendance bulk controls */
.sms-att-bulkbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin:0 0 16px;padding:14px;border:1px solid rgba(255,255,255,.12);border-radius:16px;background:rgba(255,255,255,.05);box-shadow:0 12px 30px rgba(0,0,0,.12)}.sms-att-bulkbar label{display:flex;gap:8px;align-items:center;font-weight:700}.sms-att-bulkbar .sms-input-sm{min-width:120px}


/* v14.4.1 Late / Half-day percentage dashboard */
.sms-att-dashboard-card{border-radius:24px!important;padding:22px!important;background:linear-gradient(180deg,#fff,#f8fafc)!important;border:1px solid #e2e8f0!important;box-shadow:0 16px 40px rgba(15,23,42,.08)!important;margin:16px 0}.sms-att-dashboard-head{display:flex;justify-content:space-between;gap:18px;align-items:center}.sms-att-dashboard-head h2{margin:8px 0 4px;font-size:22px;color:#0f172a}.sms-att-dashboard-head p{margin:0;color:#64748b}.sms-att-pill.soft{background:#eef2ff;color:#3730a3;border-color:#c7d2fe}.sms-att-percent-ring{width:132px;height:132px;border-radius:999px;background:radial-gradient(circle at center,#fff 55%,transparent 56%),conic-gradient(var(--sms-admin-primary,#006633) 0deg,var(--sms-admin-secondary,#0f766e) 260deg,#e2e8f0 260deg);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:inset 0 0 0 1px rgba(15,23,42,.05)}.sms-att-percent-ring strong{font-size:28px;color:#0f172a;line-height:1}.sms-att-percent-ring span{font-size:11px;color:#64748b;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.sms-att-progress{height:12px;background:#e2e8f0;border-radius:999px;overflow:hidden;margin:18px 0}.sms-att-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--sms-admin-primary,#006633),var(--sms-admin-secondary,#0f766e));border-radius:999px}.sms-att-mini-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.sms-att-mini-stats div{border:1px solid #e2e8f0;border-radius:16px;background:#fff;padding:14px}.sms-att-mini-stats b{display:block;font-size:24px;color:#0f172a}.sms-att-mini-stats span{font-size:11px;color:#64748b;text-transform:uppercase;font-weight:800;letter-spacing:.05em}@media(max-width:760px){.sms-att-dashboard-head{flex-direction:column;align-items:flex-start}.sms-att-percent-ring{width:110px;height:110px}}
.sms-view-more{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:999px;background:#e8fff3;color:#176b4d!important;text-decoration:none!important;font-size:12px;font-weight:800;border:1px solid rgba(22,101,52,.12);box-shadow:0 8px 20px rgba(15,118,110,.08)}
.sms-view-more:hover{background:#d7fbe8;color:#064e3b!important;transform:translateY(-1px)}

/* v2.1.0 Document Template System */
.sms-template-system-card{margin:18px 0 24px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #dbe7f3;border-radius:18px;padding:22px;box-shadow:0 18px 45px rgba(15,23,42,.07)}
.sms-template-grid{display:grid;grid-template-columns:1fr;gap:20px;margin:18px 0}
.sms-template-group{border:1px solid #e1e8f0;border-radius:16px;padding:16px;background:#fff}
.sms-template-group h3{margin:0 0 12px;font-size:16px;color:#172033}
.sms-template-preview-row{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:14px}
.sms-template-preview{position:relative;display:flex;flex-direction:column;gap:7px;padding:12px;border:2px solid #e2e8f0;border-radius:16px;background:#fff;cursor:pointer;transition:.2s ease;min-height:190px}
.sms-template-preview:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(15,23,42,.09)}
.sms-template-preview input{position:absolute;opacity:0;pointer-events:none}
.sms-template-preview.is-selected{border-color:var(--sms-admin-primary,#0ea574);box-shadow:0 0 0 4px rgba(14,165,116,.12)}
.sms-preview-art{height:110px;border-radius:13px;border:1px solid #d8e2ee;background:#f8fafc;position:relative;overflow:hidden;display:block}
.sms-preview-art:before{content:"";position:absolute;left:0;right:0;top:0;height:28px;background:linear-gradient(135deg,#14532d,#0ea574)}
.sms-preview-art i{position:absolute;left:14px;top:38px;width:42px;height:52px;border-radius:8px;background:#e2e8f0;border:1px solid #cbd5e1}
.sms-preview-art b{position:absolute;left:70px;top:42px;width:92px;height:8px;background:#94a3b8;border-radius:99px;box-shadow:0 18px 0 #cbd5e1,0 36px 0 #cbd5e1}
.sms-preview-art em{position:absolute;left:70px;bottom:14px;width:64px;height:9px;background:#0ea574;border-radius:99px}
.sms-template-preview strong{font-size:13px;color:#152238}.sms-template-preview small{color:#64748b;line-height:1.35}
.sms-preview-id_card-landscape_blue .sms-preview-art{height:78px;margin-top:16px;background:#eef6ff}.sms-preview-id_card-landscape_blue .sms-preview-art:before,.sms-preview-admit_card-modern_blue .sms-preview-art:before,.sms-preview-migration-formal_blue .sms-preview-art:before,.sms-preview-marksheet-modern_academic .sms-preview-art:before{background:linear-gradient(135deg,#1d4ed8,#38bdf8)}
.sms-preview-id_card-premium_dark .sms-preview-art,.sms-preview-admit_card-premium_gold .sms-preview-art,.sms-preview-migration-premium_gold .sms-preview-art,.sms-preview-bonafide-premium_corner .sms-preview-art,.sms-preview-marksheet-premium_certificate .sms-preview-art{background:#111827;border-color:#d4a017}.sms-preview-id_card-premium_dark .sms-preview-art:before,.sms-preview-admit_card-premium_gold .sms-preview-art:before,.sms-preview-migration-premium_gold .sms-preview-art:before,.sms-preview-bonafide-premium_corner .sms-preview-art:before,.sms-preview-marksheet-premium_certificate .sms-preview-art:before{background:linear-gradient(135deg,#111827,#d4a017)}
.sms-preview-bonafide-minimal_letterhead .sms-preview-art:before{height:10px;background:#e2e8f0}.sms-preview-bonafide-minimal_letterhead .sms-preview-art i{display:none}
@media(max-width:900px){.sms-template-preview-row{grid-template-columns:1fr}.sms-template-preview{min-height:auto}}

/* v2.2.0 Premium Document Template Preview UI */
.sms-template-system-card{position:relative;overflow:hidden;background:radial-gradient(circle at 0 0,rgba(14,165,116,.10),transparent 34%),linear-gradient(180deg,#ffffff,#f8fbff)!important;border:1px solid #d9e6f2!important;border-radius:24px!important;padding:24px!important;box-shadow:0 24px 70px rgba(15,23,42,.09)!important}
.sms-template-titlebar{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:8px}.sms-template-titlebar h2{margin:0 0 6px!important;font-size:22px;color:#0f172a}.sms-template-version{display:inline-flex;align-items:center;border-radius:999px;padding:8px 12px;background:#ecfdf5;color:#047857;font-size:12px;font-weight:900;border:1px solid #bbf7d0;white-space:nowrap}
.sms-template-grid{gap:24px!important}.sms-template-group{border:1px solid #e2e8f0!important;border-radius:22px!important;padding:18px!important;background:rgba(255,255,255,.92)!important;box-shadow:0 12px 35px rgba(15,23,42,.045)}.sms-template-group h3{display:flex;align-items:center;gap:10px;text-transform:uppercase;letter-spacing:.06em;font-size:13px!important;color:#334155!important}.sms-template-group h3:before{content:"";width:10px;height:10px;border-radius:999px;background:linear-gradient(135deg,#0ea574,#3451ff);box-shadow:0 0 0 4px rgba(14,165,116,.10)}
.sms-template-preview-row{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))!important;gap:16px!important}.sms-template-preview{min-height:270px!important;padding:14px!important;border-radius:22px!important;border:2px solid #e5edf5!important;background:linear-gradient(180deg,#fff,#fbfdff)!important;overflow:hidden}.sms-template-preview:hover{transform:translateY(-3px)!important;box-shadow:0 22px 45px rgba(15,23,42,.11)!important;border-color:#bdd1e7!important}.sms-template-preview.is-selected{border-color:var(--sms-admin-primary,#0ea574)!important;box-shadow:0 0 0 5px rgba(14,165,116,.13),0 22px 45px rgba(15,23,42,.10)!important}.sms-template-preview input{position:absolute;opacity:0;pointer-events:none}.sms-template-check{position:absolute;right:12px;top:12px;width:26px;height:26px;border-radius:999px;background:#e2e8f0;color:#64748b;display:flex;align-items:center;justify-content:center;font-weight:900;opacity:.9}.sms-template-preview.is-selected .sms-template-check{background:#0ea574;color:#fff}.sms-template-meta{display:flex;flex-direction:column;gap:4px;margin-top:4px}.sms-template-meta strong{font-size:14px!important;color:#0f172a!important;line-height:1.25}.sms-template-meta small{font-size:12px!important;color:#64748b!important;line-height:1.35}.sms-template-tags{display:flex;gap:7px;flex-wrap:wrap;margin-top:auto}.sms-template-tags em{font-style:normal;border-radius:999px;border:1px solid #dbe7f3;background:#f8fafc;color:#334155;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;padding:5px 8px}
.sms-preview-art{position:relative;display:block!important;width:100%!important;height:148px!important;border-radius:16px!important;border:1px solid #d7e0ea!important;background:#fff!important;overflow:hidden;margin:0 0 8px!important;box-shadow:inset 0 0 0 1px rgba(255,255,255,.75)}.sms-preview-art>*{position:absolute;display:block}.sms-preview-topbar{left:0;right:0;top:0;height:26px;background:linear-gradient(135deg,#0f766e,#16a34a)}.sms-preview-logo-dot{left:13px;top:8px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.25)}.sms-preview-title-line{left:44px;right:22px;top:10px;height:6px;border-radius:999px;background:rgba(255,255,255,.92)}.sms-preview-subtitle-line{left:44px;width:42%;top:20px;height:4px;border-radius:999px;background:rgba(255,255,255,.68)}.sms-preview-photo-box{right:14px;top:42px;width:34px;height:42px;border-radius:8px;background:#e2e8f0;border:1px solid #cbd5e1}.sms-preview-row{left:14px;right:58px;height:7px;border-radius:999px;background:#dbe4ef}.sms-preview-row.r1{top:48px}.sms-preview-row.r2{top:65px;right:78px}.sms-preview-row.r3{top:82px;right:68px}.sms-preview-table{left:14px;right:14px;bottom:26px;height:28px;border-radius:8px;border:1px solid #cbd5e1;background:repeating-linear-gradient(0deg,#f8fafc 0 8px,#e2e8f0 8px 9px)}.sms-preview-footer-line{left:0;right:0;bottom:0;height:16px;background:#f1f5f9}.sms-preview-watermark{right:16px;bottom:32px;font-size:34px;font-weight:900;color:rgba(15,23,42,.06)}
.sms-preview-accent-blue .sms-preview-topbar{background:linear-gradient(135deg,#1d4ed8,#38bdf8)}.sms-preview-accent-gold .sms-preview-topbar,.sms-preview-accent-dark .sms-preview-topbar{background:linear-gradient(135deg,#111827,#d4a017)}.sms-preview-accent-gold,.sms-preview-accent-dark{border-color:#d4a017!important;background:#111827!important}.sms-preview-accent-gold .sms-preview-row,.sms-preview-accent-dark .sms-preview-row{background:#4b5563}.sms-preview-accent-gold .sms-preview-table,.sms-preview-accent-dark .sms-preview-table{border-color:#d4a017;background:repeating-linear-gradient(0deg,#1f2937 0 8px,#d4a017 8px 9px)}.sms-preview-accent-gold .sms-preview-footer-line,.sms-preview-accent-dark .sms-preview-footer-line{background:#020617}.sms-preview-accent-minimal .sms-preview-topbar{height:10px;background:#e5e7eb}.sms-preview-accent-minimal .sms-preview-logo-dot{background:#f8fafc;border:1px solid #d1d5db}.sms-preview-doc-id_card.sms-preview-style-landscape_blue{height:118px!important;margin-top:15px!important}.sms-preview-doc-id_card.sms-preview-style-landscape_blue .sms-preview-topbar{right:auto;width:34%;height:100%;}.sms-preview-doc-id_card.sms-preview-style-landscape_blue .sms-preview-title-line{left:42%;top:18px;background:#1d4ed8}.sms-preview-doc-id_card.sms-preview-style-landscape_blue .sms-preview-subtitle-line{left:42%;top:31px;background:#93c5fd}.sms-preview-doc-id_card.sms-preview-style-landscape_blue .sms-preview-photo-box{left:42%;top:48px;right:auto}.sms-preview-doc-id_card.sms-preview-style-landscape_blue .sms-preview-row{left:62%;right:14px}.sms-preview-doc-marksheet .sms-preview-table{height:52px;bottom:20px}.sms-preview-doc-bonafide,.sms-preview-doc-migration{background:linear-gradient(180deg,#fff,#fffdf7)!important}.sms-preview-doc-bonafide .sms-preview-table,.sms-preview-doc-migration .sms-preview-table{display:none}.sms-preview-doc-bonafide .sms-preview-watermark,.sms-preview-doc-migration .sms-preview-watermark{font-size:42px;bottom:28px}
@media(max-width:782px){.sms-template-titlebar{display:block}.sms-template-version{margin-top:10px}.sms-template-preview{min-height:auto!important}.sms-preview-art{height:130px!important}}

/* v2.4.4 Class Management Upgrade */
.sms-class-management-card .sms-muted {
    margin: -6px 0 16px;
    color: rgba(15, 23, 42, 0.64);
}
.sms-class-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.sms-btn.sms-btn-danger,
.sms-btn-danger {
    background: linear-gradient(135deg, #dc2626, #991b1b) !important;
    color: #fff !important;
    border: 0 !important;
}
.sms-btn.sms-btn-danger:hover,
.sms-btn-danger:hover {
    filter: brightness(1.05);
    transform: translateY(-1px);
}
.sms-inline-edit-box {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) minmax(120px, .6fr) minmax(180px, 1fr) auto auto;
    gap: 10px;
    align-items: center;
    padding: 16px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(248,250,252,.92));
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
}
.sms-class-edit-row td {
    background: rgba(248, 250, 252, 0.78) !important;
}
@media (max-width: 900px) {
    .sms-inline-edit-box {
        grid-template-columns: 1fr;
    }
    .sms-class-actions {
        flex-direction: column;
    }
}


/* v2.4.5 Smart class delete controls */
.sms-class-delete-box{
    display:grid;
    grid-template-columns: minmax(220px,1.2fr) minmax(180px,.9fr) minmax(180px,.9fr) auto auto;
    gap:12px;
    align-items:center;
    background:rgba(255,255,255,.78);
    border:1px solid rgba(15,23,42,.08);
    border-radius:18px;
    padding:14px;
}
@media (max-width: 900px){
    .sms-class-delete-box{grid-template-columns:1fr;}
}

/* v2.4.7 Document Preview Center */
.sms-document-preview-wrap .sms-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin:18px 0 20px;padding:22px 24px;border-radius:24px;background:linear-gradient(135deg,rgba(9,65,41,.98),rgba(12,92,59,.92));color:#fff;box-shadow:0 18px 42px rgba(15,23,42,.14)}
.sms-document-preview-wrap .sms-page-header h1{margin:0 0 6px;font-size:28px;font-weight:900;color:#fff}.sms-document-preview-wrap .sms-page-header p{margin:0;color:rgba(255,255,255,.78)}
.sms-badge{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);font-weight:800;color:#fff}
.sms-preview-control-card,.sms-live-preview-card{border-radius:22px;padding:20px;background:#fff;box-shadow:0 16px 38px rgba(15,23,42,.08);border:1px solid rgba(15,23,42,.08)}
.sms-document-preview-form{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:16px;align-items:end}.sms-document-preview-form label{display:block;margin-bottom:7px;font-weight:800;color:#16251d}.sms-preview-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.sms-preview-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}.sms-preview-toolbar h2{margin:0 0 4px;font-size:20px}.sms-preview-toolbar p{margin:0;color:#64748b}.sms-preview-toolbar-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.sms-document-preview-frame{width:100%;height:78vh;min-height:720px;border:1px solid rgba(15,23,42,.12);border-radius:18px;background:#f8fafc;box-shadow:inset 0 0 0 1px rgba(255,255,255,.45)}
.sms-empty-state{padding:70px 20px;text-align:center;border-radius:18px;background:linear-gradient(135deg,#f8fafc,#eef6f1);border:1px dashed rgba(15,23,42,.18);color:#64748b;font-weight:700}
@media(max-width:1100px){.sms-document-preview-form{grid-template-columns:repeat(2,minmax(180px,1fr))}.sms-document-preview-frame{height:70vh;min-height:560px}}
@media(max-width:720px){.sms-document-preview-form{grid-template-columns:1fr}.sms-preview-toolbar,.sms-document-preview-wrap .sms-page-header{flex-direction:column;align-items:flex-start}.sms-document-preview-frame{height:68vh;min-height:460px}}

/* v2.4.8 Document Preview Center template selector */
.sms-preview-template-picker{margin-top:18px;padding-top:18px;border-top:1px solid rgba(15,23,42,.10)}
.sms-preview-template-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:12px}
.sms-preview-template-head strong{font-size:16px;font-weight:900;color:#102018}.sms-preview-template-head span{font-size:12px;color:#667085;text-align:right;max-width:560px}
.sms-preview-template-grid{display:grid;grid-template-columns:repeat(5,minmax(170px,1fr));gap:14px}
.sms-template-preview-card{position:relative;display:flex;flex-direction:column;gap:9px;padding:12px;border:1px solid rgba(15,23,42,.10);border-radius:18px;background:linear-gradient(180deg,#fff,#f8fafc);text-decoration:none;color:#17251d;box-shadow:0 10px 26px rgba(15,23,42,.06);transition:.22s ease;overflow:hidden}
.sms-template-preview-card:hover{transform:translateY(-2px);border-color:rgba(8,91,56,.34);box-shadow:0 18px 40px rgba(15,23,42,.12)}
.sms-template-preview-card.is-selected{border-color:#0c6b43;background:linear-gradient(180deg,#f2fff8,#ffffff);box-shadow:0 18px 44px rgba(8,91,56,.18)}
.sms-template-preview-card .sms-template-meta{display:flex;flex-direction:column;gap:3px}.sms-template-preview-card .sms-template-meta strong{font-size:13px;line-height:1.2}.sms-template-preview-card .sms-template-meta small{font-size:11px;line-height:1.3;color:#667085}
.sms-template-preview-card .sms-template-tags{display:flex;gap:6px;flex-wrap:wrap}.sms-template-preview-card .sms-template-tags em{font-style:normal;font-size:10px;font-weight:800;padding:4px 7px;border-radius:999px;background:#eef7f1;color:#0d5d3b}
.sms-template-preview-card .sms-template-check{position:absolute;top:10px;right:10px;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#0c6b43;color:#fff;font-size:12px;font-weight:900;opacity:0;transform:scale(.8);transition:.18s ease}.sms-template-preview-card.is-selected .sms-template-check{opacity:1;transform:scale(1)}
.sms-preview-accent-maroon .sms-preview-topbar{background:linear-gradient(90deg,#450a0a,#991b1b)!important}.sms-preview-accent-maroon{border-color:#991b1b!important}.sms-preview-accent-maroon .sms-preview-watermark{color:rgba(153,27,27,.18)!important}
.sms-preview-accent-saffron .sms-preview-topbar{background:linear-gradient(90deg,#f88412,#fb923c)!important}.sms-preview-accent-saffron{border-color:#fb923c!important}.sms-preview-accent-saffron .sms-preview-watermark{color:rgba(248,132,18,.22)!important}
@media(max-width:1400px){.sms-preview-template-grid{grid-template-columns:repeat(3,minmax(170px,1fr))}}
@media(max-width:900px){.sms-preview-template-grid{grid-template-columns:repeat(2,minmax(160px,1fr))}.sms-preview-template-head{align-items:flex-start;flex-direction:column}.sms-preview-template-head span{text-align:left}}
@media(max-width:560px){.sms-preview-template-grid{grid-template-columns:1fr}}


/* v2.5.2 Document Preview Center - visible admin document color controls */
.sms-document-brand-admin-card{border-top:4px solid var(--sms-admin-primary,#0ea574)!important;background:linear-gradient(180deg,#fff,#f8fafc)!important}
.sms-document-brand-admin-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.sms-document-brand-admin-head h2{margin:0 0 6px!important;color:#0f172a!important}.sms-document-brand-admin-head p{margin:0;color:#64748b;max-width:850px}.sms-brand-live-chip{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;border-radius:999px;padding:9px 13px;font-weight:900;color:#fff;background:linear-gradient(135deg,var(--sms-doc-primary,#0ea574),var(--sms-doc-secondary,#0b7a58));box-shadow:0 12px 28px rgba(15,23,42,.14)}
.sms-document-brand-admin-form{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr)) minmax(260px,1.2fr) auto;gap:14px;align-items:end}.sms-document-brand-admin-form label{display:block;margin-bottom:7px;font-weight:800;color:#16251d}.sms-document-brand-admin-form input[type=color]{min-height:44px;padding:4px;border-radius:12px;background:#fff}.sms-document-brand-checks{display:grid;gap:8px;align-self:center}.sms-document-brand-checks label{margin:0!important;font-weight:700;color:#334155}.sms-document-brand-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}@media(max-width:1100px){.sms-document-brand-admin-form{grid-template-columns:repeat(2,minmax(180px,1fr))}.sms-document-brand-actions{grid-column:1/-1}}@media(max-width:700px){.sms-document-brand-admin-head{display:block}.sms-brand-live-chip{margin-top:12px}.sms-document-brand-admin-form{grid-template-columns:1fr}}

/* v2.5.3 Template-level color customization */
.sms-template-color-customizer{margin:18px 0 8px;padding:18px;border-radius:22px;border:1px solid rgba(15,23,42,.08);background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(248,250,252,.96));box-shadow:0 16px 38px rgba(15,23,42,.06);display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.sms-template-color-info{display:flex;align-items:center;gap:12px;min-width:280px;flex:1}.sms-template-color-info strong{display:block;color:#0f172a;font-size:15px}.sms-template-color-info p{margin:3px 0 0;color:#64748b;font-size:12px;line-height:1.45}.sms-template-color-chip{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--sms-template-primary,#0ea574),var(--sms-template-secondary,#0b7a58));box-shadow:0 12px 24px rgba(15,23,42,.15);border:1px solid rgba(255,255,255,.7)}
.sms-template-color-form{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.sms-template-color-form label{display:flex;flex-direction:column;gap:6px;color:#334155;font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:900}.sms-template-color-form input[type="color"]{width:74px;height:43px;padding:3px;border-radius:13px;border:1px solid #dbe5ef;background:#fff;cursor:pointer}.sms-template-color-form .sms-btn{min-height:42px;align-self:flex-end}
.sms-preview-art{--sms-template-primary:#0ea574;--sms-template-secondary:#0b7a58}.sms-preview-art .sms-preview-topbar{background:linear-gradient(135deg,var(--sms-template-primary),var(--sms-template-secondary))!important}.sms-preview-art .sms-preview-footer-line{background:linear-gradient(135deg,color-mix(in srgb,var(--sms-template-primary) 10%,#f8fafc),color-mix(in srgb,var(--sms-template-secondary) 12%,#f8fafc))!important}.sms-preview-art .sms-preview-watermark{color:color-mix(in srgb,var(--sms-template-primary) 22%,transparent)!important}.sms-preview-art .sms-preview-table{border-color:color-mix(in srgb,var(--sms-template-primary) 30%,#cbd5e1)!important}.sms-template-preview-card.is-selected{border-color:var(--sms-template-primary,#0ea574)!important;box-shadow:0 20px 50px color-mix(in srgb,var(--sms-template-primary,#0ea574) 18%,transparent)!important}.sms-template-preview-card.is-selected .sms-template-check{background:var(--sms-template-primary,#0ea574)!important}
@media(max-width:782px){.sms-template-color-customizer{align-items:stretch}.sms-template-color-form{width:100%}.sms-template-color-form label{flex:1}.sms-template-color-form input[type="color"]{width:100%}.sms-template-color-form .sms-btn{width:100%;justify-content:center}}

/* v2.9.3 Routine & Homework */
.sms-rh-wrap .sms-rh-hero{display:flex;justify-content:space-between;gap:18px;align-items:center;background:linear-gradient(135deg,rgba(15,118,110,.12),rgba(37,99,235,.10));border:1px solid rgba(15,118,110,.18)}
.sms-rh-wrap .sms-rh-hero h2{margin:0 0 5px;font-size:24px;color:#0f3d34}.sms-rh-wrap .sms-rh-hero p{margin:0;color:#64748b}.sms-rh-actions{display:flex;gap:10px;flex-wrap:wrap}.sms-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin:18px 0}.sms-color-inline{display:flex;align-items:center;gap:10px;font-weight:700;color:#334155}.sms-color-inline input[type=color]{width:70px;height:42px;border:1px solid #dbe3ef;border-radius:10px;background:#fff;padding:3px}@media(max-width:960px){.sms-grid-2{grid-template-columns:1fr}.sms-rh-wrap .sms-rh-hero{align-items:flex-start;flex-direction:column}}

/* v3.1.2 Premium Settings UI */
.sms-settings-premium{max-width:1440px;}
.sms-settings-premium .sms-settings-hero{position:relative;overflow:hidden;display:flex;justify-content:space-between;gap:24px;align-items:center;margin:18px 0 18px;padding:28px;border-radius:28px;background:linear-gradient(135deg,var(--sms-admin-primary,#0f766e),var(--sms-admin-secondary,#1d4ed8));color:#fff;box-shadow:0 28px 70px rgba(15,23,42,.18)}
.sms-settings-premium .sms-settings-hero:before{content:"";position:absolute;inset:-60px -80px auto auto;width:280px;height:280px;border-radius:999px;background:rgba(255,255,255,.16);filter:blur(2px)}
.sms-settings-premium .sms-settings-hero:after{content:"";position:absolute;left:-70px;bottom:-110px;width:280px;height:280px;border-radius:999px;background:rgba(255,255,255,.10)}
.sms-settings-premium .sms-settings-hero>*{position:relative;z-index:1}.sms-settings-kicker{display:inline-flex;margin-bottom:10px;padding:7px 11px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#fff}.sms-settings-premium .sms-settings-hero h1{margin:0!important;padding:0!important;color:#fff!important;font-size:32px;font-weight:950;letter-spacing:-.04em}.sms-settings-premium .sms-settings-hero p{max-width:780px;margin:8px 0 0;color:rgba(255,255,255,.82);font-size:15px}.sms-settings-hero-card{min-width:250px;padding:18px;border-radius:22px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.24);box-shadow:inset 0 1px 0 rgba(255,255,255,.18);backdrop-filter:blur(10px)}.sms-settings-hero-card strong{display:block;font-size:16px;color:#fff;line-height:1.25}.sms-settings-hero-card span{display:inline-flex;margin-top:8px;font-weight:800;color:rgba(255,255,255,.78)}
.sms-settings-premium .sms-card>form{display:block}.sms-settings-toolbar{position:sticky;top:32px;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:18px;margin:-4px 0 14px;padding:14px 16px;border-radius:20px;background:rgba(255,255,255,.88);border:1px solid rgba(15,23,42,.08);box-shadow:0 16px 40px rgba(15,23,42,.08);backdrop-filter:blur(14px)}.sms-settings-toolbar strong{display:block;color:#0f172a;font-size:14px;font-weight:950}.sms-settings-toolbar span{display:block;margin-top:2px;color:#64748b;font-size:12px}.sms-settings-save-top{border-radius:999px!important;padding:6px 18px!important;min-height:40px!important;font-weight:900!important;background:linear-gradient(135deg,var(--sms-admin-primary,#0f766e),var(--sms-admin-secondary,#1d4ed8))!important;border:0!important;box-shadow:0 12px 28px rgba(15,23,42,.16)!important}
.sms-settings-tabs{position:sticky;top:104px;z-index:19;display:flex;gap:10px;overflow-x:auto;margin:0 0 18px;padding:10px;border-radius:22px;background:#f8fafc;border:1px solid #e2e8f0;box-shadow:0 12px 30px rgba(15,23,42,.05)}.sms-settings-tabs::-webkit-scrollbar{height:7px}.sms-settings-tabs::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}.sms-settings-tab{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;text-decoration:none;padding:10px 13px;border-radius:16px;background:#fff;border:1px solid #e2e8f0;color:#334155;box-shadow:0 8px 18px rgba(15,23,42,.04);transition:.18s ease}.sms-settings-tab span{font-size:15px}.sms-settings-tab b{font-size:12px;font-weight:950}.sms-settings-tab:hover,.sms-settings-tab.is-active{color:#fff;background:linear-gradient(135deg,var(--sms-admin-primary,#0f766e),var(--sms-admin-secondary,#1d4ed8));border-color:transparent;transform:translateY(-1px);box-shadow:0 14px 30px rgba(15,23,42,.14)}
.sms-settings-section{scroll-margin-top:178px;position:relative;margin:18px 0;padding:22px;border-radius:26px;background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid rgba(15,23,42,.08);box-shadow:0 18px 44px rgba(15,23,42,.07)}.sms-settings-section>h2{display:flex!important;align-items:center;gap:10px;margin:0 0 18px!important;padding:0 0 14px!important;border-bottom:1px solid rgba(15,23,42,.08)!important;color:#0f172a!important;font-size:21px!important;font-weight:950!important;letter-spacing:-.02em}.sms-settings-section>h2:before{content:"";width:12px;height:28px;border-radius:99px;background:linear-gradient(180deg,var(--sms-admin-primary,#0f766e),var(--sms-admin-secondary,#1d4ed8));box-shadow:0 10px 22px rgba(15,23,42,.15)}.sms-settings-section>hr{display:none!important}.sms-settings-section .sms-form-grid{gap:16px}.sms-settings-section .sms-form-grid>div,.sms-settings-section .sms-gateway-panel,.sms-settings-section .sms-card{transition:.18s ease}.sms-settings-section .sms-form-grid>div:hover{transform:translateY(-1px)}.sms-settings-premium label{font-weight:850!important;color:#182436}.sms-settings-premium .sms-input,.sms-settings-premium input[type=text],.sms-settings-premium input[type=url],.sms-settings-premium input[type=email],.sms-settings-premium input[type=password],.sms-settings-premium input[type=number],.sms-settings-premium select,.sms-settings-premium textarea{border-radius:14px!important;border-color:#dbe4ef!important;background:#fff!important;box-shadow:0 6px 18px rgba(15,23,42,.035)!important;min-height:42px}.sms-settings-premium .sms-input:focus,.sms-settings-premium input:focus,.sms-settings-premium select:focus,.sms-settings-premium textarea:focus{border-color:var(--sms-admin-primary,#0f766e)!important;box-shadow:0 0 0 3px color-mix(in srgb,var(--sms-admin-primary,#0f766e) 16%,transparent),0 8px 22px rgba(15,23,42,.05)!important;outline:none!important}.sms-settings-premium input[type=color]{width:100%;height:46px;padding:4px!important;border-radius:14px!important;cursor:pointer}.sms-settings-premium .description{color:#64748b!important;line-height:1.55}.sms-settings-premium .sms-gateway-panel{margin-top:16px;padding:18px;border-radius:22px;background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid rgba(15,23,42,.08);box-shadow:0 12px 28px rgba(15,23,42,.05)}.sms-settings-premium .sms-gateway-panel-head h3{margin-top:0;color:#0f172a;font-size:18px;font-weight:950}.sms-settings-premium .button:not(.sms-settings-save-top),.sms-settings-premium .sms-btn{border-radius:999px!important;font-weight:850!important}
@media(max-width:960px){.sms-settings-premium .sms-settings-hero{align-items:flex-start;flex-direction:column}.sms-settings-hero-card{min-width:0;width:100%;box-sizing:border-box}.sms-settings-toolbar{top:0;align-items:flex-start;flex-direction:column}.sms-settings-save-top{width:100%;justify-content:center}.sms-settings-tabs{top:118px}.sms-settings-section{padding:18px;scroll-margin-top:210px}.sms-settings-premium .sms-settings-hero h1{font-size:26px}}
@media(max-width:640px){.sms-settings-premium{margin-left:0}.sms-settings-premium .sms-settings-hero{padding:22px;border-radius:22px}.sms-settings-section{border-radius:22px;padding:16px}.sms-settings-tabs{top:142px}.sms-settings-tab{padding:9px 11px}.sms-settings-section>h2{font-size:18px!important}}


/* v3.2.1 fixed product-name field */
.sms-settings-premium input[readonly] {
  background:#f8fafc;
  color:#475569;
  cursor:not-allowed;
}


/* v3.4.0 camera/photo UI */
.sms-photo-capture-box{display:grid;grid-template-columns:96px 1fr;gap:14px;align-items:center;padding:14px;border:1px solid #dbe4ef;border-radius:18px;background:linear-gradient(180deg,#fff,#f8fafc)}
.sms-photo-preview{width:86px;height:86px;border-radius:18px;background:#eef2f7;border:1px dashed #cbd5e1;display:flex;align-items:center;justify-content:center;overflow:hidden;color:#64748b;font-weight:800;font-size:12px;text-align:center}
.sms-photo-preview img{width:100%;height:100%;object-fit:cover;display:block}.sms-photo-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.sms-camera-video{grid-column:1/-1;width:100%;max-width:460px;border-radius:18px;background:#0f172a;box-shadow:0 16px 34px rgba(15,23,42,.16)}
@media(max-width:640px){.sms-photo-capture-box{grid-template-columns:1fr}.sms-photo-preview{width:112px;height:112px}.sms-photo-actions .sms-btn,.sms-photo-actions .sms-input{width:100%;box-sizing:border-box}.sms-camera-video{max-width:100%}}
