:root{--color-primary: #2e2b6e;--color-primary-dark: #211f52;--color-primary-soft: #eeedfb;--color-accent: #fbc388;--color-accent-soft: #fff3e2;--color-bg: #f7f8fc;--color-text: #12172a;--color-muted: #667085;--color-border: #e4e7ec;--color-card: #fff;--chart-positive: #10b981;--chart-positive-soft: #d1fae5;--chart-negative: #ef4444;--chart-negative-soft: #fee2e2;--chart-warning: #f59e0b;--chart-warning-soft: #fef3c7;--chart-neutral: #6366f1;--chart-neutral-soft: #e0e7ff;--chart-info: #06b6d4;--chart-info-soft: #cffafe;--chart-violet: #8b5cf6;--chart-violet-soft: #ede9fe;--chart-pink: #ec4899;--chart-pink-soft: #fce7f3;--chart-grid: rgba(228, 231, 236, .55);--chart-axis-tick: #98a2b3;--chart-module-1: #6366f1;--chart-module-2: #10b981;--chart-module-3: #f59e0b;--chart-module-4: #06b6d4;--chart-module-5: #ec4899;--chart-module-6: #8b5cf6;--chart-module-7: #ef4444;--chart-module-8: #14b8a6;--heatmap-0: #f1f3f8;--heatmap-1: #e0e7ff;--heatmap-2: #c7d2fe;--heatmap-3: #a5b4fc;--heatmap-4: #818cf8;--heatmap-5: #6366f1;--heatmap-6: #4f46e5;--shadow-sm: 0 1px 2px rgba(18, 23, 42, .04), 0 1px 3px rgba(18, 23, 42, .06);--shadow-md: 0 2px 4px rgba(18, 23, 42, .05), 0 8px 24px rgba(18, 23, 42, .08);--shadow-lg: 0 8px 16px rgba(18, 23, 42, .06), 0 24px 48px rgba(18, 23, 42, .12);--color-skeleton-base: #eef0f5;--color-skeleton-highlight: #fafbfd;color:var(--color-text);background:var(--color-bg);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}@keyframes anal-count-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes anal-fade-in-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes anal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes anal-slide-in-right{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}@keyframes anal-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;background:radial-gradient(circle at top left,rgba(251,195,136,.18),transparent 32rem),var(--color-bg)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid rgba(251,195,136,.72);outline-offset:2px}.screen-center{display:grid;min-height:100vh;place-items:center}.login-page{align-items:center;background:linear-gradient(135deg,#2e2b6ef0,#2e2b6eb8),radial-gradient(circle at 22% 22%,rgba(251,195,136,.34),transparent 28rem),linear-gradient(180deg,#f7f8fc,#eceef8);background-position:center;background-size:cover;display:flex;justify-content:center;min-height:100vh;padding:24px}.login-panel{background:#fffffffa;border:1px solid rgba(251,195,136,.38);border-radius:8px;box-shadow:0 28px 90px #12172a47;display:grid;gap:26px;max-width:430px;padding:32px;width:100%}.login-panel:before{background:var(--color-accent);border-radius:999px;content:"";height:4px;width:76px}.login-brand,.brand,.user-menu,.nav-item,.field,.task-item{align-items:center;display:flex}.login-brand,.brand{gap:12px}.brand-logo,.login-logo{display:block;height:auto;object-fit:contain}.login-logo{max-width:96px}.brand-logo{flex:0 0 auto;max-width:54px}.login-brand strong,.brand strong{display:block;font-size:18px}.login-brand span,.brand span,.muted,.topbar p,.stat-card p{color:var(--color-muted)}.eyebrow{color:var(--color-primary);font-size:12px;font-weight:800;letter-spacing:0;margin:0 0 6px;text-transform:uppercase}h1,h2,p{margin-top:0}h1{font-size:clamp(30px,5vw,44px);letter-spacing:0;line-height:1.05;margin-bottom:12px}h2{font-size:22px;margin-bottom:0}.login-form{display:grid;gap:16px}.login-form label{color:#283046;display:grid;font-size:14px;font-weight:700;gap:8px}.field{background:#fbfcff;border:1px solid #d7dbea;border-radius:8px;gap:10px;min-height:46px;padding:0 12px}.field input{background:transparent;border:0;color:var(--color-text);min-width:0;outline:0;width:100%}.login-form button{background:var(--color-primary);border:0;border-radius:8px;color:#fff;font-weight:800;min-height:48px}.login-form button:hover:not(:disabled){background:var(--color-primary-dark)}.login-form button:disabled{opacity:.7}.error-text,.danger{color:#b42318}.app-shell{display:grid;background:var(--color-bg);grid-template-columns:292px minmax(0,1fr);min-height:100vh;width:100%}.sidebar{background:linear-gradient(180deg,#fff,#f7f8fc);border-right:1px solid var(--color-border);color:var(--color-text);padding:24px}.mobile-sidebar-overlay,.sidebar-close-button,.mobile-topbar-brand{display:none}.brand{align-items:flex-start;margin-bottom:34px}.brand span{color:var(--color-primary);font-size:13px;font-weight:700}.nav-list{display:grid;gap:8px}.nav-item{border-radius:8px;color:#344054;gap:10px;padding:12px}.nav-item.active,.nav-item:hover{background:var(--color-primary);box-shadow:0 10px 22px #2e2b6e2e;color:#fff}.nav-item.active svg,.nav-item:hover svg{color:var(--color-accent)}.main-panel{margin-inline:auto;max-width:1440px;min-width:0;padding:28px;width:100%}.topbar{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:28px}.topbar-title{min-width:0}.topbar h1{margin-bottom:8px;overflow-wrap:anywhere}.user-menu{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;gap:12px;padding:10px 12px;white-space:nowrap}.topbar-actions{align-items:center;display:flex;gap:12px;min-width:0}.icon-button{align-items:center;background:var(--color-primary-soft);border:0;border-radius:8px;color:var(--color-primary);display:inline-flex;height:36px;justify-content:center;width:36px}.icon-button:hover{background:var(--color-primary);color:#fff}.notifications-menu,.notification-button{position:relative}.notification-badge{align-items:center;background:#b42318;border:2px solid #fff;border-radius:999px;color:#fff;display:inline-flex;font-size:11px;font-weight:900;height:22px;justify-content:center;min-width:22px;padding:0 5px;position:absolute;right:-8px;top:-8px}.notifications-dropdown{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 24px 60px #12172a29;display:grid;gap:12px;max-height:min(560px,calc(100vh - 120px));overflow:auto;padding:14px;position:absolute;right:0;top:48px;width:min(390px,calc(100vw - 40px));z-index:20}.notifications-dropdown-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.notifications-dropdown-header button,.notifications-all-link,.notification-preview button,.notification-filter-form button{align-items:center;background:var(--color-primary);border:0;border-radius:8px;color:#fff;display:inline-flex;font-size:13px;font-weight:800;min-height:34px;padding:0 10px}.notifications-dropdown-header button:disabled{cursor:not-allowed;opacity:.55}.notifications-dropdown-list,.notifications-page-list{display:grid;gap:10px}.notification-preview,.notification-card{background:#fbfcff;border:1px solid #edf0f7;border-left:4px solid transparent;border-radius:8px}.notification-preview{align-items:start;display:grid;gap:12px;grid-template-columns:minmax(0,1fr) auto;padding:12px}.notification-preview.unread,.notification-card.unread{border-left-color:var(--color-accent);background:#fffaf2}.notification-preview p,.notification-card p{color:#344054;margin:4px 0 8px}.notification-preview time,.notification-card time,.read-dot{color:var(--color-muted);font-size:12px;font-weight:700}.notification-preview button{background:var(--color-primary-soft);color:var(--color-primary);white-space:nowrap}.notifications-all-link{justify-content:center;min-height:40px}.dropdown-notice{background:#f8fafc;border:1px solid #edf2f7;border-radius:8px;padding:10px 12px}.stats-grid{display:grid;gap:16px;grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:24px}.stat-card,.work-panel,.notice{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px}.stat-card{box-shadow:0 14px 32px #12172a0d;min-height:150px;padding:20px;position:relative}.stat-card:after{background:var(--color-accent);border-radius:999px;content:"";height:3px;left:20px;position:absolute;right:20px;top:0}.stat-icon{align-items:center;background:var(--color-primary-soft);border-radius:8px;color:var(--color-primary);display:inline-flex;height:42px;justify-content:center;margin-bottom:18px;width:42px}.stat-card p{margin-bottom:8px}.stat-card strong{font-size:34px;color:var(--color-text)}.work-panel{display:grid;gap:22px;padding:24px}.analytics-toolbar{align-items:center;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;display:flex;gap:16px;justify-content:space-between;margin-bottom:18px;padding:16px 18px}.analytics-refresh{align-items:center;display:inline-flex;gap:8px}.analytics-filter-form{align-items:end;display:grid;grid-template-columns:minmax(180px,1fr) repeat(3,minmax(120px,160px)) repeat(3,auto)}.analytics-filter-form label{color:#344054;display:grid;font-size:13px;font-weight:800;gap:7px}.analytics-filter-form input,.analytics-filter-form select{background:#f8fafc;border:1px solid #d0d5dd;border-radius:8px;color:#18202a;min-height:40px;min-width:0;padding:0 10px;width:100%}.analytics-grid{display:grid;gap:18px;grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:18px}.referral-analytics-grid{margin-bottom:0}.analytics-chart-grid{display:grid;gap:18px;grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:18px}.analytics-section{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;display:grid;gap:14px;min-width:0;padding:20px}.analytics-section-header{align-items:center;display:flex;justify-content:space-between}.analytics-section h2{font-size:20px;margin:0}.analytics-section h3{color:#344054;font-size:14px;margin:8px 0 0}.analytics-mini-stats{display:flex;flex-wrap:wrap;gap:8px}.analytics-mini-stats span{background:#f8fafc;border:1px solid #edf2f7;border-radius:8px;color:#475467;display:inline-flex;gap:6px;padding:8px 10px}.analytics-mini-stats strong{color:var(--color-text)}.analytics-chart-list{display:grid;gap:12px}.analytics-chart-row{background:#fbfcff;border:1px solid #edf2f7;border-radius:8px;color:inherit;display:grid;gap:8px;min-width:0;padding:12px}.analytics-chart-row-main{align-items:center;display:flex;gap:10px;justify-content:space-between;min-width:0}.analytics-chart-row-main span{color:#344054;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analytics-chart-row-main strong{color:var(--color-text);flex:0 0 auto;font-size:13px}.analytics-bar-track{background:#eef2f6;border-radius:999px;height:9px;overflow:hidden;width:100%}.analytics-bar-fill{background:var(--color-primary);border-radius:inherit;height:100%;width:var(--bar-width)}.analytics-list{display:grid;gap:10px}.analytics-list-row{align-items:center;background:#fbfcff;border:1px solid #edf2f7;border-radius:8px;color:inherit;display:flex;gap:12px;justify-content:space-between;min-width:0;padding:12px}.analytics-list-row div{display:grid;gap:4px;min-width:0}.analytics-list-row span:not(.badge){color:#667085}.analytics-list-meta{align-items:end;justify-items:end;text-align:right}.analytics-table{border:1px solid #eef2f6;border-radius:8px}.analytics-table table{min-width:720px}.analytics-inline-link{font-size:12px;min-height:30px;padding:0 10px}.task-list{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.task-item{background:#fbfcff;border:1px solid #edf0f7;border-radius:8px;gap:10px;min-height:48px;padding:12px}.notice{margin-bottom:18px;padding:14px 16px}.success{color:#027a48}.password-rules{display:flex;flex-wrap:wrap;gap:8px}.password-rule{background:#f2f4f7;border-radius:999px;color:#667085;font-size:12px;font-weight:800;padding:7px 10px}.password-rule.valid{background:#dcfae6;color:#027a48}.account-security-panel{max-width:760px}.page-actions{align-items:center;gap:12px;display:flex;flex-wrap:wrap;justify-content:flex-end;margin-bottom:16px}.primary-link,.form-actions button,.compact-form button{align-items:center;background:var(--color-primary);border:0;border-radius:8px;color:#fff;display:inline-flex;font-weight:800;gap:8px;min-height:42px;padding:0 16px}button.primary-link{border:0}.primary-link:hover,.form-actions button:hover,.compact-form button:hover,.users-filter-form button:hover,.report-filter-form button:hover{background:var(--color-primary-dark)}.form-actions .secondary-button{background:#f2f4f7;color:#344054}.split-actions{gap:10px}.table-panel,.form-panel,.info-panel,.compact-form{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px}.table-panel{overflow:hidden;padding:8px}.responsive-table{margin:0;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;width:100%}.responsive-table::-webkit-scrollbar{height:10px}.responsive-table::-webkit-scrollbar-thumb{background:#c7cbe0;border-radius:999px}.responsive-table::-webkit-scrollbar-track{background:#f1f3f8}.responsive-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}.touch-target{min-height:44px;min-width:44px}.search-input{align-items:center;background:#fbfcff;border:1px solid #d7dbea;border-radius:10px;display:inline-flex;flex:1 1 240px;gap:8px;max-width:400px;min-height:40px;padding:0 10px;width:100%}.search-input:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #2e2b6e1f}.search-input-icon{color:var(--color-muted);flex:0 0 auto}.search-input-field{background:transparent;border:0;color:var(--color-text);flex:1 1 auto;font-size:14px;min-height:40px;min-width:0;outline:none;padding:0;width:100%}.search-input-field::-webkit-search-cancel-button{-webkit-appearance:none;-moz-appearance:none;appearance:none}.search-input-clear{align-items:center;background:transparent;border:0;border-radius:999px;color:var(--color-muted);cursor:pointer;display:inline-flex;flex:0 0 auto;height:24px;justify-content:center;min-height:0;padding:0;width:24px}.search-input-clear:hover,.search-input-clear:focus-visible{background:var(--color-primary-soft);color:var(--color-primary)}.clickable-row{cursor:pointer;transition:background-color .12s ease}.clickable-row:hover,.clickable-row:focus-visible{background-color:var(--color-primary-soft)}.clickable-row:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}table{border-collapse:collapse;min-width:980px;width:100%}th,td{border-bottom:1px solid #eef2f6;padding:14px 16px;text-align:left;vertical-align:middle;white-space:nowrap}th{background:#fbfcff;color:#4b5568;font-size:12px;text-transform:uppercase}th:first-child,td:first-child{left:0;position:sticky;z-index:1}th:first-child{background:#fbfcff;z-index:2}td:first-child{background:#fff}.table-link{color:var(--color-primary);font-weight:800}.badge{background:#f2f4f7;border-radius:999px;color:#344054;display:inline-flex;font-size:12px;font-weight:800;padding:5px 9px}.badge.paid{background:#dcfae6;color:#027a48}.badge.partial{background:#fef0c7;color:#b54708}.badge.unpaid,.badge.absent{background:#fee4e2;color:#b42318}.badge.late{background:#fef0c7;color:#b54708}.badge.present{background:#dcfae6;color:#027a48}.badge.excused{background:#e0f2fe;color:#026aa2}.badge.pending{background:#fef0c7;color:#b54708}.badge.approved{background:#dcfae6;color:#027a48}.badge.rejected{background:#fee4e2;color:#b42318}.form-panel{display:grid;gap:26px;padding:24px}.form-panel section{display:grid;gap:16px}.form-grid{display:grid;gap:16px;grid-template-columns:repeat(3,minmax(0,1fr))}.form-field,.compact-form label{color:#283046;display:grid;font-size:14px;font-weight:800;gap:8px}.form-field input,.form-field select,.form-field textarea,.compact-form input,.compact-form select{background:#fbfcff;border:1px solid #d7dbea;border-radius:8px;color:var(--color-text);min-height:44px;min-width:0;padding:0 12px;width:100%}.form-field textarea{min-height:120px;padding:12px;resize:vertical}.span-2{grid-column:span 2}.span-3{grid-column:span 3}.checkbox-row{align-items:center;display:flex;font-weight:800;gap:10px}.checkbox-row input{height:18px;width:18px}.form-actions{display:flex;justify-content:flex-end}.export-actions{flex-wrap:wrap;gap:10px;justify-content:flex-start}.detail-grid{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.lead-referral-cell{align-items:flex-start;display:grid;gap:6px}.lead-referral-cell .muted{font-size:12px;white-space:normal}.lead-referral-panel .section-heading p{margin:6px 0 0}.info-panel{display:grid;gap:14px;padding:20px}.info-panel.wide{grid-column:1 / -1}.info-row{align-items:center;border-bottom:1px solid #eef2f6;display:flex;gap:16px;justify-content:space-between;padding-bottom:10px}.info-row span{color:#667085}.split-title{justify-content:space-between}.archive-actions{display:flex;gap:10px}.archive-filter{align-items:center;color:#344054;display:inline-flex;font-size:14px;font-weight:800;gap:8px}.archive-filter select{background:#fff;border:1px solid #d0d5dd;border-radius:8px;color:#18202a;min-height:40px;padding:0 10px}.student-history-panel{gap:20px}.history-summary-grid{display:grid;gap:12px;grid-template-columns:repeat(5,minmax(0,1fr))}.history-metric{background:#fbfcff;border:1px solid #edf2f7;border-radius:8px;display:grid;gap:8px;min-height:92px;padding:14px}.history-metric.wide{grid-column:span 2}.history-metric span{color:var(--color-muted);font-size:13px;font-weight:800}.history-metric strong{color:var(--color-text);font-size:20px;line-height:1.25;overflow-wrap:anywhere}.student-timeline{display:grid;gap:14px;position:relative}.timeline-item{display:grid;gap:14px;grid-template-columns:18px minmax(0,1fr);position:relative}.timeline-marker{background:var(--color-accent);border:4px solid #fff;border-radius:999px;box-shadow:0 0 0 1px var(--color-border);height:18px;margin-top:18px;width:18px}.timeline-content{background:#fbfcff;border:1px solid #edf2f7;border-left:4px solid var(--color-primary);border-radius:8px;display:grid;gap:10px;padding:14px}.timeline-heading{align-items:start;display:flex;gap:14px;justify-content:space-between}.timeline-heading span{color:var(--color-primary);font-size:12px;font-weight:900;text-transform:uppercase}.timeline-heading h3{font-size:18px;margin:4px 0 0}.timeline-heading time{color:var(--color-muted);font-size:13px;font-weight:800;white-space:nowrap}.timeline-content p{color:#344054;margin:0}.timeline-meta-line{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.compact-form{align-items:end;display:grid;gap:14px;grid-template-columns:1.4fr repeat(4,1fr) auto;margin-bottom:18px;padding:18px}.inline-panel-form{border:0;box-shadow:none;grid-template-columns:repeat(4,minmax(0,1fr));margin:0;padding:0}.inline-panel-form button{min-height:44px}.checkbox-label{align-items:center;display:flex!important;gap:10px;min-height:44px}.checkbox-label input{min-height:18px;width:18px}.teacher-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.class-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;display:grid;gap:16px;min-height:245px;padding:20px}.class-card-header{align-items:flex-start;display:flex;gap:14px;justify-content:space-between}.warning-icon,.warning-text{color:#b54708}.progress-bar{background:#eef2f6;border-radius:999px;height:10px;overflow:hidden}.progress-bar.large{height:16px}.progress-bar span{background:var(--color-primary);display:block;height:100%}.class-metrics,.card-actions{align-items:center;display:flex;gap:12px;justify-content:space-between}.card-actions{flex-wrap:wrap}.class-metrics{color:#667085}.secondary-link{align-items:center;background:#f2f4f7;border:0;border-radius:8px;color:#344054;display:inline-flex;font-weight:800;gap:8px;min-height:42px;padding:0 14px}.fit-link{justify-content:center;width:fit-content}.attendance-list{display:grid;gap:10px}.attendance-row{align-items:center;background:#f8fafc;border:1px solid #edf2f7;border-radius:8px;display:grid;gap:12px;grid-template-columns:minmax(180px,1fr) 150px minmax(220px,1.5fr);padding:12px}.attendance-row select,.attendance-row input{background:#fff;border:1px solid #d0d5dd;border-radius:8px;min-height:42px;padding:0 12px}.teacher-attendance-grid{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr))}.teacher-attendance-card{background:#fbfcff;border:1px solid #edf2f7;border-radius:8px;display:grid;gap:14px;padding:16px}.teacher-attendance-card-header{align-items:start;display:flex;gap:12px;justify-content:space-between}.teacher-attendance-card-header div{display:grid;gap:4px}.teacher-attendance-card-header span,.performance-field small{color:#667085;font-size:13px}.checkbox-row{align-items:center;display:inline-flex;flex:0 0 auto;font-weight:800;gap:8px}.attendance-toggle{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.attendance-toggle button,.star-rating button{background:#fff;border:1px solid #d0d5dd;border-radius:8px;color:#344054;font-weight:900;min-height:42px}.attendance-toggle button.active{background:#ecfdf3;border-color:#12b76a;color:#027a48}.attendance-toggle button.active.danger{background:#fef3f2;border-color:#f04438;color:#b42318}.teacher-attendance-notes{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.performance-field{display:grid;gap:8px}.performance-field>span{color:#344054;font-weight:800}.star-rating{display:flex;flex-wrap:wrap;gap:6px}.star-rating button{color:#98a2b3;min-width:42px}.star-rating button.active{background:#fffaeb;border-color:#fdb022;color:#b54708}.star-rating button:disabled{cursor:not-allowed;opacity:.45}.reports-table{margin-top:18px}.compact-notice{margin:0;padding:11px 12px}.filters-row{align-items:end;display:flex;flex-wrap:wrap;gap:14px;margin-bottom:16px;max-width:100%;width:100%}.table-input{background:#fff;border:1px solid #d0d5dd;border-radius:8px;min-height:38px;min-width:180px;padding:0 10px}.score-input{min-width:90px}.score-field{align-items:center;display:inline-flex;gap:8px;white-space:nowrap}.score-field span{color:#667085;font-weight:800}.attachment-panel{display:grid;gap:14px}.attachment-current{background:#f8fafc;border:1px solid #edf2f7;border-radius:8px;display:grid;gap:4px;padding:12px}.attachment-current span,.attachment-current small{color:#667085}.attachment-current strong{color:#101828;overflow-wrap:anywhere}.row-actions{display:flex;flex-wrap:wrap;gap:8px}.section-heading{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.overview-actions{justify-content:flex-start}.class-overview-grid{margin-bottom:18px}.overview-alerts,.overview-list{display:grid;gap:10px}.overview-alert,.overview-list-item,.empty-state{background:#f8fafc;border:1px solid #edf2f7;border-radius:8px;padding:12px}.overview-alert{align-items:flex-start;display:flex;gap:10px}.overview-alert p{margin:2px 0 0}.overview-alert.critical{background:#fff5f4;border-color:#ffd8d4}.overview-alert.warning{background:#fffbeb;border-color:#fde68a}.overview-list-item{display:grid;gap:4px}.overview-list-item span,.empty-state{color:#667085}.overview-table table{min-width:760px}.teacher-homework-actions{margin-top:18px}.calendar-class-link{min-height:38px}.homework-layout{display:grid;gap:18px;grid-template-columns:minmax(260px,.8fr) minmax(0,1.2fr)}.homework-form,.homework-list{display:grid;gap:14px}.homework-card{background:#f8fafc;border:1px solid #edf2f7;border-radius:8px;display:grid;gap:12px;padding:14px}.homework-card h4,.homework-card p{margin:0}.homework-card p{color:#667085;overflow-wrap:anywhere}.homework-meta{color:#667085;display:flex;flex-wrap:wrap;font-size:13px;gap:8px 14px}.homework-download{align-items:center;display:inline-flex;gap:6px;justify-content:center;width:fit-content}.portal-homework-grid{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr))}.portal-homework-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;display:grid;gap:14px;padding:18px}.portal-homework-card h2,.portal-homework-card p{margin:0}.portal-homework-card p{color:#667085;overflow-wrap:anywhere}.referral-layout{align-items:stretch;display:grid;gap:18px;grid-template-columns:minmax(0,1fr) 300px}.referral-panel,.referral-qr-panel{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;padding:22px}.referral-panel{display:grid;gap:22px}.referral-heading{align-items:flex-start;display:flex;gap:14px}.referral-heading h2,.referral-heading p{margin:0}.referral-heading p{color:#667085;margin-top:6px;max-width:720px}.referral-fields{display:grid;gap:12px}.referral-copy-row{align-items:center;background:#f8fafc;border:1px solid #edf2f7;border-radius:8px;display:grid;gap:14px;grid-template-columns:minmax(0,1fr) auto;padding:14px}.referral-copy-row span,.referral-qr-panel span{color:#667085;display:block;font-size:13px;font-weight:800;margin-bottom:6px}.referral-copy-row strong{display:block;font-size:18px;overflow-wrap:anywhere}.referral-refresh{align-items:center;display:inline-flex;gap:8px;justify-content:center;width:fit-content}.referral-qr-panel{align-content:center;display:grid;justify-items:center;text-align:center}.referral-qr-panel svg{background:#fff;border:1px solid #edf2f7;border-radius:8px;height:auto;max-width:100%;padding:10px}.public-apply-page{align-items:center;background:radial-gradient(circle at 12% 12%,rgba(251,195,136,.2),transparent 28rem),linear-gradient(180deg,#f7f8fc,#eef1f8);display:flex;justify-content:center;min-height:100vh;padding:24px}.public-apply-panel{background:#fffffffa;border:1px solid var(--color-border);border-radius:8px;box-shadow:0 24px 70px #12172a1f;display:grid;gap:22px;max-width:820px;padding:28px;width:100%}.public-apply-brand{align-items:center;display:flex;gap:12px}.public-apply-brand img{display:block;max-width:56px}.public-apply-brand strong,.public-apply-brand span{display:block}.public-apply-brand span{color:var(--color-primary);font-size:13px;font-weight:800}.public-apply-heading{align-items:flex-start;display:flex;gap:14px}.public-apply-heading h1{font-size:clamp(30px,5vw,42px);margin-bottom:10px}.public-apply-heading p:not(.eyebrow){color:#667085;margin-bottom:0}.public-apply-form{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.public-apply-submit{justify-content:center;width:fit-content}.public-apply-submit:disabled{cursor:not-allowed;opacity:.7}.public-apply-success{align-items:center;color:#027a48;display:flex;gap:8px}.small-button{border:0;border-radius:8px;color:#fff;font-weight:800;min-height:34px;padding:0 10px}.small-button.approve{background:var(--color-primary)}.small-button.reject{background:#b42318}.small-button.neutral{background:#344054}.badge.active{background:#dcfae6;color:#027a48}.badge.paused{background:#fef0c7;color:#b54708}.badge.completed{background:#e0f2fe;color:#026aa2}.badge.cancelled{background:#fee4e2;color:#b42318}.catalog-form{margin-bottom:18px}.users-filter-form{align-items:end;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;display:grid;gap:14px;grid-template-columns:minmax(220px,1fr) 180px 160px auto;margin-bottom:18px;padding:18px}.users-filter-form label{color:#344054;display:grid;font-size:14px;font-weight:800;gap:8px}.users-filter-form input,.users-filter-form select,.inline-password input{background:#f8fafc;border:1px solid #d0d5dd;border-radius:8px;color:#18202a;min-height:40px;min-width:0;padding:0 12px}.users-filter-form button{align-items:center;background:var(--color-primary);border:0;border-radius:8px;color:#fff;display:inline-flex;font-weight:800;min-height:40px;padding:0 16px}.users-table{min-width:960px}.user-profile-links{display:grid;gap:4px}.inline-password{align-items:center;display:flex;gap:8px}.inline-password input{width:190px}.multi-select{min-height:112px;padding:8px 12px}.compact-select{min-height:34px;min-width:132px}.report-filter-form{align-items:end;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;display:grid;gap:14px;grid-template-columns:repeat(2,minmax(180px,240px)) repeat(3,auto);margin-bottom:18px;padding:18px}.report-filter-form label{color:#344054;display:grid;font-size:14px;font-weight:800;gap:8px}.report-filter-form input{background:#f8fafc;border:1px solid #d0d5dd;border-radius:8px;color:#18202a;min-height:44px;min-width:0;padding:0 12px}.report-filter-form button{align-items:center;background:var(--color-primary);border:0;border-radius:8px;color:#fff;display:inline-flex;font-weight:800;gap:8px;min-height:44px;padding:0 16px}.report-filter-form button[type=button]{background:#344054}.report-filter-form button:disabled{opacity:.7}.notification-filter-form{align-items:end;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;display:grid;gap:14px;grid-template-columns:repeat(2,minmax(180px,240px)) auto;margin-bottom:18px;padding:18px}.notification-filter-form label{color:#344054;display:grid;font-size:14px;font-weight:800;gap:8px}.notification-filter-form select{background:#f8fafc;border:1px solid #d0d5dd;border-radius:8px;color:#18202a;min-height:44px;min-width:0;padding:0 12px;width:100%}.notification-filter-form button{font-size:14px;min-height:44px;padding:0 16px}.notification-card{box-shadow:0 12px 28px #12172a0a;display:grid;gap:12px;padding:18px}.notification-card-main,.notification-card-footer{align-items:center;display:flex;gap:14px;justify-content:space-between}.notification-card h2{font-size:19px;margin:10px 0 0}.notification-card-footer{border-top:1px solid #edf2f7;padding-top:12px}.notifications-pagination{margin-top:18px}.audit-filter-form{align-items:end;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;display:grid;gap:14px;grid-template-columns:minmax(240px,1.4fr) 170px repeat(2,minmax(150px,1fr)) repeat(2,minmax(150px,.8fr)) auto;margin-bottom:18px;padding:18px}.audit-filter-form label{color:#344054;display:grid;font-size:14px;font-weight:800;gap:8px}.audit-filter-form input,.audit-filter-form select{background:#f8fafc;border:1px solid #d0d5dd;border-radius:8px;color:#18202a;min-height:44px;min-width:0;padding:0 12px;width:100%}.audit-filter-form button,.pagination-actions button{align-items:center;background:var(--color-primary);border:0;border-radius:8px;color:#fff;display:inline-flex;font-weight:800;gap:8px;min-height:44px;padding:0 16px}.audit-filter-form button:hover,.pagination-actions button:hover{background:var(--color-primary-dark)}.pagination-actions button:disabled{cursor:not-allowed;opacity:.55}.table-toolbar,.pagination-actions{align-items:center;display:flex;gap:12px}.table-toolbar{justify-content:space-between;padding:10px 8px 16px}.pagination-actions span{color:#344054;font-size:14px;font-weight:800}.audit-logs-table{min-width:1280px}.metadata-details summary{color:var(--color-primary);cursor:pointer;font-weight:800}.metadata-details pre{background:#f8fafc;border:1px solid #e4e7ec;border-radius:8px;color:#18202a;margin:10px 0 0;max-height:220px;max-width:420px;overflow:auto;padding:12px;white-space:pre-wrap;word-break:break-word}.report-page,.report-section,.alerts-list{display:grid;gap:16px}.report-page{gap:22px}.report-period,.section-title{align-items:center;display:flex;gap:10px}.report-period{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;color:#344054;padding:16px 18px}.section-title{color:var(--color-text)}.section-title h2{font-size:20px}.report-grid{margin-bottom:0}.compact-report-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.report-stat{min-height:118px}.report-stat strong{font-size:26px;line-height:1.2;overflow-wrap:anywhere}.table-progress{background:#eef2f6;border-radius:999px;display:inline-flex;height:8px;margin-right:8px;overflow:hidden;vertical-align:middle;width:120px}.table-progress span{background:var(--color-primary);display:block;height:100%}.alert-row{align-items:center;background:var(--color-card);border:1px solid var(--color-border);border-left:5px solid #667085;border-radius:8px;display:grid;gap:12px;grid-template-columns:92px minmax(0,1fr);padding:14px 16px}.alert-row span{border-radius:999px;font-size:12px;font-weight:800;padding:5px 8px;text-align:center;text-transform:uppercase}.alert-row p{margin:0}@media(max-width:480px){.alert-row{grid-template-columns:minmax(0,1fr);padding:12px}.alert-row span{justify-self:start}}.audit-logs-table .audit-log-time{max-width:14ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.alert-row.info{border-left-color:#026aa2}.alert-row.info span{background:#e0f2fe;color:#026aa2}.alert-row.warning{border-left-color:#b54708}.alert-row.warning span{background:#fef0c7;color:#b54708}.alert-row.danger{border-left-color:#b42318}.alert-row.danger span{background:#fee4e2;color:#b42318}@media(max-width:900px){.app-shell{display:block;grid-template-columns:none;max-width:100%;overflow-x:clip;width:100%}.sidebar{bottom:0;box-shadow:20px 0 60px #12172a38;left:0;max-width:min(86vw,340px);overflow-y:auto;padding:18px;position:fixed;top:0;transform:translate(-105%);transition:transform .18s ease;width:340px;z-index:50}.sidebar-open .sidebar{transform:translate(0)}.mobile-sidebar-overlay{background:#12172a73;border:0;bottom:0;display:block;left:0;opacity:0;pointer-events:none;position:fixed;right:0;top:0;transition:opacity .18s ease;z-index:40}.sidebar-open .mobile-sidebar-overlay{opacity:1;pointer-events:auto}.sidebar-close-button{display:inline-flex;margin-left:auto}.mobile-topbar-brand{align-items:center;color:var(--color-primary);display:flex;font-weight:900;gap:10px;margin-bottom:14px;min-width:0}.mobile-brand-logo{border-radius:6px;height:34px;object-fit:contain;width:34px}.mobile-menu-button{flex:0 0 auto}.brand{align-items:center;margin-bottom:18px}.nav-list{grid-template-columns:1fr;overflow-x:visible;padding-bottom:18px}.nav-item{font-size:14px;justify-content:flex-start;min-height:46px}.nav-item svg{flex:0 0 auto}.stats-grid,.analytics-grid,.analytics-chart-grid,.analytics-filter-form,.task-list,.form-grid,.detail-grid,.compact-form,.history-summary-grid,.users-filter-form,.report-filter-form,.notification-filter-form,.audit-filter-form,.compact-report-grid,.teacher-card-grid,.teacher-attendance-grid,.teacher-attendance-notes,.attendance-row{grid-template-columns:repeat(2,minmax(0,1fr))}.main-panel{padding:22px;max-width:none;min-height:100vh;width:100%}.topbar{align-items:stretch;background:#f7f8fcf5;border-bottom:1px solid var(--color-border);display:grid;gap:16px;margin:-22px -22px 22px;padding:16px 22px;position:sticky;top:0;z-index:30}.topbar h1{font-size:28px;line-height:1.14}.topbar p{margin-bottom:0}.topbar-actions{align-items:center;display:flex;flex-wrap:wrap;justify-content:space-between}.user-menu{min-width:0}.user-menu span{overflow:hidden;text-overflow:ellipsis}.notifications-dropdown{max-height:70vh;width:min(380px,calc(100vw - 16px))}.notifications-dropdown-header,.notification-preview,.notification-preview>div{min-width:0}.notification-preview strong,.notification-preview p,.notification-preview time{overflow-wrap:anywhere;word-break:break-word}.table-panel{margin-inline:-4px;padding:6px}.responsive-table{border-radius:8px}table{min-width:760px}.users-table,.audit-logs-table{min-width:1040px}.report-filter-form{grid-template-columns:repeat(2,minmax(0,1fr))}.span-2,.span-3{grid-column:span 2}}@media(max-width:760px){.page-actions,.filters-row,.planning-filters,.form-actions,.export-actions,.archive-actions,.card-actions,.class-metrics,.row-actions,.split-actions{align-items:stretch;display:grid;grid-template-columns:minmax(0,1fr);justify-content:stretch;width:100%}.filters-row>*,.page-actions>*,.planning-filters>*{min-width:0;width:100%}.primary-link,.secondary-link,.small-button,.form-actions button,.compact-form button,.report-filter-form button,.users-filter-form button,.audit-filter-form button,.notification-filter-form button{justify-content:center;min-height:44px;width:100%}.archive-filter,.filters-row .form-field{width:100%}.archive-filter{align-items:stretch;display:grid}.archive-filter select{width:100%}.topbar-actions{align-items:stretch;display:grid;grid-template-columns:minmax(0,auto) minmax(0,1fr);width:100%}.user-menu{justify-content:space-between;width:100%}.users-filter-form,.audit-filter-form,.report-filter-form,.notification-filter-form,.stats-grid,.form-grid,.detail-grid,.compact-form,.history-summary-grid,.teacher-card-grid,.teacher-attendance-grid,.teacher-attendance-notes,.homework-layout,.attendance-row,.portal-homework-grid,.referral-layout{grid-template-columns:minmax(0,1fr)}.parent-portal-table th,.parent-portal-table td{padding:12px 10px}}@media(max-width:620px){.login-panel,.main-panel{padding:16px}.login-brand{align-items:flex-start}.login-logo{max-width:78px}.topbar{margin:-16px -16px 18px;padding:14px 16px}.stats-grid,.analytics-grid,.analytics-chart-grid,.analytics-filter-form,.task-list,.form-grid,.detail-grid,.compact-form,.history-summary-grid,.users-filter-form,.report-filter-form,.audit-filter-form,.notification-filter-form,.compact-report-grid,.teacher-card-grid,.teacher-attendance-grid,.teacher-attendance-notes,.homework-layout,.portal-homework-grid,.referral-layout,.public-apply-form,.attendance-row{grid-template-columns:1fr}.referral-copy-row{align-items:stretch;grid-template-columns:1fr}.referral-refresh{width:100%}.public-apply-panel{padding:20px}.public-apply-heading{display:grid}.public-apply-submit{width:100%}.topbar-actions{gap:10px}.analytics-toolbar,.analytics-list-row{align-items:stretch;flex-direction:column}.analytics-list-meta{align-items:start;justify-items:start;text-align:left}.icon-button{height:42px;width:42px}.user-menu{gap:10px;min-height:46px;padding:8px 10px}.table-panel{margin-inline:-8px}.responsive-table{padding-bottom:8px}table{min-width:680px}th,td{padding:12px 10px}th:first-child,td:first-child{left:auto;position:static}.table-input,.inline-password input,.compact-select{min-width:0;width:100%}.form-panel,.compact-form,.users-filter-form,.report-filter-form,.notification-filter-form,.audit-filter-form{padding:14px}.info-row,.split-title,.class-card-header,.timeline-heading,.notification-card-main,.notification-card-footer{align-items:stretch;display:grid}.history-metric.wide{grid-column:span 1}.table-toolbar,.pagination-actions{align-items:stretch;display:grid}.alert-row{align-items:start;grid-template-columns:1fr}.timeline-heading time{white-space:normal}.span-2,.span-3{grid-column:span 1}.notifications-menu{justify-self:stretch}.notifications-dropdown{width:min(380px,calc(100vw - 16px))}.notifications-dropdown-header,.notification-preview{align-items:stretch;display:grid;grid-template-columns:1fr}}html[dir=rtl] body{direction:rtl}html[dir=rtl] input,html[dir=rtl] textarea,html[dir=rtl] select{text-align:right}html[dir=rtl] .form-field>*{text-align:start}html[dir=rtl] .form-field input,html[dir=rtl] .form-field textarea,html[dir=rtl] .form-field select{text-align:start}.notifications-popover{inset-inline-end:0}.sidebar,.dashboard-topbar,.dashboard-shell{padding-inline-start:var(--space-md, 16px);padding-inline-end:var(--space-md, 16px)}html[dir=rtl] .badge{margin-inline-end:0;margin-inline-start:4px}html[dir=rtl] .row-actions{justify-content:flex-start}html[dir=rtl] .public-apply-form .form-field{text-align:start}@media(max-width:900px){html[dir=rtl] .sidebar{left:auto;right:0;box-shadow:-20px 0 60px #12172a38;transform:translate(105%)}html[dir=rtl] .sidebar-open .sidebar{transform:translate(0)}html[dir=rtl] .sidebar-close-button{margin-inline-start:auto}}@media(max-width:900px){body:not(:has(.mercia-landing)){overflow-x:clip}.app-shell{overflow-x:clip}}@media(max-width:480px){.main-panel{padding:12px}.topbar{margin:-12px -12px 14px;padding:12px}.topbar h1{font-size:22px}.topbar p{font-size:13px}.page-actions,.filters-row,.planning-filters,.topbar-actions{grid-template-columns:1fr}.page-actions>*,.filters-row>*,.planning-filters>*,.topbar-actions>*{width:100%;min-width:0}[role=dialog]{max-width:calc(100vw - 16px)!important}.class-overview-grid,.detail-grid{gap:12px}.referral-qr-panel svg{height:auto!important;max-width:100%}.user-menu span:not(.muted),.language-switcher-label{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notifications-dropdown{inset:60px 8px auto 8px;max-height:calc(100vh - 76px);max-width:none;position:fixed;width:auto}}@media(max-width:360px){.main-panel{padding:10px}.topbar h1{font-size:20px}th,td{padding:10px 8px}}@media(max-width:760px){button,.small-button,.secondary-button{min-height:40px}}.homework-meta,.attachment-current,.notification-card-footer .muted{flex-wrap:wrap;word-break:break-word}.anal-shell{display:grid;gap:20px;animation:anal-fade-in .32s ease-out both}.anal-header{align-items:center;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between}.anal-header-meta{align-items:center;color:var(--color-muted);display:inline-flex;font-size:13px;gap:8px}.anal-header-meta .dot{background:var(--chart-positive);border-radius:999px;box-shadow:0 0 0 4px var(--chart-positive-soft);display:inline-block;height:8px;width:8px}.anal-period-selector{align-items:center;background:var(--color-card);border:1px solid var(--color-border);border-radius:999px;box-shadow:var(--shadow-sm);display:inline-flex;flex-wrap:wrap;gap:2px;padding:4px}.anal-period-selector button{background:transparent;border:0;border-radius:999px;color:var(--color-muted);cursor:pointer;font-size:13px;font-weight:700;letter-spacing:.01em;min-height:32px;padding:6px 14px;transition:background .16s ease,color .16s ease,transform .16s ease}.anal-period-selector button:hover{color:var(--color-text)}.anal-period-selector button.is-active{background:var(--color-primary);box-shadow:0 2px 6px #2e2b6e2e;color:#fff}.anal-period-selector button:focus-visible{outline:2px solid var(--chart-neutral);outline-offset:2px}.anal-kpi-grid{display:grid;gap:18px;grid-template-columns:repeat(4,minmax(0,1fr))}.anal-kpi-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:14px;box-shadow:var(--shadow-sm);display:grid;gap:12px;padding:20px 22px;position:relative;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;animation:anal-fade-in-up .48s cubic-bezier(.2,.7,.3,1) both}.anal-kpi-card[data-i="0"]{animation-delay:0ms}.anal-kpi-card[data-i="1"]{animation-delay:90ms}.anal-kpi-card[data-i="2"]{animation-delay:.18s}.anal-kpi-card[data-i="3"]{animation-delay:.27s}.anal-kpi-card:hover{border-color:var(--color-primary-soft);box-shadow:var(--shadow-md);transform:translateY(-2px)}.anal-kpi-card:before{background:var(--kpi-accent, var(--chart-neutral));border-radius:999px;content:"";height:28px;left:0;position:absolute;top:22px;width:3px}.anal-kpi-label{color:var(--color-muted);font-size:11px;font-weight:800;letter-spacing:.12em;margin:0;text-transform:uppercase}.anal-kpi-value{align-items:baseline;display:flex;gap:8px;font-size:clamp(28px,3vw,38px);font-weight:800;letter-spacing:-.02em;line-height:1;margin:0;animation:anal-count-up .64s cubic-bezier(.2,.7,.3,1) both}.anal-kpi-value-suffix{color:var(--color-muted);font-size:14px;font-weight:600;letter-spacing:0}.anal-kpi-delta{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:700;gap:4px;padding:3px 9px}.anal-kpi-delta.up{background:var(--chart-positive-soft);color:var(--chart-positive)}.anal-kpi-delta.down{background:var(--chart-negative-soft);color:var(--chart-negative)}.anal-kpi-delta.flat{background:#f1f3f8;color:var(--color-muted)}.anal-kpi-meta{align-items:center;color:var(--color-muted);display:flex;font-size:12px;gap:6px;margin:0}.anal-kpi-spark{height:36px;margin-top:4px}.anal-panel{background:var(--color-card);border:1px solid var(--color-border);border-radius:14px;box-shadow:var(--shadow-sm);display:grid;gap:10px;padding:22px;animation:anal-fade-in-up .54s cubic-bezier(.2,.7,.3,1) both}.anal-panel:hover{box-shadow:var(--shadow-md)}.anal-panel-head{align-items:flex-start;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}.anal-panel-head h2{font-size:16px;font-weight:800;letter-spacing:-.01em;margin:0}.anal-panel-head p{color:var(--color-muted);font-size:13px;margin:4px 0 0}.anal-grid-2{display:grid;gap:18px;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr)}.anal-grid-2--reverse{grid-template-columns:minmax(0,1fr) minmax(0,1.4fr)}.anal-tooltip{background:var(--color-card);border:1px solid var(--color-border);border-radius:10px;box-shadow:var(--shadow-lg);font-size:13px;min-width:180px;padding:10px 12px}.anal-tooltip-title{border-bottom:1px solid var(--color-border);color:var(--color-text);font-size:12px;font-weight:800;letter-spacing:.04em;margin:0 0 8px;padding-bottom:6px;text-transform:uppercase}.anal-tooltip-row{align-items:center;display:flex;gap:8px;justify-content:space-between;padding:2px 0}.anal-tooltip-row>span{color:var(--color-muted)}.anal-tooltip-row>strong{color:var(--color-text)}.anal-tooltip-dot{border-radius:999px;display:inline-block;height:8px;margin-inline-end:6px;width:8px}.anal-bars{display:grid;gap:12px}.anal-bar-row{display:grid;gap:6px}.anal-bar-row-head{align-items:center;display:flex;font-size:13px;gap:8px;justify-content:space-between}.anal-bar-row-head strong{font-size:14px;font-weight:700}.anal-bar-row-head .muted{color:var(--color-muted);font-size:12px}.anal-bar-track{background:#f1f3f8;border-radius:999px;height:10px;overflow:hidden;position:relative}.anal-bar-fill{border-radius:999px;height:100%;position:relative;transition:width .6s cubic-bezier(.2,.7,.3,1);background:linear-gradient(90deg,var(--bar-from, var(--chart-neutral)),var(--bar-to, var(--chart-neutral)));width:var(--bar-width, 0%)}.anal-funnel{display:grid;gap:14px}.anal-funnel-row{display:grid;gap:6px;animation:anal-fade-in-up .54s cubic-bezier(.2,.7,.3,1) both}.anal-funnel-row[data-i="0"]{animation-delay:0ms}.anal-funnel-row[data-i="1"]{animation-delay:.12s}.anal-funnel-row[data-i="2"]{animation-delay:.24s}.anal-funnel-row[data-i="3"]{animation-delay:.36s}.anal-funnel-bar{align-items:center;border-radius:12px;color:#fff;display:flex;font-weight:700;height:56px;justify-content:space-between;padding:0 18px;position:relative;transition:transform .2s ease,box-shadow .2s ease;width:var(--funnel-width, 100%)}.anal-funnel-bar:hover{box-shadow:var(--shadow-md);transform:translate(2px)}.anal-funnel-bar>span{font-size:14px;letter-spacing:.01em}.anal-funnel-bar>strong{font-size:18px;font-variant-numeric:tabular-nums}.anal-funnel-conv{align-items:center;color:var(--color-muted);display:inline-flex;font-size:12px;font-weight:700;gap:4px;letter-spacing:.04em;padding-inline-start:18px;text-transform:uppercase}.anal-funnel-conv strong{color:var(--chart-positive);font-size:14px}.anal-heatmap{display:grid;gap:6px;overflow-x:auto}.anal-heatmap-row{align-items:center;display:grid;gap:4px;grid-template-columns:36px repeat(24,minmax(14px,1fr))}.anal-heatmap-row-label{color:var(--color-muted);font-size:11px;font-weight:700;text-transform:uppercase}.anal-heatmap-cell{aspect-ratio:1;background:var(--cell-bg, var(--heatmap-0));border-radius:3px;cursor:pointer;position:relative;transition:transform .16s ease,outline .16s ease}.anal-heatmap-cell:hover{outline:2px solid var(--color-text);outline-offset:1px;transform:scale(1.08)}.anal-heatmap-row-hours{color:var(--color-muted);display:grid;font-size:10px;font-weight:700;gap:4px;grid-template-columns:36px repeat(24,minmax(14px,1fr));padding-top:4px}.anal-heatmap-legend{align-items:center;color:var(--color-muted);display:inline-flex;font-size:11px;font-weight:700;gap:4px;letter-spacing:.06em;margin-top:4px;text-transform:uppercase}.anal-heatmap-legend-swatch{border-radius:3px;height:12px;width:12px}.anal-skel{background:linear-gradient(90deg,var(--color-skeleton-base) 0%,var(--color-skeleton-highlight) 50%,var(--color-skeleton-base) 100%);background-size:200% 100%;animation:anal-shimmer 1.5s linear infinite;border-radius:8px;display:block}.anal-empty,.anal-error{align-items:center;background:var(--color-card);border:1px dashed var(--color-border);border-radius:14px;display:grid;gap:14px;justify-items:center;padding:40px 24px;text-align:center}.anal-empty .anal-empty-icon,.anal-error .anal-error-icon{align-items:center;background:var(--color-primary-soft);border-radius:24px;color:var(--color-primary);display:flex;height:64px;justify-content:center;width:64px}.anal-error .anal-error-icon{background:var(--chart-negative-soft);color:var(--chart-negative)}.anal-empty h3,.anal-error h3{font-size:18px;font-weight:800;margin:0}.anal-empty p,.anal-error p{color:var(--color-muted);max-width:420px;margin:0}.anal-donut-center{pointer-events:none;text-anchor:middle}.anal-donut-center-value{fill:var(--color-text);font-size:22px;font-weight:800;letter-spacing:-.01em}.anal-donut-center-label{fill:var(--color-muted);font-size:10px;font-weight:700;letter-spacing:.14em}.anal-donut-legend{display:grid;gap:8px}.anal-donut-legend-row{align-items:center;background:transparent;border:0;cursor:pointer;display:grid;gap:10px;grid-template-columns:14px 1fr auto;padding:4px 0;text-align:start;transition:opacity .16s ease}.anal-donut-legend-row[data-muted=true]{opacity:.4}.anal-donut-legend-swatch{border-radius:4px;height:14px;width:14px}.anal-donut-legend-label{color:var(--color-text);font-size:13px;font-weight:600}.anal-donut-legend-value{color:var(--color-muted);font-size:12px;font-variant-numeric:tabular-nums}.recharts-tooltip-wrapper:focus{outline:none}.recharts-default-tooltip{display:none!important}.recharts-surface{overflow:visible}@media(max-width:1024px){.anal-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.anal-grid-2,.anal-grid-2--reverse{grid-template-columns:minmax(0,1fr)}}@media(max-width:760px){.anal-kpi-grid{grid-template-columns:minmax(0,1fr)}.anal-period-selector{width:100%;justify-content:flex-start;overflow-x:auto}.anal-period-selector button{flex:0 0 auto}.anal-panel{padding:16px}.anal-heatmap-row,.anal-heatmap-row-hours{grid-template-columns:28px repeat(24,minmax(12px,1fr))}}html[dir=rtl] .anal-bar-fill{background:linear-gradient(270deg,var(--bar-from),var(--bar-to))}html[dir=rtl] .anal-funnel-bar:hover{transform:translate(-2px)}.visually-hidden{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}
