@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";@import "https://fonts.googleapis.com/css2?family=Cairo:wght@400;500;600;700;800;900&display=swap";:root{--font-family:"Outfit", sans-serif;--bg-primary:#0a0a0c;--bg-secondary:#121216;--bg-surface:#1e1e24;--bg-card:#1e1e2499;--border-color:#ffffff14;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent-primary:#7c3aed;--accent-primary-hover:#6d28d9;--accent-secondary:#06b6d4;--success:#10b981;--success-bg:#10b9811a;--warning:#f59e0b;--warning-bg:#f59e0b1a;--danger:#ef4444;--danger-bg:#ef44441a;--shadow-sm:0 2px 4px #0000001a;--shadow-md:0 8px 16px #0003;--shadow-lg:0 16px 32px #0006;--glass-effect:backdrop-filter: blur(12px);--border-radius-sm:8px;--border-radius-md:14px;--border-radius-lg:20px;--transition:all .25s cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--bg-primary:#f8fafc;--bg-secondary:#f1f5f9;--bg-surface:#fff;--bg-card:#fffc;--border-color:#00000014;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--accent-primary:#6366f1;--accent-primary-hover:#4f46e5;--glass-effect:backdrop-filter: blur(8px)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;transition:background-color .3s,color .3s;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px)}.glow-btn{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;cursor:pointer;transition:var(--transition);border:none;font-weight:600;box-shadow:0 0 15px #7c3aed66}.glow-btn:hover{transform:translateY(-2px);box-shadow:0 0 25px #7c3aed99}.glow-btn:active{transform:translateY(0)}.app-container{min-height:100vh;display:flex}.sidebar{border-right:1px solid var(--border-color);background-color:var(--bg-secondary);width:260px;transition:var(--transition);z-index:100;flex-direction:column;padding:24px;display:flex}.sidebar-toggle-btn{color:var(--text-primary);cursor:pointer;border-radius:var(--border-radius-sm);transition:var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;font-size:20px;display:flex}.sidebar-toggle-btn:hover{background-color:#ffffff14}@media (width<=768px){.sidebar-toggle-btn{display:none}}.logo-section{align-items:center;gap:12px;margin-bottom:40px;display:flex}.logo-section h2{background:linear-gradient(135deg, #fff, var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:22px;font-weight:800}.sidebar-nav{flex-direction:column;flex-grow:1;gap:8px;display:flex}.nav-item{color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition);align-items:center;gap:12px;padding:12px 16px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover,.nav-item.active{color:var(--text-primary);background-color:#ffffff0d}.nav-item.active{border-right:3px solid var(--accent-primary);background:linear-gradient(-90deg,#7c3aed26 0%,#7c3aed00 100%);padding-right:13px}.user-profile{border-top:1px solid var(--border-color);align-items:center;gap:12px;margin-top:auto;padding-top:20px;display:flex}.avatar{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-weight:700;display:flex}.main-content{flex-direction:column;flex-grow:1;gap:30px;padding:40px;display:flex;overflow-y:auto}.top-bar{justify-content:space-between;align-items:center;display:flex}.top-bar h1{font-size:32px;font-weight:700}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}.stat-card{border-radius:var(--border-radius-md);flex-direction:column;gap:12px;padding:24px;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";background-color:var(--accent-primary);width:4px;height:100%;position:absolute;top:0;left:0}.stat-card.success:before{background-color:var(--success)}.stat-card.warning:before{background-color:var(--warning)}.stat-card.danger:before{background-color:var(--danger)}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:14px}.stat-value{font-size:32px;font-weight:700}.stat-desc{color:var(--text-secondary);font-size:14px}.stats-grid-4,.stats-grid-3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}@media (width>=1024px){.stats-grid-4{grid-template-columns:repeat(4,1fr)}.stats-grid-3{grid-template-columns:repeat(3,1fr)}}.dashboard-layout{grid-template-columns:2fr 1fr;gap:30px;display:grid}@media (width<=1024px){.dashboard-layout{grid-template-columns:1fr}}.card{border-radius:var(--border-radius-md);flex-direction:column;gap:20px;padding:24px;display:flex}.card-header{justify-content:space-between;align-items:center;display:flex}.card-title{font-size:18px;font-weight:600}.table-container{border-radius:var(--border-radius-sm);overflow-x:auto}table{border-collapse:collapse;text-align:left;width:100%}th{color:var(--text-secondary);border-bottom:1px solid var(--border-color);background-color:#ffffff05;padding:14px 16px;font-size:14px;font-weight:600}td{border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle;padding:14px 16px;font-size:15px}tr:hover td{background-color:#ffffff03}.badge{text-transform:capitalize;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.badge.paid{background-color:var(--success-bg);color:var(--success)}.badge.unpaid{background-color:var(--warning-bg);color:var(--warning)}.badge.draft{background-color:var(--text-muted);color:var(--text-secondary)}.badge.cancelled{background-color:var(--danger-bg);color:var(--danger)}.form-group{flex-direction:column;gap:8px;display:flex}label{color:var(--text-secondary);font-size:14px;font-weight:500}input,select,textarea{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-family);transition:var(--transition);padding:12px 16px;font-size:15px}select option{background-color:var(--bg-surface);color:var(--text-primary)}input:focus,select:focus,textarea:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 2px #7c3aed33}.btn{border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition);border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;display:inline-flex}.btn-primary{background-color:var(--accent-primary);color:#fff}.btn-primary:hover{background-color:var(--accent-primary-hover)}.btn-secondary{border-color:var(--border-color);color:var(--text-secondary);background-color:#0000}.btn-secondary:hover{color:var(--text-primary);background-color:#ffffff0d}.btn-danger{background-color:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.btn-danger:hover{background-color:var(--danger);color:#fff}.login-wrapper{background-color:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{border-radius:var(--border-radius-lg);flex-direction:column;gap:30px;width:100%;max-width:420px;padding:40px;display:flex}.login-header{text-align:center}.login-header h1{margin-bottom:8px;font-size:28px;font-weight:800}.login-header p{color:var(--text-secondary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#0009;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{border-radius:var(--border-radius-md);flex-direction:column;gap:20px;width:100%;max-width:600px;max-height:90vh;padding:30px;display:flex;overflow-y:auto}.actions-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.search-input{max-width:320px}.invoice-wizard{grid-template-columns:1fr 1fr;gap:30px;display:grid}@media (width<=900px){.invoice-wizard{grid-template-columns:1fr}}.items-select-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;max-height:580px;padding-right:8px;display:grid;overflow-y:auto}.product-select-card{border-radius:var(--border-radius-sm);border:1px solid var(--border-color);cursor:pointer;transition:var(--transition);flex-direction:column;gap:4px;padding:8px 10px;display:flex}.product-select-card:hover{border-color:var(--accent-primary);background-color:#7c3aed0d}.product-select-card.selected{border-color:var(--accent-secondary);background-color:#06b6d41a}@media print{@page{margin:0!important}#root{display:none!important}html,body{height:auto!important;min-height:0!important}.modal-overlay{width:100%!important;height:auto!important;min-height:auto!important;box-shadow:none!important;-webkit-backdrop-filter:none!important;background:0 0!important;margin:0!important;padding:0!important;display:block!important;position:absolute!important;top:0!important;left:0!important}.print-invoice-modal{color:#000!important;box-sizing:border-box!important;width:100%!important;box-shadow:none!important;background:#fff!important;border:none!important;height:auto!important;max-height:none!important;padding:40px 15% 40px 10px!important;display:block!important;position:absolute!important;top:0!important;left:0!important;overflow:visible!important}.print-invoice-modal *{font-weight:700!important}.print-invoice-modal td,.print-invoice-modal th{color:#000!important;border-bottom:1px solid #ddd!important}body.print-receipt-mode{background:#fff!important;width:100%!important;height:auto!important;min-height:0!important;margin:0!important;padding:0!important}body.print-receipt-mode .print-invoice-modal{width:100%!important;max-width:100%!important;box-shadow:none!important;background:#fff!important;border:none!important;height:auto!important;max-height:none!important;margin:0!important;padding:0!important;display:block!important;position:relative!important;top:0!important;left:0!important;right:auto!important;overflow:visible!important}body.print-receipt-mode .print-invoice-modal *{color:#000!important}body.print-receipt-mode .print-invoice-modal td,body.print-receipt-mode .print-invoice-modal th{padding:4px 2px!important;font-size:15px!important}body.print-receipt-mode .thermal-receipt-preview{width:100%!important;max-width:100%!important;box-shadow:none!important;text-align:right!important;box-sizing:border-box!important;direction:rtl!important;border:none!important;margin:0!important;padding:3mm 2mm 1mm!important;font-size:8.5pt!important}.a4-invoice-preview{width:100%!important;max-width:100%!important;box-shadow:none!important;padding:0!important}.no-print{display:none!important}}.thermal-receipt-preview{text-align:right;direction:rtl;background:#fff;border:none;border-radius:4px;width:77mm;max-width:100%;margin:0 auto;padding:3mm 1.5mm 1mm;font-family:Cairo,Courier New,Courier,monospace;font-size:11px;line-height:1.5;box-shadow:0 4px 10px #00000026;color:#000!important}.thermal-receipt-preview *{font-weight:900!important}.a4-invoice-preview{font-family:var(--font-family);text-align:right;direction:rtl;border-radius:6px;width:800px;margin:0 auto;box-shadow:0 4px 12px #00000026;color:#000!important;background:#fff!important;max-width:none!important;padding:30px 20px!important}.a4-invoice-preview *{color:#000!important;border-color:#eee!important}.a4-invoice-preview table{border-collapse:collapse;width:100%;margin:20px 0}.a4-invoice-preview th,.a4-invoice-preview td{text-align:right;border-bottom:1px solid #eee!important;padding:12px 10px!important}.a4-invoice-preview th{font-weight:700;background-color:#f8fafc!important}.payment-details-section{color:#000!important}.payment-details-section *{color:#000!important;border-color:#000!important}.payment-methods-grid{justify-content:space-between;gap:8px;display:flex}.payment-methods-grid>div{background:#fff;border:2.5px solid #000;border-radius:4px;flex:1;padding:6px;font-size:11px;line-height:1.4}.thermal-receipt-preview *{color:#000!important}.thermal-receipt-preview h1,.thermal-receipt-preview h2,.thermal-receipt-preview h3,.thermal-receipt-preview h4{text-align:center;margin-bottom:4px}.thermal-receipt-preview table{border-collapse:collapse;width:100%;margin:10px 0}.thermal-receipt-preview th{padding:4px 0;font-weight:700;color:#000!important;background:0 0!important}.thermal-receipt-preview td{padding:5px 0;color:#000!important}.thermal-receipt-preview .dashed-line{border-bottom:4.5px dashed #000;margin:8px 0}.thermal-receipt-preview .total-section{border-top:4.5px solid #000;margin-top:8px;padding-top:8px;font-size:15px;font-weight:700}.thermal-receipt-preview .footer-text{text-align:center;margin-top:20px;font-size:10px;line-height:1.3}.low-stock-alert{background-color:var(--danger-bg);border:1px solid var(--danger);color:var(--danger);border-radius:var(--border-radius-sm);align-items:center;gap:12px;padding:12px 16px;font-size:14px;display:flex}.loading-spinner{border:4px solid #ffffff1a;border-left-color:var(--accent-primary);border-radius:50%;width:40px;height:40px;margin:40px auto;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.modal-grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.form-grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}@media (width<=600px){.modal-grid-3,.form-grid-2{grid-template-columns:1fr}}.mobile-header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:200;-webkit-backdrop-filter:blur(12px);justify-content:space-between;align-items:center;height:60px;padding:0 20px;display:none;position:sticky;top:0}.mobile-logo{align-items:center;gap:10px;display:flex}.mobile-logo h2{background:linear-gradient(135deg, #fff, var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:18px;font-weight:800}.menu-toggle{color:var(--text-primary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;font-size:24px;display:flex}.sidebar-backdrop{-webkit-backdrop-filter:blur(4px);z-index:150;background-color:#0009;width:100vw;height:100vh;position:fixed;top:0;left:0}@media (width<=768px){.app-container{flex-direction:column;min-height:100vh}.mobile-header{display:flex}.sidebar{width:280px;height:100vh;box-shadow:var(--shadow-lg);border-left:1px solid var(--border-color);background-color:var(--bg-secondary);z-index:180;border-right:none;padding:20px;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;top:0;right:-280px;transform:translate(0)}.sidebar.open{transform:translate(-280px)}.logo-section{border-bottom:1px solid var(--border-color);margin-bottom:24px;padding-bottom:16px}.sidebar-nav{flex-grow:0;gap:6px}.nav-item{padding:10px 14px}.nav-item.active{border-right:3px solid var(--accent-primary);border-left:none;padding-left:14px;padding-right:11px}.user-profile{border-top:1px solid var(--border-color);margin-top:auto;padding-top:16px;display:flex}.main-content{gap:20px;padding:20px 16px}.top-bar{flex-direction:column;align-items:flex-start;gap:12px}.top-bar h1{font-size:24px}}.global-desktop-header{justify-content:flex-end;align-items:center;margin-bottom:-15px;padding-bottom:5px;display:flex}.user-badge-header{border:1px solid var(--border-color);background-color:var(--bg-secondary);color:var(--text-primary);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(8px);border-radius:20px;align-items:center;gap:8px;padding:6px 14px;font-size:13px;display:flex}.user-status-dot{background-color:#10b981;border-radius:50%;width:8px;height:8px;box-shadow:0 0 8px #10b981}.user-username{font-weight:600}.user-role-label{color:var(--text-secondary);font-size:11px}@media (width<=768px){.global-desktop-header{display:none!important}}.charts-row{grid-template-columns:2fr 1fr;gap:20px;margin-top:20px;display:grid}@media (width<=1024px){.charts-row{grid-template-columns:1fr!important}}.chart-tooltip-badge{transition:all .2s ease-in-out}@keyframes toast-in{0%{opacity:0;transform:translate(60px)scale(.92)}to{opacity:1;transform:translate(0)scale(1)}}.toast{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);cursor:pointer;border:1px solid #ffffff1a;border-radius:14px;align-items:center;gap:12px;min-width:280px;max-width:420px;padding:14px 18px;font-family:Cairo,Outfit,sans-serif;font-size:14px;font-weight:600;transition:transform .15s,box-shadow .15s;animation:.35s cubic-bezier(.34,1.56,.64,1) both toast-in;display:flex;box-shadow:0 8px 32px #00000073,0 2px 8px #0000004d}.toast:hover{transform:translate(-4px);box-shadow:0 12px 40px #0000008c}.toast-success{color:#34d399;background:#10b98126;border-color:#10b9814d}.toast-error{color:#f87171;background:#ef444426;border-color:#ef44444d}.toast-warning{color:#fbbf24;background:#f59e0b26;border-color:#f59e0b4d}.toast-info{color:#a5b4fc;background:#6366f126;border-color:#6366f14d}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast-icon svg{width:100%;height:100%}.toast-message{flex:1;line-height:1.4}.toast-close{cursor:pointer;color:inherit;opacity:.6;background:0 0;border:none;padding:0;font-size:18px;line-height:1;transition:opacity .15s}.toast-close:hover{opacity:1}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes modal-pop{0%{opacity:0;transform:scale(.88)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.confirm-overlay{z-index:9999;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000a6;justify-content:center;align-items:center;padding:20px;animation:.2s both overlay-in;display:flex;position:fixed;inset:0}.confirm-modal{text-align:center;background:#1a1a22;border:1px solid #ffffff1a;border-radius:20px;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:400px;padding:36px 32px 28px;animation:.3s cubic-bezier(.34,1.3,.64,1) both modal-pop;display:flex;box-shadow:0 24px 80px #000000b3,0 4px 16px #0006}.confirm-icon-wrap{border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:4px;display:flex}.confirm-icon-danger{color:#f87171;background:#ef444426}.confirm-icon-warning{color:#fbbf24;background:#f59e0b26}.confirm-icon-info{color:#a5b4fc;background:#6366f126}.confirm-title{color:var(--text-primary);margin:0;font-family:Cairo,sans-serif;font-size:20px;font-weight:700}.confirm-message{color:var(--text-secondary);margin:0;font-family:Cairo,Outfit,sans-serif;font-size:14px;line-height:1.6}.confirm-actions{gap:12px;width:100%;margin-top:8px;display:flex}.confirm-btn{cursor:pointer;letter-spacing:.3px;border:none;border-radius:10px;flex:1;padding:12px 20px;font-family:Cairo,Outfit,sans-serif;font-size:15px;font-weight:700;transition:all .2s}.confirm-btn:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.confirm-btn-cancel{color:var(--text-secondary);background:#ffffff12;border:1px solid #ffffff1a}.confirm-btn-cancel:hover{color:var(--text-primary);background:#ffffff1f}.confirm-btn-danger{color:#fff;background:#ef4444}.confirm-btn-danger:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 6px 20px #ef444466}.confirm-btn-warning{color:#000;background:#f59e0b}.confirm-btn-warning:hover{background:#d97706;transform:translateY(-1px)}.confirm-btn-info{color:#fff;background:#6366f1}.confirm-btn-info:hover{background:#4f46e5;transform:translateY(-1px)}.spinner{border:2.5px solid #ffffff40;border-top-color:currentColor;border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}.btn-loading{pointer-events:none;opacity:.75;align-items:center;gap:8px;display:inline-flex}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff17 50%,#ffffff0a 75%) 0 0/800px 100%;border-radius:8px;animation:1.6s infinite shimmer}.skeleton-row{border-radius:10px;height:52px;margin-bottom:8px}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 20px;display:flex}.empty-state-icon{opacity:.35;width:64px;height:64px}.empty-state h3{color:var(--text-secondary);margin:0;font-family:Cairo,sans-serif;font-size:18px;font-weight:600}.empty-state p{max-width:300px;margin:0;font-family:Cairo,Outfit,sans-serif;font-size:14px;line-height:1.6}.action-btn-delete{transition:all .2s}.action-btn-delete:hover{transform:scale(1.08);color:#f87171!important;background:#ef444433!important}.action-btn-edit:hover{transform:scale(1.08)}@media (width>=769px){.sidebar.collapsed .logo-section{justify-content:center;gap:0;margin-bottom:30px}.sidebar.collapsed .logo-text,.sidebar.collapsed .logo-icon{display:none}.sidebar.collapsed{width:80px;padding:24px 10px}.sidebar.collapsed .sidebar-nav{align-items:center}.sidebar.collapsed .nav-item{border-radius:50%;justify-content:center;gap:0;width:48px;height:48px;padding:12px}.sidebar.collapsed .nav-text{display:none}.sidebar.collapsed .nav-icon{font-size:20px}.sidebar.collapsed .nav-item.active{background:var(--accent-primary);color:#fff;border-left:none;border-right:none;padding:12px;box-shadow:0 0 12px #7c3aed66}.sidebar.collapsed .user-profile{justify-content:center;gap:0;padding-top:16px}.sidebar.collapsed .user-profile-info,.sidebar.collapsed .user-profile-actions{display:none}}
