:root{--font-family: "Outfit", sans-serif;--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: rgba(99, 102, 241, .15);--secondary: #10b981;--danger: #ef4444;--warning: #f59e0b;--info: #0ea5e9;--bg-color: #0f172a;--bg-surface: #1e293b;--bg-glass: rgba(30, 41, 59, .6);--border-glass: rgba(255, 255, 255, .08);--border-focus: rgba(99, 102, 241, .4);--text-main: #f8fafc;--text-muted: #94a3b8;--text-inverse: #ffffff;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-glass: 0 8px 32px 0 rgba(0, 0, 0, .3);--radius-sm: .375rem;--radius-md: .75rem;--radius-lg: 1.25rem;--radius-full: 9999px;--transition: all .2s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;background-image:radial-gradient(circle at 15% 50%,rgba(99,102,241,.08),transparent 25%),radial-gradient(circle at 85% 30%,rgba(16,185,129,.05),transparent 25%);background-attachment:fixed}.glass-panel{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-glass);box-shadow:var(--shadow-glass);border-radius:var(--radius-lg)}.glass-card{background:#1e293b66;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border-glass);border-radius:var(--radius-md);padding:var(--space-4);transition:var(--transition)}.glass-card:hover{background:#1e293b99;border-color:var(--border-focus)}h1,h2,h3,h4,h5,h6{font-weight:600;letter-spacing:-.025em;color:var(--text-main)}.text-muted{color:var(--text-muted)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-semibold{font-weight:600}.text-center{text-align:center}.flex{display:flex}.flex-col{flex-direction:column}.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}.flex-1{flex:1 1 0%}.grid{display:grid}.relative{position:relative}.inline{display:inline}.inline-block{display:inline-block}.block{display:block}.gap-2{gap:var(--space-2)}.gap-1{gap:var(--space-1)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.input-group{display:flex;flex-direction:column;gap:var(--space-1)}.input-group label{font-size:.875rem;font-weight:600;color:#a7b5cc}.input-control{background:linear-gradient(180deg,#0f172ac7,#0f172a94);border:1px solid rgba(148,163,184,.2);padding:.75rem 1rem;border-radius:1rem;color:var(--text-main);font-family:var(--font-family);font-weight:500;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease,background-color .2s ease;outline:none;box-shadow:inset 0 1px #ffffff0d,0 10px 24px -18px #020617f2}.input-control::placeholder{color:#7f8da6}.input-control:hover{border-color:#6366f173;background:linear-gradient(180deg,#0f172ae0,#0f172aa8)}.input-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f138,inset 0 1px #ffffff14,0 14px 28px -18px #6366f1cc;transform:translateY(-1px)}select.input-control{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:3rem;background-image:radial-gradient(circle at right 1.35rem center,#6366f129 0 .75rem,#6366f100 .76rem),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23dbe7ff' stroke-width='2.3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right center,right .85rem center;background-size:2.2rem 2.2rem,1rem}select.input-control::-ms-expand{display:none}select.input-control option{background-color:#0f172a;color:var(--text-main)}input[type=number].input-control,input[type=number].form-input{-moz-appearance:textfield;appearance:textfield}input[type=number].input-control::-webkit-outer-spin-button,input[type=number].input-control::-webkit-inner-spin-button,input[type=number].form-input::-webkit-outer-spin-button,input[type=number].form-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.custom-select{position:relative;width:100%;max-width:inherit}.custom-select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;text-align:left;cursor:pointer}.custom-select-trigger span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select-trigger.is-open{border-color:var(--primary);box-shadow:0 0 0 3px #6366f138,inset 0 1px #ffffff14,0 14px 28px -18px #6366f1cc}.custom-select-chevron{color:#cbd5e1;transition:transform .2s ease;flex-shrink:0}.custom-select-chevron.is-open{transform:rotate(180deg)}.custom-select-menu{background:#0b1533;border:1px solid rgba(148,163,184,.35);border-radius:.9rem;box-shadow:0 18px 34px -18px #020617f2,0 0 0 1px #6366f124 inset;padding:.35rem;margin:0;list-style:none;max-height:220px;overflow-y:auto;overflow-x:hidden}.custom-select-menu-portal{position:fixed}.custom-select-menu.show-below{top:calc(100% + .35rem)}.custom-select-menu.show-above{bottom:calc(100% + .35rem);top:auto}.custom-select-option{display:block;width:100%;border:none;background:transparent;color:var(--text-main);text-align:left;border-radius:.65rem;padding:.58rem .75rem;font-weight:500;cursor:pointer;transition:background-color .16s ease,color .16s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;box-sizing:border-box}.custom-select-option:hover{background:#6366f133;color:#e8eeff}.custom-select-option.is-selected{background:#6366f159;color:#f8fbff}.btn,.btn-primary,.btn-secondary,.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:.75rem 1.5rem;font-weight:600;border-radius:var(--radius-md);border:none;cursor:pointer;transition:var(--transition);font-family:var(--font-family);font-size:.95rem}.btn-primary{background:var(--primary);color:var(--text-inverse)}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:var(--bg-surface);color:var(--text-main);border:1px solid var(--border-glass)}.btn-secondary:hover{background:#ffffff0d;border-color:var(--text-muted)}.btn-danger{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:var(--danger);color:var(--text-inverse)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.px-2{padding-left:var(--space-2);padding-right:var(--space-2)}.px-3{padding-left:var(--space-3);padding-right:var(--space-3)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.py-1{padding-top:var(--space-1);padding-bottom:var(--space-1)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.pt-4{padding-top:var(--space-4)}.pr-2{padding-right:var(--space-2)}.pl-10{padding-left:2.5rem}.m-0{margin:0}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-10{margin-top:2.5rem}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.text-lg{font-size:1.125rem}.text-2xl{font-size:1.5rem}.font-bold{font-weight:700}.text-right{text-align:right}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-none{line-height:1}.text-primary{color:var(--primary)}.text-secondary{color:var(--secondary)}.text-info{color:var(--info)}.text-inverse{color:var(--text-inverse)}.border{border:1px solid var(--border-glass)}.border-dashed{border-style:dashed}.border-t{border-top:1px solid var(--border-glass)}.border-glass{border-color:var(--border-glass)}.rounded-md{border-radius:var(--radius-md)}.rounded-full{border-radius:var(--radius-full)}.w-max{width:max-content}.h-full{height:100%}.max-w-md{max-width:28rem}.max-h-60{max-height:15rem}.max-h-72{max-height:18rem}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.mx-auto{margin-left:auto;margin-right:auto}.table-wrapper{width:100%;overflow:visible}*{scrollbar-width:thin;scrollbar-color:rgba(99,102,241,.72) rgba(15,23,42,.55)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:#0f172a8c;border-radius:999px}*::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#6366f1f2,#4f46e5e6);border-radius:999px;border:2px solid rgba(15,23,42,.65)}*::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#818cf8fa,#6366f1f2)}.custom-select-menu::-webkit-scrollbar{width:8px;height:8px}.table-controls{margin-bottom:var(--space-4)}.data-table{width:100%;border-collapse:collapse;text-align:left}.data-table th,.data-table td{padding:var(--space-4);border-bottom:1px solid var(--border-glass);vertical-align:middle}.data-table th{font-weight:500;color:var(--text-muted);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.data-table tr:hover{background:#ffffff05}.actions-cell{text-align:right;white-space:nowrap}.unit-badge{background:#ffffff14;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;letter-spacing:.05em;font-family:monospace}.status-badge{padding:4px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;white-space:nowrap}.status-badge.active{background:#10b98126;color:var(--secondary)}.status-badge.inactive{background:#ef444426;color:var(--danger)}.no-wrap{white-space:nowrap}.icon-btn{padding:6px;min-width:34px;min-height:34px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);color:var(--text-muted)}.icon-btn:hover{background:#ffffff14;color:var(--primary)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.data-table .actions-cell .icon-btn,.data-table .actions-cell .relative-hover{display:inline-flex;vertical-align:middle}.data-table .actions-cell .relative-hover+.relative-hover{margin-left:.25rem}.toast-notification{position:fixed;bottom:24px;right:24px;z-index:9999;min-width:320px;max-width:480px}.toast-content{background:var(--bg-surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-glass);padding:1rem 1.25rem;border-radius:var(--radius-md);box-shadow:var(--shadow-glass);display:flex;align-items:center;gap:12px}.toast-notification.success .toast-content{border-left:4px solid var(--secondary)}.toast-notification.error .toast-content{border-left:4px solid var(--danger);background:#ef44440d}.toast-icon{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.toast-message{font-size:.9rem;font-weight:500;color:var(--text-main)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-slide-up{animation:slideUp .3s cubic-bezier(.16,1,.3,1) forwards}.lucide{color:inherit;stroke:currentColor;fill:none;vertical-align:middle}.icon-btn.text-primary{color:var(--primary)}.icon-btn.text-secondary{color:var(--secondary)}.icon-btn.text-danger{color:var(--danger)}.icon-btn.text-success{color:var(--success)}.icon-btn.text-warning{color:var(--warning)}.text-primary .lucide,.text-secondary .lucide,.text-danger .lucide,.text-success .lucide,.text-warning .lucide,.text-info .lucide,.text-muted .lucide{color:inherit}.page-container{display:flex;flex-direction:column;gap:var(--space-6)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.page-title{font-size:1.75rem;font-weight:700;color:var(--text-inverse);line-height:1.2}.page-subtitle{font-size:.9rem;color:var(--text-muted);margin-top:var(--space-1)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.stat-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6);background:#1e293b66;border:1px solid var(--border-glass);border-radius:var(--radius-md);transition:var(--transition)}.stat-card:hover{background:#1e293b99;border-color:var(--border-focus)}.stat-card.highlight{background:linear-gradient(135deg,#1e293b99,#6366f114);border-color:#6366f140}.stat-icon{flex-shrink:0;color:var(--primary)}.stat-icon.text-yellow{color:var(--warning)}.stat-icon.text-red{color:var(--danger)}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-inverse);line-height:1.2}.stat-label{font-size:.8rem;color:var(--text-muted);margin-top:2px}.disclaimer-banner{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-md);font-size:.8rem;color:var(--warning);font-weight:500;line-height:1.4}.info-banner{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-md);font-size:.8rem;color:var(--primary);font-weight:500;line-height:1.4}.tab-group{display:flex;gap:var(--space-2);flex-wrap:wrap}.tab-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:transparent;color:var(--text-muted);border:1px solid var(--border-glass);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-family);font-size:.85rem;font-weight:500;transition:var(--transition);white-space:nowrap}.tab-btn:hover{background:#ffffff0a;color:var(--text-main);border-color:var(--text-muted)}.tab-btn.active{background:var(--primary-light);color:var(--primary);border-color:var(--primary);font-weight:600}.filters-row{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.search-input{background:linear-gradient(180deg,#0f172ac7,#0f172a94);border:1px solid rgba(148,163,184,.2);padding:.6rem 1rem;border-radius:1rem;color:var(--text-main);font-family:var(--font-family);font-weight:500;font-size:.875rem;min-width:220px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.search-input::placeholder{color:#7f8da6}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f138}.checkbox-label{display:inline-flex;align-items:center;gap:var(--space-2);font-size:.85rem;color:var(--text-muted);cursor:pointer;white-space:nowrap;font-weight:500}.checkbox-label input[type=checkbox]{accent-color:var(--primary);width:16px;height:16px}.form-card{background:#1e293b66;border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3);overflow:visible}.form-section-title{font-size:1.1rem;font-weight:700;color:var(--text-inverse);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-glass);margin-bottom:var(--space-2)}.form-group{display:flex;flex-direction:column;gap:var(--space-1);flex:1;min-width:0}.form-group label{font-size:.8rem;font-weight:600;color:#a7b5cc;letter-spacing:.02em}.form-row{display:flex;gap:var(--space-4);flex-wrap:wrap}.form-row>.form-group{flex:1;min-width:140px}.form-input{background:linear-gradient(180deg,#0f172ac7,#0f172a94);border:1px solid rgba(148,163,184,.2);padding:.5rem .75rem;border-radius:.75rem;color:var(--text-main);font-family:var(--font-family);font-weight:500;font-size:.875rem;outline:none;width:100%;transition:border-color .2s ease,box-shadow .2s ease;min-height:36px}.form-input::placeholder{color:#7f8da6}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f138}.form-hint{font-size:.75rem;color:var(--text-muted);margin-top:2px;line-height:1.4}.form-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);font-size:.8rem;color:var(--danger);font-weight:500}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600;letter-spacing:.02em;white-space:nowrap}.badge-green{background:#10b98126;color:var(--secondary)}.badge-red{background:#ef444426;color:var(--danger)}.badge-yellow{background:#f59e0b26;color:var(--warning)}.badge-gray{background:#94a3b826;color:var(--text-muted)}.flex-inline{display:inline-flex;align-items:center;gap:4px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-8) var(--space-4);color:var(--text-muted);text-align:center;min-height:120px;font-size:.9rem}.loading-state{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8);color:var(--text-muted);font-size:.9rem}.spin{animation:spin 1s linear infinite}.btn-ghost{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:transparent;color:var(--text-muted);border:1px solid var(--border-glass);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-family);font-size:.85rem;font-weight:500;transition:var(--transition)}.btn-ghost:hover{background:#ffffff0d;color:var(--text-main);border-color:var(--text-muted)}.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:var(--space-1) var(--space-2);font-size:.8rem}.text-red{color:var(--danger)}.text-yellow{color:var(--warning)}.text-green{color:var(--secondary)}.pagination-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) 0;border-top:1px solid var(--border-glass);margin-top:var(--space-4)}.section-subtitle{font-size:1rem;font-weight:700;color:var(--text-inverse);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-glass)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-glass)}@media(max-width:768px){.page-header{flex-direction:column}.stats-grid{grid-template-columns:1fr 1fr}.filters-row{flex-direction:column;align-items:stretch}.form-row{flex-direction:column}.form-card{padding:var(--space-6)}.pagination-row{flex-direction:column;gap:var(--space-3);text-align:center}}.layout-container{display:flex;min-height:100vh;width:100%;max-width:100vw;overflow-x:hidden}.sidebar{width:260px;min-width:260px;height:100vh;position:sticky;top:0;display:flex;flex-direction:column;padding:var(--space-4) var(--space-4);border-radius:0;border-top:none;border-bottom:none;border-left:none;background:#0f172ad9;overflow:hidden}.sidebar-header{margin-bottom:var(--space-4)}.sidebar-header h2{font-size:1.5rem;font-weight:700;color:var(--text-inverse);display:flex;align-items:center;gap:.25rem}.sidebar-header h2 span{color:var(--primary)}.role-badge{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--secondary);font-weight:600;margin-top:var(--space-1)}.sidebar-nav{display:flex;flex-direction:column;flex-grow:1;gap:var(--space-1);overflow-y:auto;overflow-x:hidden;margin-right:-6px;padding-right:6px}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);color:var(--text-muted);text-decoration:none;border-radius:var(--radius-md);transition:var(--transition);font-weight:500;font-size:.875rem;flex-shrink:0}.nav-item:hover{background:#ffffff0d;color:var(--text-main)}.nav-item.active{background:var(--primary-light);color:var(--primary);border-left:3px solid var(--primary)}.nav-separator{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);margin-top:var(--space-2);flex-shrink:0}.nav-separator span{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:700;white-space:nowrap}.nav-separator:after{content:"";flex:1;height:1px;background:var(--border-glass)}.sidebar-footer{margin-top:auto;border-top:1px solid var(--border-glass);padding-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-3);flex-shrink:0}.user-profile{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2);background:#ffffff08;border-radius:var(--radius-md)}.avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff}.user-info{display:flex;flex-direction:column}.user-name{font-size:.875rem;font-weight:600;color:var(--text-main)}.logout-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);width:100%;background:transparent;color:var(--text-muted);border:1px solid var(--border-glass);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);font-family:var(--font-family);font-size:.875rem;font-weight:500}.logout-btn:hover{background:#ef44441a;color:var(--danger);border-color:#ef444433}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden;background-image:radial-gradient(circle at 15% 50%,rgba(99,102,241,.08),transparent 25%),radial-gradient(circle at 85% 30%,rgba(16,185,129,.05),transparent 25%);background-attachment:fixed}.main-content{flex-grow:1;padding:var(--space-8);height:100vh;overflow-y:auto;overflow-x:hidden;width:0;min-width:0}@media(max-width:1024px){.sidebar{width:220px;min-width:220px}}@media(max-width:768px){.layout-container{flex-direction:column}.sidebar{width:100%;min-width:100%;height:auto;position:sticky;top:0;z-index:100;padding:var(--space-3) var(--space-4);border-right:none;border-bottom:1px solid var(--border-glass);flex-direction:row;align-items:center;justify-content:space-between;gap:var(--space-4)}.sidebar-header{margin-bottom:0}.sidebar-header h2{font-size:1.1rem}.role-badge{display:none}.sidebar-nav{flex-direction:row;gap:var(--space-1);overflow-x:auto;padding:0;scroll-behavior:smooth;-ms-overflow-style:none;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.nav-item{padding:var(--space-2) var(--space-3);font-size:.75rem;white-space:nowrap;flex-direction:column;justify-content:center;align-items:center;gap:.2rem}.nav-item span{display:block;font-size:.65rem;line-height:1}.sidebar-footer{display:none}.main-content{padding:var(--space-4);height:auto;width:100%}.module-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.module-header .flex{width:100%;justify-content:space-between}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background-image:radial-gradient(circle at top right,rgba(99,102,241,.15),transparent 40%),radial-gradient(circle at bottom left,rgba(16,185,129,.1),transparent 40%)}.login-card{width:100%;max-width:440px;padding:var(--space-8);display:flex;flex-direction:column;gap:var(--space-6)}.login-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.logo-icon{background:#6366f11a;padding:var(--space-3);border-radius:var(--radius-full);margin-bottom:var(--space-2);display:inline-flex}.login-header h1{font-size:2rem;letter-spacing:-.05em}.login-header h1 span{color:var(--primary)}.login-form{display:flex;flex-direction:column;gap:var(--space-4)}.login-error{background:#ef44441a;color:var(--danger);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid rgba(239,68,68,.2);font-size:.875rem;text-align:center}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dashboard-container{display:flex;flex-direction:column}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-6)}.metric-card{display:flex!important;align-items:center!important;gap:var(--space-6)!important;padding:var(--space-8)!important;transition:transform .2s cubic-bezier(.4,0,.2,1);min-height:120px}.metric-card:hover{transform:translateY(-2px)}.metric-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.bg-primary-light{background:#6366f126}.bg-warning-light{background:#f59e0b26}.bg-danger-light{background:#ef444426}.bg-info-light{background:#0ea5e926}.bg-secondary-light{background:#10b98126}.luxury-border{border-bottom:3px solid var(--primary)}.highlight-card{background:linear-gradient(135deg,#1e293b99,#6366f10d);border:1px solid rgba(99,102,241,.2)}.secondary-metrics .glass-card{display:flex!important;align-items:center!important;gap:var(--space-6)!important;padding:var(--space-8)!important;border-left:4px solid var(--border-glass)!important;min-height:120px}.mt-6{margin-top:var(--space-6)}.mb-6{margin-bottom:var(--space-6)}.metric-content{display:flex;flex-direction:column}.metric-label{font-size:.875rem;font-weight:500;color:var(--text-muted);margin-bottom:var(--space-1)}.metric-value{font-size:1.5rem;font-weight:700;color:var(--text-main);line-height:1.2}.metric-trend{font-weight:600}.panels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:var(--space-6)}.panels-grid .glass-panel{padding:var(--space-8)!important;display:flex;flex-direction:column;gap:var(--space-6)}.panel-title{font-size:1.25rem;font-weight:700;color:var(--text-inverse);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-glass)}.breakdown-content{display:flex;flex-direction:column;gap:var(--space-6)}.breakdown-stat{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0}.chart-container{display:flex;justify-content:center;align-items:center}.relative-hover{position:relative}.hover-legend{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);margin-bottom:0;background:#171725f2;border:1px solid var(--primary);padding:.4rem .75rem;border-radius:var(--radius-md);font-size:.75rem;line-height:1.3;font-weight:500;color:#fff;white-space:nowrap;text-align:center;opacity:0;pointer-events:none;transition:opacity .15s ease;z-index:10050;box-shadow:0 4px 12px #00000080}.actions-cell .hover-legend{left:auto;right:0;transform:none}.relative-hover:hover .hover-legend{opacity:1}.hover-legend .hl-title{font-weight:700;font-size:.95rem;margin-bottom:.25rem;color:var(--text-main)}.hover-legend .hl-body{font-weight:500;font-size:.85rem;color:#ffffffeb}.secondary-metrics{margin-top:var(--space-8)}.secondary-metrics .glass-card{padding:var(--space-5) var(--space-6);min-height:100px}.modal-overlay{position:fixed;inset:0;width:100%;height:100%;background-color:#020617d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:10001;padding:var(--space-4)}.modal-content{width:95%;max-width:480px;max-height:90vh;display:flex;flex-direction:column;background:var(--bg-surface);border:1px solid var(--border-glass);box-shadow:0 25px 50px -12px #0009;border-radius:var(--radius-lg);overflow:hidden;position:relative;animation:modalEnter .3s cubic-bezier(.165,.84,.44,1) forwards}@keyframes modalEnter{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-glass)}.modal-header h3{font-size:1.125rem;font-weight:600;color:var(--text-inverse);margin:0}.modal-body{padding:var(--space-6);overflow-y:auto;overflow-x:visible;flex:1;min-height:0}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-glass)}@media(max-width:768px){.modal-overlay{align-items:flex-end;padding:0}.modal-content{width:100%!important;max-width:100%!important;max-height:min(100dvh,100vh);border-radius:1.25rem 1.25rem 0 0;border-bottom-left-radius:0;border-bottom-right-radius:0}.modal-header{padding:var(--space-4)}.modal-body{padding:var(--space-4);padding-bottom:calc(var(--space-6) + env(safe-area-inset-bottom))}.modal-footer{padding:var(--space-4);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom))}}.notification-container{position:fixed;bottom:24px;right:24px;z-index:10000;display:flex;flex-direction:column;gap:12px;pointer-events:none;max-width:400px;width:calc(100% - 48px)}.toast-notification{pointer-events:auto;position:relative;overflow:hidden;border-radius:12px;box-shadow:0 10px 25px -5px #0000004d,0 8px 10px -6px #0003;background:#1a2847;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(99,102,241,.2)}.toast-content{padding:16px;display:flex;align-items:center;gap:12px}.toast-icon{flex-shrink:0}.toast-icon.success{background:#10b981;color:#fff}.toast-icon.error{background:#ef4444;color:#fff}.toast-icon.info{background:#3b82f6;color:#fff}.toast-icon.warning{background:#f59e0b;color:#fff}.toast-message{font-size:.95rem;color:var(--text-main);font-weight:500;flex-grow:1}.toast-message .no-wrap{white-space:nowrap}.toast-close-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.toast-close-btn:hover{background:#ffffff1a;color:var(--text-main)}.toast-progress{position:absolute;bottom:0;left:0;height:3px;background:#0000000d;opacity:.5}.toast-notification.success .toast-progress{background:#10b981}.toast-notification.error .toast-progress{background:#ef4444}.toast-notification.info .toast-progress{background:#3b82f6}.toast-notification.warning .toast-progress{background:#f59e0b}.skeleton{background:linear-gradient(90deg,rgba(var(--border-glass-rgb, 229, 231, 235),.1) 25%,rgba(var(--border-glass-rgb, 229, 231, 235),.3),rgba(var(--border-glass-rgb, 229, 231, 235),.1) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px;display:inline-block;min-height:1em;width:100%}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:.8rem;margin:.2rem 0}.skeleton-title{height:1.2rem;margin-bottom:.5rem;width:60%}.skeleton-circle{border-radius:50%;width:2.5rem;height:2.5rem}.skeleton-table-row{height:1.5rem;margin:.5rem 0}.module-container{display:flex;flex-direction:column}.table-controls{margin-bottom:var(--space-6)}.search-box{position:relative;width:100%;max-width:400px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%)}.search-box .input-control{width:100%;padding-left:2.5rem;background:var(--bg-surface)}.ingredients-section{display:flex;flex-direction:column}.bg-surface{background-color:#1e293b66}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.date-picker{width:100%}.date-picker span{flex:1}.date-picker-trigger{display:flex;align-items:center;justify-content:flex-start;cursor:pointer;text-align:left;font-family:inherit;font-size:.9375rem;width:100%;padding:var(--input-padding, 10px 12px);height:40px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:var(--radius-md);color:var(--text-primary);transition:all .2s ease}.date-picker-trigger:hover{border-color:var(--border-secondary)}.date-picker-trigger:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.date-picker-trigger.is-open{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.date-picker-portal{background:var(--bg-surface);border:1px solid var(--border-glass);border-radius:var(--radius-md);box-shadow:0 10px 25px -5px #00000040;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-width:280px;max-width:320px}.date-picker-calendar{padding:var(--space-4)}.date-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-secondary)}.date-picker-month-year{font-size:.9375rem;font-weight:600;color:var(--text-inverse);text-transform:capitalize}.date-picker-nav-btn{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.date-picker-nav-btn:hover{background:#6366f11a;color:var(--primary)}.date-picker-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:var(--space-2);text-align:center}.date-picker-weekday{font-size:.75rem;font-weight:600;color:var(--text-secondary);padding:6px 0}.date-picker-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:var(--space-3)}.date-picker-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;padding:0}.date-picker-day:not(:disabled):hover{background:#6366f11a;border-color:var(--primary);color:var(--primary)}.date-picker-day:disabled{color:var(--text-secondary);opacity:.3;cursor:not-allowed}.date-picker-day.is-today{border-color:var(--text-secondary);font-weight:600}.date-picker-day.is-selected{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600;box-shadow:0 2px 8px #6366f14d}.date-picker-day.is-selected:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.date-picker-footer{display:flex;gap:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--border-secondary)}.date-picker-quick-btn{flex:1;padding:6px 12px;background:transparent;color:var(--primary);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease}.date-picker-quick-btn:hover{background:#6366f11a;border-color:var(--primary)}@media(max-width:640px){.date-picker-portal{min-width:260px;max-width:300px}.date-picker-day{font-size:.8rem}.date-picker-month-year{font-size:.875rem}}.bg-surface{background-color:var(--bg-surface)}.opacity-50{opacity:.5}.sales-header{gap:var(--space-4)}.sales-search-box{max-width:100%}.sales-history-mobile{display:none}.sale-card{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4)}.sale-card-voided{opacity:.65}.sale-card-top,.sale-card-item,.sale-card-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.sale-card-ticket{font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--space-1)}.sale-card-date{font-weight:600}.sale-card-items{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);border:1px solid var(--border-glass);border-radius:var(--radius-md);background:#0f172a52}.sale-card-item-name{min-width:0;flex:1}.sale-card-summary{display:flex;flex-direction:column;gap:var(--space-2)}.sale-card-total{font-size:1.125rem;color:var(--text-inverse)}.sale-card-action{width:100%}.sales-form{display:flex;flex-direction:column;gap:var(--space-4)}.sale-detail-panel{display:flex;flex-direction:column;gap:var(--space-3)}.sale-items-header,.sale-item-grid{display:grid;grid-template-columns:minmax(0,1fr) 70px 110px 28px;gap:8px}.sale-items-header{align-items:end}.sale-item-grid{align-items:center}.sale-item-grid>*{min-width:0}.sale-add-item-btn{align-self:flex-start}.sale-payment-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-4);align-items:start}.sale-payment-field{min-width:0}.sale-total-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4);margin-top:var(--space-2);background:var(--primary-light);border:1px solid rgba(99,102,241,.28);border-radius:var(--radius-md)}.sale-total-block,.sale-total-change{min-width:0}.sale-total-change{text-align:right}.sale-form-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-glass)}@media(max-width:768px){.sales-panel{padding:var(--space-4)}.sales-header .btn,.sale-add-item-btn,.sale-form-actions .btn{width:100%}.sale-card-top,.sale-card-item,.sale-card-row,.sale-total-card{flex-direction:column}.sale-items-header{display:none}.sale-total-change{text-align:left}.sale-item-grid{grid-template-columns:88px minmax(0,1fr) 36px!important;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--border-glass);border-radius:var(--radius-md);background:#0f172a52}.sale-item-grid>.custom-select,.sale-item-grid>input,.sale-item-grid>div{min-width:0}.sale-item-grid>:nth-child(1){grid-column:1 / -1}.sale-item-grid>:nth-child(2){grid-column:1 / 2}.sale-item-grid>:nth-child(3){grid-column:2 / 3}.sale-item-grid>:nth-child(4){grid-column:3 / 4;justify-self:end;align-self:end}.sale-payment-grid{grid-template-columns:1fr}.sale-form-actions{flex-direction:column-reverse}}@media(max-width:768px){.sales-history-desktop{display:none}.sales-history-mobile{display:flex;flex-direction:column;gap:var(--space-4)}}@media(min-width:769px){.sales-history-mobile{display:none}}.text-warning{color:var(--warning)}.bg-danger-light{background-color:#ef44441a}.text-danger{color:var(--danger)}.tour-overlay{position:fixed;inset:0;z-index:9999;pointer-events:none}.tour-mask{position:fixed;background:#080c14a6;pointer-events:auto;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.tour-mask-full{inset:0}.tour-spotlight-ring{position:fixed;border:2px solid #3b82f6;border-radius:10px;box-shadow:0 0 0 4px #3b82f640,0 0 20px #3b82f680;pointer-events:none;transition:top .25s ease,left .25s ease,width .25s ease,height .25s ease}.tour-tooltip{position:fixed;background:#111827;color:#f3f4f6;border:1px solid rgba(148,163,184,.25);border-radius:12px;padding:18px 18px 14px;box-shadow:0 20px 50px #00000073,0 0 0 1px #3b82f626;pointer-events:auto;transition:top .25s ease,left .25s ease;font-family:inherit}.tour-tooltip:before{content:"";position:absolute;width:12px;height:12px;background:#111827;border:1px solid rgba(148,163,184,.25);transform:rotate(45deg)}.tour-arrow-top:before{top:-7px;left:calc(50% - 6px);border-right:none;border-bottom:none}.tour-arrow-bottom:before{bottom:-7px;left:calc(50% - 6px);border-left:none;border-top:none}.tour-arrow-left:before{left:-7px;top:calc(50% - 6px);border-right:none;border-top:none}.tour-arrow-right:before{right:-7px;top:calc(50% - 6px);border-left:none;border-bottom:none}.tour-arrow-none:before{display:none}.tour-close{position:absolute;top:8px;right:10px;background:transparent;border:none;color:#94a3b8;font-size:22px;line-height:1;cursor:pointer;padding:4px 8px;border-radius:6px}.tour-close:hover{background:#94a3b826;color:#f3f4f6}.tour-step-indicator{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#60a5fa;font-weight:600;margin-bottom:6px}.tour-title{margin:0 0 8px;font-size:17px;font-weight:600;color:#f8fafc}.tour-content{margin:0 0 16px;font-size:14px;line-height:1.55;color:#cbd5e1;white-space:pre-line}.tour-actions{display:flex;justify-content:space-between;align-items:center;gap:8px}.tour-actions-right{display:flex;gap:8px}.tour-btn{font-family:inherit;font-size:13px;font-weight:500;padding:7px 14px;border-radius:8px;cursor:pointer;border:1px solid transparent;transition:background .15s ease,border-color .15s ease,color .15s ease}.tour-btn-primary{background:#3b82f6;color:#fff}.tour-btn-primary:hover{background:#2563eb}.tour-btn-secondary{background:transparent;color:#cbd5e1;border-color:#94a3b84d}.tour-btn-secondary:hover{background:#94a3b81f;color:#f3f4f6}.tour-btn-ghost{background:transparent;color:#94a3b8;border-color:transparent;padding:7px 10px}.tour-btn-ghost:hover{color:#f3f4f6;text-decoration:underline}.tour-trigger-btn{display:flex;align-items:center;gap:10px;width:100%;background:transparent;border:1px solid rgba(148,163,184,.2);border-radius:8px;padding:8px 12px;color:inherit;font:inherit;font-size:13px;cursor:pointer;margin-bottom:10px;transition:background .15s ease,border-color .15s ease}.tour-trigger-btn:hover{background:#3b82f61f;border-color:#3b82f666}.tour-trigger-btn svg{flex-shrink:0}
