@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary: #0ea5e9;--primary-hover: #0284c7;--primary-light: rgba(14, 165, 233, .12);--accent: #f97316;--accent-hover: #ea580c;--accent-light: rgba(249, 115, 22, .12);--danger: #ef4444;--danger-light: rgba(239, 68, 68, .1);--success: #22c55e;--success-light: rgba(34, 197, 94, .1);--warning: #f59e0b;--warning-light: rgba(245, 158, 11, .1);--info: #8b5cf6;--info-light: rgba(139, 92, 246, .1);--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-hover: #f1f5f9;--bg-input: #f8fafc;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--border: #e2e8f0;--border-hover: #cbd5e1;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--font-family: "Inter", system-ui, -apple-system, sans-serif;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .1);--transition: .25s ease;--gradient-primary: linear-gradient(135deg, #0ea5e9, #06b6d4);--gradient-accent: linear-gradient(135deg, #f97316, #fb923c);--gradient-brand: linear-gradient(135deg, #0ea5e9, #8b5cf6)}[data-theme=dark]{--primary: #38bdf8;--primary-hover: #0ea5e9;--primary-light: rgba(56, 189, 248, .15);--accent: #fb923c;--accent-hover: #f97316;--accent-light: rgba(251, 146, 60, .15);--danger: #f87171;--danger-light: rgba(248, 113, 113, .15);--success: #4ade80;--success-light: rgba(74, 222, 128, .15);--warning: #fbbf24;--warning-light: rgba(251, 191, 36, .15);--info: #a78bfa;--info-light: rgba(167, 139, 250, .15);--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: #1e293b;--bg-hover: #334155;--bg-input: #1e293b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border: #334155;--border-hover: #475569;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .5);--gradient-primary: linear-gradient(135deg, #38bdf8, #22d3ee);--gradient-accent: linear-gradient(135deg, #fb923c, #fdba74);--gradient-brand: linear-gradient(135deg, #38bdf8, #a78bfa)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);font-weight:400;line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);min-height:100vh;margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-synthesis:none;text-rendering:optimizeLegibility}#root{min-height:100vh}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px;opacity:.5}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}::selection{background:#0ea5e940;color:var(--text-primary)}a{color:var(--primary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--primary-hover)}img{max-width:100%;display:block}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}.text-primary{color:var(--primary)}.text-muted{color:var(--text-muted)}.page{min-height:100vh;width:100%}.flex{display:flex}.flex-col{flex-direction:column}.flex-center{align-items:center;justify-content:center}.flex-between{justify-content:space-between}.flex-gap-sm{gap:.5rem}.flex-gap-md{gap:1rem}.flex-gap-lg{gap:1.5rem}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1rem;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #0ea5e933}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 12px #0ea5e94d}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{opacity:.9}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{opacity:.9}.btn-sm{padding:.35rem .6rem;font-size:.78rem}.btn-icon{padding:.4rem;background:transparent;border:none;color:var(--text-muted);border-radius:6px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center}.btn-icon:hover{background:var(--bg-hover);color:var(--primary)}.btn-icon.danger:hover{background:var(--danger-light);color:var(--danger)}.data-table-wrapper{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.dt-toolbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;gap:1rem;flex-wrap:wrap}.dt-title{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:0}.dt-toolbar-end{display:flex;align-items:center;gap:.5rem}.dt-search{display:flex;align-items:center;gap:.4rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.4rem .7rem;transition:all .2s}.dt-search:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.dt-search svg{color:var(--text-muted);flex-shrink:0}.dt-search input{background:transparent;border:none;outline:none;color:var(--text-primary);font-size:.85rem;width:160px;font-family:inherit}.dt-search input::placeholder{color:var(--text-muted)}.dt-add-btn{display:flex;align-items:center;gap:.35rem;background:var(--primary);color:#fff;border:none;padding:.45rem .85rem;border-radius:var(--radius-sm);font-size:.83rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;box-shadow:0 2px 6px #0ea5e933}.dt-add-btn:hover{background:var(--primary-hover);box-shadow:0 4px 10px #0ea5e94d}.dt-container{overflow-x:auto}.dt-table{width:100%;border-collapse:collapse}.dt-table thead{background:var(--bg-hover)}.dt-table th{padding:.7rem 1rem;text-align:start;font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none}.dt-table th.sortable{cursor:pointer}.dt-table th.sortable:hover{color:var(--text-secondary)}.sort-icon{display:inline-flex;margin-inline-start:.25rem;vertical-align:middle}.dt-table td{padding:.7rem 1rem;font-size:.88rem;color:var(--text-primary);border-bottom:1px solid var(--border)}.dt-table tbody tr{transition:background .15s}.dt-table tbody tr:hover{background:var(--bg-hover)}.dt-table tbody tr.clickable{cursor:pointer}.dt-empty{text-align:center;color:var(--text-muted);padding:2.5rem 1rem!important;font-size:.9rem}.dt-actions{display:flex;align-items:center;gap:.25rem}.dt-actions-header{width:100px}.dt-footer{padding:.65rem 1.25rem;border-top:1px solid var(--border)}.dt-count{font-size:.78rem;color:var(--text-muted)}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem;animation:fadeIn .15s ease}.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:scaleIn .2s ease}.modal-sm{max-width:380px}.modal-md{max-width:520px}.modal-lg{max-width:700px}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal-header h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.modal-close{background:none;border:none;color:var(--text-muted);padding:.3rem;border-radius:6px;cursor:pointer;transition:all .2s}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-body{padding:1.5rem}.form-field{display:flex;flex-direction:column;gap:.35rem}.form-field label{font-size:.82rem;font-weight:500;color:var(--text-secondary)}.form-field .required{color:var(--danger);margin-inline-start:.2rem}.form-field input,.form-field select,.form-field textarea{padding:.6rem .8rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;font-family:inherit;outline:none;transition:all .2s;width:100%}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-field input::placeholder,.form-field textarea::placeholder{color:var(--text-muted)}.form-field input:disabled,.form-field select:disabled,.form-field textarea:disabled{opacity:.5;cursor:not-allowed}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}@media(max-width:600px){.form-grid{grid-template-columns:1fr}}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all .25s ease;box-shadow:var(--shadow-sm)}.stat-card[role=button]{cursor:pointer}.stat-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-primary .stat-icon{background:var(--primary-light);color:var(--primary)}.stat-success .stat-icon{background:var(--success-light);color:var(--success)}.stat-warning .stat-icon{background:var(--warning-light);color:var(--warning)}.stat-danger .stat-icon{background:var(--danger-light);color:var(--danger)}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.6rem;font-weight:700;color:var(--text-primary);line-height:1.2}.stat-label{font-size:.82rem;color:var(--text-muted);margin-top:.15rem}.confirm-dialog{text-align:center}.confirm-icon{color:var(--warning);margin-bottom:.75rem}.confirm-message{color:var(--text-secondary);font-size:.92rem;margin-bottom:1.5rem}.confirm-actions{display:flex;justify-content:center;gap:.5rem}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-weight:600}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-primary{background:var(--primary-light);color:var(--primary)}.badge-muted{background:var(--bg-hover);color:var(--text-muted)}.page-header{margin-bottom:1.5rem}.page-title{font-size:1.35rem;font-weight:700;color:var(--text-primary);margin:0}.page-subtitle{font-size:.85rem;color:var(--text-muted);margin-top:.25rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}@media(max-width:600px){.stats-grid{grid-template-columns:1fr 1fr}.dt-toolbar{flex-direction:column;align-items:stretch}.dt-toolbar-end{flex-wrap:wrap}.dt-search input{width:100%}}.test-cards{display:flex;flex-direction:column;gap:.75rem}.test-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem;transition:all .2s}.test-card:hover{border-color:var(--border-hover)}.test-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}.test-card-header h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.test-card-info{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.85rem;font-size:.85rem;color:var(--text-secondary)}.balance.positive{color:var(--success);font-weight:600}.balance.negative{color:var(--danger);font-weight:600}.test-card-actions{display:flex;gap:.5rem;flex-wrap:wrap}.test-card-actions .btn{flex:1;min-width:80px}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted);font-size:.95rem}.date-filter-bar{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:1rem;flex-wrap:wrap;box-shadow:var(--shadow-sm)}.date-filter-label{display:flex;align-items:center;gap:.4rem;font-size:.88rem;font-weight:500;color:var(--text-secondary)}.date-filter-label svg{color:var(--primary)}.date-filter-input{padding:.4rem .7rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.88rem;font-family:inherit;outline:none;transition:all .2s}.date-filter-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.live-indicator{display:flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:600;color:var(--success);margin-inline-start:auto;padding:.3rem .65rem;background:var(--success-light);border-radius:20px;animation:pulse-glow 2s ease-in-out infinite}.live-indicator svg{animation:spin-slow 3s linear infinite}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.7}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dt-table tbody tr.row-active{background:var(--success-light);border-inline-start:3px solid var(--success)}.dt-table tbody tr.row-active:hover{background:#22c55e26}.dt-table tbody tr.row-ending-soon{background:var(--warning-light);border-inline-start:3px solid var(--warning);animation:row-pulse 1.5s ease-in-out infinite}.dt-table tbody tr.row-ending-soon:hover{background:#f59e0b26}@keyframes row-pulse{0%,to{background:var(--warning-light)}50%{background:#f59e0b33}}.dt-table tbody tr.row-expired{background:var(--danger-light);border-inline-start:3px solid var(--danger)}.dt-table tbody tr.row-expired:hover{background:#ef444426}.dt-table tbody tr.row-completed{opacity:.55}.time-active{color:var(--success);font-weight:600}.time-ending-soon{color:var(--warning);font-weight:600}.time-expired{color:var(--danger);font-weight:600;text-decoration:line-through}.toast-container{position:fixed;top:1rem;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:.5rem;max-width:480px;width:90%}.toast{display:flex;align-items:center;gap:.65rem;padding:.75rem 1rem;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:toast-slide-in .4s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.toast-warning{background:#f59e0b1f;border-color:#f59e0b4d;color:var(--warning)}[data-theme=dark] .toast-warning{background:#f59e0b33}.toast-ended{background:#ef44441f;border-color:#ef44444d;color:var(--danger)}[data-theme=dark] .toast-ended{background:#ef444433}.toast-icon{flex-shrink:0;display:flex;align-items:center}.toast-warning .toast-icon{animation:bell-ring .6s ease .3s}@keyframes bell-ring{0%,to{transform:rotate(0)}15%{transform:rotate(12deg)}30%{transform:rotate(-10deg)}45%{transform:rotate(8deg)}60%{transform:rotate(-6deg)}75%{transform:rotate(3deg)}}.toast-message{flex:1;font-size:.88rem;font-weight:500;color:var(--text-primary)}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem;border-radius:4px;display:flex;transition:all .15s}.toast-close:hover{background:#0000001a;color:var(--text-primary)}.link-cell{color:var(--primary);cursor:pointer;font-weight:600;transition:all .15s;text-decoration:underline;text-decoration-color:transparent}.link-cell:hover{text-decoration-color:var(--primary);opacity:.85}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.student-profile{max-width:1100px}.sp-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1rem;flex-wrap:wrap}.sp-info{display:flex;align-items:center;gap:1rem;flex:1;min-width:260px}.sp-avatar{width:56px;height:56px;border-radius:50%;background:var(--primary-gradient);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sp-name{font-size:1.35rem;font-weight:700;margin:0 0 .35rem;color:var(--text-primary)}.sp-meta{display:flex;flex-wrap:wrap;gap:.6rem 1.2rem;font-size:.85rem;color:var(--text-muted)}.sp-meta span{display:flex;align-items:center;gap:.3rem}.sp-finance{display:flex;gap:.75rem;flex-wrap:wrap}.sp-finance-item{display:flex;align-items:center;gap:.6rem;padding:.6rem 1rem;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-secondary);min-width:130px}.sp-finance-item div{display:flex;flex-direction:column}.sp-finance-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-weight:600}.sp-finance-value{font-size:1.05rem;font-weight:700}.sp-debit,.sp-debit .sp-finance-value{color:var(--danger)}.sp-credit,.sp-credit .sp-finance-value,.sp-balance.positive,.sp-balance.positive .sp-finance-value{color:var(--success)}.sp-balance.negative,.sp-balance.negative .sp-finance-value{color:var(--danger)}.sp-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:1rem;overflow-x:auto}.sp-tab{display:flex;align-items:center;gap:.4rem;padding:.65rem 1.1rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.88rem;font-weight:500;color:var(--text-muted);transition:all .2s;white-space:nowrap}.sp-tab:hover{color:var(--primary);background:var(--primary-light)}.sp-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.sp-tab-content{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem}.sp-section{animation:fade-in .25s ease-out}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.sp-filter-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.sp-lesson-counts{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border)}.sp-lesson-count-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .85rem;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border);font-size:.85rem}.sp-lc-label{color:var(--text-muted);font-weight:500}.sp-lc-value{font-weight:700;color:var(--primary)}.empty-state{text-align:center;padding:2rem;color:var(--text-muted);font-size:.95rem}@media(max-width:768px){.sp-header{flex-direction:column}.sp-finance{width:100%}.sp-finance-item{flex:1;min-width:100px}}.debt-warning{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;margin:.75rem 0 0;background:var(--danger-light);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--danger);animation:fade-in .25s ease-out}.debt-warning strong{display:block;font-size:.88rem;margin-bottom:.15rem}.debt-warning span{font-size:.82rem;opacity:.85}.dashboard-home{max-width:1100px}.dash-section{margin-top:1.5rem}.dash-section-title{display:flex;align-items:center;gap:.5rem;font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem}.dash-cards-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.dash-mini-card{display:flex;flex-direction:column;padding:1rem 1.1rem;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform .15s,box-shadow .15s}.dash-mini-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000f}.dmc-label{font-size:.78rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.25rem}.dmc-value{font-size:1.5rem;font-weight:800;color:var(--text-primary)}.dash-finance-card{display:flex;align-items:center;gap:.85rem;padding:1rem 1.2rem;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);border-inline-start:4px solid;transition:transform .15s}.dash-finance-card:hover{transform:translateY(-2px)}.dash-finance-card div{display:flex;flex-direction:column}.dash-finance-card.success{border-inline-start-color:var(--success);color:var(--success)}.dash-finance-card.info{border-inline-start-color:var(--primary);color:var(--primary)}.dash-finance-card.danger{border-inline-start-color:var(--danger);color:var(--danger)}.dfc-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.03em;font-weight:600;opacity:.75}.dfc-value{font-size:1.25rem;font-weight:800;color:var(--text-primary)}.dfc-sub{font-size:.78rem;color:var(--text-muted);margin-top:.1rem}.dash-rate-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg)}.rate-circle{width:72px;height:72px;position:relative;flex-shrink:0}.rate-circle svg{width:100%;height:100%;transform:rotate(-90deg)}.rate-bg{fill:none;stroke:var(--border);stroke-width:3}.rate-fg{fill:none;stroke:var(--primary);stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .8s ease-out}.rate-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:800;color:var(--text-primary)}.rate-info{display:flex;flex-direction:column;gap:.2rem}.rate-info strong{font-size:.9rem;color:var(--text-primary)}.rate-info span{font-size:.82rem;color:var(--text-muted)}.dash-chart-container{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}.dash-chart{display:flex;align-items:flex-end;gap:0;height:180px;border-bottom:2px solid var(--border);padding-bottom:.5rem}.chart-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.chart-bar-wrap{flex:1;display:flex;align-items:flex-end;justify-content:center;width:100%}.chart-bar{width:60%;max-width:38px;min-height:4px;background:var(--primary-gradient);border-radius:4px 4px 0 0;transition:height .6s ease-out;position:relative;cursor:default}.chart-bar-label{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:.7rem;font-weight:700;color:var(--text-muted);white-space:nowrap}.chart-month{font-size:.68rem;color:var(--text-muted);margin-top:.4rem;font-weight:500}.chart-rate{font-size:.65rem;font-weight:700;margin-top:.15rem}.chart-rate.good{color:var(--success)}.chart-rate.bad{color:var(--danger)}.chart-legend{display:flex;justify-content:center;gap:1.5rem;margin-top:.75rem;font-size:.78rem;color:var(--text-muted)}.chart-legend span{display:flex;align-items:center;gap:.35rem}.legend-dot{width:10px;height:10px;border-radius:2px;display:inline-block}.legend-dot.bar{background:var(--primary)}.legend-dot.good{background:var(--success)}.legend-dot.bad{background:var(--danger)}@media(max-width:768px){.dash-cards-row{grid-template-columns:repeat(2,1fr)}.dash-chart{height:140px}.chart-month{font-size:.6rem}.chart-rate{font-size:.58rem}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#0ea5e9,#06b6d4 30%,#8b5cf6 70%,#d946ef);padding:1rem}.login-bg{position:fixed;inset:0;pointer-events:none;z-index:0}.login-bg-circle{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:floatCircle 12s ease-in-out infinite}.login-bg-circle-1{width:400px;height:400px;background:#fbbf24;top:-100px;left:-100px;animation-delay:0s}.login-bg-circle-2{width:300px;height:300px;background:#f97316;bottom:-80px;right:-80px;animation-delay:-4s}.login-bg-circle-3{width:250px;height:250px;background:#22d3ee;top:50%;left:60%;animation-delay:-8s}@keyframes floatCircle{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}.lang-switcher{position:fixed;top:1.25rem;right:1.25rem;display:flex;gap:.35rem;z-index:100}.lang-switcher button{background:#ffffff26;border:1px solid rgba(255,255,255,.25);color:#ffffffbf;padding:.4rem .75rem;border-radius:8px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .25s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lang-switcher button:hover{background:#ffffff40;color:#fff}.lang-switcher button.active{background:#fff;border-color:#fff;color:#0ea5e9;font-weight:600;box-shadow:0 2px 12px #ffffff4d}.login-card{position:relative;z-index:10;width:100%;max-width:420px;background:#fffffff2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.6);border-radius:24px;padding:2.5rem 2rem;box-shadow:0 20px 60px #00000026,0 0 0 1px #ffffff4d inset;animation:fadeInUp .6s ease-out}[data-theme=dark] .login-card{background:#1e293be6;border-color:#ffffff1a}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-card.shake{animation:shakeCard .6s ease-in-out}@keyframes shakeCard{0%,to{transform:translate(0)}15%{transform:translate(-8px)}30%{transform:translate(8px)}45%{transform:translate(-6px)}60%{transform:translate(6px)}75%{transform:translate(-3px)}90%{transform:translate(3px)}}.login-header{text-align:center;margin-bottom:2rem}.login-logo{display:flex;justify-content:center;margin-bottom:1rem}.login-logo-icon{width:60px;height:60px;border-radius:18px;background:linear-gradient(135deg,#0ea5e9,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 20px #0ea5e959;overflow:hidden}.login-logo-img{width:100%;height:100%;object-fit:cover}.login-title{font-size:1.75rem;font-weight:700;color:#0f172a;margin:0;letter-spacing:-.5px}[data-theme=dark] .login-title{color:#f1f5f9}.login-subtitle{font-size:.9rem;color:#64748b;margin:.4rem 0 0}.login-form{display:flex;flex-direction:column;gap:1.25rem}.input-group{display:flex;flex-direction:column;gap:.4rem}.input-group label{font-size:.82rem;font-weight:500;color:#475569;padding:0 .25rem}[data-theme=dark] .input-group label{color:#94a3b8}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:.9rem;color:#94a3b8;pointer-events:none;transition:color .25s ease;flex-shrink:0}[dir=rtl] .input-icon{left:auto;right:.9rem}.input-wrapper input{width:100%;padding:.8rem .9rem .8rem 2.75rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;color:#0f172a;font-size:.95rem;font-family:inherit;transition:all .25s ease;outline:none}[data-theme=dark] .input-wrapper input{background:#1e293b;border-color:#334155;color:#f1f5f9}[dir=rtl] .input-wrapper input{padding:.8rem 2.75rem .8rem .9rem}.input-wrapper input::placeholder{color:#94a3b8}.input-wrapper input:focus{border-color:#0ea5e9;background:#fff;box-shadow:0 0 0 3px #0ea5e926}[data-theme=dark] .input-wrapper input:focus{background:#1e293b}.input-wrapper:has(input:focus) .input-icon{color:#0ea5e9}.toggle-password{position:absolute;right:.6rem;background:none;border:none;color:#94a3b8;cursor:pointer;padding:.3rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}[dir=rtl] .toggle-password{right:auto;left:.6rem}.toggle-password:hover{color:#475569;background:#0000000d}.login-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:10px;padding:.65rem .9rem;display:flex;align-items:center;gap:.5rem;animation:fadeIn .3s ease}.login-error span{color:#ef4444;font-size:.85rem;font-weight:500}.login-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.85rem;border:none;border-radius:12px;background:linear-gradient(135deg,#0ea5e9,#06b6d4);color:#fff;font-size:.95rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .3s ease;margin-top:.25rem;box-shadow:0 4px 15px #0ea5e94d}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,#38bdf8,#0ea5e9);transform:translateY(-1px);box-shadow:0 6px 25px #0ea5e966}.login-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 10px #0ea5e94d}.login-btn:disabled{opacity:.65;cursor:not-allowed}.spinner{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-footer{text-align:center;margin-top:1.75rem;padding-top:1.25rem;border-top:1px solid #e2e8f0}[data-theme=dark] .login-footer{border-color:#334155}.login-footer p{color:#94a3b8;font-size:.78rem;margin:0}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);color:var(--text-muted);font-size:1rem}@media(max-width:480px){.login-card{padding:2rem 1.5rem;border-radius:20px}.login-title{font-size:1.5rem}.login-bg-circle-1{width:250px;height:250px}.login-bg-circle-2{width:200px;height:200px}.login-bg-circle-3{width:150px;height:150px}}.dashboard{display:flex;min-height:100vh;background:var(--bg-primary)}.sidebar{width:250px;min-height:100vh;background:var(--bg-secondary);border-inline-end:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;bottom:0;z-index:50;transition:transform .3s ease}[dir=rtl] .sidebar{right:0}[dir=ltr] .sidebar{left:0}.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1rem;border-bottom:1px solid var(--border)}.brand-logo{width:38px;height:38px;border-radius:10px;background:var(--gradient-brand);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 3px 10px #0ea5e940;overflow:hidden}.brand-logo-img{width:100%;height:100%;object-fit:cover}.brand-name{font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.sidebar-close{display:none;background:none;border:none;color:var(--text-muted);margin-inline-start:auto;padding:.25rem;border-radius:6px;transition:all .2s}.sidebar-close:hover{color:var(--text-primary);background:var(--bg-hover)}.sidebar-nav{flex:1;padding:.75rem .6rem;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:.7rem;padding:.65rem .85rem;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:.88rem;font-weight:500;transition:all .2s ease;border:none;background:none;width:100%;cursor:pointer;font-family:inherit}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-link.active{background:var(--primary-light);color:var(--primary);font-weight:600}.sidebar-footer{padding:.6rem;border-top:1px solid var(--border)}.logout-link{color:var(--danger)!important}.logout-link:hover{background:var(--danger-light)!important}.dashboard-main{flex:1;margin-inline-start:250px;display:flex;flex-direction:column;min-height:100vh}.dashboard-content{flex:1;padding:1.5rem;max-width:1400px;width:100%}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg-secondary);position:sticky;top:0;z-index:30;box-shadow:var(--shadow-sm)}.header-start{display:flex;align-items:center;gap:.75rem}.menu-toggle{display:none;background:none;border:none;color:var(--text-secondary);padding:.4rem;border-radius:8px;transition:all .2s}.menu-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.header-end{display:flex;align-items:center;gap:.75rem}.header-btn{display:flex;align-items:center;gap:.4rem;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-secondary);padding:.4rem .75rem;border-radius:8px;font-size:.82rem;cursor:pointer;transition:all .2s;font-family:inherit}.header-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.lang-dropdown{position:relative}.lang-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:.35rem;min-width:120px;box-shadow:var(--shadow-lg);z-index:100;animation:fadeIn .15s ease}[dir=rtl] .lang-menu{right:auto;left:0}.lang-option{display:block;width:100%;padding:.45rem .75rem;border:none;background:none;color:var(--text-secondary);font-size:.85rem;font-family:inherit;border-radius:6px;cursor:pointer;text-align:start;transition:all .15s}.lang-option:hover{background:var(--bg-hover);color:var(--text-primary)}.lang-option.active{background:var(--primary-light);color:var(--primary);font-weight:600}.header-user{display:flex;align-items:center;gap:.5rem}.user-avatar{width:30px;height:30px;border-radius:8px;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 2px 8px #0ea5e933}.user-name{font-size:.85rem;font-weight:500;color:var(--text-primary)}.theme-toggle{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-secondary);padding:.4rem;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.theme-toggle:hover{background:var(--bg-hover);color:var(--warning)}.sidebar-overlay{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%);width:260px;box-shadow:var(--shadow-lg);background:var(--bg-secondary)}[dir=rtl] .sidebar{transform:translate(100%)}.sidebar.open{transform:translate(0)}.sidebar-close{display:flex}.sidebar-overlay{display:block;position:fixed;inset:0;background:#0006;z-index:40}.dashboard-main{margin-inline-start:0}.menu-toggle{display:flex}.dashboard-content{padding:1rem}.user-name{display:none}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}
