:root{--color-primary:#358c75;--color-primary-hover:#2b7360;--color-primary-glow:#358c7559;--color-secondary:#68aa98;--color-accent:#fcbf02;--color-bg:#f5f8f7;--color-surface:#ffffffb8;--color-surface-solid:#fff;--sidebar-bg:#0c1220;--sidebar-bg2:#0f1829;--sidebar-text:#ffffffb8;--sidebar-text-hover:#fff;--sidebar-active-bg:#6366f138;--sidebar-border:#ffffff0f;--sidebar-width:260px;--sidebar-collapsed-width:72px;--color-text:#1e2a3b;--color-text-light:#6b7280;--color-text-muted:#9ca3af;--color-success:#10b981;--color-success-bg:#10b9811a;--color-success-border:#10b98140;--color-danger:#ef4444;--color-danger-bg:#ef44441a;--color-danger-border:#ef444440;--color-absent:#ef4444;--color-absent-bg:#ef44441a;--color-absent-border:#ef444440;--color-warning:#f59e0b;--color-warning-bg:#f59e0b1a;--color-warning-border:#f59e0b40;--color-late:#f59e0b;--color-late-bg:#f59e0b1a;--color-late-border:#f59e0b40;--color-left-early:#0ea5e9;--color-left-early-bg:#0ea5e91a;--color-left-early-border:#0ea5e940;--font-family:"Inter", system-ui, -apple-system, sans-serif;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014, 0 2px 6px #0000000a;--shadow-lg:0 12px 30px #0000001a, 0 4px 8px #0000000d;--shadow-xl:0 24px 50px #00000024;--shadow-primary:0 8px 30px #4f46e559;--glass-bg:#ffffffb8;--glass-border:1px solid #ffffff7a;--glass-blur:blur(20px);--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.26s cubic-bezier(.4, 0, .2, 1);--transition-slow:.42s cubic-bezier(.4, 0, .2, 1);--radius-sm:.5rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.375rem}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{font-family:var(--font-family);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(140deg,#e4f0ec 0%,#f4f9f7 45%,#fff 100%) fixed;min-height:100vh;line-height:1.6}a{color:inherit;text-decoration:none}h1{color:#111827;font-size:1.875rem;font-weight:800;line-height:1.2}h2{color:#1e2a3b;font-size:1.325rem;font-weight:700}h3{color:#1e2a3b;font-size:1.1rem;font-weight:600}h4{color:#374151;font-size:.925rem;font-weight:600}p{color:var(--color-text-light)}.app-shell{min-height:100vh;display:flex;position:relative}.app-main{min-width:0;margin-left:var(--sidebar-collapsed-width);transition:margin-left var(--transition-normal);flex-direction:column;flex:1;display:flex}.app-shell.sidebar-is-pinned.sidebar-desktop-open .app-main{margin-left:var(--sidebar-width)}.app-shell.sidebar-is-pinned.sidebar-desktop-collapsed .app-main,.app-shell.sidebar-is-unpinned .app-main{margin-left:var(--sidebar-collapsed-width)}.sidebar-seam-toggle{top:1.1rem;left:calc(var(--sidebar-width) - 18px);color:#fff;cursor:pointer;z-index:140;width:36px;height:36px;box-shadow:var(--shadow-md);transition:left var(--transition-normal), transform var(--transition-fast), box-shadow var(--transition-fast);background:#c0935a;border:1px solid #c0935a59;border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:fixed}.sidebar-seam-toggle.closed{left:calc(var(--sidebar-collapsed-width) - 18px)}.sidebar-seam-toggle:hover{box-shadow:var(--shadow-lg);background:#ab814d;transform:translateY(-1px)}.page-content{flex:1;width:100%;max-width:1320px;margin:0 auto;padding:2rem 2.25rem}.sidebar{height:100vh;width:var(--sidebar-width);background:linear-gradient(180deg, var(--sidebar-bg) 0%, var(--sidebar-bg2) 100%);border-right:1px solid var(--sidebar-border);z-index:100;transition:transform var(--transition-normal), width var(--transition-normal), box-shadow var(--transition-normal);box-shadow:var(--shadow-lg);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:visible}.sidebar.collapsed{width:var(--sidebar-collapsed-width);transform:translate(0)}.sidebar.expanded{transform:translate(0)}.sidebar-brand{border-bottom:1px solid var(--sidebar-border);flex-shrink:0;justify-content:space-between;align-items:center;gap:.75rem;padding:1.375rem 1.25rem;display:flex}.sidebar-brand-text{flex:1;min-width:0}.sidebar-logo{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 4px 16px #4f46e580}.sidebar-brand-name{color:#fff;font-size:.82rem;font-weight:700;line-height:1.2}.sidebar-brand-sub{color:#ffffff61;margin-top:2px;font-size:.64rem}.sidebar-controls{flex-shrink:0;align-items:center;gap:.35rem;display:flex}.sidebar-icon-btn{color:#ffffffad;cursor:pointer;width:30px;height:30px;transition:all var(--transition-fast);background:#ffffff0a;border:1px solid #ffffff14;border-radius:9px;justify-content:center;align-items:center;display:inline-flex}.sidebar-icon-btn:hover{color:#fff;background:#ffffff1a}.sidebar-nav{flex:1;padding:.875rem .75rem;overflow:visible auto}.sidebar-section-label{text-transform:uppercase;letter-spacing:.09em;color:#ffffff47;margin-top:.375rem;padding:.625rem .5rem .2rem;font-size:.58rem;font-weight:600}.sidebar-nav-item{border-radius:var(--radius-sm);color:var(--sidebar-text);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;align-items:center;gap:.42rem;width:100%;margin-bottom:2px;padding:.54rem .64rem;font-size:.76rem;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-item-label{white-space:nowrap;min-width:0}.sidebar-item-badge{flex-shrink:0}.sidebar-notification-badge{color:#fff;background:#ef4444;border-radius:999px;justify-content:center;align-items:center;min-width:1.1rem;height:1.1rem;margin-left:auto;padding:0 .28rem;font-size:.64rem;font-weight:700;line-height:1;display:inline-flex;box-shadow:0 0 0 1px #ffffff14}.sidebar-nav-item:hover{color:var(--sidebar-text-hover);background:#ffffff12}.sidebar-nav-item.active{background:var(--sidebar-active-bg);color:#fff;box-shadow:inset 0 0 0 1px #6366f159}.sidebar-nav-item .nav-icon{opacity:.72;flex-shrink:0;width:15px;height:15px}.sidebar-nav-item:hover .nav-icon,.sidebar-nav-item.active .nav-icon{opacity:1}.sidebar-nav-item.active .nav-icon{color:#a5b4fc}.sidebar-role-switcher{border-top:1px solid var(--sidebar-border);flex-shrink:0;padding:.75rem}.role-switcher-label{text-transform:uppercase;letter-spacing:.09em;color:#ffffff47;margin-bottom:.4rem;padding:0 .25rem;font-size:.62rem;font-weight:600}.role-btn{border-radius:var(--radius-sm);cursor:pointer;color:#ffffff80;width:100%;transition:all var(--transition-fast);font-size:.8rem;font-weight:500;font-family:var(--font-family);background:0 0;border:1px solid #0000;align-items:center;gap:.6rem;margin-bottom:2px;padding:.5rem .75rem;display:flex}.role-btn:hover{color:#ffffffd9;background:#ffffff0f}.role-btn.active{color:#c7d2fe;background:#4f46e52e;border-color:#6366f166}.role-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:7px;height:7px}.sidebar-footer{border-top:1px solid var(--sidebar-border);flex-shrink:0;padding:.75rem}.sidebar-submenu{margin-bottom:.4rem;position:relative}.sidebar-submenu-trigger{border-radius:var(--radius-sm);width:100%;color:var(--sidebar-text);cursor:pointer;transition:all var(--transition-fast);font-size:.76rem;font-weight:500;font-family:var(--font-family);background:0 0;border:none;justify-content:space-between;align-items:center;gap:.42rem;padding:.54rem .64rem;display:flex}.sidebar-submenu-trigger:hover{color:var(--sidebar-text-hover);background:#ffffff12}.sidebar-submenu-chevron{color:#ffffff85;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.sidebar-submenu-items{gap:.2rem;margin-top:.2rem;padding-left:.9rem;display:grid}.sidebar-submenu-item{border-radius:var(--radius-sm);color:#ffffffb8;min-height:2rem;transition:all var(--transition-fast);white-space:nowrap;align-items:center;padding:.42rem .64rem;font-size:.72rem;font-weight:500;text-decoration:none;display:flex}.sidebar-submenu-label{display:inline-block}.sidebar-submenu-item:hover{color:#fff;background:#ffffff0f}.sidebar-submenu-item.active{color:#fff;background:#ffffff1a}.sidebar-signout{border-radius:var(--radius-sm);color:#ffffff6b;cursor:pointer;width:100%;transition:all var(--transition-fast);font-size:.76rem;font-weight:500;font-family:var(--font-family);background:0 0;border:none;align-items:center;gap:.42rem;padding:.54rem .64rem;display:flex}.sidebar-signout:hover{color:#fca5a5;background:#ef44441a}.sidebar.collapsed .sidebar-brand{flex-direction:column;gap:.5rem;padding:1rem .75rem}.sidebar.collapsed .sidebar-brand-text,.sidebar.collapsed .sidebar-section-label,.sidebar.collapsed .sidebar-item-label,.sidebar.collapsed .sidebar-submenu-chevron,.sidebar.collapsed .role-switcher-label{display:none}.sidebar.collapsed .sidebar-item-badge{display:inline-flex}.sidebar.collapsed .sidebar-notification-badge{min-width:.92rem;height:.92rem;margin-left:0;padding:0 .18rem;font-size:.56rem;position:absolute;top:.34rem;right:.34rem}.dashboard-notification-badge,.dashboard-inline-notification-badge{color:#fff;background:#ef4444;border-radius:999px;justify-content:center;align-items:center;min-width:1.1rem;height:1.1rem;padding:0 .28rem;font-size:.64rem;font-weight:700;line-height:1;display:inline-flex;box-shadow:0 0 0 1px #ffffff14}.dashboard-notification-badge{margin-left:.5rem}.dashboard-inline-notification-badge{margin-left:.35rem}.sidebar.collapsed .sidebar-controls{justify-content:center;width:100%}.sidebar.collapsed .sidebar-nav,.sidebar.collapsed .sidebar-role-switcher,.sidebar.collapsed .sidebar-footer{padding-left:.5rem;padding-right:.5rem}.sidebar.collapsed .sidebar-nav-item,.sidebar.collapsed .sidebar-submenu-trigger,.sidebar.collapsed .role-btn,.sidebar.collapsed .sidebar-signout{justify-content:center;gap:0;padding-left:.6rem;padding-right:.6rem}.sidebar.collapsed .sidebar-submenu{margin-bottom:.25rem}.sidebar.collapsed .sidebar-submenu-items{z-index:130;background:linear-gradient(#101828fa 0%,#162034fa 100%);border:1px solid #ffffff14;border-radius:.9rem;min-width:11rem;margin-top:0;padding:.35rem;position:absolute;top:50%;left:calc(100% + .55rem);transform:translateY(-50%);box-shadow:0 16px 32px #0206175c}.sidebar.collapsed .sidebar-submenu-item{justify-content:flex-start;padding:.52rem .65rem;font-size:.74rem}.sidebar.collapsed .sidebar-nav-item .nav-icon,.sidebar.collapsed .role-btn svg,.sidebar.collapsed .sidebar-signout svg{margin:0}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:99;background:#00000080;display:none;position:fixed;inset:0}.app-header{-webkit-backdrop-filter:blur(18px);z-index:50;background:#ffffffa6;border-bottom:1px solid #ffffff8c;justify-content:space-between;align-items:center;gap:1rem;padding:.875rem 2.25rem;display:flex;position:sticky;top:0}body.student-detail-drawer-open .app-header,body.user-detail-drawer-open .app-header,body.academic-term-set-drawer-open .app-header,body.invite-user-drawer-open .app-header{display:none}.header-left{align-items:center;gap:.75rem;display:flex}.header-title{color:#111827;font-size:1.05rem;font-weight:700}.mobile-menu-btn{cursor:pointer;color:#374151;background:0 0;border:none;padding:.25rem;display:none}.header-user{align-items:center;gap:.75rem;display:flex}.header-avatar{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));color:#fff;width:36px;height:36px;box-shadow:0 2px 10px var(--color-primary-glow);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.78rem;font-weight:700;display:flex}.header-user-info{line-height:1.25}.header-user-name{color:#374151;font-size:.875rem;font-weight:600}.header-user-role{color:var(--color-text-muted);font-size:.7rem}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:transform var(--transition-normal), box-shadow var(--transition-normal);padding:1.5rem;position:relative}.glass-panel:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.glass-panel.no-hover:hover{box-shadow:var(--shadow-md);transform:none}.glass-panel:has(.custom-select.is-open){z-index:130}.btn-primary{background:linear-gradient(135deg, var(--color-primary) 0%, #6366f1 100%);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-normal);box-shadow:0 4px 20px var(--color-primary-glow);letter-spacing:.01em;width:100%;font-size:.95rem;font-weight:700;font-family:var(--font-family);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.825rem 1.75rem;display:inline-flex}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-primary);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.62;cursor:not-allowed}.btn-ghost{color:#374151;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-size:.875rem;font-weight:500;font-family:var(--font-family);background:#ffffffbf;border:1px solid #d1d5db99;align-items:center;gap:.5rem;padding:.5rem 1.1rem;display:inline-flex}.btn-ghost:hover{box-shadow:var(--shadow-sm);background:#fffffff2}.form-group{margin-bottom:1.25rem}.form-group:has(.custom-select.is-open){z-index:120;position:relative}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.form-label{color:#374151;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.45rem;font-size:.78rem;font-weight:600;display:block}input,select,textarea{font-family:var(--font-family);width:100%;color:var(--color-text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);appearance:none;background-color:#ffffffe0;border:1.5px solid #d1d5dbb3;border-radius:16px;padding:.75rem 1rem;font-size:.95rem;box-shadow:0 10px 24px #0f172a0f}input[type=checkbox]{appearance:auto;-webkit-appearance:checkbox;width:1rem;height:1rem;accent-color:var(--color-primary);padding:0}textarea{resize:vertical;min-height:96px;line-height:1.45}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);background-color:#fff;outline:none;box-shadow:0 0 0 3px #4f46e526}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%236b7280' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right .95rem center;background-repeat:no-repeat;background-size:18px 18px;padding-right:2.9rem}.filter-select{background-color:#fffffff5;border-color:#cbd5e1e6;border-radius:18px;min-height:48px;box-shadow:0 14px 28px #0f172a14,inset 0 1px #ffffffbf}.filter-select.is-active{background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'%3E%3Ccircle cx='10' cy='10' r='8.5' fill='%234f46e5' fill-opacity='0.12' stroke='%234f46e5'/%3E%3Cpath d='M6.5 10.2L8.7 12.4L13.5 7.6' stroke='%234f46e5' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%234f46e5' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:.95rem,right .95rem center;background-repeat:no-repeat,no-repeat;background-size:20px 20px,18px 18px;border-color:#4f46e566;padding-left:2.85rem;box-shadow:0 16px 32px #4f46e51f,inset 0 1px #ffffffe6}.custom-select{width:100%;position:relative}.custom-select.is-open{z-index:120}.custom-select-trigger{font-family:var(--font-family);width:100%;color:var(--color-text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);appearance:none;text-align:left;cursor:pointer;background-color:#ffffffe0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%236b7280' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right .95rem center;background-repeat:no-repeat;background-size:18px 18px;border:1.5px solid #d1d5e1b3;border-radius:16px;padding:.75rem 2.9rem .75rem 1rem;font-size:.95rem;position:relative;box-shadow:0 10px 24px #0f172a0f}.custom-select-trigger:focus-visible,.custom-select.is-open .custom-select-trigger{border-color:var(--color-primary);background-color:#fff;outline:none;box-shadow:0 0 0 3px #4f46e526}.custom-select-trigger:disabled,.custom-select.is-disabled .custom-select-trigger{opacity:.62;cursor:not-allowed}.custom-select-trigger-label{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.custom-select-menu{z-index:121;-webkit-backdrop-filter:blur(18px);background:#fffffffa;border:1px solid #cbd5e1e6;border-radius:20px;max-height:18rem;padding:.4rem;position:absolute;top:calc(100% + .55rem);left:0;right:0;overflow-y:auto;box-shadow:0 24px 40px #0f172a29}.custom-select-option{width:100%;color:var(--color-text);text-align:left;cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);background:0 0;border:none;border-radius:14px;align-items:center;gap:.75rem;padding:.75rem .85rem;display:flex}.custom-select-option:hover,.custom-select-option.is-highlighted{background:#4f46e514}.custom-select-option.is-selected{color:#312e81;background:#4f46e51f}.custom-select-option:disabled{opacity:.45;cursor:not-allowed}.custom-select-option-check{color:#4f46e5;background:#ffffffeb;border:1px solid #94a3b8a6;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:1.25rem;height:1.25rem;display:inline-flex}.custom-select-option.is-selected .custom-select-option-check{background:#4f46e51f;border-color:#4f46e580}.custom-select-option-label{min-width:0}.badge{text-transform:uppercase;letter-spacing:.06em;border-radius:99px;align-items:center;gap:.3rem;padding:.28rem .65rem;font-size:.72rem;font-weight:700;display:inline-flex}.badge-present{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.badge-absent{background:var(--color-absent-bg);color:var(--color-absent);border:1px solid var(--color-absent-border)}.badge-late{background:var(--color-late-bg);color:var(--color-late);border:1px solid var(--color-late-border)}.badge-late-left-early{color:#0f766e;background:linear-gradient(135deg,#f59e0b24,#0ea5e924);border:1px solid #0f766e33}.badge-left-early{background:var(--color-left-early-bg);color:var(--color-left-early);border:1px solid var(--color-left-early-border)}.badge-role{color:var(--color-primary);background:#4f46e51a;border:1px solid #4f46e540}.badge-neutral{color:#475569;background:#94a3b81f;border:1px solid #94a3b847}.stat-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition-normal), box-shadow var(--transition-normal);flex-direction:column;gap:.4rem;padding:1.25rem 1.375rem;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-card.success:before{background:linear-gradient(90deg,#10b981,#34d399)}.stat-card.danger:before{background:linear-gradient(90deg,#ef4444,#f87171)}.stat-card.warning:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.stat-card.primary:before{background:linear-gradient(90deg, var(--color-primary), var(--color-secondary))}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.stat-card-icon{border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;margin-bottom:.2rem;display:flex}.stat-card.success .stat-card-icon{background:var(--color-success-bg);color:var(--color-success)}.stat-card.danger .stat-card-icon{background:var(--color-absent-bg);color:var(--color-absent)}.stat-card.warning .stat-card-icon{background:var(--color-late-bg);color:var(--color-late)}.stat-card.primary .stat-card-icon{color:var(--color-primary);background:#4f46e51a}.stat-card-value{color:#111827;font-size:2rem;font-weight:800;line-height:1}.stat-card-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:500}.stats-grid{grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem;display:grid}.stats-grid.attendance-spotlight-grid,.stats-grid.attendance-day-stats-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.children-grid{grid-template-columns:repeat(auto-fill,minmax(295px,1fr));gap:1.25rem;display:grid}.child-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition-normal);color:inherit;padding:1.5rem;text-decoration:none;display:block}.child-card:hover{box-shadow:var(--shadow-lg);border-color:#6366f159;transform:translateY(-4px)}.child-card-header{align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.child-avatar{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.2rem;font-weight:800;display:flex;box-shadow:0 4px 14px #4f46e561}.child-name{color:#111827;margin-bottom:2px;font-size:1.05rem;font-weight:700}.child-class{color:var(--color-text-muted);font-size:.78rem}.child-stats-row{gap:.625rem;margin-bottom:1rem;display:flex}.child-stat-pill{text-align:center;border-radius:var(--radius-md);background:#ffffffa6;border:1px solid #ffffff8c;flex:1;padding:.6rem .4rem}.child-stat-num{font-size:1.05rem;font-weight:800;line-height:1}.child-stat-num.success{color:var(--color-success)}.child-stat-num.danger{color:var(--color-absent)}.child-stat-num.warning{color:var(--color-late)}.child-stat-lbl{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:3px;font-size:.6rem;font-weight:500}.percentage-bar-label{color:var(--color-text-muted);justify-content:space-between;margin-bottom:.35rem;font-size:.72rem;display:flex}.percentage-bar-label strong{color:var(--color-success);font-weight:700}.percentage-bar-track{background:#00000012;border-radius:99px;height:5px;overflow:hidden}.percentage-bar-fill{background:linear-gradient(90deg, var(--color-success), #34d399);border-radius:99px;height:100%;transition:width .9s cubic-bezier(.4,0,.2,1)}.attendance-list{flex-direction:column;gap:.5rem;display:flex}.attendance-row{border-radius:var(--radius-md);transition:background var(--transition-fast);background:#ffffffb8;border:1px solid #ffffff8c;justify-content:space-between;align-items:center;padding:.9rem 1.25rem;display:flex}.attendance-row:hover{background:#fffffff2}.dashboard-setup-link{transition:background var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast)}.dashboard-setup-link:hover,.dashboard-setup-link:focus-visible{box-shadow:var(--shadow-lg);background:#fffffffa;border-color:#10b9812e;outline:none;transform:translateY(-2px)scale(1.01)}.dashboard-setup-link-arrow{transition:color var(--transition-fast), transform var(--transition-fast)}.dashboard-setup-link:hover .dashboard-setup-link-arrow,.dashboard-setup-link:focus-visible .dashboard-setup-link-arrow{transform:translate(2px);color:var(--color-success)!important}.attendance-day{color:var(--color-text-muted);font-size:.78rem;font-weight:500}.attendance-date{color:#1e2a3b;font-size:.95rem;font-weight:600}.attendance-filter-grid{grid-template-columns:repeat(4,minmax(140px,1fr)) minmax(220px,1.4fr);align-items:end;gap:.75rem;display:grid}.admin-directory-filter-grid{grid-template-columns:minmax(220px,2fr) repeat(5,minmax(140px,1fr));align-items:end;gap:.75rem;display:grid}.attendance-split-layout{grid-template-columns:minmax(320px,.92fr) minmax(0,1.35fr);align-items:start;gap:1rem;display:grid}.attendance-student-layout{transition:grid-template-columns .32s}.attendance-student-detail-panel{will-change:opacity, transform;min-width:0}.attendance-card-list{gap:.9rem;display:grid}.attendance-class-card{text-align:left;cursor:pointer;width:100%;transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);box-shadow:var(--shadow-sm);background:linear-gradient(#fffffff0,#f5f8f7eb);border:1px solid #d1d5db80;border-radius:20px;padding:1rem;position:relative}.attendance-class-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.attendance-class-card.is-active{border-color:#111827;transform:translateY(-1px)scale(1.01);box-shadow:0 18px 34px #0f172a24}.attendance-class-card.is-active .attendance-range-bar{box-shadow:inset 0 0 0 1px #1118271f}.attendance-card-badges{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.attendance-card-selection{color:#fff;letter-spacing:.05em;text-transform:uppercase;background:#111827;border-radius:999px;align-items:center;padding:.3rem .6rem;font-size:.68rem;font-weight:800;display:inline-flex}.attendance-card-head,.attendance-detail-header,.attendance-date-strip-head,.attendance-calendar-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.attendance-card-title{color:#111827;font-size:.98rem;font-weight:700}.attendance-card-subtitle{color:var(--color-text-muted);margin-top:.15rem;font-size:.8rem}.attendance-card-meta,.attendance-range-legend{flex-wrap:wrap;gap:.8rem;display:flex}.attendance-card-meta{color:var(--color-text-muted);margin-top:.75rem;font-size:.74rem}.attendance-range-legend{color:#475569;margin-top:.55rem;font-size:.76rem}.attendance-range-bar{background:#e2e8f0e6;border-radius:999px;width:100%;height:.8rem;margin-top:.9rem;display:flex;overflow:hidden}.attendance-range-segment{min-width:0;height:100%}.attendance-segment-present{background:linear-gradient(90deg,#10b981,#34d399)}.attendance-segment-late{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.attendance-segment-left-early{background:linear-gradient(90deg,#0ea5e9,#38bdf8)}.attendance-segment-absent{background:linear-gradient(90deg,#ef4444,#f87171)}.attendance-segment-unmarked{background:linear-gradient(90deg,#94a3b8,#cbd5e1)}.attendance-summary-row{grid-template-columns:repeat(5,minmax(0,1fr));gap:.75rem;margin:1rem 0 1.1rem;display:grid}.attendance-summary-pill{background:#f7f9f8eb;border:1px solid #0000000b;border-radius:16px;gap:.15rem;padding:.85rem .95rem;display:grid}.attendance-summary-kicker{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-size:.68rem;font-weight:800}.attendance-summary-pill strong{color:#111827;font-size:1.3rem;line-height:1}.attendance-date-strip-list{gap:.8rem;display:grid}.attendance-date-strip-card{background:#ffffffe0;border:1px solid #d1d5db80;border-radius:18px;padding:.95rem 1rem}.attendance-register-link{border-color:#10b98138;min-height:auto;padding:.35rem .7rem;font-size:.78rem}.attendance-register-link:hover{background:#10b98114;border-color:#10b98180}.attendance-empty-inline{color:var(--color-text-muted);text-align:center;background:#f8fafce6;border-radius:16px;padding:1rem}.attendance-calendar-card{background:linear-gradient(#fffffffa,#f4f7f5f2);border:1px solid #d1d5db8c;border-radius:22px;padding:1rem}.attendance-calendar-legend{color:var(--color-text-muted);flex-wrap:wrap;gap:.85rem;font-size:.78rem;display:flex}.attendance-calendar-controls{justify-items:end;gap:.75rem;display:grid}.attendance-month-nav{align-items:center;gap:.5rem;display:inline-flex}.attendance-month-btn{width:2.2rem;height:2.2rem;color:var(--color-text);cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);background:#fffffff2;border:1px solid #00000014;border-radius:12px;justify-content:center;align-items:center;display:inline-flex}.attendance-month-btn:hover{box-shadow:var(--shadow-sm);border-color:#358c753d;transform:translateY(-1px)}.attendance-month-input{width:auto;min-width:9.5rem;padding:.6rem .85rem}.attendance-calendar-legend span{align-items:center;gap:.4rem;display:inline-flex}.attendance-calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:.55rem;display:grid}.attendance-calendar-weekdays{margin:1rem 0 .55rem}.attendance-calendar-weekday{text-align:center;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-size:.7rem;font-weight:700}.attendance-calendar-cell{background:#ffffffd1;border:1px solid #e2e8f0e6;border-radius:18px;min-height:92px;padding:.7rem}.attendance-calendar-cell.is-blank{background:#f8fafc9e}.attendance-calendar-day-number{color:#111827;font-size:.82rem;font-weight:700}.attendance-calendar-dots{flex-wrap:wrap;gap:.35rem;margin-top:.75rem;display:flex}.attendance-dot{border-radius:999px;width:.65rem;height:.65rem;display:inline-block}.attendance-dot-present{background:var(--color-success)}.attendance-dot-late{background:var(--color-late)}.attendance-dot-late-left-early{background:linear-gradient(135deg, var(--color-late), var(--color-left-early))}.attendance-dot-left-early{background:var(--color-left-early)}.attendance-dot-absent{background:var(--color-absent)}.attendance-dot-unmarked{background:#cbd5e1;border:1px solid #94a3b8}.attendance-dot-pending{background:#358c7533;border:1px dashed #358c7580}.attendance-dot-clear{background:#cbd5e14d}.attendance-day-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:end;gap:1rem;display:flex}.attendance-day-picker{min-width:220px}.attendance-refresh-surface{position:relative;overflow:hidden}.attendance-refreshing .attendance-refresh-surface:after{content:"";pointer-events:none;z-index:1;background:linear-gradient(90deg,#fff0 0%,#ffffff61 45%,#ffffffb3 50%,#ffffff61 55%,#fff0 100%);animation:1.1s attendanceRefreshShimmer;position:absolute;inset:0;transform:translate(-100%)}@keyframes attendanceRefreshShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.page-header-text h1{margin-bottom:.2rem}.page-header-text p{font-size:.875rem}.filter-bar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.filter-bar select{width:auto;min-width:155px;padding:.5rem .875rem;font-size:.875rem}.mobile-section-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.mobile-data-card-list{gap:.85rem;padding:0 1rem 1rem;display:none}.notifications-history-card-list{gap:.85rem;margin-bottom:.5rem;display:none}.mobile-data-card{box-shadow:var(--shadow-sm);background:#ffffffeb;border:1px solid #d1d5db99;border-radius:18px;padding:1rem}.mobile-data-card-header,.mobile-data-card-actions,.table-pagination,.table-pagination-actions{gap:.75rem;display:flex}.mobile-data-card-header,.table-pagination{justify-content:space-between;align-items:flex-start}.mobile-data-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem 1rem;margin-top:.9rem;display:grid}.mobile-data-card-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:.2rem;font-size:.7rem;font-weight:700}.mobile-data-card-actions{flex-wrap:wrap;margin-top:1rem}.mobile-data-card-empty,.table-pagination{padding:1rem}.mobile-data-card-empty{color:var(--color-text-muted);text-align:center}.table-pagination{border-top:1px solid #0000000d;justify-content:space-between;align-items:center}.table-pagination-actions{flex-wrap:wrap;justify-content:flex-end}.spinner{border:3px solid #4f46e526;border-top-color:var(--color-primary);border-radius:50%;animation:.75s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spinner-fullscreen{min-height:100vh;color:var(--color-text-light);flex-direction:column;justify-content:center;align-items:center;gap:1rem;font-size:.9rem;display:flex}.spinner-inline{color:var(--color-text-muted);justify-content:center;align-items:center;gap:.75rem;padding:3rem;font-size:.875rem;display:flex}.error-alert{background:var(--color-absent-bg);border:1px solid var(--color-absent-border);border-radius:var(--radius-sm);color:#b91c1c;align-items:flex-start;gap:.75rem;margin-bottom:1rem;padding:.875rem 1rem;font-size:.875rem;display:flex}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";z-index:-1;background:radial-gradient(at 20% 15%,#358c7526 0%,#0000 55%),radial-gradient(at 80% 85%,#fcbf021a 0%,#0000 50%),linear-gradient(140deg,#e4f0ec 0%,#fff 100%);position:fixed;inset:0}.login-card{-webkit-backdrop-filter:blur(28px);border-radius:var(--radius-xl);width:100%;max-width:430px;box-shadow:0 28px 65px #4f46e524, var(--shadow-xl);background:#ffffffd1;border:1px solid #ffffffa6;padding:2.625rem 2.5rem;animation:.5s cubic-bezier(.4,0,.2,1) slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}.login-logo-wrap{justify-content:center;margin-bottom:1.625rem;display:flex}.login-logo{background:linear-gradient(135deg, var(--color-primary) 0%, #6366f1 50%, var(--color-secondary) 100%);border-radius:22px;justify-content:center;align-items:center;width:70px;height:70px;display:flex;box-shadow:0 10px 32px #4f46e56b}.login-header{text-align:center;margin-bottom:2rem}.login-title{color:#111827;margin-bottom:.3rem;font-size:1.5rem;font-weight:800}.login-subtitle{color:var(--color-text-muted);font-size:.875rem}.coming-soon{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:60vh;display:flex}.coming-soon-icon{width:78px;height:78px;color:var(--color-primary);background:linear-gradient(135deg,#4f46e51a,#0ea5e91a);border-radius:22px;justify-content:center;align-items:center;margin-bottom:.25rem;display:flex}.empty-state{text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 2rem;display:flex}.empty-state svg{opacity:.38}.holiday-success-alert{border-radius:var(--radius-md);color:#0f766e;background:#10b9811a;border:1px solid #10b98138;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.95rem 1rem;font-weight:600;display:flex}.holiday-page-grid{grid-template-columns:minmax(280px,340px) minmax(0,1fr);align-items:start;gap:1.25rem;display:grid}.academic-governance-grid{grid-template-columns:minmax(260px,1fr) minmax(0,2fr)}.applications-review-grid{grid-template-columns:minmax(320px,420px) minmax(0,1fr)}.notifications-workspace-grid{grid-template-columns:minmax(360px,1.05fr) minmax(320px,.95fr);align-items:start;gap:1rem;display:grid}.user-management-header-actions{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.user-management-filter-grid{grid-template-columns:minmax(280px,1fr) minmax(200px,240px);align-items:center;gap:1rem;display:grid}.user-management-step-card{background:linear-gradient(#fffffff5,#f5f8f7f0);border:1px solid #d1d5dbb8;border-radius:1rem;gap:.28rem;padding:.95rem 1rem;display:grid;box-shadow:0 10px 24px #0f172a0d}.user-management-step-icon{width:2rem;height:2rem;color:var(--color-primary);background:#358c751f;border-radius:.75rem;justify-content:center;align-items:center;margin-bottom:.25rem;display:inline-flex;box-shadow:inset 0 0 0 1px #358c7514}.holiday-action-stack{gap:.9rem;display:grid;position:sticky;top:1rem}.holiday-panel-header,.holiday-option-header,.holiday-manual-toolbar,.holiday-stat-row{gap:1rem;display:flex}.holiday-panel-header,.holiday-option-header,.holiday-manual-toolbar{justify-content:space-between;align-items:center}.holiday-option-header{align-items:flex-start;margin-bottom:.9rem}.holiday-option-header svg{color:var(--color-primary);flex-shrink:0;margin-top:.1rem}.holiday-option-header h3,.holiday-panel-header h3{margin-bottom:.25rem}.holiday-option-header p,.holiday-panel-header p{color:var(--color-text-muted);margin:0;line-height:1.45}.holiday-year-chip{color:var(--color-primary);white-space:nowrap;background:#358c751f;border-radius:999px;padding:.55rem .8rem;font-size:.78rem;font-weight:700}.holiday-stat-row{margin-top:1rem}.holiday-stat-card{border-radius:var(--radius-md);background:linear-gradient(#ffffffdb,#f4f7f5eb);border:1px solid #0000000b;flex-direction:column;flex:1;gap:.12rem;min-width:0;padding:.9rem 1rem;display:flex}.holiday-stat-kicker{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);font-size:.68rem;font-weight:800}.holiday-stat-value{color:#111827;font-size:1.45rem;font-weight:800;line-height:1}.holiday-stat-label{color:var(--color-text-muted);font-size:.8rem}.holiday-manual-header{grid-template-columns:minmax(0,1fr) minmax(240px,280px);align-items:start;gap:1rem;margin-bottom:1rem;display:grid}.holiday-selection-card{background:linear-gradient(135deg,#358c751f,#ffffffe6);border:1px solid #358c7524;border-radius:16px;gap:.2rem;padding:.95rem 1rem;display:grid}.holiday-selection-label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);font-size:.72rem;font-weight:800}.holiday-manual-meta{background:#f7f9f8e6;border:1px solid #0000000b;border-radius:16px;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;padding:.9rem 1rem;display:flex}.holiday-calendar-legend{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.holiday-legend-chip{color:var(--color-text-muted);background:#fff;border:1px solid #0000000d;border-radius:999px;align-items:center;gap:.45rem;padding:.4rem .7rem;font-size:.78rem;font-weight:700;display:inline-flex}.holiday-legend-swatch{border:1px solid #00000014;border-radius:999px;width:.8rem;height:.8rem;display:inline-block}.holiday-legend-swatch-selected{background:linear-gradient(135deg,#358c7552,#6366f13d);border-color:#358c7552}.holiday-legend-swatch-existing{background:#f59e0b2e;border-color:#f59e0b52}.holiday-manual-toolbar{flex-wrap:wrap;gap:.6rem}.holiday-calendar-frame{gap:.9rem;display:grid}.holiday-calendar-nav{background:linear-gradient(#f7f9f8f5,#fffffff5);border:1px solid #0000000b;border-radius:16px;justify-content:space-between;align-items:center;gap:1rem;padding:.95rem 1rem;display:flex}.holiday-calendar-title{color:#111827;font-size:1rem;font-weight:800}.holiday-calendar-subtitle{color:var(--color-text-muted);margin-top:.2rem;font-size:.8rem}.holiday-calendar-controls{flex-wrap:wrap;align-items:center;gap:.55rem;display:flex}.holiday-nav-btn{width:2.4rem;height:2.4rem;color:var(--color-text);cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);background:#fff;border:1px solid #0000000f;border-radius:12px;justify-content:center;align-items:center;display:inline-flex}.holiday-nav-btn:hover:not(:disabled){box-shadow:var(--shadow-sm);border-color:#358c753d;transform:translateY(-1px)}.holiday-nav-btn:disabled{opacity:.45;cursor:not-allowed}.holiday-month-select{width:auto;min-width:220px}.holiday-calendar-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:.75rem;display:grid}.holiday-calendar-grid-single{grid-template-columns:minmax(0,1fr)}.holiday-month-card{background:#ffffffd6;border:1px solid #0000000b;border-radius:16px;padding:.85rem}.holiday-month-title{margin-bottom:.7rem;font-size:.92rem;font-weight:700}.holiday-weekday-row,.holiday-day-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:.25rem;display:grid}.holiday-weekday-row{margin-bottom:.35rem}.holiday-weekday-row span{text-align:center;color:var(--color-text-muted);font-size:.68rem;font-weight:700}.holiday-day-empty{min-height:32px}.holiday-day-btn{min-height:32px;color:var(--color-text);cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast), background-color var(--transition-fast);background:#fff;border:1px solid #0000000b;border-radius:10px;font-size:.82rem;font-weight:600}.holiday-day-btn:hover{box-shadow:var(--shadow-sm);border-color:#358c753d;transform:translateY(-1px)}.holiday-day-btn.selected{color:var(--color-primary);background:linear-gradient(135deg,#358c752e,#6366f12e);border-color:#358c7561}.holiday-day-btn.existing{box-shadow:inset 0 0 0 1px #f59e0b38}.holiday-day-btn.selected.existing{box-shadow:inset 0 0 0 1px #f59e0b38,0 0 0 1px #358c7526}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.animate-fadeIn{animation:.4s both fadeIn}.animate-fadeInUp{animation:.45s cubic-bezier(.4,0,.2,1) both fadeInUp}.side-drawer-overlay{-webkit-backdrop-filter:blur(6px);opacity:0;background:#0f172a47;justify-content:flex-end;transition:opacity .75s cubic-bezier(.22,1,.36,1);display:flex;position:fixed;inset:0}.side-drawer-overlay.open{opacity:1}.side-drawer-panel{opacity:0;will-change:transform, opacity;transition:transform .75s cubic-bezier(.22,1,.36,1),opacity .75s cubic-bezier(.22,1,.36,1);transform:translate(100%)}.side-drawer-panel.open{opacity:1;transform:translate(0)}.stagger>:first-child{animation-delay:0s}.stagger>:nth-child(2){animation-delay:65ms}.stagger>:nth-child(3){animation-delay:.13s}.stagger>:nth-child(4){animation-delay:.195s}.stagger>:nth-child(5){animation-delay:.26s}.stagger>:nth-child(6){animation-delay:.325s}.text-muted{color:var(--color-text-muted)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.fw-600{font-weight:600}.fw-700{font-weight:700}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}@media (width<=1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.stats-grid.attendance-spotlight-grid,.stats-grid.attendance-day-stats-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}@media (width<=768px){.app-shell.is-mobile .app-main{margin-left:0}.app-shell.is-mobile .sidebar{width:min(82vw,320px);max-width:320px;box-shadow:none;transform:translate(-100%)}.app-shell.is-mobile .sidebar.collapsed,.app-shell.is-mobile .sidebar.expanded{width:min(82vw,320px);transform:translate(-100%)}.app-shell.is-mobile .sidebar.open,.app-shell.is-mobile .sidebar.open.collapsed,.app-shell.is-mobile .sidebar.open.expanded{box-shadow:var(--shadow-xl);transform:translate(0)}.sidebar-seam-toggle{display:none}.sidebar-overlay.open{display:block}.mobile-menu-btn{align-items:center;display:flex}.app-header{padding:.875rem 1rem}.page-content{padding:1.25rem 1rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.stats-grid.attendance-spotlight-grid,.stats-grid.attendance-day-stats-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.academic-governance-grid,.applications-review-grid,.notifications-workspace-grid,.children-grid,.user-management-filter-grid,.user-management-invite-steps,.grid-2,.holiday-page-grid,.holiday-calendar-grid{grid-template-columns:1fr}.holiday-action-stack{position:static;top:auto}.holiday-manual-header{grid-template-columns:1fr}.holiday-manual-meta,.holiday-calendar-nav{flex-direction:column;align-items:stretch}.holiday-calendar-controls{justify-content:space-between}.holiday-month-select{flex:1;min-width:0}.holiday-panel-header,.holiday-option-header,.holiday-manual-toolbar,.holiday-stat-row{flex-direction:column;align-items:stretch}.user-management-header-actions>*{flex:100%}.user-management-header-actions .btn-primary,.user-management-header-actions .btn-ghost{justify-content:center;width:100%!important}}@media (width<=480px){.login-card{padding:1.875rem 1.5rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.625rem}.stats-grid.attendance-spotlight-grid,.stats-grid.attendance-day-stats-grid{grid-template-columns:1fr}.stat-card-value{font-size:1.6rem}}@media (width<=1200px){.admin-directory-filter-grid,.attendance-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.attendance-split-layout{grid-template-columns:1fr}}@media (width<=900px){.admin-directory-filter-grid,.attendance-filter-grid,.attendance-summary-row{grid-template-columns:repeat(2,minmax(0,1fr))}.attendance-calendar-cell{min-height:78px;padding:.55rem}}@media (width<=640px){.admin-directory-filter-grid,.attendance-filter-grid,.attendance-summary-row{grid-template-columns:1fr}.notifications-app-tabs{gap:.45rem;padding:.3rem}.notifications-app-tabs .tab-btn{white-space:nowrap;min-width:150px;padding:.85rem .8rem}.mobile-section-header,.table-pagination{flex-direction:column;align-items:stretch}.mobile-data-card-grid{grid-template-columns:1fr}.attendance-calendar-grid{gap:.35rem}.attendance-calendar-cell{min-height:72px}}.tabs-wrapper{border-bottom:2px solid #0000000d;gap:2rem;margin-bottom:2rem;padding:0 .5rem;display:flex}.notifications-app-tabs{background:linear-gradient(#f0f7f4f5,#fffffff5);border:1px solid #358c7529;border-radius:1.15rem;gap:.6rem;padding:.35rem;overflow-x:auto;box-shadow:inset 0 1px #ffffffe6}.notifications-app-tab{min-width:180px;color:var(--color-text-light);text-align:left;background:0 0;border:1px solid #0000;border-radius:.9rem;flex-direction:column;flex:1 1 0;align-items:flex-start;gap:.2rem;padding:.95rem 1rem;display:flex}.notifications-app-tab-caption{color:var(--color-text-muted);font-size:.74rem;font-weight:600}.notifications-app-tab:hover{background:#358c750f;border-color:#358c7524}.notifications-app-tab.active{color:#123b31;background:linear-gradient(135deg,#358c752e,#fffffffa);border-color:#358c754d;box-shadow:0 10px 24px #358c751f}.notifications-app-tab.active:after{display:none}.notifications-app-tab.active .notifications-app-tab-caption{color:#123b31bf}.tab-btn{color:var(--color-text-light);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;align-items:center;gap:.6rem;padding:.875rem .25rem;font-size:.95rem;font-weight:600;display:flex;position:relative}.tab-btn:hover,.tab-btn.active{color:var(--color-primary)}.tab-btn.active:after{content:"";background:var(--color-primary);height:2px;box-shadow:0 0 8px var(--color-primary-glow);border-radius:99px;position:absolute;bottom:-2px;left:0;right:0}.data-table-wrap{border-radius:var(--radius-md);border:1px solid #0000000d;overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;white-space:nowrap;background:#fff;width:100%}.data-table th{text-transform:uppercase;color:var(--color-text-muted);background:#f9fafb;padding:1rem 1.25rem;font-size:.72rem;font-weight:700}.data-table td{vertical-align:middle;border-top:1px solid #0000000d;padding:1rem 1.25rem;font-size:.9rem}.data-table tr:hover{background:#fcfdfe}@media (width<=768px){.mobile-desktop-table{display:none}.mobile-data-card-list{display:grid}.notifications-history-table{display:none}.notifications-history-card-list,.user-management-mobile-list{display:grid}}.status-paid{color:var(--color-success);font-weight:700}.status-unpaid{color:var(--color-absent);font-weight:700}.status-partial{color:var(--color-late);font-weight:700}.status-waived{color:var(--color-text-muted);font-style:italic}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:2000;background:#0c122073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);z-index:2001;background:#fff;max-height:94vh;position:relative;overflow-y:auto}@keyframes scaleUp{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.animate-scaleUp{animation:.3s cubic-bezier(.34,1.56,.64,1) both scaleUp}
