*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #4f46e5;--primary-dark: #4338ca;--primary-light: #818cf8;--primary-hover: #6366f1;--success: #10b981;--success-dark: #059669;--danger: #ef4444;--danger-dark: #dc2626;--warning: #f59e0b;--info: #0ea5e9;--info-dark: #0284c7;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--background: #f1f5f9;--surface: #ffffff;--text-primary: #0f172a;--text-secondary: #64748b;--border: #e2e8f0;--border-focus: #4f46e5;--sidebar-bg: #1e1b4b;--sidebar-width: 220px;--sidebar-item-hover: rgba(255,255,255,.08);--sidebar-item-active: rgba(255,255,255,.15);--sidebar-text: rgba(255,255,255,.75);--sidebar-text-active: #ffffff;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -1px rgba(0,0,0,.04);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -2px rgba(0,0,0,.04);--shadow-xl: 0 20px 25px -5px rgba(0,0,0,.1), 0 10px 10px -5px rgba(0,0,0,.04);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}body{margin:0;min-width:320px;min-height:100vh;color:var(--text-primary);background-color:var(--background)}h1,h2,h3,h4,h5,h6{line-height:1.25;font-weight:600;color:var(--text-primary)}h1{font-size:1.875rem}h2{font-size:1.375rem}h3{font-size:1.125rem}h4{font-size:1rem}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:.375rem;color:var(--text-primary);font-weight:600;font-size:.8125rem;letter-spacing:.01em}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.5625rem .875rem;border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:.9rem;color:var(--text-primary);background-color:var(--surface);transition:border-color .15s ease,box-shadow .15s ease;min-height:40px;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #4f46e51f}.form-group input:disabled,.form-group select:disabled{background-color:var(--gray-100);color:var(--text-secondary);cursor:not-allowed}.error-text{display:block;color:var(--danger);font-size:.8125rem;margin-top:.25rem;font-weight:500}button{font-family:inherit;padding:.5625rem 1.125rem;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;min-height:40px;line-height:1.2;white-space:nowrap}button:disabled{opacity:.5;cursor:not-allowed}button.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 3px #4f46e54d}button.btn-primary:not(:disabled):hover{background:var(--primary-dark);box-shadow:0 4px 12px #4f46e559;transform:translateY(-1px)}button.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1.5px solid var(--border)}button.btn-secondary:not(:disabled):hover{background:var(--gray-200);transform:translateY(-1px)}button.btn-success{background:var(--success);color:#fff}button.btn-success:not(:disabled):hover{background:var(--success-dark);transform:translateY(-1px)}button.btn-danger{background:var(--danger);color:#fff}button.btn-danger:not(:disabled):hover{background:var(--danger-dark);transform:translateY(-1px)}button.btn-info{background:var(--info);color:#fff}button.btn-info:not(:disabled):hover{background:var(--info-dark);transform:translateY(-1px)}button.btn-ghost{background:transparent;color:var(--text-secondary)}button.btn-ghost:not(:disabled):hover{background:var(--gray-100);color:var(--text-primary)}.card{background:var(--surface);border-radius:var(--radius-xl);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.page-header h2{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin-bottom:.125rem}.page-description{color:var(--text-secondary);font-size:.875rem;margin:0}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.875rem}thead{background:var(--gray-50)}th{padding:.625rem 1rem;text-align:left;font-weight:700;color:var(--gray-600);border-bottom:2px solid var(--border);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}td{padding:.75rem 1rem;border-bottom:1px solid var(--gray-100);color:var(--text-primary);font-size:.875rem;vertical-align:middle}tbody tr:hover{background:#fafafe}tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.02em}.btn-sm{padding:.3125rem .75rem;font-size:.8125rem;min-height:30px;border-radius:var(--radius-sm)}.action-buttons{display:flex;gap:.375rem}.btn-edit{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}.btn-edit:hover{background:#dbeafe;transform:translateY(-1px)}.btn-delete{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.btn-delete:hover{background:#fee2e2;transform:translateY(-1px)}.toast-success,.toast-error{position:fixed;top:1.25rem;right:1.25rem;padding:.875rem 1.25rem;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;box-shadow:var(--shadow-lg);z-index:99999;animation:toastSlide .25s ease-out;min-width:260px;display:flex;align-items:center;gap:.5rem}.toast-success{background:var(--success);color:#fff}.toast-error{background:var(--danger);color:#fff}@keyframes toastSlide{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}.modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-box{background:var(--surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:modalIn .2s ease-out}.modal-box.modal-lg{max-width:760px}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--border)}.modal-head h3{font-size:1.0625rem;font-weight:700}.modal-body{padding:var(--spacing-xl)}.modal-close{background:transparent;border:none;width:32px;height:32px;min-height:32px;padding:0;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:1.25rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.modal-close:hover{background:var(--gray-100);color:var(--text-primary);transform:none}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;padding-top:var(--spacing-lg);margin-top:var(--spacing-md);border-top:1px solid var(--border)}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary)}.empty-state p{font-size:1rem;margin:0}.loading-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary);font-size:.9375rem}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-muted{color:var(--text-secondary)}.text-center{text-align:center}.inline-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:var(--radius-md);padding:.5rem .875rem;font-size:.8125rem;font-weight:500;margin-bottom:.75rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.login-page{display:flex;min-height:100vh}.login-panel{flex:0 0 420px;display:flex;flex-direction:column;justify-content:center;padding:3rem 2.5rem;background:var(--surface)}.login-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:2.5rem}.login-logo-icon{width:44px;height:44px;background:var(--primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:800;color:#fff;box-shadow:0 4px 12px #4f46e559}.login-logo-text{display:flex;flex-direction:column;line-height:1.2}.login-logo-name{font-size:1.0625rem;font-weight:700;color:var(--text-primary)}.login-logo-sub{font-size:.75rem;color:var(--text-secondary);letter-spacing:.04em}.login-heading{margin-bottom:.375rem;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.login-sub{color:var(--text-secondary);font-size:.9rem;margin-bottom:2rem}.login-form{display:flex;flex-direction:column;gap:0}.login-form .form-group{margin-bottom:1.125rem}.login-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:var(--radius-md);padding:.75rem 1rem;font-size:.875rem;font-weight:500;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.login-submit{width:100%;padding:.75rem;font-size:.9375rem;font-weight:600;margin-top:.5rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s;min-height:44px}.login-submit:not(:disabled):hover{background:var(--primary-dark);box-shadow:0 4px 14px #4f46e559;transform:translateY(-1px)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-deco{flex:1;background:linear-gradient(145deg,#1e1b4b,#312e81,#4f46e5);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;position:relative;overflow:hidden}.login-deco:before{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:#ffffff08;top:-100px;right:-100px}.login-deco:after{content:"";position:absolute;width:350px;height:350px;border-radius:50%;background:#ffffff0a;bottom:-80px;left:-80px}.login-deco-content{position:relative;z-index:1;text-align:center;max-width:380px}.login-deco-icon{width:80px;height:80px;background:#ffffff1f;border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto 1.75rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15)}.login-deco-title{font-size:1.625rem;font-weight:700;color:#fff;margin-bottom:1rem;line-height:1.3}.login-deco-desc{color:#ffffffa6;font-size:.9375rem;line-height:1.6}.login-deco-features{margin-top:2rem;display:flex;flex-direction:column;gap:.75rem;text-align:left}.login-deco-feature{display:flex;align-items:center;gap:.75rem;color:#ffffffbf;font-size:.875rem}.login-deco-dot{width:8px;height:8px;border-radius:50%;background:var(--primary-light);flex-shrink:0}@media(max-width:768px){.login-page{flex-direction:column}.login-deco{display:none}.login-panel{flex:1;padding:2rem 1.5rem}}.print-modal{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999}.print-modal-content{background:#fff;padding:1.5rem;border-radius:10px;max-width:420px;width:90%;box-shadow:0 20px 60px #0006}.print-preview{background:#f0f0f0;padding:1rem;border-radius:6px;margin-bottom:1rem;max-height:70vh;overflow-y:auto;display:flex;justify-content:center}.thermal-receipt{background:#fff;width:72mm;padding:6mm 0 10mm;font-family:Courier New,Consolas,monospace;font-size:14px;line-height:1.6;color:#000}.receipt-header{text-align:center;margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid #000}.receipt-header h2{margin:0 0 6px;font-size:22px;font-weight:900;letter-spacing:3px}.receipt-id{margin:0;font-size:15px;font-weight:700}.receipt-divider{border-top:1px dashed #000;margin:10px 0}.receipt-divider-solid{border-top:2px solid #000;margin:10px 0}.receipt-details,.receipt-amounts{margin:10px 0}.detail-row,.amount-row{display:flex;justify-content:space-between;margin:6px 0;line-height:1.5}.detail-row .label,.amount-row .label{font-weight:700;flex-shrink:0;min-width:110px}.detail-row .value,.amount-row .value{text-align:right;word-break:break-word;flex-grow:1;font-weight:600}.total-row{font-size:17px;font-weight:900;margin-top:12px;padding-top:10px;border-top:2px solid #000}.total-row .label{letter-spacing:1px;font-weight:900}.total-row .value{font-size:19px;font-weight:900}.receipt-footer{text-align:center;font-size:13px;margin-top:14px;padding-top:10px;border-top:1px dashed #000}.entered-by{margin:4px 0;font-weight:700}.timestamp{margin:4px 0;font-weight:600}.receipt-footer-note{text-align:center;margin-top:12px;padding-top:10px;font-size:12px;font-weight:800;border-top:2px double #000}.receipt-footer-note p{margin:4px 0}.print-actions{display:flex;gap:.75rem}.print-actions button{flex:1}@media print{@page{size:80mm auto;margin:5mm 3mm}body *{visibility:hidden}.print-modal{background:none!important}.thermal-receipt,.thermal-receipt *{visibility:visible}.thermal-receipt{position:fixed;top:0;left:0;width:100%;padding:0;margin:0;background:#fff;font-size:12pt;line-height:1.6}.no-print{display:none!important}}.receipt-form-page{max-width:860px;margin:0 auto}.receipt-form{display:flex;flex-direction:column;gap:1rem}.form-card{background:var(--surface);border-radius:var(--radius-xl);border:1px solid var(--border);padding:1.25rem 1.5rem 1.375rem;box-shadow:var(--shadow-sm)}.form-card-title{font-size:.75rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:1rem}.type-pills{display:flex;gap:.5rem;flex-wrap:wrap}.type-pill{display:flex;align-items:center;justify-content:center;padding:.4rem 1rem;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;transition:all .15s ease;min-width:56px;height:40px}.type-pill:hover{border-color:var(--primary-light);background:#f5f3ff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.type-pill-code{font-size:.9375rem;font-weight:700;line-height:1;color:var(--text-primary)}.type-pill.type-c.active{border-color:var(--primary);background:#eef2ff}.type-pill.type-c.active .type-pill-code{color:var(--primary)}.type-pill.type-rc.active{border-color:var(--danger);background:#fef2f2}.type-pill.type-rc.active .type-pill-code{color:var(--danger)}.type-pill.type-o.active{border-color:var(--gray-500);background:var(--gray-100)}.type-pill.type-o.active .type-pill-code{color:var(--gray-700)}.customer-select-row{display:flex;gap:.75rem;align-items:flex-end}.customer-select-group{flex:1;margin-bottom:0}.btn-add-customer{flex-shrink:0;height:40px;padding-top:0;padding-bottom:0;align-self:flex-end;margin-bottom:0}.amounts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.amount-input-wrap{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--surface);transition:border-color .15s,box-shadow .15s}.amount-input-wrap:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px #4f46e51f}.currency-prefix{padding:0 .625rem;font-size:.8125rem;font-weight:600;color:var(--text-secondary);background:var(--gray-50);border-right:1.5px solid var(--border);height:40px;display:flex;align-items:center;white-space:nowrap}.amount-input{flex:1;border:none!important;box-shadow:none!important;padding:.5rem .75rem;font-size:.9rem;font-weight:600;min-height:40px;width:0}.amount-input:focus{outline:none}.total-display{height:40px;display:flex;align-items:center;gap:.375rem;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:var(--radius-md);padding:0 .875rem;box-shadow:0 2px 8px #4f46e540}.total-prefix{font-size:.75rem;font-weight:600;color:#ffffffb3}.total-value{font-size:1rem;font-weight:700;color:#fff;letter-spacing:.01em}.form-actions-bar{display:flex;gap:.75rem;align-items:center;padding-top:.25rem}.btn-submit{padding:.6875rem 1.75rem;font-size:.9375rem}.shortcut-hint{font-size:.8rem;color:var(--text-secondary);margin-top:-.25rem}.shortcut-hint kbd{display:inline-block;padding:.1rem .375rem;font-size:.75rem;font-family:monospace;background:var(--gray-100);border:1px solid var(--gray-300);border-radius:4px;box-shadow:0 1px 0 var(--gray-300);font-weight:600}@media(max-width:900px){.amounts-grid{grid-template-columns:1fr 1fr}}@media(max-width:600px){.amounts-grid{grid-template-columns:1fr}.customer-select-row{flex-direction:column}.btn-add-customer{width:100%;height:auto}.form-card{padding:1rem}.type-pills{gap:.375rem}.type-pill{min-width:70px;padding:.4rem .75rem}}.receipt-management{max-width:1200px;margin:0 auto}.filters-card{margin-bottom:1rem}.filters-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:.875rem;align-items:end}.summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem;margin-bottom:1rem}.summary-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:1rem 1.25rem;box-shadow:var(--shadow-xs);transition:all .15s}.summary-stat:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.summary-stat-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);margin-bottom:.375rem}.summary-stat-value{font-size:1.375rem;font-weight:700;color:var(--text-primary);line-height:1.2}.summary-stat.total{background:linear-gradient(135deg,var(--primary),#7c3aed);border:none}.summary-stat.total .summary-stat-label{color:#ffffffbf}.summary-stat.total .summary-stat-value{color:#fff;font-size:1.5rem}.receipts-table-card{padding:0;overflow:hidden}.receipts-table-card .table-container{overflow-x:auto}.receipts-table-card table{border-radius:0}.badge-type{font-weight:700;font-size:.75rem;letter-spacing:.03em}.badge-c{background:#eef2ff;color:var(--primary);border:1px solid #c7d2fe}.badge-rc{background:#fef2f2;color:var(--danger);border:1px solid #fecaca}.badge-o{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-200)}.badge-f{background:#eff6ff;color:var(--info);border:1px solid #bfdbfe}.badge-u{background:#fffbeb;color:var(--warning);border:1px solid #fde68a}.cheque-count{font-size:.75rem;color:var(--text-secondary);margin-left:.25rem}.modal-body .form-section{margin-bottom:1.25rem}.modal-body .section-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);margin-bottom:.75rem;display:block}.modal-body .form-row-2{gap:.875rem}.modal-body .amounts-4{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem}@media(max-width:1100px){.filters-grid{grid-template-columns:1fr 1fr 1fr}.summary-row{grid-template-columns:1fr 1fr}}@media(max-width:768px){.filters-grid{grid-template-columns:1fr}.summary-row,.modal-body .amounts-4{grid-template-columns:1fr 1fr}}@media(max-width:480px){.summary-row{grid-template-columns:1fr}}.customer-management{max-width:900px;margin:0 auto}.cm-toolbar{display:flex;align-items:center;gap:.875rem;margin-bottom:1rem;flex-wrap:wrap}.cm-count{font-size:.8125rem;color:var(--text-secondary);font-weight:500;white-space:nowrap}@media(max-width:600px){.cm-toolbar{flex-direction:column;align-items:stretch}.cm-toolbar .btn-primary{width:100%}}.user-management{max-width:900px;margin:0 auto}.um-toolbar{display:flex;align-items:center;gap:.875rem;margin-bottom:1rem;justify-content:flex-end}.um-count{font-size:.8125rem;color:var(--text-secondary);font-weight:500;margin-right:auto}.badge-admin{background:var(--primary);color:#fff}.badge-user{background:var(--gray-500);color:#fff}.badge-active{background:var(--success);color:#fff}.badge-inactive{background:var(--danger);color:#fff}.um-checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-primary)}.um-checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary)}.um-access-denied{display:flex;align-items:center;gap:.5rem;background:#fffbeb;color:#92400e;border:1px solid #fde68a;border-left:4px solid var(--warning);border-radius:var(--radius-md);padding:.875rem 1.125rem;font-size:.875rem;font-weight:500}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;overflow:hidden}.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.08)}.brand-icon{width:36px;height:36px;background:var(--primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.0625rem;font-weight:800;color:#fff;flex-shrink:0;box-shadow:0 2px 8px #4f46e566}.brand-text{display:flex;flex-direction:column;line-height:1.2}.brand-name{font-size:.9375rem;font-weight:700;color:#fff}.brand-sub{font-size:.6875rem;color:var(--sidebar-text);letter-spacing:.04em;text-transform:uppercase}.sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.125rem;overflow-y:auto}.nav-section-label{display:block;font-size:.6875rem;font-weight:700;letter-spacing:.08em;color:#ffffff59;padding:.5rem .625rem .375rem;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:.625rem;padding:.625rem .75rem;border-radius:var(--radius-md);background:transparent;border:none;color:var(--sidebar-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:left;width:100%;min-height:38px}.nav-item:hover{background:var(--sidebar-item-hover);color:var(--sidebar-text-active);transform:none;box-shadow:none}.nav-item.active{background:var(--sidebar-item-active);color:var(--sidebar-text-active);font-weight:600;box-shadow:none}.nav-item.active svg{color:var(--primary-light)}.nav-item svg{flex-shrink:0;opacity:.75}.nav-item.active svg,.nav-item:hover svg{opacity:1}.sidebar-footer{border-top:1px solid rgba(255,255,255,.08);padding:.875rem .75rem;display:flex;align-items:center;gap:.5rem}.sidebar-user{display:flex;align-items:center;gap:.625rem;flex:1;min-width:0}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary-light),var(--primary));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}.sidebar-user-info{display:flex;flex-direction:column;min-width:0}.sidebar-user-name{font-size:.8125rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.6875rem;color:var(--sidebar-text);text-transform:capitalize}.btn-logout-sidebar{background:transparent;border:none;color:var(--sidebar-text);padding:.375rem;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;min-height:auto;flex-shrink:0}.btn-logout-sidebar:hover{background:#ef444433;color:#fca5a5;transform:none;box-shadow:none}.main-area{margin-left:var(--sidebar-width);flex:1;display:flex;flex-direction:column;min-height:100vh}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:.875rem 2rem;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-xs)}.topbar-title h2{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:.0625rem}.topbar-title p{font-size:.8125rem;color:var(--text-secondary);margin:0}.page-content{flex:1;padding:1.75rem 2rem;max-width:1400px;width:100%;margin-left:auto;margin-right:auto}@media(max-width:768px){.sidebar{transform:translate(-100%)}.main-area{margin-left:0}.page-content{padding:1rem}.topbar{padding:.75rem 1rem}}#root{width:100%;min-height:100vh;margin:0;padding:0}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,var(--primary) 0%,#7c3aed 100%)}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:1rem}.spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.loading-text{color:#fff;font-size:1.125rem;font-weight:500}@keyframes spin{to{transform:rotate(360deg)}}
