*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}button{font-family:inherit;cursor:pointer}*{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.12) transparent}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(var(--primary-rgb),.18);border:2px solid transparent;border-radius:8px;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:rgba(var(--primary-rgb),.35);background-clip:padding-box}*{scrollbar-color:rgba(var(--primary-rgb),.25) transparent}img{max-width:100%;height:auto;display:block}input,textarea,select{font-family:inherit;font-size:100%}:root{--primary: #000000;--primary-hover: #1a1a1a;--primary-dark: #000000;--primary-light: rgba(0, 0, 0, .05);--primary-focus: rgba(0, 0, 0, .2);--primary-alpha: rgba(0, 0, 0, .1);--accent-color: #000000;--primary-rgb: 0, 0, 0;--bg-hover: rgba(0, 0, 0, .04);--bg-warning: var(--warning-bg);--text-warning: var(--warning-dark);--bg-danger: var(--error-bg);--text-danger: var(--error-dark);--gray-50: #fafafa;--gray-100: #f5f5f5;--gray-200: #e5e5e5;--gray-300: #d4d4d4;--gray-400: #a3a3a3;--gray-500: #737373;--gray-600: #525252;--gray-700: #404040;--gray-800: #262626;--gray-900: #171717;--success: #10b981;--success-dark: #059669;--success-bg: #ecfdf5;--success-light: rgba(16, 185, 129, .1);--error: #ef4444;--error-dark: #dc2626;--error-bg: #fef2f2;--danger: #ef4444;--danger-hover: #dc2626;--danger-light: rgba(239, 68, 68, .1);--warning: #f59e0b;--warning-dark: #d97706;--warning-bg: #fffbeb;--warning-light: rgba(251, 191, 36, .1);--info: #3b82f6;--info-dark: #2563eb;--info-bg: #eff6ff;--info-light: rgba(59, 130, 246, .1);--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f5f5f6;--bg-elevated: #ffffff;--bg-veryless: #f3f4f669;--text-primary: #171717;--text-secondary: #525252;--text-tertiary: #a3a3a3;--text-disabled: #d4d4d4;--border-primary: #e5e5e5;--border-secondary: #d4d4d4;--border-focus: #000000;--border-color: #e5e5e5;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--sidebar-width: 240px;--sidebar-collapsed: 64px;--header-height: 64px;--max-content-width: 1400px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", "Courier New", monospace;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-sticky-table-header: 12;--z-sticky-table-corner: 14;--z-sticky-filters: 11;--z-sticky-cell: 9;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--font-scale: 1;--font-size-xs: calc(.75rem * var(--font-scale, 1));--font-size-sm: calc(.8125rem * var(--font-scale, 1));--font-size-base: calc(.875rem * var(--font-scale, 1));--font-size-md: calc(1rem * var(--font-scale, 1));--font-size-lg: calc(1.125rem * var(--font-scale, 1));--font-size-xl: calc(1.25rem * var(--font-scale, 1));--font-size-2xl: calc(1.5rem * var(--font-scale, 1));--color-primary: var(--accent-color, var(--primary));--color-success: var(--success);--color-danger: var(--danger);--color-warning: var(--warning);--color-info: var(--info)}.dark,[data-theme=dark]{--primary: #ffffff;--primary-hover: #e5e5e5;--primary-dark: #ffffff;--primary-light: rgba(255, 255, 255, .1);--primary-focus: rgba(255, 255, 255, .2);--primary-alpha: rgba(255, 255, 255, .1);--primary-rgb: 255, 255, 255;--bg-hover: rgba(255, 255, 255, .06);--accent-color: #ffffff;--gray-50: #171717;--gray-100: #262626;--gray-200: #404040;--gray-300: #525252;--gray-400: #737373;--gray-500: #a3a3a3;--gray-600: #d4d4d4;--gray-700: #e5e5e5;--gray-800: #f5f5f5;--gray-900: #fafafa;--success-bg: rgba(16, 185, 129, .15);--success-light: rgba(16, 185, 129, .15);--error-bg: #7f1d1d;--warning-bg: #78350f;--warning-light: rgba(251, 191, 36, .15);--danger-light: rgba(239, 68, 68, .15);--info-bg: #1e3a8a;--info-light: rgba(59, 130, 246, .15);--bg-primary: #000000;--bg-secondary: #0a0a0a;--bg-tertiary: #141414;--bg-elevated: #1a1a1a;--text-primary: #fafafa;--text-secondary: #a3a3a3;--text-tertiary: #737373;--text-disabled: #404040;--border-primary: #262626;--border-secondary: #404040;--border-focus: #ffffff;--border-color: #262626;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .4);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .6);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .7);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .8)}body{font-family:var(--font-sans);background:var(--bg-primary);background-image:var(--app-bg-image, none);background-size:var(--app-bg-size, cover);background-attachment:fixed;color:var(--text-primary);line-height:1.6;transition:background-color var(--transition-base),color var(--transition-base);min-height:100vh;overflow-x:hidden}body.modal-open{overflow:hidden}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.spin{animation:spin 1s linear infinite}.app-container{display:flex;min-height:100vh;background:var(--bg-primary)}.page-content{padding:var(--space-md);max-width:var(--max-content-width);margin:0 auto;width:100%}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--bg-elevated);border-right:1px solid var(--border-primary);box-shadow:var(--shadow-sm);transition:width var(--transition-slow);z-index:var(--z-fixed);display:flex;flex-direction:column;overflow:hidden}.sidebar-collapsed{width:var(--sidebar-collapsed)}.sidebar-right{left:auto;right:0;border-right:none;border-left:1px solid var(--border-primary)}.sidebar-header{padding:var(--space-md);border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;min-height:var(--header-height);gap:var(--space-sm);flex-shrink:0}.sidebar-collapsed .sidebar-header{justify-content:center;padding:var(--space-sm)}.sidebar-collapsed .sidebar-header>.brand-icon-box{display:none}.sidebar-collapsed .sidebar-toggle{width:36px;height:36px;min-width:36px;min-height:36px}.sidebar-brand{display:flex;align-items:center;gap:.625rem;overflow:hidden;min-width:0}.brand-icon-box{width:32px;height:32px;border-radius:var(--radius-lg);background:var(--accent-color, var(--primary));display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.brand-text{overflow:hidden}.brand-name{font-weight:700;font-size:.9375rem;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:155px}.brand-role{font-size:.6875rem;color:var(--text-secondary);margin:0}.sidebar-toggle{width:30px;height:30px;min-width:30px;min-height:30px;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);flex-shrink:0}.sidebar-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-secondary)}.sidebar-toggle:active{transform:scale(.95)}.sidebar-nav{flex:1;min-height:0;padding:.5rem;display:flex;flex-direction:column;gap:2px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-secondary) transparent}.nav-item{width:100%;display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:400;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);text-align:left;white-space:nowrap;overflow:hidden;line-height:1.3;flex-shrink:0}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item:active{transform:scale(.98)}.nav-item-active{background:var(--accent-color, var(--primary));color:var(--bg-primary);font-weight:600;box-shadow:0 2px 8px #00000026}.nav-item-active:hover{background:var(--accent-color, var(--primary));color:var(--bg-primary);filter:brightness(1.08)}.sidebar-collapsed .nav-item{padding:.5rem;justify-content:center;border-radius:var(--radius-md)}.nav-icon{width:18px;height:18px;flex-shrink:0}.nav-label{overflow:hidden;text-overflow:ellipsis;flex:1 1 auto}.nav-item-group{display:flex;flex-direction:column}.nav-item-parent .nav-caret{display:inline-flex;align-items:center;justify-content:center;margin-left:auto;opacity:.7;flex-shrink:0;transition:transform var(--transition-fast),opacity var(--transition-fast)}.nav-item-parent:hover .nav-caret{opacity:1}.sidebar-collapsed .nav-caret{display:none}.nav-submenu{display:flex;flex-direction:column;gap:2px;padding:4px 0 6px 10px;margin-left:18px;border-left:1px solid var(--border-primary);animation:nav-submenu-slide .18s ease-out}@keyframes nav-submenu-slide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.nav-subitem{display:flex;align-items:center;gap:.5rem;width:100%;padding:.35rem .75rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:.8125rem;font-weight:400;cursor:pointer;text-align:left;white-space:nowrap;overflow:hidden;transition:background var(--transition-fast),color var(--transition-fast)}.nav-subitem:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-subitem-active{background:var(--accent-color, var(--primary));color:var(--bg-primary);font-weight:600}.nav-subitem-active:hover{background:var(--accent-color, var(--primary));color:var(--bg-primary);filter:brightness(1.08)}.nav-subicon{width:14px;height:14px;flex-shrink:0;opacity:.85}.nav-sublabel{overflow:hidden;text-overflow:ellipsis}.sidebar-collapsed .nav-submenu,.sidebar-collapsed .nav-label{display:none}.sidebar-footer{padding:.5rem;border-top:1px solid var(--border-primary);display:flex;gap:2px;flex-direction:column;flex-shrink:0}.sidebar-dm-toggle{display:flex;justify-content:flex-start;padding:0 .375rem}.sidebar-collapsed .sidebar-dm-toggle{justify-content:center;padding:0}.logout-btn{width:100%;display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--danger);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.sidebar-collapsed .logout-btn{padding:.5rem;justify-content:center}.logout-btn:hover{background:var(--danger-light);color:var(--danger-hover)}.logout-btn:active{transform:scale(.98)}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:calc(var(--z-fixed) - 1);cursor:pointer;opacity:0;transition:opacity var(--transition-base)}.sidebar-backdrop.active{display:block;opacity:1}.main-content{flex:1;margin-left:var(--sidebar-width);transition:margin var(--transition-slow);min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);overflow-x:hidden}.main-content-collapsed{margin-left:var(--sidebar-collapsed)}.sidebar-right~.main-content{margin-left:0;margin-right:var(--sidebar-width)}.sidebar-right.sidebar-collapsed~.main-content{margin-right:var(--sidebar-collapsed)}.page-header{margin-bottom:var(--space-xl);display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:var(--space-lg)}.page-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs);letter-spacing:-.02em;line-height:1.2}.page-subtitle{font-size:var(--font-size-base);color:var(--text-secondary);margin-top:var(--space-xs);font-weight:400;line-height:1.5}.page-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap}.card{background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-xs);margin-bottom:var(--space-lg);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-md)}.card-header{padding:var(--space-lg);border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap}.card-title{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.card-actions{display:flex;gap:var(--space-sm);align-items:center;flex-wrap:wrap}.card-body{padding:var(--space-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:.625rem 1.25rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--font-size-base);font-weight:500;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);white-space:nowrap;background:var(--bg-elevated);color:var(--text-primary);letter-spacing:-.01em;min-height:44px;text-decoration:none}.btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--border-secondary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-color, var(--text-primary));color:var(--bg-primary);border-color:var(--accent-color, var(--text-primary))}.btn-primary:hover:not(:disabled){background:var(--primary-hover, var(--accent-color, var(--primary)));border-color:var(--primary-hover, var(--accent-color, var(--primary)));filter:brightness(1.08);transform:translateY(-1px);box-shadow:var(--shadow-md),0 6px 18px rgba(var(--primary-rgb),.25)}.btn-primary:active:not(:disabled){filter:brightness(.95);transform:translateY(0)}.btn-secondary{background:transparent;color:var(--text-primary);border-color:var(--border-secondary)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover:not(:disabled){background:var(--success-dark);border-color:var(--success-dark)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger-hover);border-color:var(--danger-hover)}.btn-sm{padding:.5rem 1rem;font-size:var(--font-size-sm);min-height:36px}.btn-lg{padding:.875rem 1.75rem;font-size:.9375rem;min-height:48px}.btn-full{width:100%}.btn-icon{width:16px;height:16px}.form-label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm);letter-spacing:.01em;text-transform:uppercase}.form-input,.form-select{width:100%;padding:.75rem 1rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:.9375rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);min-height:44px}.form-input:focus,.form-select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-focus)}.form-input::placeholder{color:var(--text-tertiary)}.form-input-error{border-color:var(--error)}.form-input-error:focus{box-shadow:0 0 0 3px var(--error-bg)}select{max-width:100%;padding:.625rem .875rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--font-size-base);line-height:1.4;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-focus)}select:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-tertiary)}input:where(:not([type]),[type=text],[type=email],[type=password],[type=number],[type=search],[type=tel],[type=url],[type=date],[type=time],[type=datetime-local],[type=month],[type=week]),textarea{max-width:100%;padding:.625rem .875rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--font-size-base);line-height:1.4;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}textarea{min-height:80px;resize:vertical}input:where(:not([type]),[type=text],[type=email],[type=password],[type=number],[type=search],[type=tel],[type=url],[type=date],[type=time],[type=datetime-local],[type=month],[type=week]):focus,textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-focus)}.form-error{margin-top:var(--space-sm);font-size:var(--font-size-sm);color:var(--error);font-weight:500}.form-grid{display:grid;grid-template-columns:1fr;gap:var(--space-lg)}.filter-input{padding:.625rem .75rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);font-size:var(--font-size-base);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.filter-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.filters-row,.filters-row-payment{display:flex;flex-direction:row;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;align-items:center}.filters-row>*,.filters-row-payment>*{flex:0 1 auto}.filters-row .form-select,.filters-row-payment .form-select{width:auto}.search-input-wrapper{position:relative;flex:1 1 180px;min-width:150px}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-tertiary);pointer-events:none}.search-input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-size-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);min-height:44px}.search-input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-focus)}.search-input::placeholder{color:var(--text-tertiary)}.search-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:background var(--transition-fast),color var(--transition-fast)}.search-clear:hover{background:var(--bg-secondary);color:var(--text-primary)}.filter-select{flex:0 1 auto;width:auto;min-width:120px}.filter-select-sm{flex:0 1 auto;width:auto;min-width:100px;padding:.625rem .875rem;font-size:var(--font-size-base)}.sort-btn,.sort-btn-large{padding:.75rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);display:flex;align-items:center;gap:var(--space-sm);min-width:44px;min-height:44px;justify-content:center}.sort-btn-large{padding:.75rem 1rem;min-width:auto}.sort-btn:hover,.sort-btn-large:hover{background:var(--bg-tertiary);border-color:var(--border-secondary);color:var(--text-primary)}.sort-btn:active,.sort-btn-large:active{transform:scale(.95)}.sort-btn-active,.sort-btn-active:hover{background:var(--bg-tertiary);border-color:var(--border-secondary);color:var(--text-primary)}.sticky-filters{position:sticky;top:0;z-index:var(--z-sticky-filters);background:var(--bg-elevated);padding:var(--space-lg);margin:calc(var(--space-lg) * -1);margin-bottom:var(--space-lg);border-bottom:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.stats-grid{display:grid;grid-template-columns:1fr;gap:var(--space-lg);margin-bottom:var(--space-xl)}.stat-card{display:flex;justify-content:space-between;align-items:flex-start;background:var(--bg-elevated);border-radius:var(--radius-xl);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.stat-card-sm{padding:var(--space-md)}.stat-info{flex:1}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs);letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1.2}.stat-trend,.stat-subtitle{font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:500}.stat-icon{width:44px;height:44px;border-radius:var(--radius-lg);border:1px solid var(--border-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--bg-tertiary)}.stat-card--premium{padding:16px 18px;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:12px;width:100%;text-align:left;font:inherit;color:inherit;cursor:default;align-items:center;gap:12px;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease,background .15s ease}.stat-card--premium .stat-icon{background:color-mix(in srgb,var(--stat-accent, var(--accent-color, currentColor)) 14%,transparent);color:var(--stat-accent, var(--accent-color, currentColor));border:none}.stat-card--premium .stat-value{font-size:1.5rem;margin-bottom:2px}.stat-card--premium .stat-label{font-size:11px;margin-bottom:4px}.stat-card--premium .stat-trend{font-size:11.5px}.stat-card--clickable{cursor:pointer}.stat-card--clickable:hover{border-color:var(--stat-accent, var(--border-secondary));transform:translateY(-1px);box-shadow:0 8px 20px -8px #0000001a}.stat-card--clickable:active{transform:translateY(0)}.stat-card--clickable:focus-visible{outline:none;border-color:var(--stat-accent, var(--accent-color));box-shadow:0 0 0 3px color-mix(in srgb,var(--stat-accent, var(--accent-color)) 22%,transparent)}@media (max-width: 600px){.stat-card--premium{padding:12px 14px;gap:10px}.stat-card--premium .stat-value{font-size:1.25rem}.stat-card--premium .stat-icon{width:36px;height:36px}}@media (prefers-reduced-motion: reduce){.stat-card--premium,.stat-card--clickable:hover{transform:none!important;transition:none!important}}.dashboard-charts{display:grid;grid-template-columns:1fr;gap:var(--space-lg);margin-bottom:var(--space-xl)}.dashboard-lists{display:grid;grid-template-columns:1fr;gap:var(--space-lg)}.table-container{overflow-x:auto;border-radius:var(--radius-xl);border:1px solid var(--border-primary);background:var(--bg-elevated);box-shadow:var(--shadow-xs);-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.12) transparent}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-base)}.table thead{background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary)}.table th{padding:.875rem 1rem;text-align:left;font-weight:600;color:var(--text-secondary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.table td{padding:1rem;border-bottom:1px solid var(--border-primary);color:var(--text-primary);font-variant-numeric:tabular-nums}.table tbody tr:last-child td{border-bottom:none}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--bg-secondary)}.table tfoot{background:var(--bg-tertiary);font-weight:600;border-top:2px solid var(--border-primary)}.fee-table-container{overflow:hidden;border-radius:var(--radius-lg)}.fee-table-wrapper{overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 280px)}.fee-table{width:100%;border-collapse:collapse;font-size:var(--font-size-base)}.fee-table thead{position:sticky;top:0;z-index:var(--z-sticky-table-header);background:var(--bg-elevated)}.fee-table th{padding:.75rem;text-align:center;font-weight:600;border:1px solid var(--border-primary);background:var(--bg-tertiary);white-space:nowrap}.fee-table td{padding:.75rem;border:1px solid var(--border-primary);white-space:nowrap}.fee-header-sticky{position:sticky;left:0;z-index:var(--z-sticky-table-corner);background:var(--bg-tertiary);min-width:150px}.fee-header-year{background:var(--bg-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.fee-header-year:hover{background:var(--bg-tertiary)}.fee-header-collapsed{writing-mode:vertical-rl;text-orientation:mixed;padding:.5rem;min-width:40px}.fee-header-term{font-size:var(--font-size-xs);font-weight:500}.fee-cell-sticky{position:sticky;left:0;z-index:var(--z-sticky-cell);background:var(--bg-elevated)}.fee-cell-center{text-align:center}.fee-header-amount{position:sticky;right:120px;z-index:var(--z-sticky-table-corner);background:var(--bg-tertiary);min-width:120px}.fee-header-actions{position:sticky;right:0;z-index:var(--z-sticky-table-corner);background:var(--bg-tertiary);min-width:120px}.fee-cell-amount{position:sticky;right:120px;z-index:var(--z-sticky-cell);background:var(--bg-elevated);text-align:center}.fee-cell-actions{position:sticky;right:0;z-index:var(--z-sticky-cell);background:var(--bg-elevated);text-align:center}.fee-cell-collapsed{background:var(--bg-tertiary);color:var(--text-tertiary);font-size:var(--font-size-xs);min-width:40px}.fee-student-name{font-weight:600;text-align:left}.fee-input{width:100px;padding:.5rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--font-size-base);text-align:center;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.fee-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.fee-actions{display:flex;gap:.5rem;justify-content:center}.fee-btn{padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);cursor:pointer;font-size:var(--font-size-base);font-weight:500;transition:background var(--transition-fast),border-color var(--transition-fast);display:flex;align-items:center;gap:.25rem}.fee-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-secondary)}.fee-btn:disabled{opacity:.5;cursor:not-allowed}.fee-btn-pay{background:var(--success);color:#fff;border-color:var(--success)}.fee-btn-pay:hover:not(:disabled){background:var(--success-dark)}.fee-btn-msg{background:var(--accent-color, var(--primary));color:var(--bg-primary);border-color:var(--accent-color, var(--primary))}.fee-btn-msg:hover:not(:disabled){background:var(--accent-color, var(--primary));color:var(--bg-primary);filter:brightness(1.08)}.fee-btn-edit{background:var(--warning);color:#fff;border-color:var(--warning)}.fee-btn-edit:hover:not(:disabled){background:var(--warning-dark)}.action-buttons,.action-buttons-group{display:flex;gap:var(--space-sm);justify-content:center;flex-wrap:wrap}.action-btn{width:36px;height:36px;min-width:36px;min-height:36px;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:transform var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);display:flex;align-items:center;justify-content:center}.action-btn:hover{transform:scale(1.05);background:var(--bg-tertiary);border-color:var(--border-secondary)}.action-btn:active{transform:scale(.95)}.action-btn-edit:hover{color:var(--info)}.action-btn-delete:hover{color:var(--error)}.action-btn-delete{color:var(--danger);border-color:var(--danger)}.action-btn-delete:hover:not(:disabled){background:var(--danger-light);border-color:var(--danger)}.action-btn-delete:disabled{opacity:.5;cursor:not-allowed}.action-btn-warning{color:var(--warning);border-color:var(--warning)}.action-btn-warning:hover:not(:disabled){background:var(--warning-light);border-color:var(--warning)}.action-btn-warning:disabled{opacity:.5;cursor:not-allowed}.team-action-btn{background:transparent;border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:.5rem;cursor:pointer;color:var(--text-secondary);transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);display:flex;align-items:center;justify-content:center}.team-action-btn:hover{background:var(--bg-tertiary);border-color:var(--border-secondary);color:var(--text-primary)}.team-action-btn-danger{border-color:var(--danger);color:var(--danger)}.team-action-btn-danger:hover{background:var(--error-bg);border-color:var(--danger)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--space-md);animation:fadeIn var(--transition-base);overflow-y:auto;isolation:isolate}.modal{background:var(--bg-elevated);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);max-height:90vh;width:100%;display:flex;flex-direction:column;overflow:hidden;animation:slideUp var(--transition-slow);border:1px solid var(--border-primary);margin:auto}.modal-sm{max-width:400px}.modal-md{max-width:600px}.modal-lg{max-width:900px}.modal-xl{width:90vw;max-width:1200px}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.modal-close{width:36px;height:36px;min-width:36px;min-height:36px;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-secondary)}.modal-close:active{transform:scale(.95)}.modal-body{padding:var(--space-lg);overflow-y:auto;min-height:0;flex:1 1 auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.modal-footer{padding:var(--space-lg);border-top:1px solid var(--border-primary);display:flex;justify-content:flex-end;gap:var(--space-sm);background:var(--bg-secondary);flex-shrink:0;flex-wrap:wrap}.alert{padding:1rem;border-radius:var(--radius-lg);display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-lg);border:1px solid var(--border-primary);background:var(--bg-tertiary)}.alert-success{background:var(--success-bg);border-color:var(--success);color:var(--success-dark)}.alert-error{background:var(--error-bg);border-color:var(--error);color:var(--error-dark)}.alert-warning{background:var(--warning-bg);border-color:var(--warning);color:var(--warning-dark)}.alert-info{background:var(--info-bg);border-color:var(--info);color:var(--info-dark)}.alert-icon{width:20px;height:20px;flex-shrink:0}.alert-content{flex:1;font-size:var(--font-size-base);line-height:1.5}.alert-close{width:24px;height:24px;min-width:24px;min-height:24px;border-radius:var(--radius-sm);border:none;background:transparent;color:currentColor;cursor:pointer;transition:opacity var(--transition-fast),background var(--transition-fast);display:flex;align-items:center;justify-content:center;opacity:.6}.alert-close:hover{opacity:1;background:#0000001a}.loading-container,.loading-page{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);gap:var(--space-md);color:var(--text-secondary)}.loading-page{min-height:400px}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--text-secondary)}.empty-state-large{padding:4rem var(--space-xl)}.empty-icon{width:64px;height:64px;margin:0 auto var(--space-lg);color:var(--text-tertiary);opacity:.5}.empty-text{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.empty-subtext{font-size:var(--font-size-base);color:var(--text-secondary);margin-bottom:var(--space-lg);line-height:1.5}.empty-state__action{margin-top:var(--space-md)}.loading-spinner-icon{color:var(--accent-color, var(--primary))}.loading-text{font-size:var(--font-size-base);color:var(--text-secondary);margin:0}.badge{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;border-radius:var(--radius-full);font-weight:600;line-height:1;white-space:nowrap;vertical-align:middle;max-width:100%}.badge>svg{flex-shrink:0;display:block}.badge-sm{padding:.1875rem .5rem;font-size:.6875rem}.badge-md{padding:.25rem .75rem;font-size:var(--font-size-xs)}.badge-lg{padding:.375rem 1rem;font-size:var(--font-size-sm)}.badge-default{background:var(--bg-tertiary);color:var(--text-secondary)}.badge-success{background:var(--success-bg);color:var(--success-dark)}.badge-warning{background:var(--warning-bg);color:var(--warning-dark)}.badge-error{background:var(--error-bg);color:var(--error-dark)}.badge-info{background:var(--info-bg);color:var(--info-dark)}.badge-primary{background:var(--primary-light);color:var(--primary)}.tabs{border-bottom:1px solid var(--border-primary);margin-bottom:var(--space-lg)}.tabs__list{display:flex;gap:var(--space-md);overflow-x:auto}.tab{display:flex;align-items:center;gap:var(--space-sm);padding:.75rem 1rem;border:none;background:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast);white-space:nowrap;font-size:var(--font-size-base);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab:hover{color:var(--text-primary);background:rgba(var(--primary-rgb),.04);border-bottom-color:var(--border-secondary)}.tab-active{border-bottom-color:var(--accent-color, var(--primary));color:var(--accent-color, var(--primary));font-weight:600}.info-field{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.info-field__label{font-size:var(--font-size-xs);font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.info-field__value{font-size:var(--font-size-base);color:var(--text-primary);font-weight:500}.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;overflow:hidden;flex-shrink:0;color:#fff}.avatar-sm{width:32px;height:32px;font-size:var(--font-size-xs)}.avatar-md{width:48px;height:48px;font-size:var(--font-size-md)}.avatar-lg{width:64px;height:64px;font-size:var(--font-size-2xl)}.avatar-xl{width:96px;height:96px;font-size:2rem}.avatar img{width:100%;height:100%;object-fit:cover}.icon-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);padding:0;flex-shrink:0;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),opacity var(--transition-fast)}.icon-btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn-sm{width:32px;height:32px}.icon-btn-md{width:40px;height:40px}.icon-btn-lg{width:48px;height:48px}.icon-btn-ghost{background:transparent;color:var(--text-secondary);border:none}.icon-btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.icon-btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary)}.icon-btn-secondary:hover:not(:disabled){background:var(--bg-tertiary)}.icon-btn-primary{background:var(--accent-color, var(--primary));color:var(--bg-primary);border:none}.icon-btn-primary:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 4px 12px rgba(var(--primary-rgb),.28)}.icon-btn-danger{background:transparent;color:var(--danger);border:none}.icon-btn-danger:hover:not(:disabled){background:var(--danger-light)}.toast-container{position:fixed;top:var(--space-md);right:var(--space-md);z-index:var(--z-tooltip);display:flex;flex-direction:column;gap:.75rem;max-width:400px}.toast{display:flex;align-items:flex-start;gap:.75rem;padding:var(--space-md);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:300px;animation:slideIn var(--transition-slow)}.toast-success{background:var(--success-bg);border:1px solid var(--success)}.toast-error{background:var(--error-bg);border:1px solid var(--error)}.toast-warning{background:var(--warning-bg);border:1px solid var(--warning)}.toast-info{background:var(--info-bg);border:1px solid var(--info)}.toast__icon{flex-shrink:0;margin-top:2px}.toast__content{flex:1;font-size:var(--font-size-base);color:var(--text-primary);line-height:1.5}.toast__close{background:transparent;border:none;cursor:pointer;padding:0;color:var(--text-tertiary);flex-shrink:0;transition:color var(--transition-fast)}.toast__close:hover{color:var(--text-primary)}.donut-chart{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.donut-chart__empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-secondary)}.donut-chart__center-text{font-size:var(--font-size-xl);font-weight:700;fill:var(--text-primary)}.donut-chart__legend{display:flex;flex-direction:column;gap:var(--space-sm)}.donut-chart__legend-item{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-base)}.donut-chart__legend-color{width:12px;height:12px;border-radius:2px;flex-shrink:0}.donut-chart__legend-label{color:var(--text-primary)}.password-wrapper{position:relative}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;padding:.25rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.password-toggle:hover{color:var(--text-primary)}.password-strength{margin-top:var(--space-sm)}.password-strength__bar{height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden;margin-bottom:.25rem}.password-strength__fill{height:100%;transition:width var(--transition-slow),background var(--transition-slow)}.password-strength__label{font-size:var(--font-size-xs);font-weight:500}.form-group{margin-bottom:var(--space-md)}.form-label--error{color:var(--danger)}.form-required{color:var(--danger);margin-left:.25rem}.form-hint{margin-top:.25rem;font-size:var(--font-size-xs);color:var(--text-secondary)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-xl);background:var(--bg-primary)}.login-dark-toggle{position:absolute;top:var(--space-lg);right:var(--space-lg)}.login-card{width:100%;max-width:440px}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-icon{width:64px;height:64px;margin:0 auto var(--space-lg);padding:var(--space-md);border-radius:var(--radius-2xl);border:2px solid var(--border-primary);background:var(--bg-elevated);color:var(--text-primary);display:flex;align-items:center;justify-content:center}.login-title{font-size:1.75rem;font-weight:700;margin-bottom:var(--space-sm);color:var(--text-primary);letter-spacing:-.02em}.login-subtitle{font-size:var(--font-size-base);color:var(--text-secondary);line-height:1.5}.login-form{margin-bottom:var(--space-lg)}.login-footer{text-align:center;padding-top:var(--space-lg);border-top:1px solid var(--border-primary)}.login-toggle{background:none;border:none;color:var(--text-primary);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:color var(--transition-fast);text-decoration:underline;text-underline-offset:2px;padding:0;min-height:auto}.login-toggle:hover{color:var(--text-secondary)}.payment-list,.defaulter-list,.reminder-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:400px;overflow-y:auto;overflow-x:hidden;padding-right:var(--space-xs)}.payment-item,.defaulter-item,.reminder-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);transition:background var(--transition-fast),border-color var(--transition-fast);gap:var(--space-md)}.payment-item:hover,.defaulter-item:hover,.reminder-item:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.payment-name,.defaulter-name,.reminder-name{font-weight:500;color:var(--text-primary);margin-bottom:var(--space-xs)}.payment-date,.defaulter-contact,.reminder-details{font-size:var(--font-size-sm);color:var(--text-secondary)}.payment-amount{font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.amount-paid{color:var(--success);font-weight:600}.amount-due{color:var(--danger);font-weight:600}.defaulter-filters{display:flex;gap:var(--space-sm);align-items:center;flex-wrap:wrap}.status-badge{padding:.375rem .75rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;border:1px solid currentColor;display:inline-block}.status-success{background:var(--success-bg);color:var(--success-dark);border-color:var(--success)}.status-error,.status-failed{background:var(--error-bg);color:var(--error-dark);border-color:var(--error)}.status-pending,.status-warning{background:var(--warning-bg);color:var(--warning-dark);border-color:var(--warning)}.status-info{background:var(--info-bg);color:var(--info-dark);border-color:var(--info)}.settings-layout{display:grid;grid-template-columns:260px 1fr;gap:var(--space-xl);align-items:start}.settings-sidebar{position:sticky;top:var(--space-xl);display:flex;flex-direction:column;gap:2px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-sm);max-height:calc(100vh - var(--space-xl) * 2);overflow-y:auto;overflow-x:hidden}.settings-tab{display:flex;align-items:center;gap:var(--space-md);padding:.625rem var(--space-md);border:none;border-left:3px solid transparent;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:var(--font-size-base);font-weight:500;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);text-align:left;width:100%}.settings-tab:hover{background:var(--bg-tertiary);color:var(--text-primary);border-left-color:var(--border-secondary)}.settings-tab-active{background:var(--bg-primary);color:var(--color-primary);font-weight:600;border-left-color:var(--color-primary);box-shadow:0 1px 3px #0000000f}.settings-tab-active .settings-tab-icon{color:var(--color-primary)}.settings-tab-icon{width:18px;height:18px;flex-shrink:0;transition:color var(--transition-fast)}.settings-content{min-height:400px}.set__sidebar-divider{border:none;border-top:1px solid var(--border-primary);margin:.25rem 0}.set__sidebar-logout-btn{color:var(--danger)!important}.set__sidebar-logout-btn:hover{background:var(--danger-light)!important;color:var(--danger-hover)!important;border-left-color:var(--danger)!important}.settings-form{display:flex;flex-direction:column;gap:var(--space-lg)}.icon-xs{width:14px;height:14px}.icon-sm{width:16px;height:16px}.icon-md{width:20px;height:20px}.icon-lg{width:24px;height:24px}.icon-xl{width:32px;height:32px}.icon-xxl{width:48px;height:48px}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--space-xs)}.mb-2{margin-bottom:var(--space-sm)}.mb-3{margin-bottom:var(--space-md)}.mb-4{margin-bottom:var(--space-lg)}.mb-5{margin-bottom:var(--space-xl)}.mt-1{margin-top:var(--space-xs)}.mt-2{margin-top:var(--space-sm)}.mt-3{margin-top:var(--space-md)}.mt-4{margin-top:var(--space-lg)}.gap-1{gap:var(--space-xs)}.gap-2{gap:var(--space-sm)}.gap-3{gap:var(--space-md)}.gap-4{gap:var(--space-lg)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-row{display:flex;flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-start{display:flex;align-items:flex-start}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.shrink-0{flex-shrink:0}.min-w-0{min-width:0}.grid{display:grid}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:1.75rem}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-info{color:var(--info)}.text-right{text-align:right}.text-center{text-align:center}.text-left{text-align:left}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.tabular-nums{font-variant-numeric:tabular-nums}.bg-primary{background:var(--bg-primary)}.bg-secondary{background:var(--bg-secondary)}.bg-tertiary{background:var(--bg-tertiary)}.bg-elevated{background:var(--bg-elevated)}.bg-success-light{background:var(--success-bg)}.bg-danger-light{background:var(--error-bg)}.bg-warning-light{background:var(--warning-bg)}.bg-info-light{background:var(--info-bg)}.border{border:1px solid var(--border-primary)}.border-b{border-bottom:1px solid var(--border-primary)}.border-t{border-top:1px solid var(--border-primary)}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.relative{position:relative}.absolute{position:absolute}.sticky{position:sticky}.transition{transition:all var(--transition-fast)}.hidden{display:none}.pointer-events-none{pointer-events:none}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.p-2{padding:var(--space-sm)}.p-3{padding:var(--space-md)}.p-4{padding:var(--space-lg)}.px-3{padding-left:var(--space-md);padding-right:var(--space-md)}.py-2{padding-top:var(--space-sm);padding-bottom:var(--space-sm)}.py-3{padding-top:var(--space-md);padding-bottom:var(--space-md)}.action-center{display:flex;justify-content:center;margin:var(--space-xl) 0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}*:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (min-width: 768px){.page-content{padding:var(--space-xl)}.page-title{font-size:1.75rem}.stat-value{font-size:1.875rem}.stats-grid,.dashboard-charts,.form-grid{grid-template-columns:repeat(2,1fr)}.sidebar-backdrop{display:none!important}}@media (max-width: 768px){.grid-auto,.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}}@media (min-width: 1024px){.stats-grid{grid-template-columns:repeat(4,1fr)}.dashboard-charts{grid-template-columns:repeat(3,1fr)}.dashboard-lists{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1280px){.page-content{padding:var(--space-2xl)}}@media (max-width: 767px){.page-header{flex-direction:column;align-items:stretch}.page-actions{width:100%;flex-direction:row;flex-wrap:wrap}.page-actions>*{flex:1 1 auto;min-width:0}.page-actions .btn{flex:1}.filters-row,.filters-row-payment{flex-direction:row;flex-wrap:wrap;align-items:center;gap:var(--space-sm)}.filters-row>*,.filters-row-payment>*{flex:1 1 auto;min-width:0}.search-input-wrapper{flex:2 1 140px;min-width:120px}.filter-select{flex:1 1 100px;min-width:80px}.card-header{flex-direction:column;align-items:stretch}.card-actions{width:100%}.table-container:after{content:"←Scroll →";display:block;text-align:center;padding:var(--space-sm);font-size:var(--font-size-xs);color:var(--text-tertiary);background:var(--bg-secondary)}.modal-overlay{padding:0}.modal{margin:var(--space-sm);max-height:calc(100vh - 1rem)}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%}.sidebar-backdrop.active{display:block}.settings-layout{grid-template-columns:1fr}.settings-sidebar{position:static;flex-direction:row;padding:var(--space-xs);gap:4px;border-radius:var(--radius-md);max-height:none;overflow-x:auto;overflow-y:visible}.settings-tab{min-width:max-content;border-left:none;border-bottom:3px solid transparent;border-radius:var(--radius-sm);white-space:nowrap;padding:var(--space-sm) var(--space-md)}.settings-tab:hover{border-left-color:transparent;border-bottom-color:var(--border-secondary)}.settings-tab-active{border-left-color:transparent;border-bottom-color:var(--color-primary)}.fee-table-wrapper{max-height:500px}.fee-table{font-size:var(--font-size-xs)}.fee-table th,.fee-table td{padding:.5rem}.fee-input{width:80px}}@media (max-width: 480px){html{font-size:14px}.page-title,.stat-value{font-size:var(--font-size-xl)}.btn{font-size:var(--font-size-sm)}}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:calc(var(--z-modal-backdrop, 1040) + 20);padding:var(--space-md, 16px);animation:fadeIn var(--transition-base, .2s);isolation:isolate;overflow-y:auto}.confirm-modal{background:var(--bg-elevated, #fff);border-radius:var(--radius-2xl, 16px);box-shadow:var(--shadow-xl, 0 20px 60px rgba(0,0,0,.3));max-width:400px;width:100%;max-height:90vh;overflow-y:auto;margin:auto;padding:28px 24px 20px;text-align:center;animation:slideUp var(--transition-slow, .3s);border:1px solid var(--border-primary, #e5e7eb)}.confirm-modal__icon-wrap{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;background:var(--bg-warning, #fef3c7);color:var(--text-warning, #d97706)}.confirm-modal__icon-wrap[data-danger]{background:var(--bg-danger, #fee2e2);color:var(--text-danger, #dc2626)}.confirm-modal__title{font-size:18px;font-weight:600;margin:0 0 8px;color:var(--text-primary, #111827)}.confirm-modal__message{font-size:14px;color:var(--text-secondary, #6b7280);margin:0 0 24px;line-height:1.5}.confirm-modal__actions{display:flex;gap:12px}.confirm-modal__btn{flex:1;padding:10px 16px;border-radius:var(--radius-lg, 10px);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .15s}.confirm-modal__btn:disabled{opacity:.6;cursor:not-allowed}.confirm-modal__btn--cancel{background:var(--bg-secondary, #f3f4f6);color:var(--text-primary, #374151)}.confirm-modal__btn--cancel:hover:not(:disabled){background:var(--bg-tertiary, #e5e7eb)}.confirm-modal__btn--confirm{background:var(--color-primary, #000);color:#fff}.confirm-modal__btn--confirm:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 4px 12px rgba(var(--primary-rgb),.28)}.confirm-modal__btn--danger{background:var(--color-danger, #dc2626);color:#fff}.confirm-modal__btn--danger:hover:not(:disabled){background:#b91c1c}@media print{.sidebar,.sidebar-backdrop,.page-actions,.filters-row,.action-buttons,.modal-overlay,.btn{display:none!important}.main-content{margin-left:0}.page-content{padding:0}.card{border:1px solid #000;box-shadow:none;page-break-inside:avoid}body{color:#000;background:#fff}.page-header,.card-header,.table thead,.table tfoot,.modal,.modal-header,.modal-footer{background:#fff!important;color:#000!important}.badge,.status-badge,.alert,.amount-paid,.amount-due,.text-success,.text-danger,.text-warning,.text-info,.print-keep-color{print-color-adjust:exact;-webkit-print-color-adjust:exact}}.sp{padding:var(--space-md);max-width:var(--max-content-width);margin:0 auto;width:100%;min-height:100vh}@media (min-width: 768px){.sp{padding:var(--space-xl)}}@media (min-width: 1280px){.sp{padding:var(--space-2xl)}}.sp__std-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;background:var(--accent-color, var(--primary));color:var(--bg-primary);border:none;border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:background var(--transition-fast),filter var(--transition-fast),transform .1s ease,box-shadow var(--transition-fast);box-shadow:0 2px 8px #00000026}.sp__std-btn:hover{background:var(--accent-color, var(--primary));color:var(--bg-primary);filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 4px 16px rgba(var(--primary-rgb),.25)}.sp__std-btn:active{transform:translateY(0)}.sp__std-btn-label{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sp__mark-all-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;background:#22c55e;color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:background var(--transition-fast),transform .1s ease,box-shadow var(--transition-fast);box-shadow:0 2px 8px #22c55e40;white-space:nowrap}.sp__mark-all-btn:hover{background:#16a34a;transform:translateY(-1px);box-shadow:0 4px 16px #22c55e4d}.sp__mark-all-btn:active{transform:translateY(0)}.sp__mark-all-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.sp__stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.sp__body{display:grid;grid-template-columns:1fr 3fr;gap:var(--space-lg);align-items:start}.sp__left{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden;position:sticky;top:var(--space-lg)}.sp__left-tabs{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--border-primary)}.sp__left-tab{display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.75rem .5rem;border:none;background:transparent;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast);border-bottom:2px solid transparent;margin-bottom:-1px}.sp__left-tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.sp__left-tab--active{color:var(--accent-color, var(--primary));font-weight:700;border-bottom-color:var(--accent-color, var(--primary));background:var(--bg-tertiary)}.sp__class-banner{display:flex;align-items:center;justify-content:space-between;padding:.5rem var(--space-md);background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary);gap:var(--space-sm)}.sp__class-banner-label{font-size:var(--font-size-xs);font-weight:600;color:var(--text-secondary)}.sp__class-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:var(--radius-full);background:rgba(var(--primary-rgb, 0, 0, 0),.12);border:1px solid rgba(var(--primary-rgb, 0, 0, 0),.25);color:var(--accent-color, var(--primary));font-size:var(--font-size-xs);font-weight:700}.sp__class-change-btn{font-size:.75rem;font-weight:700;color:var(--accent-color, var(--primary));background:rgba(var(--primary-rgb, 0, 0, 0),.1);border:1px solid rgba(var(--primary-rgb, 0, 0, 0),.25);cursor:pointer;padding:.3rem .7rem;border-radius:var(--radius-sm);transition:background var(--transition-fast);white-space:nowrap}.sp__class-change-btn:hover{background:rgba(var(--primary-rgb, 0, 0, 0),.2)}.sp__search-wrap{padding:var(--space-md);border-bottom:1px solid var(--border-primary)}.sp__search-wrap-inner{position:relative}.sp__search{width:100%;padding:.5rem .75rem .5rem 2.25rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);font-size:var(--font-size-sm);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.sp__search:focus{border-color:var(--accent-color, var(--primary));box-shadow:0 0 0 3px rgba(var(--primary-rgb, 0, 0, 0),.12)}.sp__search-icon{position:absolute;left:.65rem;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.sp__student-list{display:flex;flex-direction:column;max-height:60vh;overflow-y:auto;padding:var(--space-sm);gap:var(--space-xs)}.sp__student-item{display:flex;align-items:center;gap:var(--space-sm);padding:.65rem .75rem;border-radius:var(--radius-lg);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast);border:1px solid transparent}.sp__student-item:hover{background:var(--bg-tertiary);border-color:var(--border-primary)}.sp__student-item--active{background:var(--bg-tertiary);border-color:var(--accent-color, var(--primary))}.sp__student-avatar{width:38px;height:38px;border-radius:50%;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-base);color:var(--text-primary);overflow:hidden;flex-shrink:0}.sp__student-avatar img{width:100%;height:100%;object-fit:cover}.sp__student-meta{flex:1;min-width:0}.sp__student-name{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp__student-roll{font-size:var(--font-size-xs);color:var(--text-secondary)}.sp__student-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 2px var(--bg-secondary)}.sp__student-status-dot--present{background:var(--success, #22c55e)}.sp__student-status-dot--absent{background:var(--danger, #ef4444)}.sp__student-status-dot--halfday{background:var(--warning, #f59e0b)}.sp__student-status-dot--leave{background:#6366f1}.sp__student-status-dot--holiday{background:#ec4899}.sp__student-list-empty{padding:var(--space-xl) var(--space-md);text-align:center;color:var(--text-tertiary);font-size:var(--font-size-sm);line-height:1.6}.sp__right{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);min-height:500px;overflow:hidden}.sp__right-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;gap:var(--space-md);color:var(--text-tertiary)}.sp__right-empty svg{opacity:.3}.sp__right-empty p{font-size:var(--font-size-base);color:var(--text-secondary);margin:0}.sp__cal{padding:var(--space-lg)}.sp__cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-sm)}.sp__cal-header h2{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin:0}.sp__cal-nav{display:flex;align-items:center;gap:var(--space-sm)}.sp__cal-nav-btn{width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.sp__cal-nav-btn:hover{background:var(--bg-elevated)}.sp__cal-month-label{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary);min-width:130px;text-align:center}.sp__cal-summary{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-lg)}.sp__cal-badge{display:flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.sp__cal-badge--present{background:#22c55e1f;color:#16a34a;border:1px solid rgba(34,197,94,.25)}.sp__cal-badge--absent{background:#ef44441f;color:#dc2626;border:1px solid rgba(239,68,68,.25)}.sp__cal-badge--halfday{background:#f59e0b1f;color:#d97706;border:1px solid rgba(245,158,11,.25)}.sp__cal-badge--leave{background:#6366f11f;color:#6366f1;border:1px solid rgba(99,102,241,.25)}.sp__cal-badge--holiday{background:#ec48991f;color:#ec4899;border:1px solid rgba(236,72,153,.25)}.dark .sp__cal-badge--present{color:#4ade80}.dark .sp__cal-badge--absent{color:#f87171}.dark .sp__cal-badge--halfday{color:#fbbf24}.dark .sp__cal-badge--leave{color:#a5b4fc}.dark .sp__cal-badge--holiday{color:#f472b6}.sp__cal-grid-header{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:.35rem}.sp__cal-day-label{text-align:center;font-size:.7rem;font-weight:600;color:var(--text-tertiary);padding:.25rem 0;text-transform:uppercase;letter-spacing:.05em}.sp__cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.sp__cal-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;position:relative;-webkit-user-select:none;user-select:none}.sp__cal-cell:hover{transform:scale(1.08);z-index:1;box-shadow:0 2px 8px #00000026}.sp__cal-cell--empty{cursor:default;pointer-events:none}.sp__cal-cell--sunday{color:var(--text-tertiary);background:var(--bg-tertiary);opacity:.5;cursor:default;pointer-events:none}.sp__cal-cell--today{outline:2px solid var(--accent-color, var(--primary));outline-offset:1px}.sp__cal-cell--present{background:#22c55e33;color:#16a34a;border:1px solid rgba(34,197,94,.35)}.sp__cal-cell--absent{background:#ef444426;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.sp__cal-cell--halfday{background:#f59e0b26;color:#d97706;border:1px solid rgba(245,158,11,.3)}.sp__cal-cell--leave{background:#6366f126;color:#6366f1;border:1px solid rgba(99,102,241,.3)}.sp__cal-cell--holiday{background:#ec489926;color:#ec4899;border:1px solid rgba(236,72,153,.3)}.dark .sp__cal-cell--present{color:#4ade80}.dark .sp__cal-cell--absent{color:#f87171}.dark .sp__cal-cell--halfday{color:#fbbf24}.dark .sp__cal-cell--leave{color:#a5b4fc}.dark .sp__cal-cell--holiday{color:#f472b6}.sp__day-popup{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--bg-elevated, #fff);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);box-shadow:0 8px 32px #0000002e;padding:.5rem;z-index:100;min-width:175px;display:flex;flex-direction:column;gap:.2rem}.sp__cal-grid>.sp__cal-cell:nth-child(-n+7) .sp__day-popup{bottom:auto;top:calc(100% + 6px)}.sp__cal-grid>.sp__cal-cell:nth-child(7n+1) .sp__day-popup{left:0;transform:none}.sp__cal-grid>.sp__cal-cell:nth-child(7n) .sp__day-popup{left:auto;right:0;transform:none}.sp__day-popup-title{font-size:.7rem;font-weight:600;color:var(--text-tertiary);padding:.2rem .5rem .4rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-primary);margin-bottom:.2rem}.sp__day-popup-btn{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;border:none;background:transparent;border-radius:var(--radius-md);font-size:.78rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast);text-align:left}.sp__day-popup-btn:hover{background:var(--bg-tertiary)}.sp__day-popup-notify-icon{margin-left:auto;color:var(--text-tertiary);opacity:.6}.sp__day-popup-divider{height:1px;background:var(--border-primary);margin:.2rem .5rem}.sp__day-popup-btn--holiday-all{font-weight:600;font-size:.72rem}.sp__cal-legend{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.sp__cal-legend-item{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--text-secondary)}.sp__cal-legend-swatch{width:10px;height:10px;border-radius:2px;display:inline-block}.sp__cal-legend-swatch--today{border:2px solid var(--primary);background:transparent}.sp__details{padding:var(--space-lg)}.sp__details-profile{display:flex;align-items:flex-start;gap:var(--space-lg);margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-primary);flex-wrap:wrap}.sp__details-avatar{width:80px;height:80px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:var(--text-primary);overflow:hidden;border:3px solid var(--border-secondary);flex-shrink:0}.sp__details-avatar img{width:100%;height:100%;object-fit:cover}.sp__details-info{flex:1;min-width:200px}.sp__details-name{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.sp__details-sub{font-size:var(--font-size-base);color:var(--text-secondary);margin:0 0 var(--space-sm)}.sp__details-chips{display:flex;gap:.4rem;flex-wrap:wrap}.sp__chip{display:inline-flex;align-items:center;gap:var(--space-xs);padding:.2rem .6rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary)}.sp__chip--class{background:#6366f11a;border-color:#6366f140;color:#6366f1}.sp__chip--section{background:#10b9811a;border-color:#10b98140;color:#059669}.dark .sp__chip--class{color:#a5b4fc}.dark .sp__chip--section{color:#34d399}.sp__info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.sp__info-item label{display:block;font-size:.7rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs)}.sp__info-item span{font-size:var(--font-size-base);color:var(--text-primary);font-weight:500}.sp__section-header-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap}.sp__form-select{padding:.35rem .6rem;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-tertiary);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.sp__att-month-select{min-width:120px}.sp__att-bars{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);border:1px solid var(--border-primary);border-radius:var(--radius-lg);background:var(--bg-tertiary);margin-bottom:var(--space-lg)}.sp__att-bar-row{display:grid;grid-template-columns:120px 1fr 48px;align-items:center;gap:var(--space-sm)}.sp__att-bar-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp__att-bar-track{height:10px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden;border:1px solid var(--border-primary)}.sp__att-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-base),background var(--transition-base);min-width:2px}.sp__att-bar-value{font-size:var(--font-size-sm);font-weight:700;color:var(--text-primary);text-align:right;font-variant-numeric:tabular-nums}.sp__att-bar-total{display:flex;justify-content:space-between;align-items:center;border-top:1px dashed var(--border-primary);padding-top:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary)}.sp__att-bar-total strong{color:var(--text-primary);font-weight:700;font-variant-numeric:tabular-nums}@media (max-width: 480px){.sp__att-bar-row{grid-template-columns:90px 1fr 40px}}.sp__bio-panel{padding:var(--space-md);border:1px solid var(--border-primary);border-radius:var(--radius-lg);background:var(--bg-tertiary);margin-bottom:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm)}.sp__bio-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);flex-wrap:wrap}.sp__bio-header .sp__section-title{margin:0}.sp__bio-kiosk-link{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.sp__bio-kiosk-link:hover{background:var(--bg-elevated);border-color:var(--border-secondary)}.sp__bio-status{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md)}.sp__bio-status-row{display:flex;justify-content:space-between;font-size:var(--font-size-sm);color:var(--text-secondary)}.sp__bio-status-row strong{color:var(--text-primary);font-weight:600}.sp__bio-ok{color:var(--success, #16a34a)!important}.sp__bio-muted{color:var(--text-tertiary)!important}.sp__bio-pin{display:flex;flex-direction:column;gap:var(--space-xs)}.sp__bio-pin-label{font-size:var(--font-size-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.sp__bio-pin-row{display:flex;gap:var(--space-sm);align-items:center}.sp__bio-pin-input{flex:1;padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);letter-spacing:.3em;text-align:center}.sp__bio-pin-input:focus{border-color:var(--accent-color, var(--primary));box-shadow:0 0 0 3px rgba(var(--primary-rgb, 0, 0, 0),.12)}.sp__bio-pin-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem .9rem;background:var(--accent-color, var(--primary));color:var(--bg-primary);border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background var(--transition-fast),filter var(--transition-fast),opacity var(--transition-fast)}.sp__bio-pin-btn:hover:not(:disabled){background:var(--accent-color, var(--primary));color:var(--bg-primary);filter:brightness(1.08)}.sp__bio-pin-btn:disabled{opacity:.6;cursor:not-allowed}.sp__section-title{font-size:var(--font-size-md);font-weight:700;color:var(--text-primary);margin:0 0 var(--space-md);display:flex;align-items:center;gap:var(--space-sm)}.sp__att-pct-wrap{margin-bottom:var(--space-lg)}.sp__att-pct-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.sp__att-pct-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary)}.sp__att-pct-value{font-size:var(--font-size-base);font-weight:800;color:var(--text-primary)}.sp__att-pct-warning{font-size:var(--font-size-xs);color:#d97706;margin-top:.4rem;font-weight:500}.sp__progress-bar{height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.sp__progress-fill{height:100%;border-radius:var(--radius-full);transition:width .6s ease}.sp__modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-md);animation:sp-overlay-in .18s ease}@keyframes sp-overlay-in{0%{opacity:0}to{opacity:1}}.sp__modal{background:var(--bg-primary, #fff);border:1px solid var(--border-secondary);border-radius:var(--radius-2xl, 1.25rem);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #00000038;animation:sp-modal-in .22s cubic-bezier(.34,1.4,.64,1)}@keyframes sp-modal-in{0%{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.sp__modal--sm{max-width:420px}.sp__modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-primary);position:sticky;top:0;background:var(--bg-primary, #fff);z-index:1}.sp__modal-header h2{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin:0}.sp__modal-close{width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.sp__modal-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.sp__modal-body{padding:var(--space-lg)}.sp__modal-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0 0 var(--space-lg)}.sp__class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-sm)}.sp__class-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;padding:var(--space-md) var(--space-sm);border-radius:var(--radius-xl);border:2px solid var(--border-primary);background:var(--bg-tertiary);cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast),transform .1s ease,box-shadow .1s ease;text-align:center}.sp__class-card:hover{border-color:var(--accent-color, var(--primary));background:var(--bg-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.sp__class-card--active{border-color:var(--accent-color, var(--primary));background:rgba(var(--primary-rgb, 0, 0, 0),.08)}.sp__class-card-name{font-size:var(--font-size-md);font-weight:800;color:var(--text-primary)}.sp__class-card-count{font-size:.7rem;color:var(--text-tertiary);font-weight:500}.sp__class-card--active .sp__class-card-name{color:var(--accent-color, var(--primary))}.sp__toast{position:fixed;bottom:var(--space-lg);right:var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-secondary);border-radius:var(--radius-xl);padding:.75rem 1.25rem;box-shadow:0 8px 32px #00000026;display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-base);font-weight:600;color:var(--text-primary);z-index:2000;animation:sp-toast-in .3s cubic-bezier(.34,1.4,.64,1);max-width:320px}.sp__toast--success{border-left:3px solid var(--success, #22c55e)}.sp__toast--error{border-left:3px solid var(--danger, #ef4444)}.sp__toast--info{border-left:3px solid var(--primary)}@keyframes sp-toast-in{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.sp__skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-elevated, #e5e7eb) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:sp-shimmer 1.4s infinite;border-radius:var(--radius-md);transform:translateZ(0);will-change:background-position}@keyframes sp-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sp__class-loading{display:flex;flex-direction:column;gap:var(--space-sm)}.sp__class-skeleton{height:70px;border-radius:var(--radius-md)}.sp__class-empty{text-align:center;color:var(--text-tertiary);font-size:var(--font-size-sm);padding:var(--space-xl) 0}.sp__cal-skeleton-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.sp__cal-skeleton-cell{aspect-ratio:1}.sp__student-skeleton{display:flex;gap:10px;padding:.65rem .75rem;align-items:center}.sp__student-skeleton__lines{flex:1;display:flex;flex-direction:column;gap:5px}.sp__skeleton--avatar{width:38px;height:38px;border-radius:50%;flex-shrink:0}.sp__skeleton--line-name{height:12px;width:70%}.sp__skeleton--line-sub{height:10px;width:40%}.sp__confirm-body{padding:var(--space-lg);text-align:center}.sp__confirm-icon{color:#ef4444;margin-bottom:8px}.sp__confirm-message{color:var(--text-secondary);font-size:.9rem;margin:0}.sp__confirm-footer{display:flex;justify-content:flex-end;gap:8px;padding:0 var(--space-lg) var(--space-lg)}.sp__std-btn--ghost{background:var(--bg-tertiary);color:var(--text-primary);box-shadow:none}.sp__std-btn--ghost:hover{background:var(--bg-elevated);transform:none;box-shadow:none}.sp__std-btn--danger{background:#ef4444}.sp__std-btn--danger:hover{background:#dc2626}@media (max-width: 1024px){.sp__body{grid-template-columns:1fr 2fr}}@media (max-width: 767px){.sp__body{grid-template-columns:1fr}.sp__left{position:static}.sp__student-list{max-height:250px}.sp__stats-row{grid-template-columns:repeat(2,1fr)}.sp__details-profile{flex-direction:column;align-items:center;text-align:center}.sp__details-chips{justify-content:center}}@media (max-width: 480px){.sp__stats-row{grid-template-columns:1fr}.sp__class-grid{grid-template-columns:repeat(3,1fr)}}.dash{padding:var(--space-md);max-width:var(--max-content-width);margin:0 auto;width:100%}@media (min-width: 768px){.dash{padding:var(--space-xl)}}@media (min-width: 1280px){.dash{padding:var(--space-2xl)}}.dash__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-2xl);flex-wrap:wrap;gap:var(--space-md)}.dash__greeting{font-size:1.875rem;font-weight:700;color:var(--text-primary);margin:0 0 var(--space-sm)}.dash__date{font-size:var(--font-size-base);color:var(--text-secondary);margin:0}.dash__year-filter{display:flex;align-items:center;gap:var(--space-sm)}.dash__year-label{font-size:var(--font-size-base);font-weight:500;color:var(--text-secondary)}.dash__stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md)}.dash__section-title{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin:0 0 var(--space-sm);display:flex;align-items:center;gap:var(--space-sm)}.dash__section-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary)}.dash__chart-wrapper{position:relative;width:100%;overflow-x:auto}.dash__chart-svg{display:block;margin:0 auto}.dash__chart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--space-sm)}.dash__chart-empty-icon{color:var(--text-tertiary)}.dash__chart-empty-title{color:var(--text-primary);font-weight:600}.dash__chart-empty-desc{font-size:var(--font-size-base);color:var(--text-secondary)}.dash__cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-lg);margin-bottom:var(--space-lg)}.dash__cards-grid--2{grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.dash__birthday-banner{padding:var(--space-lg);background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:var(--radius-xl);display:flex;align-items:center;gap:var(--space-lg);flex-wrap:wrap}.dark .dash__birthday-banner{background:linear-gradient(135deg,#78350f33,#92400e33)}.dash__birthday-icon{width:64px;height:64px;border-radius:50%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}.dark .dash__birthday-icon{background:var(--bg-tertiary)}.dash__birthday-content{flex:1;min-width:200px}.dash__birthday-title{font-size:var(--font-size-lg);font-weight:700;color:#92400e;margin:0 0 var(--space-sm)}.dark .dash__birthday-title{color:#fbbf24}.dash__birthday-names{font-size:var(--font-size-base);color:#78350f;margin:0;line-height:1.5}.dark .dash__birthday-names{color:#fde68a}.dash__birthday-count{width:48px;height:48px;border-radius:50%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:700;color:#b45309;flex-shrink:0}.dark .dash__birthday-count{background:var(--bg-tertiary);color:#fbbf24}.dash__list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:500px;overflow-y:auto}.dash__list-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);transition:background var(--transition-fast),border-color var(--transition-fast);gap:var(--space-md)}.dash__list-item:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.dash__list-item-name{font-weight:600;color:var(--text-primary);margin-bottom:.15rem}.dash__list-item-detail{font-size:var(--font-size-sm);color:var(--text-secondary)}.dash__list-item-value{font-weight:700;font-variant-numeric:tabular-nums;flex-shrink:0}.dash__list-item-value--success{color:var(--success)}.dash__list-item-value--danger{color:var(--danger)}.dash__list-item-value--warning{color:var(--warning)}.dash__filters{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap}.dash__sort-btn{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:background var(--transition-fast),border-color var(--transition-fast)}.dash__sort-btn:hover{background:var(--bg-tertiary);border-color:var(--border-secondary)}.dash__week-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-md)}.dash__week-nav-btn{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:background var(--transition-fast)}.dash__week-nav-btn:hover{background:var(--bg-tertiary)}.dash__week-nav-btn:disabled{opacity:.4;cursor:not-allowed}.dash__week-label-title{font-weight:700;font-size:var(--font-size-base);color:var(--text-primary)}.dash__week-label-range{font-size:var(--font-size-xs);color:var(--text-secondary)}.dash__legend-item{padding:.45rem .65rem;border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-primary);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.dash__legend-item:hover,.dash__legend-item--active{background:var(--bg-secondary)}.dash__legend-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.2rem}.dash__legend-item-label{display:flex;align-items:center;gap:var(--space-xs)}.dash__legend-color{width:8px;height:8px;border-radius:var(--radius-sm);flex-shrink:0}.dash__legend-name{font-weight:600;font-size:var(--font-size-xs);color:var(--text-primary)}.dash__legend-pct{font-size:.65rem;font-weight:600;color:var(--text-tertiary);background:var(--bg-elevated);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.dash__legend-footer{display:flex;justify-content:space-between;font-size:.7rem}.dash__progress-bar{height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.dash__progress-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow)}.dash__mode-breakdown{display:flex;align-items:center;gap:var(--space-lg);flex-wrap:wrap;justify-content:center}.dash__mode-legend{flex:1 1 200px;min-width:180px}.dash__mode-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);margin-bottom:var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-primary)}.dash__mode-item-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);margin:0}.dash__mode-item-count{font-size:.7rem;color:var(--text-tertiary);margin:1px 0 0}.dash__mode-item-amount{font-size:var(--font-size-sm);font-weight:700;margin:0}.dash__mode-item-pct{font-size:.65rem;color:var(--text-tertiary);margin:1px 0 0}.dash__kpi-row{display:flex;gap:var(--space-md);flex-wrap:wrap;margin-bottom:var(--space-md)}.dash__kpi{flex:1;min-width:120px;padding:var(--space-md);background:var(--bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--border-primary);text-align:center}.dash__kpi-label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.05em}.dash__kpi-value{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.dash__sub-card{padding:var(--space-lg);border-radius:var(--radius-xl);border:1px solid var(--border-primary);background:var(--bg-secondary)}.dash__sub-card--premium{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border-color:var(--border-secondary)}.dash__expense-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-md)}.dash__week-label{text-align:center}@media (max-width: 767px){.dash__greeting{font-size:var(--font-size-2xl)}.dash__header{flex-direction:column}.dash__stats-row,.dash__cards-grid{grid-template-columns:1fr}.dash__birthday-banner{flex-direction:column;text-align:center}.dash__mode-breakdown{flex-direction:column}}.dash__deflists-grid{display:grid;grid-template-columns:400px minmax(0,1fr);gap:var(--space-lg);align-items:start;margin-bottom:var(--space-lg)}.dash__term-strip{display:flex;align-items:center;gap:var(--space-sm);overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;min-width:0;scrollbar-width:none;flex:1 1 auto}.dash__term-strip::-webkit-scrollbar{display:none}.dash__term-strip-divider{width:1px;align-self:stretch;background:var(--border-primary);flex-shrink:0;margin:0 var(--space-xs)}.dash__term-card{flex-shrink:0;min-width:58px;padding:var(--space-sm);border-radius:var(--radius-md);text-align:center;cursor:pointer;background:var(--bg-secondary);border:1px solid var(--border-primary);transition:background var(--transition-fast),border-color var(--transition-fast);font:inherit;color:inherit}.dash__term-card:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.dash__term-card:hover{border-color:var(--border-secondary);background:var(--bg-elevated)}.dash__term-card--active-blue{background:var(--accent-color, var(--primary));border-color:var(--accent-color, var(--primary))}.dash__term-card--active-red{background:var(--danger);border-color:var(--danger)}.dash__term-card--active-amber{background:var(--warning);border-color:var(--warning)}.dash__term-card__label{font-size:.6rem;font-weight:600;color:var(--text-tertiary);margin-bottom:.2rem;white-space:nowrap}.dash__term-card--active-blue .dash__term-card__label{color:rgba(var(--primary-rgb),0);color:color-mix(in srgb,var(--bg-primary) 80%,transparent)}.dash__term-card--active-red .dash__term-card__label,.dash__term-card--active-amber .dash__term-card__label{color:#fffc}.dash__term-card__value{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.dash__term-card--active-blue .dash__term-card__value{color:var(--bg-primary)}.dash__term-card--active-red .dash__term-card__value,.dash__term-card--active-amber .dash__term-card__value{color:#fff}.dash__defaulter-item{display:flex;flex-direction:column;padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);gap:var(--space-xs);transition:border-color var(--transition-fast)}.dash__defaulter-item:hover{border-color:var(--border-secondary)}.dash__defaulter-item__row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-sm);min-width:0}.dash__defaulter-item__info{min-width:0;flex:1 1 auto;overflow:hidden}.dash__defaulter-item__amounts{flex:0 0 auto;text-align:right}.dash__defaulter-item__name{font-weight:600;font-size:var(--font-size-sm);color:var(--text-primary);margin:0 0 .2rem;display:inline-flex;align-items:center;gap:var(--space-xs)}.dash__defaulter-item__meta{font-size:var(--font-size-xs);color:var(--text-secondary);margin:0;word-break:break-word}.dash__defaulter-item__due{font-weight:700;font-size:var(--font-size-base);color:var(--danger);margin:0 0 .15rem;text-align:right;white-space:nowrap}.dash__defaulter-item__paid{font-size:var(--font-size-xs);color:var(--text-tertiary);margin:0;text-align:right;white-space:nowrap}.dash__term-badges{display:flex;gap:var(--space-xs);flex-wrap:wrap;margin-top:var(--space-xs)}.dash__term-badge{font-size:.65rem;padding:.15rem .45rem;border-radius:var(--radius-sm);font-weight:600}.dash__term-badge--paid{background:#d1fae5;color:#065f46}.dash__term-badge--due{background:#fee2e2;color:#991b1b}.dash__term-badge--na{background:var(--bg-tertiary);color:var(--text-tertiary)}.dash__deflists-chart-grid{display:grid;grid-template-columns:minmax(360px,420px) minmax(0,1fr);gap:var(--space-lg);align-items:stretch;margin-bottom:var(--space-lg)}.dash__deflists-donut-col,.dash__deflists-bar-col{display:flex;min-width:0}.dash__deflists-donut-col>*,.dash__deflists-bar-col>*{width:100%}.dash__deflists-donut-col .card-body,.dash__deflists-donut-col .dash__card-body{padding:45px}.dash__deflists-list-section{margin-bottom:var(--space-lg)}.dash__deflists-header{display:flex;flex-direction:column;gap:.15rem;margin-bottom:var(--space-md);min-width:0}.dash__deflists-header__title{display:flex;align-items:center;gap:var(--space-sm);min-width:0}.dash__deflists-title{font-size:1.25rem;font-weight:700;margin:0;color:var(--text-primary)}.dash__deflists-subtitle{font-size:var(--font-size-xs);color:var(--text-tertiary);margin:0}.dash__deflists-spinner{color:var(--text-tertiary);animation:spin 1s linear infinite}.dash__deflists-export{display:inline-flex;align-items:center;gap:var(--space-xs);padding:.4rem .75rem;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.dash__deflists-export:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-secondary)}.dash__deflists-export:disabled{opacity:.5;cursor:not-allowed}.dash__deflists-toolbar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg);margin-bottom:var(--space-md);flex-wrap:wrap;min-width:0;max-width:100%}.dash__deflists-filters{display:flex;align-items:center;gap:var(--space-sm);flex:1 1 300px;min-width:0;flex-wrap:wrap}.dash__deflists-search{position:relative;flex:1 1 180px;min-width:0;display:flex;align-items:center}.dash__deflists-search__icon{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.dash__deflists-search__input{width:100%;padding:.5rem .75rem .5rem 2rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);font-size:.8125rem;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.dash__deflists-search__input:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--primary-rgb),.15)}.dash__deflists-filters__select{flex:1 1 140px;min-width:0;width:auto}.dash__deflists-filters__select--sm{flex:1 1 100px;min-width:0}.dash__deflists-filters__clear{padding:.35rem .7rem;border-radius:var(--radius-sm);font-size:var(--font-size-xs);border:1px solid var(--border-primary);background:transparent;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:background var(--transition-fast),border-color var(--transition-fast)}.dash__deflists-filters__clear:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.dash__deflists-items{display:flex;flex-direction:column;gap:var(--space-sm)}.dash__def-bar{width:100%;overflow-x:auto}.dash__def-bar__plot{display:flex;align-items:flex-end;justify-content:center;gap:18px;padding:32px 0 28px;position:relative}.dash__def-bar__grid{position:absolute;left:0;right:0;border-top:1px dashed var(--border-primary);opacity:.35;pointer-events:none}.dash__def-bar__col{flex:0 0 auto;width:36px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;position:relative;cursor:pointer;border:0;background:transparent;padding:0;outline:none;transition:transform .15s ease}.dash__def-bar__col:hover,.dash__def-bar__col--active,.dash__def-bar__col:focus-visible{transform:translateY(-2px)}.dash__def-bar__value{position:absolute;font-size:.58rem;font-weight:600;white-space:nowrap;text-align:center;width:100%}.dash__def-bar__fill{width:100%;border-radius:4px 4px 2px 2px;opacity:.85;position:relative;min-height:4px;margin-bottom:28px;transition:height .5s cubic-bezier(.4,0,.2,1),opacity .15s ease}.dash__def-bar__col:hover .dash__def-bar__fill,.dash__def-bar__col--active .dash__def-bar__fill,.dash__def-bar__col:focus-visible .dash__def-bar__fill{opacity:1;box-shadow:0 4px 14px #0000001f}.dash__def-bar__pct{position:absolute;bottom:5px;left:0;right:0;text-align:center;font-size:.58rem;font-weight:600;color:#fff}.dash__def-bar__label{position:absolute;bottom:0;font-size:.62rem;font-weight:600;color:var(--text-secondary);text-align:center;line-height:20px;white-space:nowrap;width:100%}.dash__def-bar__tooltip{position:absolute;top:0;right:0;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);box-shadow:0 8px 24px #00000024;min-width:200px;font-size:var(--font-size-xs);color:var(--text-primary);pointer-events:none;z-index:5;animation:fadeIn .12s ease}.dash__def-bar__tooltip-title{display:flex;align-items:center;gap:var(--space-xs);font-weight:700;font-size:var(--font-size-sm);color:var(--text-primary);margin-bottom:.4rem}.dash__def-bar__tooltip-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.dash__def-bar__tooltip-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);padding:.15rem 0;color:var(--text-secondary)}.dash__def-bar__tooltip-row strong{color:var(--text-primary);font-weight:600}.dash__def-bar__tooltip-div{height:1px;background:var(--border-primary);margin:.35rem 0}@media (max-width: 900px){.dash__deflists-grid,.dash__deflists-chart-grid{grid-template-columns:1fr}.dash__deflists-donut-col .card-body,.dash__deflists-donut-col .dash__card-body{padding:var(--space-md)}.dash__def-bar__tooltip{right:auto;left:50%;transform:translate(-50%)}}@media (max-width: 768px){.dash__deflists-toolbar{padding:var(--space-sm);gap:var(--space-sm)}.dash__term-strip{flex:1 1 100%}.dash__deflists-filters{flex:1 1 100%;flex-wrap:wrap}.dash__deflists-search{flex:1 1 100%;max-width:none}.dash__deflists-filters__select{flex:1 1 140px;min-width:0}}@media (max-width: 480px){.dash__defaulter-item__row{flex-direction:column;align-items:stretch}.dash__defaulter-item__amounts,.dash__defaulter-item__due,.dash__defaulter-item__paid{text-align:left}}.pay__pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-sm);border-top:1px solid var(--border-primary);gap:var(--space-md);flex-wrap:wrap}.pay__pagination-info{font-size:var(--font-size-sm);color:var(--text-secondary);white-space:nowrap}.pay__pagination-controls{display:flex;align-items:center;gap:var(--space-xs)}.pay__pagination-btn{padding:.35rem .75rem;font-size:var(--font-size-sm);border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);cursor:pointer;transition:background .15s,border-color .15s}.pay__pagination-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-tertiary)}.pay__pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pay__pagination-page{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:500;padding:0 var(--space-sm);white-space:nowrap}.pay__pagination-select{padding:.35rem .5rem;font-size:var(--font-size-sm);border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);cursor:pointer}@media (max-width: 640px){.pay__pagination{flex-direction:column;align-items:stretch;text-align:center}.pay__pagination-controls{justify-content:center}}.pay__stat-card{padding:var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:var(--space-sm);box-shadow:var(--shadow-xs);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.pay__stat-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-md)}.pay__stat-header{display:flex;justify-content:space-between;align-items:center}.pay__stat-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.pay__stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;line-height:1.2}.pay__stat-trend{font-size:var(--font-size-xs);color:var(--success);display:flex;align-items:center;gap:var(--space-xs)}.pay__stat-trend--danger{color:var(--danger)}.pay__stats-section{margin-bottom:var(--space-xl)}.pay__stats-header{display:flex;justify-content:space-between;align-items:center}.pay__stats-header--open{margin-bottom:var(--space-md)}.pay__stats-title{font-size:var(--font-size-base);font-weight:600;color:var(--text-secondary)}.pay__stats-toggle{background:none;border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-xs) var(--space-sm);cursor:pointer;font-size:var(--font-size-sm);color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-xs)}.pay__stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}.pay__year-header{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);-webkit-user-select:none;user-select:none}.pay__year-header svg{transition:transform .2s ease}.pay-row--due{background:#fef2f2!important}.pay-row--partial{background:#fffbeb!important}.pay-row--paid{background:#f0fdf4!important}.pay-row--due:hover{background:#fee2e2!important}.pay-row--partial:hover{background:#fef3c7!important}.pay-row--paid:hover{background:var(--success-light)!important}.pay__name-row{font-weight:600}.pay__father-name{font-size:var(--font-size-xs);font-weight:400;color:var(--text-tertiary);margin-top:1px}.pay__due-summary{font-size:.7rem;font-weight:600;margin-top:2px}.pay__due-summary--due{color:var(--danger)}.pay__due-summary--paid{color:var(--success)}.pay__student-badges{display:flex;gap:.25rem;margin-top:.2rem;flex-wrap:wrap}.pay__badge-icon{margin-right:2px;flex-shrink:0}.pay__fee-cell{display:flex;flex-direction:column;gap:var(--space-xs);align-items:center}.pay__fee-amounts{font-size:var(--font-size-xs);color:var(--text-secondary)}.pay__fee-remaining{font-size:var(--font-size-xs);color:var(--danger);font-weight:600}.pay__fee-discount{font-size:var(--font-size-xs);color:var(--success)}.pay__collapsed-cell{text-align:center;vertical-align:middle;transition:all .2s ease}.pay__collapsed-paid{color:var(--success)}.pay__collapsed-due{color:var(--danger);font-weight:700;font-size:var(--font-size-xs);white-space:nowrap}.pay__fine-value{color:var(--danger);font-weight:600;font-size:var(--font-size-sm)}.pay__fine-empty,.pay__no-record{color:var(--text-tertiary)}.pay__fine-label{display:flex;align-items:center;gap:var(--space-xs);margin-top:var(--space-xs);font-size:var(--font-size-xs);color:var(--danger);cursor:pointer;white-space:nowrap}.pay__fine-checkbox{width:12px;height:12px;accent-color:var(--danger)}.pay__actions{gap:var(--space-xs)}.pay__btn-compact{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs)}.pay__btn-icon{padding:var(--space-xs);min-width:unset}.pay__modal-body{display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-md)}.pay__modal-body--centered{align-items:center;text-align:center}.pay__info-card{padding:var(--space-lg);background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.pay__info-card--no-border{border:none;border-radius:var(--radius-md)}.pay__info-section{margin-bottom:var(--space-md)}.pay__info-label{font-size:var(--font-size-xs);color:var(--text-secondary)}.pay__info-name{font-size:var(--font-size-lg);font-weight:600}.pay__info-subtitle{font-size:var(--font-size-base);color:var(--text-secondary)}.pay__info-divider{padding-top:var(--space-md);border-top:1px solid var(--border-primary)}.pay__amount-display{font-size:var(--font-size-2xl);font-weight:700}.pay__amount-display--positive{color:var(--success)}.pay__amount-display--negative{color:var(--warning)}.pay__mode-label{display:block;font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--space-sm);color:var(--text-primary)}.pay__mode-required{color:var(--danger)}.pay__alert-title{font-weight:600;margin-bottom:var(--space-xs)}.pay__alert-text{font-size:var(--font-size-sm)}.pay__alert-advance{font-size:var(--font-size-base)}.pay__modal-footer{display:flex;gap:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-primary)}.pay__modal-footer--end{justify-content:flex-end}.pay__discount-current{margin-top:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--warning-light);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.pay__discount-hint{font-size:var(--font-size-sm);color:var(--text-secondary)}.pay__discount-delete{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:none;border:1px solid var(--danger);border-radius:var(--radius-sm);color:var(--danger);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);white-space:nowrap;flex-shrink:0}.pay__discount-delete:hover:not(:disabled){background:var(--danger);color:#fff}.pay__discount-delete:disabled{opacity:.5;cursor:not-allowed}.pay__lock-label{display:block;font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--space-sm);color:var(--text-primary)}.pay__lock-description{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-sm)}.pay__lock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-sm);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.pay__lock-btn{padding:var(--space-sm);border:2px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);position:relative}.pay__lock-btn--locked{border-color:var(--danger);background:var(--danger-light);font-weight:600;color:var(--danger)}.pay__lock-status{font-size:var(--font-size-xs)}.pay__lock-status--unlock{color:var(--success)}.pay__lock-status--lock{color:var(--danger)}.pay__lock-summary{margin-top:var(--space-sm);padding:var(--space-sm);background:var(--warning-light);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--warning-dark)}.pay__success-icon{width:80px;height:80px;border-radius:50%;background:var(--success-light);display:flex;align-items:center;justify-content:center;position:relative}.pay__success-sparkle{position:absolute;top:10px;right:10px;color:var(--warning)}.pay__success-title{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--space-sm)}.pay__success-subtitle{font-size:var(--font-size-base);color:var(--text-secondary)}.pay__receipt-amount{padding:var(--space-lg);background:var(--bg-tertiary);border-radius:var(--radius-lg);width:100%}.pay__receipt-amount-label{font-size:var(--font-size-base);color:var(--text-secondary);margin-bottom:var(--space-sm)}.pay__receipt-amount-value{font-size:2rem;font-weight:700}.pay__receipt-amount-value--success{color:var(--success)}.pay__receipt-amount-value--warning{color:var(--warning)}.pay__receipt-number{width:100%;padding:var(--space-md);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.pay__receipt-number-label{font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:var(--space-xs)}.pay__receipt-number-value{font-size:var(--font-size-md);font-weight:600;font-family:monospace;color:var(--text-primary)}.pay__allocations{width:100%;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);text-align:left}.pay__allocations-title{font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--space-sm);color:var(--text-primary)}.pay__allocations-list{display:flex;flex-direction:column;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--text-secondary)}.pay__allocation-row{display:flex;justify-content:space-between}.pay__allocation-amount{color:var(--text-primary);font-weight:600}.pay__allocations-more{font-size:var(--font-size-xs);font-style:italic;color:var(--text-tertiary)}.pay__whatsapp-status{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--success-light);border-radius:var(--radius-md);width:100%;font-size:var(--font-size-base);color:var(--success-dark)}.pay__whatsapp-detail{font-size:var(--font-size-xs);margin-top:var(--space-xs)}.pay__details-info{padding:var(--space-lg);background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.pay__details-name{font-size:var(--font-size-lg);font-weight:600}.pay__details-father{font-size:var(--font-size-sm);color:var(--text-tertiary)}.pay__details-class{font-size:var(--font-size-base);color:var(--text-secondary);margin-top:var(--space-xs)}.pay__details-contact{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-xs)}.pay__details-section-title{font-size:var(--font-size-base);font-weight:600;color:var(--text-secondary)}.pay__details-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.pay__details-tile{padding:var(--space-md);border-radius:var(--radius-md);text-align:center}.pay__details-tile--default{background:var(--bg-tertiary)}.pay__details-tile--success{background:var(--success-light)}.pay__details-tile--danger{background:var(--danger-light, #fef2f2)}.pay__details-tile--primary{background:var(--primary-light)}.pay__details-tile--warning{background:var(--warning-light)}.pay__details-tile-label{font-size:var(--font-size-xs);color:var(--text-secondary)}.pay__details-tile-value{font-size:var(--font-size-xl);font-weight:700}.pay__details-tile-value--primary{color:var(--text-primary)}.pay__details-tile-value--success{color:var(--success)}.pay__details-tile-value--danger{color:var(--danger)}.pay__details-tile-value--accent{color:var(--primary)}.pay__details-tile-value--warning{color:var(--warning)}.pay__term-list{display:flex;flex-direction:column;gap:var(--space-xs);font-size:var(--font-size-sm)}.pay__term-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm);background:var(--bg-tertiary);border-radius:var(--radius-sm)}.pay__term-info{display:flex;align-items:center;gap:var(--space-sm)}.pay__fine-info-grid{padding-top:var(--space-md);margin-top:var(--space-md);border-top:1px solid var(--border-primary);display:flex;justify-content:space-between}.pay__fine-pending-value{font-size:var(--font-size-md);font-weight:600;color:var(--danger)}.pay__fine-paying-value{font-size:var(--font-size-xl);font-weight:700;color:var(--success)}.pay__year-select{width:auto;min-width:130px}.pay__fine-header{min-width:70px}.pay__clickable{cursor:pointer}.pay__icon--success{color:var(--success)}.pay__alert-icon{margin-right:var(--space-sm)}.pay__filters-bar{position:sticky;top:0;z-index:var(--z-sticky-filters);background:var(--bg-elevated);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-primary)}.pay__th-roll{width:50px;text-align:center;font-size:var(--font-size-xs)}.pay__cell-roll{text-align:center;font-size:var(--font-size-xs);color:var(--text-tertiary);font-family:monospace;white-space:nowrap}@media (max-width: 1024px){.pay__stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.pay__stats-grid,.pay__details-grid{grid-template-columns:1fr}.pay__modal-footer{flex-direction:column}.pay__lock-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}.pay__discount-current{flex-direction:column;align-items:flex-start}}.sub-stat{padding:var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:var(--space-sm);box-shadow:var(--shadow-xs);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.sub-stat:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-md)}.sub-stat__header{display:flex;justify-content:space-between;align-items:center}.sub-stat__label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.sub-stat__icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center}.sub-stat__value{font-size:1.75rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;line-height:1.2}.sub-stat__subtitle{font-size:var(--font-size-xs);color:var(--text-secondary)}.sub-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.sub-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);padding:var(--space-md)}.sub-details__label{font-size:var(--font-size-base);color:var(--text-secondary);margin-bottom:var(--space-sm)}.sub-details__value{font-size:var(--font-size-md);font-weight:600}.sub-details__value--success{color:var(--success)}.sub-form{display:flex;flex-direction:column;gap:var(--space-xl)}.sub-form__fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg)}.sub-form__hint{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-sm);display:block}.sub-form__hint--recommended{color:var(--success);display:flex;align-items:center;gap:var(--space-xs)}.sub-icon--mr-sm{margin-right:var(--space-sm)}.sub-icon--mr{margin-right:.75rem}.sub-icon--success{color:var(--success);flex-shrink:0}.sub-alert__text{margin-top:var(--space-xs);font-size:var(--font-size-base)}.sub-pricing{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-xl)}.sub-pricing__header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg)}.sub-pricing__title{font-size:var(--font-size-lg);font-weight:600;margin:0}.sub-pricing__row{display:flex;justify-content:space-between;margin-bottom:var(--space-md);font-size:var(--font-size-base)}.sub-pricing__row--discount{margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-primary)}.sub-pricing__row--total{align-items:center;margin-bottom:var(--space-lg);font-size:inherit}.sub-pricing__row-label{color:var(--text-secondary)}.sub-pricing__row-label--success{color:var(--success)}.sub-pricing__row-value{font-weight:500;font-variant-numeric:tabular-nums}.sub-pricing__row-value--success{color:var(--success)}.sub-pricing__total-label{font-size:var(--font-size-lg);font-weight:600}.sub-pricing__total-value{font-size:2rem;font-weight:700;color:var(--primary);font-variant-numeric:tabular-nums}.sub-features{padding-top:var(--space-lg);border-top:1px solid var(--border-primary)}.sub-features__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary)}.sub-features__item{display:flex;align-items:center;gap:var(--space-sm)}.sub-activate-btn{width:100%;font-size:var(--font-size-lg);font-weight:600}.sub-trust{padding:var(--space-lg);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.sub-trust__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);font-size:var(--font-size-sm);color:var(--text-secondary)}.sub-trust__item{display:flex;align-items:center;gap:.75rem}.sub-topup{margin-top:var(--space-xl)}.sub-topup__header{display:flex;align-items:center;gap:.75rem;margin-bottom:var(--space-lg)}.sub-topup__icon{width:40px;height:40px;border-radius:10px;background:var(--success-light);display:flex;align-items:center;justify-content:center}.sub-topup__icon svg{color:var(--success-dark)}.sub-topup__title{margin:0;font-size:var(--font-size-lg);font-weight:700}.sub-topup__subtitle{margin:0;font-size:var(--font-size-sm);color:var(--text-secondary)}.sub-topup__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.sub-pack{position:relative;padding:1rem;border-radius:var(--radius-lg);border:2px solid var(--border-primary);background:var(--bg-secondary);cursor:pointer;text-align:left;transition:border-color .15s,background .15s;outline:none}.sub-pack--selected{border-color:var(--primary);background:rgba(var(--primary-rgb),.06)}.sub-pack__tag{position:absolute;top:-10px;right:10px;color:#fff;font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:99px;letter-spacing:.03em}.sub-pack__tag--best{background:var(--success-dark)}.sub-pack__tag--popular{background:var(--accent-color, var(--primary));color:var(--bg-primary)}.sub-pack__tag--default{background:var(--gray-500)}.sub-pack__qty{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.sub-pack__unit{font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:var(--space-sm)}.sub-pack__price{font-size:var(--font-size-md);font-weight:700;color:var(--text-primary)}.sub-pack__price--selected{color:var(--primary)}.sub-pack__rate{font-size:.7rem;color:var(--text-secondary)}.sub-pack__check{position:absolute;top:8px;left:8px;color:var(--primary)}.sub-topup__summary{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding:var(--space-lg);background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.sub-topup__summary-label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-xs)}.sub-topup__summary-value{font-size:var(--font-size-md);font-weight:700}.sub-topup__summary-note{font-size:var(--font-size-xs);color:var(--text-secondary);margin-top:.2rem}.sub-topup__buy-btn{min-width:180px}.sub-modal{display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-md)}.sub-modal--center{align-items:center;text-align:center}.sub-modal__icon-circle{border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto}.sub-modal__icon-circle--warning{width:80px;height:80px;background:var(--warning-light)}.sub-modal__icon-circle--success{width:100px;height:100px;background:var(--success-bg);position:relative}.sub-modal__icon-circle--wa{width:64px;height:64px;background:var(--success-light);margin:0 auto 1rem}.sub-modal__icon-circle--wa svg{color:var(--success-dark)}.sub-modal__heading{font-size:var(--font-size-xl);font-weight:600;text-align:center;margin:0}.sub-modal__heading--lg{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-sm)}.sub-modal__heading--wa{margin:0 0 .5rem;font-size:var(--font-size-lg);font-weight:700}.sub-modal__text{font-size:var(--font-size-base);color:var(--text-secondary);margin:0}.sub-modal__text--center{text-align:center}.sub-modal__details{background:var(--bg-tertiary);padding:var(--space-lg);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.sub-modal__details--full{width:100%}.sub-modal__detail-row{display:flex;justify-content:space-between;margin-bottom:var(--space-md);font-size:var(--font-size-base)}.sub-modal__detail-row--last{margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-primary)}.sub-modal__detail-total{display:flex;justify-content:space-between;align-items:center}.sub-modal__detail-total-label{font-size:var(--font-size-md);font-weight:600}.sub-modal__detail-total-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--primary)}.sub-modal__discount{color:var(--success, #10b981)}.sub-modal__actions{display:flex;gap:var(--space-md);justify-content:flex-end}.sub-topup-detail{display:flex;flex-direction:column;gap:.625rem}.sub-topup-detail__row{display:flex;justify-content:space-between;font-size:var(--font-size-base)}.sub-topup-detail__total{display:flex;justify-content:space-between;align-items:center;padding-top:.625rem;border-top:1px solid var(--border-primary)}.sub-topup-detail__total-value{font-size:var(--font-size-xl);font-weight:700;color:var(--success)}.sub-success__sparkle{position:absolute;top:10px;right:10px;color:var(--warning)}.sub-success__slots{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);justify-content:center}.sub-success__slots-label{font-size:var(--font-size-md);font-weight:600}.sub-success__info{font-size:var(--font-size-base);color:var(--text-secondary);margin-bottom:var(--space-sm)}.sub-success__info-row{display:flex;justify-content:space-between;margin-bottom:var(--space-sm)}.sub-success__info-row--last{margin-bottom:var(--space-md)}.sub-success__paid-row{display:flex;justify-content:space-between;padding-top:var(--space-md);border-top:1px solid var(--border-primary)}.sub-success__paid-label{font-weight:600}.sub-success__paid-value{color:var(--success);font-size:var(--font-size-lg);font-weight:700}.sub-success__cta{width:100%}.sub__section-title{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary);margin-bottom:1rem}.sub__plans-config{margin-bottom:1.5rem}.sub__plans-config-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.sub-duration-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm)}.sub-duration{position:relative;padding:.75rem .5rem;border-radius:var(--radius-md);border:2px solid var(--border-primary);background:var(--bg-secondary);cursor:pointer;text-align:center;transition:border-color .15s,background .15s;outline:none;font-family:inherit}.sub-duration:hover{border-color:var(--border-secondary)}.sub-duration--selected{border-color:var(--primary);background:rgba(var(--primary-rgb),.06)}.sub-duration__tag{position:absolute;top:-8px;left:50%;transform:translate(-50%);background:var(--accent-color, var(--primary));color:var(--bg-primary);font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:99px;white-space:nowrap;letter-spacing:.03em}.sub-duration__tag--best{background:var(--success-dark)}.sub-duration__value{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);line-height:1;margin-top:2px}.sub-duration__unit{font-size:var(--font-size-xs);color:var(--text-secondary);margin-top:2px}.sub-duration--selected .sub-duration__value{color:var(--primary)}.sub-duration__check{position:absolute;top:6px;right:6px;color:var(--primary)}.sub__plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;align-items:start}.sub__plan-card{display:flex;flex-direction:column;border:2px solid var(--border-primary);border-radius:var(--radius-xl);padding:1.5rem 1.25rem;background:var(--bg-elevated);transition:border-color .2s,box-shadow .2s,transform .15s;position:relative}.sub__plan-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.sub__plan-card--popular{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary),var(--shadow-md);padding-top:1.75rem}.sub__plan-card--selected{border-color:var(--success);box-shadow:0 0 0 1px var(--success)}.sub__plan-card--current{border-color:var(--success)}.sub__plan-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.625rem;flex-wrap:wrap}.sub__plan-name{font-size:var(--font-size-lg);font-weight:700;line-height:1}.sub__plan-badge{display:inline-flex;align-items:center;padding:.2rem .5rem;border-radius:999px;font-size:11px;font-weight:700;background:var(--accent-color, var(--primary));color:var(--bg-primary);letter-spacing:.02em}.sub__plan-badge--current{background:var(--success)}.sub__plan-rate{font-size:1.6rem;font-weight:800;color:var(--text-primary);line-height:1.1;margin-bottom:.25rem}.sub__plan-rate-unit{font-size:var(--font-size-sm);font-weight:400;color:var(--text-secondary)}.sub__plan-original{font-size:.85rem;color:var(--text-tertiary);text-decoration:line-through;margin-bottom:.1rem}.sub__plan-total{font-size:1.25rem;font-weight:700;color:var(--primary);margin-bottom:.125rem}.sub__plan-total-label{font-size:11px;color:var(--text-secondary);margin-bottom:.875rem}.sub__plan-savings{color:var(--success);font-weight:600}.sub__plan-divider{height:1px;background:var(--border-primary);margin-bottom:.875rem}.sub__plan-features{list-style:none;padding:0;margin:0 0 1.25rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.sub__plan-feature{display:flex;align-items:flex-start;gap:.5rem;font-size:var(--font-size-sm);color:var(--text-primary);line-height:1.4}.sub__plan-feature-check{color:var(--success);flex-shrink:0;margin-top:1px}.sub__plan-btn{width:100%;padding:.625rem 1rem;border-radius:var(--radius-lg);border:2px solid var(--primary);background:transparent;color:var(--primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background .15s,color .15s;text-align:center;margin-top:auto}.sub__plan-btn--popular{background:var(--accent-color, var(--primary));color:var(--bg-primary);border-color:var(--accent-color, var(--primary))}.sub__plan-btn--popular:hover{filter:brightness(1.1);color:var(--bg-primary)}.sub__current-plan{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-primary)}.sub__current-plan-badge{font-size:1.4rem;font-weight:800;letter-spacing:-.02em}@media (max-width: 900px){.sub__plans-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}.sub__plan-card--popular{order:-1}}@media (max-width: 768px){.sub-status-grid{grid-template-columns:1fr}.sub-details-grid{grid-template-columns:1fr 1fr}.sub-form__fields,.sub-features__grid,.sub-trust__grid{grid-template-columns:1fr}.sub-topup__grid{grid-template-columns:repeat(2,1fr)}.sub-topup__summary{flex-direction:column;align-items:stretch;text-align:center}.sub-topup__buy-btn{width:100%}.sub-pricing__total-value{font-size:var(--font-size-2xl)}}@media (max-width: 600px){.sub__plans-config-grid{grid-template-columns:1fr}}@media (max-width: 480px){.sub-details-grid,.sub-topup__grid{grid-template-columns:1fr}.sub-duration-grid{grid-template-columns:repeat(2,1fr)}}.dark .sub-topup__icon,.dark .sub-modal__icon-circle--wa{background:#16a36a26}.stu-table__reg{font-size:var(--font-size-xs);color:var(--text-tertiary);font-family:monospace}.stu-table__name-cell{display:flex;align-items:center;gap:var(--space-sm)}.stu-table__inactive-badge{font-size:.625rem;font-weight:600;padding:.125rem .375rem;border-radius:var(--radius-sm);background:#ef44441a;color:var(--danger);text-transform:uppercase;letter-spacing:.05em;line-height:1.4}.stu-table__row--inactive{background:#ef44440f;opacity:.75}.stu-table__reactivate-btn{color:var(--success);background:#10b9811a;border-radius:var(--radius-sm)}.promote{display:flex;flex-direction:column;gap:var(--space-md)}.promote__info{padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.5}.promote__filters{display:flex;gap:var(--space-sm);flex-wrap:wrap}.promote__search-wrapper{flex:1;min-width:200px;position:relative}.promote__search-icon{position:absolute;left:var(--space-sm);top:50%;transform:translateY(-50%);color:var(--text-tertiary)}.promote__search-input{width:100%;padding:var(--space-sm) var(--space-md) var(--space-sm) 2.25rem;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);font-size:var(--font-size-sm);outline:none}.promote__search-input:focus{border-color:var(--accent-color, var(--primary))}.promote__select{padding:var(--space-sm) var(--space-md);border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);font-size:var(--font-size-sm);cursor:pointer}.promote__select-row{display:flex;justify-content:space-between;align-items:center}.promote__select-all{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;font-size:var(--font-size-sm);color:var(--text-primary)}.promote__checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--primary)}.promote__count{font-size:var(--font-size-sm);color:var(--text-secondary)}.promote__list{max-height:400px;overflow-y:auto;border:1px solid var(--border-primary);border-radius:var(--radius-lg)}.promote__empty{padding:var(--space-xl);text-align:center;color:var(--text-secondary);font-size:var(--font-size-sm)}.promote__table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.promote__table thead tr{background:var(--bg-secondary);position:sticky;top:0;z-index:1}.promote__table th{padding:var(--space-sm) var(--space-md);color:var(--text-secondary);font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;text-align:left}.promote__table th:nth-child(3),.promote__table th:nth-child(4){text-align:center}.promote__table th:first-child{width:40px}.promote__row{cursor:pointer;border-bottom:1px solid var(--border-primary);transition:background .1s}.promote__row:hover{background:rgba(var(--primary-rgb),.04)}.promote__row--selected{background:rgba(var(--primary-rgb),.06)}.promote__row td{padding:var(--space-sm) var(--space-md)}.promote__student-name{font-weight:500;color:var(--text-primary)}.promote__student-detail{font-size:.7rem;color:var(--text-tertiary)}.promote__std-badge{display:inline-block;padding:.2rem var(--space-sm);border-radius:var(--radius-sm);background:var(--bg-tertiary);font-size:var(--font-size-sm);color:var(--text-primary);font-weight:500}.promote__std-badge--next{background:var(--bg-tertiary);color:var(--text-secondary);font-weight:500}.promote__std-badge--next-selected{background:#10b9811a;color:var(--success);font-weight:600}.promote__actions{display:flex;justify-content:flex-end;gap:var(--space-sm);padding-top:var(--space-sm)}.bulk-delete-btn{color:var(--danger)!important;border-color:var(--danger)!important}.bulk-delete-btn:hover{background:#ef44441a!important}.stu-pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-sm);border-top:1px solid var(--border-primary);gap:var(--space-md);flex-wrap:wrap}.stu-pagination__info{font-size:var(--font-size-sm);color:var(--text-secondary);white-space:nowrap}.stu-pagination__controls{display:flex;align-items:center;gap:var(--space-xs)}.stu-pagination__btn{padding:.35rem .75rem;font-size:var(--font-size-sm);border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);cursor:pointer;transition:background .15s,border-color .15s}.stu-pagination__btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-tertiary)}.stu-pagination__btn:disabled{opacity:.4;cursor:not-allowed}.stu-pagination__page{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:500;padding:0 var(--space-sm);white-space:nowrap}.stu-pagination__size{display:flex;align-items:center}.stu-pagination__select{padding:.35rem .5rem;font-size:var(--font-size-sm);border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);cursor:pointer}@media (max-width: 640px){.stu-pagination{flex-direction:column;align-items:stretch;text-align:center}.stu-pagination__controls,.stu-pagination__size{justify-content:center}}.mp-skip-link{position:absolute;left:-9999px;top:0;z-index:9999;background:var(--accent-color, var(--text-primary));color:var(--bg-primary);padding:10px 16px;border-radius:0 0 10px;font-weight:600;font-size:13px}.mp-skip-link:focus{left:0}.mp-subloading{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:var(--bg-primary);z-index:9999}.mp-subloading__dot{width:36px;height:36px;border-radius:50%;border:3px solid var(--border-primary);border-top-color:var(--accent-color, var(--primary));animation:spin .7s linear infinite}.app-premium{background:var(--bg-secondary)}.sidebar-premium{width:260px;background:var(--bg-elevated);border-right:1px solid var(--border-primary);box-shadow:var(--elev-3, 0 12px 24px -6px rgba(0,0,0,.08));display:flex;flex-direction:column;overflow:hidden}.sidebar-premium.sidebar-collapsed{width:72px}.sidebar-header--premium{padding:16px 16px 14px;border-bottom:1px solid var(--border-primary);background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-secondary) 100%);display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:68px}.sidebar-collapsed .sidebar-header--premium{padding:14px 0;justify-content:center;flex-direction:row;gap:0}.mp-brand-mark{width:38px;height:38px;min-width:38px;border-radius:10px;display:grid;place-items:center;background:transparent;border:none;overflow:hidden;flex-shrink:0;padding:0}.mp-brand-mark__img{width:100%;height:100%;object-fit:contain;display:block;background:transparent}.mp-brand-mark--clickable{cursor:pointer;border-radius:10px;transition:transform .14s ease,box-shadow .14s ease}.mp-brand-mark--clickable:hover{transform:scale(1.06);box-shadow:0 6px 18px -6px rgba(var(--primary-rgb, 0, 0, 0),.25)}.mp-brand-mark--clickable:active{transform:scale(.96)}.sidebar-header--premium .brand-text{flex:1;min-width:0}.sidebar-header--premium .brand-name{font-weight:700;font-size:14px;letter-spacing:-.01em;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-header--premium .brand-role{font-size:11px;color:var(--text-tertiary);margin:2px 0 0;font-weight:500;letter-spacing:.01em}.sidebar-search{position:relative;margin:12px 14px 4px;display:flex;align-items:center}.sidebar-search__icon{position:absolute;left:10px;color:var(--text-tertiary);pointer-events:none}.sidebar-search__input{flex:1;width:100%;padding:8px 28px 8px 30px;font-size:13px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:9px;color:var(--text-primary);outline:none;transition:border-color .15s,box-shadow .15s,background .15s}.sidebar-search__input::placeholder{color:var(--text-tertiary)}.sidebar-search__input:focus{border-color:var(--accent-color, var(--text-primary));background:var(--bg-elevated);box-shadow:0 0 0 3px rgba(var(--primary-rgb, 0, 0, 0),.12)}.sidebar-search__clear{position:absolute;right:6px;width:20px;height:20px;border:none;background:transparent;color:var(--text-tertiary);border-radius:6px;display:grid;place-items:center;cursor:pointer}.sidebar-search__clear:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-collapsed .sidebar-search{display:none}.sidebar-nav--premium{flex:1;min-height:0;padding:8px 10px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.nav-group{display:flex;flex-direction:column;gap:1px;padding-top:6px}.nav-group:first-child{padding-top:0}.nav-group__label{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);padding:10px 12px 6px;-webkit-user-select:none;user-select:none}.sidebar-collapsed .nav-group{padding-top:10px}.sidebar-collapsed .nav-group:first-child{padding-top:0}.sidebar-collapsed .nav-group+.nav-group{border-top:1px solid var(--border-primary);margin-top:4px}.sidebar-empty{padding:24px 12px;text-align:center;font-size:12px;color:var(--text-tertiary)}.nav-item--premium{position:relative;width:100%;display:flex;align-items:center;gap:10px;padding:9px 12px 9px 14px;border:none;background:transparent;border-radius:9px;color:var(--text-secondary);font-size:13.5px;font-weight:500;cursor:pointer;text-align:left;white-space:nowrap;overflow:hidden;transition:background .14s,color .14s,transform .14s}.nav-item--premium .nav-rail{position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:0 3px 3px 0;background:transparent;transition:background .14s}.nav-item--premium:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-item--premium.nav-item-active{background:rgba(var(--primary-rgb, 0, 0, 0),.08);color:var(--accent-color, var(--text-primary));font-weight:600;box-shadow:none}.nav-item--premium.nav-item-active .nav-rail{background:var(--accent-color, var(--primary))}.nav-item--premium.nav-item-active:hover{background:rgba(var(--primary-rgb, 0, 0, 0),.12)}.nav-item--premium .nav-icon{flex-shrink:0;opacity:.9}.nav-item--premium.nav-item-active .nav-icon{opacity:1}.nav-item--premium.nav-item--danger{color:var(--danger)}.nav-item--premium.nav-item--danger:hover{background:var(--danger-light);color:var(--danger)}.nav-item--premium.nav-item--danger .nav-rail{background:transparent}.sidebar-collapsed .nav-item--premium{justify-content:center;padding:11px 0;margin:1px 6px}.sidebar-collapsed .nav-item--premium .nav-rail{left:-10px}.nav-submenu--premium{display:flex;flex-direction:column;gap:1px;margin:2px 0 6px 28px;padding-left:10px;border-left:1.5px dashed var(--border-primary);animation:nav-submenu-slide .18s ease-out}.nav-submenu--premium .nav-subitem{padding:6px 10px;border-radius:7px;font-size:12.5px;color:var(--text-tertiary);display:flex;align-items:center;gap:8px;border:none;background:transparent;cursor:pointer;text-align:left;white-space:nowrap;overflow:hidden}.nav-submenu--premium .nav-subitem:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-submenu--premium .nav-subitem-active{background:rgba(var(--primary-rgb, 0, 0, 0),.08);color:var(--accent-color, var(--text-primary));font-weight:600}.nav-submenu--premium .nav-subicon{opacity:.85}.sidebar-collapsed .nav-item--premium[data-tooltip],.sidebar-toggle[data-tooltip],.mp-topbar__icon-btn[data-tooltip]{position:relative}.sidebar-collapsed .nav-item--premium[data-tooltip]:hover:after,.sidebar-collapsed .nav-item--premium[data-tooltip]:focus-visible:after,.mp-topbar__icon-btn[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:var(--text-primary);color:var(--bg-primary);font-size:12px;font-weight:500;padding:5px 9px;border-radius:6px;white-space:nowrap;z-index:1000;box-shadow:0 6px 16px #0000002e;pointer-events:none}.mp-topbar__icon-btn[data-tooltip]:hover:after{left:50%;top:calc(100% + 6px);transform:translate(-50%)}.sidebar-footer--premium{padding:10px;border-top:1px solid var(--border-primary);display:flex;flex-direction:column;gap:2px;background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-secondary) 100%)}.sidebar-profile{display:flex;align-items:center;gap:10px;padding:10px;margin-bottom:6px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:11px;min-width:0;width:100%;text-align:left;cursor:pointer;font:inherit;color:inherit;transition:background .15s ease,border-color .15s ease,transform .15s ease}.sidebar-profile--btn:hover{background:var(--bg-elevated);border-color:var(--border-secondary)}.sidebar-profile--btn:active{transform:scale(.985)}.sidebar-profile--active{border-color:var(--accent-color, var(--text-primary));box-shadow:0 0 0 3px rgba(var(--primary-rgb, 0, 0, 0),.1)}.sidebar-profile__avatar{width:36px;height:36px;min-width:36px;border-radius:9px;display:grid;place-items:center;overflow:hidden;background:var(--bg-elevated);border:1px solid var(--border-primary)}.sidebar-profile__avatar-img{width:100%;height:100%;object-fit:contain;display:block;background:transparent}.sidebar-profile__avatar-initials{width:100%;height:100%;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent-color, #6366f1) 0%,color-mix(in srgb,var(--accent-color, #8b5cf6) 60%,#8b5cf6) 100%);color:#fff;font-weight:700;font-size:13px;letter-spacing:.02em}.sidebar-profile__meta{flex:1;min-width:0;display:flex;flex-direction:column}.sidebar-profile__name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-profile__sub{font-size:11px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.sidebar-profile__chev{color:var(--text-tertiary);flex-shrink:0;opacity:.7;transition:transform .15s ease,opacity .15s ease}.sidebar-profile--btn:hover .sidebar-profile__chev{opacity:1;transform:translate(2px)}.sidebar-brand--btn{display:flex;align-items:center;gap:10px;background:transparent;border:none;padding:6px 4px;margin:-6px -4px;border-radius:9px;cursor:pointer;color:inherit;font:inherit;text-align:left;overflow:hidden;min-width:0;flex:1;transition:background .14s ease}.sidebar-brand--btn:hover{background:var(--bg-secondary)}.sidebar-brand--btn .brand-text{display:flex;flex-direction:column;min-width:0}.sidebar-brand--btn .brand-name,.sidebar-brand--btn .brand-role{display:block}.nav-item__avatar-img{width:22px;height:22px;border-radius:6px;object-fit:contain;background:transparent;flex-shrink:0}.mp-user-menu__avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.main-content-premium{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-secondary)}.mp-topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 22px;background:rgba(var(--bg-elevated-rgb, 255, 255, 255),.85);background:color-mix(in srgb,var(--bg-elevated) 92%,transparent);backdrop-filter:saturate(160%) blur(10px);-webkit-backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--border-primary);min-height:56px}.mp-topbar__left,.mp-topbar__right{display:flex;align-items:center;gap:10px;min-width:0}.mp-topbar__right{gap:6px}.mp-topbar__icon-btn{width:34px;height:34px;border-radius:9px;border:1px solid transparent;background:transparent;color:var(--text-secondary);display:grid;place-items:center;cursor:pointer;transition:background .14s,color .14s,border-color .14s}.mp-topbar__icon-btn:hover{background:var(--bg-secondary);border-color:var(--border-primary);color:var(--text-primary)}.mp-topbar__menu{display:none}.mp-breadcrumb{display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden}.mp-breadcrumb__crumb{font-size:13px;color:var(--text-tertiary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-breadcrumb__crumb--current{color:var(--text-primary);font-weight:600}.mp-breadcrumb__sep{color:var(--text-tertiary);flex-shrink:0}.mp-imp-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:8px;background:#f59e0b24;color:#b45309;border:1px solid rgba(245,158,11,.35);font-size:11.5px;font-weight:600}[data-theme=dark] .mp-imp-chip{color:#fbbf24}.mp-user-menu{position:relative}.mp-user-menu__trigger{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 5px;background:transparent;border:1px solid var(--border-primary);border-radius:999px;cursor:pointer;color:var(--text-primary);transition:background .14s,border-color .14s}.mp-user-menu__trigger:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.mp-user-menu__avatar{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent-color, #6366f1) 0%,color-mix(in srgb,var(--accent-color, #8b5cf6) 60%,#8b5cf6) 100%);color:#fff;font-weight:700;font-size:11px}.mp-user-menu__name{font-size:13px;font-weight:500;max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-user-menu__panel{position:absolute;right:0;top:calc(100% + 8px);min-width:240px;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:12px;box-shadow:var(--elev-3, 0 12px 32px -8px rgba(0,0,0,.18));padding:6px;z-index:100;animation:mp-menu-in .14s ease-out}@keyframes mp-menu-in{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.mp-user-menu__header{padding:10px 12px 12px;border-bottom:1px solid var(--border-primary);margin-bottom:4px}.mp-user-menu__header-name{font-size:13px;font-weight:600;color:var(--text-primary)}.mp-user-menu__header-email{font-size:11.5px;color:var(--text-tertiary);margin-top:2px;word-break:break-all}.mp-user-menu__item{width:100%;display:flex;align-items:center;gap:10px;padding:9px 12px;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);font-size:13px;cursor:pointer;text-align:left;transition:background .14s,color .14s}.mp-user-menu__item:hover{background:var(--bg-secondary);color:var(--text-primary)}.mp-user-menu__item--danger{color:var(--danger)}.mp-user-menu__item--danger:hover{background:var(--danger-light);color:var(--danger)}.mp-user-menu__divider{height:1px;background:var(--border-primary);margin:4px 0}.mp-imp-banner{padding:10px 18px;display:flex;align-items:center;gap:10px;background:linear-gradient(90deg,#fef3c7,#fde68a);border-bottom:1px solid #f59e0b;color:#78350f;font-size:13px;font-weight:500}.mp-imp-banner__icon{color:#b45309;flex-shrink:0}.mp-imp-banner__text{flex:1}.mp-imp-banner__btn{background:#b45309;color:#fff;border:none;padding:6px 14px;border-radius:7px;cursor:pointer;font-size:12px;font-weight:600;transition:filter .14s}.mp-imp-banner__btn:hover:not(:disabled){filter:brightness(1.08)}.mp-imp-banner__btn:disabled{opacity:.6;cursor:not-allowed}.mp-announce{display:flex;align-items:center;gap:10px;padding:10px 18px;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-primary)}.mp-announce--info{background:var(--info-light, #eff6ff);color:var(--info-dark, #1e40af)}.mp-announce--success{background:var(--success-light, #f0fdf4);color:#166534}.mp-announce--warning{background:var(--warning-light, #fffbeb);color:#92400e}.mp-announce--error{background:var(--danger-light, #fef2f2);color:#991b1b}.mp-announce__text{flex:1}.mp-announce__close{background:transparent;border:none;cursor:pointer;padding:4px;color:inherit;opacity:.6;border-radius:5px}.mp-announce__close:hover{opacity:1;background:#0000000f}.mp-maintenance{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000000e0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;color:#fff}.mp-maintenance__icon{color:#f59e0b;margin-bottom:16px}.mp-maintenance__title{font-size:26px;font-weight:700;margin:0 0 12px;letter-spacing:-.02em}.mp-maintenance__msg{font-size:15px;color:#ffffffbf;max-width:440px;line-height:1.55}.mp-outlet{flex:1;min-width:0;padding:0}.app-premium .main-content-premium{margin-left:260px;transition:margin .26s cubic-bezier(.4,0,.2,1)}.app-premium .sidebar-collapsed~.main-content-premium{margin-left:72px}.app-premium .sidebar-right~.main-content-premium{margin-left:0;margin-right:260px}.app-premium .sidebar-right.sidebar-collapsed~.main-content-premium{margin-right:72px}.app-no-sub{flex-direction:column;background:var(--bg-secondary)}.mp-nosub-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid var(--border-primary);background:var(--bg-elevated);position:sticky;top:0;z-index:10}.mp-nosub-brand{display:flex;align-items:center;gap:12px}.mp-nosub-brand__title{font-size:14px;font-weight:700;color:var(--text-primary)}.mp-nosub-brand__sub{font-size:11px;color:var(--text-tertiary)}.mp-nosub-main{min-height:calc(100vh - 60px);background:var(--bg-secondary)}.mp-btn-ghost{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--border-primary);color:var(--text-secondary);padding:8px 14px;border-radius:9px;font-size:13px;font-weight:500;cursor:pointer;transition:background .14s,border-color .14s,color .14s}.mp-btn-ghost:hover{background:var(--bg-secondary);border-color:var(--border-secondary);color:var(--text-primary)}@media (max-width: 1024px){.mp-user-menu__name{display:none}}@media (max-width: 768px){.app-premium .main-content-premium,.app-premium .sidebar-collapsed~.main-content-premium{margin-left:0}.sidebar-premium{position:fixed;top:0;bottom:0;left:0;z-index:var(--z-fixed);transform:translate(0);transition:transform .26s cubic-bezier(.4,0,.2,1)}.sidebar-premium.sidebar-collapsed{transform:translate(-100%);width:260px}.mp-topbar{padding:10px 14px}.mp-topbar__menu{display:grid}.mp-breadcrumb__crumb:first-child,.mp-breadcrumb__sep:first-of-type{display:none}}.mp-sr-live{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.mp-route-progress{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,var(--accent-color, var(--primary, #6366f1)) 50%,transparent 100%);background-size:200% 100%;background-position:100% 0;opacity:0;pointer-events:none;z-index:40;transition:opacity .12s ease}.mp-route-progress--active{opacity:1;animation:mp-route-sweep .42s ease-out}@keyframes mp-route-sweep{0%{background-position:100% 0}to{background-position:-100% 0}}.mp-status-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:8px;font-size:11.5px;font-weight:600;border:1px solid transparent;white-space:nowrap}.mp-status-chip--offline{background:#ef44441f;color:#b91c1c;border-color:#ef444452}[data-theme=dark] .mp-status-chip--offline{color:#fca5a5}.mp-crash{max-width:560px;margin:80px auto;padding:36px 30px;text-align:center;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:16px;box-shadow:var(--elev-2, 0 4px 12px rgba(0,0,0,.06))}.mp-crash__icon{color:var(--danger, #ef4444);margin-bottom:14px}.mp-crash__title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 8px;letter-spacing:-.01em}.mp-crash__msg{font-size:13.5px;color:var(--text-secondary);margin:0 0 20px;line-height:1.55;word-break:break-word}.mp-crash__actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}@media (prefers-reduced-motion: reduce){.mp-route-progress--active,.sidebar-premium,.app-premium .main-content-premium,.mp-brand-mark--clickable,.sidebar-profile--btn,.sidebar-profile__chev,.nav-item--premium,.mp-user-menu__panel,.mp-palette,.mp-notif__panel,.mp-bottombar{animation:none!important;transition:none!important}.mp-brand-mark--clickable:hover,.sidebar-profile--btn:active{transform:none!important}}.nav-icon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.nav-badge{background:var(--danger, #ef4444);color:#fff;font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:999px;min-width:18px;line-height:1.5;text-align:center;letter-spacing:0;margin-left:auto;flex-shrink:0}.nav-badge--dot{position:absolute;top:-2px;right:-2px;min-width:8px;width:8px;height:8px;padding:0;border-radius:50%;border:2px solid var(--bg-elevated)}.nav-group__label-icon{opacity:.7}.mp-topbar__kbd-btn{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:9px;color:var(--text-tertiary);font-size:12.5px;cursor:pointer;transition:background .14s,border-color .14s,color .14s;min-width:180px}.mp-topbar__kbd-btn:hover{background:var(--bg-elevated);border-color:var(--border-secondary);color:var(--text-primary)}.mp-topbar__kbd-label{flex:1;text-align:left;font-weight:500}.mp-topbar__kbd{display:inline-flex;align-items:center;gap:2px;padding:1px 6px;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:5px;font-size:10.5px;font-family:var(--font-mono, monospace);color:var(--text-secondary);font-weight:600}@media (max-width: 900px){.mp-topbar__kbd-label,.mp-topbar__kbd{display:none}.mp-topbar__kbd-btn{min-width:auto;padding:7px}}.mp-notif,.mp-notif__trigger{position:relative}.mp-notif__dot{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--danger, #ef4444);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center;border:2px solid var(--bg-elevated);line-height:1}.mp-notif__panel{position:absolute;right:0;top:calc(100% + 8px);width:340px;max-width:calc(100vw - 24px);background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:12px;box-shadow:var(--elev-3, 0 12px 32px -8px rgba(0,0,0,.18));z-index:100;overflow:hidden;animation:mp-menu-in .14s ease-out;display:flex;flex-direction:column;max-height:480px}.mp-notif__panel-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border-primary)}.mp-notif__panel-title{font-size:13px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.mp-notif__mark-all{background:transparent;border:none;color:var(--accent-color, var(--text-secondary));font-size:12px;font-weight:600;cursor:pointer;padding:4px 6px;border-radius:6px}.mp-notif__mark-all:hover{background:var(--bg-secondary)}.mp-notif__empty{padding:36px 20px;text-align:center;color:var(--text-tertiary)}.mp-notif__empty svg{color:var(--text-tertiary);opacity:.6}.mp-notif__empty-title{margin:10px 0 4px;font-size:13.5px;font-weight:600;color:var(--text-primary)}.mp-notif__empty-sub{margin:0;font-size:12px;color:var(--text-tertiary)}.mp-notif__list{flex:1;overflow-y:auto;padding:4px}.mp-notif__item{display:block;width:100%;text-align:left;padding:10px 12px;background:transparent;border:none;border-radius:8px;cursor:pointer;color:var(--text-primary);transition:background .14s}.mp-notif__item:hover{background:var(--bg-secondary)}.mp-notif__item--unread{background:rgba(var(--primary-rgb, 0, 0, 0),.04);position:relative}.mp-notif__item--unread:before{content:"";position:absolute;left:4px;top:14px;width:6px;height:6px;border-radius:50%;background:var(--accent-color, var(--primary))}.mp-notif__item-title{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.mp-notif__item-body{font-size:12px;color:var(--text-secondary);line-height:1.45}.mp-notif__footer-link{display:flex;align-items:center;justify-content:center;gap:4px;padding:11px;background:var(--bg-secondary);border:none;border-top:1px solid var(--border-primary);color:var(--text-secondary);font-size:12.5px;font-weight:600;cursor:pointer}.mp-notif__footer-link:hover{color:var(--text-primary);background:var(--bg-tertiary)}.mp-palette-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000007a;backdrop-filter:blur(8px) saturate(140%);-webkit-backdrop-filter:blur(8px) saturate(140%);display:flex;align-items:flex-start;justify-content:center;padding:12vh 16px 16px;z-index:200;animation:mp-palette-fade .16s ease-out}@keyframes mp-palette-fade{0%{opacity:0}to{opacity:1}}.mp-palette{width:100%;max-width:620px;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:16px;box-shadow:0 30px 60px -20px #00000080;overflow:hidden;display:flex;flex-direction:column;max-height:70vh;animation:mp-palette-pop .2s cubic-bezier(.22,1,.36,1)}@keyframes mp-palette-pop{0%{opacity:0;transform:translateY(-12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.mp-palette__search{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--border-primary)}.mp-palette__search-icon{color:var(--text-tertiary);flex-shrink:0}.mp-palette__input{flex:1;border:none;outline:none;background:transparent;font-size:15px;color:var(--text-primary);font-weight:500;padding:4px 0}.mp-palette__input::placeholder{color:var(--text-tertiary)}.mp-palette__close{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;padding:4px 6px;color:var(--text-tertiary);cursor:pointer;display:grid;place-items:center}.mp-palette__close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.mp-palette__list{flex:1;overflow-y:auto;padding:6px}.mp-palette__group{padding:4px 0}.mp-palette__group-label{display:flex;align-items:center;gap:5px;padding:8px 12px 4px;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary)}.mp-palette__item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:9px;cursor:pointer;text-align:left;color:var(--text-primary);font-size:13.5px;transition:background .1s}.mp-palette__item--active{background:rgba(var(--primary-rgb, 0, 0, 0),.08)}.mp-palette__item-icon{color:var(--text-secondary);flex-shrink:0}.mp-palette__item--active .mp-palette__item-icon{color:var(--accent-color, var(--text-primary))}.mp-palette__item-label{flex:1;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-palette__item-section{font-size:11px;color:var(--text-tertiary);font-weight:500;padding:2px 7px;background:var(--bg-secondary);border-radius:5px;letter-spacing:.02em}.mp-palette__item-enter{color:var(--text-tertiary);flex-shrink:0}.mp-palette__empty{padding:36px 16px;text-align:center;color:var(--text-tertiary);font-size:13.5px}.mp-palette__footer{display:flex;align-items:center;gap:16px;padding:10px 16px;border-top:1px solid var(--border-primary);background:var(--bg-secondary);font-size:11.5px;color:var(--text-tertiary)}.mp-palette__footer span{display:inline-flex;align-items:center;gap:5px}.mp-palette__footer kbd{display:inline-flex;align-items:center;gap:2px;padding:2px 6px;font-family:var(--font-mono, monospace);font-size:10.5px;font-weight:600;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-secondary);min-width:18px;justify-content:center}.mp-bottombar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:55;background:var(--bg-elevated);border-top:1px solid var(--border-primary);padding:6px 4px calc(6px + env(safe-area-inset-bottom,0px));justify-content:space-around;gap:2px;box-shadow:0 -4px 20px -8px #0000001a}.mp-bottombar__item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px 6px;background:transparent;border:none;border-radius:10px;cursor:pointer;color:var(--text-tertiary);font-size:10.5px;font-weight:500;transition:color .14s,background .14s;min-width:0}.mp-bottombar__item:active{background:var(--bg-secondary)}.mp-bottombar__item--active{color:var(--accent-color, var(--text-primary));font-weight:600}.mp-bottombar__icon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}.mp-bottombar__label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.mp-bottombar__badge{position:absolute;top:-6px;right:-10px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--danger, #ef4444);color:#fff;font-size:9.5px;font-weight:700;display:grid;place-items:center;border:2px solid var(--bg-elevated);line-height:1}@media (max-width: 768px){.mp-bottombar{display:flex}.main-content-premium{padding-bottom:64px}}.nav-item--has-pin{padding-right:30px}.nav-item-group{position:relative}.nav-item__pin{position:absolute;top:9px;right:6px;width:20px;height:20px;display:grid;place-items:center;background:transparent;border:none;border-radius:5px;color:var(--text-tertiary);cursor:pointer;opacity:0;transition:opacity .14s ease,background .14s ease,color .14s ease}.nav-item-group:hover .nav-item__pin,.nav-item__pin:focus-visible{opacity:.7}.nav-item__pin:hover{opacity:1;background:var(--bg-tertiary);color:var(--text-primary)}.nav-item__pin--on{opacity:1;color:var(--accent-color, #f59e0b)}.nav-item__pin--on svg{fill:currentColor}.nav-subitem-group{position:relative;display:flex}.nav-subitem-group .nav-subitem{flex:1 1 auto}.nav-subitem__pin{position:absolute;top:50%;right:4px;transform:translateY(-50%);width:18px;height:18px;display:grid;place-items:center;background:transparent;border:none;border-radius:5px;color:var(--text-tertiary);cursor:pointer;opacity:0;transition:opacity .14s ease,background .14s ease,color .14s ease}.nav-subitem-group:hover .nav-subitem__pin,.nav-subitem__pin:focus-visible{opacity:.7}.nav-subitem__pin:hover{opacity:1;background:var(--bg-tertiary);color:var(--text-primary)}.nav-subitem__pin--on{opacity:1;color:var(--accent-color, #f59e0b)}.nav-subitem__pin--on svg{fill:currentColor}.nav-group--favorites .nav-group__label{color:var(--accent-color, var(--text-secondary));display:inline-flex;align-items:center;gap:5px}.nav-group--favorites+.nav-group{padding-top:6px}.sidebar-usage{width:100%;display:flex;flex-direction:column;gap:6px;padding:10px 12px;margin-bottom:8px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px;cursor:pointer;text-align:left;transition:border-color .14s,background .14s}.sidebar-usage:hover{background:var(--bg-elevated);border-color:var(--border-secondary)}.sidebar-usage--warn{border-color:#f59e0b66;background:#f59e0b0f}[data-theme=dark] .sidebar-usage--warn{background:#f59e0b1a}.sidebar-usage__row{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11.5px}.sidebar-usage__label{color:var(--text-secondary);font-weight:600;letter-spacing:.01em}.sidebar-usage__value{color:var(--text-primary);font-weight:600;font-variant-numeric:tabular-nums}.sidebar-usage__bar{width:100%;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.sidebar-usage__bar-fill{display:block;height:100%;background:var(--accent-color, var(--primary));border-radius:2px;transition:width .24s ease}.sidebar-usage--warn .sidebar-usage__bar-fill{background:#f59e0b}.sidebar-usage__upsell{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;color:#b45309}[data-theme=dark] .sidebar-usage__upsell{color:#fbbf24}.sidebar-profile__last-login{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;color:var(--text-tertiary);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-trial-banner{display:flex;align-items:center;gap:12px;padding:10px 18px;background:linear-gradient(90deg,rgba(var(--primary-rgb, 99, 102, 241),.08),rgba(var(--primary-rgb, 139, 92, 246),.06));border-bottom:1px solid var(--border-primary);font-size:13px;color:var(--text-primary)}.mp-trial-banner--critical{background:linear-gradient(90deg,#fff7ed,#fef3c7);border-bottom-color:#f59e0b;color:#78350f}[data-theme=dark] .mp-trial-banner--critical{background:linear-gradient(90deg,#f59e0b26,#f59e0b14);color:#fbbf24}.mp-trial-banner__icon{color:var(--accent-color, var(--primary));flex-shrink:0}.mp-trial-banner--critical .mp-trial-banner__icon{color:#b45309}[data-theme=dark] .mp-trial-banner--critical .mp-trial-banner__icon{color:#fbbf24}.mp-trial-banner__text{flex:1}.mp-trial-banner__end{color:var(--text-tertiary);margin-left:6px}.mp-trial-banner--critical .mp-trial-banner__end{color:inherit;opacity:.75}.mp-trial-banner__cta{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--accent-color, var(--primary));color:var(--bg-primary);border:none;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;transition:filter .14s;white-space:nowrap}.mp-trial-banner__cta:hover{filter:brightness(1.08)}.mp-trial-banner--critical .mp-trial-banner__cta{background:#b45309;color:#fff}.mp-trial-banner__close{background:transparent;border:none;cursor:pointer;padding:5px;color:inherit;opacity:.5;border-radius:5px;flex-shrink:0}.mp-trial-banner__close:hover{opacity:1;background:#00000014}.mp-imp-chip__timer{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;margin-left:4px;background:#b4530933;border-radius:999px;font-size:10.5px;font-variant-numeric:tabular-nums}[data-theme=dark] .mp-imp-chip__timer{background:#fbbf242e}.mp-notif__whats-new{margin:4px 8px 0;background:linear-gradient(135deg,rgba(var(--primary-rgb, 99, 102, 241),.1),rgba(var(--primary-rgb, 139, 92, 246),.05));border:1px solid rgba(var(--primary-rgb, 99, 102, 241),.2);border-radius:10px;overflow:hidden}.mp-notif__whats-new-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px}.mp-notif__whats-new-icon{color:var(--accent-color, var(--primary));flex-shrink:0;margin-top:1px}.mp-notif__whats-new-body{flex:1;min-width:0}.mp-notif__whats-new-title{font-size:12.5px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.mp-notif__whats-new-msg{font-size:11.5px;color:var(--text-secondary);margin-top:2px;line-height:1.45}.mp-notif__whats-new-dismiss{background:transparent;border:1px solid var(--border-primary);border-radius:5px;width:22px;height:22px;display:grid;place-items:center;cursor:pointer;color:var(--text-secondary);flex-shrink:0}.mp-notif__whats-new-dismiss:hover{background:var(--bg-elevated);color:var(--text-primary)}.mp-notif__sparkle{position:absolute;top:2px;right:2px;width:14px;height:14px;display:grid;place-items:center;border-radius:50%;background:var(--accent-color, var(--primary));color:#fff;border:2px solid var(--bg-elevated);animation:mp-sparkle-pulse 1.6s ease-in-out infinite}@keyframes mp-sparkle-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.mp-user-menu__header-meta{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;color:var(--text-tertiary);margin-top:4px}.mp-user-menu__section-label{padding:8px 12px 4px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary)}.mp-user-menu__item--tenant{gap:10px}.mp-user-menu__tenant-mark{width:24px;height:24px;display:grid;place-items:center;border-radius:6px;background:linear-gradient(135deg,var(--accent-color, #6366f1) 0%,color-mix(in srgb,var(--accent-color, #8b5cf6) 60%,#8b5cf6) 100%);color:#fff;font-weight:700;font-size:11px;flex-shrink:0}.mp-user-menu__tenant-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.mp-user-menu__tenant-arrow{color:var(--text-tertiary);flex-shrink:0}@media (prefers-reduced-motion: reduce){.mp-notif__sparkle,.sidebar-usage__bar-fill,.mp-trial-banner__cta,.nav-item__pin{animation:none!important;transition:none!important}}:root{--bg-tertiary: #f3f4f6;--primary-light: var(--color-primary-light, #f3f4f6);--font-scale: 1}:root.dark{--bg-tertiary: #374151;--primary-light: var(--color-primary-light, #374151)}[data-font-size=small]{--font-scale: .92}[data-font-size=medium]{--font-scale: 1}[data-font-size=large]{--font-scale: 1.14}body,.form-input,.form-select,textarea,button,.btn{font-size:var(--font-size-base)}h1,.page-title{font-size:var(--font-size-xl)}h2{font-size:var(--font-size-lg)}h3{font-size:var(--font-size-md)}h4{font-size:var(--font-size-base)}label{font-size:var(--font-size-sm)}small,.text-xs{font-size:var(--font-size-xs)}.text-sm,.page-subtitle{font-size:var(--font-size-sm)}.compact{--space-xs: .125rem;--space-sm: .25rem;--space-md: .5rem;--space-lg: .75rem;--space-xl: 1rem;--space-2xl: 1.25rem}.compact .page-header{padding-bottom:.75rem}.compact .page-content{padding:1rem}.compact [class*=-stat-card],.compact [class*=-card-item]{padding:.5rem .75rem}.compact .settings-layout{gap:.75rem}.compact .settings-tab{padding:.375rem .75rem}[data-table-density=comfortable]{--table-cell-py: .75rem;--table-cell-px: .75rem}[data-table-density=compact]{--table-cell-py: .5rem;--table-cell-px: .5rem}[data-table-density=dense]{--table-cell-py: .25rem;--table-cell-px: .375rem}table th,table td,[class*=-table] th,[class*=-table] td{padding:var(--table-cell-py, .75rem) var(--table-cell-px, .75rem)}.no-animations *,.no-animations *:before,.no-animations *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.reduced-motion *,.reduced-motion *:before,.reduced-motion *:after{animation-duration:.3s!important;transition-duration:.15s!important}.high-contrast{--border-primary: #000000;--border-secondary: #000000;--text-secondary: #374151;--text-tertiary: #4b5563}.high-contrast.dark{--border-primary: #ffffff;--border-secondary: #e5e7eb;--text-secondary: #d1d5db;--text-tertiary: #9ca3af}.high-contrast input,.high-contrast select,.high-contrast textarea,.high-contrast button{border-width:2px}.high-contrast a:focus,.high-contrast button:focus,.high-contrast input:focus,.high-contrast select:focus{outline:3px solid var(--color-primary);outline-offset:2px}@media print{.print-no-logo .print-logo,.print-no-logo .school-logo,.print-no-header .print-header,.print-no-header .page-header{display:none!important}.sidebar,nav,.settings-sidebar,.no-print{display:none!important}body{font-size:12pt;color:#000!important;background:#fff!important}}.appearance-section{margin-bottom:1.5rem}.appearance-section__title{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-primary)}.appearance-row{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:var(--bg-tertiary, var(--bg-secondary));border-radius:var(--radius-lg, .75rem);border:1px solid var(--border-primary);margin-bottom:.75rem;transition:border-color .2s}.appearance-row:hover{border-color:var(--border-secondary)}.appearance-row__info{flex:1;min-width:0}.appearance-row__label{display:flex;align-items:center;gap:.625rem;margin-bottom:.25rem}.appearance-row__label h4{margin:0;font-size:var(--font-size-base);font-weight:600;color:var(--text-primary)}.appearance-row__label svg{flex-shrink:0;color:var(--text-secondary)}.appearance-row__desc{margin:0;font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.4}.appearance-row__desc strong{color:var(--text-primary)}.appearance-row__control{flex-shrink:0;margin-left:1rem}.pill-group{display:flex;gap:.375rem;background:var(--bg-primary);padding:.25rem;border-radius:var(--radius-lg, .75rem);border:1px solid var(--border-primary)}.pill-btn{padding:.375rem .875rem;border:2px solid transparent;border-radius:var(--radius-md, .5rem);background:transparent;color:var(--text-secondary);cursor:pointer;font-size:var(--font-size-sm);font-weight:500;min-width:60px;text-transform:capitalize;transition:all .2s;white-space:nowrap}.pill-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.pill-btn--active{background:var(--color-primary-light, #f3f4f6);color:var(--color-primary, #000);border-color:var(--color-primary, #000);font-weight:600}.color-swatches{display:flex;gap:.625rem;flex-wrap:wrap}.color-swatch{width:44px;height:44px;border-radius:10px;border:2px solid var(--border-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;position:relative}.color-swatch:hover{transform:scale(1.08);box-shadow:0 4px 12px #0000001f}.color-swatch--active{border-width:3px;border-color:var(--text-primary);transform:scale(1.05);box-shadow:0 4px 12px #00000026}.color-swatch__check{color:#fff;filter:drop-shadow(0 1px 3px rgba(0,0,0,.4))}.color-swatch--default{background:linear-gradient(135deg,#000 50%,#fff 50%);border-color:var(--text-tertiary);box-shadow:0 0 0 1px var(--bg-elevated) inset}.dark .color-swatch--default,[data-theme=dark] .color-swatch--default{border-color:var(--text-secondary)}.appearance-preview{padding:1.5rem;background:var(--bg-secondary, #f9fafb);border-radius:var(--radius-lg, .75rem);border:1px solid var(--border-primary);text-align:center}.appearance-preview__chips{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}.appearance-preview__chip{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-full, 9999px);font-size:var(--font-size-xs);color:var(--text-secondary);white-space:nowrap}.appearance-preview__chip strong{color:var(--text-primary);text-transform:capitalize}.appearance-slider{display:flex;align-items:center;gap:.75rem}.appearance-slider input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:120px;height:6px;background:var(--border-primary);border-radius:3px;outline:none}.appearance-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-primary, #000);cursor:pointer;border:2px solid var(--bg-primary);box-shadow:0 1px 3px #0003}.appearance-slider__value{min-width:30px;text-align:center;font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}@media (max-width: 768px){.appearance-row{flex-direction:column;align-items:flex-start;gap:.75rem}.appearance-row__control{margin-left:0;width:100%}.pill-group{width:100%;justify-content:stretch}.pill-btn{flex:1;text-align:center}.color-swatches{width:100%}.appearance-row__control .form-select{width:100%!important}.appearance-slider{width:100%}.appearance-slider input[type=range]{flex:1;width:auto}}:root{--elev-1: 0 1px 2px rgba(0, 0, 0, .04), 0 1px 3px rgba(0, 0, 0, .06);--elev-2: 0 4px 8px -2px rgba(0, 0, 0, .06), 0 2px 4px -2px rgba(0, 0, 0, .04);--elev-3: 0 12px 24px -6px rgba(0, 0, 0, .1), 0 4px 8px -4px rgba(0, 0, 0, .06);--elev-4: 0 24px 48px -12px rgba(0, 0, 0, .14);--ring: 0 0 0 3px rgba(var(--primary-rgb), .18);--ring-strong: 0 0 0 3px rgba(var(--primary-rgb), .28)}.dark,[data-theme=dark]{--elev-1: 0 1px 2px rgba(0, 0, 0, .5), 0 1px 3px rgba(0, 0, 0, .6);--elev-2: 0 4px 8px -2px rgba(0, 0, 0, .55), 0 2px 4px -2px rgba(0, 0, 0, .4);--elev-3: 0 12px 24px -6px rgba(0, 0, 0, .6), 0 4px 8px -4px rgba(0, 0, 0, .45);--elev-4: 0 24px 48px -12px rgba(0, 0, 0, .7)}.brand-icon-box{background:var(--bg-elevated);border:1px solid var(--border-primary);box-shadow:var(--elev-1);padding:4px}.brand-logo-img{width:100%;height:100%;object-fit:contain;display:block;border-radius:calc(var(--radius-lg) - 4px)}.sidebar{background:var(--bg-elevated);box-shadow:var(--elev-2)}.sidebar-header{background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-secondary) 100%)}.brand-name{letter-spacing:-.01em}.nav-item{font-weight:500;letter-spacing:-.005em}.nav-item-active{box-shadow:0 4px 12px rgba(var(--primary-rgb),.22)}.nav-subitem-active{background:rgba(var(--primary-rgb),.1);color:var(--accent-color, var(--primary))}.btn{border-radius:10px;font-weight:600;letter-spacing:-.005em;box-shadow:var(--elev-1)}.btn:hover:not(:disabled){box-shadow:var(--elev-2)}.btn:focus-visible{outline:none;box-shadow:var(--elev-1),var(--ring)}.btn-secondary:hover:not(:disabled){border-color:var(--text-primary)}.btn-danger:hover:not(:disabled){filter:brightness(1.06);box-shadow:var(--elev-2),0 6px 18px #ef444447}.btn-success:hover:not(:disabled){filter:brightness(1.06);box-shadow:var(--elev-2),0 6px 18px #10b98147}.card{border-radius:14px;box-shadow:var(--elev-1)}.card:hover{box-shadow:var(--elev-3)}.stat-card{border-radius:14px}.form-input,.form-select,.search-input,.filter-input,.fee-input,textarea.form-input{border-radius:10px}.form-input:focus,.form-select:focus,.search-input:focus,.filter-input:focus,.fee-input:focus,textarea.form-input:focus{outline:none;border-color:var(--accent-color, var(--text-primary));box-shadow:var(--ring)}.table tbody tr:hover{background:rgba(var(--primary-rgb),.035)}.modal-overlay,.confirm-modal-overlay{background:#00000073;backdrop-filter:blur(8px) saturate(140%);-webkit-backdrop-filter:blur(8px) saturate(140%)}.modal{border-radius:18px;box-shadow:var(--elev-4)}.sub__plan-card{border-radius:16px}.sub__plan-card--popular{border-color:var(--accent-color, var(--primary));box-shadow:0 0 0 1px var(--accent-color, var(--primary)),var(--elev-3)}.sub__plan-btn:hover{background:var(--accent-color, var(--primary));color:var(--bg-primary)}.settings-tab-active{background:var(--bg-elevated);border-left-color:var(--accent-color, var(--text-primary));box-shadow:var(--elev-1)}::selection{background:rgba(var(--primary-rgb),.18);color:var(--text-primary)}a{color:var(--accent-color, var(--text-primary));text-decoration-thickness:1px;text-underline-offset:2px;transition:opacity var(--transition-fast)}a:hover{opacity:.78}*:focus-visible{outline:none;box-shadow:var(--ring-strong);border-radius:6px}.status-badge{font-weight:700;letter-spacing:.04em}.toast{border-radius:12px;box-shadow:var(--elev-3)}@media (prefers-reduced-motion: reduce){.stat-card:hover,.sub__plan-card:hover,.btn:hover:not(:disabled){transform:none!important}}
