@import"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600;700;900&display=swap";.institutions-list-page .sa-inst-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));align-items:stretch}.institutions-list-page .sa-inst-card:not(.sa-inst-card--add){min-height:312px;padding:24px 22px 20px;gap:18px}.institutions-list-page .sa-inst-card-icon{width:50px;height:50px;border-radius:14px}.institutions-list-page .sa-inst-card-body{flex:1;display:flex;flex-direction:column;justify-content:center;min-height:76px}.institutions-list-page .sa-inst-card-body h3{font-size:1.125rem;line-height:1.38}.institutions-list-page .sa-inst-card-stats{margin-top:6px}.institutions-list-page .sa-inst-card-stats>div{padding:12px}.institutions-list-page .sa-inst-card-foot{padding-top:10px}.institutions-list-page .sa-inst-card--add{min-height:312px;padding:28px 24px}.institutions-list-page .sa-inst-card-add-icon{width:60px;height:60px}.support-filter-chips{flex-wrap:wrap;gap:6px}.support-table-head,.support-table-row{grid-template-columns:minmax(160px,1.4fr) minmax(140px,1.8fr) .68fr minmax(100px,.9fr) .7fr .62fr .58fr 88px}.support-cell-subject{display:flex;align-items:center;gap:10px}.support-cell-subject strong{display:block;font-size:13px;font-weight:600;line-height:1.35}.support-cell-subject small{display:block;font-size:11px;color:var(--sa-muted);margin-top:2px}.support-cell-preview{font-size:12px;color:var(--sa-muted);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.support-cell-tenant{font-size:12px;font-weight:600;color:var(--sa-ink)}.support-cell-date{font-size:11.5px;color:var(--sa-muted);font-variant-numeric:tabular-nums}.support-view-body{display:flex;flex-direction:column;gap:16px}.support-view-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:14px;border-radius:14px;background:linear-gradient(160deg,#fafaf9,#f4f4f0);border:1px solid var(--sa-border)}.support-view-meta-row{display:flex;flex-direction:column;gap:4px}.support-view-meta-row span{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--sa-muted)}.support-view-meta-row strong{font-size:13px;font-weight:600;color:var(--sa-ink)}.support-view-message,.support-view-existing-note{padding:14px;border-radius:14px;border:1px solid var(--sa-border)}.support-view-message{background:#fefcf8cc}.support-view-existing-note{background:#f0fdfacc;border-color:#0d948840}.support-view-message-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--sa-muted);margin-bottom:8px}.support-view-message p,.support-view-existing-note p{margin:0;font-size:13px;line-height:1.65;color:var(--sa-ink);white-space:pre-wrap}.support-reply-form{display:flex;flex-direction:column;gap:12px}@media(max-width:1280px){.support-table-head,.support-table-row{grid-template-columns:minmax(140px,1.4fr) minmax(120px,1.6fr) .7fr .9fr .7fr .62fr .55fr 78px}}@media(max-width:900px){.support-view-meta{grid-template-columns:repeat(2,minmax(0,1fr))}.support-table-head{display:none}.support-table-row{grid-template-columns:1fr;gap:6px}}.sa-kpi--indigo{background:linear-gradient(160deg,#f5f3ff,#ede9fe)}.sa-kpi--indigo:before{background:linear-gradient(180deg,#a5b4fc,#6366f1)}.sa-kpi--indigo .sa-kpi-icon{background:#6366f124;color:#4338ca}.sa-kpi--teal{background:linear-gradient(160deg,#f0fdfa,#e6f7f5)}.sa-kpi--teal:before{background:linear-gradient(180deg,#5eead4,#0d9488)}.sa-kpi--teal .sa-kpi-icon{background:#0d948824;color:#0f766e}.sa-kpi--amber{background:linear-gradient(160deg,#fffbeb,#fef3c7)}.sa-kpi--amber:before{background:linear-gradient(180deg,#fcd34d,#d97706)}.sa-kpi--amber .sa-kpi-icon{background:#d9770624;color:#b45309}.sa-kpi--coral{background:linear-gradient(160deg,#fff7f5,#fee2da)}.sa-kpi--coral:before{background:linear-gradient(180deg,#fca5a5,#e05252)}.sa-kpi--coral .sa-kpi-icon{background:#e0525224;color:#c0392b}.users-page .users-page-kpis{display:flex;flex-wrap:nowrap;align-items:stretch;gap:14px;margin-bottom:14px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch}.users-page .users-page-kpis .sa-kpi{flex:1 1 0;min-width:132px}.admin-shell.super-admin-app,.admin-shell.principal-console{font-size:12px;--sa-radius-lg: 12px;--sa-radius-md: 10px;grid-template-columns:78px minmax(0,1fr)}.admin-shell.super-admin-app .admin-navbar,.admin-shell.principal-console .admin-navbar{min-height:48px;padding:6px 12px}.admin-shell.super-admin-app .admin-mark,.admin-shell.principal-console .admin-mark{width:30px;height:30px;border-radius:9px}.admin-shell.super-admin-app .profile-avatar,.admin-shell.principal-console .profile-avatar{width:26px;height:26px;font-size:11px}.admin-shell.super-admin-app .navbar-profile,.admin-shell.principal-console .navbar-profile{min-height:32px;padding:3px 8px 3px 4px}.admin-shell.super-admin-app .ghost-action.navbar-logout,.admin-shell.principal-console .ghost-action.navbar-logout{min-height:32px;padding:0 12px;font-size:12px}.admin-shell.super-admin-app .admin-sidebar,.admin-shell.principal-console .admin-sidebar{padding:8px 6px}.admin-shell.super-admin-app .nav-button,.admin-shell.principal-console .nav-button{min-height:44px;padding:5px 3px;border-radius:10px;gap:4px}.admin-shell.super-admin-app .nav-button svg,.admin-shell.principal-console .nav-button svg{width:16px;height:16px}.admin-shell.super-admin-app .nav-button span,.admin-shell.principal-console .nav-button span{font-size:9px;max-width:62px}.admin-shell.super-admin-app .sa-overview,.admin-shell.principal-console .principal-page-stack,.admin-shell.principal-console .teacher-page-stack,.admin-shell.principal-console .teacher-main,.admin-shell.principal-console .guardian-page-stack,.admin-shell.principal-console .guardian-main,.admin-shell.principal-console .guidance-page-stack,.admin-shell.principal-console .guidance-main{gap:12px}.admin-shell.super-admin-app .sa-page-header,.admin-shell.principal-console .sa-page-header{margin-bottom:12px;padding-bottom:10px}.admin-shell.super-admin-app .sa-page-header h1,.admin-shell.principal-console .sa-page-header h1,.admin-shell.principal-console .teacher-page-title h1,.admin-shell.principal-console .guardian-page-title h1,.admin-shell.principal-console .guidance-page-title h1{font-size:1.2rem}.admin-shell.super-admin-app .sa-page-header p,.admin-shell.principal-console .sa-page-header p{font-size:.8rem;margin-top:6px}.admin-shell.super-admin-app .sa-kpi-row,.admin-shell.principal-console .principal-kpi-grid,.admin-shell.principal-console .teacher-kpi-grid,.admin-shell.principal-console .guardian-kpi-grid,.admin-shell.principal-console .guidance-kpi-grid,.admin-shell.principal-console .principal-stat-grid{gap:10px}.admin-shell.super-admin-app .sa-kpi,.admin-shell.principal-console .sa-kpi{padding:11px 12px 11px 15px;border-radius:var(--sa-radius-lg)}.admin-shell.super-admin-app .sa-kpi:before,.admin-shell.principal-console .sa-kpi:before{border-radius:var(--sa-radius-lg) 0 0 var(--sa-radius-lg)}.admin-shell.super-admin-app .sa-kpi-icon,.admin-shell.principal-console .sa-kpi-icon,.admin-shell.principal-console .principal-kpi-icon{width:32px;height:32px;margin-bottom:7px;border-radius:9px}.admin-shell.super-admin-app .sa-kpi-value,.admin-shell.principal-console .sa-kpi-value{font-size:1.2rem}.admin-shell.super-admin-app .sa-kpi label,.admin-shell.principal-console .sa-kpi label{font-size:10px;margin-bottom:2px}.admin-shell.super-admin-app .sa-kpi-hint,.admin-shell.principal-console .sa-kpi-hint{margin-top:6px;font-size:10px}.admin-shell.super-admin-app .sa-card,.admin-shell.principal-console .sa-card,.admin-shell.principal-console .principal-surface-card,.admin-shell.principal-console .principal-kpi-card,.admin-shell.principal-console .principal-stat-card{border-radius:var(--sa-radius-lg);box-shadow:0 1px 12px #0f172a0d}.admin-shell.super-admin-app .sa-panel-header,.admin-shell.principal-console .sa-panel-header{padding:11px 14px;gap:10px}.admin-shell.super-admin-app .sa-panel-header h2,.admin-shell.principal-console .sa-panel-header h2,.admin-shell.principal-console .principal-card-head h2,.admin-shell.principal-console .teacher-card-head h2,.admin-shell.principal-console .guardian-card-head h2,.admin-shell.principal-console .guidance-card-head h2{font-size:.92rem}.admin-shell.super-admin-app .sa-card-body,.admin-shell.principal-console .sa-card-body{padding:12px 14px}.admin-shell.super-admin-app .sa-chart-frame,.admin-shell.principal-console .principal-chart-frame{height:200px}.admin-shell.principal-console .principal-chart-frame--lg{height:220px}.admin-shell.super-admin-app .sa-two-col,.admin-shell.super-admin-app .sa-dash-grid,.admin-shell.principal-console .principal-visual-grid,.admin-shell.principal-console .teacher-overview-grid,.admin-shell.principal-console .guardian-overview-grid,.admin-shell.principal-console .guidance-overview-grid{gap:10px}.admin-shell.principal-console .principal-kpi-card,.admin-shell.principal-console .principal-stat-card{padding:12px 13px 12px 15px}.admin-shell.principal-console .principal-stat-card strong{font-size:clamp(1.15rem,2vw,1.4rem)}.admin-shell.principal-console .principal-kpi-card strong,.admin-shell.principal-console .teacher-kpi-card strong,.admin-shell.principal-console .guardian-kpi-card strong,.admin-shell.principal-console .guidance-kpi-card strong{font-size:clamp(1rem,1.5vw,1.2rem)}.admin-shell.principal-console .teacher-kpi-card,.admin-shell.principal-console .guardian-kpi-card,.admin-shell.principal-console .guidance-kpi-card{min-height:100px;padding:10px 12px 10px 14px}.admin-shell.principal-console .principal-surface-card{padding:12px 14px}.admin-shell.principal-console .principal-ring{width:96px;height:96px}.admin-shell.principal-console .principal-ring strong{font-size:1rem}.admin-shell.principal-console .sa-inst-card:not(.sa-inst-card--add){padding:16px 14px 14px;min-height:0;gap:12px}.admin-shell.principal-console .sa-inst-card--add{padding:20px 16px;min-height:0}.admin-shell.super-admin-app .primary-action:not(.navbar-logout),.admin-shell.principal-console .primary-action:not(.navbar-logout),.admin-shell.super-admin-app .primary-action.small-action,.admin-shell.principal-console .primary-action.small-action{min-height:38px;font-size:12px}.admin-shell.super-admin-app .ghost-action:not(.navbar-logout),.admin-shell.principal-console .ghost-action:not(.navbar-logout){min-height:36px;font-size:12px}.admin-shell.super-admin-app .field-control,.admin-shell.principal-console .field-control{min-height:40px;padding:0 11px;border-radius:9px}.admin-shell.principal-console .principal-list-row,.admin-shell.principal-console .teacher-lesson-row,.admin-shell.principal-console .guardian-lesson-row,.admin-shell.principal-console .guidance-observation-row,.admin-shell.principal-console .guidance-risk-row{padding:8px 10px;border-radius:10px}@media(max-width:1080px){.admin-shell.super-admin-app,.admin-shell.principal-console{grid-template-columns:1fr}}.admin-shell.super-admin-app,.admin-shell.principal-console{font-family:Roboto,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:12px;--sa-bg: #e8edf4;--sa-surface: #ffffff;--sa-muted: #64748b;--sa-border: #cfd8e6;--sa-ink: #0f172a;--sa-accent: #0f766e;--sa-accent-2: #2dd4bf;--sa-chart-soft: #6366f1;--sa-shadow: 0 20px 48px rgba(15, 23, 42, .085);--sa-tint-warm: color-mix(in srgb, var(--sa-accent) 9%, var(--sa-surface));--sa-tint-cream: color-mix(in srgb, var(--sa-accent) 7%, var(--sa-surface));--sa-surface-tint: color-mix(in srgb, var(--sa-accent) 5%, var(--sa-surface));--sa-accent-deep: #115e59;--sa-accent-mid: #14b8a6;background:linear-gradient(168deg,#dfe8f2 0%,var(--sa-bg) 40%,#e8f0f9 100%);grid-template-columns:78px minmax(0,1fr)}.admin-shell.super-admin-app .admin-navbar,.admin-shell.principal-console .admin-navbar{background:#ffffffe6;border-bottom:1px solid var(--sa-border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.admin-shell.super-admin-app .admin-sidebar,.admin-shell.principal-console .admin-sidebar{background:color-mix(in srgb,var(--sa-surface) 88%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-right:1px solid var(--sa-border)}.admin-shell.super-admin-app .developer-note,.admin-shell.principal-console .developer-note{border-color:color-mix(in srgb,var(--sa-accent) 30%,var(--sa-border));background:color-mix(in srgb,var(--sa-surface) 93%,transparent)}.admin-shell.super-admin-app .developer-note svg,.admin-shell.principal-console .developer-note svg{color:var(--sa-accent)}.admin-shell.super-admin-app .sa-main,.admin-shell.principal-console .sa-main{padding:14px 20px 24px}.admin-shell.super-admin-app .sa-card,.admin-shell.super-admin-app .sa-kpi,.admin-shell.principal-console .sa-card,.admin-shell.principal-console .sa-kpi,.admin-shell.principal-console .principal-kpi-card,.admin-shell.principal-console .principal-surface-card,.admin-shell.principal-console .principal-stat-card{border-radius:12px;border:1px solid var(--sa-border);box-shadow:0 1px 12px #0f172a0d}.admin-shell.super-admin-app .sa-kpi,.admin-shell.principal-console .sa-kpi,.admin-shell.principal-console .principal-kpi-card,.admin-shell.principal-console .principal-surface-card{background:linear-gradient(168deg,var(--sa-surface) 0%,var(--sa-surface-tint) 100%)}.admin-shell.principal-console .principal-stat-card{background:linear-gradient(155deg,var(--sa-surface) 0%,var(--sa-surface-tint) 100%);box-shadow:0 8px 22px #0f172a0f}.admin-shell.principal-console .principal-kpi-icon{color:var(--sa-accent-deep);background:color-mix(in srgb,var(--sa-accent) 16%,transparent)}.admin-shell.super-admin-app .sa-page-header h1,.admin-shell.principal-console .sa-page-header h1{font-weight:700;letter-spacing:-.03em}.admin-shell.super-admin-app .sa-page-header p,.admin-shell.super-admin-app .sa-kpi-hint,.admin-shell.principal-console .sa-page-header p,.admin-shell.principal-console .sa-kpi-hint{line-height:1.55}.admin-shell.super-admin-app .sa-panel-header h2,.admin-shell.principal-console .principal-card-head h2,.admin-shell.teacher-console .teacher-card-head h2,.admin-shell.teacher-console .teacher-page-title h1,.admin-shell.guardian-console .guardian-card-head h2,.admin-shell.guardian-console .guardian-page-title h1,.admin-shell.guidance-console .guidance-card-head h2,.admin-shell.guidance-console .guidance-page-title h1{font-weight:700;letter-spacing:-.02em}.admin-shell.super-admin-app .sa-kicker,.admin-shell.super-admin-app .section-kicker,.admin-shell.principal-console .sa-kicker,.admin-shell.principal-console .section-kicker{color:var(--sa-accent);letter-spacing:.05em}.admin-shell.super-admin-app .nav-button span,.admin-shell.principal-console .nav-button span{max-width:72px}.admin-shell.principal-console .principal-list-row,.admin-shell.principal-console .principal-inline-stats>div,.admin-shell.principal-console .principal-class-kpis>div,.admin-shell.principal-console .principal-class-tree-card{border-color:var(--sa-border);background:var(--sa-tint-cream)}.admin-shell.principal-console .principal-class-section-row:hover,.admin-shell.principal-console .principal-table--clickable tbody tr:hover{background:var(--sa-tint-warm)}.admin-shell.principal-console .principal-ring{background:radial-gradient(closest-side,var(--sa-surface) 72%,transparent 73% 100%),conic-gradient(var(--sa-accent-mid) var(--principal-ring),var(--sa-border) 0)}.admin-shell.principal-console .sa-inst-card:not(.sa-inst-card--add){background:linear-gradient(168deg,var(--sa-surface) 0%,var(--sa-surface-tint) 100%);box-shadow:0 2px 18px #0f172a0e}.admin-shell.principal-console .sa-inst-card--add{border-color:color-mix(in srgb,var(--sa-accent) 50%,var(--sa-border));background:var(--sa-tint-warm)}.admin-shell.principal-console .sa-inst-card--add:hover{box-shadow:0 10px 22px color-mix(in srgb,var(--sa-accent) 14%,transparent)}.admin-shell.principal-console .admin-mark,.admin-shell.principal-console .profile-avatar{color:var(--sa-accent-deep);background:linear-gradient(145deg,var(--sa-accent-2),var(--sa-accent));box-shadow:0 10px 20px color-mix(in srgb,var(--sa-accent) 25%,transparent)}.admin-shell.principal-console .nav-button.active,.admin-shell.principal-console .nav-button:hover,.admin-shell.super-admin-app .nav-button.active,.admin-shell.super-admin-app .nav-button:hover{border-color:color-mix(in srgb,var(--sa-accent) 35%,transparent);background:linear-gradient(180deg,var(--sa-surface),var(--sa-tint-warm))}.admin-shell.super-admin-app .primary-action:not(.navbar-logout),.admin-shell.principal-console .primary-action:not(.navbar-logout){color:#fff;background:linear-gradient(135deg,var(--sa-accent-mid),var(--sa-accent-deep))}.admin-shell.super-admin-app .primary-action.small-action,.admin-shell.principal-console .primary-action.small-action{color:#fff;background:linear-gradient(135deg,var(--sa-accent-mid),var(--sa-accent-deep))}.admin-shell.super-admin-app .ghost-action:not(.navbar-logout):hover,.admin-shell.principal-console .ghost-action:not(.navbar-logout):hover{border-color:var(--sa-accent);background:color-mix(in srgb,var(--sa-accent) 12%,transparent)}.admin-shell.teacher-console{--teacher-sky: #2563eb;--teacher-emerald: var(--sa-accent);--teacher-amber: var(--sa-accent-mid);--teacher-violet: #6366f1}.admin-shell.teacher-console .teacher-active-lesson,.admin-shell.teacher-console .teacher-lesson-row,.admin-shell.teacher-console .teacher-compact-row,.admin-shell.teacher-console .teacher-observation-row,.admin-shell.teacher-console .teacher-announcement-row{background:var(--sa-tint-cream)}.admin-shell.teacher-console .teacher-lesson-row.is-active{border-color:color-mix(in srgb,var(--sa-accent) 35%,var(--sa-border));background:linear-gradient(90deg,color-mix(in srgb,var(--sa-accent) 8%,transparent),var(--sa-surface))}.admin-shell.teacher-console .teacher-lesson-icon{color:var(--sa-accent-deep);background:color-mix(in srgb,var(--sa-accent) 14%,transparent)}.admin-shell.teacher-console .teacher-compact-row:hover{border-color:color-mix(in srgb,var(--sa-accent) 45%,var(--sa-border));background:var(--sa-tint-warm)}.admin-shell.teacher-console .teacher-status-toggle button.is-selected{color:var(--sa-accent-deep);border-color:color-mix(in srgb,var(--sa-accent) 60%,var(--sa-border));background:var(--sa-tint-warm)}.admin-shell.teacher-console .teacher-kpi-card.teacher-kpi-card{min-height:100px}.admin-shell.guardian-console{--guardian-sky: #2563eb;--guardian-emerald: var(--sa-accent);--guardian-amber: var(--sa-accent-mid);--guardian-violet: #6366f1}.admin-shell.guardian-console .guardian-child-card,.admin-shell.guardian-console .guardian-notice-row,.admin-shell.guardian-console .guardian-lesson-row,.admin-shell.guardian-console .guardian-attendance-row,.admin-shell.guardian-console .guardian-announcement-row,.admin-shell.guardian-console .guardian-scope-list>div{background:var(--sa-tint-cream)}.admin-shell.guardian-console .guardian-child-card{background:linear-gradient(135deg,var(--sa-surface),var(--sa-surface-tint))}.admin-shell.guardian-console .guardian-notice-row>span{background:color-mix(in srgb,var(--sa-accent) 16%,transparent)}.admin-shell.guardian-console .guardian-notice-row--warning>span{background:color-mix(in srgb,var(--sa-accent-mid) 20%,transparent);color:var(--sa-accent-deep)}.admin-shell.guardian-console .guardian-child-avatar--amber{background:linear-gradient(145deg,var(--sa-accent-2),var(--sa-accent))}.admin-shell.guardian-console .guardian-kpi-card.guardian-kpi-card{min-height:100px}.admin-shell.guidance-console{--guidance-sky: #2563eb;--guidance-emerald: var(--sa-accent);--guidance-amber: var(--sa-accent-mid);--guidance-violet: #6366f1;--guidance-rose: #b91c1c}.admin-shell.guidance-console .guidance-observation-row,.admin-shell.guidance-console .guidance-risk-row,.admin-shell.guidance-console .guidance-student-row,.admin-shell.guidance-console .guidance-plan-row,.admin-shell.guidance-console .guidance-announcement-row{background:var(--sa-tint-cream)}.admin-shell.guidance-console .guidance-risk-row--medium{border-color:color-mix(in srgb,var(--sa-accent-mid) 28%,var(--sa-border));background:linear-gradient(90deg,color-mix(in srgb,var(--sa-accent) 9%,transparent),var(--sa-surface))}.admin-shell.guidance-console .guidance-risk-icon{color:var(--sa-accent-deep);background:color-mix(in srgb,var(--sa-accent) 16%,transparent)}.admin-shell.guidance-console .guidance-filter-chip.is-active,.admin-shell.guidance-console .guidance-filter-chip:hover{color:var(--sa-accent-deep);border-color:color-mix(in srgb,var(--sa-accent) 45%,var(--sa-border));background:var(--sa-tint-warm)}.admin-shell.guidance-console .guidance-kpi-card.guidance-kpi-card{min-height:100px}@media(max-width:1080px){.admin-shell.super-admin-app,.admin-shell.principal-console,.admin-shell.teacher-console,.admin-shell.guardian-console,.admin-shell.guidance-console{grid-template-columns:1fr;grid-template-rows:56px auto minmax(0,1fr)}}.first-login-page{display:grid;min-height:100vh;place-items:center;padding:24px}.password-reset-panel{display:grid;width:min(100%,470px);gap:16px;padding:30px;border:1px solid var(--line);border-radius:8px;background:#fffdf8f0;box-shadow:var(--shadow)}.password-reset-panel p{margin:0;color:var(--muted);font-size:13px;line-height:1.55}.first-login-page .login-mark{display:grid;place-items:center;border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #0000001a}.reset-mark{width:58px;height:58px;margin:0;color:#fff;background:linear-gradient(135deg,var(--sky),var(--green))}.reset-form,.password-reset-panel .form-actions{display:grid;gap:14px}.password-reset-panel .form-actions{grid-template-columns:1fr auto;align-items:center}.login-page{position:relative;display:grid;place-items:center;min-height:100vh;padding:1.5rem;background:color-mix(in srgb,#ffffff 88%,#e8edf4);border:0}.login-home-link{position:fixed;top:1.25rem;left:1.25rem;z-index:10;display:inline-flex;align-items:center;gap:8px;min-height:40px;padding:0 14px;border-radius:12px;border:1px solid #cfd8e6;background:#fff;color:#0f172a;font-size:14px;font-weight:600;text-decoration:none;box-shadow:0 8px 20px #0f172a0f;transition:border-color .2s ease,background-color .2s ease,color .2s ease}.login-home-link:hover{border-color:color-mix(in srgb,#2d7fc7 35%,#cfd8e6);color:#2d7fc7;background:#f8fbff}.login-home-link:focus-visible{outline:2px solid #2d7fc7;outline-offset:2px}.login-form{display:grid;width:100%;gap:16px}.login-card{display:grid;width:min(100%,380px);gap:16px;padding:32px 28px;border-radius:16px;background:#fff;border:1px solid #cfd8e6;box-shadow:0 20px 48px #0f172a16}.login-form__brand{display:flex;flex-direction:column;align-items:center;gap:.85rem;margin-bottom:.25rem;text-align:center}.login-form__logo{width:min(100%,140px);height:auto}.ogta-logo-link{display:inline-flex;position:relative;z-index:2;line-height:0;border-radius:8px;cursor:pointer;pointer-events:auto;transition:opacity .2s ease}.ogta-logo-link img{pointer-events:none}.ogta-logo-link:hover{opacity:.85}.ogta-logo-link:focus-visible{outline:2px solid #2d7fc7;outline-offset:4px}.login-form__brand h1{margin:0;font-size:1.35rem;font-weight:800;letter-spacing:-.02em;color:#0f172a}.login-field.login-field{gap:7px}.login-field-control.field-control{min-height:42px;padding:0 14px;border-radius:12px;border-color:#cfd8e6;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.login-field-control:focus-within{border-color:color-mix(in srgb,#2d7fc7 55%,#cfd8e6);box-shadow:0 0 0 3px #2d7fc71f}.login-form .primary-action.login-submit{margin-top:6px;height:42px;border-radius:12px;font-size:14px;font-weight:700;border:none;background:linear-gradient(135deg,#2d7fc7,color-mix(in srgb,#3550a3 88%,#1a2a48));box-shadow:0 4px 16px #2d7fc73d}.login-form .primary-action.login-submit:hover:not(:disabled){filter:brightness(1.03)}.login-footer-link{margin:0;text-align:center;font-size:.9rem}.login-footer-link a{color:#c27803;text-decoration:none}.login-footer-link a:hover{text-decoration:underline}.login-panel--solo{width:min(100%,28rem);margin:0 auto}.login-subcopy{margin:.35rem 0 0;color:#64748b;font-size:.92rem}@media(max-width:480px){.login-home-link{top:1rem;left:1rem;min-height:36px;padding:0 12px;font-size:13px}.login-card{padding:28px 22px}}.maintenance-page{display:grid;min-height:100vh;place-items:center;padding:24px}.maintenance-panel{display:grid;justify-items:center;width:min(100%,560px);gap:14px;padding:34px;border:1px solid var(--line);border-radius:8px;background:#fffdf8f2;box-shadow:var(--shadow);text-align:center}.maintenance-icon{display:grid;width:66px;height:66px;place-items:center;border-radius:8px;color:#fff;background:linear-gradient(135deg,var(--sky),var(--green))}.maintenance-panel h1{margin:0;font-size:31px}.maintenance-panel p{margin:0;color:var(--muted);font-size:14px;line-height:1.65}.maintenance-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:4px}.support-contact-pane .sa-contact-meta{padding:12px;border-radius:12px;border:1px solid rgba(249,165,27,.25);background:#fac95a1f}.support-contact-pane .sa-contact-meta span{display:block;font-size:11px;font-weight:700;text-transform:uppercase;color:var(--sa-muted)}.support-contact-pane .sa-contact-meta strong{display:block;margin-top:4px;font-size:13px}.guidance-dashboard .observation-list{display:grid;gap:8px}.guidance-dashboard .observation-row{padding:12px;border:1px solid var(--line);border-radius:12px;background:#fbfdff}.guidance-dashboard .observation-row strong{display:block;font-size:13px}.guidance-dashboard .observation-row span,.guidance-dashboard .observation-row small{color:var(--muted);font-size:11px}.guidance-dashboard .observation-row p{margin:9px 0;color:var(--ink);font-size:12px;line-height:1.55}.guardian-dashboard .guardian-child-card{display:flex;align-items:center;justify-content:space-between;padding:18px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(135deg,#fff,#eef7fb);box-shadow:0 8px 22px #26374d0e}.guardian-dashboard .guardian-child-card span,.guardian-dashboard .guardian-child-card p{color:var(--muted);font-size:12px}.guardian-dashboard .guardian-child-card h2{margin:5px 0}.guardian-dashboard .guardian-attendance strong{display:block;font-size:2rem;color:var(--green-strong)}.guardian-dashboard .guardian-attendance span,.guardian-dashboard .guardian-attendance p{color:var(--muted);font-size:12px;line-height:1.5}.principal-dashboard .class-status-list{display:grid;gap:8px}.principal-dashboard .class-status-row{display:grid;grid-template-columns:.55fr .7fr .55fr .8fr;align-items:center;gap:12px;padding:10px;border:1px solid var(--line);border-radius:10px;background:#fbfdff}.principal-dashboard .class-status-row strong{display:block;font-size:12.5px;font-weight:700}.principal-dashboard .class-status-row span,.principal-dashboard .class-status-row small,.principal-dashboard .class-status-row em{color:var(--muted);font-size:11px;font-style:normal}@media(max-width:720px){.principal-dashboard .class-status-row{grid-template-columns:1fr}}.teacher-dashboard .active-lesson-card,.teacher-dashboard .attendance-row{display:flex;align-items:center}.teacher-dashboard .active-lesson-card{justify-content:space-between;gap:12px;padding:12px;border-radius:12px;background:#eef7fb}.teacher-dashboard .active-lesson-card span{display:block;color:var(--muted);font-size:11px}.teacher-dashboard .active-lesson-card strong{display:block;margin-top:3px;font-size:13px}.teacher-dashboard .attendance-board{display:grid;gap:8px;margin-top:12px}.teacher-dashboard .attendance-row{justify-content:space-between;gap:12px;padding:10px;border:1px solid var(--line);border-radius:10px;background:#fbfdff}.teacher-dashboard .attendance-row strong{display:block;font-size:12.5px;font-weight:700}.teacher-dashboard .attendance-actions{display:flex;flex-wrap:wrap;gap:5px;justify-content:flex-end}.teacher-dashboard .attendance-status{min-height:30px;padding:0 9px;border:1px solid var(--line);border-radius:8px;color:var(--muted);background:#fff;font-size:11px}.teacher-dashboard .attendance-status.active{color:#fff;border-color:var(--green);background:var(--green)}.teacher-dashboard .observation-form{display:grid;gap:10px}.teacher-dashboard .observation-form label{display:grid;gap:6px;color:var(--muted);font-size:11px;font-weight:700}.teacher-dashboard .observation-form select,.teacher-dashboard .observation-form textarea{min-height:38px;border:1px solid var(--line);border-radius:9px;padding:9px 10px;background:#fff}@media(max-width:720px){.teacher-dashboard .attendance-row{align-items:stretch;flex-direction:column}}.role-shell{min-height:100vh;padding:18px;background:#f5f8fb;color:var(--ink)}.role-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;max-width:1320px;margin:0 auto 16px;padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:#ffffffeb;box-shadow:0 8px 22px #26374d0f}.role-brand,.role-top-actions,.role-profile,.token-card,.role-card header div,.lesson-row,.compact-row{display:flex;align-items:center}.role-brand{gap:10px}.role-brand>span{width:36px;height:36px;display:grid;place-items:center;border-radius:11px;color:#fff;background:#2d7fc7}.role-brand strong,.role-profile strong{display:block;font-size:13px;font-weight:700}.role-brand small,.role-profile span{display:block;margin-top:2px;color:var(--muted);font-size:11px}.role-top-actions{gap:10px}.role-profile{flex-direction:column;align-items:flex-end}.role-logout{min-height:36px;color:#b42318;border-color:#b423182e;background:#fff7f6}.role-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;max-width:1320px;margin:0 auto 16px;padding:22px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,rgba(45,127,199,.12),transparent 36%),linear-gradient(225deg,rgba(20,146,127,.1),transparent 42%),#fff}.role-kicker{color:var(--green-strong);font-size:11px;font-weight:700;text-transform:uppercase}.role-hero h1{margin:6px 0 8px;font-size:1.45rem;line-height:1.18}.role-hero p{max-width:680px;margin:0;color:var(--muted);font-size:13px;line-height:1.55}.token-card{min-width:210px;gap:10px;padding:11px 12px;border:1px solid rgba(20,146,127,.18);border-radius:13px;background:#effaf7;color:var(--green-strong)}.token-card strong{display:block;font-size:12px}.token-card span{display:block;margin-top:2px;color:var(--muted);font-size:11px}.role-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.34fr);gap:16px;max-width:1320px;margin:0 auto;align-items:start}.role-main-column,.role-side-column{display:grid;gap:16px}.role-metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.role-metric,.role-card{border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:0 8px 22px #26374d0e}.role-metric{padding:14px}.role-metric span{width:34px;height:34px;display:grid;place-items:center;border-radius:10px;color:var(--green-strong);background:#e8f7f4}.role-metric small{display:block;margin-top:12px;color:var(--muted);font-size:11px}.role-metric strong{display:block;margin-top:4px;font-size:1.3rem}.role-card{padding:14px}.role-card header{margin-bottom:12px}.role-card header div{gap:8px}.role-card h2{margin:0;font-size:14px}.lesson-list,.compact-list{display:grid;gap:8px}.lesson-row,.compact-row{justify-content:space-between;gap:12px;padding:10px;border:1px solid var(--line);border-radius:10px;background:#fbfdff}.lesson-row strong,.compact-row strong{display:block;font-size:12.5px;font-weight:700}.lesson-row span,.compact-row span{color:var(--muted);font-size:11px}.lesson-row small{color:var(--green-strong);font-size:11px;font-weight:700;white-space:nowrap}.role-alert{max-width:1320px;margin:0 auto 12px;padding:11px 13px;border:1px solid rgba(20,146,127,.18);border-radius:10px;background:#effaf7;color:var(--green-strong);font-size:12px}.role-alert--inline{max-width:none;margin:10px 0 0}.role-alert--warn{border-color:#d89b2247;background:#fff8e8;color:#8a5a09}.role-empty{margin:0;color:var(--muted);font-size:12px}.role-support-panel{max-width:1320px;margin:16px auto 0}@media(max-width:1100px){.role-grid{grid-template-columns:1fr}.role-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.role-shell{padding:10px}.role-topbar,.role-hero{align-items:stretch;flex-direction:column}.role-top-actions{justify-content:space-between}.role-profile{align-items:flex-start}.role-metric-grid{grid-template-columns:1fr}}.notice-list{display:flex;flex-direction:column;gap:.55rem}.notice-row{display:grid;grid-template-columns:auto 1fr;gap:.65rem;padding:.65rem .75rem;border-radius:12px;background:#f8faf9;border:1px solid #e8ecea}.notice-row.is-read{opacity:.72}.notice-row.is-clickable{cursor:pointer}.notice-row.is-clickable:hover{border-color:#f9a51b;background:#fffaf2}.notice-row>span{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:999px;background:#fff;color:#64748b}.notice-row--warning>span{color:#d97706;background:#fff7ed}.notice-row--success>span{color:#059669;background:#ecfdf5}.notice-row strong{display:block;font-size:.92rem}.notice-row p{margin:.15rem 0 0;color:#64748b;font-size:.84rem;line-height:1.45}.notification-bell{position:relative}.notification-bell-trigger{position:relative;display:inline-flex;align-items:center;justify-content:center;width:2.35rem;height:2.35rem;border-radius:999px;border:1px solid #e5e7eb;background:#fff;color:#334155;cursor:pointer}.notification-bell-trigger:hover{border-color:#f9a51b;color:#c27803}.notification-bell-badge{position:absolute;top:-.2rem;right:-.15rem;min-width:1.1rem;height:1.1rem;padding:0 .25rem;border-radius:999px;background:#ef4444;color:#fff;font-size:.65rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.notification-bell-panel{position:absolute;top:calc(100% + .55rem);right:0;width:min(22rem,88vw);max-height:24rem;overflow:auto;padding:.85rem;border-radius:16px;border:1px solid #e5e7eb;background:#fff;box-shadow:0 18px 40px #0f172a1f;z-index:40}.notification-bell-panel header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.65rem}.notification-bell-panel header strong{font-size:.95rem}.notification-bell-panel header small{color:#64748b}.guidance-console{--guidance-sky: #2d7fc7;--guidance-emerald: #0f8b68;--guidance-amber: #d98214;--guidance-violet: #7566b5;--guidance-rose: #b91c1c}.guidance-main,.guidance-page-stack{display:grid;gap:14px}.guidance-page-title{display:flex;flex-direction:column;gap:4px}.guidance-page-title h1{margin:0;font-size:1.45rem;font-weight:700;letter-spacing:-.02em;color:var(--sa-ink)}.guidance-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.guidance-kpi-card{padding:10px 12px 10px 14px;min-height:100px}.guidance-kpi-card .principal-stat-icon{width:34px;height:34px;border-radius:10px}.guidance-kpi-card small{margin-top:9px;font-size:9.5px}.guidance-kpi-card strong{margin-top:5px;font-size:clamp(1.1rem,1.8vw,1.45rem);font-weight:700;letter-spacing:-.02em}.guidance-kpi-card em{margin-top:5px;font-size:11px}.guidance-overview-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(300px,.92fr);gap:12px;align-items:start}.guidance-overview-grid--secondary{grid-template-columns:repeat(2,minmax(0,1fr))}.guidance-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.guidance-card-head h2{margin:2px 0 0;font-size:1rem;font-weight:700;letter-spacing:-.01em}.guidance-card-head p{margin:5px 0 0;color:var(--sa-muted);font-size:12px;line-height:1.45}.guidance-observation-list,.guidance-risk-list,.guidance-student-list,.guidance-plan-list,.guidance-announcement-list{display:grid;gap:8px}.guidance-observation-row,.guidance-announcement-row{display:grid;gap:8px;padding:11px 12px;border:1px solid var(--sa-border);border-radius:12px;background:var(--sa-tint-cream)}.guidance-observation-main{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.guidance-observation-row strong,.guidance-risk-row strong,.guidance-student-row strong,.guidance-plan-row strong,.guidance-announcement-row strong{display:block;color:var(--sa-ink);font-size:13px;font-weight:600}.guidance-observation-row span,.guidance-risk-row span,.guidance-student-row span,.guidance-plan-row span,.guidance-announcement-row span{display:block;margin-top:3px;color:var(--sa-muted);font-size:11.5px;line-height:1.35}.guidance-observation-row p,.guidance-risk-row p,.guidance-announcement-row p{margin:0;color:var(--sa-ink);font-size:12px;line-height:1.45}.guidance-observation-row small,.guidance-risk-row small,.guidance-student-row small,.guidance-plan-row small{color:var(--sa-muted);font-size:11px}.guidance-risk-row{display:grid;grid-template-columns:40px minmax(0,1fr) 82px;gap:10px;align-items:start;padding:11px 12px;border:1px solid var(--sa-border);border-radius:12px;background:var(--sa-tint-cream)}.guidance-risk-row--high{border-color:#b91c1c38;background:linear-gradient(90deg,#ef444414,#fff)}.guidance-risk-row--medium{border-color:color-mix(in srgb,var(--sa-accent-mid) 28%,var(--sa-border));background:linear-gradient(90deg,color-mix(in srgb,var(--sa-accent) 9%,transparent),var(--sa-surface))}.guidance-risk-row--low{border-color:#0f8b6833;background:linear-gradient(90deg,#0f8b6812,#fff)}.guidance-risk-icon{display:grid;width:40px;height:40px;place-items:center;border-radius:12px;color:var(--guidance-amber);background:color-mix(in srgb,var(--sa-accent) 16%,transparent)}.guidance-risk-row--high .guidance-risk-icon{color:var(--guidance-rose);background:#ef44441f}.guidance-risk-row small{text-align:right;font-weight:700;line-height:1.45}.guidance-student-row,.guidance-plan-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 12px;border:1px solid var(--sa-border);border-radius:12px;background:var(--sa-tint-cream)}.guidance-student-meta,.guidance-plan-meta{display:grid;justify-items:end;gap:5px;min-width:100px}.guidance-toolbar{display:grid;gap:10px;margin-bottom:12px}.guidance-toolbar-fields{display:grid;grid-template-columns:minmax(140px,180px) minmax(140px,180px) minmax(220px,1fr);gap:10px}.guidance-filter-row{display:flex;flex-wrap:wrap;gap:8px}.guidance-filter-chip{min-height:34px;border:1px solid var(--sa-border);border-radius:11px;background:#fff;color:var(--sa-muted);padding:0 11px;font:inherit;font-size:12px;font-weight:600;cursor:pointer}.guidance-filter-chip.is-active,.guidance-filter-chip:hover{color:var(--sa-accent-deep);border-color:color-mix(in srgb,var(--sa-accent) 45%,var(--sa-border));background:var(--sa-tint-warm)}.guidance-toolbar-fields input,.guidance-toolbar-fields select,.guidance-toolbar input{min-height:36px;border:1px solid var(--sa-border);border-radius:11px;background:#fff;color:var(--sa-ink);padding:0 11px;font:inherit;font-size:12px}.guidance-announcement-row p{margin-top:2px}.guidance-empty-pad{padding:10px 0}.guidance-console .support-contact-pane{max-width:820px}@media(max-width:1180px){.guidance-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.guidance-overview-grid,.guidance-overview-grid--secondary{grid-template-columns:1fr}}@media(max-width:760px){.guidance-kpi-grid,.guidance-toolbar{grid-template-columns:1fr}.guidance-card-head,.guidance-observation-main,.guidance-student-row,.guidance-plan-row{align-items:flex-start;flex-direction:column}.guidance-risk-row{grid-template-columns:1fr}.guidance-risk-row small,.guidance-student-meta,.guidance-plan-meta{justify-items:start;text-align:left}}.guardian-console{--guardian-sky: #2d7fc7;--guardian-emerald: #0f8b68;--guardian-amber: #d98214;--guardian-violet: #7566b5}.guardian-main,.guardian-page-stack{display:grid;gap:14px}.guardian-page-title{display:flex;flex-direction:column;gap:4px}.guardian-page-title h1{margin:0;font-size:1.45rem;font-weight:700;letter-spacing:-.02em;color:var(--sa-ink)}.guardian-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.guardian-kpi-card{padding:10px 12px 10px 14px;min-height:100px}.guardian-kpi-card .principal-stat-icon{width:34px;height:34px;border-radius:10px}.guardian-kpi-card small{margin-top:9px;font-size:9.5px}.guardian-kpi-card strong{margin-top:5px;font-size:clamp(1.1rem,1.8vw,1.45rem);font-weight:700;letter-spacing:-.02em}.guardian-kpi-card em{margin-top:5px;font-size:11px}.guardian-overview-grid,.guardian-child-layout{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(300px,.95fr);gap:12px;align-items:start}.guardian-overview-grid--secondary{grid-template-columns:repeat(2,minmax(0,1fr))}.guardian-focus-card{min-height:260px}.guardian-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.guardian-card-head h2{margin:2px 0 0;font-size:1rem;font-weight:700;letter-spacing:-.01em}.guardian-card-head p{margin:5px 0 0;color:var(--sa-muted);font-size:12px;line-height:1.45}.guardian-child-card{display:grid;grid-template-columns:58px minmax(0,1fr) auto;gap:12px;align-items:center;padding:13px;border:1px solid var(--sa-border);border-radius:14px;background:linear-gradient(135deg,var(--sa-surface),var(--sa-surface-tint))}.guardian-child-card--compact{grid-template-columns:46px minmax(0,1fr) auto;padding:11px}.guardian-child-avatar{display:grid;width:58px;height:58px;place-items:center;border-radius:16px;color:var(--sa-ink)}.guardian-child-card--compact .guardian-child-avatar{width:46px;height:46px;border-radius:14px}.guardian-child-avatar--amber{background:linear-gradient(145deg,var(--sa-accent-2),var(--sa-accent))}.guardian-child-avatar--sky{background:linear-gradient(145deg,#93c5fd,#3b82f6)}.guardian-child-avatar--emerald{background:linear-gradient(145deg,#86efac,#10b981)}.guardian-child-info span{display:block;color:var(--sa-muted);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.guardian-child-info strong{display:block;margin-top:4px;color:var(--sa-ink);font-size:1.05rem;font-weight:700}.guardian-child-info small{display:block;margin-top:3px;color:var(--sa-muted);font-size:11.5px}.guardian-child-status{display:inline-flex;align-items:center;gap:5px;color:var(--guardian-emerald);font-size:11.5px;font-weight:700}.guardian-notice-list,.guardian-lesson-list,.guardian-attendance-list,.guardian-announcement-list,.guardian-scope-list{display:grid;gap:8px}.guardian-notice-list{margin-top:12px}.guardian-notice-row{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;align-items:start;padding:10px;border:1px solid var(--sa-border);border-radius:12px;background:var(--sa-tint-cream)}.guardian-notice-row>span{display:grid;width:34px;height:34px;place-items:center;border-radius:10px;background:color-mix(in srgb,var(--sa-accent) 16%,transparent);color:var(--sa-ink)}.guardian-notice-row--info>span{background:#2d7fc71f;color:var(--guardian-sky)}.guardian-notice-row--success>span{background:#0f8b681f;color:var(--guardian-emerald)}.guardian-notice-row--warning>span{background:color-mix(in srgb,var(--sa-accent-mid) 20%,transparent);color:var(--sa-accent-deep)}.guardian-notice-row strong,.guardian-lesson-body strong,.guardian-attendance-row strong,.guardian-announcement-row strong,.guardian-scope-list strong{display:block;color:var(--sa-ink);font-size:13px;font-weight:600}.guardian-notice-row p{margin:3px 0 0;color:var(--sa-muted);font-size:11.5px;line-height:1.4}.guardian-lesson-row{display:grid;grid-template-columns:70px minmax(0,1fr) minmax(120px,.45fr);gap:10px;align-items:center;min-height:58px;padding:9px 10px;border:1px solid var(--sa-border);border-radius:12px;background:var(--sa-tint-cream)}.guardian-lesson-time{display:grid;gap:2px;padding:7px;border:1px solid rgba(219,219,217,.75);border-radius:10px;background:#fff;text-align:center;font-variant-numeric:tabular-nums}.guardian-lesson-time strong{font-size:12px;font-weight:700}.guardian-lesson-time span{color:var(--sa-muted);font-size:10.5px}.guardian-lesson-body span,.guardian-attendance-row span,.guardian-announcement-row span{display:block;margin-top:3px;color:var(--sa-muted);font-size:11.5px;line-height:1.35}.guardian-lesson-meta{display:grid;justify-content:end;gap:4px}.guardian-lesson-meta span{display:inline-flex;align-items:center;justify-content:flex-end;gap:5px;color:var(--sa-muted);font-size:11px}.guardian-attendance-row,.guardian-announcement-row,.guardian-scope-list>div{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:11px 12px;border:1px solid var(--sa-border);border-radius:12px;background:var(--sa-tint-cream)}.guardian-attendance-row .status-badge{gap:5px}.guardian-announcement-row{align-items:flex-start;flex-direction:column}.guardian-announcement-row p{margin:0;color:var(--sa-ink);font-size:12px;line-height:1.45}.guardian-scope-list{grid-template-columns:repeat(2,minmax(0,1fr))}.guardian-scope-list>div{justify-content:flex-start;align-items:flex-start;flex-direction:column}.guardian-scope-list svg{color:var(--sa-accent)}.guardian-scope-list span{color:var(--sa-muted);font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.guardian-empty-pad{padding:10px 0}.guardian-console .support-contact-pane{max-width:820px}@media(max-width:1180px){.guardian-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.guardian-overview-grid,.guardian-child-layout,.guardian-overview-grid--secondary{grid-template-columns:1fr}}@media(max-width:720px){.guardian-kpi-grid,.guardian-scope-list{grid-template-columns:1fr}.guardian-card-head{align-items:flex-start;flex-direction:column}.guardian-child-card,.guardian-child-card--compact,.guardian-lesson-row,.guardian-attendance-row{grid-template-columns:1fr}.guardian-attendance-row{align-items:flex-start;flex-direction:column}.guardian-lesson-meta{justify-content:start}.guardian-lesson-meta span{justify-content:flex-start}}.principal-attendance-page{gap:12px}.principal-attendance-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.principal-attendance-stat{display:grid;grid-template-columns:30px minmax(0,1fr);grid-template-rows:auto auto auto;column-gap:10px;min-height:78px;padding:10px 12px;border-radius:12px;border:1px solid var(--sa-border);background:#fff;box-shadow:0 4px 14px #1622350b}.principal-attendance-stat svg{grid-row:1 / 4;width:30px;height:30px;padding:7px;border-radius:9px;box-sizing:border-box}.principal-attendance-stat--sky svg{color:#1d4ed8;background:#38bdf82e}.principal-attendance-stat--emerald svg{color:#047857;background:#10b98129}.principal-attendance-stat--rose svg{color:#b91c1c;background:#f43f5e24}.principal-attendance-stat--amber svg{color:#b45309;background:#fbbf2433}.principal-attendance-stat span{font-size:9px;font-weight:600;letter-spacing:.04em;color:var(--sa-muted);text-transform:uppercase}.principal-attendance-stat strong{margin-top:2px;font-size:1.18rem;font-weight:700}.principal-attendance-stat small{margin-top:2px;font-size:10.5px;color:var(--sa-muted)}.principal-attendance-controls{display:grid;grid-template-columns:minmax(240px,1fr) auto auto auto;gap:8px;align-items:center}.principal-attendance-search,.principal-attendance-controls select,.principal-attendance-date input{min-height:34px;border-radius:9px;border:1px solid var(--sa-border);background:#fff}.principal-attendance-search{display:flex;align-items:center;gap:7px;padding:0 10px}.principal-attendance-search svg{color:var(--sa-muted)}.principal-attendance-search input{flex:1;min-width:0;border:none;outline:none;background:transparent;font:inherit;font-size:12px}.principal-attendance-controls select,.principal-attendance-date input{padding:0 10px;font:inherit;font-size:12px}.principal-attendance-table-card{padding:10px;border-radius:13px;box-shadow:0 4px 14px #1622350b}.principal-attendance-table-card .principal-table-wrap{border-radius:10px}.principal-attendance-section-table,.principal-attendance-student-table{min-width:760px}.principal-attendance-section-table th,.principal-attendance-section-table td,.principal-attendance-student-table th,.principal-attendance-student-table td{padding:7px 9px;font-size:11.5px}.principal-attendance-section-table th,.principal-attendance-student-table th{font-size:9px;font-weight:600;letter-spacing:.045em}.principal-attendance-section-name{display:inline-grid;gap:2px}.principal-attendance-section-name strong{font-size:12px;font-weight:700}.principal-attendance-section-name small{font-size:10.5px;color:var(--sa-muted)}.principal-attendance-pill,.principal-attendance-status{display:inline-flex;align-items:center;justify-content:center;gap:5px;min-width:30px;padding:3px 7px;border-radius:999px;font-size:10px;font-weight:700}.principal-attendance-pill--present,.principal-attendance-status--present{color:#047857;background:#10b98129}.principal-attendance-pill--absent,.principal-attendance-status--absent{color:#b91c1c;background:#f43f5e24}.principal-attendance-status svg{width:14px;height:14px}.principal-attendance-open.ghost-action:not(.navbar-logout){min-height:30px;height:30px;padding:0 10px;border-radius:8px;font-size:11px;font-weight:600}.principal-attendance-detail-head{display:flex;align-items:center;gap:10px;min-height:44px}.principal-attendance-back.ghost-action:not(.navbar-logout){width:32px;min-width:32px;height:32px;min-height:32px;padding:0;border-radius:9px;color:var(--sa-muted);background:#fff}.principal-attendance-detail-head h1{margin:0;font-size:clamp(1.55rem,3vw,2.25rem);font-weight:700;letter-spacing:-.015em}.principal-attendance-date{display:inline-flex;align-items:center;gap:8px;margin-left:auto}.principal-attendance-date span{font-size:10px;color:var(--sa-muted);font-weight:700;text-transform:uppercase}.principal-attendance-number{font-size:11px;padding:2px 6px;border-radius:7px;background:#2d7fc714;color:var(--sky, #2d7fc7);font-weight:500}@media(max-width:1100px){.principal-attendance-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.principal-attendance-controls{grid-template-columns:1fr 1fr}.principal-attendance-search{grid-column:1 / -1}}@media(max-width:700px){.principal-attendance-stats,.principal-attendance-controls{grid-template-columns:1fr}.principal-attendance-detail-head{flex-wrap:wrap}.principal-attendance-date{width:100%;margin-left:0}}.principal-class-detail{gap:12px}.principal-class-detail-hero{margin-bottom:2px}.principal-class-detail-title-row{display:flex;align-items:center;gap:10px;min-height:44px;flex-wrap:nowrap}.principal-class-detail-back-icon.ghost-action:not(.navbar-logout){width:32px;min-width:32px;height:32px;min-height:32px;padding:0;border-radius:9px;color:var(--sa-muted);background:#fff}.principal-class-detail-back-icon.ghost-action:not(.navbar-logout):hover{color:var(--ink, #162235)}.principal-class-detail-title-icon{width:38px;height:38px;border-radius:11px;background:#2d7fc71a;color:var(--sky, #2d7fc7)}.principal-class-detail-title{margin:0;font-size:clamp(1.45rem,2.8vw,2.05rem);font-weight:700;letter-spacing:-.015em;line-height:1.08;color:var(--ink, #162235)}.principal-class-detail-add.primary-action{margin-left:auto;height:36px;min-height:36px;padding:0 12px;border-radius:9px;gap:6px;font-size:12px;font-weight:600;white-space:nowrap}.principal-class-detail-add.primary-action svg{width:15px;height:15px}.principal-class-detail-card{padding:12px;border-radius:13px;box-shadow:0 4px 14px #1622350b}.principal-class-detail-card .principal-card-head{margin-bottom:10px}.principal-class-detail-card .principal-card-head h2{font-size:1rem;font-weight:700}.principal-class-detail-card .principal-table-wrap{border-radius:10px}.principal-class-detail-card .principal-table th,.principal-class-detail-card .principal-table td{padding:8px 9px;font-size:11.5px}.principal-class-detail-card .principal-table th{font-size:9px;font-weight:600;letter-spacing:.045em}.principal-class-detail-card .principal-table-actions{gap:5px}.principal-class-detail-card .principal-table-actions .ghost-action:not(.navbar-logout){min-height:30px;height:30px;padding:0 10px;border-radius:8px;font-size:11px;font-weight:600}.principal-section-name{display:inline-grid;gap:2px}.principal-section-name strong{font-size:12.5px;font-weight:700}.principal-section-name small{font-size:10.5px;color:var(--sa-muted)}.principal-section-count{display:inline-flex;align-items:center;gap:5px;padding:3px 7px;border-radius:999px;color:#047857;background:#10b98124;font-size:11px;font-weight:700}.principal-section-advisor{display:inline-flex;max-width:190px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink, #162235);font-weight:500}.principal-section-advisor--empty{color:var(--sa-muted);font-weight:500}.principal-section-action.ghost-action:not(.navbar-logout){gap:5px}.principal-section-action--icon.ghost-action:not(.navbar-logout){width:30px;min-width:30px;padding:0}.principal-section-form-modal{width:min(100%,520px)}.principal-section-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px}@media(max-width:640px){.principal-class-detail-title-row{flex-wrap:wrap}.principal-class-detail-add.primary-action{width:100%;margin-left:0}.principal-section-form-grid{grid-template-columns:1fr}}.principal-section-students-page{gap:12px}.principal-section-students-hero{margin-bottom:2px}.principal-section-students-title-row{display:flex;align-items:center;gap:10px;min-height:44px}.principal-section-students-back.ghost-action:not(.navbar-logout){width:32px;min-width:32px;height:32px;min-height:32px;padding:0;border-radius:9px;color:var(--sa-muted);background:#fff}.principal-section-students-title-row h1{margin:0;font-size:clamp(1.65rem,3.2vw,2.35rem);font-weight:700;letter-spacing:-.015em;color:var(--ink, #162235)}.principal-section-students-add.primary-action{margin-left:auto;height:36px;min-height:36px;padding:0 12px;border-radius:9px;gap:6px;font-size:12px;font-weight:600;white-space:nowrap}.principal-section-students-controls{display:grid;grid-template-columns:minmax(240px,1fr) auto auto;gap:8px;align-items:center}.principal-section-students-search,.principal-section-students-controls select,.principal-section-students-modal-search{min-height:34px;border-radius:9px;border:1px solid var(--sa-border);background:#fff}.principal-section-students-search,.principal-section-students-modal-search{display:flex;align-items:center;gap:7px;padding:0 10px}.principal-section-students-search svg,.principal-section-students-modal-search svg{color:var(--sa-muted)}.principal-section-students-search input,.principal-section-students-modal-search input{flex:1;min-width:0;border:none;outline:none;background:transparent;font:inherit;font-size:12px}.principal-section-students-controls select{min-width:150px;padding:0 10px;font:inherit;font-size:12px}.principal-section-students-card{padding:10px;border-radius:13px;box-shadow:0 4px 14px #1622350b}.principal-section-students-card .principal-table-wrap{border-radius:10px}.principal-section-students-table{min-width:760px}.principal-section-students-table th,.principal-section-students-table td{padding:7px 9px;font-size:11.5px}.principal-section-students-table th{font-size:9px;font-weight:600;letter-spacing:.045em}.principal-section-student-number{font-size:11px;padding:2px 6px;border-radius:7px;background:#2d7fc714;color:var(--sky, #2d7fc7);font-weight:500}.principal-section-student-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 7px;border-radius:999px;font-size:9.5px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.principal-section-student-badge--active{color:#047857;background:#10b98129}.principal-section-student-badge--passive{color:#9f1239;background:#f43f5e24}.principal-assign-students-modal{width:min(100%,600px)}.principal-section-students-modal-search{margin-bottom:12px}.principal-assign-list{display:grid;gap:7px;max-height:min(50vh,420px);overflow:auto;padding-right:2px}.principal-assign-row{display:grid;grid-template-columns:18px minmax(0,1fr);gap:9px;align-items:center;padding:9px 10px;border-radius:10px;border:1px solid var(--sa-border);background:#fff;cursor:pointer}.principal-assign-row:hover{background:var(--sa-tint-warm)}.principal-assign-row input{width:15px;height:15px}.principal-assign-row strong{display:block;font-size:12px;font-weight:600}.principal-assign-row small{display:block;margin-top:2px;font-size:10.5px;color:var(--sa-muted)}@media(max-width:760px){.principal-section-students-title-row{flex-wrap:wrap}.principal-section-students-add.primary-action{width:100%;margin-left:0}.principal-section-students-controls{grid-template-columns:1fr}}.principal-classes-only{gap:12px;padding-top:0}.principal-classes-controls{display:grid;grid-template-columns:minmax(240px,1fr) auto auto;gap:8px;align-items:center}.principal-classes-search,.principal-classes-select{display:flex;align-items:center;gap:7px;min-height:34px;padding:0 10px;border-radius:9px;border:1px solid var(--sa-border);background:#fff}.principal-classes-search svg,.principal-classes-select svg{width:15px;height:15px;color:var(--sa-muted)}.principal-classes-search input,.principal-classes-select select{min-width:0;border:none;outline:none;background:transparent;font:inherit;font-size:12px}.principal-classes-search input{width:100%}.principal-classes-select select{min-width:142px}.principal-classes-card-row.sa-inst-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;align-items:stretch}.principal-class-card-slot.sa-inst-card{min-height:156px;border-radius:13px;padding:13px;gap:10px;box-shadow:0 4px 14px #1622350b}.principal-class-card-slot.sa-inst-card:hover{transform:translateY(-1px);box-shadow:0 10px 22px #16223514}.principal-add-class-card.sa-inst-card--add{align-items:stretch;justify-content:flex-start;text-align:left;border:1px dashed color-mix(in srgb,var(--sa-accent) 55%,var(--sa-border));background:var(--sa-tint-cream)}.principal-add-class-card.sa-inst-card--add:hover{background:var(--sa-tint-warm);box-shadow:0 10px 22px color-mix(in srgb,var(--sa-accent) 14%,transparent)}.principal-add-class-card .sa-inst-card-add-icon{width:34px;height:34px;border-radius:10px;box-shadow:0 8px 16px color-mix(in srgb,var(--sa-accent) 22%,transparent)}.principal-add-class-card.sa-inst-card--add strong{font-size:13px;font-weight:700}.principal-add-class-card.sa-inst-card--add span{max-width:none;font-size:11px}.principal-add-class-hint{margin-top:-4px;line-height:1.35}.principal-add-class-form{margin-top:auto;grid-template-columns:minmax(0,1fr) auto;gap:7px}.principal-add-class-form input{width:100%;min-width:0;min-height:34px;border-radius:9px;font-size:12px}.principal-add-class-form .primary-action{min-width:48px;min-height:34px;height:34px;padding:0 10px;border-radius:9px;font-size:12px;font-weight:600}.principal-class-card.sa-inst-card{position:relative;background:#fff;cursor:pointer}.principal-class-card-delete.ghost-action:not(.navbar-logout){position:absolute;top:8px;right:8px;z-index:2;width:28px;min-width:28px;height:28px;min-height:28px;padding:0;border-radius:8px;background:#fff;box-shadow:0 2px 8px #16223514}.principal-class-card-delete.ghost-action:not(.navbar-logout):hover{background:#fff5f5}.principal-class-card .sa-inst-card-band{height:3px;background:linear-gradient(90deg,#93c5fd,#2d7fc7)}.principal-class-card-title-block{gap:9px;margin-top:2px;min-height:40px}.principal-class-card-title-icon{width:34px;height:34px;border-radius:10px;background:#2d7fc71a;color:var(--sky, #2d7fc7)}.principal-class-card-title-text{font-size:clamp(1.28rem,2.6vw,1.7rem);font-weight:700;letter-spacing:-.01em}.principal-class-card-meta{margin-top:0;font-size:10.5px}.principal-class-card-stats.sa-inst-card-stats{gap:7px}.principal-class-card-stats.sa-inst-card-stats>div{gap:7px;padding:7px 8px;border-radius:9px;background:#fbfbfa}.principal-class-card-stats.sa-inst-card-stats svg{width:13px;height:13px}.principal-class-card-stats.sa-inst-card-stats span{font-size:8.5px;font-weight:600;letter-spacing:.035em}.principal-class-card-stats.sa-inst-card-stats strong{font-size:.95rem;font-weight:700}.principal-classes-empty{margin:0;padding:12px;border:1px dashed var(--sa-border);border-radius:12px;color:var(--sa-muted);background:#fff;font-size:12px;text-align:center}@media(max-width:900px){.principal-classes-controls{grid-template-columns:1fr 1fr}.principal-classes-search{grid-column:1 / -1}}@media(max-width:620px){.principal-classes-controls{grid-template-columns:1fr}.principal-classes-select select{width:100%}}.principal-schedule-page{gap:10px}.principal-schedule-page--overview{height:calc(100vh - 112px);min-height:590px;overflow:hidden;grid-template-rows:auto auto minmax(132px,1fr)}.principal-schedule-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.principal-schedule-stat{display:grid;grid-template-columns:30px minmax(0,1fr);grid-template-rows:auto auto auto;column-gap:10px;min-height:72px;padding:9px 11px;border-radius:12px;border:1px solid var(--sa-border);background:#fff;box-shadow:0 4px 14px #1622350b}.principal-schedule-stat svg{grid-row:1 / 4;width:30px;height:30px;padding:7px;border-radius:9px;box-sizing:border-box}.principal-schedule-stat--sky svg{color:#1d4ed8;background:#38bdf82e}.principal-schedule-stat--emerald svg{color:#047857;background:#10b98129}.principal-schedule-stat--amber svg{color:#b45309;background:#fbbf2433}.principal-schedule-stat--violet svg{color:#6d28d9;background:#a78bfa2e}.principal-schedule-stat span,.principal-schedule-card-head span,.principal-schedule-builder-head span{font-size:9px;font-weight:600;letter-spacing:.04em;color:var(--sa-muted);text-transform:uppercase}.principal-schedule-stat strong{margin-top:1px;font-size:1.1rem;font-weight:700}.principal-schedule-stat small{margin-top:1px;font-size:10px;color:var(--sa-muted)}.principal-schedule-panel{padding:11px;border-radius:13px;box-shadow:0 4px 14px #1622350b}.principal-schedule-card-head,.principal-schedule-load-head,.principal-schedule-board-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.principal-schedule-card-head h2,.principal-schedule-builder-head h1{margin:2px 0 0;font-size:14px;font-weight:700;color:var(--ink, #162235)}.principal-schedule-card-head>svg{color:var(--sky, #2d7fc7);flex-shrink:0}.principal-schedule-overview-main{display:grid;grid-template-columns:minmax(420px,max-content) minmax(280px,1fr);gap:10px;min-height:0}.principal-schedule-board-card,.principal-schedule-control-card,.principal-schedule-capacity-card,.principal-schedule-warning-card{min-height:0;overflow:hidden}.principal-schedule-board-card{width:min(100%,var(--schedule-card-max-width, 720px));justify-self:start}.principal-schedule-board-head{margin-bottom:8px}.principal-schedule-board-head>select{min-height:32px;min-width:180px;padding:0 9px;border-radius:9px;border:1px solid var(--sa-border);background:#fff;font:inherit;font-size:12px}.principal-schedule-board{display:grid;gap:4px;overflow:auto;max-height:var(--schedule-board-height, 280px);padding-bottom:2px}.principal-schedule-board-row{display:grid;grid-template-columns:84px repeat(var(--schedule-slot-count, 7),minmax(var(--schedule-cell-min, 88px),1fr));gap:4px;min-width:var(--schedule-board-min-width, 760px)}.principal-schedule-board-row--head>span,.principal-schedule-board-row>strong{display:grid;align-content:center;min-height:30px;padding:5px 6px;border-radius:8px;color:var(--sa-muted);background:#f8fafc;font-size:8.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.principal-schedule-board-row--head>span small{margin-top:1px;color:#64748b;font-size:8px;font-weight:500;text-transform:none;letter-spacing:0}.principal-schedule-slot{display:grid;align-content:center;min-height:50px;padding:6px;border-radius:8px;border:1px dashed #dbe3ee;background:#fff}.principal-schedule-slot.is-filled{border-style:solid;border-color:#2d7fc72e;background:linear-gradient(160deg,#eff6ffcc,#fff)}.principal-schedule-slot b{overflow:hidden;font-size:10px;font-weight:700;color:var(--ink, #162235);text-overflow:ellipsis;white-space:nowrap}.principal-schedule-slot span,.principal-schedule-slot small,.principal-schedule-slot em{margin-top:1px;overflow:hidden;color:var(--sa-muted);font-size:8.5px;font-style:normal;text-overflow:ellipsis;white-space:nowrap}.principal-schedule-board.is-editable .principal-schedule-board-row{grid-template-columns:92px repeat(var(--schedule-slot-count, 7),minmax(var(--schedule-cell-min, 118px),1fr))}.principal-schedule-board.is-editable .principal-schedule-slot{min-height:66px;padding:6px}.principal-schedule-control-card{display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:9px}.principal-schedule-refresh.primary-action,.principal-schedule-save.primary-action,.principal-schedule-generate.primary-action,.principal-schedule-reset.ghost-action:not(.navbar-logout),.principal-schedule-add.ghost-action:not(.navbar-logout),.principal-schedule-back.ghost-action:not(.navbar-logout){display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:34px;height:34px;padding:0 11px;border-radius:9px;font-size:12px;font-weight:600}.principal-schedule-refresh.primary-action,.principal-schedule-save.primary-action,.principal-schedule-generate.primary-action{width:100%}.principal-schedule-saved-list{display:grid;gap:7px;overflow:auto;min-height:0}.principal-schedule-saved-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:7px;align-items:center;padding:8px;border:1px solid var(--sa-border);border-radius:10px;background:#fff}.principal-schedule-saved-row strong{display:block;overflow:hidden;color:var(--ink, #162235);font-size:11.5px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.principal-schedule-saved-row span{display:block;margin-top:2px;color:var(--sa-muted);font-size:10px}.principal-schedule-state{justify-self:end;padding:3px 7px;border-radius:999px;font-size:9px;font-style:normal;font-weight:700;text-transform:uppercase}.principal-schedule-state--active{color:#047857;background:#10b98129}.principal-schedule-state--passive{color:#64748b;background:#f1f5f9}.principal-schedule-saved-actions{grid-column:1 / -1;display:flex;gap:6px}.principal-schedule-saved-actions .ghost-action:not(.navbar-logout){min-height:28px;height:28px;padding:0 8px;border-radius:8px;font-size:10.5px}.principal-schedule-delete.ghost-action:not(.navbar-logout){width:28px;min-width:28px;padding:0}.principal-schedule-bottom-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,.82fr);gap:10px;min-height:0}.principal-schedule-capacity-card,.principal-schedule-warning-card{display:grid;grid-template-rows:auto minmax(0,1fr);gap:8px}.principal-schedule-teacher-list{display:grid;gap:6px;min-height:0;overflow:auto}.principal-schedule-teacher-list.is-compact{max-height:92px}.principal-schedule-teacher-row{display:grid;grid-template-columns:minmax(0,1fr) 90px auto;gap:8px;align-items:center;padding:7px 8px;border-radius:9px;border:1px solid var(--sa-border);background:#fff}.principal-schedule-teacher-row strong{display:block;overflow:hidden;font-size:11px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.principal-schedule-teacher-row span{display:block;margin-top:1px;color:var(--sa-muted);font-size:9.5px}.principal-schedule-load-meter{height:6px;overflow:hidden;border-radius:999px;background:#e2e8f0}.principal-schedule-load-meter span{display:block;height:100%;min-width:3px;border-radius:inherit;background:#2d7fc7}.principal-schedule-load-status,.principal-schedule-load-pill{display:inline-flex;align-items:center;justify-content:center;min-width:56px;padding:3px 7px;border-radius:999px;font-size:9.5px;font-style:normal;font-weight:700;color:#334155;background:#f1f5f9}.principal-schedule-load-status--exact{color:#047857;background:#10b98129}.principal-schedule-load-status--under{color:#92400e;background:#f59e0b29}.principal-schedule-load-status--over{color:#b91c1c;background:#f43f5e24}.principal-schedule-warning-list{display:grid;gap:6px;overflow:auto;max-height:92px}.principal-schedule-warning-row,.principal-schedule-warning-empty{display:flex;align-items:center;gap:7px;min-height:28px;padding:6px 8px;border-radius:9px;font-size:10.5px;font-weight:500}.principal-schedule-warning-row{color:#92400e;background:#f59e0b1f}.principal-schedule-warning-empty{color:#047857;background:#10b9811f}.principal-schedule-page--builder{gap:10px}.principal-schedule-builder-head{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center}.principal-schedule-builder-head h1{font-size:1.24rem}.principal-schedule-back.ghost-action:not(.navbar-logout){width:34px;min-width:34px;padding:0}.principal-schedule-builder-layout{display:grid;grid-template-columns:minmax(0,1fr) 310px;gap:10px}.principal-schedule-builder-control{display:grid;gap:10px;align-content:start}.principal-schedule-days{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.principal-schedule-day{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:30px;border-radius:999px;border:1px solid var(--sa-border);color:var(--sa-muted);background:#fff;font-size:11px;font-weight:600;cursor:pointer}.principal-schedule-day input{display:none}.principal-schedule-day.is-active{color:#1d4ed8;border-color:#2563eb40;background:#2563eb14}.principal-schedule-settings-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px;margin-top:10px}.principal-schedule-settings-grid .principal-field,.principal-schedule-name-row .principal-field{font-size:11px}.principal-schedule-settings-grid .principal-field span,.principal-schedule-name-row .principal-field span{font-size:10px;font-weight:600}.principal-schedule-settings-grid input,.principal-schedule-name-row input{min-height:34px;border-radius:9px;font-size:12px}.principal-schedule-name-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:end;margin-top:10px}.principal-schedule-readiness{display:grid;gap:7px}.principal-schedule-ready{display:flex;align-items:center;gap:7px;min-height:30px;padding:7px 9px;border-radius:9px;color:#92400e;background:#f59e0b1f;font-size:11.5px;font-weight:500}.principal-schedule-ready.is-ok{color:#047857;background:#10b98121}.principal-schedule-builder-message{margin:0;padding:8px 9px;border-radius:9px;color:#1d4ed8;background:#2563eb14;font-size:11.5px}.principal-schedule-loads{display:grid;gap:9px}.principal-schedule-load-table-wrap{border-radius:10px;max-height:240px;overflow:auto}.principal-schedule-load-table{min-width:840px}.principal-schedule-load-table th,.principal-schedule-load-table td{padding:7px 8px;font-size:11.5px}.principal-schedule-load-table th{font-size:9px;font-weight:600;letter-spacing:.045em}.principal-schedule-cell-input,.principal-schedule-slot-select{width:100%;min-height:30px;border-radius:8px;border:1px solid var(--sa-border);background:#fff;padding:0 8px;font:inherit;font-size:11px;outline:none}.principal-schedule-hour-input{max-width:76px}.principal-schedule-icon-action.ghost-action:not(.navbar-logout){width:30px;min-width:30px;height:30px;min-height:30px;padding:0;border-radius:8px}.principal-schedule-builder-bottom{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:10px;align-items:start}.principal-schedule-preview-card .principal-schedule-board{max-height:520px}.principal-schedule-slot-select+.principal-schedule-slot-select{margin-top:4px}.principal-schedule-builder-warnings{display:grid;gap:9px}@media(max-width:1180px){.principal-schedule-page--overview{height:auto;overflow:visible;grid-template-rows:none}.principal-schedule-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.principal-schedule-overview-main,.principal-schedule-bottom-grid,.principal-schedule-builder-layout,.principal-schedule-builder-bottom{grid-template-columns:1fr}.principal-schedule-board-card{width:100%}}@media(max-width:720px){.principal-schedule-stats,.principal-schedule-settings-grid,.principal-schedule-name-row,.principal-schedule-builder-head{grid-template-columns:1fr}.principal-schedule-board-head,.principal-schedule-load-head{align-items:stretch;flex-direction:column}.principal-schedule-board-head>select,.principal-schedule-save.primary-action,.principal-schedule-refresh.primary-action,.principal-schedule-generate.primary-action{width:100%}}.principal-table-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-top:1px solid #e8edf3;background:#fafbfd}.principal-table-pagination-summary{margin:0;font-size:.88rem;color:#64748b}.principal-table-pagination-summary strong{color:#162235;font-weight:700}.principal-table-pagination-meta{margin-left:10px;padding-left:10px;border-left:1px solid #dbe3ec}.principal-table-pagination-controls{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.principal-table-pagination-nav{display:inline-flex;align-items:center;gap:4px;min-height:34px;padding:0 10px;font-size:.84rem}.principal-table-pagination-nav:disabled{opacity:.45;cursor:not-allowed}.principal-table-pagination-pages,.principal-table-pagination-page-wrap{display:inline-flex;align-items:center;gap:4px}.principal-table-pagination-gap{color:#94a3b8;padding:0 2px;-webkit-user-select:none;user-select:none}.principal-table-pagination-page{min-width:34px;height:34px;padding:0 8px;border:1px solid #dbe3ec;border-radius:8px;background:#fff;color:#334155;font-size:.84rem;font-weight:600;cursor:pointer}.principal-table-pagination-page:hover{border-color:#94a3b8;background:#f8fafc}.principal-table-pagination-page.active{border-color:#2563eb;background:#eff6ff;color:#1d4ed8}@media(max-width:640px){.principal-table-pagination{flex-direction:column;align-items:stretch}.principal-table-pagination-controls{justify-content:space-between}.principal-table-pagination-meta{display:block;margin:4px 0 0;padding:0;border:0}}.principal-students-page{gap:12px}.principal-students-stats{gap:8px;margin-bottom:0}.principal-students-page .principal-stat-card{display:grid;grid-template-columns:32px minmax(0,1fr);grid-template-rows:auto auto auto;column-gap:10px;min-height:82px;padding:10px 12px;border-radius:12px;background:#fff;box-shadow:0 4px 14px #1622350b}.principal-students-page .principal-stat-card:before{width:3px}.principal-students-page .principal-stat-icon{grid-row:1 / 4;width:30px;height:30px;border-radius:9px}.principal-students-page .principal-stat-icon svg{width:16px;height:16px}.principal-students-page .principal-stat-card small{margin-top:0;font-size:9px;font-weight:600;letter-spacing:.04em}.principal-students-page .principal-stat-card strong{margin-top:3px;font-size:1.18rem;font-weight:700;letter-spacing:0}.principal-students-page .principal-stat-card em{margin-top:3px;font-size:10.5px;line-height:1.25}.principal-students-stat-pair{font-weight:600;opacity:.82}.principal-students-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;padding-top:2px}.principal-students-toolbar-text{display:inline-flex;align-items:center;gap:8px;color:var(--ink, #162235)}.principal-students-toolbar-text h2{margin:0;font-size:1.34rem;font-weight:700;letter-spacing:-.01em}.principal-students-toolbar-text svg{width:18px;height:18px;color:var(--sky, #2d7fc7);flex-shrink:0}.principal-students-toolbar-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.principal-students-page .principal-students-add.primary-action,.principal-students-page .principal-students-import.ghost-action:not(.navbar-logout){display:inline-flex;align-items:center;gap:6px;height:36px;min-height:36px;padding:0 12px;border-radius:9px;font-size:12px;font-weight:600}.principal-students-page .principal-students-import.ghost-action:not(.navbar-logout){color:#2563eb;background:#fff}.principal-students-page .principal-students-add.primary-action svg,.principal-students-page .principal-students-import.ghost-action:not(.navbar-logout) svg{width:15px;height:15px}.principal-students-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.principal-students-search{flex:1 1 220px;display:flex;align-items:center;gap:7px;min-height:34px;padding:0 10px;border-radius:9px;border:1px solid var(--sa-border);background:#fff}.principal-students-search svg{width:15px;height:15px;color:var(--sa-muted)}.principal-students-search input{flex:1;min-width:0;border:none;background:transparent;font:inherit;font-size:12px;outline:none}.principal-students-select{min-height:34px;padding:0 10px;border-radius:9px;border:1px solid var(--sa-border);background:#fff;font:inherit;font-size:12px;min-width:142px}.principal-students-table-card{margin-top:0;padding:10px;border-radius:12px;box-shadow:0 4px 14px #1622350b}.principal-students-page .principal-table-wrap{border-radius:10px}.principal-students-page .principal-table{min-width:820px}.principal-students-page .principal-table th,.principal-students-page .principal-table td{padding:7px 9px;font-size:11.5px}.principal-students-page .principal-table th{font-size:9px;font-weight:600;letter-spacing:.045em}.principal-students-page .principal-table tbody tr{background:#fff}.principal-students-page .principal-table tbody tr:hover{background:var(--sa-tint-warm)}.principal-students-page .principal-table-name{gap:6px;font-weight:500}.principal-students-page .principal-table-name svg{width:14px;height:14px;color:var(--sa-muted)}.principal-students-number{font-size:11px;padding:2px 6px;border-radius:7px;background:#2d7fc714;color:var(--sky, #2d7fc7);font-weight:500}.principal-students-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 7px;border-radius:999px;font-size:9.5px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.principal-students-badge svg{width:11px;height:11px}.principal-students-badge--active{color:#047857;background:#10b98129}.principal-students-badge--passive{color:#9f1239;background:#f43f5e24}.principal-students-actions{flex-wrap:wrap;gap:5px}.principal-students-page .principal-table-actions .ghost-action:not(.navbar-logout){width:30px;min-width:30px;height:30px;min-height:30px;padding:0;border-radius:8px;gap:0}.principal-students-page .principal-table-actions .ghost-action:not(.navbar-logout) svg{width:14px;height:14px}.principal-students-page .empty-text{padding:10px 4px;font-size:12px;text-align:center}.principal-student-form-modal{width:min(100%,560px)}.principal-student-import-modal{width:min(100%,760px)}.principal-student-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px}.principal-student-import-body{display:grid;gap:12px}.principal-student-import-body .principal-modal-error{display:inline-flex;align-items:center;gap:7px;margin-bottom:0;font-size:12px}.principal-student-import-drop{display:grid;justify-items:center;gap:7px;padding:18px;border:1px dashed rgba(45,127,199,.38);border-radius:14px;background:linear-gradient(180deg,#eff6ffd9,#ffffffeb);cursor:pointer;text-align:center}.principal-student-import-drop input{display:none}.principal-student-import-drop-icon{display:grid;place-items:center;width:40px;height:40px;border-radius:12px;color:#2563eb;background:#2563eb1a}.principal-student-import-drop strong{font-size:13px;font-weight:700;color:var(--ink, #162235)}.principal-student-import-drop small,.principal-student-import-format{font-size:11px;color:var(--sa-muted)}.principal-student-import-format{display:inline-flex;align-items:center;gap:6px}.principal-student-import-stats{display:flex;flex-wrap:wrap;gap:7px}.principal-student-import-stat,.principal-student-import-row-status{display:inline-flex;align-items:center;gap:5px;padding:3px 7px;border-radius:999px;font-size:10px;font-weight:600}.principal-student-import-stat--valid,.principal-student-import-row-status--valid{color:#047857;background:#10b98129}.principal-student-import-stat--duplicate,.principal-student-import-row-status--duplicate{color:#92400e;background:#f59e0b29}.principal-student-import-stat--invalid,.principal-student-import-row-status--invalid{color:#b91c1c;background:#f43f5e24}.principal-student-import-preview{max-height:300px;overflow:auto;border-radius:10px}.principal-student-import-preview .principal-table{min-width:640px}.principal-student-import-preview .principal-table th,.principal-student-import-preview .principal-table td{padding:7px 9px;font-size:11.5px}@media(max-width:520px){.principal-student-form-grid{grid-template-columns:1fr}.principal-students-toolbar-actions{width:100%;justify-content:stretch}.principal-students-page .principal-students-add.primary-action,.principal-students-page .principal-students-import.ghost-action:not(.navbar-logout){flex:1 1 100%;justify-content:center}}.principal-students-summary-modal{width:min(640px,calc(100vw - 32px))}.principal-students-summary-subtitle{margin:4px 0 0;color:#64748b;font-size:.88rem}.principal-students-summary-loading{display:inline-flex;align-items:center;gap:8px;color:#64748b}.principal-students-summary-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px}.principal-students-summary-stats article{padding:10px 12px;border-radius:12px;background:#f8fafc;border:1px solid #e2e8f0}.principal-students-summary-stats small{display:block;color:#64748b;font-size:.78rem}.principal-students-summary-stats strong{display:block;margin-top:4px;font-size:1.25rem}.principal-students-summary-table td:last-child{text-transform:capitalize}@media(max-width:640px){.principal-students-summary-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}.principal-teachers-page{gap:12px}.principal-teachers-stats{gap:8px;margin-bottom:0}.principal-teachers-page .principal-stat-card{display:grid;grid-template-columns:32px minmax(0,1fr);grid-template-rows:auto auto auto;column-gap:10px;min-height:82px;padding:10px 12px;border-radius:12px;background:#fff;box-shadow:0 4px 14px #1622350b}.principal-teachers-page .principal-stat-card:before{width:3px}.principal-teachers-page .principal-stat-icon{grid-row:1 / 4;width:30px;height:30px;border-radius:9px}.principal-teachers-page .principal-stat-icon svg{width:16px;height:16px}.principal-teachers-page .principal-stat-card small{margin-top:0;font-size:9px;font-weight:600;letter-spacing:.04em}.principal-teachers-page .principal-stat-card strong{margin-top:3px;font-size:1.18rem;font-weight:700;letter-spacing:0}.principal-teachers-page .principal-stat-card em{margin-top:3px;font-size:10.5px;line-height:1.25}.principal-teachers-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;padding-top:2px}.principal-teachers-toolbar-text{display:inline-flex;align-items:center;gap:8px;color:var(--ink, #162235)}.principal-teachers-toolbar-text h2{margin:0;font-size:1.34rem;font-weight:700;letter-spacing:-.01em}.principal-teachers-toolbar-text svg{color:var(--sky, #2d7fc7);flex-shrink:0;width:18px;height:18px}.principal-teachers-page .principal-teachers-add.primary-action{display:inline-flex;align-items:center;gap:6px;height:36px;min-height:36px;padding:0 12px;border-radius:9px;font-size:12px;font-weight:600}.principal-teachers-page .principal-teachers-add.primary-action svg{width:15px;height:15px}.principal-teachers-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.principal-teachers-search{flex:1 1 220px;display:flex;align-items:center;gap:7px;min-height:34px;padding:0 10px;border-radius:9px;border:1px solid var(--sa-border);background:#fff}.principal-teachers-search svg{width:15px;height:15px;color:var(--sa-muted)}.principal-teachers-search input{flex:1;min-width:0;border:none;background:transparent;font:inherit;font-size:12px;outline:none}.principal-teachers-select{min-height:34px;padding:0 10px;border-radius:9px;border:1px solid var(--sa-border);background:#fff;font:inherit;font-size:12px;min-width:142px}.principal-teachers-table-card{margin-top:0;padding:10px;border-radius:12px;box-shadow:0 4px 14px #1622350b}.principal-teachers-page .principal-table-wrap{border-radius:10px}.principal-teachers-username{font-size:11px;padding:2px 6px;border-radius:7px;background:#2d7fc714;color:var(--sky, #2d7fc7);font-weight:500}.principal-teachers-badge{display:inline-flex;align-items:center;padding:3px 7px;border-radius:999px;font-size:9.5px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.principal-teachers-badge--pending{color:#b45309;background:#f59e0b2e}.principal-teachers-badge--ok{color:#047857;background:#10b98129}.principal-teachers-actions{flex-wrap:wrap;gap:5px}.principal-teachers-page .principal-table{min-width:760px}.principal-teachers-page .principal-table th,.principal-teachers-page .principal-table td{padding:7px 9px;font-size:11.5px}.principal-teachers-page .principal-table th{font-size:9px;font-weight:600;letter-spacing:.045em}.principal-teachers-page .principal-table tbody tr{background:#fff}.principal-teachers-page .principal-table tbody tr:hover{background:var(--sa-tint-warm)}.principal-teachers-page .principal-table-name{gap:6px;font-weight:500}.principal-teachers-page .principal-table-name svg{width:14px;height:14px;color:var(--sa-muted)}.principal-teachers-page .principal-table-actions .ghost-action:not(.navbar-logout){width:30px;min-width:30px;height:30px;min-height:30px;padding:0;border-radius:8px;gap:0}.principal-teachers-page .principal-table-actions .ghost-action:not(.navbar-logout) svg{width:14px;height:14px}.principal-teachers-page .empty-text{padding:10px 4px;font-size:12px;text-align:center}.principal-console .sa-main{display:grid;gap:16px}.principal-page-stack{display:grid;gap:14px}.principal-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.principal-kpi-card,.principal-surface-card{border:1px solid var(--sa-border);border-radius:16px;background:linear-gradient(160deg,var(--sa-surface) 0%,var(--sa-surface-tint) 100%);box-shadow:var(--sa-shadow)}.principal-kpi-card{padding:12px 13px}.principal-kpi-icon{display:grid;width:38px;height:38px;place-items:center;border-radius:10px;color:var(--sa-ink);background:color-mix(in srgb,var(--sa-accent) 16%,transparent)}.principal-kpi-card small{display:block;margin-top:10px;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--sa-muted);font-weight:700}.principal-kpi-card strong{display:block;margin-top:6px;font-size:1.45rem;line-height:1.1}.principal-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.principal-stat-card{position:relative;padding:12px 13px 12px 15px;border-radius:12px;border:1px solid var(--sa-border);background:linear-gradient(155deg,var(--sa-surface) 0%,var(--sa-surface-tint) 100%);box-shadow:0 8px 22px #0f172a0f;overflow:hidden}.principal-stat-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:4px 0 0 4px;background:linear-gradient(180deg,var(--stat-accent, #f59e0b),var(--stat-accent-2, #d97706))}.principal-stat-card--sky{--stat-accent: #38bdf8;--stat-accent-2: #2563eb}.principal-stat-card--emerald{--stat-accent: #34d399;--stat-accent-2: #059669}.principal-stat-card--amber{--stat-accent: #fbbf24;--stat-accent-2: #d97706}.principal-stat-card--violet{--stat-accent: #a78bfa;--stat-accent-2: #7c3aed}.principal-stat-card--rose{--stat-accent: #fb7185;--stat-accent-2: #e11d48}.principal-stat-icon{display:grid;width:40px;height:40px;place-items:center;border-radius:12px}.principal-stat-card--sky .principal-stat-icon{color:#1d4ed8;background:#38bdf838}.principal-stat-card--emerald .principal-stat-icon{color:#047857;background:#34d39938}.principal-stat-card--amber .principal-stat-icon{color:#b45309;background:#fbbf2447}.principal-stat-card--violet .principal-stat-icon{color:#5b21b6;background:#a78bfa40}.principal-stat-card--rose .principal-stat-icon{color:#be123c;background:#fb718538}.principal-stat-card small{display:block;margin-top:12px;font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--sa-muted);font-weight:700}.principal-stat-card strong{display:block;margin-top:6px;font-size:clamp(1.5rem,2.8vw,1.85rem);font-weight:800;letter-spacing:-.03em;line-height:1.05;color:var(--ink, #162235)}.principal-stat-card em{display:block;margin-top:6px;font-size:12px;font-style:normal;color:var(--sa-muted);font-weight:500;line-height:1.35}.principal-surface-card{padding:12px 14px}.principal-surface-card h2{margin:0 0 8px;font-size:1rem}.principal-surface-card p{margin:0 0 6px;font-size:13px;color:var(--sa-muted)}.principal-surface-card small{color:var(--sa-ink);font-size:12px;font-weight:600}.principal-inline-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:12px}.principal-inline-stats>div{border:1px solid var(--sa-border);border-radius:12px;padding:10px;background:var(--sa-tint-cream)}.principal-inline-stats span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--sa-muted);font-weight:700}.principal-inline-stats strong{display:block;margin-top:5px;font-size:1.1rem}.principal-list{display:grid;gap:9px}.principal-list-row{display:grid;grid-template-columns:minmax(0,1fr) 120px minmax(180px,.7fr);gap:10px;align-items:center;padding:10px 11px;border-radius:12px;border:1px solid var(--sa-border);background:var(--sa-tint-cream)}.principal-list-row strong{display:block;font-size:13px}.principal-list-row span,.principal-list-row em,.principal-list-row small{color:var(--sa-muted);font-size:11px;font-style:normal}.principal-class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.principal-visual-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.principal-card-head h2{margin:0;font-size:1.02rem}.principal-card-head p{margin:6px 0 0;font-size:12px;color:var(--sa-muted)}.principal-card-head--split{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.principal-class-kpis{display:grid;grid-template-columns:repeat(3,minmax(110px,1fr));gap:10px}.principal-class-kpis>div{border:1px solid var(--sa-border);background:var(--sa-tint-cream);border-radius:12px;padding:10px}.principal-class-kpis small{display:block;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--sa-muted)}.principal-class-kpis strong{display:block;margin-top:4px;font-size:1.1rem}.principal-class-management-grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);gap:12px}.principal-class-tree{display:grid;gap:10px;margin-top:10px}.principal-class-tree-card{border:1px solid var(--sa-border);border-radius:14px;padding:12px;background:var(--sa-tint-cream)}.principal-class-tree-card header{display:flex;justify-content:space-between;gap:10px;align-items:center}.principal-class-tree-card h3{margin:0;font-size:14px}.principal-class-tree-card header small{color:var(--sa-muted);font-size:11px}.principal-class-tree-section-list{margin-top:10px;display:grid;gap:8px}.principal-class-tree-section-list>p{margin:0;font-size:12px;color:var(--sa-muted);border:1px dashed var(--sa-border);border-radius:10px;padding:10px;background:#fff}.principal-class-section-row{width:100%;border:1px solid var(--sa-border);border-radius:12px;padding:10px;background:#fff;text-align:left;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) auto;align-items:center;gap:8px;cursor:pointer}.principal-class-section-row:hover{background:var(--sa-tint-warm)}.principal-class-section-row strong{font-size:13px}.principal-class-section-row span,.principal-class-section-row em,.principal-class-section-row small{font-size:11px;color:var(--sa-muted);font-style:normal}.principal-empty-note{margin:10px 0 0;border:1px dashed var(--sa-border);border-radius:10px;padding:12px;background:#fff}.principal-focus-note{margin:8px 0 10px;font-size:12px;color:var(--sa-muted)}.principal-class-card-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.principal-classes-only{padding-top:4px}.principal-classes-card-row{align-items:stretch}.principal-class-card-slot{min-height:240px;display:flex;flex-direction:column;box-sizing:border-box}.principal-add-class-hint{margin-top:4px;font-size:13px;line-height:1.4;color:var(--sa-muted)}.principal-class-card-stats{margin-top:auto}.principal-add-class-card{align-items:stretch;text-align:left}.principal-add-class-form{margin-top:8px;display:grid;grid-template-columns:1fr auto;gap:8px}.principal-add-class-form input{min-height:38px;border:1px solid var(--sa-border);border-radius:10px;padding:0 10px;font:inherit;font-size:12px;background:#fff}.principal-class-card{width:100%;text-align:left}.principal-class-card-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;font:inherit;color:inherit;text-align:left}.principal-class-card-btn:focus-visible{outline:3px solid rgba(45,127,199,.45);outline-offset:3px}.principal-class-card-title-block{display:flex;align-items:center;gap:12px;margin-top:8px;min-height:3.25rem}.principal-class-card-title-icon{flex-shrink:0;display:grid;place-items:center;width:48px;height:48px;border-radius:14px;background:#10b9811f;color:#047857}.principal-class-card-title-text{flex:1;min-width:0;font-size:clamp(1.85rem,4.2vw,2.85rem);font-weight:800;line-height:1.05;letter-spacing:-.03em;color:var(--ink, #162235);text-align:left}.principal-class-card-meta{margin-top:10px}.principal-class-detail-back{display:inline-flex;align-items:center;gap:8px;margin-bottom:16px}.principal-class-detail-hero{margin-bottom:20px}.principal-class-detail-title-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.principal-class-detail-title-icon{flex-shrink:0;display:grid;place-items:center;width:64px;height:64px;border-radius:18px;background:#2d7fc71f;color:var(--sky, #2d7fc7)}.principal-class-detail-title{margin:0;font-size:clamp(2rem,4.5vw,3.25rem);font-weight:800;letter-spacing:-.03em;line-height:1.08;color:var(--ink, #162235)}.principal-class-detail-sub{margin:12px 0 0;max-width:52rem;font-size:15px;line-height:1.5;color:var(--sa-muted)}.principal-class-detail-missing{margin:0 0 12px;color:var(--sa-muted)}.principal-class-detail-section-form{margin-bottom:16px}.principal-table-actions{display:inline-flex;gap:8px}.principal-table-name{display:inline-flex;align-items:center;gap:8px}.ghost-action.danger{border-color:#fecaca;color:#b91c1c}.ghost-action.danger:hover{border-color:#ef4444;background:#fef2f2}.principal-ring-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}.principal-ring-wrap{display:grid;place-items:center;gap:8px}.principal-ring-wrap span{font-size:11px;color:var(--sa-muted);text-align:center}.principal-ring{--principal-ring: 0%;width:114px;height:114px;border-radius:999px;display:grid;place-items:center;background:radial-gradient(closest-side,#ffffff 72%,transparent 73% 100%),conic-gradient(var(--sa-accent-mid) var(--principal-ring),var(--sa-border) 0)}.principal-ring--warn{background:radial-gradient(closest-side,#ffffff 72%,transparent 73% 100%),conic-gradient(#ef4444 var(--principal-ring),#ececeb 0)}.principal-ring--risk{background:radial-gradient(closest-side,#ffffff 72%,transparent 73% 100%),conic-gradient(#8b5cf6 var(--principal-ring),#ececeb 0)}.principal-ring strong{font-size:1.2rem;line-height:1}.principal-chart-frame{width:100%;height:210px;margin-top:8px}.principal-chart-frame--lg{height:260px}.principal-inline-form,.principal-student-form{display:grid;gap:10px;margin-top:12px;margin-bottom:12px}.principal-inline-form{grid-template-columns:minmax(220px,1fr) auto}.principal-inline-form--wide{grid-template-columns:repeat(5,minmax(160px,1fr)) auto}.principal-student-form{grid-template-columns:repeat(4,minmax(150px,1fr)) auto}.principal-inline-form input,.principal-inline-form select,.principal-student-form input,.principal-student-form select{width:100%;min-height:38px;border:1px solid var(--sa-border);border-radius:10px;background:#fff;padding:0 10px;font:inherit;font-size:12px}.principal-table-wrap{overflow-x:auto;border:1px solid var(--sa-border);border-radius:12px}.principal-table{width:100%;border-collapse:collapse;min-width:640px}.principal-table th,.principal-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--sa-border);font-size:12px}.principal-table th{font-size:10px;color:var(--sa-muted);text-transform:uppercase;letter-spacing:.05em}.principal-table tbody tr:last-child td{border-bottom:0}.principal-table--clickable tbody tr{cursor:pointer}.principal-table--clickable tbody tr:hover{background:var(--sa-tint-warm)}@media(max-width:1100px){.principal-kpi-grid,.principal-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.principal-visual-grid{grid-template-columns:1fr}.principal-inline-form,.principal-inline-form--wide,.principal-student-form{grid-template-columns:1fr 1fr}.principal-class-management-grid{grid-template-columns:1fr}.principal-card-head--split{flex-direction:column}.principal-class-kpis{width:100%}.principal-add-class-form{grid-template-columns:1fr}}@media(max-width:760px){.principal-kpi-grid,.principal-stat-grid,.principal-inline-stats,.principal-list-row,.principal-ring-grid,.principal-inline-form,.principal-inline-form--wide,.principal-student-form,.principal-class-kpis{grid-template-columns:1fr}.principal-class-tree-card header{flex-direction:column;align-items:flex-start}.principal-class-section-row{grid-template-columns:1fr}}.principal-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:grid;place-items:center;padding:24px;background:#16223573;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.principal-modal{width:min(100%,480px);max-height:min(92vh,720px);overflow:auto;border-radius:18px;border:1px solid var(--sa-border);background:linear-gradient(165deg,#fff,#faf9f7);box-shadow:0 24px 48px #1622352e}.principal-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 20px 0}.principal-modal-head h2{margin:0;font-size:20px;font-weight:800;letter-spacing:-.02em;color:var(--ink, #162235)}.principal-modal-close{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--sa-border);background:#fff;cursor:pointer;color:var(--sa-muted)}.principal-modal-close:hover{color:var(--ink, #162235);border-color:#cbd5e1}.principal-modal-body{padding:16px 20px 8px}.principal-modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px 18px;border-top:1px solid rgba(22,34,53,.06)}.principal-modal-error{margin-bottom:12px}.principal-teacher-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px}.principal-field{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--ink, #162235)}.principal-field--full{grid-column:1 / -1}.principal-field input,.principal-field select{min-height:40px;border-radius:10px;border:1px solid var(--sa-border);padding:0 10px;font:inherit;font-size:14px;font-weight:500;background:#fff}.principal-password-preview span:first-child{font-size:13px;font-weight:700}.principal-password-note{margin:4px 0 8px;font-size:12px;line-height:1.45;color:var(--sa-muted);font-weight:500}.principal-password-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.principal-password-code{flex:1;min-width:0;padding:10px 12px;border-radius:10px;background:#2d7fc714;font-size:14px;word-break:break-all}.principal-credential-dialog .principal-modal-title{display:flex;align-items:center;gap:10px}.principal-credential-dialog .principal-modal-title h2{margin:0;font-size:18px}.principal-credential-hint{margin:0 0 14px;font-size:13px;line-height:1.5;color:var(--sa-muted)}.principal-credential-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--sa-muted)}.principal-credential-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.principal-credential-row code{flex:1;min-width:0;padding:10px 12px;border-radius:10px;background:#f1f5f9;font-size:14px;word-break:break-all}.principal-credential-copy{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}.principal-alert-banner{display:grid;grid-template-columns:auto 1fr auto;gap:.85rem;align-items:center;padding:.9rem 1rem;border-radius:14px;border:1px solid transparent}.principal-alert-banner strong{display:block}.principal-alert-banner p{margin:.2rem 0 0;color:#64748b;font-size:.88rem}.principal-alert-banner--warning{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.principal-alert-banner--amber{background:#fffbeb;border-color:#fde68a}.principal-alert-banner--risk{background:#fef2f2;border-color:#fecaca}.principal-operations-list{display:flex;flex-direction:column;gap:.65rem}.principal-operation-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;border-radius:12px;border:1px solid #e8ecea;text-decoration:none;color:inherit;transition:border-color .15s ease,background .15s ease}.principal-operation-row:hover{border-color:#f9a51b;background:#fffaf2}.principal-operation-meta{display:flex;gap:.5rem;margin-top:.25rem;font-size:.82rem;color:#64748b}.principal-op-priority{display:inline-flex;padding:.12rem .45rem;border-radius:999px;font-size:.72rem;font-weight:700}.principal-op-priority--urgent{background:#fee2e2;color:#b91c1c}.principal-op-priority--high{background:#ffedd5;color:#c2410c}.principal-op-priority--normal{background:#ecfdf5;color:#047857}.principal-operation-action{display:inline-flex;align-items:center;gap:.25rem;color:#c27803;font-weight:600;white-space:nowrap}.principal-operation-hint{display:flex;align-items:center;gap:.65rem;color:#64748b}.principal-announcement-audience-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.principal-announcement-audience{display:inline-flex;align-items:center;gap:.35rem}@media(max-width:520px){.principal-teacher-form-grid{grid-template-columns:1fr}.principal-field--full{grid-column:1}.principal-announcement-audience-grid,.principal-alert-banner{grid-template-columns:1fr}}.teacher-console{--teacher-sky: #2d7fc7;--teacher-emerald: #0f8b68;--teacher-amber: #d98214;--teacher-violet: #7566b5}.teacher-main,.teacher-page-stack{display:grid;gap:14px}.teacher-page-title{display:flex;flex-direction:column;gap:4px}.teacher-page-title h1{margin:0;font-size:1.45rem;font-weight:700;letter-spacing:-.02em;color:var(--sa-ink)}.teacher-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.teacher-kpi-card{padding:10px 12px 10px 14px;min-height:100px}.teacher-kpi-card .principal-stat-icon{width:34px;height:34px;border-radius:10px}.teacher-kpi-card small{margin-top:9px;font-size:9.5px}.teacher-kpi-card strong{margin-top:5px;font-size:clamp(1.1rem,1.8vw,1.45rem);font-weight:700;letter-spacing:-.02em}.teacher-kpi-card em{margin-top:5px;font-size:11px}.teacher-overview-grid,.teacher-attendance-grid,.teacher-observation-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(300px,.92fr);gap:12px;align-items:start}.teacher-overview-grid--secondary{grid-template-columns:repeat(2,minmax(0,1fr))}.teacher-focus-card{min-height:230px}.teacher-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.teacher-card-head--wrap{align-items:center;flex-wrap:wrap}.teacher-card-head h2{margin:2px 0 0;font-size:1rem;font-weight:700;letter-spacing:-.01em}.teacher-card-head p{margin:5px 0 0;color:var(--sa-muted);font-size:12px;line-height:1.45}.teacher-active-lesson{display:grid;grid-template-columns:48px minmax(0,1fr);gap:12px;align-items:center;margin:10px 0 14px;padding:13px;border:1px solid var(--sa-border);border-radius:14px;background:var(--sa-tint-cream)}.teacher-lesson-icon{display:grid;width:48px;height:48px;place-items:center;border-radius:14px;color:var(--teacher-emerald);background:#0f8b681f}.teacher-active-lesson strong,.teacher-lesson-body strong,.teacher-observation-row strong,.teacher-announcement-row strong{display:block;color:var(--sa-ink);font-size:13px;font-weight:600}.teacher-active-lesson span,.teacher-lesson-body span,.teacher-observation-row span,.teacher-announcement-row span{display:block;margin-top:3px;color:var(--sa-muted);font-size:11.5px;line-height:1.35}.teacher-wide-action{width:100%;justify-content:center;min-height:38px;font-size:12px}.teacher-lesson-list,.teacher-observation-list,.teacher-announcement-list,.teacher-compact-list{display:grid;gap:8px}.teacher-lesson-row{display:grid;grid-template-columns:70px minmax(0,1fr) auto;gap:10px;align-items:center;min-height:58px;padding:9px 10px;border:1px solid var(--sa-border);border-radius:12px;background:var(--sa-tint-cream)}.teacher-lesson-row.is-active{border-color:color-mix(in srgb,var(--sa-accent) 35%,var(--sa-border));background:linear-gradient(90deg,color-mix(in srgb,var(--sa-accent) 8%,transparent),var(--sa-surface))}.teacher-lesson-list--detailed .teacher-lesson-row{min-height:64px}.teacher-lesson-time{display:grid;gap:2px;padding:7px;border-radius:10px;background:#fff;border:1px solid rgba(219,219,217,.75);text-align:center;font-variant-numeric:tabular-nums}.teacher-lesson-time strong{font-size:12px;font-weight:700}.teacher-lesson-time span{color:var(--sa-muted);font-size:10.5px}.teacher-compact-row{display:grid;grid-template-columns:54px minmax(0,.7fr) minmax(0,1fr);gap:8px;align-items:center;min-height:40px;padding:8px 9px;border:1px solid var(--sa-border);border-radius:11px;background:var(--sa-tint-cream);color:var(--sa-ink);font:inherit;text-align:left;cursor:pointer}.teacher-compact-row:hover{border-color:color-mix(in srgb,var(--sa-accent) 45%,var(--sa-border));background:var(--sa-tint-warm)}.teacher-compact-row span{color:var(--sa-muted);font-size:11px;font-variant-numeric:tabular-nums}.teacher-compact-row strong,.teacher-compact-row em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-style:normal}.teacher-compact-row em{color:var(--sa-muted)}.teacher-attendance-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:8px}.teacher-table-wrap{margin-top:4px}.teacher-attendance-table{min-width:720px}.teacher-attendance-table td{vertical-align:middle}.teacher-attendance-table td:first-child{width:82px;color:var(--sa-muted);font-variant-numeric:tabular-nums}.teacher-status-toggle{display:inline-flex;flex-wrap:wrap;gap:6px}.teacher-status-toggle button{min-height:31px;padding:0 9px;border:1px solid var(--sa-border);border-radius:10px;background:#fff;color:var(--sa-muted);display:inline-flex;align-items:center;gap:5px;font:inherit;font-size:11.5px;font-weight:500;cursor:pointer}.teacher-status-toggle button.is-selected{color:var(--sa-accent-deep);border-color:color-mix(in srgb,var(--sa-accent) 60%,var(--sa-border));background:var(--sa-tint-warm)}.teacher-observation-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.teacher-observation-form .field{gap:6px}.teacher-observation-form select,.teacher-observation-form textarea{width:100%;border:1px solid var(--sa-border);border-radius:11px;background:#fff;color:var(--sa-ink);font:inherit;font-size:12px}.teacher-observation-form select{min-height:38px;padding:0 10px}.teacher-observation-form textarea{resize:vertical;min-height:126px;padding:10px;line-height:1.45}.teacher-observation-note,.teacher-observation-form .primary-action{grid-column:1 / -1}.teacher-observation-form .primary-action{justify-content:center;min-height:38px}.teacher-observation-row,.teacher-announcement-row{display:grid;gap:8px;padding:11px 12px;border:1px solid var(--sa-border);border-radius:12px;background:var(--sa-tint-cream)}.teacher-observation-row p,.teacher-announcement-row p{margin:0;color:var(--sa-ink);font-size:12px;line-height:1.45}.teacher-observation-row small{color:var(--sa-muted);font-size:11px}.teacher-announcement-list--detailed .teacher-announcement-row{gap:10px}.teacher-empty-pad{padding:10px 0}.teacher-console .support-contact-pane{max-width:820px}@media(max-width:1180px){.teacher-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.teacher-overview-grid,.teacher-attendance-grid,.teacher-observation-grid,.teacher-overview-grid--secondary{grid-template-columns:1fr}}@media(max-width:720px){.teacher-kpi-grid{grid-template-columns:1fr}.teacher-card-head,.teacher-card-head--wrap{align-items:flex-start;flex-direction:column}.teacher-attendance-actions{justify-content:flex-start}.teacher-lesson-row,.teacher-compact-row,.teacher-observation-form{grid-template-columns:1fr}}.teacher-alert-banner,.teacher-lesson-picker{display:flex;gap:.75rem;align-items:flex-start;padding:.9rem 1rem;border-radius:14px;border:1px solid #fde68a;background:#fffbeb}.teacher-lesson-picker{display:block;border-color:#e8ecea;background:#fff}:root{color-scheme:light;font-family:Roboto,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:12px;--paper: #f4f7fb;--surface: #ffffff;--surface-2: #eef7fb;--ink: #162235;--muted: #6b7788;--line: #dbe5ef;--green: #14927f;--green-strong: #0e6d63;--sky: #2d7fc7;--amber: #d89b22;--coral: #d75f52;--indigo: #3550a3;--chalk: #e7f7f4;--shadow: 0 8px 24px rgba(38, 55, 77, .07);--sidebar-bg: #f8fbff;--sidebar-ink: #1a2a40;--sidebar-muted: #6b7b90}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--ink);background:linear-gradient(135deg,rgba(45,127,199,.09),transparent 34%),linear-gradient(225deg,rgba(20,146,127,.1),transparent 38%),var(--paper)}body:before{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background-image:linear-gradient(rgba(45,127,199,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(20,146,127,.04) 1px,transparent 1px);background-size:30px 30px;content:"";-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.65),transparent 78%);mask-image:linear-gradient(to bottom,rgba(0,0,0,.65),transparent 78%)}button,input,select,textarea{font:inherit}button{cursor:pointer}.form-heading span,.section-kicker{color:var(--green);font-size:12px;font-weight:800;letter-spacing:0;text-transform:uppercase}.form-heading h2{margin:4px 0 0}.form-heading h2{font-size:25px}.field{display:grid;gap:8px;color:var(--muted);font-size:13px;font-weight:800}.field-control{display:flex;align-items:center;gap:10px;min-height:48px;padding:0 13px;border:1px solid var(--line);border-radius:8px;color:var(--green-strong);background:#fff}.field-control input,.field-control select{width:100%;min-width:0;border:0;outline:0;color:var(--ink);background:transparent}textarea{width:100%;min-width:0;resize:vertical;border:1px solid var(--line);border-radius:8px;padding:12px 13px;color:var(--ink);background:#fff;outline:0}.primary-action,.ghost-action,.nav-button{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:44px;border-radius:8px;border:1px solid transparent;font-weight:800}.primary-action{color:#fff;background:var(--green)}.small-action{min-height:36px;padding:0 12px;font-size:12px}.primary-action:hover{background:var(--green-strong)}.primary-action:disabled{cursor:default;opacity:.72}.ghost-action{padding:0 14px;color:var(--green-strong);border-color:var(--line);background:var(--surface)}.form-error{padding:12px 13px;border-radius:8px;color:#812c2b;background:#fde8e3;font-size:14px;font-weight:700}.form-success{padding:12px 13px;border-radius:8px;color:#17614f;background:#e3f3eb;font-size:13px;font-weight:800}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.admin-shell{--sa-bg: #f9f9f8;--sa-surface: #ffffff;--sa-muted: #919a9f;--sa-border: #dbdbd9;--sa-ink: #131313;--sa-accent: #f9a51b;--sa-accent-2: #fac95a;--sa-shadow: 0 12px 32px rgba(19, 19, 19, .08);--sa-chart-soft: #6b8f86;--sa-tint-warm: #fffaf0;--sa-tint-cream: #fffcf4;--sa-surface-tint: #fefdfb;--sa-accent-deep: #b45309;--sa-accent-mid: #e67e00}.admin-shell{display:grid;grid-template-columns:86px minmax(0,1fr);grid-template-rows:56px minmax(0,1fr);min-height:100vh;background:linear-gradient(180deg,var(--sa-bg),#efefeb);font-family:Roboto,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--sa-ink)}.admin-navbar{grid-column:1 / -1;grid-row:1;position:sticky;top:0;z-index:30;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:14px;min-height:56px;padding:8px 16px;border-bottom:1px solid var(--sa-border);background:#ffffffeb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 1px #fff9 inset}.navbar-brand,.navbar-actions,.navbar-profile-text{display:flex;align-items:center}.navbar-brand{gap:10px}.navbar-actions{grid-column:3;justify-content:flex-end;gap:10px;min-width:0}.navbar-brand strong,.navbar-profile strong{display:block;font-weight:600}.navbar-brand span,.navbar-profile span{display:block;color:var(--sa-muted);font-size:10.5px}.admin-mark{width:36px;height:36px;border-radius:11px;color:var(--sa-ink);background:linear-gradient(145deg,var(--sa-accent-2),var(--sa-accent));box-shadow:0 10px 20px color-mix(in srgb,var(--sa-accent) 25%,transparent)}.navbar-profile{display:inline-flex;align-items:center;gap:9px;max-width:220px;min-height:36px;padding:4px 10px 4px 5px;border-radius:999px;border:1px solid var(--sa-border);background:var(--sa-surface)}.profile-avatar{display:grid;width:28px;height:28px;place-items:center;border-radius:999px;font-size:12px;font-weight:600;color:var(--sa-ink);background:linear-gradient(145deg,var(--sa-accent-2),var(--sa-accent))}.navbar-profile-text{flex-direction:column;align-items:flex-start;min-width:0}.navbar-profile strong,.navbar-profile span{max-width:154px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-shell .ghost-action.navbar-logout{min-height:36px;padding:0 14px;color:#fff;border-color:#b91c1c80;background:linear-gradient(135deg,#ef4444,#b91c1c);box-shadow:0 6px 14px #b91c1c33}.admin-shell .ghost-action.navbar-logout:hover{color:#fff;border-color:#991b1b;background:linear-gradient(135deg,#dc2626,#991b1b)}.admin-sidebar{grid-column:1;grid-row:2;position:sticky;top:56px;height:calc(100vh - 56px);display:flex;flex-direction:column;gap:10px;padding:10px 8px;border-right:1px solid var(--sa-border);background:#ffffffbf}.admin-sidebar .admin-brand{display:none}.admin-nav{display:flex;flex-direction:column;gap:8px;padding:0}.nav-button{display:inline-flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:100%;min-height:54px;padding:7px 4px;border:1px solid transparent;border-radius:12px;color:var(--sa-muted);background:transparent;text-align:center;text-decoration:none;line-height:1.08}.nav-button span{display:block;max-width:64px;font-size:10px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-button.active,.nav-button:hover{color:var(--sa-ink);border-color:color-mix(in srgb,var(--sa-accent) 35%,transparent);background:linear-gradient(180deg,var(--sa-surface),var(--sa-tint-warm));box-shadow:var(--sa-shadow)}.nav-button svg{width:18px;height:18px}.developer-note{margin-top:auto;display:grid;place-items:center;min-height:48px;padding:8px;border-radius:12px;border:1px dashed var(--sa-border);background:#ffffffe6}.developer-note svg{color:var(--sa-accent)}.developer-note div{display:none}.admin-workspace{grid-column:2;grid-row:2;padding:0;overflow-x:hidden}.sa-main{padding:20px 28px 36px}.sa-page-header{margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--sa-border)}.sa-page-header h1{margin:4px 0 0;font-size:1.65rem;font-weight:700;letter-spacing:-.02em}.sa-page-header p{margin:8px 0 0;font-size:.875rem;color:var(--sa-muted);max-width:640px;line-height:1.5}.admin-shell .section-kicker,.admin-shell .sa-kicker{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--sa-accent)}.workspace-error.sa-alert{border-radius:12px;margin-bottom:14px}.loading-line{display:flex;align-items:center;gap:9px;margin-bottom:14px;color:var(--sa-muted);font-weight:600;font-size:13px}.sa-overview{display:flex;flex-direction:column;gap:20px}.sa-kpi-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.sa-kpi{padding:16px 16px 16px 20px;border-radius:16px;border:1px solid var(--sa-border);background:linear-gradient(160deg,#ffffff 0%,var(--sa-surface-tint) 100%);box-shadow:var(--sa-shadow);position:relative;overflow:hidden}.sa-kpi:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;border-radius:16px 0 0 16px;background:linear-gradient(180deg,var(--sa-accent-2),var(--sa-accent))}.sa-kpi--purple{background:linear-gradient(160deg,#fdfbfe,#f8f5fc)}.sa-kpi--purple:before{background:linear-gradient(180deg,#d8b4fe,#a855f7)}.sa-kpi--purple .sa-kpi-icon{background:#a855f726;color:#7e22ce}.sa-kpi--blue{background:linear-gradient(160deg,#f8fbfe,#f4f8fd)}.sa-kpi--blue:before{background:linear-gradient(180deg,#93c5fd,#3b82f6)}.sa-kpi--blue .sa-kpi-icon{background:#3b82f626;color:#1d4ed8}.sa-kpi--green{background:linear-gradient(160deg,#f8fdfa,#f2fbf6)}.sa-kpi--green:before{background:linear-gradient(180deg,#86efac,#22c55e)}.sa-kpi--green .sa-kpi-icon{background:#22c55e26;color:#15803d}.sa-kpi--rose{background:linear-gradient(160deg,#fefbfb,#fdf5f6)}.sa-kpi--rose:before{background:linear-gradient(180deg,#fda4af,#ef4444)}.sa-kpi--rose .sa-kpi-icon{background:#ef444426;color:#b91c1c}.sa-kpi--slate{background:linear-gradient(160deg,#f6f6f4,#f0f0ee)}.sa-kpi--slate:before{background:linear-gradient(180deg,#b4b9bc,var(--sa-muted))}.sa-kpi-icon{display:grid;width:40px;height:40px;place-items:center;border-radius:12px;background:color-mix(in srgb,var(--sa-accent) 15%,transparent);color:var(--sa-accent);margin-bottom:10px}.sa-kpi--slate .sa-kpi-icon{background:#919a9f33}.sa-kpi label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--sa-muted);margin-bottom:4px}.sa-kpi-value{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;line-height:1.1}.sa-kpi-hint{display:block;margin-top:10px;font-size:11px;color:var(--sa-muted);line-height:1.35}.sa-dash-grid{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(260px,.55fr);gap:16px;align-items:start}.sa-card{border-radius:16px;border:1px solid var(--sa-border);background:linear-gradient(160deg,#ffffff 0%,var(--sa-surface-tint) 100%);box-shadow:var(--sa-shadow);overflow:hidden}.sa-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:16px 18px;background:linear-gradient(90deg,var(--sa-tint-cream) 0%,#ffffff 100%);border-bottom:1px solid rgba(219,219,217,.7)}.sa-panel-header h2{margin:4px 0 0;font-size:1.0625rem;font-weight:700}.sa-panel-header--action{align-items:center}.sa-card-body{padding:16px 18px}.sa-chart-frame{width:100%;height:260px}.sa-mini-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}.sa-mini-head strong{font-size:.9375rem}.sa-mini-head span{font-size:11px;color:var(--sa-muted)}.sa-chip-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px}.sa-stat-mini{padding:10px 12px;border-radius:12px;border:1px solid var(--sa-border);background:linear-gradient(180deg,var(--sa-surface),var(--sa-bg));min-width:100px;flex:1 1 auto}.sa-stat-mini span{display:block;font-size:10px;color:var(--sa-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.sa-stat-mini strong{display:block;margin-top:4px;font-size:1rem}.sa-insights{display:flex;flex-direction:column;gap:14px}.sa-list-plain{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.sa-list-plain li{display:flex;justify-content:space-between;gap:10px;padding:11px 12px;border-radius:12px;border:1px solid var(--sa-border);background:#fafafa;font-size:13px}.sa-incident-stack{display:flex;flex-direction:column;gap:16px}.sa-two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.sa-release-step{display:grid;grid-template-columns:28px minmax(0,1fr) auto;gap:10px;align-items:center;padding:12px;border-radius:14px;border:1px solid var(--sa-border);background:linear-gradient(180deg,var(--sa-surface),var(--sa-bg));font-size:13px}.sa-release-step svg{color:var(--sa-accent)}.sa-release-step span{color:var(--sa-muted);font-weight:600}.sa-release-step strong{font-weight:600;font-variant-numeric:tabular-nums}.admin-shell .empty-text{margin:0;color:var(--sa-muted);font-size:13px;font-weight:500}.sa-infra-panel{display:flex;flex-direction:column;gap:0}.sa-resource-bars-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;padding-bottom:20px}.sa-resource-bar-item{display:flex;flex-direction:column;gap:6px}.sa-resource-bar-label{display:flex;justify-content:space-between;align-items:baseline}.sa-resource-bar-label strong{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--sa-ink)}.sa-resource-bar-label span{font-size:14px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--sa-ink)}.sa-bar-track{height:8px;border-radius:999px;background:#dbdbd98c;overflow:hidden}.sa-bar-fill{height:100%;border-radius:999px;transition:width .5s ease}.sa-bar-fill--ok{background:linear-gradient(90deg,var(--sa-accent-2),var(--sa-accent))}.sa-bar-fill--warn{background:linear-gradient(90deg,var(--sa-accent),var(--sa-accent-mid))}.sa-bar-fill--critical{background:linear-gradient(90deg,#ef4444,#dc2626)}.sa-bar-fill--loading{width:30%!important;background:linear-gradient(90deg,#dbdbd999,#dbdbd959);animation:sa-bar-pulse 1.4s ease-in-out infinite}@keyframes sa-bar-pulse{0%,to{opacity:.5}50%{opacity:1}}.sa-resource-bar-desc{font-size:11px;color:var(--sa-muted);line-height:1.3}.sa-health-divider{height:1px;background:var(--sa-border);margin:4px 0 16px}.sa-health-table{display:flex;flex-direction:column;gap:4px}.sa-health-table-head{display:grid;grid-template-columns:minmax(0,1fr) 100px 80px;gap:10px;padding:0 10px 8px;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--sa-muted);border-bottom:1px solid var(--sa-border)}.sa-health-row{display:grid;grid-template-columns:minmax(0,1fr) 100px 80px;gap:10px;align-items:center;padding:9px 10px;border-radius:10px;font-size:12px;transition:background .12s}.sa-health-row:hover{background:color-mix(in srgb,var(--sa-accent) 6%,transparent)}.sa-health-name{display:grid;grid-template-columns:10px minmax(0,1fr);gap:10px;align-items:center}.sa-health-name strong{display:block;font-size:13px;font-weight:600}.sa-health-name span{display:block;margin-top:2px;font-size:11px;color:var(--sa-muted);line-height:1.3}.sa-health-latency span{font-size:12px;font-variant-numeric:tabular-nums;color:var(--sa-muted);font-weight:600}.sa-service-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--sa-chart-soft);box-shadow:0 0 0 3px #6b8f8633}.sa-service-dot.warning{background:#d97706;box-shadow:0 0 0 3px #d9770633}.sa-service-dot.critical{background:#dc2626;box-shadow:0 0 0 3px #dc262633}.sa-page-stack{display:flex;flex-direction:column;gap:18px}.sa-kpi-mini-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.sa-mini-card{display:grid;grid-template-columns:40px minmax(0,1fr);gap:10px;align-items:center;padding:12px;border-radius:14px;border:1px solid var(--sa-border);background:var(--sa-surface);box-shadow:0 4px 12px #1313130a}.sa-mini-card-icon{display:grid;width:40px;height:40px;place-items:center;border-radius:11px;background:color-mix(in srgb,var(--sa-accent) 18%,transparent);color:var(--sa-ink)}.sa-mini-card span{display:block;font-size:10px;color:var(--sa-muted);font-weight:600}.sa-mini-card strong{display:block;font-size:1rem}.sa-role-mini{display:grid;grid-template-columns:38px minmax(0,1fr);gap:8px;align-items:center;padding:12px;border-radius:14px;border:1px solid var(--sa-border);background:linear-gradient(180deg,var(--sa-surface),var(--sa-bg));font-size:12px}.sa-role-icon{width:36px;height:36px;border-radius:10px;background:#919a9f2e;display:grid;place-items:center}.sa-strip{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;padding:16px;border-radius:16px;border:1px solid var(--sa-border);background:linear-gradient(90deg,var(--sa-surface),#fdfbf7);box-shadow:var(--sa-shadow)}.sa-strip h2{margin:4px 0 0;font-size:1rem}.sa-module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.sa-module-card{display:grid;grid-template-columns:48px minmax(0,1fr) auto;gap:12px;align-items:start;padding:16px;border-radius:16px;border:1px solid var(--sa-border);background:var(--sa-surface);box-shadow:0 4px 14px #1313130d;min-height:110px}.sa-module-card p{margin:4px 0 0;font-size:12px;color:var(--sa-muted);line-height:1.45}.sa-module-icon{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:#fac95a59}.sa-split{display:grid;grid-template-columns:minmax(260px,.92fr) minmax(280px,1.08fr);gap:16px;align-items:start}.sa-log-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.sa-log-filters .sa-chip{gap:8px}.sa-log-filters .sa-chip span{min-width:22px;padding:2px 7px;border-radius:999px;background:#919a9f24;color:var(--sa-muted);font-size:10px;font-variant-numeric:tabular-nums}.sa-log-filters .sa-chip.is-active span{background:#fff9;color:var(--sa-ink)}.sa-log-table-card .sa-card-body{padding-top:14px}.sa-log-table-head,.sa-log-table-row{grid-template-columns:minmax(210px,1.35fr) minmax(150px,.9fr) minmax(150px,.9fr) minmax(110px,.66fr) minmax(118px,.72fr) minmax(150px,.74fr)}.sa-log-table-row{font-size:12px}.sa-log-table-row>span,.sa-log-table-row>small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sa-log-table-row>small{color:var(--sa-muted);font-size:11.5px;font-variant-numeric:tabular-nums}.sa-log-action{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;align-items:center;min-width:0}.sa-log-action strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12.5px;font-weight:600}.sa-audit-icon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:#919a9f29;color:var(--sa-ink)}.sa-log-empty{padding:14px 12px}.sa-support-filters{margin:4px 0 12px}.sa-settings-form{display:grid;gap:14px}.sa-settings-tabs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px;border-radius:16px;border:1px solid var(--sa-border);background:var(--sa-surface)}.sa-settings-tab{min-height:38px;border:0;border-radius:12px;background:transparent;color:var(--sa-muted);padding:8px 11px;display:inline-flex;align-items:center;gap:8px;font:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:background .14s ease,color .14s ease,box-shadow .14s ease}.sa-settings-tab:hover{background:#919a9f1a;color:var(--sa-ink)}.sa-settings-tab.is-active{background:#fff7df;color:var(--sa-ink);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--sa-accent) 24%,transparent)}.sa-settings-tab-icon{width:24px;height:24px;border-radius:8px;display:grid;place-items:center;background:#919a9f1f}.sa-settings-tab.is-active .sa-settings-tab-icon{background:color-mix(in srgb,var(--sa-accent) 18%,transparent)}.sa-settings-tab small{min-width:20px;padding:2px 6px;border-radius:999px;background:#919a9f24;color:var(--sa-muted);font-size:10px;font-weight:700;font-variant-numeric:tabular-nums}.sa-settings-tab-card .sa-card-body{padding:18px}.sa-maintenance-tab{display:grid;gap:16px;max-width:760px}.sa-maintenance-state{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--sa-border)}.sa-maint-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;font-size:12px;font-weight:600;background:#919a9f26;border:1px solid var(--sa-border)}.sa-maint-pill.enabled{background:#fca5a540;border-color:#ef444473}.sa-settings-meta{display:grid;gap:6px;margin-top:14px;padding-top:14px;border-top:1px solid var(--sa-border)}.sa-settings-meta span{font-size:11px;font-weight:700;color:var(--sa-muted);text-transform:uppercase}.sa-settings-meta strong{font-size:13px}.sa-maintenance-state .sa-settings-meta{margin:0;padding:0;border:0;text-align:right}.sa-cred-list{display:flex;flex-direction:column;gap:12px}.sa-settings-grid{display:grid;grid-template-columns:minmax(300px,.4fr) minmax(320px,1fr);gap:16px;align-items:start}.sa-save-bar{display:flex;justify-content:flex-end;padding-top:4px}.sa-credential{display:grid;grid-template-columns:42px minmax(0,1fr);gap:12px;padding:14px;border-radius:14px;border:1px solid var(--sa-border);background:var(--sa-surface)}.sa-cred-icon{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:#fac95a59}.sa-cred-rows{display:flex;flex-direction:column;gap:10px}.sa-credential-title{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px}.admin-shell .credential-input-row,.admin-shell .credential-title-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}.admin-shell .clear-check{font-size:12px;color:var(--sa-muted);font-weight:600;white-space:nowrap}.sa-data-grid{display:flex;flex-direction:column;gap:8px}.sa-row-head{display:grid;gap:10px;padding:0 12px;min-height:32px;align-items:center;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--sa-muted)}.sa-row-body{display:grid;gap:10px;padding:11px 12px;border-radius:12px;border:1px solid var(--sa-border);background:linear-gradient(180deg,var(--sa-surface),var(--sa-bg));align-items:center;transition:transform .14s ease,box-shadow .14s ease}.sa-row-body:hover{transform:translateY(-1px);box-shadow:0 6px 14px #13131312}.sa-row-body.sa-row-selected{border-color:color-mix(in srgb,var(--sa-accent) 45%,transparent);background:linear-gradient(180deg,var(--sa-tint-cream),color-mix(in srgb,var(--sa-accent) 8%,transparent))}.sa-row-body-cell small{display:block;font-size:11px;color:var(--sa-muted);margin-top:2px}.sa-institutions-head,.sa-institutions-row{grid-template-columns:minmax(200px,1.55fr) .7fr .52fr .55fr .68fr 48px}.sa-users-mini-head,.sa-users-mini-row{grid-template-columns:minmax(200px,1.38fr) minmax(140px,1fr) .74fr .68fr 48px}.sa-users-global-head,.sa-users-global-row{grid-template-columns:minmax(160px,1.35fr) minmax(140px,1fr) .58fr .58fr 92px}.sa-support-head,.sa-support-row{grid-template-columns:minmax(200px,1.52fr) minmax(140px,1fr) .62fr .68fr .58fr}.sa-icon-btn{display:grid;width:34px;height:34px;place-items:center;border-radius:11px;border:1px solid var(--sa-border);background:var(--sa-surface);color:var(--sa-accent)}.sa-icon-btn.danger{color:#b91c1c;border-color:#b91c1c40}.sa-row-actions{display:flex;gap:6px}.sa-chip{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;border:1px solid var(--sa-border);background:var(--sa-surface);font-size:12px;font-weight:600;color:var(--sa-muted);cursor:pointer;transition:border-color .15s,background .15s,color .15s}.sa-chip:hover{border-color:var(--sa-accent);color:var(--sa-ink)}.sa-chip.is-active{background:color-mix(in srgb,var(--sa-accent) 90%,transparent);border-color:var(--sa-accent);color:var(--sa-ink)}.admin-shell .status-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 9px;border-radius:999px;font-size:10px;font-weight:600}.admin-shell .status-badge.active,.admin-shell .status-badge.operational,.admin-shell .status-badge.configured,.admin-shell .status-badge.resolved,.admin-shell .status-badge.support,.admin-shell .status-badge.high,.admin-shell .status-badge.closed{color:#374151;background:#919a9f33}.admin-shell .status-badge.trial,.admin-shell .status-badge.planned,.admin-shell .status-badge.normal,.admin-shell .status-badge.warning,.admin-shell .status-badge.suggestion{background:color-mix(in srgb,var(--sa-accent) 22%,transparent);color:var(--sa-ink)}.admin-shell .status-badge.passive{background:#e5e7ebcc}.admin-shell .status-badge.report,.admin-shell .status-badge.open,.admin-shell .status-badge.missing,.admin-shell .status-badge.critical{background:#ef44441f;color:#991b1b}.admin-shell .status-badge.low{background:#e5e7ebe6;color:#4b5563}.admin-shell .status-badge.high,.admin-shell .status-badge.complaint,.admin-shell .status-badge.invited{background:#ef44441a}.admin-shell .status-badge.normal{background:#fac95a47}.admin-shell .status-badge.warning{background:#fbbf2459}.admin-shell .severity-badge{padding:3px 8px;border-radius:6px;font-size:10px;font-weight:700}.admin-shell .sensitivity-badge{padding:3px 8px;border-radius:6px;font-size:10px;background:#919a9f26}.admin-shell .support-ticket-row{width:100%;text-align:left;font:inherit;color:inherit;cursor:pointer}.support-ticket-cell{display:grid;grid-template-columns:38px minmax(0,1fr);gap:10px;align-items:center}.sa-type-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:color-mix(in srgb,var(--sa-accent) 15%,transparent);color:var(--sa-ink)}.sa-message-block{padding:14px;border-radius:14px;border:1px solid var(--sa-border);background:linear-gradient(180deg,var(--sa-surface),var(--sa-bg))}.sa-message-meta span{display:block;font-size:10px;font-weight:700;text-transform:uppercase;color:var(--sa-muted)}.sa-message-meta strong{display:block;margin-top:4px;font-size:12px}.sa-message-block p{margin:10px 0 0;font-size:13px;line-height:1.55;white-space:pre-wrap}.sa-form-stack{display:flex;flex-direction:column;gap:13px}.sa-inline-controls{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.admin-shell .inline-form.sa-form-grid-four{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr)) auto;gap:12px;align-items:end}.admin-shell .inline-form.sa-user-create-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr)) auto;gap:12px;align-items:end}.sa-credential-banner{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;padding:14px;border-radius:14px;border:1px solid color-mix(in srgb,var(--sa-accent) 45%,transparent);background:#fac95a26}.sa-credential-banner code{display:block;margin-top:6px;font-family:ui-monospace,monospace}.sa-split-main{display:grid;grid-template-columns:minmax(0,1.52fr) minmax(260px,.78fr);gap:16px;align-items:start}.support-detail-pane,.user-edit-pane{position:sticky;top:72px}.tenant-map-flex{display:flex;flex-wrap:wrap;gap:12px;padding:4px}.tenant-chip{display:flex;flex-direction:column;gap:4px;min-width:140px;padding:12px;border-radius:14px;border:1px solid var(--sa-border);background:linear-gradient(180deg,var(--sa-surface),var(--sa-bg));text-align:left;cursor:pointer}.tenant-chip strong{font-size:13px}.tenant-chip span{font-size:11px;color:var(--sa-muted)}.tenant-chip.selected{border-color:color-mix(in srgb,var(--sa-accent) 50%,transparent);background:#fac95a1f}.sa-tenant-top{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,280px);gap:16px;align-items:stretch}.detail-meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.meta-line{display:grid;gap:4px;margin-top:14px;padding-top:14px;border-top:1px solid var(--sa-border);font-size:11px;color:var(--sa-muted);font-weight:600}.admin-shell .form-actions.sa-form-actions-split{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px}.admin-shell .primary-action.small-action{min-height:36px;padding:0 12px;font-size:12px;border-radius:11px;color:var(--sa-ink);background:linear-gradient(145deg,var(--sa-accent-2),var(--sa-accent));border:none}.admin-shell .primary-action.small-action:hover{filter:brightness(.98)}.admin-shell .primary-action:not(.navbar-logout){color:var(--sa-ink);background:linear-gradient(145deg,var(--sa-accent-2),var(--sa-accent));border:none;text-decoration:none}.admin-shell .primary-action:not(.navbar-logout):hover{filter:brightness(.96)}.admin-shell .ghost-action:not(.navbar-logout){border-color:var(--sa-border);color:var(--sa-ink);background:var(--sa-surface);text-decoration:none}.admin-shell .ghost-action:not(.navbar-logout):hover{border-color:var(--sa-accent);background:#fac95a1f}.admin-shell .ghost-action.danger-text{color:#b91c1c;border-color:#b91c1c47}.admin-shell .toggle-row span{background:#dbdbd9e6}.admin-shell .toggle-row input:checked+span{background:var(--sa-accent)}.support-ticket-cell small{display:block;margin-top:4px;font-size:11px;color:var(--sa-muted)}.sa-inst-summary{margin-bottom:4px}.sa-inst-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}.sa-inst-card{position:relative;display:flex;flex-direction:column;gap:14px;padding:18px 18px 16px;border-radius:18px;border:1px solid var(--sa-border);background:linear-gradient(160deg,#fff,#fdfcfa);box-shadow:0 6px 18px #1313130d;text-decoration:none;color:inherit;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;min-height:220px}.sa-inst-card:hover{transform:translateY(-3px);box-shadow:0 16px 32px #1313131a}.sa-inst-card-band{position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--sa-accent-2),var(--sa-accent))}.sa-inst-card--plan-mvp .sa-inst-card-band{background:linear-gradient(90deg,#93c5fd,#3b82f6)}.sa-inst-card--plan-starter .sa-inst-card-band{background:linear-gradient(90deg,#d8b4fe,#8b5cf6)}.sa-inst-card--plan-growth .sa-inst-card-band{background:linear-gradient(90deg,#86efac,#10b981)}.sa-inst-card--plan-premium .sa-inst-card-band{background:linear-gradient(90deg,#fcd34d,#f59e0b)}.sa-inst-card--plan-trial .sa-inst-card-band{background:linear-gradient(90deg,#cbd5e1,#94a3b8)}.sa-inst-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-top:6px}.sa-inst-card-icon{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--sa-accent) 16%,transparent);color:var(--sa-accent)}.sa-inst-card--plan-mvp .sa-inst-card-icon{background:#3b82f624;color:#1d4ed8}.sa-inst-card--plan-starter .sa-inst-card-icon{background:#8b5cf624;color:#6d28d9}.sa-inst-card--plan-growth .sa-inst-card-icon{background:#10b98124;color:#047857}.sa-inst-card--plan-premium .sa-inst-card-icon{background:#f59e0b29;color:var(--sa-accent-deep)}.sa-inst-card--plan-trial .sa-inst-card-icon{background:#94a3b82e;color:#475569}.sa-inst-card-badges{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.sa-inst-card-body h3{margin:0;font-size:1.05rem;font-weight:700;letter-spacing:-.01em;line-height:1.3}.sa-inst-card-meta{display:inline-flex;align-items:center;gap:6px;margin:6px 0 0;font-size:11.5px;color:var(--sa-muted)}.sa-inst-card-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:auto}.sa-inst-card-stats>div{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:11px;border:1px solid var(--sa-border);background:#fff9}.sa-inst-card-stats svg{color:var(--sa-muted)}.sa-inst-card-stats span{display:block;font-size:10px;color:var(--sa-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.sa-inst-card-stats strong{display:block;font-size:1rem;font-weight:700;font-variant-numeric:tabular-nums}.sa-inst-card-foot{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--sa-muted);padding-top:8px;border-top:1px solid rgba(219,219,217,.6)}.sa-inst-card-cta{display:inline-flex;align-items:center;gap:4px;font-weight:600;color:var(--sa-accent)}.sa-inst-card:hover .sa-inst-card-cta{color:#d97706}.sa-inst-card--add{display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;gap:10px;padding:24px;border:2px dashed color-mix(in srgb,var(--sa-accent) 50%,transparent);background:linear-gradient(160deg,#fffcf499,#fff5da66);cursor:pointer;font-family:inherit;color:var(--sa-ink);min-height:220px}.sa-inst-card--add:hover{border-color:var(--sa-accent);background:linear-gradient(160deg,#fff8e8,#fde3a8);box-shadow:0 14px 30px color-mix(in srgb,var(--sa-accent) 18%,transparent)}.sa-inst-card-add-icon{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(145deg,var(--sa-accent-2),var(--sa-accent));color:#fff;box-shadow:0 12px 22px color-mix(in srgb,var(--sa-accent) 30%,transparent)}.sa-inst-card--add strong{font-size:1rem}.sa-inst-card--add span{font-size:12px;color:var(--sa-muted);max-width:200px;line-height:1.4}.sa-plan-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:999px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;background:#919a9f2e;color:var(--sa-ink);border:1px solid transparent}.sa-plan-badge--mvp{background:#3b82f624;color:#1d4ed8}.sa-plan-badge--starter{background:#8b5cf624;color:#6d28d9}.sa-plan-badge--growth{background:#10b98129;color:#047857}.sa-plan-badge--premium{background:#f59e0b29;color:var(--sa-accent-deep)}.sa-plan-badge--trial{background:#94a3b833;color:#334155}.sa-detail-back{margin:-4px 0 0}.sa-back-link{display:inline-flex;align-items:center;gap:6px;padding:6px 12px 6px 8px;border-radius:999px;border:1px solid var(--sa-border);background:var(--sa-surface);color:var(--sa-muted);font-weight:600;font-size:12px;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.sa-back-link:hover{color:var(--sa-ink);border-color:var(--sa-accent);background:var(--sa-tint-warm)}.sa-detail-hero{position:relative;display:grid;grid-template-columns:60px minmax(0,1fr) auto;gap:16px;align-items:center;padding:20px 22px;border-radius:18px;border:1px solid var(--sa-border);background:linear-gradient(135deg,#ffffff,var(--sa-tint-warm));box-shadow:var(--sa-shadow);overflow:hidden}.sa-detail-hero:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;background:linear-gradient(180deg,var(--sa-accent-2),var(--sa-accent))}.sa-detail-hero--mvp:before{background:linear-gradient(180deg,#93c5fd,#3b82f6)}.sa-detail-hero--starter:before{background:linear-gradient(180deg,#d8b4fe,#8b5cf6)}.sa-detail-hero--growth:before{background:linear-gradient(180deg,#86efac,#10b981)}.sa-detail-hero--premium:before{background:linear-gradient(180deg,#fcd34d,#f59e0b)}.sa-detail-hero--trial:before{background:linear-gradient(180deg,#cbd5e1,#94a3b8)}.sa-detail-hero-icon{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(145deg,var(--sa-accent-2),var(--sa-accent));color:#fff;box-shadow:0 10px 20px color-mix(in srgb,var(--sa-accent) 22%,transparent)}.sa-detail-hero--mvp .sa-detail-hero-icon{background:linear-gradient(145deg,#93c5fd,#3b82f6);box-shadow:0 10px 20px #3b82f638}.sa-detail-hero--starter .sa-detail-hero-icon{background:linear-gradient(145deg,#d8b4fe,#8b5cf6);box-shadow:0 10px 20px #8b5cf638}.sa-detail-hero--growth .sa-detail-hero-icon{background:linear-gradient(145deg,#86efac,#10b981);box-shadow:0 10px 20px #10b98138}.sa-detail-hero--premium .sa-detail-hero-icon{background:linear-gradient(145deg,#fcd34d,#f59e0b);box-shadow:0 10px 20px #f59e0b38}.sa-detail-hero--trial .sa-detail-hero-icon{background:linear-gradient(145deg,#cbd5e1,#94a3b8);box-shadow:0 10px 20px #94a3b838}.sa-detail-hero-text h1{margin:4px 0 0;font-size:1.6rem;font-weight:700;letter-spacing:-.02em}.sa-detail-hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;align-items:center}.sa-detail-hero-meta{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--sa-muted);font-weight:600}.sa-detail-hero-loading{display:grid;place-items:center;color:var(--sa-accent)}.sa-detail-info{display:flex;flex-direction:column;gap:14px;padding:16px;border-radius:16px;border:1px solid var(--sa-border);background:var(--sa-surface);box-shadow:0 4px 14px #1313130a}.sa-detail-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;padding:12px;border-radius:12px;background:linear-gradient(180deg,#fafaf8,#fffefb);border:1px solid var(--sa-border)}.sa-detail-meta>div{display:flex;flex-direction:column;gap:2px;font-size:12px}.sa-detail-meta strong{font-weight:600;font-size:13px;word-break:break-all}.sa-detail-users{display:flex;flex-direction:column;gap:14px;padding:16px;border-radius:16px;border:1px solid var(--sa-border);background:var(--sa-surface);box-shadow:0 4px 14px #1313130a}.sa-detail-users-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}.sa-detail-users-head h2{margin:4px 0 0;font-size:1.05rem}.sa-user-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.sa-user-card{display:grid;grid-template-columns:48px minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px 12px 12px 14px;border-radius:14px;border:1px solid var(--sa-border);background:linear-gradient(180deg,#fff,#fafaf8);transition:transform .15s,box-shadow .15s,border-color .15s}.sa-user-card:hover{transform:translateY(-2px);box-shadow:0 10px 22px #1313130f;border-color:color-mix(in srgb,var(--sa-accent) 40%,transparent)}.sa-user-avatar{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-size:14px;font-weight:700;color:#fff;background:linear-gradient(145deg,#94a3b8,#475569);flex-shrink:0}.sa-user-avatar--super{background:linear-gradient(145deg,var(--sa-accent),var(--sa-accent-deep))}.sa-user-avatar--system{background:linear-gradient(145deg,#60a5fa,#1d4ed8)}.sa-user-avatar--principal{background:linear-gradient(145deg,#a78bfa,#6d28d9)}.sa-user-avatar--guidance{background:linear-gradient(145deg,#34d399,#047857)}.sa-user-avatar--teacher{background:linear-gradient(145deg,#fbbf24,var(--sa-accent-deep))}.sa-user-avatar--guardian{background:linear-gradient(145deg,#f472b6,#be185d)}.sa-user-card-body{display:flex;flex-direction:column;gap:4px;min-width:0}.sa-user-card-body strong{font-size:13px;font-weight:600;color:var(--sa-ink);line-height:1.2}.sa-user-email{font-size:11px;color:var(--sa-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sa-user-card-badges{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}.sa-role-badge{display:inline-flex;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700;background:#919a9f2e;color:var(--sa-ink);text-transform:uppercase;letter-spacing:.04em}.sa-role-badge--super{background:color-mix(in srgb,var(--sa-accent) 18%,transparent);color:var(--sa-accent-deep)}.sa-role-badge--system{background:#3b82f629;color:#1d4ed8}.sa-role-badge--principal{background:#8b5cf629;color:#6d28d9}.sa-role-badge--guidance{background:#10b98129;color:#047857}.sa-role-badge--teacher{background:#fbbf2433;color:#92400e}.sa-role-badge--guardian{background:#f472b62e;color:#be185d}.sa-user-card-actions{display:flex;flex-direction:column;gap:6px}.sa-user-card-actions .sa-icon-btn[disabled]{opacity:.35;cursor:not-allowed}.sa-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#13131373;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;padding:16px;z-index:100;animation:sa-modal-fade .18s ease}@keyframes sa-modal-fade{0%{opacity:0}to{opacity:1}}.sa-modal{width:100%;max-width:520px;max-height:calc(100vh - 32px);overflow:auto;background:#fff;border-radius:18px;border:1px solid var(--sa-border);box-shadow:0 24px 60px #13131340;animation:sa-modal-pop .22s ease}@keyframes sa-modal-pop{0%{transform:translateY(8px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.sa-modal--sm{max-width:420px}.sa-modal--lg{max-width:680px}.sa-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 22px 12px;border-bottom:1px solid var(--sa-border);background:linear-gradient(90deg,var(--sa-tint-cream),#ffffff)}.sa-modal-heading h2{display:flex;align-items:center;gap:8px;margin:4px 0 0;font-size:1.1rem;font-weight:700}.sa-modal-title-icon{display:grid;place-items:center;width:28px;height:28px;border-radius:9px;background:color-mix(in srgb,var(--sa-accent) 18%,transparent);color:var(--sa-accent)}.sa-modal-close{width:32px;height:32px;border-radius:10px;border:1px solid var(--sa-border);background:var(--sa-surface);display:grid;place-items:center;cursor:pointer;color:var(--sa-muted);transition:color .15s,border-color .15s,background .15s}.sa-modal-close:hover{color:#b91c1c;border-color:#b91c1c66;background:#fef2f2}.sa-modal-body{padding:18px 22px 22px}.sa-modal-form{display:flex;flex-direction:column;gap:12px}.sa-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px;padding-top:12px;border-top:1px solid var(--sa-border)}.sa-modal-actions .ghost-action,.sa-modal-actions .primary-action{min-width:110px;justify-content:center}@media(max-width:1080px){.admin-shell{grid-template-columns:1fr;grid-template-rows:56px auto minmax(0,1fr)}.admin-navbar{grid-row:1}.admin-sidebar{grid-column:1;grid-row:2;flex-direction:row;align-items:center;height:auto;position:sticky;top:56px;z-index:20;border-right:0;border-bottom:1px solid var(--sa-border);overflow-x:auto}.admin-nav{flex-direction:row;gap:6px}.nav-button{min-width:68px;min-height:48px}.developer-note{display:none}.admin-workspace{grid-column:1;grid-row:3}.sa-kpi-row{grid-template-columns:repeat(2,minmax(0,1fr))}.sa-dash-grid,.sa-two-col,.sa-split,.sa-split-main,.sa-settings-grid,.sa-tenant-top{grid-template-columns:1fr}.sa-log-table-head,.sa-log-table-row{grid-template-columns:minmax(180px,1.2fr) minmax(130px,.9fr) minmax(130px,.9fr) minmax(100px,.65fr) minmax(112px,.72fr) minmax(135px,.74fr)}.sa-detail-hero{grid-template-columns:56px minmax(0,1fr)}.sa-detail-hero-loading{display:none}.support-detail-pane,.user-edit-pane{position:static}}@media(max-width:760px){.navbar-brand span,.navbar-profile span{display:none}.navbar-profile strong{max-width:100px}.sa-kpi-row{grid-template-columns:1fr}.sa-chart-frame{height:220px}.sa-row-head{display:none}.sa-row-body,.sa-users-global-row,.sa-users-mini-row,.sa-institutions-row,.sa-support-row,.sa-log-table-row,.sa-inst-grid,.sa-user-card-grid{grid-template-columns:1fr}.sa-detail-hero h1{font-size:1.3rem}.sa-modal{max-height:calc(100vh - 16px);border-radius:14px}}
