.library-page{max-width:1280px}.library-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.library-header-text h1{margin:0;font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.library-header-text p{margin:6px 0 0;color:var(--muted);font-size:.95rem;max-width:36rem}.library-header-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.library-kpi-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:22px}@media (max-width: 1200px){.library-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 1100px){.library-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 480px){.library-kpi-grid{grid-template-columns:minmax(0,1fr)}}.library-kpi{display:flex;flex-direction:column;align-items:stretch;gap:6px;min-width:0;min-height:108px;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 16px 18px;position:relative;overflow:hidden}.library-kpi:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--kpi-accent, var(--primary));opacity:.85;pointer-events:none}.library-kpi-label,.library-kpi-value,.library-kpi-sub{display:block;width:100%;min-width:0}.library-kpi-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);line-height:1.3;flex-shrink:0}.library-kpi-value{font-size:1.65rem;font-weight:700;line-height:1.15;margin:0;flex-shrink:0}.library-kpi-sub{font-size:.78rem;color:var(--muted);line-height:1.4;margin:auto 0 0;overflow-wrap:anywhere;word-break:break-word}.library-kpi--warn{--kpi-accent: var(--warning)}.library-kpi--warn .library-kpi-value{color:var(--warning)}.library-kpi--danger{--kpi-accent: var(--danger)}.library-kpi--danger .library-kpi-value{color:var(--danger)}.library-segments{display:inline-flex;padding:4px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;margin-bottom:20px;gap:4px}.library-segments button{background:transparent;border:none;color:var(--muted);padding:10px 18px;border-radius:9px;font-weight:600;font-size:.9rem;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background .15s,color .15s}.library-segments button:hover{color:var(--text);background:var(--card)}.library-segments button.is-active{background:var(--card);color:var(--text);box-shadow:0 1px 3px #00000040}.library-segment-count{font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:20px;background:var(--border);color:var(--text)}.library-segments button.is-active .library-segment-count{background:var(--primary-dim);color:var(--primary)}.library-segment-count--alert{background:#ef444433;color:#fca5a5}.library-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:18px;padding:14px 16px;background:var(--card);border:1px solid var(--border);border-radius:12px}.library-search-wrap{flex:1;min-width:200px;position:relative}.library-search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--muted);pointer-events:none}.library-search-wrap input{width:100%;min-width:0;padding-left:40px}.library-filter-chips{display:flex;flex-wrap:wrap;gap:8px}.library-chip{background:transparent;border:1px solid var(--border);color:var(--muted);padding:8px 14px;border-radius:20px;font-size:.85rem;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.library-chip:hover{color:var(--text);border-color:var(--muted)}.library-chip.is-active{border-color:var(--primary);background:var(--primary-dim);color:var(--primary)}.library-chip--danger.is-active{border-color:var(--danger);background:#ef444422;color:#fca5a5}.library-catalog-wrap{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden}.library-catalog-table{width:100%;border-collapse:collapse;font-size:.9rem}.library-catalog-table thead{position:sticky;top:0;z-index:2;background:var(--bg-elevated);box-shadow:0 1px 0 var(--border)}.library-catalog-table th{text-align:left;padding:12px 14px;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600;white-space:nowrap}.library-catalog-table th button{background:none;border:none;color:inherit;font:inherit;font-weight:600;cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:4px}.library-catalog-table th button:hover{color:var(--text)}.library-catalog-table th button.is-sorted{color:var(--primary)}.library-catalog-table td{padding:11px 14px;border-top:1px solid var(--border);vertical-align:middle}.library-catalog-table tbody tr{cursor:pointer;transition:background .12s}.library-catalog-table tbody tr:hover{background:var(--bg-elevated)}.library-catalog-table tbody tr.is-selected{background:var(--primary-dim)}.library-catalog-table tbody tr.is-selected td:first-child{box-shadow:inset 3px 0 0 var(--primary)}.library-catalog-title{font-weight:600;color:var(--text);max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-catalog-sub{font-size:.8rem;color:var(--muted);margin-top:2px}.library-catalog-avail{display:inline-flex;align-items:center;gap:8px;min-width:100px}.library-catalog-avail-bar{flex:1;max-width:72px;height:5px;background:var(--bg);border-radius:3px;overflow:hidden}.library-catalog-avail-fill{height:100%;background:var(--primary);border-radius:3px}.library-catalog-avail-fill.is-low{background:var(--warning)}.library-catalog-avail-fill.is-zero{background:var(--danger)}.library-catalog-actions{text-align:right;white-space:nowrap}.library-catalog-scroll{max-height:min(70vh,720px);overflow:auto}.library-catalog-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-top:1px solid var(--border);background:var(--bg-elevated)}.library-page-size{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--muted)}.library-page-size select{min-width:0;padding:6px 10px}.library-tag{font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:6px;background:var(--bg-elevated);color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.library-avail-row{display:flex;justify-content:space-between;align-items:baseline;font-size:.8rem;margin-bottom:6px}.library-avail-row strong{color:var(--primary);font-size:.9rem}.library-avail-row strong.is-zero{color:var(--danger)}.library-avail-bar{height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden}.library-avail-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .3s ease}.library-avail-fill.is-low{background:var(--warning)}.library-avail-fill.is-zero{background:var(--danger)}.library-detail-panel{margin-top:20px;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;animation:library-slide-in .2s ease}@keyframes library-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.library-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}.library-detail-header h3{margin:0;font-size:1.15rem}.library-book-meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px 20px;margin-bottom:16px;padding:14px 16px;background:var(--bg-elevated);border-radius:10px}.library-book-meta-item label{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:2px}.library-book-meta-item span{font-size:.9rem;word-break:break-word}.library-copy-list{display:flex;flex-direction:column;gap:8px}.library-copy-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--bg-elevated);border-radius:10px;border:1px solid transparent}.library-copy-row-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.library-copy-status-select{font-size:.8rem;padding:4px 8px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);max-width:140px}.library-copy-status--withdrawn{background:#94a3b833;color:var(--muted)}.library-copy-status--damaged{background:#f9731633;color:#ea580c}.library-copy-code{font-family:ui-monospace,monospace;font-weight:600;font-size:.9rem}.library-loan-list{display:flex;flex-direction:column;gap:10px}.library-loan-card{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:16px 18px;background:var(--card);border:1px solid var(--border);border-radius:14px;transition:border-color .15s}.library-loan-card.is-overdue{border-color:#ef444466;background:linear-gradient(135deg,var(--card) 0%,#ef444408 100%)}.library-loan-card.is-ready{border-color:var(--primary);background:linear-gradient(135deg,var(--card) 0%,var(--primary-dim) 100%)}.library-reservation-actions{display:flex;flex-direction:column;gap:8px;margin-top:8px;min-width:140px}.library-borrower-chips{margin-bottom:10px}.library-chip--ready.is-active{border-color:var(--primary);background:var(--primary-dim);color:var(--primary)}@media (max-width: 700px){.library-loan-card{grid-template-columns:auto 1fr}.library-loan-actions{grid-column:1 / -1;justify-self:stretch}.library-loan-actions button{width:100%}}.library-loan-avatar{width:44px;height:44px;border-radius:12px;background:var(--primary-dim);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.library-loan-avatar.is-overdue{background:#ef444422;color:#fca5a5}.library-loan-main h4{margin:0 0 4px;font-size:1rem;font-weight:600}.library-loan-book{margin:0 0 8px;font-size:.9rem;color:var(--muted)}.library-loan-book strong{color:var(--text);font-weight:600}.library-loan-dates{display:flex;flex-wrap:wrap;gap:12px 20px;font-size:.8rem;color:var(--muted)}.library-loan-dates span strong{color:var(--text);font-weight:500}.library-empty{text-align:center;padding:56px 28px;background:var(--card);border:1px dashed var(--border);border-radius:16px}.library-empty-icon{width:64px;height:64px;margin:0 auto 20px;border-radius:16px;background:var(--primary-dim);color:var(--primary);display:flex;align-items:center;justify-content:center}.library-empty h3{margin:0 0 8px;font-size:1.15rem}.library-empty p{color:var(--muted);max-width:360px;margin:0 auto 20px}.library-modal{width:min(520px,100%);max-height:90vh;overflow-y:auto}.library-modal--wide{width:min(720px,96vw)}.library-modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 520px){.library-modal .form-row{grid-template-columns:1fr}}.library-modal h2{margin:0 0 4px;font-size:1.25rem}.library-modal-sub{margin:0 0 20px;color:var(--muted);font-size:.9rem}.library-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.library-btn-icon{display:inline-flex;align-items:center;gap:8px}.library-btn-icon svg{width:18px;height:18px}button.library-ghost{background:transparent;border:1px solid var(--border);color:var(--text)}button.library-ghost:hover:not(:disabled){background:var(--bg-elevated)}.library-results-hint{font-size:.85rem;color:var(--muted);margin:0 0 12px}.library-btn-loan{position:relative}.library-btn-loan-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 6px;font-size:.7rem;font-weight:700;border-radius:20px;background:#ffffff40}.library-loan-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 640px){.library-loan-modal-grid{grid-template-columns:1fr}}.library-loan-modal-section{display:flex;flex-direction:column;min-height:0}.library-loan-step{margin:0 0 10px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--primary)}.library-search-wrap--compact input{padding-top:8px;padding-bottom:8px;font-size:.9rem}.library-pick-list{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto;margin:10px 0 8px;padding:4px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px}.library-pick-list--students{max-height:200px}.library-pick-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;text-align:left;padding:10px 12px;border:1px solid transparent;border-radius:8px;background:var(--card);color:var(--text);cursor:pointer;font:inherit;transition:border-color .12s,background .12s}.library-pick-item:hover{border-color:var(--border)}.library-pick-item.is-selected{border-color:var(--primary);background:var(--primary-dim)}.library-pick-item-title{font-weight:600;font-size:.9rem;line-height:1.3}.library-pick-item-meta{font-size:.78rem;color:var(--muted);font-family:ui-monospace,monospace}.library-pick-empty{padding:16px;text-align:center;margin:0}.library-pick-hint{font-size:.75rem;margin:0}.library-due-presets{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.library-due-date-label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--muted)}.library-due-date-label input{width:100%;min-width:0}.library-loan-summary{margin:16px 0 0;padding:12px 14px;background:var(--primary-dim);border:1px solid var(--primary);border-radius:10px;font-size:.9rem;line-height:1.45}.library-loan-modal-empty{padding:8px 0}.library-loan-modal-empty p{color:var(--muted);margin:0 0 16px}.library-copy-code-picker{display:flex;flex-direction:column;gap:8px}.library-copy-code-picker-label{font-size:.85rem;font-weight:600}.library-copy-code-picker-hint{margin:0;font-size:.82rem}.library-copy-code-preview{display:flex;align-items:baseline;gap:2px;padding:12px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;font-family:ui-monospace,monospace}.library-copy-code-prefix{font-size:1.1rem;font-weight:700;color:var(--primary)}.library-copy-code-value{font-size:1.35rem;font-weight:700;letter-spacing:.06em}.library-copy-number-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:8px;max-height:220px;overflow-y:auto;padding:4px}.library-copy-number-btn{min-height:44px;padding:8px 6px;border:1px solid var(--border);border-radius:8px;background:var(--card);color:var(--text);font:inherit;font-family:ui-monospace,monospace;font-size:.9rem;font-weight:600;cursor:pointer;transition:border-color .12s,background .12s,opacity .12s}.library-copy-number-btn:hover:not(:disabled){border-color:var(--primary);background:var(--primary-dim)}.library-copy-number-btn.is-selected{border-color:var(--primary);background:var(--primary-dim);box-shadow:inset 0 0 0 1px var(--primary)}.library-copy-number-btn.is-used,.library-copy-number-btn:disabled{opacity:.38;cursor:not-allowed;text-decoration:line-through}.library-copy-modal-section{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}.library-copy-form .library-pick-list{max-height:200px}.library-copy-selected-book{margin:0 0 4px;font-size:.88rem}.library-checkbox-label{display:flex;align-items:center;gap:10px;margin:4px 0 0;font-size:.92rem;cursor:pointer}.library-checkbox-label input{width:18px;height:18px;margin:0;flex-shrink:0}.library-taxonomy-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 600px){.library-taxonomy-row{grid-template-columns:1fr}}.library-taxonomy-row label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;font-weight:600}.library-taxonomy-row select{font-weight:400}.library-taxonomy-code{margin:0 0 8px;padding:10px 12px;background:var(--primary-dim);border:1px solid var(--primary);border-radius:8px;font-size:.9rem}.library-taxonomy-code strong{font-family:ui-monospace,monospace;letter-spacing:.04em}.library-category-code{display:inline-block;margin-right:6px;padding:1px 6px;border-radius:4px;background:var(--bg-elevated);border:1px solid var(--border);font-family:ui-monospace,monospace;font-size:.75rem;font-weight:700;color:var(--primary)}.library-report-period{display:flex;align-items:center;gap:10px;font-size:.9rem;font-weight:600}.library-report-period select{min-width:180px}.library-report{display:flex;flex-direction:column;gap:20px}.library-report-alerts{display:flex;flex-wrap:wrap;gap:10px}.library-report-alert{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:10px;font-size:.85rem;background:var(--bg-elevated);border:1px solid var(--border)}.library-report-alert--lost,.library-report-alert--damaged{border-color:#f9731644;background:#f9731615;color:#ea580c}.library-report-alert--no_copies{border-color:#f59e0b44;background:#f59e0b15}.library-report-kpi-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}@media (max-width: 1100px){.library-report-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 480px){.library-report-kpi-grid{grid-template-columns:minmax(0,1fr)}}.library-report-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}@media (max-width: 900px){.library-report-grid{grid-template-columns:minmax(0,1fr)}}.library-report-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px 20px}.library-report-card--wide{grid-column:1 / -1}.library-report-card--danger{border-color:#ef444444}.library-report-card h3{margin:0;font-size:1.05rem}.library-report-card-sub{margin:4px 0 16px;font-size:.85rem}.library-report-chart{display:flex;align-items:flex-end;gap:10px;min-height:160px;padding-top:8px}.library-report-chart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;min-width:0}.library-report-chart-bars{display:flex;align-items:flex-end;gap:4px;height:120px;width:100%;justify-content:center}.library-report-bar{width:12px;min-height:4px;border-radius:4px 4px 0 0;transition:height .2s}.library-report-bar--loans{background:var(--primary);opacity:.85}.library-report-bar--returns{background:#22c55e;opacity:.75}.library-report-chart-label{font-size:.72rem;color:var(--muted);text-align:center;line-height:1.2}.library-report-legend{display:flex;gap:16px;margin-top:14px;font-size:.8rem;color:var(--muted)}.library-report-swatch{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:6px;vertical-align:middle}.library-report-swatch--loans{background:var(--primary)}.library-report-swatch--returns{background:#22c55e}.library-report-bars{display:flex;flex-direction:column;gap:10px}.library-report-bar-row{display:grid;grid-template-columns:100px 1fr 36px;gap:10px;align-items:center;font-size:.85rem}.library-report-bar-label{color:var(--muted)}.library-report-bar-track{height:8px;background:var(--bg-elevated);border-radius:4px;overflow:hidden}.library-report-bar-fill{height:100%;border-radius:4px;min-width:2px}.library-report-bar-fill--available{background:#22c55e}.library-report-bar-fill--on_loan{background:var(--warning)}.library-report-bar-fill--damaged{background:#f97316}.library-report-bar-fill--withdrawn{background:#94a3b8}.library-report-bar-fill--lost{background:var(--danger)}.library-report-bar-value{font-weight:700;text-align:right}.library-report-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.library-report-list li{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-elevated);border-radius:10px;font-size:.9rem}.library-report-table-wrap{overflow-x:auto}.library-report-table{width:100%;border-collapse:collapse;font-size:.88rem}.library-report-table th,.library-report-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}.library-report-table th{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600}.library-report-table tbody tr:last-child td{border-bottom:none}:root{--bg: #F3F4F6;--bg-elevated: #FFFFFF;--card: #FFFFFF;--border: #E5E7EB;--text: #111827;--muted: #6B7280;--primary: #22C55E;--primary-dark: #16A34A;--primary-dim: #DCFCE7;--primary-light: #4ADE80;--danger: #EF4444;--warning: #F59E0B;--accent-teal: #14B8A6;--accent-blue: #3B82F6;--accent-purple: #8B5CF6;--accent-orange: #F97316;--sidebar-bg: #1E293B;--sidebar-text: #F8FAFC;--sidebar-muted: #94A3B8;--sidebar-border: rgba(255, 255, 255, .1);--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow-md: 0 4px 14px rgba(15, 23, 42, .08);--hover-surface: rgba(15, 23, 42, .04);--hover-border: #CBD5E1;--interactive-transition: background .15s ease, border-color .15s ease, color .15s ease, box-shadow .15s ease, filter .15s ease;--track: #E5E7EB;--chart-1: #22C55E;--chart-2: #3B82F6;--chart-3: #F59E0B;--chart-4: #8B5CF6;--sidebar-w: 260px;--topbar-h: 64px}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}a{color:var(--primary);text-decoration:none;transition:var(--interactive-transition)}a:hover{color:var(--primary-dark)}.offline-banner{display:flex;flex-direction:column;gap:4px;padding:12px 16px;border-radius:10px;margin-bottom:16px;font-size:.88rem;border:1px solid var(--border)}.offline-banner strong{font-size:.92rem}.offline-banner-offline{background:#f59e0b22;border-color:#f59e0b55}.offline-banner-cache{background:#3b82f618;border-color:#3b82f655}.offline-banner span{color:var(--muted)}.app-shell{display:flex;min-height:100vh}.menu-toggle{display:none;position:fixed;top:12px;left:12px;z-index:100;background:var(--card);border:1px solid var(--border);color:var(--text);width:44px;height:44px;border-radius:8px;font-size:1.25rem;cursor:pointer;box-shadow:var(--shadow-md)}.sidebar-backdrop{display:none}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);padding:20px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:50;color:var(--sidebar-text)}.sidebar-brand{display:flex;gap:12px;align-items:center;margin-bottom:20px}.brand-mark{width:40px;height:40px;border-radius:10px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.25rem}.sidebar h1{color:var(--sidebar-text);font-size:1.15rem;margin:0}.brand-tag{margin:0;font-size:.7rem;color:var(--sidebar-muted)}.school-chip{background:#ffffff14;border:1px solid var(--sidebar-border);border-radius:10px;padding:10px 12px;margin-bottom:16px;font-size:.85rem}.school-chip strong{display:block;color:var(--sidebar-text)}.school-chip span{color:var(--primary-light);font-size:.75rem;font-weight:600}.sidebar-nav{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;margin-right:-4px;padding-right:4px}.nav-section{margin-bottom:4px}.nav-section-title{margin:12px 0 6px;padding:0 14px;font-size:.68rem;font-weight:700;letter-spacing:.08em;color:var(--sidebar-muted);text-transform:uppercase}.nav-section:first-child .nav-section-title{display:none}.sidebar-nav .nav-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;border-radius:10px;color:var(--sidebar-text);font-weight:500;font-size:.92rem;text-decoration:none}.nav-item-left{display:flex;align-items:center;gap:12px;min-width:0}.nav-icon{width:20px;height:20px;flex-shrink:0;opacity:.9}.sidebar-nav .nav-item.active{background:var(--primary);color:#fff}.sidebar-nav .nav-item.active .nav-icon{opacity:1;color:#fff}.sidebar-nav .nav-item:hover:not(.active){background:#ffffff14;color:var(--sidebar-text)}.nav-group{border-radius:10px;margin-bottom:4px}.nav-group-head{display:flex;align-items:center;padding:10px 14px;font-weight:600;font-size:.92rem;color:var(--sidebar-text);border-radius:10px}.nav-group-active .nav-group-head{background:#8b5cf640;color:#c4b5fd}.nav-group-active .nav-group-head .nav-icon{color:#c4b5fd;opacity:1}.nav-group-items{display:flex;flex-direction:column;gap:2px;padding:4px 0 6px 36px}.nav-sub-item{display:block;padding:8px 12px;border-radius:8px;font-size:.88rem;font-weight:500;color:var(--sidebar-muted);text-decoration:none}.nav-sub-item:hover{background:#ffffff14;color:var(--sidebar-text)}.nav-sub-item.active{background:#8b5cf64d;color:#fff;font-weight:600}.teachers-module-page .teachers-module-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px}.teachers-module-breadcrumb{font-size:.85rem;margin:0 0 4px}.teachers-module-title{margin:0;font-size:1.5rem}.teachers-module-sub{margin:4px 0 0;font-size:.9rem}.teachers-eval-toolbar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:16px;margin-bottom:16px}.teachers-eval-year-field{min-width:220px}.teachers-eval-period-field{min-width:120px}.teachers-eval-period-value{display:flex;align-items:center;min-height:40px;padding:8px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg-elevated);font-size:.95rem;font-weight:700;color:var(--primary);letter-spacing:.02em}.teachers-eval-toolbar .field-input,.teachers-eval-toolbar select.field-input{min-height:40px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-elevated);color:var(--text);font-size:.9rem;min-width:220px}.teachers-eval-table-wrap{overflow-x:auto}.teachers-eval-table{min-width:960px}.teachers-eval-table .teachers-eval-col-name{min-width:200px}.teachers-eval-table .teachers-eval-col-subject{min-width:120px;max-width:180px}.teachers-eval-table .teachers-eval-col-num,.teachers-eval-table .teachers-eval-col-action{white-space:nowrap;width:1%}.teachers-eval-name-cell{display:flex;align-items:center;gap:10px;min-width:0}.teachers-eval-name-link{color:var(--primary);font-weight:600;font-size:.9rem;text-decoration:none;white-space:nowrap;line-height:1.3}.teachers-eval-name-link:hover{text-decoration:underline}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--sidebar-border)}.sidebar-link{display:block;font-size:.85rem;margin-bottom:12px;color:var(--sidebar-muted)}.sidebar-link:hover{color:var(--sidebar-text)}.sidebar-footer button.secondary{background:transparent;border:1px solid rgba(255,255,255,.25);color:var(--sidebar-text)}.sidebar-footer button.secondary:hover:not(:disabled){background:#ffffff14}.content-column{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:var(--topbar-h);padding:0 28px;border-bottom:1px solid var(--border);background:var(--card);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:40}.topbar-breadcrumb{margin:0;font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.topbar-title{margin:0;font-size:1.1rem;font-weight:600}.topbar-meta{display:flex;align-items:center;gap:16px;font-size:.85rem;color:var(--muted)}.topbar-user{background:var(--bg);border:1px solid var(--border);padding:6px 12px;border-radius:20px;color:var(--text)}.main{flex:1;padding:24px 28px 48px;max-width:1400px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;flex-wrap:wrap}.page-header h2{margin:0 0 4px;font-size:1.5rem}.page-subtitle{margin:0;color:var(--muted);font-size:.95rem}.page-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow-sm)}.card label{color:var(--muted);font-size:.85rem}.card strong{display:block;font-size:1.75rem;color:var(--primary);margin-top:4px}.panel{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:24px;box-shadow:var(--shadow-sm)}.chart{display:flex;align-items:flex-end;gap:12px;height:160px;margin-bottom:24px}.bar-col{flex:1;text-align:center;min-width:0}.bar-track{height:120px;background:var(--track);border-radius:4px;display:flex;align-items:flex-end;overflow:hidden}.bar-fill{width:100%;background:var(--primary);border-radius:4px;transition:height .3s}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:12px;background:var(--card)}table{width:100%;border-collapse:collapse;min-width:480px}th,td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--border)}th{background:var(--bg-elevated);color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;font-weight:600}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--hover-surface)}.badge{padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge.paid{background:#22c55e33;color:var(--primary)}.badge.partial{background:#f59e0b33;color:var(--warning)}.badge.unpaid,.badge.overdue{background:#ef444433;color:var(--danger)}.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:20px}input,select,button{font:inherit}input,select{padding:10px 12px;background:var(--card);border:1px solid var(--border);border-radius:8px;color:var(--text);max-width:100%}input:not([type=number]):not(.inline){min-width:200px}button{background:var(--primary);color:#fff;border:none;padding:10px 18px;border-radius:8px;cursor:pointer;font-weight:600;white-space:nowrap;transition:var(--interactive-transition)}button:not(:disabled):not(.secondary):not(.danger):hover{background:var(--primary-dark)}button:disabled{opacity:.5;cursor:not-allowed}button.secondary,a.secondary{background:transparent;border:1px solid var(--border);color:var(--text)}a.secondary{display:inline-flex;align-items:center;padding:10px 18px;border-radius:8px;font-weight:600;text-decoration:none;transition:var(--interactive-transition)}a.primary{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:8px;font-weight:600;text-decoration:none;background:var(--primary);color:#fff;border:none;white-space:nowrap;transition:var(--interactive-transition);box-sizing:border-box}a.primary:hover{background:var(--primary-dark);color:#fff}button.secondary:not(:disabled):hover,a.secondary:hover{background:var(--hover-surface);border-color:var(--hover-border);color:var(--text)}button.full-width{width:100%}.menu-toggle,.btn-link,.sidebar-link,.sidebar-nav .nav-item,.nav-sub-item,.slot-empty,.slot-card-btn,.table-row-clickable,.timetable-tabs .tab,.tab,.grades-segments button,.grades-segments-tabs button,.att-btn,.step-pill,.finance-reports-nav button,.settings-assign-pick-item,.timetable-copy-item,.staff-att-status-btn{transition:var(--interactive-transition)}.menu-toggle:hover{background:var(--hover-surface);border-color:var(--hover-border)}.slot-card-btn:hover .slot-card--course{box-shadow:0 2px 8px #0f172a14;filter:brightness(.98)}.staff-att-status-btn:hover:not(.active){background:var(--hover-surface);border-color:var(--hover-border);color:var(--text)}.grades-segments-tabs button:hover:not(.is-active){background:var(--hover-surface);color:var(--text)}.tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:24px}.plan-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px}.plan-card--featured{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary)}.plan-badge{position:absolute;top:12px;right:12px;background:var(--primary);color:#fff;font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:20px}.plan-card h3{margin:0 0 8px;font-size:1.25rem}.plan-price{font-size:1.5rem;font-weight:700;color:var(--primary);margin:0 0 8px}.plan-desc{color:var(--muted);font-size:.9rem;margin:0 0 16px}.plan-card ul{margin:0 0 20px;padding-left:18px;color:var(--text);font-size:.9rem}.plan-card li{margin-bottom:6px}.muted-note{color:var(--muted);font-size:.9rem}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,#DCFCE7 0%,var(--bg) 45%,#E0F2FE 100%)}.login-page{width:100%;max-width:400px;padding:36px;background:var(--card);border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow-md)}.login-page h1{color:var(--primary);text-align:center;margin:0 0 8px;font-size:2rem}.login-page input{width:100%;margin-bottom:12px}.login-page button[type=submit]{width:100%;margin-top:8px}.loading-wrap{display:flex;flex-direction:column;align-items:center;padding:48px;color:var(--muted)}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:12px}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{background:#ef444422;border:1px solid var(--danger);color:var(--danger);padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.info-banner{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:.95rem;line-height:1.45}.info-banner-info{border:1px solid #3b82f655;background:#3b82f618;color:var(--text)}.info-banner-warning{border:1px solid #f59e0b55;background:#f59e0b18;color:var(--text)}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px;color:var(--muted);font-size:.9rem}.row-present{cursor:pointer}.row-present.absent td{opacity:.7}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}.msg-ok{color:var(--primary);margin-bottom:16px}.success-banner{background:var(--primary-dim);border:1px solid var(--primary);color:var(--primary);padding:14px 16px;border-radius:10px;margin-bottom:16px;font-weight:500}.grades-summary-table .grades-num-col,.grades-prep-table .grades-num-col,.grades-entry-table .grades-num-col{text-align:right;white-space:nowrap}.attendance-toolbar{flex-wrap:wrap;align-items:flex-end;gap:12px}.grades-sheet-badge{display:inline-flex;align-items:center;padding:.35rem .65rem;border-radius:6px;font-size:.85rem;font-weight:600;background:#f3f4f6;color:#374151}.grades-sheet-draft{background:#fef3c7;color:#92400e}.grades-sheet-submitted{background:#dbeafe;color:#1e40af}.grades-sheet-validated{background:#d1fae5;color:#065f46}.grades-validation-banner{margin:12px 0 16px;padding:10px 14px;border-radius:10px;background:#f59e0b18;border:1px solid #f59e0b55;font-size:.95rem;color:var(--text);line-height:1.45}.grades-validation-banner strong{color:var(--text)}.grades-validation-banner .muted{color:var(--muted)}.grades-validation-ready{background:var(--primary-dim);border-color:#22c55e55}.grades-validation-ready strong{color:var(--primary)}.grades-validation-pending{margin-top:6px}.grades-validation-pending summary{cursor:pointer;color:var(--muted);font-size:.9rem}.grades-validation-pending ul{margin:8px 0 0;padding-left:1.25rem;color:var(--muted);font-size:.88rem}.grades-validation-pending li{margin-bottom:2px}.grades-segments-tabs{gap:0;border-bottom:1px solid var(--border);margin-bottom:20px}.grades-segments-tabs button{border:none;border-radius:0;background:transparent;padding:.65rem 1rem;border-bottom:3px solid transparent;margin-bottom:-1px}.grades-segments-tabs button.is-active{background:transparent;color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.grades-segments-tabs .grades-segment-count{background:var(--primary-dim)}.grades-recap-scroll{overflow-x:auto;margin-bottom:20px}.grades-recap-table{min-width:720px;font-size:.88rem}.grades-recap-table th,.grades-recap-table td{white-space:nowrap}.grades-segments{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 20px}.grades-segments button{display:inline-flex;align-items:center;gap:8px;padding:.45rem .9rem;border-radius:999px;border:1px solid var(--border);background:var(--card);color:var(--muted);cursor:pointer;font-size:.9rem}.grades-segments button:hover:not(.is-active){color:var(--text);background:var(--hover-surface);border-color:var(--hover-border)}.grades-segments button.is-active{background:var(--primary-dim);border-color:#22c55e66;color:var(--primary);font-weight:600}.grades-segment-count{display:inline-flex;min-width:1.25rem;justify-content:center;padding:0 .35rem;border-radius:999px;background:var(--bg);font-size:.78rem;font-weight:600}.grades-segments button.is-active .grades-segment-count{background:#22c55e33}.grades-histogram{padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:var(--bg-elevated)}.grades-bulletin-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.8rem;font-weight:600}.grades-bulletin-ready{background:#f59e0b22;color:#fbbf24}.grades-bulletin-generated{background:#3b82f622;color:#93c5fd}.grades-bulletin-sent{background:var(--primary-dim);color:var(--primary)}.grades-mention{font-size:.85rem;font-weight:600}.grades-prog-up{color:#15803d}.grades-prog-down{color:#b91c1c}input.grade-input-ok{border-color:#16a34a;color:#14532d}input.grade-input-warn{border-color:#ea580c;color:#9a3412}input.grade-input-low{border-color:#dc2626;color:#7f1d1d}.grades-prep-table .grades-num-input{width:4.5rem;text-align:right;margin-left:auto;display:block}.grades-toolbar{flex-wrap:wrap;align-items:flex-end;gap:12px}.toolbar-actions{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.grades-toolbar .toolbar-field select,.attendance-toolbar .toolbar-field select,.attendance-toolbar .toolbar-field input[type=date],.grades-toolbar .toolbar-actions button,.attendance-toolbar .toolbar-actions button{height:42px;box-sizing:border-box}.grades-toolbar .toolbar-field select,.attendance-toolbar .toolbar-field select{width:100%;min-width:180px}.toolbar-field{display:flex;flex-direction:column;gap:4px;min-width:160px}.toolbar-field-grow{flex:1;min-width:200px}.toolbar-field-grow .field-input,.toolbar-field-grow input,.toolbar-field-grow select{width:100%}.toolbar-field .field-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.toolbar-field-actions{min-width:0;flex-shrink:0}.toolbar-field-actions .toolbar-actions{align-items:flex-end}.attendance-summary{margin:0 0 12px;color:var(--muted);font-size:.9rem}.attendance-status-btns{display:inline-flex;vertical-align:middle;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--bg)}.att-btn{padding:6px 11px;margin:0;border:none;border-radius:0;border-right:1px solid var(--border);background:transparent;color:var(--muted);font-size:.72rem;font-weight:500;line-height:1.2;cursor:pointer;white-space:nowrap}.att-btn:last-child{border-right:none}.att-btn:hover:not(.is-active){color:var(--text);background:var(--hover-surface)}.att-btn.is-active.present{background:var(--primary);color:#fff;font-weight:600}.att-btn.is-active.absent{background:var(--danger);color:#fff;font-weight:600}.att-btn.is-active.late{background:var(--warning);color:#1a1a1a;font-weight:600}.attendance-row.status-present td:first-child{box-shadow:inset 3px 0 0 var(--primary)}.attendance-row.status-absent td:first-child{box-shadow:inset 3px 0 0 var(--danger)}.attendance-row.status-late td:first-child{box-shadow:inset 3px 0 0 var(--warning)}.attendance-row{cursor:default}.attendance-row:hover{background:var(--bg-elevated)}.school-chip .school-select{width:100%;margin-bottom:4px;font-weight:600;font-size:.85rem;background:#ffffff1a;border:1px solid var(--sidebar-border);border-radius:6px;color:var(--sidebar-text);padding:6px 8px}@media (max-width: 900px){.menu-toggle{display:block}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0008;border:none;z-index:45;cursor:pointer}.sidebar{position:fixed;left:0;transform:translate(-100%);transition:transform .2s ease}.app-shell.menu-open .sidebar{transform:translate(0)}.topbar{padding-left:64px}.main{padding:20px 16px 40px}.grid-2{grid-template-columns:1fr}.topbar-title{font-size:1rem}}@media (max-width: 600px){.cards{grid-template-columns:1fr}.page-header{flex-direction:column}}.timetable-select{min-width:160px}.timetable-tabs{display:flex;gap:6px;margin-bottom:16px;padding:4px;background:var(--bg);border:1px solid var(--border);border-radius:12px;flex-wrap:wrap}.timetable-tabs .tab{background:transparent;border:none;color:var(--muted);padding:10px 16px;border-radius:8px;font-weight:600;font-size:.88rem;transition:background .15s,color .15s,box-shadow .15s}.timetable-tabs .tab:hover:not(.active){color:var(--text);background:#ffffffd9}.timetable-tabs .tab.active{color:var(--text);background:var(--card);box-shadow:var(--shadow-sm)}.week-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap;padding:10px 14px;background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-sm)}.week-label{font-weight:700;min-width:200px;color:var(--text);font-size:.95rem}.timetable-grid-wrap{overflow-x:auto;margin-bottom:32px;border:1px solid var(--border);border-radius:14px;background:var(--card);box-shadow:var(--shadow-md)}.timetable-grid{min-width:900px;border-collapse:collapse}.timetable-grid th,.timetable-grid td{border:1px solid #E2E8F0;padding:8px;vertical-align:top;min-width:120px}.timetable-grid thead th:not(.time-col){background:#f8fafc;font-size:.72rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#64748b;padding:12px 8px;text-align:center}.timetable-grid .time-col{width:88px;min-width:88px;color:#475569;font-size:.82rem;font-weight:600;background:#f1f5f9}.time-col-range{display:block;font-size:.7rem;margin-top:2px;color:#94a3b8;font-weight:500}.timetable-grid th.day-today{background:#dcfce7;color:#15803d}.timetable-grid td.day-today{background:#f0fdf4}.slot-card{border-radius:10px;border:1px solid var(--border);padding:10px 10px 10px 12px;min-height:72px;display:flex;flex-direction:column;gap:3px;font-size:.85rem;box-shadow:0 1px 2px #0f172a0d}.slot-card--course{--slot-color: var(--accent-blue);background:color-mix(in srgb,var(--slot-color) 10%,white);border-color:color-mix(in srgb,var(--slot-color) 35%,white);border-left:4px solid var(--slot-color)}.slot-card strong{color:#0f172a;font-size:.92rem;font-weight:700;line-height:1.25}.slot-card--course strong{color:color-mix(in srgb,var(--slot-color) 72%,#0F172A)}.slot-card span{color:#64748b;font-size:.78rem}.slot-teacher{margin-top:auto;color:#334155!important;font-weight:500}.slot-card--recess,.slot-card--lunch_break,.slot-card--special_activity{border-style:dashed;text-align:center;justify-content:center;min-height:56px;border-left-width:1px}.slot-card--recess{background:#fffbeb!important;border-color:#d97706!important;color:#92400e}.slot-card--lunch_break{background:#fff7ed!important;border-color:#ea580c!important;color:#9a3412}.slot-card--special_activity{background:#f5f3ff!important;border-color:#7c3aed!important;color:#5b21b6}.slot-period-type{font-size:.75rem!important;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text)!important}.slot-empty{min-height:72px;width:100%;border:1px dashed #CBD5E1;border-radius:10px;background:#fafbfc;cursor:pointer;color:#94a3b8;font-size:.8rem;font-weight:500;transition:border-color .15s,background .15s,color .15s}.slot-empty:hover{border-color:var(--primary);background:#f0fdf4;color:var(--primary-dark)}.slot-empty-readonly{cursor:default;pointer-events:none}.slot-empty-readonly:hover{border-color:var(--border);background:var(--bg-elevated);color:transparent}.teachers-page .teacher-detail-modal{max-width:960px;width:min(96vw,960px);max-height:90vh;overflow-y:auto}.teacher-schedule-section{margin:20px 0}.teacher-schedule-section h4{margin:0 0 8px}.teacher-month-hint{margin:0 0 12px;padding:10px 14px;border-radius:8px;background:var(--primary-dim);border:1px solid var(--primary);color:var(--text);font-size:.9rem}.slot-card-btn{width:100%;min-height:72px;padding:0;border:none;background:transparent;cursor:pointer;text-align:left;font:inherit}.timetable-slot-modal{max-width:440px}.timetable-copy-modal{max-width:480px}.timetable-slot-time-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.timetable-copy-list{list-style:none;margin:0 0 16px;padding:0;max-height:280px;overflow-y:auto;border:1px solid var(--border);border-radius:10px}.timetable-copy-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer}.timetable-copy-item:hover{background:var(--hover-surface)}.timetable-copy-item:last-child{border-bottom:none}.timetable-copy-actions{display:flex;gap:8px;margin-bottom:8px}.timetable-slot-context{margin:0 0 16px;font-size:.9rem}.timetable-slot-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap;margin-top:8px}.timetable-slot-actions .danger{margin-right:auto;border-color:var(--danger);color:var(--danger)}.break-row td{text-align:center;background:var(--bg);color:var(--muted);font-size:.85rem;padding:10px!important}.timetable-view-title{margin:0 0 12px;font-weight:700;font-size:1rem;color:#1e293b}.annual-calendar{display:flex;flex-direction:column;gap:24px}.annual-intro{margin:0;color:var(--muted)}.annual-month h3{margin:0 0 12px;font-size:1.1rem;color:var(--primary)}.annual-events{list-style:none;margin:0;padding:0;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card)}.annual-event{display:flex;align-items:center;gap:16px;padding:12px 16px;border-bottom:1px solid var(--border)}.annual-event:last-child{border-bottom:none}.annual-event time{min-width:72px;font-weight:600;color:var(--muted);font-size:.9rem}.annual-event.holiday{background:#ef44440d}.annual-event.academic{background:#22c55e0d}.workload-section{margin-top:8px}.workload-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.workload-header h3{margin:0}.workload-header a{font-size:.9rem}.workload-summary .card strong.text-ok{color:var(--primary)}.workload-summary .card strong.text-danger{color:var(--danger)}.workload-section-compact{margin-bottom:20px}.workload-hint{margin:4px 0 0;font-size:.85rem}.workload-module-links{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}.workload-module-link{color:var(--primary);font-weight:600;font-size:.9rem;text-decoration:none}.workload-module-link:hover{text-decoration:underline}.teacher-cell{display:flex;align-items:center;gap:12px}.avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-dim);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.teacher-cell small{display:block;color:var(--muted);font-size:.75rem}.btn-link{color:var(--primary);font-weight:600;padding:10px 16px;border:1px solid var(--primary);border-radius:8px;transition:var(--interactive-transition)}.btn-link:hover{background:var(--primary-dim);border-color:var(--primary-dark);color:var(--primary-dark)}.modal-backdrop,.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000a;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}.modal.panel{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;max-width:560px;width:100%;max-height:90vh;overflow-y:auto}.modal h3{margin:0 0 8px}.confirm-dialog{max-width:440px}.confirm-dialog-text{margin:0 0 20px;color:var(--muted);line-height:1.5}.confirm-dialog-text strong{color:var(--text)}.confirm-dialog-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}button.danger{background:var(--danger);color:#fff}button.danger:hover:not(:disabled){filter:brightness(.94)}.nav-badge{flex-shrink:0;min-width:22px;height:22px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;background:var(--danger);color:#fff;font-size:.7rem;border-radius:11px;font-weight:700}.settings-tabs{margin-bottom:24px}.settings-section{margin-bottom:32px}.settings-section h3{margin:0 0 8px}.settings-hint{margin:0 0 16px}.settings-year-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:16px}@media (max-width: 768px){.settings-year-grid{grid-template-columns:1fr}}.settings-year-form{max-width:900px}.settings-fieldset{border:1px solid var(--border);border-radius:10px;padding:16px 18px;margin:20px 0}.settings-fieldset legend{padding:0 8px}.settings-enrollment-dates{margin-top:12px}.settings-time-row-form{margin-top:24px}.settings-subsection{margin:20px 0}.settings-break-list{margin:8px 0;padding-left:1.2rem}.settings-breaks-section{margin-top:40px;padding-top:24px;border-top:1px solid var(--border, #e5e7eb)}.annual-hint{margin:0 0 20px;max-width:52rem}.settings-calendar-toolbar{margin:16px 0 20px}.settings-year-filter{max-width:220px}.settings-calendar-form{margin-top:24px}.settings-controls-section{margin-bottom:36px;padding-bottom:28px;border-bottom:1px solid var(--border, #e5e7eb)}.settings-subsection-title{margin:28px 0 12px;font-size:1rem}.annual-event.control{background:#a78bfa14}.annual-period-range{color:var(--muted);font-weight:400}.annual-event.enrollment{border-left-color:#38bdf8}.badge.annual-type-badge{font-size:.7rem;font-weight:600;opacity:.9;margin-left:auto;flex-shrink:0}.enrollment-period-cell{font-size:.88rem;max-width:200px}.settings-subjects-layout{display:grid;grid-template-columns:minmax(200px,280px) 1fr;gap:24px;margin-top:20px}@media (max-width: 768px){.settings-subjects-layout{grid-template-columns:1fr}}.settings-class-list{list-style:none;padding:0;margin:0}.settings-class-btn{display:flex;flex-direction:column;align-items:flex-start;width:100%;text-align:left;padding:10px 12px;margin-bottom:6px;border:1px solid var(--border);border-radius:8px;background:var(--surface);cursor:pointer}.settings-class-btn.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--surface))}.settings-subject-checklist{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:8px}.settings-catalog-section{margin-bottom:24px;padding:16px 18px}.settings-subject-add-form{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:16px}.settings-subject-add-form .field-block{flex:1;min-width:160px;margin:0}.settings-catalog-import-row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start;margin-bottom:12px}.settings-catalog-import-row .field-block{margin:0}.settings-catalog-import-program{flex:1;min-width:220px;max-width:480px}.settings-catalog-import-action{flex:0 1 auto;min-width:200px}.settings-catalog-import-row select.field-input,.settings-catalog-import-btn{box-sizing:border-box;min-height:42px;width:100%}.settings-catalog-import-btn{display:inline-flex;align-items:center;justify-content:center;margin:0}.settings-catalog-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.settings-catalog-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-elevated)}.settings-catalog-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0;margin:0 0 12px;border:none;background:transparent;cursor:pointer;text-align:left}.settings-catalog-toggle .settings-subsection-title{margin:0}.settings-catalog-table-wrap{margin-top:8px}.settings-assign-filters{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:16px;padding:14px 16px}.settings-assign-filters .field-block-grow{flex:1;min-width:180px}.settings-assign-import-action button{width:100%;white-space:nowrap}.settings-assign-overview{margin-bottom:20px}.settings-assign-row-active{background:color-mix(in srgb,var(--primary) 8%,transparent)}.settings-assign-col-action{width:1%;white-space:nowrap;text-align:right}.settings-assign-preview-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.settings-assign-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.8rem;font-weight:600;background:var(--primary-dim);color:var(--primary);border:1px solid color-mix(in srgb,var(--primary) 35%,transparent)}.settings-assign-chip.preview{font-weight:500;padding:3px 8px;font-size:.75rem}.settings-assign-chip-remove{border:none;background:transparent;color:inherit;cursor:pointer;font-size:1.1rem;line-height:1;padding:0 2px;opacity:.75}.settings-assign-chip-remove:hover{opacity:1}.settings-assign-workspace{padding:18px 20px;margin-top:4px}.settings-assign-workspace-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}.settings-assign-workspace-head h4{margin:0}.settings-assign-copy{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.settings-assign-copy .field-input{min-width:200px}.settings-assign-dual{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 900px){.settings-assign-dual{grid-template-columns:1fr}}.settings-assign-column{display:flex;flex-direction:column;gap:10px;min-height:280px;padding:14px;border:1px solid var(--border);border-radius:10px;background:var(--bg-elevated)}.settings-assign-column-assigned{border-color:color-mix(in srgb,var(--primary) 30%,var(--border))}.settings-assign-column-head{display:flex;justify-content:space-between;align-items:center}.settings-assign-column-head h5{margin:0;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.settings-assign-pick-list{list-style:none;margin:0;padding:0;flex:1;overflow-y:auto;max-height:240px;display:flex;flex-direction:column;gap:4px}.settings-assign-pick-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:.9rem}.settings-assign-pick-item:hover{background:var(--hover-surface)}.settings-assign-chip-grid{display:flex;flex-wrap:wrap;gap:8px;flex:1;align-content:flex-start;min-height:120px}.settings-assign-empty{flex:1;margin:0;font-size:.9rem}.settings-assign-column-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:8px;border-top:1px solid var(--border)}.settings-assign-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.settings-import-panel{margin-bottom:20px;padding:16px 18px}.settings-import-options{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 768px){.settings-import-options{grid-template-columns:1fr}}.settings-import-option{display:flex;flex-direction:column;gap:10px}.settings-import-from-school{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.settings-import-from-school .field-input{min-width:160px;flex:1}.settings-filters{margin-bottom:16px}.success-banner{color:var(--success, #0a7);margin:12px 0}.settings-checkbox{display:flex;align-items:center;gap:8px;margin-bottom:20px;cursor:pointer}.export-columns-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px 16px;margin-top:8px}.export-columns-actions{display:flex;flex-wrap:wrap;gap:8px}.export-columns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:10px 16px;margin:12px 0 20px}.export-column-check{display:flex;align-items:center;gap:8px;cursor:pointer}.student-export-modal{max-width:640px}.settings-form-actions{display:flex;gap:12px;flex-wrap:wrap}.settings-years-table{min-width:520px}.settings-classrooms-lists{display:grid;gap:24px;margin-bottom:24px}@media (min-width: 900px){.settings-classrooms-lists{grid-template-columns:1fr 1fr}}.settings-add-classroom{border:1px solid var(--border);border-radius:12px;padding:20px;background:var(--card)}.settings-years-table tr.row-editing{background:color-mix(in srgb,var(--primary) 12%,transparent);outline:1px solid color-mix(in srgb,var(--primary) 35%,var(--border))}.settings-admin-panel{max-width:560px}.settings-filters-row{margin-bottom:20px}.settings-fee-editor{max-width:960px;border:1px solid var(--border);border-radius:12px;padding:20px;background:var(--card)}.installments-preview{font-size:.85rem;max-width:320px}.installments-edit-table{margin:16px 0}.block-text{display:block;font-size:.8rem}.fee-totals-banner{padding:12px 16px;border-radius:8px;margin:12px 0;font-size:.95rem}.fee-totals-ok{background:#e8f5e9;color:#1b5e20;border:1px solid #a5d6a7}.fee-totals-error{background:#3d2020;color:#ffcdd2;border:1px solid #c62828}.field-hint{display:block;font-size:.8rem;color:var(--muted);margin-top:4px}.field-hint-warn{color:#ffb74d;line-height:1.45}.field-hint-warn a{color:var(--primary)}.link-button{background:none;border:none;padding:0;color:var(--primary);cursor:pointer;font:inherit;text-decoration:underline}.link-button:disabled{opacity:.5;cursor:not-allowed}.badge-success{background:#e8f5e9;color:#2e7d32;padding:2px 8px;border-radius:4px;font-size:.85rem;font-weight:600}.success-banner{padding:12px 16px;background:#e8f5e9;color:#1b5e20;border-radius:8px;margin-bottom:16px}.settings-links{margin:16px 0;padding-left:20px;line-height:2}.settings-links a{color:var(--primary)}.enrollment-wizard{max-width:1200px}.enrollment-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px}.enrollment-top h2{margin:8px 0 0}.enrollment-body{display:grid;grid-template-columns:1fr 300px;gap:24px;align-items:start}@media (max-width: 960px){.enrollment-body{grid-template-columns:1fr}}.stepper-horizontal{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.step-pill{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;background:var(--bg-elevated);color:var(--muted);font-size:.85rem;border:1px solid transparent;cursor:default;font-family:inherit}.step-pill:disabled{opacity:.6;cursor:not-allowed}.step-pill.done:not(:disabled){cursor:pointer}.step-pill.done:not(:disabled):hover{background:var(--hover-surface);border-color:var(--hover-border)}.step-pill.active{background:var(--primary-dim);color:var(--primary);border:1px solid var(--primary)}.step-pill.done{color:var(--primary)}.step-num{width:24px;height:24px;border-radius:50%;background:var(--card);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}.student-recap{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:20px;display:flex;flex-wrap:wrap;gap:12px;align-items:center}.student-recap span{color:var(--muted);font-size:.9rem}.enrollment-form-step2{padding:20px}.step-form-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.step-form-header h3{margin:0;font-size:1.1rem;font-weight:700}.step-form-icon{width:36px;height:36px;border-radius:10px;background:var(--primary-dim);display:flex;align-items:center;justify-content:center;font-size:1.1rem}.student-recap-card{display:flex;align-items:center;gap:14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;padding:14px 16px;margin-bottom:20px}.student-recap-avatar{width:52px;height:52px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--primary-dim);display:flex;align-items:center;justify-content:center}.student-recap-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{font-size:1.4rem;opacity:.7}.student-recap-info{flex:1;min-width:0}.student-recap-info strong{display:block;font-size:1rem;margin-bottom:4px}.student-recap-info span{color:var(--muted);font-size:.8rem;line-height:1.35}.step-complete-badge{flex-shrink:0;font-size:.7rem;white-space:nowrap}.form-grid-step2{display:grid;grid-template-columns:1fr 1fr;gap:16px 14px}.form-grid-step2 .field-full{grid-column:1 / -1}.field-block{display:flex;flex-direction:column;gap:8px;margin:0}.field-label{display:block;font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.enrollment-form-step2 .field-input{width:100%;margin:0;padding:14px 16px;border-radius:12px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.95rem;font-family:inherit}.enrollment-form-step2 select.field-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23666' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}.enrollment-form-step2 textarea.field-input{resize:vertical;min-height:88px}.fee-row .field-label{margin-bottom:4px}.fee-input-wrap{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:0 16px}.fee-currency{font-weight:700;color:var(--muted);font-size:1rem}.fee-amount{flex:1;border:none!important;background:transparent!important;padding:14px 0!important;text-align:right;font-weight:600}@media (max-width: 640px){.form-grid-step2{grid-template-columns:1fr}.form-grid-step2 .field-block:not(.field-full){grid-column:1 / -1}.student-recap-card{flex-wrap:wrap}.step-complete-badge{width:100%;text-align:center}}.enrollment-form{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:24px}.enrollment-form label{display:block;margin-bottom:16px;font-size:.85rem;color:var(--muted)}.enrollment-form label input,.enrollment-form label select,.enrollment-form label textarea{display:block;width:100%;margin-top:6px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.photo-capture{margin:16px 0;padding:16px;border:1px dashed var(--border);border-radius:12px}.photo-preview{width:120px;height:120px;object-fit:cover;border-radius:12px;display:block;margin-bottom:12px}.wizard-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border);flex-wrap:wrap}.wizard-footer span{color:var(--muted);font-size:.85rem}.whatsapp-hint{background:var(--primary-dim);border-radius:8px;padding:12px;font-size:.9rem;color:var(--primary)}.doc-upload-list{list-style:none;margin:0;padding:0}.doc-upload-list li{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.enrollment-sidebar .matricule-card{background:linear-gradient(145deg,#22c55e22,var(--card));border:1px solid var(--primary);border-radius:12px;padding:20px;margin-bottom:20px}.matricule-card label{font-size:.75rem;text-transform:uppercase;color:var(--muted);letter-spacing:.05em}.matricule-value{display:block;font-size:1.5rem;color:var(--primary);margin:8px 0 12px;font-family:ui-monospace,monospace}.matricule-meta{margin:0;font-size:.85rem}.matricule-meta dt{color:var(--muted);margin-top:8px}.matricule-meta dd{margin:2px 0 0}.sidebar-steps,.sidebar-docs{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:16px}.sidebar-steps h4,.sidebar-docs h4{margin:0 0 12px;font-size:.95rem}.sidebar-steps ol{margin:0;padding:0;list-style:none}.sidebar-steps li{padding:10px 0;border-bottom:1px solid var(--border)}.sidebar-steps li strong{display:block;font-size:.9rem}.sidebar-steps li span{font-size:.8rem;color:var(--muted)}.sidebar-steps li.current span,.sidebar-steps li.done span{color:var(--primary)}.sidebar-docs ul{margin:0;padding:0;list-style:none;font-size:.9rem}.sidebar-docs li{padding:6px 0;color:var(--muted)}.sidebar-docs li.done{color:var(--primary)}.id-card-preview{margin:20px 0}.id-card{display:flex;align-items:center;gap:16px;padding:16px;border:1px solid var(--border);border-radius:12px;background:var(--bg-elevated)}.id-card img:first-child{width:64px;height:64px;object-fit:cover;border-radius:8px}.id-card div{flex:1;display:flex;flex-direction:column;gap:4px}.confirm-check{display:flex;align-items:center;gap:10px;margin-top:16px}.confirm-check input{width:auto;margin:0}.enrollment-done{max-width:480px;margin:0 auto;text-align:center}.enrollment-done-actions{display:flex;gap:12px;justify-content:center;margin-top:24px;flex-wrap:wrap}.empty-state{text-align:center;padding:48px 24px;background:var(--card);border:1px solid var(--border);border-radius:12px}.empty-state p{margin:0 0 12px}.actions-cell{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.actions-cell .primary,.actions-cell .secondary{padding:6px 12px;font-size:.85rem}.enrollment-period.closed{background:#ef444422;color:#fca5a5;border-radius:8px;padding:12px}.matricule-cell{font-size:.85rem;color:var(--primary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.finance-page{max-width:1400px}.finance-page-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.finance-title{margin:0;font-size:1.75rem;font-weight:700}.finance-context{margin:4px 0 0;color:var(--muted);font-size:.95rem}.finance-global-year,.finance-global-year select{min-width:11rem}.finance-header-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.finance-tranche-btn{display:inline-flex;align-items:center;gap:8px}.finance-btn-icon{width:1.1rem;height:1.1rem;flex-shrink:0}.finance-row-actions{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.finance-tranche-readonly{margin:0;padding:10px 12px;background:var(--bg-elevated);border-radius:8px;font-weight:600}.finance-main-tabs{margin-bottom:20px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.finance-main-tabs .tab{flex-shrink:0;white-space:nowrap}.finance-sub-header{margin-top:0;margin-bottom:16px}.finance-subtitle{margin:0;font-size:1.15rem;font-weight:600}.finance-tab-hint{margin:0 0 16px;font-size:.9rem}.finance-toolbar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px;padding:14px 16px}.finance-year-select{min-width:160px}.finance-tranche-picker{margin-bottom:20px}.finance-tranche-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.chip{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);padding:6px 14px;border-radius:999px;font-size:.85rem;cursor:pointer}.chip.active{border-color:var(--primary);background:var(--primary-dim);color:var(--primary)}.finance-tranche-chip{display:flex;flex-direction:row;align-items:center;gap:8px;min-width:9rem;text-align:left;border-radius:10px;padding:8px 12px}.finance-tranche-chip-check{font-size:1rem;line-height:1;flex-shrink:0}.finance-tranche-chip-body{display:flex;flex-direction:column;gap:2px}.finance-tranche-chip-label{font-weight:600;font-size:.88rem}.finance-tranche-chip-meta{font-size:.78rem;opacity:.85}.finance-tranche-chip.paid{opacity:.65;cursor:default}.finance-tranche-chip.blocked{opacity:.5;cursor:not-allowed}.finance-tranche-chip.active .finance-tranche-chip-meta{opacity:1}.finance-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}@media (max-width: 1100px){.finance-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.finance-kpi-grid{grid-template-columns:1fr}}.finance-kpi{position:relative;overflow:hidden;padding:18px 20px}.finance-kpi-label{display:block;font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.finance-kpi-value{display:block;font-size:1.35rem;font-weight:700}.finance-kpi-sub{display:block;font-size:.8rem;margin-top:6px}.finance-kpi-bar{position:absolute;bottom:0;left:0;height:3px;background:var(--primary);max-width:100%}.finance-kpi-bar.partial{background:var(--warning)}.finance-kpi-bar.unpaid{background:var(--danger)}.kpi-collected .finance-kpi-value{color:var(--primary)}.kpi-partial .finance-kpi-value{color:var(--warning)}.kpi-unpaid .finance-kpi-value{color:var(--danger)}.finance-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:16px;padding:14px 16px}.finance-search{flex:1;min-width:200px}.finance-class-filters{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.finance-class-filters .toolbar-field{min-width:140px}.finance-class-filters .field-input,.finance-class-filters select,.finance-class-filters button.secondary{min-width:160px;height:42px;box-sizing:border-box}.finance-class-filters .toolbar-field-grow .field-input{min-width:200px;width:100%}.finance-filter-chips{display:flex;flex-wrap:wrap;gap:8px}.finance-table-wrap{margin-bottom:24px;overflow-x:auto}.finance-actions-col{min-width:11rem;white-space:nowrap}.finance-btn-releve{border-color:var(--primary);color:var(--primary)}.finance-aids-tab{display:flex;flex-direction:column;gap:16px}.finance-aids-hint{padding:16px 18px;font-size:.9rem;line-height:1.5}.finance-aids-steps{margin:10px 0 0;padding-left:1.25rem}.finance-aids-steps li{margin-bottom:6px}.finance-aids-filter{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;color:var(--muted)}.finance-aids-empty{padding:24px;text-align:center;display:flex;flex-direction:column;gap:12px;align-items:center}.finance-aid-badge{display:inline-block;margin-left:6px;font-size:.72rem;vertical-align:middle}.finance-discount-hint{font-size:.82rem}.finance-reports{display:flex;flex-direction:column;gap:16px}.finance-reports-filters{flex-wrap:wrap;gap:8px}.finance-reports-layout{display:grid;grid-template-columns:240px 1fr;gap:16px;align-items:start}@media (max-width: 900px){.finance-reports-layout{grid-template-columns:1fr}}.finance-reports-nav{padding:12px;position:sticky;top:12px;max-height:calc(100vh - 120px);overflow-y:auto}.finance-reports-nav-group{margin-bottom:14px}.finance-reports-nav-group h3{margin:0 0 6px;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.finance-reports-nav ul{list-style:none;margin:0;padding:0}.finance-reports-nav button{width:100%;text-align:left;border:none;background:transparent;padding:8px 10px;border-radius:8px;font-size:.88rem;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:space-between;gap:6px}.finance-reports-nav button:hover{background:var(--hover-surface);border-color:var(--hover-border)}.finance-reports-nav button.is-active{background:var(--primary-dim);color:var(--primary);font-weight:600}.finance-reports-soon{font-size:.65rem;padding:2px 6px;border-radius:6px;background:var(--border);color:var(--muted)}.finance-reports-main{padding:18px 20px;min-width:0}.finance-reports-main-head{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;margin-bottom:16px}.finance-reports-main-head h3{margin:0}.finance-reports-actions{display:flex;flex-wrap:wrap;gap:8px}.finance-reports-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:20px}.finance-reports-kpi{padding:14px;border-radius:12px;background:var(--bg-elevated);border:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.finance-reports-kpi.is-accent{border-color:var(--primary)}.finance-reports-kpi.is-warn{border-color:var(--warning)}.finance-reports-kpi-label{font-size:.72rem;text-transform:uppercase;color:var(--muted)}.finance-reports-kpi-value{font-size:1.35rem}.finance-reports-charts{display:grid;grid-template-columns:1.2fr 1fr;gap:16px;margin-bottom:16px}@media (max-width: 800px){.finance-reports-charts{grid-template-columns:1fr}}.finance-reports-chart-card{padding:14px;border-radius:12px;border:1px solid var(--border);background:var(--card)}.finance-reports-chart-card h4{margin:0 0 12px;font-size:.95rem}.finance-reports-bars{display:flex;align-items:flex-end;gap:8px;min-height:140px}.finance-reports-bars--wide{min-height:180px}.finance-reports-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0;font-size:.72rem;color:var(--muted)}.finance-reports-bar-fill{width:100%;max-width:36px;min-height:4px;background:var(--primary);border-radius:4px 4px 0 0;opacity:.85}.finance-reports-cat-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.finance-reports-cat-list li{display:flex;justify-content:space-between;padding:8px 10px;background:var(--bg-elevated);border-radius:8px}.finance-reports-coming{padding:14px;border-radius:10px;font-size:.88rem}.finance-reports-coming ul{margin:8px 0 0;padding-left:1.2rem}.finance-reports-aging-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-bottom:16px}.finance-reports-aging-card{padding:12px;border-radius:10px;background:var(--bg-elevated);display:flex;flex-direction:column;gap:4px}.finance-reports-aging-label{font-size:.8rem;color:var(--muted)}.finance-reports-aging-bar{height:4px;margin-top:6px;border-radius:2px;background:var(--accent, #2563eb);min-width:4px}.finance-reports-unavailable{padding:24px;text-align:center;color:var(--muted)}.finance-reports-summary,.finance-reports-period{margin:0 0 12px}.finance-reports-table{font-size:.88rem}.finance-reports-loading{opacity:.72;pointer-events:none}.finance-reports-refresh{margin:0 0 8px;font-size:.85rem}.finance-reports-truncation{margin:0 0 12px;font-size:.85rem}.finance-budget-summary{display:flex;flex-wrap:wrap;gap:24px;margin-bottom:16px;padding:16px 20px}.finance-budget-summary>div{display:flex;flex-direction:column;gap:4px}.finance-budget-summary strong{font-size:1.15rem}.finance-budget-code{display:block;font-size:.75rem}.finance-budget-input{width:8rem;max-width:100%}.finance-budget-notes{width:100%;min-width:10rem}.finance-budget-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.comms-config-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:16px}@media (max-width: 768px){.comms-config-grid{grid-template-columns:1fr}}.comms-config-item{display:flex;flex-direction:column;gap:6px;padding:16px 18px;min-width:0}.comms-config-label{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.comms-config-value{font-size:1rem;font-weight:600;line-height:1.35;word-break:break-word}.messages-history-filters{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:8px}.messages-history-filters select{min-width:160px}.messages-history-hint{font-size:.85rem;margin:0 0 12px}.attendance-status-select{min-width:120px;padding:6px 8px;border-radius:6px;border:1px solid var(--border);background:var(--card);color:var(--text)}.attendance-status-select.status-absent{border-color:var(--danger);color:var(--danger)}.attendance-status-select.status-late{border-color:var(--warning, #f59e0b)}.finance-expenses-summary{display:flex;flex-wrap:wrap;gap:24px;padding:16px 18px;margin-bottom:16px}.finance-expenses-summary>div{display:flex;flex-direction:column;gap:4px}.finance-expenses-summary strong{font-size:1.25rem}.finance-expenses-modal{max-width:480px;width:100%}.finance-expenses-form{display:flex;flex-direction:column;gap:12px}.finance-msg.success{color:var(--primary);margin:0 0 12px}.finance-settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.finance-inline-form{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.finance-inline-form .field-input{flex:1 1 160px}.finance-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.finance-treasury-hint{margin-bottom:16px;font-size:.9rem;line-height:1.5}.data-table tr.muted-row{opacity:.65}@media print{.finance-reports-nav,.finance-reports-actions,.finance-main-tabs,.finance-page-header,.sidebar,.app-header{display:none!important}.finance-reports-layout{grid-template-columns:1fr}}.finance-student-cell{display:flex;align-items:center;gap:12px}.finance-avatar{width:36px;height:36px;border-radius:50%;background:var(--border);display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.finance-avatar.lg{width:48px;height:48px;font-size:.9rem}.finance-id{display:block;font-size:.75rem}.paid-cell.status-paid{color:var(--primary)}.paid-cell.status-partial{color:var(--warning)}.paid-cell.status-unpaid,.paid-cell.status-overdue{color:var(--danger)}.finance-bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 900px){.finance-bottom-grid{grid-template-columns:1fr}}.finance-methods-panel h3,.finance-recent-panel h3{margin:0 0 16px;font-size:1rem}.finance-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:4px}.finance-panel-head h3{margin:0}.finance-list-hint{margin:0 0 12px;font-size:.85rem}.finance-treasury-journal{margin-top:24px}.finance-treasury-journal-filters{margin-bottom:16px}.finance-method-bars{list-style:none;margin:0;padding:0}.finance-method-bars li{margin-bottom:14px}.finance-method-bar-head{display:flex;justify-content:space-between;font-size:.9rem;margin-bottom:6px}.finance-method-bar-track{height:8px;background:var(--bg);border-radius:4px;overflow:hidden}.finance-method-bar-fill{height:100%;border-radius:4px;background:var(--primary)}.finance-method-bar-fill.method-moncash{background:#22c55e}.finance-method-bar-fill.method-natcash{background:#3b82f6}.finance-method-bar-fill.method-cash{background:#f59e0b}.finance-method-bar-fill.method-stripe{background:#a855f7}.finance-recent-list{list-style:none;margin:0;padding:0}.finance-recent-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.finance-recent-item:last-child{border-bottom:none}.finance-recent-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.finance-recent-dot.paid{background:var(--primary)}.finance-recent-body{flex:1;min-width:0}.finance-recent-body strong{display:block;font-size:.9rem}.finance-recent-amount{color:var(--primary);font-size:.95rem}.finance-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}.finance-modal{background:var(--card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;padding:24px}.finance-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.finance-modal-header h2{margin:0;font-size:1.25rem}.finance-modal-close{background:none;border:none;color:var(--muted);font-size:1.5rem;cursor:pointer;line-height:1}.finance-modal-student{display:flex;align-items:center;gap:14px;padding:16px;background:var(--bg-elevated);border-radius:12px;margin-bottom:20px}.finance-modal-balance{margin-left:auto;text-align:right}.finance-modal-balance .balance-due{display:block;color:var(--danger);font-size:1.2rem}.finance-modal-form .field-block{margin-bottom:16px}.finance-amount-row{display:flex;gap:8px}.finance-amount-row .field-input{flex:1}.finance-method-fieldset{border:none;margin:0 0 16px;padding:0}.finance-method-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:8px}.finance-method-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;border:2px solid var(--border);border-radius:12px;background:var(--bg-elevated);color:var(--text);cursor:pointer;font-size:.85rem;font-weight:600}.finance-method-card.active{border-color:var(--primary);background:var(--primary-dim)}.finance-method-card.method-moncash.active{border-color:#22c55e}.finance-method-icon{font-size:1.4rem}.finance-modal-submit{width:100%;margin-top:8px;padding:14px;font-size:1rem}.dashboard-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}@media (max-width: 1100px){.dashboard-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 520px){.dashboard-kpi-grid{grid-template-columns:1fr}}.dashboard-kpi{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-sm)}.dashboard-kpi-label{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.dashboard-kpi-value{font-size:1.5rem;font-weight:700;line-height:1.2}.dashboard-kpi-hint{font-size:.8rem;color:var(--muted)}.dashboard-kpi-ok .dashboard-kpi-value{color:var(--primary)}.dashboard-kpi-warn .dashboard-kpi-value{color:var(--warning)}.dashboard-kpi-danger .dashboard-kpi-value{color:var(--danger)}.dashboard-alerts{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.dashboard-alerts-bottom{margin-bottom:0;margin-top:8px}.dashboard-alert{padding:10px 14px;border-radius:10px;font-size:.9rem;border:1px solid var(--border);background:var(--bg-elevated)}.dashboard-alert-warn{border-color:#f59e0b55;background:#f59e0b18}.dashboard-alert-info{border-color:#3b82f655;background:#3b82f618}.reports-hub-kpi-grid{margin-top:4px}.reports-hub-kpi-empty{margin:0 0 16px;font-size:.9rem}.reports-hub-section-title{margin:0 0 12px;font-size:.95rem;font-weight:700;color:var(--text)}.reports-hub-alerts{margin-bottom:20px}.reports-hub-trend{margin-bottom:20px;padding:16px 18px}.reports-hub-shortcuts{margin-bottom:24px}.reports-hub-shortcut-group{margin-bottom:18px}.reports-hub-shortcut-group-label{margin:0 0 8px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.reports-hub-shortcut-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media (max-width: 960px){.reports-hub-shortcut-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 520px){.reports-hub-shortcut-grid{grid-template-columns:1fr}}.reports-hub-shortcut-card{display:flex;flex-direction:column;gap:6px;padding:14px 16px;background:var(--card);border:1px solid var(--border);border-radius:12px;text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}.reports-hub-shortcut-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.reports-hub-shortcut-card strong{font-size:.95rem;color:var(--primary)}.reports-hub-shortcut-card span{font-size:.82rem;line-height:1.35}.reports-hub-exports{padding:16px 18px}.reports-hub-exports-hint{margin:0 0 12px;font-size:.85rem}.reports-hub-export-actions{display:flex;flex-wrap:wrap;gap:8px}.reports-hub-tabs{margin:20px 0 16px}.reports-hub-rankings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}@media (max-width: 640px){.reports-hub-rankings-grid{grid-template-columns:1fr}}.reports-hub-ranking{padding:14px 16px}.reports-hub-ranking-title{margin:0 0 10px;font-size:.85rem;font-weight:600}.reports-hub-ranking-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.reports-hub-ranking-list li{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:.88rem}.reports-hub-ranking-name{color:var(--text)}.reports-hub-ranking-rate{font-weight:700;font-variant-numeric:tabular-nums}.reports-hub-ranking-rate--top{color:var(--primary)}.reports-hub-ranking-rate--bottom{color:#dc2626}.reports-hub-pipeline{display:flex;align-items:center;flex-wrap:wrap;gap:12px}.reports-hub-pipeline-step{flex:1;min-width:100px;padding:12px 14px;border-radius:10px;background:var(--bg);border:1px solid var(--border);text-align:center}.reports-hub-pipeline-step strong{display:block;font-size:1.35rem;color:var(--text)}.reports-hub-pipeline-step span{font-size:.78rem;color:var(--muted)}.reports-hub-pipeline-step--warn strong{color:#d97706}.reports-hub-pipeline-step--ok strong{color:var(--primary)}.reports-hub-pipeline-arrow{color:var(--muted);font-size:1.1rem}.reports-hub-aging{display:flex;flex-direction:column;gap:10px}.reports-hub-aging-row{display:grid;grid-template-columns:88px 1fr auto;align-items:center;gap:10px;font-size:.85rem}.reports-hub-aging-label{color:var(--muted)}.reports-hub-aging-bar-wrap{height:8px;background:var(--bg);border-radius:4px;overflow:hidden}.reports-hub-aging-bar{height:100%;background:var(--primary);border-radius:4px;min-width:2px}.reports-hub-aging-meta{font-variant-numeric:tabular-nums;white-space:nowrap;font-size:.78rem;color:var(--muted)}.reports-hub-comms-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.reports-hub-comms-list li{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:.9rem}.reports-hub-comms-list li:last-child{border-bottom:none}.finance-reports-bar-fill--revenue{background:var(--primary)}.finance-reports-bar-fill--grades{background:#6366f1}.reports-advanced-toolbar-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px;justify-content:space-between}.reports-advanced-compare-hint{margin:12px 0 0;font-size:.85rem}.reports-advanced-table th,.reports-advanced-table td{font-size:.88rem}.reports-advanced-delta--ok{color:var(--primary);font-weight:600}.reports-advanced-delta--warn{color:#dc2626;font-weight:600}.reports-advanced-matrix-wrap{max-height:420px;overflow:auto}.reports-advanced-matrix th,.reports-advanced-matrix td{white-space:nowrap}.reports-advanced-last-sent{margin:10px 0 0;font-size:.82rem}.reports-advanced-msg{margin-top:12px;padding:10px 14px;border-radius:8px;background:var(--bg);border:1px solid var(--border);font-size:.9rem}.dashboard-charts-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:16px}.dashboard-charts-grid-top{margin-bottom:16px}.dashboard-charts-grid-top .dashboard-panel-performance,.dashboard-charts-grid-top .dashboard-panel-gender{min-width:0}.dashboard-charts-grid-top .performance-chart-wrap,.dashboard-charts-grid-top .donut-wrap{min-height:200px}.dashboard-charts-grid-top .donut-wrap{align-content:center}@media (max-width: 960px){.dashboard-charts-grid{grid-template-columns:1fr}}.dashboard-panel{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px 20px;box-shadow:var(--shadow-sm)}.dashboard-panel-compact{padding-bottom:14px}.dashboard-panel-header h3{margin:0 0 4px;font-size:1rem}.dashboard-panel-header .muted{margin:0 0 12px;font-size:.85rem}.dashboard-panel-link{display:inline-block;margin-top:12px;font-size:.85rem}.chart-tall{height:200px;margin-bottom:0}.chart-tall .bar-track{height:140px}.bar-rate{display:block;font-size:.65rem;color:var(--muted);margin-bottom:4px}.bar-fill-ok{background:var(--primary)}.bar-fill-warn{background:var(--warning)}.bar-fill-danger{background:var(--danger)}.performance-chart-wrap{margin-top:2px}.performance-chart-legend{display:flex;flex-wrap:wrap;gap:16px;list-style:none;margin:0 0 10px;padding:0;font-size:.85rem;color:var(--muted)}.performance-chart-legend li{display:flex;align-items:center;gap:6px}.performance-chart-legend .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.performance-chart{width:100%;height:200px;display:block}.perf-grid-line{stroke:var(--track);stroke-width:1}.perf-axis-label{fill:var(--muted);font-size:10px;font-family:Segoe UI,system-ui,sans-serif}.donut-wrap-compact{gap:12px}.donut-wrap-compact .donut-chart{width:88px;height:88px}.donut-wrap-compact .donut-hole{top:24%;right:24%;bottom:24%;left:24%;font-size:.65rem}.donut-wrap-compact .donut-hole strong{font-size:.95rem}.donut-wrap-compact .donut-legend{font-size:.78rem}.donut-wrap{display:flex;flex-wrap:wrap;align-items:center;gap:20px}.donut-chart{width:120px;height:120px;border-radius:50%;position:relative;flex-shrink:0}.donut-hole{position:absolute;top:22%;right:22%;bottom:22%;left:22%;border-radius:50%;background:var(--card);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.75rem;color:var(--muted)}.donut-hole strong{font-size:1.1rem;color:var(--text)}.donut-legend{list-style:none;margin:0;padding:0;font-size:.85rem}.donut-legend li{display:flex;align-items:center;gap:8px;margin-bottom:6px}.donut-legend .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.cycle-rate-list{display:flex;flex-direction:column;gap:12px}.cycle-rate-row{display:grid;grid-template-columns:90px 1fr auto auto;gap:10px;align-items:center;font-size:.85rem}.cycle-rate-bar{height:8px;background:var(--track);border-radius:4px;overflow:hidden}.cycle-rate-bar .bar-fill{height:100%;border-radius:4px}.hbar-list{display:flex;flex-direction:column;gap:10px}.hbar-row{display:grid;grid-template-columns:minmax(0,1fr) 2fr auto;gap:10px;align-items:center;font-size:.85rem}.hbar-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hbar-track{height:8px;background:var(--track);border-radius:4px;overflow:hidden}.hbar-fill{height:100%;background:var(--primary);border-radius:4px;min-width:2px}.hbar-fill-ok{background:var(--primary)}.hbar-fill-warn{background:var(--warning)}.hbar-fill-danger{background:var(--danger)}.hbar-fill-muted{background:var(--muted)}.hbar-value{font-weight:600;min-width:2.5rem;text-align:right}.staff-presence-stack{display:flex;flex-direction:column;gap:8px}.staff-presence-row{display:grid;grid-template-columns:90px 1fr auto;gap:10px;align-items:center;font-size:.85rem}.dashboard-dl{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 16px;margin:0 0 16px}.dashboard-dl dt{font-size:.78rem;color:var(--muted);margin-bottom:2px}.dashboard-dl dd{margin:0;font-weight:700;font-size:1.1rem}.dashboard-subtitle{margin:0 0 8px;font-size:.85rem;font-weight:600}.dashboard-channel-list{list-style:none;margin:0;padding:0;font-size:.85rem}.dashboard-channel-list li{padding:4px 0}.staff-att-page{max-width:100%}.staff-att-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px}.staff-att-breadcrumb{font-size:.85rem;margin:0 0 4px}.staff-att-title{margin:0;font-size:1.5rem}.staff-att-date{margin:4px 0 0;text-transform:capitalize}.staff-att-header-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.staff-att-kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:16px}@media (max-width: 1100px){.staff-att-kpi-grid{grid-template-columns:repeat(2,1fr)}}.staff-att-kpi{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:2px}.staff-att-kpi-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.staff-att-kpi-value{font-size:1.45rem;font-weight:700}.staff-att-kpi-pct{font-size:.9rem;font-weight:600;color:var(--muted)}.staff-att-kpi-ok .staff-att-kpi-value{color:var(--primary)}.staff-att-kpi-danger .staff-att-kpi-value{color:var(--danger)}.staff-att-kpi-warn .staff-att-kpi-value{color:var(--warning)}.staff-att-kpi-excused .staff-att-kpi-value{color:#a855f7}.staff-att-kpi-warn-text{font-size:.78rem;color:var(--danger)}.staff-att-alert{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;align-items:flex-start;padding:14px 16px;margin-bottom:16px;border-radius:10px;border:1px solid #ef444455;background:#ef444412}.staff-att-alert ul{margin:8px 0 0;padding-left:18px;font-size:.88rem}.staff-att-alert-actions{display:flex;gap:8px;flex-shrink:0}.staff-att-layout{display:grid;grid-template-columns:1fr;gap:0}.staff-att-layout-panel{grid-template-columns:1fr minmax(280px,340px);gap:16px;align-items:start}@media (max-width: 960px){.staff-att-layout-panel{grid-template-columns:1fr}}.staff-att-table-wrap{border-radius:12px;overflow:hidden}.staff-att-table tbody tr{cursor:pointer}.staff-att-row td:first-child{border-left:4px solid transparent}.staff-att-row-danger td:first-child{border-left-color:var(--danger)}.staff-att-row-warn td:first-child{border-left-color:var(--warning)}.staff-att-row-excused td:first-child{border-left-color:#a855f7}.staff-att-row-ok td:first-child{border-left-color:var(--primary)}.staff-att-row-selected{background:#22c55e10}.staff-att-teacher-cell{display:flex;align-items:center;gap:10px}.staff-att-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.staff-att-dot-present{background:var(--primary)}.staff-att-dot-absent{background:var(--danger)}.staff-att-dot-late{background:var(--warning)}.staff-att-dot-excused{background:#a855f7}.staff-att-sub{display:block;font-size:.78rem}.staff-att-courses-warn{color:var(--danger);font-weight:600}.staff-att-late{color:var(--warning);font-weight:600}.staff-att-impact{color:var(--danger);font-weight:600;font-size:.88rem}.staff-att-status-btns{display:flex;gap:4px}.staff-att-status-btn{padding:4px 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--muted);font-size:.72rem;font-weight:600;cursor:pointer}.staff-att-status-btn.active.staff-att-btn-present{background:#22c55e22;border-color:var(--primary);color:var(--primary)}.staff-att-status-btn.active.staff-att-btn-late{background:#f59e0b22;border-color:var(--warning);color:var(--warning)}.staff-att-status-btn.active.staff-att-btn-absent{background:#ef444422;border-color:var(--danger);color:var(--danger)}.staff-att-footnote{margin-top:10px;font-size:.8rem}.staff-att-panel{position:sticky;top:16px;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;max-height:calc(100vh - 48px);overflow-y:auto}.staff-att-panel-close{position:absolute;top:8px;right:10px;border:none;background:none;color:var(--muted);font-size:1.4rem;cursor:pointer}.staff-att-panel-head{display:flex;gap:12px;margin-bottom:16px;padding-right:24px}.staff-att-panel-head h2{margin:0;font-size:1.1rem}.staff-att-avatar{width:44px;height:44px;border-radius:10px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.staff-att-badge{display:inline-block;margin-top:6px;padding:2px 8px;border-radius:6px;font-size:.75rem;font-weight:600}.staff-att-badge-present{background:#22c55e22;color:var(--primary)}.staff-att-badge-absent{background:#ef444422;color:var(--danger)}.staff-att-badge-late{background:#f59e0b22;color:var(--warning)}.staff-att-badge-excused{background:#a855f722;color:#a855f7}.staff-att-panel-section{margin-bottom:16px}.staff-att-panel-section h3{margin:0 0 8px;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.staff-att-timeline{list-style:none;padding:0;border-left:2px solid var(--border);margin:0 0 0 8px}.staff-att-timeline li{display:flex;gap:10px;padding:8px 0 8px 12px;position:relative}.staff-att-timeline li:before{content:"";position:absolute;left:-5px;top:14px;width:8px;height:8px;border-radius:50%;background:var(--primary)}.staff-att-time{font-weight:700;font-size:.85rem;min-width:42px}.staff-att-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0}.staff-att-stats div{background:var(--bg-elevated);border-radius:8px;padding:8px 10px}.staff-att-stats dt{font-size:.72rem;color:var(--muted);margin:0}.staff-att-stats dd{margin:2px 0 0;font-weight:700}.staff-att-heatmap{display:flex;flex-wrap:wrap;gap:4px}.staff-att-heat{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.7rem;background:var(--bg-elevated);color:var(--muted)}.staff-att-heat-present{background:#166534;color:#fff}.staff-att-heat-absent{background:#991b1b;color:#fff}.staff-att-heat-late{background:#b45309;color:#fff}.staff-att-heat-excused{background:#6b21a8;color:#fff}.staff-att-replace-btn{display:block;text-align:center;margin-top:8px}.staff-att-panel-hint{font-size:.82rem;margin-top:8px}@media print{.sidebar,.topbar,.enrollment-top,.wizard-footer,.menu-toggle,.staff-att-panel,.staff-att-header-actions,.staff-att-status-btns,.timetable-tabs,.week-toolbar,.workload-section,.settings-hint,.finance-modal-backdrop{display:none!important}.id-card-preview{page-break-inside:avoid}#timetable-print-area{border:none;overflow:visible}.timetable-grid{min-width:0;width:100%;font-size:10pt}.slot-card--recess,.slot-card--lunch_break,.slot-card--special_activity{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.table-row-clickable{cursor:pointer}.table-row-clickable:hover td{background:#16a34a0d}.student-dossier{padding:0 16px 32px}.student-dossier-profile{display:flex;align-items:center;gap:16px;padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:16px}.student-dossier-avatar{width:56px;height:56px;border-radius:50%;background:#22c55e22;color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0}.student-dossier-name{margin:0 0 4px;font-size:1.25rem}.student-dossier-meta{margin:0}.student-dossier-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:16px;border-bottom:1px solid var(--border)}.student-dossier-tab{padding:10px 16px;border:none;background:transparent;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font:inherit}.student-dossier-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.student-dossier-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px}.student-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px}.student-summary-card{padding:16px;border:1px solid var(--border);border-radius:10px;background:var(--bg)}.student-metric{display:block;font-size:1.35rem;margin:6px 0 10px}.student-metric.tone-good{color:var(--primary)}.student-metric.tone-warn{color:var(--warning)}.student-metric.tone-bad{color:var(--danger)}.student-progress{height:6px;background:var(--border);border-radius:999px;overflow:hidden}.student-progress-fill{height:100%;border-radius:999px}.student-progress-fill.tone-good{background:var(--primary)}.student-progress-fill.tone-warn{background:var(--warning)}.student-progress-fill.tone-bad{background:var(--danger)}.student-contact-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px;border:1px solid var(--border);border-radius:10px;margin-bottom:16px}.student-quick-links{display:flex;flex-wrap:wrap;gap:8px}.student-period-field{margin-bottom:16px;max-width:280px}.student-grades-header{display:flex;flex-wrap:wrap;gap:24px 32px;margin-bottom:16px}.student-grades-stat{display:flex;flex-direction:column;gap:4px;min-width:88px}.student-grades-stat .muted{display:block}.student-grades-stat .student-metric{margin:0}.student-fee-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.student-subsection-title{margin:20px 0 12px;font-size:1rem}.student-balance-card{margin-bottom:16px}.student-finance-link{display:inline-block;margin-top:20px;text-decoration:none}.bulletin-config-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);gap:28px;align-items:start}@media (max-width: 1100px){.bulletin-config-layout{grid-template-columns:1fr}}.bulletin-config-form{min-width:0}.bulletin-config-readonly-hint{margin:0 0 16px}.bulletin-config-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 16px}.bulletin-config-fields .field-full{grid-column:1 / -1}@media (max-width: 640px){.bulletin-config-fields{grid-template-columns:1fr}}.bulletin-color-row{display:flex;align-items:center;gap:10px}.bulletin-color-swatch{width:42px;height:38px;padding:2px;border:1px solid var(--border);border-radius:8px;background:var(--surface, #fff);cursor:pointer}.bulletin-logo-section{margin-top:4px}.bulletin-logo-hint{margin:4px 0 12px;font-size:.85rem}.bulletin-logo-hint code{font-size:.8rem}.bulletin-logo-current{display:flex;align-items:center;gap:12px;margin-bottom:12px}.bulletin-logo-current img{width:56px;height:56px;object-fit:contain;border:1px solid var(--border);border-radius:8px;background:#fff;padding:4px}.bulletin-logo-current-name{font-size:.85rem;word-break:break-all}.bulletin-logo-upload-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}.bulletin-logo-file-input{display:none}.bulletin-logo-gallery{display:flex;flex-wrap:wrap;gap:8px}.bulletin-logo-thumb{width:56px;height:56px;padding:4px;border:2px solid var(--border);border-radius:8px;background:#fff;cursor:pointer}.bulletin-logo-thumb.active{border-color:var(--accent, #22c55e);box-shadow:0 0 0 1px var(--accent, #22c55e)}.bulletin-logo-thumb img{width:100%;height:100%;object-fit:contain}.bulletin-logo-thumb:disabled{cursor:default;opacity:.8}.bulletin-template-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}@media (max-width: 900px){.bulletin-template-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.bulletin-template-grid{grid-template-columns:1fr}}.bulletin-template-card .bulletin-template-persona{font-size:.75rem;color:var(--accent, #22c55e);font-weight:600}.bulletin-template-swatch[data-template=elegant]{background:linear-gradient(90deg,#92400e,#fef3c7)}.bulletin-template-swatch[data-template=compact]{background:linear-gradient(90deg,#475569,#f1f5f9)}.bulletin-preview-page--compact{padding:12px 10px;font-size:8px}.bulletin-preview-grades--compact{font-size:7px}.bulletin-preview-grades--dense{font-size:7px;margin:6px 0}.bulletin-preview-grades--dense th,.bulletin-preview-grades--dense td,.bulletin-preview-grades--compact th,.bulletin-preview-grades--compact td{padding:2px 4px}.bulletin-preview-compact-strip{display:flex;flex-wrap:wrap;justify-content:space-around;gap:4px;padding:6px;margin:8px 0;border:1px solid;background:#f1f5f9;font-weight:700;font-size:7px}.bulletin-preview-compact-top{display:grid;grid-template-columns:36px 1fr auto;gap:8px;align-items:center;border-bottom:2px solid;padding-bottom:6px;margin-bottom:6px}.bulletin-preview-compact-meta{text-align:right;font-size:7px;color:#64748b}.bulletin-preview-compact-student{margin:0 0 8px;font-size:8px}.bulletin-preview-logo--tiny{max-width:28px;max-height:28px}.bulletin-preview-logo--elegant{max-width:40px;max-height:40px}.bulletin-preview-logo-placeholder.bulletin-preview-logo--elegant{width:40px;height:40px;font-size:7px}.bulletin-preview-elegant-top{display:grid;grid-template-columns:48px 1fr;gap:12px;align-items:center}.bulletin-preview-elegant-top--symmetric{grid-template-columns:1fr auto 1fr;gap:8px}.bulletin-preview-elegant-top--symmetric>:first-child,.bulletin-preview-elegant-top--symmetric>:last-child{justify-self:center}.bulletin-preview-elegant-center{text-align:center}.bulletin-preview-elegant-center .bulletin-preview-school{margin:0 0 4px}.bulletin-preview-elegant-center .bulletin-preview-subtitle,.bulletin-preview-elegant-center .bulletin-preview-flag{margin:0 0 2px;text-align:center}.bulletin-preview-elegant-rules{margin:4px 0 8px}.bulletin-preview-elegant-rule{height:1px;width:100%}.bulletin-preview-elegant-period{text-align:center;font-weight:700;font-size:9px;margin:8px 0}.bulletin-preview-elegant-pupil{width:100%;border-collapse:collapse;font-size:8px;margin-bottom:10px}.bulletin-preview-elegant-pupil th,.bulletin-preview-elegant-pupil td{border:1px solid #e2e8f0;padding:4px 8px}.bulletin-preview-elegant-pupil th{background:#f8fafc;width:28%;text-align:left}.bulletin-preview-summary--elegant th{background:#f8fafc;font-size:7px;color:#64748b;font-weight:600}.bulletin-preview-summary--elegant td{font-weight:700;font-size:9px}.bulletin-preview-elegant-summary{margin:6px 0 0}.bulletin-preview-elegant-signatures{margin-top:32px}.bulletin-preview-elegant-signatures .bulletin-preview-signatures--quad{margin:0}.bulletin-preview-elegant-absences-row td{text-align:right}.bulletin-preview-signatures--two{grid-template-columns:1fr 1fr}.bulletin-template-card{display:flex;flex-direction:column;align-items:flex-start;gap:6px;text-align:left;padding:14px;border:2px solid var(--border);border-radius:12px;background:var(--surface-elevated, var(--card));cursor:pointer;transition:border-color .15s,box-shadow .15s}.bulletin-template-card:hover:not(:disabled){border-color:var(--accent, #22c55e)}.bulletin-template-card.active{border-color:var(--accent, #22c55e);box-shadow:0 0 0 1px var(--accent, #22c55e)}.bulletin-template-card:disabled{opacity:.7;cursor:default}.bulletin-template-swatch{display:block;width:100%;height:28px;border-radius:6px;margin-bottom:4px}.bulletin-template-swatch[data-template=moderne]{background:linear-gradient(90deg,#2563eb,#eff6ff)}.bulletin-template-swatch[data-template=professionnel]{background:linear-gradient(90deg,#111,#f5f5f5)}.bulletin-toggle-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 16px;margin-bottom:16px}@media (max-width: 640px){.bulletin-toggle-grid{grid-template-columns:1fr}}.bulletin-toggle-item{margin-bottom:8px}.bulletin-config-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.bulletin-config-preview-panel{position:sticky;top:16px;min-width:0}.bulletin-config-preview-header h3{margin:0 0 4px}.bulletin-config-preview-header{margin-bottom:12px}.bulletin-preview-shell{background:#e5e7eb;border-radius:12px;padding:16px;overflow:auto;max-height:calc(100vh - 120px)}.bulletin-preview-template-badge{margin:0 0 10px;font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.bulletin-preview-page{background:#fff;color:#111;font-family:Helvetica,Arial,sans-serif;font-size:9px;line-height:1.35;padding:18px 16px;min-height:420px;box-shadow:0 4px 24px #0000001f;border-radius:4px}.bulletin-preview-page[data-template=elegant],.bulletin-preview-page--elegant{display:flex;flex-direction:column;width:100%;max-width:420px;min-height:594px;aspect-ratio:210 / 297;padding:14px 12px;margin:0 auto}.bulletin-preview-band{height:6px;margin:-18px -16px 12px;border-radius:4px 4px 0 0}.bulletin-preview-flag{margin:0 0 4px;font-size:7px;color:#64748b}.bulletin-preview-flag--center{text-align:center}.bulletin-preview-flag--right{text-align:right}.bulletin-preview-school{margin:0 0 4px;font-size:13px;font-weight:700}.bulletin-preview-school--center{text-align:center}.bulletin-preview-school--upper{text-transform:uppercase;text-align:center;letter-spacing:.04em}.bulletin-preview-subtitle{margin:0 0 6px;font-size:8px;color:#64748b}.bulletin-preview-subtitle--center{text-align:center}.bulletin-preview-contact{margin:0 0 8px;font-size:7px;color:#94a3b8}.bulletin-preview-title{margin:8px 0 4px;font-size:9px;font-weight:600}.bulletin-preview-student{margin:0 0 10px;font-size:8px}.bulletin-preview-student--center{text-align:center}.bulletin-preview-logo{max-width:48px;max-height:48px;object-fit:contain}.bulletin-preview-classique-banner{text-align:center;color:#fff;font-weight:700;font-size:10px;padding:8px;margin:10px 0;border-radius:2px}.bulletin-preview-logo--left{display:block;margin:0 0 8px}.bulletin-preview-logo--right{display:block;margin:0 0 8px auto}.bulletin-preview-logo--center{display:block;margin:0 auto 8px}.bulletin-preview-logo-placeholder.bulletin-preview-logo--right{margin-left:auto}.bulletin-preview-logo-placeholder.bulletin-preview-logo--center{margin-left:auto;margin-right:auto}.bulletin-preview-logo--small{max-width:40px;max-height:40px}.bulletin-preview-logo-placeholder{width:40px;height:40px;border:1px dashed #cbd5e1;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:7px;color:#94a3b8;margin-bottom:6px}.bulletin-preview-line{height:2px;width:35%;margin:6px auto 8px}.bulletin-preview-banner{text-align:center;font-weight:600;font-size:9px;padding:8px;background:#eff6ff;border:1px solid;border-radius:4px;margin-bottom:8px}.bulletin-preview-pro-box{border:1.5px solid #111;padding:10px;margin-bottom:8px}.bulletin-preview-pro-box-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px}.bulletin-preview-pro-box-inner--logo-left{grid-template-columns:auto 1fr}.bulletin-preview-pro-box-inner--logo-right{grid-template-columns:1fr auto}.bulletin-preview-pro-box-inner--logo-center{grid-template-columns:1fr}.bulletin-preview-pro-center{text-align:center}.bulletin-preview-logo--pro{max-width:44px;max-height:44px;object-fit:contain}.bulletin-preview-logo-placeholder.bulletin-preview-logo--pro{width:44px;height:44px;font-size:7px}.bulletin-preview-pro-banner{margin:4px 0 0;font-weight:700;font-size:9px}.bulletin-preview-inst-grid{display:grid;grid-template-columns:56px 1fr;gap:10px;align-items:center}.bulletin-preview-inst-bar{height:3px;margin:8px 0}.bulletin-preview-grades{width:100%;border-collapse:collapse;margin:8px 0;font-size:8px}.bulletin-preview-grades th,.bulletin-preview-grades td{border:.5px solid #d1d5db;padding:4px 6px}.bulletin-preview-grades th{font-weight:700}.bulletin-preview-grades .num{text-align:right}.bulletin-preview-category td,.bulletin-preview-total td{background:#e8e8e8;font-weight:700}.bulletin-preview-grades tbody tr:nth-child(2n):not(.bulletin-preview-category):not(.bulletin-preview-total){background:#f5f5f5}.bulletin-preview-summary{width:100%;border-collapse:collapse;margin:10px 0;font-size:8px}.bulletin-preview-summary th,.bulletin-preview-summary td{border:.5px solid #d1d5db;padding:5px 8px}.bulletin-preview-summary--elegant{width:100%;table-layout:fixed}.bulletin-preview-summary--elegant th,.bulletin-preview-summary--elegant td{width:25%}.bulletin-preview-summary th{text-align:left;width:42%;font-weight:600}.bulletin-preview-summary td.num{text-align:right}.bulletin-preview-signatures--three{grid-template-columns:1fr 1fr 1fr}.bulletin-preview-cards{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}.bulletin-preview-card{flex:1 1 70px;min-width:70px;border:1px solid;border-radius:6px;padding:8px 6px;text-align:center;background:#fff}.bulletin-preview-card-value{font-size:11px;font-weight:700}.bulletin-preview-card-label{font-size:7px;color:#64748b;margin-top:2px}.bulletin-preview-qr{display:flex;align-items:center;gap:8px;margin:12px 0 8px}.bulletin-preview-qr-box{width:36px;height:36px;border:1px solid #111;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700}.bulletin-preview-qr-label{font-size:7px;color:#64748b}.bulletin-preview-signatures--quad{display:grid;grid-template-columns:repeat(4,1fr);row-gap:8px;margin:36px 0 8px}.bulletin-preview-signatures--quad .bulletin-preview-sig-line:nth-child(1){grid-column:1 / 3}.bulletin-preview-signatures--quad .bulletin-preview-sig-line:nth-child(2){grid-column:3 / 5}.bulletin-preview-signatures--quad span{text-align:center;font-size:8px;font-weight:700}.bulletin-preview-signatures--quad span:nth-child(3){grid-column:1 / 3}.bulletin-preview-signatures--quad span:nth-child(4){grid-column:3 / 5}.bulletin-preview-signatures{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:14px 0 8px}.bulletin-preview-sig-block{text-align:center}.bulletin-preview-sig-line{display:block;width:100%;min-height:28px;border-bottom:1px solid #111}.bulletin-preview-sig-block span{display:block;margin-top:8px;font-size:8px;font-weight:700}.bulletin-preview-footer{margin-top:10px;padding-top:8px;border-top:.5px solid #e5e7eb;font-size:7px;color:#64748b;text-align:center}.bulletin-preview-page--elegant .bulletin-preview-footer{margin-top:auto;padding-top:8px;padding-bottom:2px;border-top:none}.bulletin-preview-page--elegant .bulletin-preview-edukasyon{margin:2px 0 0;color:#888}.bulletin-preview-edukasyon{margin:4px 0 0}.grades-bulletin-blockers{margin:0 0 16px;padding:12px 14px;border:1px solid #f59e0b;border-radius:10px;background:#f59e0b14}.grades-bulletin-blockers-title{margin:0 0 8px;font-weight:600}.grades-bulletin-blocker-reason{margin:0 0 6px}.grades-bulletin-pending-list{margin:8px 0 0;padding-left:1.2rem;font-size:.9rem}.grades-bulletin-pending-list li{margin-bottom:4px}.audit-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.audit-filters label{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem}.audit-table .audit-detail{max-width:280px;word-break:break-word}.audit-entity-id{font-size:.8rem}
