@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#0b0c10;--bg-secondary:#141622;--bg-tertiary:#1f2235;--glass-bg:#14162299;--glass-bg-hover:#1f2235d9;--glass-border:#ffffff12;--glass-border-glow:#6366f140;--color-primary:#6366f1;--color-primary-glow:#6366f126;--color-success:#10b981;--color-success-glow:#10b98126;--color-warning:#f59e0b;--color-warning-glow:#f59e0b26;--color-danger:#ef4444;--color-danger-glow:#ef444426;--color-info:#06b6d4;--text-primary:#f3f4f6;--text-muted:#9ca3af;--text-dark:#111827;--font-sans:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--sidebar-width:260px;--header-height:70px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 2px 8px #0003;--shadow-md:0 8px 24px #0000004d;--shadow-lg:0 16px 40px #0006;--glow-primary:0 0 20px #6366f140;--glow-success:0 0 20px #10b98140}*{box-sizing:border-box;font-family:var(--font-sans);margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(at 0 0,#6366f11a 0,#0000 50%),radial-gradient(at 100% 100%,#06b6d414 0,#0000 50%),radial-gradient(#10b98105 0,#0000 50%);background-attachment:fixed;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}#root{width:100vw;min-height:100vh;display:flex}.app-container{width:100%;display:flex}.sidebar{width:var(--sidebar-width);background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border-right:1px solid var(--glass-border);z-index:100;flex-direction:column;transition:all .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid var(--glass-border);align-items:center;gap:.75rem;padding:1.5rem;display:flex}.brand-logo{background:linear-gradient(135deg, var(--color-primary) 0%, #4f46e5 100%);border-radius:var(--radius-md);width:40px;height:40px;box-shadow:var(--glow-primary);justify-content:center;align-items:center;display:flex}.icon-logo{color:#fff}.brand-info h2{letter-spacing:-.02em;margin:0;font-size:1.15rem;font-weight:700}.brand-info span{color:var(--text-muted);letter-spacing:.05em;font-size:.7rem;font-weight:500}.sidebar-nav{flex:1;padding:1.5rem 1rem}.sidebar-nav ul{flex-direction:column;gap:.5rem;list-style:none;display:flex}.nav-link{border-radius:var(--radius-md);width:100%;color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;outline:none;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex;position:relative}.nav-link:hover{color:var(--text-primary);background:#ffffff08}.nav-link.active{color:#fff;background:var(--color-primary-glow);box-shadow:inset 3px 0 0 var(--color-primary)}.nav-badge{border-radius:999px;margin-left:auto;padding:.2rem .5rem;font-size:.75rem;font-weight:600}.sidebar-footer{border-top:1px solid var(--glass-border);padding:1.5rem 1rem}.user-profile{align-items:center;gap:.75rem;padding:.5rem;display:flex}.avatar{background:var(--bg-tertiary);border:1px solid var(--glass-border);width:36px;height:36px;color:var(--color-primary);border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;display:flex}.user-name{color:var(--text-primary);font-size:.85rem;font-weight:600}.user-role{color:var(--text-muted);font-size:.75rem}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex-grow:1;min-height:100vh;padding:2rem;transition:all .3s;display:flex}@media (width<=1024px){.sidebar{width:80px}.brand-info,.nav-label,.sidebar-footer .user-details{display:none}.sidebar-brand,.sidebar-nav{justify-content:center;padding:1rem .5rem}.nav-link{justify-content:center;padding:.75rem}.nav-badge{margin-left:0;position:absolute;top:2px;right:2px}.main-content{margin-left:80px;padding:1.5rem}}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:1.5rem;transition:transform .2s,border-color .2s,box-shadow .2s}.glass-card:hover{border-color:var(--glass-border-glow);box-shadow:var(--shadow-lg);transform:translateY(-2px)}h1,h2,h3,h4,h5,h6{letter-spacing:-.025em;color:var(--text-primary);font-weight:600}.text-gradient{background:linear-gradient(135deg,#a5b4fc 0%,#6366f1 50%,#06b6d4 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.btn{border-radius:var(--radius-md);cursor:pointer;border:1px solid #0000;outline:none;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--glow-primary)}.btn-primary:hover{background:#4f46e5;transform:translateY(-1px);box-shadow:0 0 25px #6366f166}.btn-success{background:var(--color-success);color:#fff;box-shadow:var(--glow-success)}.btn-success:hover{background:#059669;transform:translateY(-1px);box-shadow:0 0 25px #10b98166}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--glass-border)}.btn-secondary:hover{background:var(--glass-bg-hover);border-color:var(--text-muted)}.btn-danger{background:var(--color-danger);color:#fff;box-shadow:var(--color-danger-glow)}.btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.btn-icon-only{border-radius:var(--radius-sm);justify-content:center;align-items:center;padding:.5rem;display:flex}.form-group{margin-bottom:1.25rem}.form-label{color:var(--text-muted);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.form-control{border:1px solid var(--glass-border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);background:#0f172a80;outline:none;padding:.75rem 1rem;font-size:.875rem;transition:all .2s}.form-control:focus{border-color:var(--color-primary);box-shadow:var(--color-primary-glow), 0 0 0 2px var(--color-primary-glow);background:#0f172acc}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.table-container{border-radius:var(--radius-md);border:1px solid var(--glass-border);background:#14162266;width:100%;overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%;font-size:.875rem}.custom-table th{color:var(--text-primary);border-bottom:1px solid var(--glass-border);text-transform:uppercase;letter-spacing:.05em;background:#1f2235b3;padding:1rem 1.5rem;font-size:.75rem;font-weight:600}.custom-table td{border-bottom:1px solid var(--glass-border);color:var(--text-muted);vertical-align:middle;padding:1rem 1.5rem}.custom-table tbody tr{transition:background-color .15s}.custom-table tbody tr:hover{background-color:#6366f10a}.custom-table tbody tr:last-child td{border-bottom:none}.badge{border-radius:9999px;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:600;line-height:1;display:inline-flex}.badge-success{color:var(--color-success);background:#10b9811a;border:1px solid #10b98133}.badge-warning{color:var(--color-warning);background:#f59e0b1a;border:1px solid #f59e0b33}.badge-danger{color:var(--color-danger);background:#ef44441a;border:1px solid #ef444433}.badge-info{color:var(--color-info);background:#06b6d41a;border:1px solid #06b6d433}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000bf;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius-lg);border:1px solid var(--glass-border);width:100%;max-width:600px;max-height:90vh;box-shadow:var(--shadow-lg);margin:1rem;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;overflow-y:auto}.modal-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid var(--glass-border);justify-content:flex-end;gap:.75rem;padding:1.5rem;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.alert{border-radius:var(--radius-md);border:1px solid #0000;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem;display:flex}.alert-warning{color:#fbbf24;background:#f59e0b14;border-color:#f59e0b33}.view-header{border-bottom:1px solid var(--glass-border);margin-bottom:2rem;padding-bottom:1.5rem}.subtitle{color:var(--text-muted);margin-top:.25rem;font-size:.95rem}.analytics-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.stat-card{align-items:center;gap:1.25rem;display:flex}.stat-icon-wrapper{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.stat-icon{width:24px;height:24px}.bg-indigo{color:#818cf8;background:#6366f11a;border:1px solid #6366f133}.bg-teal{color:#34d399;background:#10b9811a;border:1px solid #10b98133}.bg-cyan{color:#22d3ee;background:#06b6d41a;border:1px solid #06b6d433}.bg-rose{color:#f87171;background:#ef44441a;border:1px solid #ef444433}.stat-info{flex-direction:column;gap:.15rem;display:flex;overflow:hidden}.stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.75rem;font-weight:600}.stat-value{color:var(--text-primary);font-size:1.65rem;font-weight:700}.stat-trend{align-items:center;gap:.25rem;font-size:.75rem;font-weight:500;display:flex}.text-success{color:var(--color-success)!important}.text-danger{color:var(--color-danger)!important}.dashboard-content-split{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.dashboard-panel{flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.panel-header{justify-content:space-between;align-items:center;display:flex}.panel-header h3{font-size:1.1rem}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:3rem 1.5rem;display:flex}.empty-icon{opacity:.4}.text-xs{font-size:.75rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-indigo{color:#818cf8}@media (width<=768px){.dashboard-content-split{grid-template-columns:1fr}}.filters-bar{justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:1.5rem;padding:1.25rem 1.5rem;display:flex}.search-box{flex:1;align-items:center;display:flex;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:1rem}.search-input{padding-left:2.75rem;padding-right:2.5rem}.clear-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:absolute;right:1rem}.clear-btn:hover{color:var(--text-primary)}.category-filter-box{align-items:center;min-width:200px;display:flex;position:relative}.filter-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:1rem}.filter-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239ca3af'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;background-size:1rem;padding-left:2.75rem}.row-alert{background-color:#ef444405}.row-alert:hover{background-color:#ef44440a!important}.product-cell-name{align-items:center;gap:.5rem;display:flex}.low-stock-alert-dot{color:var(--color-warning);justify-content:center;align-items:center;animation:2s infinite pulse;display:inline-flex}.actions-cell{gap:.5rem;display:flex}.empty-table-cell{padding:0!important}@keyframes pulse{0%{opacity:.5;transform:scale(.95)}50%{opacity:1;transform:scale(1.1)}to{opacity:.5;transform:scale(.95)}}@media (width<=768px){.filters-bar{flex-direction:column;align-items:stretch;gap:1rem}.category-filter-box{min-width:100%}}.billing-layout{grid-template-columns:1fr 350px;align-items:start;gap:1.5rem;display:grid}.billing-left,.billing-right,.billing-sidebar-form{flex-direction:column;gap:1.5rem;display:flex}.billing-search-panel,.billing-cart-panel,.billing-customer-panel,.billing-summary-panel{padding:1.5rem}.section-title{border-bottom:1px solid var(--glass-border);align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem;font-size:1rem;font-weight:600;display:flex}.billing-search-box{position:relative}.autocomplete-dropdown{background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-md);z-index:50;max-height:250px;box-shadow:var(--shadow-lg);margin-top:.5rem;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.dropdown-item{border-bottom:1px solid var(--glass-border);cursor:pointer;justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:background-color .15s;display:flex}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover:not(.disabled){background-color:#6366f114}.dropdown-item.disabled{opacity:.5;cursor:not-allowed}.dropdown-item-details{flex-direction:column;gap:.15rem;display:flex}.dropdown-item-name{color:var(--text-primary);font-size:.9rem;font-weight:500}.dropdown-item-sku{font-size:.75rem}.dropdown-item-action{align-items:center;gap:.75rem;display:flex}.dropdown-item-price{color:#818cf8;font-size:.9rem;font-weight:600}.dropdown-item.empty{color:var(--text-muted);text-align:center;padding:1rem;font-size:.85rem}.empty-cart-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 1.5rem;display:flex}.empty-cart-icon{opacity:.3}.qty-counter{border:1px solid var(--glass-border);border-radius:var(--radius-sm);background:#0f172a80;align-items:center;height:32px;display:inline-flex;overflow:hidden}.qty-btn{width:32px;height:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;outline:none;justify-content:center;align-items:center;font-size:1.1rem;font-weight:600;transition:background-color .15s;display:flex}.qty-btn:hover{background-color:#ffffff0d}.qty-input{width:44px;height:100%;color:var(--text-primary);text-align:center;border:none;border-left:1px solid var(--glass-border);border-right:1px solid var(--glass-border);background:0 0;outline:none;font-size:.85rem;font-weight:600}.billing-receipt-summary{border-top:1px solid var(--glass-border);flex-direction:column;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.summary-row{color:var(--text-muted);justify-content:space-between;font-size:.85rem;display:flex}.summary-divider{background:var(--glass-border);height:1px;margin:.25rem 0}.summary-row.total{color:var(--text-primary);font-size:1.1rem;font-weight:700}.btn-checkout{width:100%;margin-top:1.5rem;padding:.85rem;font-size:.95rem;font-weight:600}.invoice-receipt-modal{max-width:580px}.modal-header-actions{gap:.5rem;display:flex}.invoice-printable-sheet{color:#1f2937;border-radius:var(--radius-sm);background:#fff;padding:2rem;font-family:Courier New,Courier,monospace}.invoice-printable-sheet h2,.invoice-printable-sheet h3,.invoice-printable-sheet strong,.invoice-printable-sheet td,.invoice-printable-sheet th{color:#1f2937!important}.invoice-print-header{text-align:center;margin-bottom:1.5rem}.invoice-print-header h2{letter-spacing:.05em;margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.invoice-print-header p{font-size:.75rem;line-height:1.4;color:#4b5563!important}.invoice-print-divider{border:0;border-top:1px dashed #9ca3af;margin:1.25rem 0}.invoice-print-meta{justify-content:space-between;margin-bottom:1.5rem;font-size:.8rem;line-height:1.6;display:flex}.print-invoice-table{border-collapse:collapse;width:100%;margin:1.5rem 0;font-size:.8rem}.print-invoice-table th{text-align:left;border-bottom:1px solid #1f2937;padding:.5rem 0;font-weight:700}.print-invoice-table td{border-bottom:1px dashed #e5e7eb;padding:.5rem 0}.invoice-print-totals{flex-direction:column;gap:.5rem;width:260px;margin-left:auto;font-size:.8rem;display:flex}.totals-row{justify-content:space-between;display:flex}.totals-row.print-total{border-top:1px dashed #1f2937;margin-top:.25rem;padding-top:.5rem;font-size:.95rem;font-weight:700}.invoice-print-footer{text-align:center;margin-top:2.5rem;font-size:.7rem;line-height:1.4;color:#6b7280!important}@media (width<=1024px){.billing-layout{grid-template-columns:1fr}}@media print{body{color:#000!important;background:#fff!important}#root,.app-container{display:block!important}.sidebar,.main-content-header,.no-print,.btn,.alert,.modal-overlay:not(.print-modal-overlay){display:none!important}.main-content{width:100%!important;margin-left:0!important;padding:0!important}.print-only{display:block!important}.glass-panel,.glass-card,.table-container{box-shadow:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;color:#000!important;background:0 0!important;border:none!important;padding:0!important}.custom-table th{color:#000!important;background:#f3f4f6!important;border-bottom:2px solid #000!important}.custom-table td{color:#000!important;border-bottom:1px solid #e5e7eb!important}}.login-page-container{z-index:1000;background-color:var(--bg-primary);background-image:radial-gradient(at 10% 10%,#6366f126 0,#0000 40%),radial-gradient(at 90% 90%,#06b6d41f 0,#0000 40%),radial-gradient(#10b9810a 0,#0000 50%);background-size:cover;justify-content:center;align-items:center;width:100vw;min-height:100vh;padding:1.5rem;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.login-card-wrapper{width:100%;max-width:460px;padding:2.5rem;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative}.login-card-wrapper:before{content:"";border-radius:var(--radius-lg);z-index:-1;pointer-events:none;background:linear-gradient(135deg,#6366f14d 0%,#06b6d400 50%,#10b98133 100%);position:absolute;inset:-1px}.login-header{text-align:center;margin-bottom:2rem}.login-logo{background:linear-gradient(135deg, var(--color-primary) 0%, #4f46e5 100%);border-radius:var(--radius-lg);width:52px;height:52px;box-shadow:var(--glow-primary);color:#fff;justify-content:center;align-items:center;margin:0 auto 1rem;display:flex}.login-header h2{letter-spacing:-.03em;margin-bottom:.25rem;font-size:1.75rem;font-weight:800}.login-header p{color:var(--text-muted);font-size:.9rem}.login-tabs-container{border:1px solid var(--glass-border);border-radius:var(--radius-md);background:#0f172a66;margin-bottom:1.75rem;padding:.25rem;display:flex}.login-tab-btn{color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;flex:1;padding:.625rem;font-size:.875rem;font-weight:600;transition:all .2s}.login-tab-btn:hover{color:var(--text-primary)}.login-tab-btn.active{color:#fff;background:var(--bg-tertiary);box-shadow:var(--shadow-sm);border:1px solid var(--glass-border)}.form-group-with-icon{margin-bottom:1.25rem;position:relative}.form-group-icon{color:var(--text-muted);pointer-events:none;transition:color .2s;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.form-control-with-icon{padding-left:2.75rem;padding-right:2.75rem}.form-group-with-icon:focus-within .form-group-icon{color:var(--color-primary)}.password-toggle-eye{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:color .2s;display:flex;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.password-toggle-eye:hover{color:var(--text-primary)}.auth-btn{justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:.75rem;padding:.8rem;font-size:.95rem;font-weight:600;display:flex}.auth-footer{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.85rem}.auth-link{color:var(--color-primary);cursor:pointer;background:0 0;border:none;font-weight:600;text-decoration:none}.auth-link:hover{text-decoration:underline}.setup-wizard-container{flex-direction:column;gap:1.25rem;display:flex}.setup-instruction{color:var(--text-muted);font-size:.85rem;line-height:1.5}.setup-textarea{resize:vertical;width:100%;min-height:140px;font-family:monospace;font-size:.8rem;line-height:1.4}.setup-divider{text-align:center;color:var(--text-muted);text-transform:uppercase;align-items:center;margin:.5rem 0;font-size:.75rem;font-weight:600;display:flex}.setup-divider:before,.setup-divider:after{content:"";border-bottom:1px solid var(--glass-border);flex:1}.setup-divider:not(:empty):before{margin-right:.5em}.setup-divider:not(:empty):after{margin-left:.5em}.setup-badge-env{border-radius:var(--radius-sm);color:var(--color-success);background:#10b9811a;border:1px solid #10b98133;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.75rem;display:inline-flex}.setup-badge-local{border-radius:var(--radius-sm);color:var(--color-info);background:#06b6d41a;border:1px solid #06b6d433;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.75rem;display:inline-flex}.spinner{width:18px;height:18px;animation:1s linear infinite rotate}@keyframes rotate{to{transform:rotate(360deg)}}.sidebar-footer-menu{flex-direction:column;gap:.5rem;width:100%;display:flex}.logout-btn{color:#f87171;border-radius:var(--radius-md);cursor:pointer;background:#ef44440d;border:1px solid #ef444426;outline:none;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.logout-btn:hover{color:#ef4444;background:#ef444426;border-color:#ef44444d}@media (width<=1024px){.logout-btn{justify-content:center;padding:.75rem}.logout-btn span{display:none}}
