@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";
:root{--background:#f6f8fb;--foreground:#0f172a;--primary:#2563eb;--primary-hover:#1d4ed8;--secondary:#0f766e;--accent:#7c3aed;--surface:#fffffff0;--surface-border:#e2e8f0;--glass:#f8fafcdb;--success:#059669;--warning:#d97706;--danger:#dc2626;--sidebar-width:240px;--header-height:76px}*{box-sizing:border-box;margin:0;padding:0}html,body{max-width:100%;overflow-x:hidden}body{background-color:var(--background);color:var(--foreground);background-image:linear-gradient(135deg,#f8fafc 0%,#eef2ff 46%,#f0fdfa 100%);background-attachment:fixed;min-height:100vh;font-family:Inter,sans-serif}a{color:inherit;text-decoration:none;transition:color .2s}a:hover{color:var(--primary)}.glass-panel{background:var(--surface);border:1px solid var(--surface-border);border-radius:8px;padding:24px;transition:border-color .18s,box-shadow .18s,transform .18s;box-shadow:0 12px 32px #0f172a0f}.glass-panel:hover{border-color:#2563eb2e;box-shadow:0 16px 38px #0f172a14}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;min-height:42px;padding:10px 24px;font-size:.95rem;font-weight:500;transition:background-color .18s,border-color .18s,color .18s,box-shadow .18s,transform .18s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;box-shadow:0 10px 24px #2563eb3d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 26px #2563eb47;color:#fff!important}.modal-backdrop{z-index:3000;background:#0f172a85;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.modal-card{border:1px solid var(--surface-border);background:#fff;border-radius:14px;width:min(100%,760px);max-height:calc(100vh - 36px);padding:22px;overflow:auto;box-shadow:0 24px 70px #0f172a40}.btn-secondary{color:var(--foreground);border:1px solid var(--surface-border);background:0 0}.btn-secondary:hover{background:var(--glass);border-color:#2563eb38;color:var(--foreground)!important}.was-validated .input-field:required:invalid,.was-validated input:required:invalid,.was-validated select:required:invalid,.was-validated textarea:required:invalid,.input-field[aria-invalid=true]{background:#fff7f7;box-shadow:0 0 0 3px #ef444429;border-color:#ef4444!important}.save-result-backdrop{z-index:1800;pointer-events:none;width:min(440px,100vw - 32px);position:fixed;bottom:18px;right:18px}.save-result-dialog{width:100%;box-shadow:var(--shadow-xl);color:#0f172a;pointer-events:auto;background:#fff;border:1px solid #dbe4f0;border-radius:14px;gap:16px;padding:22px;display:grid}.save-result-dialog h3{margin:0 0 6px;font-size:1.2rem}.save-result-dialog p{color:#475569;overflow-wrap:anywhere;margin:0}.save-result-icon{border-radius:999px;place-items:center;width:44px;height:44px;font-weight:900;display:grid}.save-result-icon.error{color:#b91c1c;background:#fee2e2}.save-result-icon.success{color:#166534;background:#dcfce7}.save-result-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.directory-actions-row td{background:#f8fafc;border-top:0;padding:14px 24px 18px}.directory-action-strip{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.directory-action-strip>*{flex:none}.directory-action-left,.directory-action-right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.directory-action-right{justify-content:flex-end;margin-left:auto}.directory-action-strip .btn{min-width:120px}.input-field{width:100%;color:var(--foreground);background:#fff;border:1px solid #0000001a;border-radius:8px;padding:12px 16px;font-family:inherit;font-size:.95rem;transition:border-color .18s,box-shadow .18s,background-color .18s;box-shadow:0 1px 2px #0000000d}.input-field:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f126}select.input-field{cursor:pointer;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}.input-field,.input-field option{color:var(--foreground);background-color:#fff}h1{margin-bottom:1rem;font-size:2.5rem;font-weight:700}h2{margin-bottom:1rem;font-size:2rem;font-weight:600}h3{margin-bottom:.75rem;font-size:1.5rem;font-weight:600}.gradient-text{background:linear-gradient(to right, var(--primary), var(--secondary));color:#0000;-webkit-background-clip:text}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s forwards fadeIn}.grid-cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.dashboard-layout{width:100%;min-height:100dvh;display:flex}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--surface-border);z-index:30;background:#fffffff5;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-brand{border-bottom:1px solid var(--surface-border);margin-bottom:8px;padding:20px 18px}.brand-row{align-items:center;gap:12px;min-width:0;display:flex}.brand-logo{object-fit:contain;background:#fff;border-radius:8px;flex:0 0 44px;width:44px;height:44px}.brand-logo-fallback{background:var(--primary);color:#fff;justify-content:center;align-items:center;font-size:1.15rem;font-weight:800;display:flex}.brand-copy{min-width:0}.brand-name{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;font-size:1.05rem;font-weight:700;overflow:hidden}.brand-portal{color:#64748b;font-size:.8rem}.brand-school-id{color:#2563eb;letter-spacing:0;background:#2563eb1a;border-radius:999px;align-items:center;width:fit-content;max-width:100%;margin-top:6px;padding:3px 8px;font-size:.68rem;font-weight:800;display:inline-flex}.dashboard-nav{flex-direction:column;flex:1;gap:2px;padding:4px 8px 12px;display:flex;overflow:hidden auto}.dashboard-nav-shell{flex-direction:column;flex:1;min-height:0;display:flex}.sidebar-logout{border-top:1px solid var(--surface-border);background:#fffffffa;flex:none;padding:12px 14px 16px}.sidebar-logout .logout-button,.sidebar-logout button{justify-content:center;width:100%}.mobile-menu-toggle{border:1px solid var(--surface-border);color:#0f172a;width:calc(100% - 32px);font:inherit;cursor:pointer;background:#fff;border-radius:8px;margin:0 16px 12px;padding:10px 12px;font-weight:700;display:none}.main-content{margin-left:var(--sidebar-width);width:calc(100vw - var(--sidebar-width));max-width:calc(100vw - var(--sidebar-width));flex-direction:column;flex:1;min-width:0;display:flex;overflow-x:hidden}.top-header{min-height:var(--header-height);border-bottom:1px solid var(--surface-border);z-index:20;background:#fffffffa;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;min-width:0;padding:0 28px;display:flex;position:sticky;top:0}.top-header-brand{min-width:220px;display:none}.top-header-left,.top-header-right{align-items:center;gap:16px;min-width:0;display:flex}.top-header-left{flex:420px}.top-header-right{flex:0 auto;justify-content:flex-end;gap:18px}.top-header-title{color:#0f172a;white-space:nowrap;margin:0;font-size:1.2rem}.top-search{flex:320px;min-width:220px;max-width:520px}.academic-year-pill{border:1px solid var(--surface-border);background:#fff;border-radius:999px;align-items:center;gap:10px;min-width:0;padding:6px 14px;display:flex}.academic-year-pill span{color:#64748b;white-space:nowrap;font-size:.86rem}.user-chip{align-items:center;gap:12px;min-width:0;display:flex}.user-avatar{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:50%;flex:0 0 36px;justify-content:center;align-items:center;width:36px;height:36px;font-size:.88rem;font-weight:800;display:flex}.user-copy{min-width:0}.user-role{font-size:.9rem;font-weight:600}.user-school{color:#64748b;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.content-area{flex:1;min-width:0;padding:28px;overflow-x:hidden}.layout-mode-switch{border:1px solid var(--surface-border);background:#f8fafc;border-radius:8px;align-items:center;gap:2px;padding:4px;display:inline-flex}.layout-mode-switch button{color:#64748b;cursor:pointer;min-height:32px;font:inherit;background:0 0;border:0;border-radius:6px;padding:0 12px;font-size:.82rem;font-weight:800}.layout-mode-switch button.active{background:var(--primary);color:#fff}.top-header-controls{align-items:center;gap:10px;display:inline-flex}.top-header-logout{display:none}.dashboard-layout.top-nav-mode .top-header-logout{display:block}.header-mobile-menu-button{color:#0f172a;cursor:pointer;background:#fff;border:1px solid #dbe4f0;border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.35rem;font-weight:800;display:none}.calculator-workspace{grid-template-columns:minmax(280px,420px) minmax(260px,1fr);align-items:start;gap:18px;display:grid}.top-header-logout .logout-button,.top-header-logout button{min-height:40px;padding-inline:16px}.top-dashboard-bar{display:none}.dashboard-layout.top-nav-mode{display:block}.dashboard-layout.top-nav-mode .sidebar{display:none}.dashboard-layout.top-nav-mode .main-content{width:100%;max-width:100%;margin-left:0}.dashboard-layout.top-nav-mode .top-dashboard-bar{top:var(--header-height);z-index:19;border-bottom:1px solid var(--surface-border);background:#fffffffa;justify-content:center;align-items:flex-start;gap:14px;padding:10px 28px;display:flex;position:sticky}.dashboard-layout.top-nav-mode .top-header-brand{display:block}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav-shell{width:min(1280px,100%);min-width:0}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav{flex-flow:wrap;justify-content:center;align-items:center;gap:6px;padding:0;display:flex;overflow:visible}.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-link{white-space:nowrap;min-height:38px;box-shadow:none}.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-link.active{box-shadow:inset 0 -3px 0 var(--primary)}.top-dashboard-brand{display:none}.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-group{align-items:center;gap:6px;display:inline-flex;position:relative}.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-group-children{z-index:40;border:1px solid var(--surface-border);min-width:230px;max-width:min(360px,92vw);max-height:min(70vh,520px);box-shadow:var(--shadow-xl);background:#fff;border-radius:8px;padding:8px;display:none;position:absolute;top:100%;left:50%;overflow:auto;transform:translate(-50%)}.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-group:hover .nav-group-children{display:grid}.top-dashboard-logout{width:130px}.dashboard-notice-strip{gap:10px;margin-bottom:20px;display:grid}.dashboard-notice-item{color:#1e3a8a;background:#eff6ff;border:1px solid #2563eb33;border-radius:8px;gap:4px;padding:12px 14px;display:grid}.dashboard-notice-item.urgent{color:#991b1b;background:#fff1f2;border-color:#dc262640}.dashboard-notice-item span{color:inherit;font-size:.9rem;line-height:1.45}.nav-link{color:#64748b;overflow-wrap:anywhere;border-radius:8px;align-items:center;min-width:0;min-height:40px;padding:9px 12px;font-size:.95rem;font-weight:600;line-height:1.25;transition:background-color .18s,color .18s;display:flex}.nav-link:hover{background:var(--glass);color:var(--foreground)}.nav-link.active{color:var(--primary);box-shadow:inset 3px 0 0 var(--primary);background:#2563eb1a}.nav-link.active:hover,.nav-group-heading.active,.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-link.active,.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-link.active:hover{color:#1d4ed8!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-link,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-heading{color:#475569}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-link.active,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-heading.active{background:#e8f0ff;color:#1d4ed8!important}.portal-detail-stack{grid-template-columns:1fr;gap:24px;display:grid}.nav-group{gap:6px;display:grid}.nav-group-heading{cursor:pointer;width:100%;font:inherit;text-align:left;background:0 0;border:0;justify-content:space-between;font-weight:850}.nav-group-heading span:first-child{font-weight:850}.nav-group-children{gap:4px;padding-left:12px;display:none}.nav-group.expanded>.nav-group-children{display:grid}.nav-sub-link{min-height:34px;padding:7px 10px;font-size:.88rem}.staff-config-option-row,.staff-config-edit-form{align-items:center;gap:8px;display:flex}.staff-config-edit-form{flex:1;min-width:0}.staff-config-edit-form .input-field{min-width:0}.admission-package-row{background:#f8fafcb8;border:1px solid #94a3b838;border-radius:8px;grid-template-columns:minmax(240px,1fr) minmax(160px,.38fr);align-items:start;gap:14px;padding:14px;display:grid}.admission-package-meta,.admission-package-terms,.admission-package-books{color:#64748b;flex-wrap:wrap;gap:6px;margin-top:8px;font-size:.82rem;display:flex}.admission-package-meta span,.admission-package-terms span,.admission-package-books span{background:#fff;border:1px solid #94a3b833;border-radius:999px;padding:4px 8px}.global-search{flex:1;min-width:0;position:relative}.global-search-desktop{display:block}.mobile-search-trigger{border:1px solid var(--surface-border);color:#0f172a;cursor:pointer;background:#fff;border-radius:8px;width:40px;height:40px;font-size:1.25rem;font-weight:800;display:none}.mobile-search-modal{z-index:80;background:#0f172a6b;justify-content:center;align-items:flex-start;padding:82px 16px 16px;display:flex;position:fixed;inset:0}.mobile-search-panel{border:1px solid var(--surface-border);width:min(560px,100%);box-shadow:var(--shadow-xl);background:#fff;border-radius:8px;padding:16px;position:relative}.mobile-search-panel-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.global-search-form{border:1px solid var(--surface-border);background:#fff;border-radius:999px;align-items:center;width:100%;min-width:0;padding:4px 12px;display:flex;box-shadow:inset 0 1px 3px #0f172a08}.global-search-icon{color:#64748b;margin-right:8px;font-size:1rem}.global-search-form input{min-width:0;color:var(--foreground);background:0 0;border:0;outline:0;flex:1;padding:7px 0;font-family:inherit;font-size:.92rem}.global-search-submit{background:var(--primary);color:#fff;font:inherit;cursor:pointer;border:0;border-radius:999px;padding:5px 12px;font-size:.78rem;font-weight:700}.global-search-results{z-index:60;border:1px solid var(--surface-border);background:#fff;border-radius:8px;gap:4px;max-height:340px;padding:8px;display:grid;position:absolute;top:calc(100% + 8px);left:0;right:0;overflow:auto;box-shadow:0 20px 50px #0f172a24}.global-search-result{color:#0f172a;text-align:left;width:100%;font:inherit;cursor:pointer;background:0 0;border:0;border-radius:8px;gap:3px;padding:10px 12px;display:grid}.global-search-result:hover{background:#f8fafc}.global-search-result span{font-weight:700}.global-search-result small,.global-search-empty{color:#64748b;font-size:.82rem}.global-search-empty{padding:12px}.record-controls{min-width:0}.record-action-row,.record-status-form,.record-delete-form{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.compact-input{width:auto;min-width:112px;min-height:34px;padding:5px 8px;font-size:.84rem}.icon-btn{border:1px solid var(--surface-border);color:#334155;width:auto;min-width:34px;height:34px;font:inherit;cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;padding:0 12px;font-size:1rem;font-weight:800;line-height:1;transition:background-color .18s,border-color .18s,color .18s,box-shadow .18s;display:inline-flex}.icon-btn:hover{box-shadow:0 8px 18px #0f172a14}.icon-btn.edit{color:#fff;background:#2563eb;border-color:#2563eb}.icon-btn.status{color:#fff;background:#059669;border-color:#059669}.icon-btn.delete{color:#fff;background:#dc2626;border-color:#dc2626}.icon-btn.neutral{color:#475569}.data-table{border-collapse:collapse;width:100%;min-width:980px}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--surface-border);padding:16px}.data-table th{color:#64748b;text-transform:uppercase;letter-spacing:0;background:#f8fafc;font-size:.78rem;font-weight:600}.data-table tr:hover td{background:var(--glass)}.badge{border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:600}.badge.active{color:var(--success);background:#10b98133}.badge.inactive{color:var(--danger);background:#ef444433}.dashboard-page{gap:22px;min-width:0;display:grid}.page-hero{border:1px solid var(--surface-border);background:linear-gradient(135deg,#fff 0%,#f8fafc 58%,#eef6ff 100%);border-radius:8px;justify-content:space-between;align-items:flex-end;gap:20px;padding:24px;display:flex;box-shadow:0 16px 42px #0f172a0f}.page-kicker{color:var(--secondary);text-transform:uppercase;letter-spacing:0;align-items:center;gap:8px;margin-bottom:10px;font-size:.78rem;font-weight:700;display:inline-flex}.page-title{letter-spacing:0;margin:0;font-size:clamp(1.8rem,2.2vw,2.35rem);line-height:1.1}.page-subtitle{color:#64748b;margin-top:8px;font-size:.98rem}.page-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.metric-card{border:1px solid var(--surface-border);background:#fffffff0;border-radius:8px;gap:6px;padding:16px;display:grid;box-shadow:0 12px 30px #0f172a0d}.metric-label{color:#64748b;text-transform:uppercase;letter-spacing:0;font-size:.78rem;font-weight:700}.metric-value{color:#0f172a;font-size:1.65rem;font-weight:750;line-height:1}.table-shell{padding:0;overflow:hidden}.table-toolbar{border-bottom:1px solid var(--surface-border);background:#ffffffb8;justify-content:space-between;align-items:center;gap:16px;padding:18px 20px;display:flex}.table-title{margin:0;font-size:1.05rem;font-weight:700}.table-note{color:#64748b;font-size:.86rem}.table-scroll{width:100%;overflow-x:auto}.student-filter-bar{border-bottom:1px solid var(--surface-border);background:#f8fafcc7;grid-template-columns:minmax(260px,1fr) minmax(150px,190px) minmax(140px,180px) minmax(130px,170px) auto auto;gap:10px;padding:18px 20px;display:grid}.student-filter-bar .btn{min-height:46px}.student-name-cell{gap:3px;font-weight:700;display:grid}.muted-text{color:#64748b;font-size:.82rem;font-weight:500}.details-panel{border:1px solid var(--surface-border);color:#475569;background:#f8fafc;border-radius:8px;grid-template-columns:repeat(2,minmax(150px,1fr));gap:10px;min-width:360px;max-width:520px;margin-top:12px;padding:12px;font-size:.82rem;display:grid}.details-panel span{overflow-wrap:anywhere;min-width:0}.student-detail-disclosure{position:relative}.student-detail-disclosure>summary{list-style:none}.student-detail-disclosure>summary::-webkit-details-marker{display:none}.student-detail-disclosure[open]>summary{z-index:100;background:#fff;position:fixed;top:calc(8vh + 14px);right:36px;box-shadow:0 14px 34px #0f172a2e}.student-action-stack{flex-direction:column;align-items:stretch;gap:8px;width:148px;display:flex}.student-class-pill{color:#2563eb;text-align:center;white-space:normal;overflow-wrap:anywhere;background:#2563eb1f;border-radius:8px;justify-content:center;align-items:center;min-width:82px;max-width:130px;min-height:32px;padding:6px 10px;font-size:.82rem;font-weight:800;line-height:1.2;display:inline-flex}.student-detail-trigger{color:#fff;cursor:pointer;background:#0f172a;border:1px solid #0f172a;border-radius:8px;justify-content:center;align-items:center;width:auto;min-width:132px;min-height:38px;padding:0 12px;font-weight:800;line-height:1;display:inline-flex;box-shadow:0 10px 24px #0f172a1f}.student-detail-trigger:hover{color:#fff;background:#2563eb;border-color:#2563eb;box-shadow:0 8px 18px #0f172a14}.module-tabs{background:#f8fafc;border:1px solid #dbe4f0;border-radius:10px;flex-wrap:wrap;gap:8px;padding:6px;display:inline-flex}.module-tab{color:#334155;border-radius:8px;justify-content:center;align-items:center;min-height:38px;padding:0 14px;font-weight:800;text-decoration:none;display:inline-flex}.module-tab.active{color:#fff;background:#2563eb;box-shadow:0 10px 24px #2563eb33}.multi-picker{background:#fff;border:1px solid #dbe4f0;border-radius:8px;min-height:54px;position:relative}.multi-picker>summary{color:#0f172a;cursor:pointer;justify-content:space-between;align-items:center;gap:10px;min-height:54px;padding:0 14px;font-weight:700;display:flex}.multi-picker-menu{background:#fff;border-top:1px solid #e2e8f0;gap:6px;max-height:220px;padding:10px;display:grid;overflow:auto;box-shadow:0 16px 32px #0f172a14}.multi-picker-option{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;min-height:36px;padding:8px 10px;font-weight:700;display:flex}.workflow-panel{border:1px solid #dbeafe;box-shadow:0 18px 40px #2563eb14}.workflow-summary{cursor:pointer;color:#0f172a;font-size:1.15rem;font-weight:800}.workflow-help-row,.workflow-panel-head{color:#1e3a8a;background:#eff6ff;border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:14px;padding:12px 14px;display:flex}.workflow-count-pill{color:#1d4ed8;background:#fff;border:1px solid #bfdbfe;border-radius:999px;padding:8px 12px;font-weight:800}.form-sticky-actions{z-index:3;background:linear-gradient(#fff0,#fff 36%);padding:12px 0 0;position:sticky;bottom:0}.field-label{color:#475569;gap:6px;font-size:.86rem;font-weight:800;display:grid}.setup-tab-list{flex-wrap:wrap;gap:8px;display:flex}.setup-tab{color:#334155;cursor:pointer;background:#fff;border:1px solid #dbe4f0;border-radius:8px;min-height:38px;padding:0 12px;font-weight:800}.setup-tab.active{color:#fff;background:#2563eb;border-color:#2563eb}.timetable-entry-table .compact-input{min-width:130px}.timetable-cell-card{color:#0f172a;background:#6366f11f;border:1px solid #6366f138;border-radius:8px;gap:4px;margin-bottom:8px;padding:10px;display:grid}.timetable-cell-card span{color:#64748b;font-size:.8rem}.role-access-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;margin-top:16px;display:grid}.role-access-card{background:#f8fafc;border:1px solid #dbe4f0;border-radius:10px;gap:8px;padding:14px;display:grid}.role-access-card h4{color:#0f172a;margin:0}.role-access-card p{color:#475569;margin:0;line-height:1.45}.role-access-card div{flex-wrap:wrap;gap:6px;display:flex}.role-access-card span{color:#075985;background:#e0f2fe;border-radius:999px;padding:5px 8px;font-size:.78rem;font-weight:800}.student-detail-panel{z-index:80;border:1px solid var(--surface-border);background:#fff;border-radius:8px;grid-template-columns:repeat(3,minmax(180px,1fr));gap:12px;width:min(980px,100vw - 48px);max-height:84vh;padding:22px;display:grid;position:fixed;inset:8vh auto auto 50%;overflow:auto;transform:translate(-50%);box-shadow:0 24px 70px #0f172a47}.student-detail-disclosure[open]:before{content:"";z-index:70;background:#0f172a6b;position:fixed;inset:0}.student-detail-modal-header{border-bottom:1px solid var(--surface-border);grid-column:1/-1;justify-content:space-between;align-items:center;gap:16px;padding-bottom:12px;display:flex}.student-detail-modal-header h3{margin:0}.credential-detail-group{background:#f8fbff;border:1px solid #2563eb29;border-radius:8px;padding:12px}.detail-group{align-content:start;gap:8px;min-width:0;display:grid}.detail-group h4{color:#0f172a;margin:0 0 2px;font-size:.86rem}.detail-group span{color:#475569;overflow-wrap:anywhere;gap:2px;font-size:.78rem;display:grid}.detail-group strong{color:#64748b;text-transform:uppercase;font-size:.72rem}.profile-related-section{background:#f8fafc;border:1px solid #0f172a14;border-radius:8px;grid-column:1/-1;gap:10px;padding:12px;display:grid}.profile-related-section h4{color:#0f172a;margin:0;font-size:.9rem}.profile-related-list{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px;display:grid}.profile-related-card{border:1px solid var(--surface-border);background:#fff;border-radius:8px;gap:6px;padding:10px;display:grid}.profile-related-card span{color:#334155;overflow-wrap:anywhere;gap:2px;font-size:.78rem;display:grid}.profile-related-card strong{color:#64748b;text-transform:uppercase;font-size:.7rem}.empty-state{text-align:center;color:#64748b;padding:46px 20px}.dashboard-home{gap:24px;min-width:0;display:grid}.dashboard-home-hero{justify-content:space-between;align-items:flex-end;gap:18px;min-width:0;display:flex}.dashboard-home-hero h1{color:#0f172a;margin:0 0 8px;font-size:clamp(1.65rem,2vw,2.1rem);line-height:1.1}.dashboard-home-hero p{color:#64748b;margin:0}.dashboard-home-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.dashboard-stat-grid{grid-template-columns:repeat(4,minmax(180px,1fr))}.dashboard-insight-card{border:0;width:100%}.dashboard-insight-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.dashboard-modal-backdrop{z-index:80;background:#0f172a7a;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.dashboard-modal-panel{border:1px solid var(--surface-border);width:min(1100px,96vw);max-height:88vh;box-shadow:var(--shadow-xl);background:#fff;border-radius:12px;padding:22px;overflow:auto}.dashboard-home-grid{grid-template-columns:minmax(0,1fr) minmax(240px,330px);align-items:start;gap:24px;min-width:0;display:grid}.dashboard-home-grid>.glass-panel{min-width:0}.dashboard-table .data-table{min-width:620px}.quick-actions-card{overflow:hidden}.quick-actions-list{flex-direction:column;gap:12px;display:flex}.quick-actions-list .btn{white-space:normal;text-align:left;justify-content:flex-start;width:100%;min-width:0}.module-export-buttons{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.module-export-buttons .btn{min-height:38px;padding:8px 14px;font-size:.86rem}.date-report-controls{flex-wrap:wrap;justify-content:flex-end;align-items:flex-end;gap:10px;display:flex}.date-report-controls label{color:#64748b;gap:4px;font-size:.78rem;font-weight:700;display:grid}.date-report-controls .input-field{min-width:140px;min-height:38px;padding:8px 10px;font-size:.86rem}.finance-export-controls{flex-wrap:wrap;justify-content:flex-end;align-items:flex-end;gap:10px;display:flex}.finance-export-controls label{color:#64748b;gap:4px;font-size:.78rem;font-weight:700;display:grid}.finance-export-controls .input-field{width:150px;min-height:38px;padding:8px 10px;font-size:.86rem}.finance-export-controls .btn{min-height:38px;padding:8px 14px}.finance-report-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:24px;display:grid}.finance-report-stack{gap:24px;margin-bottom:24px;display:grid}.finance-table-card{min-width:0;overflow:hidden}.finance-table-card .data-table{min-width:720px}.calendar-panel{min-width:0;margin-bottom:22px}.calendar-panel-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;display:grid}.calendar-weekday{color:#64748b;text-align:center;text-transform:uppercase;font-size:.78rem;font-weight:800}.calendar-day{border:1px solid var(--surface-border);color:#0f172a;background:#fff;border-radius:8px;align-content:space-between;gap:8px;min-height:82px;padding:10px;font-weight:800;display:grid}.calendar-day:hover{color:#0f172a;background:#f8fbff;border-color:#2563eb5c}.calendar-day small{width:max-content;max-width:100%;color:var(--primary);background:#2563eb1a;border-radius:999px;padding:3px 7px;font-size:.7rem;font-weight:800}.calendar-day.has-data{background:#ecfdf5;border-color:#0596695c}.calendar-day.selected{border-color:var(--primary);box-shadow:inset 0 0 0 2px #2563eb47}.calendar-day.empty{box-shadow:none;background:0 0;border-color:#0000}.page-heading-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:32px;display:flex}.page-heading-row>div:first-child{min-width:min(100%,320px)}.segmented-control{border:1px solid var(--surface-border);background:#f8fafc;border-radius:8px;display:inline-flex;overflow:hidden}.segmented-control button{border:0;border-right:1px solid var(--surface-border);color:#475569;cursor:pointer;background:0 0;min-height:38px;padding:8px 14px;font-weight:700}.segmented-control button:last-child{border-right:0}.segmented-control button.active{background:var(--primary);color:#fff}.id-card-page{gap:24px;min-width:0;display:grid}.id-card-header{grid-template-columns:minmax(420px,max-content) minmax(0,1fr);align-items:start;gap:18px 36px;min-width:0;margin-bottom:32px;display:grid}.id-card-title-block{min-width:420px}.id-card-title-block h1{color:#0f172a;margin:0 0 8px;font-size:2rem;line-height:1.15}.id-card-title-block p{color:#64748b;margin:0;font-size:1.05rem}.id-card-toolbar{flex-wrap:nowrap;justify-content:flex-end;align-items:center;gap:8px;width:100%;min-width:0;display:flex}.id-card-toolbar>*{flex:none}.id-card-download-button{width:210px;min-width:0;padding-left:12px;padding-right:12px}.id-card-mode-toggle{width:150px}.id-card-mode-toggle button{width:75px;min-width:0;padding-left:8px;padding-right:8px}.id-card-filter{width:118px;min-height:42px;padding:10px 12px}.id-card-vertical-button{width:96px;min-width:0;box-shadow:none;padding-left:12px;padding-right:12px}.id-card-toolbar .id-card-action-strong{min-width:0;padding-left:12px;padding-right:12px}.id-card-toolbar .id-card-action-strong:not(.id-card-pdf-button){width:132px}.id-card-toolbar .id-card-pdf-button{width:112px}.id-cards-print-area{margin-top:4px}.id-card-item{justify-items:start;gap:12px;display:grid}.id-card-single-actions{grid-template-columns:1fr 1fr;gap:8px;width:286px;display:grid}.id-card-single-actions .btn{white-space:normal;min-height:38px;padding:8px 10px;font-size:.82rem}.id-card-actions .btn,.id-card-actions .segmented-control,.id-card-actions .input-field{flex:none}.id-card-pdf-button{color:#0f172a;background:#fff;border-color:#cbd5e1}.link-button{color:var(--primary);font:inherit;cursor:pointer;text-align:left;background:0 0;border:0;padding:0;font-weight:700}.front-office-form-grid,.front-office-list-grid{gap:24px;margin-bottom:24px;display:grid}.front-office-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.front-office-list-grid{grid-template-columns:minmax(0,1fr)}.front-office-panel{min-width:0}.front-office-panel summary{color:#0f172a;cursor:pointer;font-weight:700}.front-office-table-card{min-width:0;overflow:hidden}.front-office-table-card .data-table{min-width:760px}.communication-layout{gap:20px;display:grid}.communication-tabs{grid-template-columns:1fr 1fr;gap:8px;display:grid}.communication-tabs label{border:1px solid var(--surface-border);color:#0f172a;cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:48px;font-weight:700;display:flex}.communication-tabs input{accent-color:var(--primary)}.communication-list{min-width:0}.communication-list-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.communication-list-header h3,.chat-message h4{margin:0}.chat-feed{background:linear-gradient(135deg,#eff6ffb8,#f0fdf4a8),#f8fafc;border:1px solid #cbd5e1b8;border-radius:8px;align-content:start;gap:14px;min-height:430px;max-height:62vh;padding:18px;display:grid;overflow:auto}.chat-message{border:1px solid var(--surface-border);background:#fff;border-radius:8px;grid-template-columns:minmax(0,1fr);gap:16px;padding:12px 14px;display:grid;box-shadow:0 10px 24px #0f172a0f}.chat-message-group{gap:10px;display:grid}.chat-date-separator{color:#64748b;background:#ffffffdb;border-radius:999px;justify-self:center;padding:5px 12px;font-size:.76rem;font-weight:800;box-shadow:0 8px 18px #0f172a0f}.chat-message.unread{background:#f8fbff;border-color:#2563eb47}.chat-message.sent{background:#dcfce7;border-color:#05966938;width:min(680px,86%);margin-left:auto}.chat-message.received{width:min(680px,86%)}.chat-message-main{gap:8px;min-width:0;display:grid}.chat-message-top,.chat-actions,.chat-meta{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.chat-message-main p{color:#334155;margin:0;line-height:1.55}.chat-meta{color:#64748b;font-size:.82rem}.chat-actions{place-content:flex-start flex-end;max-width:260px}.certificate-modal{z-index:1000;background:#0f172ad1;flex-direction:column;align-items:center;width:100vw;height:100dvh;padding:24px 18px 64px;display:flex;position:fixed;inset:0;overflow:auto}.certificate-modal-actions{z-index:2;background:linear-gradient(#0f172aeb,#0f172a00);flex-wrap:wrap;justify-content:center;gap:12px;width:100%;padding:12px 0 18px;display:flex;position:sticky;top:0}.certificate-modal-actions .btn-secondary,.certificate-modal-actions .btn-primary{border-color:#ffffffb8;box-shadow:0 12px 30px #0f172a40}.certificate-modal-actions .btn-secondary{color:#0f172a;background:#fff}.certificate-sheet{color:#000;transform-origin:top;background:#fff;border:2px solid #cbd5e1;flex:none;width:min(900px,100%);min-height:1000px;margin:0 auto;padding:60px;position:relative;box-shadow:0 22px 70px #0000006b}.row-action-cluster{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.exam-import-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.exam-section-stack{grid-template-columns:1fr;gap:24px;margin-bottom:24px;display:grid}.exam-record-panel{min-width:0}.question-builder{gap:14px;display:grid}.question-builder-card{border:1px solid var(--border);background:#fff;border-radius:8px;gap:12px;padding:14px;display:grid}.question-card-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.question-option-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.school-chat-shell{grid-template-columns:minmax(320px,420px) minmax(0,1fr);align-items:stretch;gap:24px;min-height:720px;display:grid}.school-chat-sidebar,.school-chat-main{flex-direction:column;min-width:0;display:flex}.school-chat-main{min-height:720px}.school-chat-filter-grid{gap:10px;margin-bottom:14px;display:grid}.chat-tab{border:1px solid var(--border);color:#475569;border-radius:8px;justify-content:center;align-items:center;min-height:38px;padding:0 14px;font-weight:700;display:inline-flex}.chat-tab.active{border-color:var(--primary);color:var(--primary);background:#2563eb1a}.school-contact-list{gap:14px;max-height:590px;padding-top:14px;display:grid;overflow:auto}.school-contact-card{border:1px solid var(--border);background:#fff;border-radius:8px;grid-template-columns:44px minmax(0,1fr);align-items:center;gap:12px;padding:12px;display:grid}.school-contact-card.active{background:#eff6ff;border-color:#2563eb57}.contact-avatar{width:44px;height:44px;color:var(--primary);background:#2563eb1a;border-radius:999px;place-items:center;font-weight:800;display:grid}.school-chat-topbar{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.school-chat-topbar p{color:#64748b;margin-top:4px}.communication-search-box{gap:8px;margin-top:14px;display:grid}.chat-composer-box{resize:vertical;min-height:150px;font-size:1rem}.chat-empty-state{text-align:center;color:#64748b;place-items:center;min-height:260px;display:grid}.chat-empty-state strong{color:#0f172a}.invoice-builder-grid{grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr);align-items:start;gap:24px;display:grid}.invoice-builder-single{grid-template-columns:minmax(0,1fr)}.invoice-form-section,.invoice-address-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.invoice-address-grid label{color:#475569;gap:10px;font-weight:700;display:grid}.invoice-items-editor{gap:10px;display:grid}.invoice-items-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.invoice-item-row{grid-template-columns:minmax(220px,1fr) 90px 120px 120px;align-items:center;gap:10px;display:grid}.invoice-live-preview{top:calc(var(--header-height) + 18px);position:sticky}.invoice-preview-paper{border:1px solid var(--surface-border);background:#fff;border-radius:8px;gap:22px;min-width:820px;padding:34px;display:grid;position:relative;overflow:hidden;box-shadow:0 18px 42px #0f172a1f}.invoice-watermark{color:#0f172a14;letter-spacing:.08em;text-transform:uppercase;pointer-events:none;font-size:clamp(3rem,7vw,5.5rem);font-weight:900;position:absolute;inset:42% auto auto 50%;transform:translate(-50%,-50%)rotate(-18deg)}.invoice-preview-top{z-index:1;border-bottom:1px solid var(--surface-border);justify-content:space-between;gap:24px;padding-bottom:20px;display:flex;position:relative}.invoice-preview-top h3,.invoice-preview-top p,.invoice-preview-address p,.invoice-preview-notes{margin:0}.invoice-preview-address span{color:#64748b;text-transform:uppercase;margin-bottom:6px;font-size:.78rem;font-weight:800;display:block}.invoice-preview-label{color:#64748b;margin-top:8px;font-size:.85rem;font-weight:800;display:inline-flex}.invoice-preview-address-grid{z-index:1;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid;position:relative}.invoice-preview-address{border:1px solid var(--surface-border);background:#f8fafc;border-radius:8px;min-height:128px;padding:16px}.invoice-preview-table{border-collapse:collapse;width:100%}.invoice-preview-table th,.invoice-preview-table td{border-bottom:1px solid var(--surface-border);text-align:left;padding:9px 6px}.invoice-preview-totals{justify-self:end;gap:8px;min-width:240px;display:grid}.invoice-preview-totals span{justify-content:space-between;gap:18px;display:flex}.invoice-preview-grand{border-top:1px solid var(--surface-border);padding-top:10px;font-size:1.1rem}.invoice-preview-modal{z-index:120;background:#0f172a7a;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.invoice-preview-modal-inner{gap:12px;width:min(980px,100%);max-height:92vh;padding:12px;display:grid;overflow:auto}.invoice-modal-close{border:1px solid var(--surface-border);color:#0f172a;cursor:pointer;font:inherit;background:#fff;border-radius:8px;justify-self:end;min-height:42px;padding:0 18px;font-weight:800;box-shadow:0 12px 28px #0f172a29}.landing-events-panel,.landing-builder-panel{margin-bottom:24px}.landing-builder-panel h3{margin-bottom:18px}.landing-form-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.landing-media-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;display:grid}.landing-media-stack{grid-template-columns:minmax(0,1fr);gap:16px;display:grid}.landing-upload-card{color:#475569;background:#f8fbff;border:1px dashed #2563eb5c;border-radius:8px;align-content:center;gap:8px;min-height:92px;padding:16px;display:grid}.landing-upload-card strong{color:#0f172a}.landing-upload-card span{color:#64748b;font-size:.86rem}.landing-upload-tall{min-height:150px}.landing-check-row{color:#475569;align-items:center;gap:8px;display:flex}.landing-check-card{border:1px solid var(--surface-border);background:#f8fafc;border-radius:8px;min-height:90px;padding:18px;font-weight:700}.landing-color-field{border:1px solid var(--surface-border);color:#475569;background:#fff;border-radius:8px;gap:8px;min-height:64px;padding:10px 12px;font-weight:700;display:grid}.landing-color-field input{background:0 0;border:0;width:100%;height:34px;padding:0}.landing-repeater-card{border:1px solid var(--surface-border);background:#fff;border-radius:8px;gap:12px;min-width:0;padding:16px;display:grid}.landing-repeater-title,.landing-repeater-row,.landing-footer-link-row,.landing-feature-card-row,.landing-review-row{align-items:flex-start;gap:10px;display:flex}.landing-repeater-title{justify-content:space-between;align-items:center}.landing-repeater-list,.landing-footer-link-list{gap:10px;display:grid}.landing-repeater-row .input-field{min-height:62px}.landing-repeater-row .input-field,.landing-footer-link-row .input-field,.landing-feature-card-row .input-field,.landing-review-row textarea{flex:1}.landing-review-row select{flex:none;width:150px}.domain-setup-steps{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:16px;display:grid}.domain-setup-steps div{border:1px solid var(--surface-border);background:#fff;border-radius:8px;gap:6px;padding:14px;display:grid}.domain-setup-steps span{color:#64748b;font-size:.86rem;line-height:1.45}.public-login-modal{z-index:90;background:#0f172a94;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.public-login-card{background:#fff;border-radius:8px;gap:14px;width:min(420px,100%);padding:26px;display:grid;position:relative;box-shadow:0 24px 70px #0f172a52}.public-login-card h2,.public-login-card p{margin:0}.public-login-card p{color:#64748b}.public-login-close{width:auto;min-width:72px;height:38px;padding:0 14px;position:absolute;top:12px;right:12px}.public-login-form{gap:12px;display:grid}.public-login-error,.public-login-success{border-radius:8px;padding:10px 12px;font-size:.86rem}.public-login-error{color:var(--danger);background:#ef44441a}.public-login-success{color:var(--success);background:#10b9811a}.chat-composer-box{min-height:150px}.record-action-row{align-items:center}.record-action-row .icon-btn{min-width:64px;height:40px;padding:0 12px;font-size:.78rem;font-weight:700}.student-action-stack .record-action-row{gap:8px;width:100%;display:flex}.student-action-stack select.compact-input{width:auto;min-height:40px}.id-card-action-strong{font-weight:700;border:1px solid var(--success)!important;color:#047857!important;background:#fff!important}.id-card-action-strong:hover{background:#10b98114!important}.attendance-report-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;display:grid}.school-landing-public{color:#0f172a;--school-primary:#2563eb;--school-accent:#059669;background:#f8fafc;min-height:100vh}.school-public-hero{background:linear-gradient(135deg, #0f172a, var(--school-primary));color:#fff;background-position:50%;background-size:cover;flex-direction:column;min-height:78vh;display:flex}.school-landing-public .btn-primary{background:var(--school-primary)}.school-landing-public .btn-secondary{border-color:#fff6}.school-public-nav{justify-content:space-between;align-items:center;gap:18px;padding:22px clamp(18px,5vw,72px);display:flex}.school-public-brand{align-items:center;gap:12px;font-size:1.1rem;display:flex}.school-public-brand img,.school-public-brand span{object-fit:cover;color:#1d4ed8;background:#fff;border-radius:8px;place-items:center;width:48px;height:48px;font-weight:800;display:grid}.school-public-hero-copy{width:min(760px,100%);margin:auto 0;padding:40px clamp(18px,5vw,72px) 80px}.school-public-kicker{color:#fff;background:#ffffff1f;border:1px solid #ffffff52;border-radius:999px;margin-bottom:16px;padding:8px 12px;font-size:.86rem;font-weight:800;display:inline-flex}.school-public-hero-copy h1{margin-bottom:18px;font-size:clamp(2.4rem,7vw,5.6rem);line-height:1}.school-public-hero-copy p{color:#ffffffe6;max-width:680px;margin-bottom:28px;font-size:clamp(1.1rem,2vw,1.45rem)}.school-public-quick-stats{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff2e;border:1px solid #ffffff2e;border-radius:8px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;margin:0 clamp(18px,5vw,72px) 28px;display:grid;overflow:hidden}.school-public-quick-stats span{color:#ffffffdb;background:#0f172a47;gap:2px;padding:18px;display:grid}.school-public-quick-stats strong{color:#fff;font-size:1.1rem}.school-public-section{padding:64px clamp(18px,5vw,72px)}.school-public-about{flex-wrap:wrap;align-items:center;gap:28px;display:flex}.school-public-about-copy{flex:280px;max-width:620px}.school-public-section h2{margin-bottom:14px;font-size:clamp(1.8rem,3vw,2.5rem)}.school-public-section p{color:#475569;max-width:860px;line-height:1.7}.school-public-gallery,.school-public-review-grid,.school-public-video-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:24px;display:grid}.school-public-gallery img{aspect-ratio:4/3;object-fit:cover;border:1px solid var(--border);border-radius:8px;width:100%}.school-public-feature-gallery{flex:1.2 300px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.school-public-feature-gallery img:first-child{grid-row:span 2;height:100%;min-height:460px}.school-public-two{flex-wrap:wrap;align-items:start;gap:32px;display:flex}.school-public-two>div{flex:320px}.school-public-review-grid blockquote,.school-public-form{border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;border-radius:8px;padding:18px}.school-public-form{gap:12px;display:grid;box-shadow:0 18px 40px #0f172a14}.school-public-form-disabled{background:#f8fafc;align-content:center}.school-public-card-list{gap:12px;margin-top:16px;display:grid}.school-public-info-card{border:1px solid var(--surface-border);background:#fff;border-radius:8px;gap:8px;padding:16px;display:grid}.school-public-info-card p{color:#475569;margin:0}.school-public-info-card span{color:#64748b;font-size:.82rem;font-weight:700}.school-public-video-grid iframe{aspect-ratio:16/9;border:0;border-radius:8px;width:100%}.school-public-footer{color:#fff;background:#0f172a;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:18px;padding:28px clamp(18px,5vw,72px);display:flex}.school-public-footer p{color:#ffffffb8;margin:6px 0 0}.school-public-footer a{color:#fff;text-transform:capitalize;margin-left:14px;font-weight:700}.school-whatsapp-float{z-index:30;border:1px solid #ffffff7a;border-radius:50%;place-items:center;width:62px;height:62px;padding:0;font-size:0;display:grid;position:fixed;bottom:18px;right:18px;box-shadow:0 18px 38px #25d36657;color:#fff!important;background:#25d366!important}.school-whatsapp-float svg{width:34px;height:34px;fill:#fff!important}@media (max-width:1180px){.dashboard-stat-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}.dashboard-home-grid,.finance-report-grid{grid-template-columns:1fr}.student-detail-panel{grid-template-columns:repeat(2,minmax(160px,1fr));width:min(760px,100%);position:fixed}}@media (max-width:980px){.top-header{gap:12px;padding:14px 20px}.top-header-brand{width:100%;display:block}.top-header-left{width:100%}.top-header-right{justify-content:space-between;width:100%}.dashboard-layout.top-nav-mode .top-dashboard-bar{justify-content:flex-start;padding:8px 16px 10px;position:static}.dashboard-layout.top-nav-mode .top-dashboard-logout{width:100%}.id-card-header{grid-template-columns:1fr}.id-card-title-block{min-width:0}.id-card-toolbar{flex-wrap:wrap;justify-content:flex-start}.student-filter-bar{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:920px){.dashboard-layout.top-nav-mode .top-dashboard-bar{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 14px 12px!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav-shell{width:100%}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav{display:none!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open{background:#fff;border:1px solid #dbe4f0;border-radius:14px;width:100%;max-height:min(72vh,620px);padding:10px;overflow:hidden auto;box-shadow:0 18px 48px #0f172a1f;flex-direction:column!important;justify-content:flex-start!important;align-items:stretch!important;gap:8px!important;display:flex!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-link,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-heading{text-align:left;border-radius:10px;justify-content:space-between;width:100%;min-height:44px;padding:10px 12px;color:#334155!important;opacity:1!important;visibility:visible!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-link.active,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-heading.active{color:#1d4ed8!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group{gap:6px;width:100%;flex-direction:column!important;align-items:stretch!important;display:flex!important;position:static!important;transform:none!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-children{width:100%;min-width:0;max-width:none;max-height:none;box-shadow:none;background:0 0;border:0;padding:4px 0 8px 12px;overflow:visible;display:none!important;position:static!important;transform:none!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group:hover .nav-group-children{display:none!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-sub-link{background:#f8fafc;min-height:38px;font-size:.9rem}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open{color:#0f172a!important;background:#fff!important;flex-direction:column!important;align-items:stretch!important;gap:8px!important;display:flex!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-children{opacity:1!important;visibility:visible!important;width:100%!important;min-width:0!important;max-width:none!important;position:static!important;transform:none!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-children{box-shadow:none!important;background:#fff!important;border:0!important;border-top:1px solid #dbe4f0!important;padding:8px 0 2px!important;display:none!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group.expanded>.nav-group-children{grid-template-columns:1fr!important;gap:6px!important;display:grid!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-link,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-heading,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-sub-link{color:#0f172a!important;opacity:1!important;visibility:visible!important;text-shadow:none!important;background:#f8fafc!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-link.active,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-heading.active{color:#1d4ed8!important;background:#dbeafe!important}}@media (max-width:768px){.desktop-nav{display:none!important}.mobile-menu-btn{display:block!important}.hero-title{font-size:2.5rem!important;line-height:1.2!important}.hero-subtitle{font-size:1.1rem!important}.section-padding{padding:60px 20px!important}.mobile-stack{flex-direction:column!important}:root{--sidebar-width:0px}.dashboard-layout{display:block}.sidebar{border-right:0;border-bottom:1px solid var(--surface-border);width:100%;height:auto;max-height:none;position:static;overflow:visible}.sidebar-brand{margin-bottom:0;padding:16px 20px}.mobile-menu-toggle{justify-content:center;align-items:center;width:42px;height:40px;margin:0;padding:0;font-size:1.25rem;display:inline-flex}.dashboard-nav{max-height:48vh;padding:0 16px 14px;display:none;overflow:auto}.dashboard-nav.mobile-open{flex-direction:column;justify-content:flex-start;align-items:stretch;display:flex}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav{width:100%;max-height:56vh;padding:8px 0 0;display:none;overflow:auto}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open{flex-direction:column;justify-content:flex-start;align-items:stretch;gap:8px;display:flex}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-children{max-width:none;box-shadow:none;position:static;transform:none}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group{width:100%}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-children{background:0 0;border:0;width:100%;min-width:0;padding:6px 0 0 10px;display:none}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group.expanded>.nav-group-children{display:grid}.sidebar-logout{padding:14px 16px}.main-content{width:100%;max-width:100%;margin-left:0}.top-header{min-height:var(--header-height);flex-direction:row;align-items:center;gap:8px;height:auto;padding:10px 12px;position:static}.top-header-brand{flex:150px;width:auto;min-width:0}.brand-logo{flex-basis:38px;width:38px;height:38px}.brand-name{font-size:.98rem}.brand-portal,.brand-school-id{font-size:.68rem}.top-header-left{flex:none;gap:10px}.top-header-title{font-size:1.05rem;display:none}.top-header-right{flex:0 auto;gap:10px;width:auto}.academic-year-pill{max-width:148px;padding:6px 10px}.academic-year-pill span,.user-copy{display:none}.layout-mode-switch{width:auto}.layout-mode-switch button{flex:1;min-width:44px;padding:0 8px}.top-header-controls{flex:none}.top-header-logout{display:none!important}.content-area{padding:16px}.dashboard-home-hero{flex-direction:column;align-items:flex-start}.dashboard-home-actions{justify-content:flex-start;width:100%}.dashboard-stat-grid{grid-template-columns:1fr}.top-search{flex:none;width:auto;min-width:40px}.global-search{flex:none}.global-search-desktop{display:none}.mobile-search-trigger{justify-content:center;align-items:center;display:inline-flex}.front-office-form-grid,.front-office-list-grid,.invoice-builder-grid,.invoice-item-row,.invoice-preview-address-grid,.chat-message,.school-chat-shell,.school-public-about,.school-public-quick-stats,.school-public-two{grid-template-columns:1fr}.landing-repeater-row,.landing-footer-link-row,.landing-feature-card-row,.landing-review-row{flex-direction:column}.landing-repeater-row .btn,.landing-footer-link-row .btn,.landing-feature-card-row .btn,.landing-review-row .btn,.landing-review-row select{width:100%}.invoice-preview-paper{min-width:720px}.chat-actions{justify-content:flex-start;max-width:none}.student-detail-panel{grid-template-columns:1fr}.certificate-modal{padding:16px}.certificate-sheet{min-height:720px;padding:28px}.page-hero{flex-direction:column;align-items:flex-start;padding:18px}.page-actions{justify-content:flex-start;width:100%}.id-card-download-button,.id-card-toolbar .segmented-control,.id-card-toolbar .btn,.id-card-filter{width:100%}.id-card-toolbar .segmented-control button{flex:1}.calendar-grid{gap:5px}.calendar-day{min-height:58px;padding:7px;font-size:.82rem}.calendar-day small{padding:2px 5px;font-size:.64rem}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.student-filter-bar{grid-template-columns:1fr}}@media (min-width:769px){.hero-title{font-size:4.5rem;line-height:1.1}.hero-subtitle{font-size:1.5rem}.section-padding{padding:100px 40px}}.landing-hero{text-align:center;max-width:1200px;margin:0 auto;padding:60px 20px}.landing-pill{color:var(--primary);background:#2563eb1a;border-radius:999px;margin-bottom:24px;padding:8px 20px;font-size:.875rem;font-weight:600;display:inline-block}.landing-hero-title{letter-spacing:-.04em;color:#0f172a;margin-bottom:24px;font-size:clamp(2.5rem,5vw,4.5rem);line-height:1.1}.landing-hero-subtitle{color:#64748b;max-width:700px;margin:0 auto 40px;font-size:clamp(1.1rem,2vw,1.3rem);line-height:1.6}.landing-feature-row{align-items:center;gap:60px;margin-bottom:100px;display:flex}.landing-feature-row.reverse{flex-direction:row-reverse}.landing-feature-text{flex:1;min-width:300px}.landing-feature-img{background:#fff;border:1px solid #0000000d;border-radius:20px;flex:1.2;min-width:300px;overflow:hidden;box-shadow:0 20px 40px -10px #0000001a}@media (max-width:768px){.landing-feature-row{flex-direction:column;gap:40px}.landing-feature-row.reverse{flex-direction:column}.mobile-stack{flex-direction:column;width:100%}.mobile-stack .btn{width:100%}.landing-hero{padding:40px 20px}}.admin-card-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px;display:grid}.table-responsive-wrapper{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.glass-nav{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:50;background:#ffffffd9;border-bottom:1px solid #0000000d;position:sticky;top:0}.school-public-hero-modern{background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);justify-content:space-between;align-items:center;gap:40px;min-height:70vh;padding:80px clamp(20px,5vw,80px);display:flex;position:relative;overflow:hidden}.hero-modern-content{z-index:2;flex:1;max-width:600px}.hero-modern-image{z-index:2;border-radius:24px;flex:1;position:relative;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.hero-modern-image img{object-fit:cover;width:100%;height:100%;display:block}.hero-image-glow{background:linear-gradient(#0000,#0000004d);position:absolute;inset:0}@media (max-width:900px){.school-public-hero-modern{flex-direction:column;padding-top:40px}}.premium-glass-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffe6;border:1px solid #fff6;border-radius:16px;padding:24px;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 6px -1px #0000000d,0 10px 15px -3px #0000000d}.hover-lift:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modern-stats{z-index:10;flex-wrap:wrap;gap:24px;margin-top:-40px;padding:0 clamp(20px,5vw,80px);display:flex;position:relative}.stat-card{flex:1;align-items:center;gap:16px;min-width:250px;display:flex}.stat-icon{background:var(--school-primary,#2563eb);color:#fff;border-radius:12px;place-items:center;width:56px;height:56px;font-size:2rem;display:grid}.stat-card strong{color:#0f172a;font-size:1.1rem;display:block}.stat-card span{color:#64748b;font-size:.9rem}.premium-btn{background:var(--school-primary,#2563eb);color:#fff;border:none;border-radius:999px;padding:12px 28px;font-weight:600;transition:all .2s;box-shadow:0 4px 14px #2563eb63}.premium-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66}.premium-btn-outline{color:#0f172a;background:0 0;border:2px solid #cbd5e1;border-radius:999px;padding:10px 26px;font-weight:600;transition:all .2s}.premium-btn-outline:hover{background:#00000005;border-color:#94a3b8}.premium-input{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;width:100%;padding:14px 16px;font-size:1rem;transition:all .2s}.premium-input:focus{border-color:var(--school-primary,#2563eb);background:#fff;outline:none;box-shadow:0 0 0 3px #2563eb26}.premium-form{flex-direction:column;gap:16px;display:flex}.section-title{letter-spacing:-.02em;color:#0f172a;margin-bottom:16px;font-size:clamp(2rem,4vw,2.75rem);font-weight:800}.section-desc{color:#64748b;font-size:1.1rem;line-height:1.6}.card-title{color:#0f172a;margin-bottom:8px;font-size:1.25rem;font-weight:700;display:block}.card-body{color:#475569;margin-bottom:16px;line-height:1.5}.card-meta{color:#94a3b8;font-size:.85rem;font-weight:600}.review-card{color:#334155;font-size:1.1rem;font-style:italic;line-height:1.7}.gallery-img-wrapper{border-radius:16px;transition:transform .3s;overflow:hidden;box-shadow:0 10px 15px -3px #0000001a}.gallery-img-wrapper:hover{transform:scale(1.02)}.hero-stats-glass{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);color:#fff;z-index:10;background:#ffffff1f;border:1px solid #ffffff38;border-radius:20px;width:90%;max-width:480px;padding:24px;position:absolute;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 24px 60px #00000038}.hero-stat-row{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;display:grid}.hero-stat-row span{text-align:center;background:#ffffff1f;border-radius:18px;flex-direction:column;padding:16px 8px;font-size:.9rem;font-weight:500;display:flex}.hero-stat-row strong{color:#ffb700;margin-bottom:4px;font-size:24px;font-weight:800;display:block}.hero-stats-glass p{color:#ffffffe0;text-align:center;margin:0;font-size:14px;line-height:1.5}@media (max-width:768px){.hero-stats-glass{width:100%;max-width:100%;margin-top:24px;position:relative;bottom:auto;left:auto;transform:none}}.school-template-public{--template-navy:#06254a;--template-blue:var(--school-primary,#0057d9);--template-yellow:var(--school-accent,#ffc83d);--template-button:var(--school-button,#ffc83d);--template-button-text:var(--school-button-text,#061d38);--template-header:var(--school-header,#06254a);--template-header-text:var(--school-header-text,#fff);--template-footer:var(--school-footer,#061d38);--template-footer-text:var(--school-footer-text,#fff);--template-text:#0b1f3a;--template-muted:#667085;--template-shadow:0 18px 45px #081f421f;--template-radius:24px;min-height:100vh;color:var(--template-text);background:linear-gradient(135deg,#f4f9ff 0%,#fff 45%,#ecf7ff 100%);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;overflow-x:hidden}.school-template-public a{color:inherit;text-decoration:none}.school-template-container{width:min(1180px,92%);margin:0 auto}.school-template-header{z-index:80;background:var(--template-header);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);position:sticky;top:0;box-shadow:0 12px 30px #02122a2e}.school-template-nav-wrap{justify-content:space-between;align-items:center;gap:24px;min-height:82px;display:flex}.school-template-brand{color:var(--template-header-text);align-items:center;gap:12px;display:flex}.school-template-logo-mark{background:linear-gradient(135deg, var(--template-blue), #071e42);width:48px;height:48px;color:var(--template-yellow);border:2px solid #ffffff40;border-radius:16px;place-items:center;font-size:24px;font-weight:900;display:grid;overflow:hidden;box-shadow:0 12px 24px #00000029}.school-template-logo-mark img{box-sizing:border-box;object-fit:contain;background:#fff;width:100%;height:100%;padding:5px}.school-template-brand-text{min-width:0;display:block}.school-template-brand strong{color:var(--template-header-text);font-size:22px;font-weight:900;line-height:1;display:block}.school-template-brand small{opacity:.92;color:var(--template-header-text);font-size:13px;font-weight:600;display:block}.school-template-nav-menu{color:var(--template-header-text);align-items:center;gap:26px;font-size:14px;font-weight:700;display:flex}.school-template-nav-menu a{opacity:.92;white-space:nowrap;position:relative}.school-template-nav-menu a:after{content:"";background:var(--template-yellow);width:0;height:2px;transition:all .25s;position:absolute;bottom:-7px;left:0}.school-template-nav-menu a:hover:after{width:100%}.school-template-login-btn,.school-template-footer button{cursor:pointer;background:var(--template-button);color:var(--template-button-text);border:0;border-radius:12px;padding:13px 22px;font-weight:900;box-shadow:0 10px 22px #ffc83d47}.school-template-hero{align-items:center;min-height:610px;display:flex;position:relative;overflow:hidden}.school-template-hero-bg{background:var(--school-hero-image) center / cover no-repeat;position:absolute;inset:0;transform:scale(1.02)}.school-template-hero-overlay{background:linear-gradient(90deg,#02122beb 0%,#042043c7 42%,#04204338 100%);position:absolute;inset:0}.school-template-hero-content{z-index:1;grid-template-columns:1.2fr .8fr;align-items:center;gap:34px;display:grid;position:relative}.school-template-eyebrow{color:var(--template-yellow);text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;font-size:14px;font-weight:900;display:inline-block}.school-template-hero h1{color:#fff;letter-spacing:0;max-width:680px;font-size:clamp(42px,6vw,76px);line-height:.98}.school-template-hero p{color:#ffffffeb;max-width:590px;margin:22px 0 30px;font-size:18px}.school-template-hero-buttons{flex-wrap:wrap;gap:16px;display:flex}.school-template-btn{border-radius:14px;justify-content:center;align-items:center;padding:15px 24px;font-weight:900;transition:all .25s;display:inline-flex}.school-template-btn-primary{background:var(--template-button);color:var(--template-button-text);box-shadow:0 14px 30px #ffc63340}.school-template-btn-outline{color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #ffffff80}.school-template-glass-card{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-radius:var(--template-radius);color:#fff;background:#ffffff1f;border:1px solid #ffffff38;padding:28px;box-shadow:0 24px 60px #00000038}.school-template-stat-row{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;display:grid}.school-template-stat-row span{text-align:center;background:#ffffff1f;border-radius:18px;padding:16px}.school-template-stat-row strong{color:var(--template-yellow);font-size:26px;display:block}.school-template-section{padding:72px 0}.school-template-section-title{text-align:center}.school-template-section-title span,.school-template-tag{color:var(--template-blue);text-transform:uppercase;letter-spacing:.08em;font-weight:900}.school-template-section-title h2,.school-template-section-head h2,.school-template-appointment-card h2,.school-template-about-card h2{letter-spacing:0;font-size:clamp(26px,3.5vw,42px);line-height:1.1}.school-template-section-title p{max-width:760px;color:var(--template-muted);margin:14px auto 0}.school-template-features-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-top:38px;display:grid}.school-template-feature-card,.school-template-card-section,.school-template-panel{border-radius:var(--template-radius);box-shadow:var(--template-shadow);background:#ffffffd6;border:1px solid #0f67ff17}.school-template-feature-card{text-align:center;padding:28px 18px;transition:all .25s}.school-template-feature-card:hover{transform:translateY(-6px)}.school-template-feature-card span{margin-bottom:14px;font-weight:900;display:inline-flex}.school-template-feature-card h3{font-size:16px}.school-template-public .blue{color:#1672ff}.school-template-public .green{color:#22c55e}.school-template-public .yellow{color:#f59e0b}.school-template-public .purple{color:#8b5cf6}.school-template-card-section,.school-template-panel{padding:24px}.school-template-section-head{justify-content:space-between;align-items:center;gap:20px;margin-bottom:20px;display:flex}.school-template-section-head a{color:var(--template-blue);font-size:14px;font-weight:900}.school-template-section-head.small h2{font-size:22px}.school-template-gallery-grid{grid-template-columns:1.15fr 1fr 1fr 1fr 1fr;gap:16px;display:grid}.school-template-gallery-grid img{object-fit:cover;border-radius:18px;width:100%;height:170px;box-shadow:0 12px 26px #0f2f561a}.school-template-dashboard{padding-top:10px}.school-template-dashboard-grid{grid-template-columns:1fr;gap:20px;max-width:960px;display:grid}.school-template-review-grid{grid-template-columns:1fr;gap:16px;display:grid}.school-template-review-card,.school-template-notice-list li,.school-template-event-list article{background:#fff;border:1px solid #edf2f7;border-radius:20px;align-items:flex-start;gap:14px;padding:18px;display:flex;box-shadow:0 10px 22px #081f420f}.school-template-review-avatar,.school-template-icon{width:58px;height:58px;color:var(--template-blue);background:#eaf2ff;border-radius:50%;flex:none;place-items:center;font-weight:900;display:grid}.school-template-icon.blue-bg{background:linear-gradient(135deg, var(--template-blue), #0644a9);color:#fff}.school-template-stars{color:#ffbd16;letter-spacing:2px;font-size:14px}.school-template-stars span{color:#667085;letter-spacing:0;margin-left:8px;font-weight:900}.school-template-review-card p{color:#344054;margin:8px 0;font-size:14px}.school-template-review-card small,.school-template-notice-list small,.school-template-event-list small{color:var(--template-muted);margin-top:3px;font-size:12px;display:block}.school-template-notice-list,.school-template-event-list{gap:14px;list-style:none;display:grid}.school-template-date{color:#fff;border-radius:15px;flex:none;place-items:center;width:54px;height:58px;font-size:22px;font-weight:900;line-height:1;display:grid}.school-template-date small{color:#fff;font-size:11px}.school-template-public .blue-date{background:linear-gradient(135deg, var(--template-blue), #0644a9)}.school-template-about-appointment{padding-top:20px}.school-template-split-grid{grid-template-columns:1fr;align-items:stretch;gap:28px;display:grid}.school-template-appointment-card{background:linear-gradient(160deg, var(--template-blue), #003384);color:#fff;border-radius:var(--template-radius);padding:28px;overflow:hidden;box-shadow:0 24px 55px #004cc838}.school-template-appointment-card p{opacity:.9;margin:8px 0 18px}.school-template-form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.school-template-public input,.school-template-public select,.school-template-public textarea{width:100%;font:inherit;color:#0b1f3a;background:#fff;border:1px solid #0a2c5521;border-radius:12px;outline:none;padding:13px 14px}.school-template-public textarea{resize:vertical;margin-top:12px}.school-template-submit-btn{background:var(--template-button);width:100%;color:var(--template-button-text);cursor:pointer;border:0;border-radius:14px;margin-top:14px;padding:15px;font-weight:900}.school-template-about-content{grid-template-columns:1fr 1fr;align-items:center;gap:22px;display:grid}.school-template-about-card p{color:var(--template-muted);margin:14px 0}.school-template-check-list{gap:10px;list-style:none;display:grid}.school-template-check-list li:before{content:"";background:#16a34a;border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.school-template-about-image img{object-fit:cover;border-radius:22px;width:100%;height:280px}.school-template-stats{border-top:1px solid #edf2f7;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:20px;padding-top:18px;display:grid}.school-template-stats span{text-align:center;color:var(--template-muted);font-size:13px}.school-template-stats strong{color:var(--template-blue);font-size:26px;display:block}.school-template-video-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;display:grid}.school-template-video-grid iframe{aspect-ratio:16/9;border:0;border-radius:18px;width:100%}.school-template-footer{background:var(--template-footer);color:var(--template-footer-text);margin-top:40px}.school-template-footer-grid{grid-template-columns:1.25fr .8fr 1.1fr 1.1fr;gap:44px;padding:54px 0;display:grid}.school-template-footer p,.school-template-footer a{color:var(--template-footer-text);opacity:.82;margin:7px 0;font-size:14px;display:block}.school-template-footer h3{margin-bottom:15px;font-size:18px}.school-template-footer-brand{flex-direction:column;align-items:flex-start;gap:24px;margin-bottom:24px}.school-template-footer-brand .school-template-logo-mark{background:#fff;width:62px;height:62px}.school-template-footer-brand .school-template-logo-mark img{box-sizing:border-box;object-fit:contain;padding:6px}.school-template-footer-brand .school-template-brand-text{padding-top:4px}.school-template-footer .school-template-brand strong,.school-template-footer .school-template-brand small{color:var(--template-footer-text)}.school-template-copyright{text-align:center;border-top:1px solid #ffffff1f;padding:18px 4%}.school-template-modal{z-index:100;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#02122b9e;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.school-template-login-modal{background:#fff;border-radius:26px;width:min(430px,96%);padding:34px;position:relative;box-shadow:0 30px 80px #00000052}.school-template-close-modal{cursor:pointer;background:#f2f6fb;border:0;border-radius:999px;min-width:76px;height:38px;font-weight:900;position:absolute;top:16px;right:18px}.school-template-login-modal h2{text-align:center;font-size:28px}.school-template-login-modal>p{text-align:center;color:var(--template-muted);margin-bottom:22px}.school-template-login-modal label{border:1px solid #d8e1ef;border-radius:14px;align-items:center;margin-bottom:14px;padding:0 14px;display:flex}.school-template-login-modal label input,.school-template-login-modal label select{border:0;padding-left:0}.school-template-login-modal form>button[type=submit]{background:linear-gradient(135deg,var(--template-blue),#0644a9);color:#fff;border:0;border-radius:14px;width:100%;margin-bottom:14px;padding:15px;font-weight:900}.school-template-forgot{color:var(--template-blue);cursor:pointer;background:0 0;border:0;margin:0 0 14px auto;font-weight:800;display:block}@media (max-width:1050px){.school-template-nav-menu{display:none}.school-template-hero-content,.school-template-about-content{grid-template-columns:1fr}.school-template-features-grid,.school-template-footer-grid{grid-template-columns:repeat(2,1fr)}.school-template-gallery-grid{grid-template-columns:repeat(3,1fr)}.school-template-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:720px){.school-template-container{width:min(94%,1180px)}.school-template-nav-wrap{min-height:74px}.school-template-brand strong{font-size:18px}.school-template-brand small{font-size:11px}.school-template-logo-mark{width:42px;height:42px}.school-template-login-btn{padding:11px 14px}.school-template-hero{min-height:720px}.school-template-hero-overlay{background:linear-gradient(#02122be0 0%,#042043d1 65%,#04204394 100%)}.school-template-hero-content{padding:70px 0 34px}.school-template-hero h1{font-size:44px}.school-template-hero-buttons,.school-template-btn{width:100%}.school-template-stat-row,.school-template-features-grid,.school-template-form-grid,.school-template-footer-grid{grid-template-columns:1fr}.school-template-section{padding:50px 0}.school-template-gallery-grid{scroll-snap-type:x mandatory;padding-bottom:6px;display:flex;overflow-x:auto}.school-template-gallery-grid img{scroll-snap-align:start;min-width:245px}.school-template-card-section,.school-template-panel,.school-template-appointment-card{border-radius:20px;padding:20px}}@media print{.top-header,.top-dashboard-bar,.sidebar,.page-heading-row,.no-print,.record-controls{display:none!important}.main-content{margin:0!important;padding:0!important}.timetable-print-area{box-shadow:none!important;border:0!important;padding:0!important;overflow:visible!important}.timetable-print-area table{font-size:11px;width:100%!important;min-width:0!important}}@media (max-width:768px){.top-header{grid-template-columns:minmax(126px,1fr) auto auto auto!important;align-items:center!important;gap:10px!important;padding:14px 16px!important;display:grid!important}.top-header-brand,.top-header-left,.top-header-right,.top-header-controls{width:auto!important}.top-header-left{display:contents!important}.top-header-title,.top-header-right .user-chip,.layout-mode-switch,.top-header-logout{display:none!important}.brand-row{gap:10px}.brand-copy{min-width:0}.brand-name{text-overflow:ellipsis;white-space:nowrap;max-width:126px;overflow:hidden}.brand-school-id{text-overflow:ellipsis;width:fit-content;max-width:116px;display:inline-flex;overflow:hidden}.top-search{width:auto!important;min-width:0!important}.academic-year-pill{white-space:nowrap;min-height:42px;padding:0 12px;font-size:.82rem}.header-mobile-menu-button{display:inline-flex!important}.calculator-workspace{grid-template-columns:1fr}.dashboard-layout.top-nav-mode .top-dashboard-bar{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 14px 12px!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav-shell{width:100%}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav{display:none!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open{background:#fff;border:1px solid #dbe4f0;border-radius:14px;flex-direction:column;gap:8px;width:100%;max-height:72vh;padding:10px;overflow:hidden auto;box-shadow:0 18px 48px #0f172a1f;grid-template-columns:none!important;justify-content:flex-start!important;align-items:stretch!important;display:flex!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-link,.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-group-heading{text-align:left;border-radius:10px;justify-content:space-between;width:100%;min-height:44px;padding:10px 12px}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-link,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-heading,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-sub-link{color:#334155!important;opacity:1!important;visibility:visible!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-link.active,.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-heading.active{color:#1d4ed8!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-group{flex-direction:column;gap:6px;width:100%;display:flex}.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-group-children{width:100%;min-width:0;box-shadow:none;background:0 0;border:0;padding:4px 0 8px 12px;display:none!important;position:static!important;transform:none!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-group:hover .nav-group-children{display:none!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-group.expanded>.nav-group-children{grid-template-columns:1fr;gap:6px;display:grid!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .nav-sub-link{background:#f8fafc;min-height:38px;font-size:.9rem}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group{background:#fff;border:1px solid #dbe4f0;border-radius:12px;padding:6px}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-heading{color:#0f172a!important;background:#eef6ff!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group.expanded>.nav-group-heading{border-color:#93c5fd;background:#dbeafe!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-group-children{background:#fff!important;border-top:1px solid #e2e8f0!important;padding:8px 0 2px!important}.dashboard-layout.top-nav-mode .top-dashboard-bar .dashboard-nav.mobile-open .nav-sub-link{border:1px solid #e2e8f0;border-radius:10px;font-weight:700;color:#0f172a!important;background:#f8fafc!important}}.saas-top-nav-mode .saas-top-dashboard-bar{justify-content:center;display:flex}.saas-top-nav-mode .saas-top-dashboard-bar .dashboard-nav{flex-wrap:wrap;justify-content:center;max-height:none;overflow:visible;display:flex!important}.saas-top-nav-mode .saas-top-dashboard-bar .nav-link,.saas-top-nav-mode .saas-top-dashboard-bar .btn{width:auto!important}@media (max-width:920px){.saas-top-nav-mode .saas-top-dashboard-bar .dashboard-nav{background:#fff;border:1px solid #dbe4f0;border-radius:14px;gap:8px;padding:10px;flex-direction:row!important;display:flex!important}.saas-top-nav-mode .saas-top-dashboard-bar .nav-link,.saas-top-nav-mode .saas-top-dashboard-bar .btn{min-height:40px;padding:9px 12px;color:#334155!important}}.saas-home{color:#101827;background:#f6f8fb;min-height:100vh}.saas-hero-modern{background-position:100%;background-size:cover;align-items:center;min-height:86vh;padding:112px 32px 96px;display:flex;position:relative}.saas-hero-modern.centered{text-align:center;background-position:50%;justify-content:center}.saas-hero-modern.centered .saas-hero-inner{justify-items:center;display:grid}.saas-hero-inner{color:#fff;width:min(1120px,100%);margin:0 auto}.saas-eyebrow,.saas-section-kicker{letter-spacing:0;text-transform:uppercase;border:1px solid #ffffff42;border-radius:999px;align-items:center;min-height:32px;padding:6px 12px;font-size:.82rem;font-weight:800;display:inline-flex}.saas-section-kicker{color:#14532d;background:#ecfdf5;border-color:#bbf7d0}.saas-hero-modern h1{letter-spacing:0;color:#fff;max-width:760px;margin:22px 0 18px;font-size:4rem;line-height:1.02}.saas-hero-modern p{color:#dbeafe;max-width:690px;margin:0;font-size:1.18rem;line-height:1.8}.saas-hero-actions{flex-wrap:wrap;gap:14px;margin-top:34px;display:flex}.saas-hero-actions .btn{min-height:50px;padding:13px 22px;text-decoration:none}.btn.btn-light{color:#0f172a;background:#fff;border:1px solid #ffffffe6;box-shadow:0 12px 34px #0f172a2e}.btn.btn-light:hover{color:#0f172a;background:#f8fafc}.saas-metric-strip{z-index:2;background:#dbe4f0;border:1px solid #dbe4f0;border-radius:18px;grid-template-columns:repeat(4,1fr);gap:1px;width:min(1120px,100% - 48px);margin:-42px auto 0;display:grid;position:relative;overflow:hidden;box-shadow:0 24px 70px #0f172a1f}.saas-metric-item{background:#fff;gap:5px;padding:22px 20px;display:grid}.saas-metric-item strong{color:#0f766e;font-size:2rem;line-height:1}.saas-metric-item span{color:#475569;font-weight:700}.saas-media-showcase{justify-content:center;gap:14px;width:min(1180px,100% - 48px);margin:54px auto 0;display:grid}.saas-media-card{background:#fff;border:1px solid #dbe4f0;border-radius:18px;width:min(980px,86vw);overflow:hidden;box-shadow:0 18px 50px #0f172a1a}.saas-media-card img{object-fit:contain;background:#0f172a;border:0;width:100%;height:auto;max-height:78vh;display:block}.saas-media-card video,.saas-media-card iframe{aspect-ratio:16/9;object-fit:contain;background:#0f172a;border:0;width:100%;height:auto;display:block}.saas-media-card h3{margin:0;padding:14px 16px 16px;font-size:1rem}.saas-media-controls{justify-content:center;align-items:center;gap:12px;display:flex}.saas-media-controls button{color:#0f172a;cursor:pointer;background:#fff;border:1px solid #dbe4f0;border-radius:999px;padding:10px 14px;font-weight:800}.saas-media-controls span{color:#475569;font-weight:800}@keyframes spin{to{transform:rotate(360deg)}}.saas-product-band,.saas-admin-showcase{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);align-items:center;gap:36px;width:min(1180px,100% - 48px);margin:84px auto 0;display:grid}.saas-product-copy h2,.saas-admin-showcase h2,.saas-section-heading h2{letter-spacing:0;color:#101827;margin:16px 0 14px;font-size:2.6rem;line-height:1.12}.saas-product-copy p,.saas-admin-showcase p,.saas-section-heading p,.saas-module-group-head p,.saas-module-card p{color:#56677f;line-height:1.7}.saas-proof-grid{gap:12px;margin-top:24px;display:grid}.saas-proof-grid div{background:#fff;border:1px solid #dbe4f0;border-radius:12px;gap:4px;padding:16px;display:grid}.saas-proof-grid strong{color:#111827}.saas-proof-grid span{color:#56677f}.saas-product-image,.saas-admin-showcase>img{width:100%}.saas-product-image img,.saas-admin-showcase img{border:1px solid #dbe4f0;border-radius:20px;width:100%;height:auto;display:block;box-shadow:0 24px 70px #0f172a21}.saas-section{width:min(1180px,100% - 48px);margin:96px auto 0}.saas-section-heading{max-width:780px}.saas-module-nav{flex-wrap:wrap;gap:10px;margin:28px 0 34px;display:flex}.saas-module-nav a{color:#0f172a;background:#fff;border:1px solid #dbe4f0;border-radius:999px;padding:10px 14px;font-weight:800;text-decoration:none}.saas-module-groups{gap:30px;display:grid}.saas-module-group{background:#fff;border:1px solid #dbe4f0;border-radius:20px;padding:26px}.saas-module-group-head{grid-template-columns:56px minmax(0,1fr);align-items:start;gap:18px;margin-bottom:22px;display:grid}.saas-module-group-head>span{color:#1d4ed8;background:#eef2ff;border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-weight:900;display:inline-flex}.saas-module-group-head h3{letter-spacing:0;margin:0 0 6px;font-size:1.55rem}.saas-module-group-head p{margin:0}.saas-module-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.saas-module-card{background:#fbfdff;border:1px solid #e2e8f0;border-radius:12px;align-content:start;gap:8px;min-height:158px;padding:18px;display:grid}.saas-module-number{color:#0f766e;font-size:.82rem;font-weight:900}.saas-module-card h4{letter-spacing:0;color:#111827;margin:0;font-size:1.05rem}.saas-module-card p{margin:0;font-size:.95rem}.saas-admin-showcase{color:#fff;background:#101827;border-radius:24px;margin-bottom:96px;padding:34px}.saas-admin-showcase h2{color:#fff}.saas-admin-showcase p{color:#cbd5e1;margin-bottom:24px}.saas-popup-backdrop{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ac7;place-items:center;padding:22px;display:grid;position:fixed;inset:0}.saas-popup-preload{opacity:0;pointer-events:none;width:1px;height:1px;position:fixed}.saas-popup{background:#fff;border:1px solid #fff3;border-radius:22px;width:min(1080px,100%);max-height:90vh;padding:18px;overflow:hidden;box-shadow:0 28px 90px #00000059}.saas-popup-header{justify-content:space-between;align-items:flex-start;gap:16px;padding:2px 2px 14px;display:flex}.saas-popup-header.no-title{justify-content:flex-end}.saas-popup h2{color:#0f172a;margin:0;font-size:1.45rem}.saas-popup-media{background:#0f172a;border-radius:16px;place-items:center;max-height:calc(90vh - 132px);display:grid;overflow:auto}.saas-popup img,.saas-popup video,.saas-popup iframe{object-fit:contain;border:0;width:100%;display:block}.saas-popup img{width:auto;max-width:100%;height:auto;max-height:calc(90vh - 132px)}.saas-popup video,.saas-popup iframe{aspect-ratio:16/9;width:100%;min-height:min(520px,62vh)}.saas-popup-close{color:#fff;cursor:pointer;background:#0f172a;border:0;border-radius:999px;padding:10px 16px;font-weight:800}.saas-popup-controls{justify-content:space-between;align-items:center;gap:12px;padding-top:14px;display:flex}.saas-popup-controls button{cursor:pointer;background:#fff;border:1px solid #dbe4f0;border-radius:10px;padding:10px 14px;font-weight:800}@media (max-width:980px){.saas-hero-modern{background-position:50%;min-height:auto;padding:84px 22px 78px}.saas-hero-modern h1{font-size:3rem}.saas-metric-strip,.saas-product-band,.saas-section,.saas-media-showcase,.saas-admin-showcase{width:min(100% - 28px,720px)}.saas-metric-strip{grid-template-columns:repeat(2,1fr)}.saas-product-band,.saas-admin-showcase{grid-template-columns:1fr;margin-top:64px}.saas-module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:860px){.section-padding>div[style*=grid-template-columns]{grid-template-columns:1fr!important}}@media (max-width:640px){.saas-hero-modern{padding:70px 16px 66px}.saas-hero-modern h1{font-size:2.35rem}.saas-hero-modern p{font-size:1rem}.saas-section-heading{text-align:center;justify-items:center;max-width:100%;margin-inline:auto;display:grid}.saas-section-heading p{margin-left:auto;margin-right:auto}.saas-hero-actions{flex-direction:column;align-items:center}.saas-hero-actions .btn{justify-content:center;width:100%}.saas-metric-strip{grid-template-columns:1fr}.saas-product-copy h2,.saas-admin-showcase h2,.saas-section-heading h2{font-size:2rem}.saas-module-group{padding:18px}.saas-module-group-head,.saas-module-grid{grid-template-columns:1fr}.saas-admin-showcase{padding:22px}.saas-footer{text-align:center;padding:44px 20px!important}.saas-footer-grid{justify-items:center;grid-template-columns:1fr!important;gap:30px!important}.saas-footer-grid>div{justify-items:center;width:100%;max-width:360px;display:grid}.saas-footer-grid ul{align-items:center;padding-left:0}.saas-footer-social{justify-content:center}.saas-popup{padding:12px}.saas-popup-header{align-items:center}.saas-popup h2{font-size:1.1rem}.saas-popup-close{padding:8px 12px}}
