:root{color-scheme:light;--bg: #f5fbff;--surface: #ffffff;--surface-soft: #e0f2fe;--primary: #0284c7;--primary-2: #0ea5e9;--primary-dark: #075985;--text: #0f172a;--muted: #64748b;--line: #dbeafe;--success: #16a34a;--success-soft: #dcfce7;--warning: #f97316;--warning-soft: #ffedd5;--danger: #e11d48;--danger-soft: #ffe4e6;--purple: #7c3aed;--purple-soft: #ede9fe;--shadow: 0 18px 48px rgba(14, 116, 144, .12);--shadow-soft: 0 10px 28px rgba(15, 23, 42, .08);--radius: 8px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;letter-spacing:0;color:var(--text);background:var(--bg)}*{box-sizing:border-box}html{min-height:100%;background:var(--bg)}body{min-height:100vh;margin:0;background:radial-gradient(circle at top left,rgba(56,189,248,.18),transparent 30rem),linear-gradient(180deg,#f8fdff,#eff8ff)}button,input,select,textarea{font:inherit;letter-spacing:0}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.68}a{color:inherit;text-decoration:none}p,h1,h2,h3{margin:0}h1,h2,h3{line-height:1.15}small{color:var(--muted)}textarea{min-height:96px;resize:vertical}input,select,textarea{width:100%;min-height:44px;border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;color:var(--text);background:#fff;outline:none;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}input:focus,select:focus,textarea:focus{border-color:var(--primary-2);box-shadow:0 0 0 4px #0ea5e924}.hidden-input{display:none}.full-page-loader,.login-page{display:grid;min-height:100vh;place-items:center;padding:24px}.full-page-loader{gap:14px;color:var(--muted)}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-mark{display:inline-grid;width:46px;height:46px;place-items:center;border-radius:14px;color:#fff;font-weight:900;background:linear-gradient(135deg,var(--primary),#22c55e);box-shadow:0 14px 34px #0284c747}.login-card{width:min(100%,430px);padding:22px;border:1px solid rgba(219,234,254,.9);border-radius:var(--radius);background:#fffffff0;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}.login-brand p,.mobile-topbar p,.admin-topbar p,.page-title-row p,.page-hero p,.section-heading p,.eyebrow{color:var(--muted);font-size:.78rem;font-weight:700;text-transform:uppercase}.login-brand h1{font-size:1.05rem}.login-copy{margin-bottom:22px}.login-copy h2{margin-bottom:6px;font-size:1.75rem}.login-copy p,.login-note,.muted{color:var(--muted)}.login-form{display:grid;gap:14px}.field{position:relative;display:grid;gap:7px;color:var(--text);font-weight:700}.field span,.checkbox-panel>span{font-size:.86rem}.field small{font-weight:500}.field.has-icon svg{position:absolute;left:12px;bottom:13px;color:var(--muted)}.field.has-icon input{padding-left:40px}.input-action{position:absolute;right:8px;bottom:6px;display:grid;width:34px;height:34px;place-items:center;border:0;border-radius:var(--radius);color:var(--muted);background:transparent}.login-note{margin-top:18px;font-size:.86rem;text-align:center}.btn,.icon-button{min-height:44px;border:0;border-radius:var(--radius);font-weight:800;transition:transform .14s ease,box-shadow .14s ease,background .14s ease}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;white-space:nowrap}.btn:active,.icon-button:active,.pressable:active{transform:scale(.98)}.btn-primary{color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-2));box-shadow:0 12px 26px #0ea5e93d}.btn-ghost{color:var(--primary-dark);background:#e0f2fe}.btn-danger{color:#fff;background:var(--danger)}.btn-small{min-height:34px;padding:6px 10px;font-size:.82rem}.btn-wide{width:100%}.icon-button{display:inline-grid;width:44px;place-items:center;color:var(--primary-dark);background:#e0f2fe}.icon-button.danger,.danger{color:var(--danger)}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.55);border-top-color:#fff;border-radius:999px;animation:spin .75s linear infinite}.app-shell,.admin-shell{min-height:100vh}.mobile-topbar,.admin-topbar{position:sticky;z-index:20;top:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:calc(env(safe-area-inset-top) + 12px) 16px 12px;border-bottom:1px solid rgba(219,234,254,.75);background:#f5fbffdb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.mobile-topbar h1,.admin-topbar h1{font-size:1rem}.view-switch-btn{min-height:38px;padding-inline:12px;font-size:.82rem}.content-page{width:min(1180px,100%);margin:0 auto;padding:16px}.user-content{padding-bottom:calc(94px + env(safe-area-inset-bottom))}.bottom-nav{position:fixed;z-index:30;right:12px;bottom:calc(10px + env(safe-area-inset-bottom));left:12px;display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:8px;border:1px solid rgba(219,234,254,.95);border-radius:18px;background:#ffffffeb;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.bottom-nav a{display:grid;min-height:52px;place-items:center;gap:2px;border-radius:var(--radius);color:var(--muted);font-size:.74rem;font-weight:800}.bottom-nav a.active{color:var(--primary-dark);background:#e0f2fe}.nav-icon-wrap{position:relative;display:inline-grid;place-items:center}.nav-badge{position:absolute;top:-10px;right:-14px;display:grid;min-width:20px;height:20px;place-items:center;border:2px solid #fff;border-radius:999px;padding:0 5px;color:#fff;font-size:.66rem;font-weight:950;line-height:1;background:var(--danger);box-shadow:0 8px 18px #e11d4859}.page-hero,.page-title-row{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}.page-hero.compact{display:block;padding:18px;border-radius:var(--radius);color:#fff;background:linear-gradient(135deg,var(--primary-dark),var(--primary-2));box-shadow:var(--shadow-soft)}.page-hero h2,.page-title-row h2{margin-top:4px;font-size:clamp(1.38rem,4vw,2rem)}.page-hero.compact p{color:#ffffffc7}.stack,.routine-list,.manager-grid,.mobile-card-list,.settings-grid{display:grid;gap:12px}.card{border:1px solid rgba(219,234,254,.88);border-radius:var(--radius);background:#fffffff5;box-shadow:var(--shadow-soft)}.routine-card,.pending-card,.manager-card,.profile-card,.settings-card,.dashboard-chart,.report-banner{padding:16px}.routine-card{display:grid;gap:14px}.routine-card-top,.routine-footer,.manager-card,.pending-card,.section-heading,.brand-row,.card-actions,.toolbar-actions,.link-row,.chip-row{display:flex;align-items:center;gap:10px}.routine-card-top,.routine-footer,.pending-card,.manager-card,.section-heading,.brand-row{justify-content:space-between}.routine-card h2{font-size:2rem}.routine-main{display:grid;gap:6px;color:var(--muted)}.routine-main h3,.manager-card h3,.pending-card h3{color:var(--text)}.subject-line{color:var(--primary-dark);font-weight:800}.card-menu-wrap{position:relative}.card-menu{position:absolute;z-index:8;top:48px;right:0;display:grid;width:min(280px,80vw);overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow)}.card-menu button{min-height:44px;border:0;border-bottom:1px solid var(--line);padding:10px 12px;color:var(--text);background:#fff;text-align:left}.card-menu button:hover{background:#f0f9ff}.search-bar{position:sticky;z-index:10;top:76px;display:flex;align-items:center;gap:8px;min-height:54px;margin-bottom:14px;padding:0 12px;border:1px solid var(--line);border-radius:var(--radius);background:#fffffff2;box-shadow:var(--shadow-soft)}.search-bar input{min-height:50px;border:0;padding:0;box-shadow:none;background:transparent}.search-bar input:focus{box-shadow:none}.search-bar button{display:grid;width:32px;height:32px;place-items:center;border:0;border-radius:var(--radius);color:var(--muted);background:#eff6ff}.status-chip{display:inline-flex;align-items:center;min-height:28px;border-radius:999px;padding:5px 10px;font-size:.78rem;font-weight:900;white-space:nowrap}.status-success{color:#166534;background:var(--success-soft)}.status-warning{color:#9a3412;background:var(--warning-soft)}.status-danger{color:#9f1239;background:var(--danger-soft)}.status-purple{color:#5b21b6;background:var(--purple-soft)}.status-info,.status-neutral{color:var(--primary-dark);background:#e0f2fe}.routine-board-legend{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 12px}.routine-board-legend span{display:inline-flex;align-items:center;gap:7px;min-height:34px;border:1px solid var(--line);border-radius:999px;padding:6px 10px;color:var(--muted);font-size:.78rem;font-weight:900;background:#ffffffe6}.legend-dot{width:11px;height:11px;border-radius:999px}.routine-board{overflow:hidden;border:1px solid rgba(219,234,254,.95);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-soft)}.routine-board-tools{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-bottom:1px solid var(--line);color:var(--muted);font-size:.76rem;font-weight:900;background:#f8fdff}.routine-board-tools>div{display:flex;gap:6px}.routine-board-tools .icon-button{width:34px;height:34px}.routine-board-scroll{overflow:auto;-webkit-overflow-scrolling:touch}.routine-board-mobile{display:none}.routine-board-mobile-card{overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-soft)}.routine-board-mobile-card header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 10px;color:var(--primary-dark);background:#dff3ff}.routine-board-mobile-card header strong{min-width:0;overflow:hidden;font-size:.88rem;text-overflow:ellipsis;white-space:nowrap}.routine-board-mobile-card header span{flex:0 0 auto;color:var(--muted);font-size:.72rem;font-weight:950}.routine-board-mobile-slots{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;padding:8px}.routine-board-mobile-slot{display:grid;min-width:0;gap:5px}.routine-board-mobile-slot p{overflow:hidden;color:var(--primary-dark);font-size:.65rem;font-weight:950;line-height:1.1;text-align:center;text-overflow:ellipsis;white-space:nowrap}.routine-board-grid{display:grid;min-width:720px}.routine-board-row-fragment{display:contents}.routine-board-head,.routine-board-row-title,.routine-board-cell-wrap{min-height:74px;border-right:1px solid #bfdbfe;border-bottom:1px solid #bfdbfe;padding:8px}.routine-board-head{position:sticky;z-index:4;top:0;display:flex;align-items:center;justify-content:center;gap:6px;color:var(--primary-dark);font-size:.78rem;font-weight:950;text-align:center;background:#dff3ff}.routine-board-corner,.routine-board-row-title{position:sticky;left:0;z-index:5}.routine-board-corner{z-index:7}.routine-board-row-title{display:grid;align-content:center;gap:4px;background:#f8fdff}.routine-board-row-title strong{font-size:.9rem}.routine-board-row-title span{color:var(--muted);font-size:.76rem;font-weight:900}.routine-board-cell-wrap{display:grid;gap:6px;align-content:stretch;background:#fff}.routine-board-cell{display:grid;width:100%;min-height:70px;border:1px solid transparent;border-radius:var(--radius);padding:9px;text-align:left;box-shadow:0 8px 18px #0f172a0f;transition:transform .16s ease,box-shadow .16s ease}.routine-board-cell:active{transform:scale(.98)}.routine-board-cell strong{overflow-wrap:anywhere;color:var(--text);font-size:.88rem}.routine-board-cell span{overflow-wrap:anywhere;color:#0f172aad;font-size:.74rem;font-weight:800}.routine-board-cell em{align-self:end;justify-self:start;border-radius:999px;margin-top:5px;padding:3px 8px;font-size:.68rem;font-style:normal;font-weight:950;background:#ffffff9e}.routine-board-blank{display:grid;min-height:70px;place-items:center;border-radius:var(--radius);color:#94a3b8;background:#f8fafc}.board-empty{color:#9f1239;background:#fecdd3;border-color:#fb7185}.board-pending{color:#854d0e;background:#fef08a;border-color:#facc15}.board-complete{color:#14532d;background:#bbf7d0;border-color:#22c55e}.board-suspended{color:#075985;background:#bae6fd;border-color:#38bdf8}.routine-board-compact .routine-board-grid{min-width:660px}.routine-board-stats{margin-top:4px}@media (max-width: 720px){.routine-board-legend{gap:6px}.routine-board-legend span{min-height:28px;padding:4px 7px;font-size:.65rem}.legend-dot{width:9px;height:9px}.routine-board{margin-inline:-8px;overflow:visible;border:0;border-radius:0;background:transparent;box-shadow:none}.routine-board-tools,.routine-board-scroll{display:none}.routine-board-mobile{display:grid;gap:10px}.routine-board-grid,.routine-board-compact .routine-board-grid{min-width:0;width:100%;grid-template-columns:minmax(calc(68px * var(--board-zoom)),.72fr) repeat(var(--slot-count),minmax(0,1fr))!important}.routine-board-head,.routine-board-row-title,.routine-board-cell-wrap{min-height:calc(62px * var(--board-zoom));padding:calc(4px * var(--board-zoom))}.routine-board-head{flex-direction:column;gap:2px;font-size:calc(.55rem * var(--board-zoom));line-height:1.12;word-break:break-word}.routine-board-head svg{width:calc(11px * var(--board-zoom));height:calc(11px * var(--board-zoom))}.routine-board-row-title{gap:2px;white-space:normal}.routine-board-row-title strong{display:-webkit-box;overflow:hidden;font-size:calc(.62rem * var(--board-zoom));line-height:1.08;-webkit-box-orient:vertical;-webkit-line-clamp:2}.routine-board-row-title span{overflow:hidden;font-size:calc(.55rem * var(--board-zoom));text-overflow:ellipsis;white-space:nowrap}.routine-board-cell-wrap{gap:3px}.routine-board-cell,.routine-board-blank{min-height:calc(54px * var(--board-zoom));border-radius:6px;padding:calc(5px * var(--board-zoom))}.routine-board-cell strong{display:-webkit-box;overflow:hidden;font-size:calc(.62rem * var(--board-zoom));line-height:1.05;-webkit-box-orient:vertical;-webkit-line-clamp:2}.routine-board-cell span{overflow:hidden;font-size:calc(.52rem * var(--board-zoom));text-overflow:ellipsis;white-space:nowrap}.routine-board-cell em{margin-top:3px;padding:2px 4px;font-size:calc(.48rem * var(--board-zoom));line-height:1}.routine-board-tools{padding:6px 8px}.routine-board-tools .icon-button{width:30px;height:30px;min-height:30px}}@media (max-width: 380px){.routine-board-mobile-slots{grid-template-columns:1fr}}.empty-state{display:grid;place-items:center;gap:8px;min-height:230px;padding:28px;border:1px dashed #bae6fd;border-radius:var(--radius);color:var(--muted);text-align:center;background:#ffffffb8}.empty-icon{display:grid;width:58px;height:58px;place-items:center;border-radius:18px;font-size:1.8rem;background:#e0f2fe}.skeleton-card{display:grid;gap:12px;padding:16px}.skeleton-line{display:block;height:14px;border-radius:999px;background:linear-gradient(90deg,#e0f2fe,#f8fafc,#e0f2fe);background-size:220% 100%;animation:shimmer 1.2s linear infinite}.w-40{width:40%}.w-55{width:55%}.w-70{width:70%}.w-90{width:90%}@keyframes shimmer{to{background-position:-220% 0}}.modal-backdrop,.drawer-layer{position:fixed;z-index:100;top:0;right:0;bottom:0;left:0;display:grid;padding:14px;background:#0f172a57;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-backdrop{align-items:end}.modal{width:min(100%,560px);max-height:min(86vh,760px);overflow:auto;margin:0 auto;border-radius:18px 18px 10px 10px;background:#fff;box-shadow:var(--shadow)}.modal-sm{width:min(100%,420px)}.modal-lg{width:min(100%,860px)}.modal-header{position:sticky;z-index:4;top:0;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px;border-bottom:1px solid var(--line);background:#fffffff5}.modal-header h2{font-size:1.2rem}.modal-header p{margin-top:4px;color:var(--muted)}.modal-body{padding:16px}.form-grid{display:grid;gap:14px}.form-grid.two{grid-template-columns:1fr}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}.selected-routine{display:grid;gap:4px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:#f0f9ff}.selected-routine span{color:var(--muted)}.checkbox-panel{display:grid;gap:9px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:#f8fdff}.checkbox-panel label,.toggle-row,.optional-out-toggle{display:flex;align-items:center;min-height:34px;gap:9px;color:var(--muted);font-weight:700}.checkbox-panel input,.toggle-row input,.optional-out-toggle input{width:18px;min-height:18px}.select-all-row{border-bottom:1px solid var(--line);padding-bottom:8px;color:var(--primary-dark)!important}.optional-out-toggle{min-height:46px;border:1px dashed #cbd5e1;border-radius:var(--radius);padding:10px 12px;color:var(--muted);background:#f8fafc}.toggle-row{justify-content:space-between;padding:12px;border:1px solid var(--line);border-radius:var(--radius);color:var(--text);background:#fff}.toast-stack{position:fixed;z-index:200;right:14px;bottom:calc(84px + env(safe-area-inset-bottom));left:14px;display:grid;gap:10px;pointer-events:none}.toast{display:flex;align-items:center;gap:9px;min-height:48px;padding:12px 14px;border-radius:var(--radius);color:#fff;font-weight:800;box-shadow:var(--shadow)}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-warning{background:var(--warning)}.toast-info{background:var(--primary)}.admin-shell{display:block}.desktop-sidebar{display:none}.admin-topbar{justify-content:flex-start}.admin-content{padding-bottom:32px}.drawer-layer{justify-content:start;padding:0}.drawer-panel{position:relative;width:min(310px,88vw);min-height:100vh;background:#fff;box-shadow:var(--shadow)}.drawer-close{position:absolute;z-index:2;top:12px;right:12px}.admin-sidebar{display:flex;min-height:100%;flex-direction:column;gap:18px;padding:18px}.brand-row{justify-content:flex-start}.brand-row div:last-child{display:grid}.brand-row span{color:var(--muted);font-size:.82rem}.side-nav{display:grid;gap:8px}.side-nav a{display:flex;align-items:center;gap:10px;min-height:46px;padding:10px 12px;border-radius:var(--radius);color:var(--muted);font-weight:800}.side-nav a.active,.side-nav a:hover{color:var(--primary-dark);background:#e0f2fe}.sidebar-logout{margin-top:auto}.page-title-row{flex-wrap:wrap}.page-title-row.sub{margin-top:24px}.toolbar-actions,.filters-row{flex-wrap:wrap}.filters-row{display:flex;gap:10px;margin-bottom:14px}.filters-row>*{flex:1 1 150px}.segmented{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:12px;padding:6px;border-radius:var(--radius);background:#e0f2fe}.segmented.two{grid-template-columns:repeat(2,1fr)}.segmented button{min-height:40px;border:0;border-radius:var(--radius);color:var(--primary-dark);font-weight:900;background:transparent}.segmented button.active{background:#fff;box-shadow:var(--shadow-soft)}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:14px}.stat-card{display:flex;align-items:center;gap:12px;min-height:96px;padding:14px;border:1px solid rgba(219,234,254,.88);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-soft)}.metric-load-card{display:grid;gap:8px}.metric-load-card .stat-card{margin:0}.stat-card p{color:var(--muted);font-size:.78rem;font-weight:800}.stat-card strong{display:block;margin-top:4px;font-size:1.55rem}.stat-icon{display:grid;width:42px;height:42px;flex:0 0 auto;place-items:center;border-radius:var(--radius);color:var(--primary-dark);background:#e0f2fe}.stat-green .stat-icon{color:#166534;background:var(--success-soft)}.stat-orange .stat-icon{color:#9a3412;background:var(--warning-soft)}.stat-red .stat-icon{color:#9f1239;background:var(--danger-soft)}.stat-purple .stat-icon{color:#5b21b6;background:var(--purple-soft)}.progress-list{display:grid;gap:14px;margin-top:16px}.progress-row{display:grid;grid-template-columns:1fr auto;gap:8px;color:var(--muted);font-weight:800}.progress-track{grid-column:1 / -1;height:10px;overflow:hidden;border-radius:999px;background:#e2e8f0}.progress-fill{height:100%;border-radius:inherit;background:var(--primary-2)}.fill-orange{background:var(--warning)}.fill-red{background:var(--danger)}.manager-card{align-items:flex-start}.manager-card>div:nth-child(2){flex:1}.subject-dot,.avatar-small,.avatar-large{display:grid;place-items:center;flex:0 0 auto;color:#fff;font-weight:900}.subject-dot,.avatar-small{width:42px;height:42px;border-radius:var(--radius)}.avatar-small{color:var(--primary-dark);background:#e0f2fe}.profile-card{display:grid;place-items:center;gap:12px;text-align:center}.avatar-large{width:80px;height:80px;border-radius:24px;background:linear-gradient(135deg,var(--primary),#22c55e)}.profile-list{display:grid;width:100%;gap:10px;margin:10px 0}.profile-list span{display:flex;align-items:center;gap:8px;min-height:42px;padding:10px;border-radius:var(--radius);color:var(--muted);background:#f0f9ff}.table-shell{width:100%;overflow:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-soft)}.desktop-table{display:none}.data-table{width:100%;min-width:980px;border-collapse:collapse}.data-table th,.data-table td{border-bottom:1px solid var(--line);padding:10px;text-align:left;vertical-align:top}.data-table th{position:sticky;z-index:3;top:0;color:var(--primary-dark);font-size:.78rem;text-transform:uppercase;background:#e0f2fe}.data-table td{color:var(--muted);font-size:.88rem}.editable-table input,.editable-table select{min-width:124px;min-height:38px;padding:7px 8px;font-size:.84rem}.editable-table th,.editable-table td{vertical-align:middle}.editable-table th:first-child,.editable-table td:first-child{width:34px;min-width:34px;color:var(--muted)}.editable-table th:nth-child(2),.editable-table td:nth-child(2){min-width:180px}.editable-table th:nth-child(8),.editable-table td:nth-child(8),.editable-table th:nth-child(9),.editable-table td:nth-child(9){min-width:132px}.table-actions{min-width:190px}.routine-table-actions,.compact-actions{display:flex;align-items:center;gap:8px}.autosave-pill{display:inline-flex;align-items:center;justify-content:center;min-height:30px;min-width:72px;border-radius:999px;padding:5px 9px;font-size:.72rem;font-weight:900}.autosave-saved{color:#166534;background:var(--success-soft)}.autosave-saving{color:var(--primary-dark);background:#e0f2fe}.autosave-error{color:#9f1239;background:var(--danger-soft)}.mobile-card-list{display:grid}.settings-grid{grid-template-columns:1fr;margin-bottom:16px}.settings-card{display:grid;gap:10px}.class-structure-card{display:grid;gap:18px;border:1px solid rgba(219,234,254,.95);border-radius:var(--radius);padding:18px;background:#fffffff5;box-shadow:var(--shadow-soft)}.class-structure-header{display:flex;align-items:center;gap:14px}.class-structure-header h3{font-size:1.35rem}.class-structure-header p{margin-top:6px;color:var(--muted)}.structure-icon{display:grid;width:58px;height:58px;flex:0 0 auto;place-items:center;border-radius:14px;color:#2563eb;background:#dbeafe}.class-structure-list{display:grid;gap:12px}.class-row-card{border:1px solid var(--line);border-radius:var(--radius);padding:14px;background:#fff;transition:border-color .16s ease,box-shadow .16s ease}.class-row-card.open{border-color:#bfdbfe;box-shadow:0 12px 30px #2563eb14}.class-row-top,.class-expand-button{display:flex;align-items:center}.class-row-top{justify-content:space-between;gap:12px}.class-expand-button{min-height:44px;flex:1;gap:10px;border:0;padding:0;color:var(--text);background:transparent;text-align:left}.class-expand-button strong{font-size:1.2rem}.class-section-panel{display:grid;gap:14px;margin-top:14px;border-top:1px solid var(--line);padding-top:16px}.class-section-panel h4{margin:0;font-size:1rem}.section-chip-input{display:flex;align-items:center;flex-wrap:wrap;gap:8px;min-height:58px;border:1px solid var(--line);border-radius:var(--radius);padding:8px;background:#fff}.section-chip-input input{min-width:220px;flex:1 1 220px;border:0;box-shadow:none}.section-chip-input input:focus{box-shadow:none}.editable-chip{display:inline-flex;align-items:center;overflow:hidden;border-radius:var(--radius);color:#1e40af;font-weight:900;background:#dbeafe}.editable-chip button{min-height:38px;border:0;color:inherit;background:transparent}.editable-chip button:first-child{padding:8px 4px 8px 12px}.editable-chip button:last-child{display:grid;width:34px;place-items:center}.link-row{flex-wrap:wrap}.report-banner{margin-bottom:14px;background:linear-gradient(135deg,#eff6ff,#dcfce7)}@media (min-width: 720px){.content-page{padding:24px}.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.modal-backdrop{align-items:center}.modal{border-radius:var(--radius)}.toast-stack{right:22px;left:auto;bottom:22px;width:min(380px,calc(100vw - 44px))}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.manager-grid,.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 980px){.admin-shell{display:grid;grid-template-columns:286px minmax(0,1fr);align-items:start}.desktop-sidebar{position:sticky;top:0;display:block;height:100vh;border-right:1px solid var(--line);background:#fffffff0}.admin-topbar{display:none}.admin-content{grid-column:2;width:100%;max-width:100%;margin:0;padding:22px;overflow-x:hidden}.admin-page{width:100%;max-width:none}.mobile-card-list{display:none}.desktop-table{display:block}.routine-manager .table-shell{width:100%;max-width:100%}.routine-manager .data-table{min-width:1120px}.manager-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.01ms!important;transition-duration:.01ms!important}}
