:root{color:#213547;background-color:#fff}body{margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.app{display:flex;flex-direction:column;min-height:100vh}.app.manager-layout{flex-direction:row}.navbar{background-color:#2c3e50;color:#fff;padding:0 20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;row-gap:8px;box-shadow:0 2px 4px #0000001a}.nav-brand h1{margin:0;font-size:24px}.nav-menu{list-style:none;display:flex;gap:12px;margin:0;padding:0;flex-wrap:wrap;justify-content:flex-end}.nav-menu a{color:#fff;text-decoration:none;padding:10px 15px;border-radius:4px;transition:background-color .3s}.nav-menu a:hover{background-color:#34495e}.sidebar{width:260px;min-width:260px;background:linear-gradient(180deg,#1f2937,#111827);color:#f9fafb;padding:16px 12px;display:flex;flex-direction:column;gap:12px;box-shadow:2px 0 10px #0000002e}.sidebar .nav-brand h1{margin:0;font-size:20px;line-height:1.25}.sidebar .nav-menu{flex-direction:column;align-items:stretch;gap:8px}.sidebar .nav-menu li{width:100%}.sidebar .nav-link{display:flex;align-items:center;gap:10px;width:100%;color:#e5e7eb;text-decoration:none;padding:10px 12px;border-radius:8px;transition:background-color .2s,color .2s,transform .2s}.sidebar .nav-link:hover{background-color:#374151;color:#fff;transform:translate(2px)}.sidebar .nav-link.active{background-color:#2563eb;color:#fff}.sidebar .nav-icon{width:20px;text-align:center;font-size:16px}.sidebar .nav-badge{margin-left:auto;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#dc2626;color:#fff;font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1}.sidebar .btn-danger{width:100%;margin-top:8px}.main-content{flex:1;padding:30px;max-width:1200px;margin:0 auto;width:100%}.manager-layout .main-content{max-width:none;margin:0;padding:24px}@media (max-width: 980px){.navbar{padding:10px 16px;align-items:flex-start}.nav-brand{width:100%}.nav-menu{width:100%;justify-content:flex-start}.app.manager-layout{flex-direction:column}.sidebar{width:100%;min-width:100%;padding:10px 12px}.sidebar .nav-menu{flex-direction:row;flex-wrap:wrap}.sidebar .nav-menu li,.sidebar .btn-danger{width:auto}.manager-layout .main-content{padding:18px}}.page-title{font-size:28px;margin-bottom:20px;color:#2c3e50}.card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px}.btn{background-color:#3498db;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:16px;transition:background-color .3s}.btn:hover{background-color:#2980b9}.btn-danger{background-color:#e74c3c}.btn-danger:hover{background-color:#c0392b}.form-group select,.form-group input{width:100%;padding:10px;border:1px solid #bdc3c7;border-radius:4px;box-sizing:border-box}table{width:100%;border-collapse:collapse;margin-top:20px}th,td{padding:12px;text-align:left;border-bottom:1px solid #bdc3c7}th{background-color:#34495e;color:#fff}tr:hover{background-color:#ecf0f1}.home-page{margin-top:20px}.home-page .welcome-card,.home-page .quick-actions,.home-page .features-grid{margin-bottom:24px}.home-page .welcome-card,.home-page .quick-actions,.home-page .features-grid h2{text-align:center}.home-page .welcome-card h2{font-weight:800;letter-spacing:.6px;text-shadow:0 1px 0 #ffffff,0 2px 0 #d9d9d9,0 3px 0 #bfbfbf,0 6px 10px rgba(0,0,0,.25)}.home-page .welcome-card p{text-align:center}.home-page .action-buttons{justify-items:center}.home-page .action-btn{max-width:320px;justify-self:center;margin:0 auto}.home-page .feature{text-align:center}.home-page .feature-icon{margin-left:auto;margin-right:auto}.home-page .role-admin{color:#1f4e79}.home-page .role-cashier{color:#8a4b00}.home-page .role-manager{color:#6a1b9a}.home-page .role-customer{color:#0b6b3a}.home-hero{text-align:center;padding:10px 10px 0}.home-page h1{margin-top:0;color:#2c3e50;font-size:2.1rem}.home-page p{color:#2c3e50}.home-actions{margin:20px 0;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.home-btn-secondary{background-color:#2c3e50}.home-btn-secondary:hover{background-color:#1f2d3a}.home-highlights{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:15px;margin:10px 0 24px}.home-highlight-card{border:1px solid #dfe6e9;border-radius:8px;padding:14px;background:#f7fbff}.home-highlight-card h3{margin:0 0 8px;color:#2c3e50}.home-highlight-card p{margin:0;color:#4e5d6c}.home-section-title{margin:0 0 12px;color:#2c3e50;font-size:1.25rem}.home-roles{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:15px;margin-top:20px}.home-role-card{border:1px solid #dfe6e9;border-radius:8px;padding:14px;background:#fafafa}.home-role-card h3{margin:0 0 8px;color:#2c3e50}.home-role-card p{margin:0;color:#636e72}.home-footer{margin-top:24px;padding-top:18px;border-top:1px solid #dfe6e9}.home-footer-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.home-footer-feature-card{padding:16px;border-radius:8px;background:#f5f7fa;border:1px solid #dfe6e9}.home-footer-feature-icon{display:inline-flex;width:28px;height:28px;border-radius:50%;align-items:center;justify-content:center;background:#2c3e50;color:#fff;font-weight:700}.home-footer-feature-card h4{margin:10px 0 6px;color:#2c3e50}.home-footer-feature-card p{margin:0;color:#636e72}.home-pro{--home-bg-top: #f4f7fb;--home-bg-bottom: #ebf1f8;--home-surface: #ffffff;--home-surface-strong: #0f2740;--home-text-primary: #102133;--home-text-secondary: #4f6275;--home-border: #d6e0ea;--home-accent: #1f5a8a;--home-accent-hover: #154769;--home-accent-soft: #e2edf7;max-width:1200px;margin:0 auto;padding:24px;color:var(--home-text-primary);background:radial-gradient(circle at 92% 6%,#dce8f5 0,transparent 36%),linear-gradient(180deg,var(--home-bg-top),var(--home-bg-bottom));border:1px solid var(--home-border);border-radius:18px;box-shadow:0 20px 50px #0f274014}.home-pro-hero{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;margin-bottom:24px}.home-pro-hero-content,.home-pro-hero-panel,.home-pro-section{background:var(--home-surface);border:1px solid var(--home-border);border-radius:14px;box-shadow:0 8px 24px #0b1f330f}.home-pro-hero-content{padding:30px}.home-pro-eyebrow{display:inline-block;margin-bottom:12px;padding:6px 12px;border-radius:999px;background:var(--home-accent-soft);color:var(--home-accent);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.home-pro-hero-content h1{margin:0;font-size:clamp(1.9rem,2.8vw,2.7rem);line-height:1.2;letter-spacing:.01em}.home-pro-hero-content p{margin:14px 0 0;max-width:62ch;color:var(--home-text-secondary);font-size:1.02rem}.home-pro-hero-actions{margin-top:22px}.home-pro-btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 20px;border-radius:10px;text-decoration:none;font-weight:600;transition:background-color .2s ease,transform .2s ease}.home-pro-btn-primary{background:var(--home-accent);color:#fff}.home-pro-btn-primary:hover{background:var(--home-accent-hover);transform:translateY(-1px)}.home-pro-hero-panel{padding:24px;background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#f1f5fb}.home-pro-hero-panel h2{margin:0 0 14px;font-size:1.05rem;letter-spacing:.02em}.home-pro-metrics{display:grid;gap:12px}.home-pro-metric{padding:14px;border:1px solid rgba(224,236,248,.18);border-radius:10px;background:#ebf2fb14}.home-pro-metric .label{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:#c7d8ec}.home-pro-icon-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;flex:0 0 24px;border-radius:8px;background:#9fbbd633;color:#e8f2fd}.home-pro-title-with-icon{display:inline-flex;align-items:center;gap:10px}.home-pro-title-with-icon .home-pro-icon-badge{width:26px;height:26px;flex-basis:26px;background:#9fbbd629}.home-pro-metric strong{display:block;margin-top:6px;font-size:1.25rem}.home-pro-section{padding:24px;margin-bottom:16px}.home-pro-section h2{margin:0;font-size:1.4rem}.home-pro-capabilities,.home-pro-role-grid{margin-top:16px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.home-pro-capability,.home-pro-role-card{padding:16px;border:1px solid var(--home-border);border-radius:12px;background:linear-gradient(180deg,#fff,#f8fbff)}.home-pro-capability{border:1px solid rgba(224,236,248,.18);background:linear-gradient(165deg,#16314c,#0f2740 55%)}.home-pro-role-card{border:1px solid rgba(224,236,248,.18);background:linear-gradient(165deg,#193650,#122b43 55%)}.home-pro-capability h3,.home-pro-role-card h3{margin:0;font-size:1.05rem}.home-pro-capability h3,.home-pro-role-card h3{color:#f1f5fb}.home-pro-capability p,.home-pro-role-card p{margin:8px 0 0;color:var(--home-text-secondary);line-height:1.5}.home-pro-capability p,.home-pro-role-card p{color:#d5e2f1}.home-pro-footer{margin-top:6px;padding:18px 2px 4px;display:flex;justify-content:space-between;align-items:center;gap:14px;border-top:1px solid var(--home-border)}.home-pro-footer p,.home-pro-footer span{margin:0;color:var(--home-text-secondary)}.home-pro-footer span{color:var(--home-surface-strong);font-weight:700}@media (max-width: 900px){.home-pro{padding:16px}.home-pro-hero,.home-pro-capabilities,.home-pro-role-grid{grid-template-columns:1fr}.home-pro-footer{flex-direction:column;align-items:flex-start}.home-pro-metric .label{letter-spacing:.05em}}.dashboard-container{--dash-bg-top: #f4f7fb;--dash-bg-bottom: #ebf1f8;--dash-surface: #ffffff;--dash-surface-deep: #0f2740;--dash-text-primary: #102133;--dash-text-muted: #587085;--dash-border: #d6e0ea;--dash-accent: #1f5a8a;--dash-accent-hover: #154769;max-width:1400px;margin:0 auto;padding:22px;border:1px solid var(--dash-border);border-radius:18px;background:radial-gradient(circle at 94% 4%,#dce8f5 0,transparent 34%),linear-gradient(180deg,var(--dash-bg-top),var(--dash-bg-bottom));box-shadow:0 20px 50px #0f274014}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;padding-bottom:14px;border-bottom:1px solid var(--dash-border)}.dashboard-header h1{font-size:clamp(1.8rem,2.3vw,2.2rem);color:var(--dash-text-primary);margin:0}.dashboard-subtitle{margin:8px 0 0;color:var(--dash-text-muted)}.btn-refresh{background:var(--dash-accent);color:#fff;border:none;padding:10px 18px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:background-color .2s ease,transform .2s ease;box-shadow:0 6px 16px #1f5a8a38}.btn-refresh:hover{background:var(--dash-accent-hover);transform:translateY(-1px)}.error-message{background-color:#fff6f4;color:#c53030;padding:13px 15px;border-radius:8px;margin-bottom:16px;border-left:4px solid #c53030}.welcome-card{background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#f1f5fb;padding:26px;margin-bottom:22px;border-radius:12px;border:1px solid rgba(224,236,248,.22);box-shadow:0 12px 30px #0f27402e}.welcome-card h2{font-size:1.5rem;margin:0 0 8px;color:#f1f5fb}.welcome-card p{font-size:.98rem;margin:0;opacity:1;line-height:1.6;color:#d5e2f1}.loading{text-align:center;padding:28px;font-size:1rem;color:var(--dash-text-muted);background:var(--dash-surface);border:1px solid var(--dash-border);border-radius:12px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;margin-bottom:18px}.stat-card{background:var(--dash-surface);border-radius:12px;padding:20px;display:flex;align-items:center;gap:14px;box-shadow:0 8px 24px #0b1f330f;transition:transform .2s ease,box-shadow .2s ease;border:1px solid var(--dash-border)}.stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 26px #0b1f331a}.stat-icon{width:44px;height:44px;border-radius:10px;font-size:.86rem;font-weight:800;letter-spacing:.05em;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.stat-content{flex:1}.stat-content h3{font-size:.75rem;color:var(--dash-text-muted);margin:0 0 6px;text-transform:uppercase;font-weight:600;letter-spacing:.08em}.stat-value{font-size:clamp(1.45rem,2vw,1.8rem);font-weight:700;margin:0 0 4px}.stat-label{font-size:.78rem;color:#7c8f9f;display:block}.stat-card-blue .stat-icon{background:#256ca1}.stat-card-blue .stat-value{color:#1f5a8a}.stat-card-green .stat-icon{background:#2f7a68}.stat-card-green .stat-value{color:#2f7a68}.stat-card-orange .stat-icon{background:#9a6432}.stat-card-orange .stat-value{color:#9a6432}.stat-card-purple .stat-icon{background:#475d83}.stat-card-purple .stat-value{color:#475d83}.quick-actions{background:var(--dash-surface);border-radius:12px;padding:24px;margin-bottom:16px;border:1px solid var(--dash-border);box-shadow:0 8px 24px #0b1f330f}.quick-actions h2{margin:0 0 14px;color:var(--dash-text-primary);font-size:1.25rem}.action-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.action-btn{padding:14px;border-radius:10px;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease;font-size:.95rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:3px}.action-btn strong{font-size:.96rem;line-height:1.3}.action-btn span{font-size:.82rem;opacity:.92}.action-btn:hover{transform:translateY(-1px)}.action-btn-primary{background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#e8f2fc;border:1px solid rgba(224,236,248,.22);box-shadow:0 10px 24px #0f274026}.action-btn-success{background:linear-gradient(165deg,#1f5a8a,#194b73 60%);color:#eaf4ff;border:1px solid rgba(183,213,242,.35);box-shadow:0 10px 24px #1f5a8a33}.action-btn-secondary{background:linear-gradient(165deg,#2f7a68,#285f56 60%);color:#ecfbf7;border:1px solid rgba(187,226,214,.35);box-shadow:0 10px 24px #2f7a6833}.features-grid{background:var(--dash-surface);border-radius:12px;padding:24px;border:1px solid var(--dash-border);box-shadow:0 8px 24px #0b1f330f}.features-grid h2{margin:0 0 14px;color:var(--dash-text-primary);font-size:1.25rem}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.feature{padding:16px;border-radius:10px;background:linear-gradient(180deg,#fff,#f7fbff);border:1px solid var(--dash-border);transition:border-color .2s ease,transform .2s ease}.feature:hover{border-color:#9cb9d3;transform:translateY(-1px)}.feature-icon{width:34px;height:34px;background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.74rem;font-weight:700;margin-bottom:8px}.feature h4{margin:6px 0 5px;color:var(--dash-text-primary);font-size:1rem}.feature p{margin:0;color:var(--dash-text-muted);font-size:.86rem;line-height:1.5}@media (max-width: 768px){.dashboard-header{flex-direction:column;gap:12px;align-items:flex-start}.btn-refresh{width:100%}.stats-grid,.action-buttons,.features{grid-template-columns:1fr}.stat-card{padding:16px}}.products-container{--products-bg-top: #f4f7fb;--products-bg-bottom: #ebf1f8;--products-surface: #ffffff;--products-text: #102133;--products-muted: #5c7388;--products-border: #d6e0ea;--products-accent: #1f5a8a;max-width:1400px;margin:0 auto;padding:22px;border:1px solid var(--products-border);border-radius:18px;background:radial-gradient(circle at 94% 4%,#dce8f5 0,transparent 34%),linear-gradient(180deg,var(--products-bg-top),var(--products-bg-bottom));box-shadow:0 20px 50px #0f274014}.products-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--products-border)}.products-header h1{font-size:clamp(1.6rem,2.2vw,2rem);color:var(--products-text);margin:0}.alert{padding:13px 15px;border-radius:8px;margin-bottom:12px;border-left:4px solid;font-weight:500}.alert-error{background-color:#fff5f5;color:#c53030;border-left-color:#c53030}.alert-success{background-color:#f0fdf4;color:#15803d;border-left-color:#15803d}.loading{text-align:center;padding:26px;font-size:1rem;color:var(--products-muted);border:1px solid var(--products-border);border-radius:12px;background:var(--products-surface)}.empty-state{text-align:center;padding:60px 40px;background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#ecf4fd;border:1px solid rgba(224,236,248,.2);border-radius:12px}.empty-state h3{font-size:24px;color:#ecf4fd;margin:0 0 10px}.empty-state p{color:#cfe0f2;margin:0 0 20px;font-size:16px}.products-content{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.products-grid{background:var(--products-surface);border-radius:12px;overflow:hidden;box-shadow:0 8px 24px #0b1f330f;border:1px solid var(--products-border)}.products-table{width:100%;border-collapse:collapse;font-size:14px}.products-table thead{background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#fff}.products-table th{padding:16px;text-align:left;font-weight:600;text-transform:uppercase;font-size:12px;letter-spacing:.5px}.products-table tbody tr{border-bottom:1px solid #e9eff5;transition:background-color .2s ease}.products-table tbody tr:hover{background-color:#f7fbff}.products-table td{padding:16px;color:var(--products-text)}.cell-id{font-weight:600;color:var(--products-accent)}.cell-name{font-weight:500;color:var(--products-text)}.cell-sku{font-family:Courier New,monospace;background:#eef4fb;padding:4px 8px;border-radius:4px;font-size:12px;color:#49627a}.cell-description{color:var(--products-muted);max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cell-price{font-weight:600;color:#2f7a68;font-size:15px}.cell-stock{text-align:center}.stock-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-align:center;min-width:50px}.stock-badge.in-stock{background:#e4f5ef;color:#1f6a57}.stock-badge.low-stock{background:#fff1d8;color:#815919}.stock-badge.out-of-stock{background:#fbe4e7;color:#8a2632}.cell-actions{display:flex;gap:8px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0b1f338c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0b1f3359;border:1px solid var(--products-border)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:25px;border-bottom:1px solid #294866;background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#fff}.modal-header h2{margin:0;font-size:20px}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#fff;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.modal-close:hover{background:#fff3}.product-form{padding:25px}.form-group{margin-bottom:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.form-group label{display:block;margin-bottom:8px;color:var(--products-text);font-weight:600;font-size:14px}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--products-border);border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease;background:#f8fbff}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#89abc9;box-shadow:0 0 0 3px #1f5a8a1f}.form-group textarea{resize:vertical}.modal-actions{display:flex;gap:10px;justify-content:flex-end;padding-top:20px;border-top:1px solid #e6eef6;margin-top:20px}.btn{padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s ease,background-color .2s ease;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:var(--products-accent);color:#fff;box-shadow:0 6px 16px #1f5a8a3d}.btn-primary:hover{transform:translateY(-1px);background:#154769}.btn-secondary{background:#e8f1fb;color:#102133;border:1px solid #c7d8ea}.btn-secondary:hover{background:#dceafa}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover{background:#c0392b}.btn-small{padding:6px 12px;font-size:12px}@media (max-width: 768px){.products-header{flex-direction:column;gap:15px;align-items:flex-start}.products-header h1{font-size:22px}.btn-primary{width:100%;justify-content:center}.products-table{font-size:12px}.products-table th,.products-table td{padding:10px}.cell-description{display:none}.cell-actions{flex-direction:column}.form-row{grid-template-columns:1fr}.modal-content{width:95%}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}.customers-page{--customers-bg-top: #f4f7fb;--customers-bg-bottom: #ebf1f8;--customers-surface: #ffffff;--customers-text: #102133;--customers-muted: #5c7388;--customers-border: #d6e0ea;--customers-accent: #1f5a8a;max-width:1400px;margin:0 auto;padding:22px;border:1px solid var(--customers-border);border-radius:18px;background:radial-gradient(circle at 94% 4%,#dce8f5 0,transparent 34%),linear-gradient(180deg,var(--customers-bg-top),var(--customers-bg-bottom));box-shadow:0 20px 50px #0f274014}.customers-page .page-title{margin-top:0;color:var(--customers-text)}.customers-page .card{background:var(--customers-surface);border:1px solid var(--customers-border);border-radius:12px;box-shadow:0 8px 24px #0b1f330f}.customers-toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}.customers-page .btn{border-radius:8px;font-weight:600}.customers-page .btn-primary{background:#1f5a8a}.customers-page .btn-primary:hover{background:#154769}.customers-page .btn-info{background:#2f7a68}.customers-page .btn-info:hover{background:#245f51}.customers-page .btn-danger{background:#b23a48}.customers-page table{margin-top:6px}.customers-page table th{background:linear-gradient(165deg,#16314c,#0f2740 55%)}.customers-page table td{color:var(--customers-text)}.customers-page table tbody tr:hover{background:#f7fbff}.customers-page table td:last-child{white-space:nowrap}.customers-page table td:last-child .btn{margin-right:6px;margin-bottom:4px}.customers-page .modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0b1f338c;display:flex;justify-content:center;align-items:center;z-index:1000}.customers-page .modal-content{background:#fff;padding:2rem;border-radius:12px;width:90%;max-width:500px;box-shadow:0 20px 60px #0b1f3359;border:1px solid var(--customers-border)}.customers-page .modal-content h3{margin-top:0;margin-bottom:1.5rem;color:var(--customers-text)}.customers-page .form-group{margin-bottom:1rem}.customers-page .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--customers-text)}.customers-page .form-group input{width:100%;padding:.75rem;border:1px solid var(--customers-border);border-radius:4px;font-size:1rem;box-sizing:border-box;color:var(--customers-text);background:#f8fbff}.customers-page .form-group textarea{width:100%;padding:.75rem;border:1px solid var(--customers-border);border-radius:4px;font-size:1rem;box-sizing:border-box;color:var(--customers-text);background:#f8fbff;resize:vertical}.customers-page .form-group input:focus{outline:none;border-color:#89abc9;box-shadow:0 0 0 3px #1f5a8a1f}.customers-page .form-group textarea:focus{outline:none;border-color:#89abc9;box-shadow:0 0 0 3px #1f5a8a1f}.customers-page .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}@media (max-width: 860px){.customers-toolbar{flex-direction:column}.customers-toolbar .btn{width:100%}}.invoice-page{--invoice-bg-top: #f4f7fb;--invoice-bg-bottom: #ebf1f8;--invoice-surface: #ffffff;--invoice-text: #102133;--invoice-muted: #5c7388;--invoice-border: #d6e0ea;--invoice-accent: #1f5a8a;max-width:1400px;margin:0 auto;padding:22px;border:1px solid var(--invoice-border);border-radius:18px;background:radial-gradient(circle at 94% 4%,#dce8f5 0,transparent 34%),linear-gradient(180deg,var(--invoice-bg-top),var(--invoice-bg-bottom));box-shadow:0 20px 50px #0f274014}.invoice-page .page-title{margin-top:0;color:var(--invoice-text)}.invoice-page .card{background:var(--invoice-surface);border:1px solid var(--invoice-border);border-radius:12px;box-shadow:0 8px 24px #0b1f330f}.invoice-page .modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0b1f338c;display:flex;justify-content:center;align-items:center;z-index:1000}.invoice-page .modal-content{background:#fff;padding:2rem;border-radius:12px;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0b1f3359;border:1px solid var(--invoice-border)}.invoice-page .modal-content h3{margin-top:0;margin-bottom:1.5rem;color:var(--invoice-text)}.invoice-page .form-group{margin-bottom:1rem}.invoice-page .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--invoice-text)}.invoice-page .form-group input,.invoice-page .form-group select{width:100%;padding:.75rem;border:1px solid var(--invoice-border);border-radius:4px;font-size:1rem;box-sizing:border-box;color:var(--invoice-text);background:#f8fbff}.invoice-page .form-group input:focus,.invoice-page .form-group select:focus{outline:none;border-color:#89abc9;box-shadow:0 0 0 3px #1f5a8a1f}.invoice-page .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.invoice-page .btn{padding:.75rem 1.5rem;border:none;border-radius:8px;cursor:pointer;font-size:.95rem;text-decoration:none;display:inline-block;transition:transform .2s ease,background-color .2s ease}.invoice-page .btn:hover{transform:translateY(-1px)}.invoice-page .btn-primary{background-color:var(--invoice-accent);color:#fff}.invoice-page .btn-primary:hover{background-color:#154769}.invoice-page .btn-secondary{background-color:#e8f1fb;color:#102133;border:1px solid #c7d8ea}.invoice-page .btn-secondary:hover{background-color:#dceafa}.invoice-page .btn-danger{background-color:#b23a48;color:#fff}.invoice-page .btn-danger:hover{background-color:#8a2632}.invoice-page .btn-success{background-color:#2f7a68;color:#fff}.invoice-page .btn-success:hover{background-color:#245f51}.invoice-items{margin-top:1rem}.invoice-item{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr auto;gap:1rem;align-items:center;padding:.5rem 0;border-bottom:1px solid #e6eef6}.invoice-item-header{font-weight:600;background-color:#edf4fb;padding:.5rem;border-radius:4px}.add-item-btn{background-color:#2f7a68;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;margin-top:1rem}.add-item-btn:hover{background-color:#245f51}.remove-item-btn{background-color:#b23a48;color:#fff;border:none;padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:.8rem}.remove-item-btn:hover{background-color:#8a2632}.invoice-summary{background-color:#f3f8fe;padding:1rem;border-radius:8px;margin-top:1rem;border:1px solid #d9e5f2}.summary-row{display:flex;justify-content:space-between;margin-bottom:.5rem}.summary-row.total{font-weight:600;font-size:1.1rem;border-top:1px solid #a8bfd7;padding-top:.5rem}.invoice-page table{width:100%;border-collapse:collapse;margin-top:1rem}.invoice-page table th,.invoice-page table td{padding:.75rem;text-align:left;border-bottom:1px solid #e7eef6;color:var(--invoice-text)}.invoice-page table th{background:linear-gradient(165deg,#16314c,#0f2740 55%);font-weight:600;color:#fff}.invoice-page table tbody tr:hover{background-color:#f7fbff}.invoice-controls{display:flex;gap:1rem;margin-bottom:1rem;align-items:center;flex-wrap:wrap}.search-input{flex:1;min-width:200px;padding:.75rem;border:1px solid var(--invoice-border);border-radius:4px;font-size:1rem;background:#f8fbff}.search-input:focus{outline:none;border-color:#89abc9;box-shadow:0 0 0 3px #1f5a8a1f}.btn-sm{padding:.4rem .8rem;font-size:.85rem}.btn-info{background-color:#1f5a8a;color:#fff}.btn-info:hover{background-color:#154769}.btn-warning{background-color:#9a6432;color:#fff}.btn-warning:hover{background-color:#7a4f28}.modal-large{max-width:900px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;border-bottom:1px solid #294866;padding-bottom:1rem}.modal-header h3{margin:0;color:#102133}.close-btn{background:none;border:none;font-size:2rem;cursor:pointer;color:#999;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#102133}.invoice-detail{margin:1rem 0}.detail-section{margin-bottom:2rem;padding:1rem;background-color:#f3f8fe;border-radius:4px;border:1px solid #d9e5f2}.detail-section h4{margin-top:0;margin-bottom:1rem;color:#102133;border-bottom:1px solid #a8bfd7;padding-bottom:.5rem}.detail-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #dde8f3;color:#102133}.detail-row:last-child{border-bottom:none}.detail-row span:first-child{font-weight:600;color:#314b63}.detail-row.total{background-color:#fff;padding:.75rem;border-radius:4px;margin-top:.5rem;border:1px solid #a8bfd7}.detail-total{font-weight:700}.detail-section table{margin-top:1rem;width:100%}.detail-section table th,.detail-section table td{padding:.75rem;border:1px solid #dde8f3;color:#102133}.detail-section table th{background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#fff}.detail-section table tbody tr:nth-child(2n){background-color:#f5f9fe}@media (max-width: 768px){.invoice-controls{flex-direction:column;align-items:stretch}.search-input{min-width:100%}.invoice-item{grid-template-columns:1fr;gap:.5rem}.invoice-item>div{display:flex;justify-content:space-between}.detail-row{flex-direction:column;gap:.5rem}.modal-content{width:95%;padding:1rem}.modal-large{max-width:95%}table{font-size:.9rem}table th,table td{padding:.5rem}}.sales-reports{--reports-bg-top: #f4f7fb;--reports-bg-bottom: #ebf1f8;--reports-surface: #ffffff;--reports-text: #102133;--reports-muted: #5c7388;--reports-border: #d6e0ea;max-width:1400px;margin:0 auto;padding:22px;border:1px solid var(--reports-border);border-radius:18px;background:radial-gradient(circle at 94% 4%,#dce8f5 0,transparent 34%),linear-gradient(180deg,var(--reports-bg-top),var(--reports-bg-bottom));box-shadow:0 20px 50px #0f274014}.page-title{color:var(--reports-text);margin-bottom:14px;font-size:clamp(1.6rem,2.2vw,2rem)}.report-controls{margin:0 0 18px;padding:14px;background-color:var(--reports-surface);border-radius:10px;border:1px solid var(--reports-border);box-shadow:0 8px 24px #0b1f330f;display:flex;gap:12px;align-items:end;flex-wrap:wrap}.report-controls label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:var(--reports-text)}.report-controls select{padding:10px 12px;border:1px solid var(--reports-border);border-radius:8px;font-size:.95rem;cursor:pointer;color:var(--reports-text);background:#f8fbff}.btn-generate,.btn-export{border:none;border-radius:8px;padding:10px 14px;font-weight:700;cursor:pointer;transition:all .2s ease}.btn-generate{background:#123456;color:#fff}.btn-generate:hover{background:#0f2c48}.btn-export{background:#e8f1fb;color:#123456;border:1px solid #c8d9ed}.btn-export:hover{background:#dceaf8}.btn-export-pdf{background:#f8edea;color:#7a2319;border:1px solid #f0cdc8}.btn-export-pdf:hover{background:#f4dfda}.btn-generate:disabled,.btn-export:disabled{opacity:.65;cursor:not-allowed}.report-error{background:#fff5f3;border:1px solid #f1c8c3;color:#a62d20;padding:10px 12px;border-radius:8px;margin-bottom:12px}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px;margin:0 0 16px}.metric-card{background:var(--reports-surface);color:var(--reports-text);padding:16px;border-radius:10px;border:1px solid var(--reports-border);box-shadow:0 8px 24px #0b1f330f}.metric-card h3{margin:0;font-size:.78rem;color:var(--reports-muted);text-transform:uppercase;letter-spacing:.07em}.metric-value,.metric-card p{font-size:clamp(1.3rem,2.1vw,1.75rem);font-weight:700;margin:8px 0 0}.report-section{background-color:var(--reports-surface);padding:18px;margin:0 0 14px;border-radius:10px;border:1px solid var(--reports-border);box-shadow:0 8px 24px #0b1f330f}.report-section h3{color:var(--reports-text);margin-top:0;margin-bottom:12px;border-bottom:1px solid var(--reports-border);padding-bottom:8px}.report-section table{width:100%;border-collapse:collapse;min-width:650px}.report-section{overflow-x:auto}.report-section table thead{background:linear-gradient(165deg,#16314c,#0f2740 55%)}.report-section table th{padding:12px;text-align:left;font-weight:600;color:#fff}.report-section table td{padding:10px 12px;border-bottom:1px solid #e7eef6;color:var(--reports-text)}.report-section table tbody tr:hover{background-color:#f7fbff}.report-section table tbody tr:last-child td{border-bottom:none}.report-section p{color:var(--reports-muted);text-align:center;padding:20px}.customer-email{font-size:.84rem;color:var(--reports-muted)}@media (max-width: 768px){.metrics-grid{grid-template-columns:1fr}.report-controls{flex-direction:column;align-items:stretch}.btn-generate,.btn-export{width:100%}.report-section{padding:15px}.report-section table th,.report-section table td{padding:8px;font-size:.9em}}.shop{--shop-bg-top: #f4f7fb;--shop-bg-bottom: #ebf1f8;--shop-surface: #ffffff;--shop-surface-deep: #0f2740;--shop-text: #102133;--shop-muted: #5c7388;--shop-border: #d6e0ea;--shop-accent: #1f5a8a;--shop-accent-hover: #154769;display:flex;flex-direction:column;min-height:calc(100vh - 120px);border:1px solid var(--shop-border);border-radius:18px;background:radial-gradient(circle at 94% 4%,#dce8f5 0,transparent 34%),linear-gradient(180deg,var(--shop-bg-top),var(--shop-bg-bottom));box-shadow:0 20px 50px #0f274014;overflow:hidden}.shop.shop-loading{justify-content:center;align-items:center;color:var(--shop-muted);font-weight:600}.shop .shop-header{background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#edf4fc;padding:18px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(224,236,248,.22)}.shop .shop-header-right{display:flex;align-items:center;gap:10px}.shop .selected-customer-chip{border:1px solid rgba(184,208,231,.7);background:#0c223859;color:#edf4fc;padding:7px 12px;border-radius:999px;font-size:.82rem;font-weight:700}.shop .shop-header h2{margin:0;font-size:clamp(1.2rem,1.9vw,1.6rem)}.shop .cart-toggle-btn{border:1px solid #b8d0e7;background:#f2f8ff;color:#123453;padding:9px 16px;border-radius:10px;font-weight:700;cursor:pointer;transition:background-color .2s ease,transform .2s ease}.shop .cart-toggle-btn:hover{background:#e5f1ff;transform:translateY(-1px)}.shop .pending-carts-card{margin:14px 18px 0;border:1px solid var(--shop-border);border-radius:12px;box-shadow:0 8px 24px #0b1f330f}.shop .pending-carts-card h3{margin-top:0;color:var(--shop-text)}.shop .pending-carts-refresh{margin-bottom:12px}.shop .pending-cart-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #e7eef6}.shop .pending-carts-empty{color:var(--shop-muted);font-weight:600}.shop .pending-cart-id{color:var(--shop-text)}.shop .pending-cart-meta{font-size:.8rem;color:var(--shop-muted)}.shop .shop-container{display:flex;flex:1;gap:16px;padding:18px;overflow:hidden}.shop .shop-main{flex:1;display:flex;flex-direction:column;overflow-y:auto}.shop .shop-main.with-sidebar{max-width:70%}.shop .product-filters{margin-bottom:14px;display:flex;gap:10px;align-items:center}.shop .search-input,.shop .barcode-input,.shop .qty-input,.shop .shop-form-group input,.shop .shop-form-group select{width:100%;padding:10px 12px;border:1px solid var(--shop-border);border-radius:8px;font-size:.95rem;box-sizing:border-box;color:var(--shop-text);background:#f8fbff}.shop .search-input,.shop .barcode-input{min-height:42px}.shop .search-input:focus,.shop .barcode-input:focus,.shop .qty-input:focus,.shop .shop-form-group input:focus,.shop .shop-form-group select:focus{outline:none;border-color:#89abc9;box-shadow:0 0 0 3px #1f5a8a1f}.shop .barcode-form{display:flex;gap:8px;min-width:320px}.shop .barcode-btn{border:none;border-radius:8px;padding:0 14px;font-weight:700;cursor:pointer;background:var(--shop-accent);color:#fff;transition:background-color .2s ease}.shop .barcode-btn:hover{background:var(--shop-accent-hover)}.shop .barcode-status{margin:-4px 0 12px;color:var(--shop-accent);font-weight:600;font-size:.86rem}.shop .products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;padding-right:4px}.shop .product-card{background:var(--shop-surface);border-radius:12px;padding:14px;box-shadow:0 8px 24px #0b1f330f;border:1px solid var(--shop-border);display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}.shop .product-card:hover{transform:translateY(-2px);box-shadow:0 10px 26px #0b1f331c}.shop .product-image{width:44px;height:44px;border-radius:10px;background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#fff;margin-bottom:10px;display:flex;align-items:center;justify-content:center;font-size:.86rem;font-weight:800;letter-spacing:.05em}.shop .product-info{display:flex;flex-direction:column;flex:1}.shop .product-info h3{margin:0 0 5px;font-size:1rem;color:var(--shop-text)}.shop .product-description{margin:5px 0;font-size:.84rem;color:var(--shop-muted);min-height:38px}.shop .stock-info{font-size:.8rem;color:#6f8395;margin-top:6px}.shop .product-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px;gap:10px}.shop .price{font-size:1.15rem;font-weight:700;color:var(--shop-accent)}.shop .add-btn{flex:1;min-height:36px;padding:8px 12px;background:#2f7a68;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:700;transition:background-color .2s ease}.shop .add-btn:hover:not(.disabled){background:#245f51}.shop .add-btn.disabled{background:#bdc9d6;cursor:not-allowed}.shop .no-products{text-align:center;padding:34px;color:var(--shop-muted);font-size:1rem;background:var(--shop-surface);border:1px solid var(--shop-border);border-radius:12px}.shop .cart-sidebar{width:30%;background:var(--shop-surface);border-radius:12px;padding:16px;border:1px solid var(--shop-border);box-shadow:0 8px 24px #0b1f330f;display:flex;flex-direction:column;max-height:calc(100vh - 220px);overflow-y:auto}.shop .cart-sidebar h3{margin:0 0 12px;color:var(--shop-text);font-size:1.2rem}.shop .cart-items{display:flex;flex-direction:column;gap:10px;flex:1;overflow-y:auto;margin-bottom:12px}.shop .cart-item{background:#f7fbff;padding:12px;border-radius:10px;border:1px solid #dbe7f4}.shop .item-name{font-weight:700;color:var(--shop-text);font-size:.92rem}.shop .item-price{color:var(--shop-accent);font-size:.86rem}.shop .item-controls{display:flex;gap:6px;align-items:center;margin:8px 0}.shop .qty-btn{width:30px;height:30px;border:1px solid #bfd1e4;background:#fff;border-radius:6px;cursor:pointer;font-weight:700;color:var(--shop-accent)}.shop .qty-btn:hover{background:#eaf3fc}.shop .qty-input{width:56px;text-align:center;padding:6px}.shop .item-total{text-align:right;font-weight:700;color:#2f7a68;margin:8px 0}.shop .remove-btn{width:100%;min-height:34px;background:#b23a48;color:#fff;border:none;border-radius:7px;cursor:pointer;font-size:.82rem;font-weight:600}.shop .remove-btn:hover{background:#8a2632}.shop .empty-cart{text-align:center;color:var(--shop-muted);padding:24px 0}.shop .cart-summary,.shop .shop-checkout-summary{background:#f3f8fe;padding:12px;border-radius:10px;border:1px solid #d9e5f2}.shop .summary-row{display:flex;justify-content:space-between;margin-bottom:8px;color:var(--shop-text)}.shop .summary-row.total{font-weight:700;color:#2f7a68;border-top:1px solid #c4d6e8;padding-top:8px;margin-top:8px}.shop .summary-row.change-due-positive{font-weight:700;color:#2f7a68}.shop .summary-row.change-due-negative{font-weight:700;color:#b23a48}.shop .checkout-btn{width:100%;min-height:42px;background:var(--shop-accent);color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;margin-top:12px;transition:background-color .2s ease}.shop .checkout-btn:hover{background:var(--shop-accent-hover)}.shop .checkout-btn:disabled{background:#b7c8d9;cursor:not-allowed}.shop .send-cart-btn{background:#2f7a68}.shop .send-cart-btn:hover{background:#245f51}.shop .shop-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b1f338c;display:flex;justify-content:center;align-items:center;padding:16px;box-sizing:border-box;overflow-y:auto;z-index:1000}.shop .shop-modal-content{background:#fff;padding:1.4rem;border-radius:12px;width:90%;max-width:560px;max-height:calc(100vh - 32px);overflow-y:auto;box-shadow:0 20px 60px #0b1f3359;border:1px solid var(--shop-border)}.shop .shop-modal-content h3{margin-top:0;margin-bottom:1rem;color:var(--shop-text)}.shop .shop-form-group{margin-bottom:12px}.shop .shop-form-group label{display:block;margin-bottom:5px;font-weight:600;color:var(--shop-text)}.shop .shop-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.shop .btn{min-height:40px;padding:8px 16px;border:none;border-radius:8px;cursor:pointer;font-weight:700;transition:background-color .2s ease,transform .2s ease}.shop .btn:hover{transform:translateY(-1px)}.shop .btn-primary{background:var(--shop-accent);color:#fff}.shop .btn-primary:hover{background:var(--shop-accent-hover)}@media (max-width: 768px){.shop .shop-header{flex-direction:column;align-items:flex-start;gap:10px}.shop .shop-header-right{width:100%;justify-content:space-between;flex-wrap:wrap}}.shop .btn-secondary{background:#e8f1fb;color:#102133;border:1px solid #c7d8ea}.shop .btn-secondary:hover{background:#dceafa}.shop .btn-success{background:#2f7a68;color:#fff}.shop .btn-success:hover{background:#245f51}@media (max-width: 1024px){.shop .product-filters{flex-direction:column;align-items:stretch}.shop .barcode-form{min-width:0;width:100%}.shop .products-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}.shop .shop-container{flex-direction:column}.shop .shop-main.with-sidebar{max-width:100%}.shop .cart-sidebar{width:100%;max-height:360px}}@media (max-width: 768px){.shop .shop-header{flex-direction:column;gap:10px;align-items:flex-start}.shop .cart-toggle-btn{width:100%}.shop .shop-container{padding:12px;gap:10px}.shop .products-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.shop .pending-cart-row{flex-direction:column;align-items:flex-start;gap:8px}.shop .shop-modal{padding:10px;align-items:flex-start}.shop .shop-modal-content{width:100%;margin-top:10px;max-height:calc(100vh - 20px)}.shop .shop-form-actions{flex-direction:column}.shop .shop-form-actions .btn{width:100%}}.cashier-dashboard{--cash-bg-top: #f4f7fb;--cash-bg-bottom: #ebf1f8;--cash-surface: #ffffff;--cash-text: #102133;--cash-muted: #5c7388;--cash-border: #d6e0ea;--cash-accent: #1f5a8a;max-width:1400px;margin:0 auto;padding:22px;border:1px solid var(--cash-border);border-radius:18px;background:radial-gradient(circle at 94% 4%,#dce8f5 0,transparent 34%),linear-gradient(180deg,var(--cash-bg-top),var(--cash-bg-bottom));box-shadow:0 20px 50px #0f274014}.cashier-header{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#edf4fc;padding:22px;border-radius:12px;margin-bottom:16px;border:1px solid rgba(224,236,248,.22);box-shadow:0 12px 30px #0f27402e}.cashier-header-title h2{margin:0;font-size:clamp(1.3rem,2vw,1.9rem)}.cashier-header-title p{margin:8px 0 0;color:#d5e2f1;font-size:.92rem}.cashier-time{font-size:1rem;font-weight:700;background-color:#d8e6f533;padding:8px 16px;border-radius:8px;border:1px solid rgba(216,230,245,.35)}.stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.stat-card{padding:16px;border-radius:12px;color:#fff;box-shadow:0 8px 24px #0b1f331a;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 26px #0b1f3324}.stat-card.primary{background:linear-gradient(165deg,#16314c,#0f2740 55%)}.stat-card.success{background:linear-gradient(165deg,#2f7a68,#285f56 60%)}.stat-card.info{background:linear-gradient(165deg,#1f5a8a,#194b73 60%)}.stat-label{font-size:.78rem;opacity:.9;margin-bottom:6px;letter-spacing:.06em;text-transform:uppercase}.stat-value{font-size:clamp(1.35rem,2.2vw,1.95rem);font-weight:700}.cashier-content{display:grid;grid-template-columns:1fr 300px;gap:14px}.section{background:var(--cash-surface);padding:18px;border-radius:12px;box-shadow:0 8px 24px #0b1f330f;border:1px solid var(--cash-border)}.section h3{margin-top:0;margin-bottom:14px;color:var(--cash-text);font-size:1.2rem;border-bottom:1px solid var(--cash-border);padding-bottom:8px}.controls{display:flex;gap:10px;margin-bottom:12px}.filter-select{flex:1;padding:10px 12px;border:1px solid var(--cash-border);border-radius:8px;font-size:.95rem;cursor:pointer;color:var(--cash-text);background:#f8fbff}.filter-select:focus{outline:none;border-color:#89abc9;box-shadow:0 0 0 3px #1f5a8a1f}.btn-refresh{padding:10px 16px;background-color:#1f5a8a;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:700;transition:background-color .2s ease,transform .2s ease}.btn-refresh:hover{background-color:#154769;transform:translateY(-1px)}.empty-message{text-align:center;color:var(--cash-muted);padding:28px;font-size:.95rem}.transactions-list{display:flex;flex-direction:column;gap:15px;max-height:500px;overflow-y:auto}.transactions-list::-webkit-scrollbar{width:8px}.transactions-list::-webkit-scrollbar-track{background:#f1f1f1}.transactions-list::-webkit-scrollbar-thumb{background:#9fb7cd;border-radius:4px}.transaction-item{border-left:4px solid #1f5a8a;background-color:#f7fbff;border-radius:10px;border:1px solid #d9e5f2;padding:15px;transition:transform .2s ease,box-shadow .2s ease}.transaction-item:hover{background-color:#fff;box-shadow:0 8px 24px #0b1f3314;transform:translateY(-1px)}.transaction-item.payment-cash{border-left-color:#28a745}.transaction-item.payment-card{border-left-color:#17a2b8}.transaction-item.payment-cheque{border-left-color:#9a6432}.transaction-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:10px}.invoice-badge{background-color:#1f5a8a;color:#fff;padding:4px 12px;border-radius:20px;font-size:.85em;font-weight:700}.payment-badge{background-color:#fff;color:#204161;padding:4px 12px;border-radius:20px;font-size:.85em;border:1px solid #c9d8e7}.transaction-time{color:#6f8395;font-size:.85em}.transaction-body{margin-bottom:10px;display:flex;gap:20px;font-size:.9em}.customer-info,.items-info{display:flex;gap:8px}.customer-info .label,.items-info .label{font-weight:600;color:#1f5a8a}.customer-info .value,.items-info .value{color:var(--cash-text)}.transaction-footer{display:flex;justify-content:space-between;align-items:flex-end;padding-top:10px;border-top:1px solid #d9e5f2}.amount-display{display:flex;align-items:center;gap:10px}.amount-display .label{font-weight:600;color:var(--cash-muted)}.amount-display .amount{font-size:1.2rem;font-weight:700;color:#2f7a68}.additional-info{display:flex;gap:15px;font-size:.8em}.additional-info .discount{color:#dc3545}.additional-info .tax{color:#1f5a8a}.quick-actions{background:var(--cash-surface);padding:18px;border-radius:12px;box-shadow:0 8px 24px #0b1f330f;border:1px solid var(--cash-border);height:fit-content;position:sticky;top:20px}.quick-actions h3{margin-top:0;margin-bottom:12px;color:var(--cash-text);font-size:1.1em;border-bottom:1px solid var(--cash-border);padding-bottom:8px}.action-buttons{display:flex;flex-direction:column;gap:10px}.action-btn{padding:11px;border-radius:8px;text-align:center;text-decoration:none;font-weight:700;transition:transform .2s ease,background-color .2s ease;cursor:pointer;display:block;font-size:.9rem}.action-btn.primary{background-color:#1f5a8a;color:#fff}.action-btn.primary:hover{background-color:#154769;transform:translateY(-1px)}.action-btn.secondary{background-color:#2f7a68;color:#fff}.action-btn.secondary:hover{background-color:#245f51;transform:translateY(-1px)}.action-btn.info{background-color:#496b89;color:#fff}.action-btn.info:hover{background-color:#385370;transform:translateY(-1px)}.stock-levels{margin-top:18px;border-top:1px solid var(--cash-border);padding-top:14px}.stock-levels h4{margin:0 0 10px;color:var(--cash-text);font-size:1em}.stock-empty{margin:0;color:var(--cash-muted);font-size:.9em}.stock-list{display:flex;flex-direction:column;gap:8px;max-height:260px;overflow-y:auto}.stock-item{display:flex;justify-content:space-between;align-items:center;background:#f7fbff;border:1px solid #dbe7f4;border-radius:6px;padding:8px 10px}.stock-name{font-size:.9em;color:var(--cash-text);font-weight:600}.stock-badge{min-width:34px;text-align:center;border-radius:999px;padding:2px 8px;font-size:.8em;font-weight:700}.stock-ok{background:#e9f8ef;color:#1f8a4c}.stock-low{background:#fff1d8;color:#815919}.stock-out{background:#fdeaea;color:#b42318}.cashier-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b1f338c;display:flex;justify-content:center;align-items:center;padding:16px;z-index:1100}.cashier-modal-content{width:min(640px,96vw);max-height:calc(100vh - 32px);overflow-y:auto;background:#fff;border-radius:12px;border:1px solid var(--cash-border);box-shadow:0 20px 60px #0b1f3359;padding:18px}.cashier-modal-content h3{margin-top:0;margin-bottom:8px;color:var(--cash-text)}.cashier-modal-subtitle{margin:0 0 14px;color:var(--cash-muted)}.customer-mode-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.customer-mode-btn{border:1px solid var(--cash-border);background:#f8fbff;color:var(--cash-text);border-radius:8px;min-height:40px;font-weight:700;cursor:pointer}.customer-mode-btn.selected{border-color:#89abc9;background:#e9f3fd;color:#123453}.registered-customer-search{margin-top:14px}.registered-customer-search label{display:block;margin-bottom:6px;color:var(--cash-text);font-weight:600}.customer-search-input{width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid var(--cash-border);border-radius:8px;background:#f8fbff}.customer-search-input:focus{outline:none;border-color:#89abc9;box-shadow:0 0 0 3px #1f5a8a1f}.customer-search-results{margin-top:10px;border:1px solid var(--cash-border);border-radius:8px;max-height:250px;overflow-y:auto;background:#fff}.customer-result{width:100%;text-align:left;border:none;border-bottom:1px solid #e4edf7;background:#fff;padding:10px 12px;cursor:pointer;display:flex;flex-direction:column;gap:2px;color:var(--cash-text)}.customer-result:last-child{border-bottom:none}.customer-result:hover{background:#f3f8fe}.customer-result.selected{background:#e9f3fd}.customer-result span{font-size:.82rem;color:var(--cash-muted)}.customer-empty{margin:0;padding:12px;color:var(--cash-muted)}.cashier-modal-actions{margin-top:16px;display:flex;gap:10px;justify-content:flex-end}@media (max-width: 1024px){.cashier-content{grid-template-columns:1fr}.quick-actions{position:static}}@media (max-width: 768px){.cashier-dashboard{padding:12px}.cashier-header{flex-direction:column;gap:10px;padding:16px;align-items:flex-start}.cashier-header-title h2{font-size:1.2rem}.stats-container{grid-template-columns:1fr;gap:10px;margin-bottom:20px}.stat-card{padding:15px}.stat-label{font-size:.9em}.stat-value{font-size:1.5em}.section{padding:15px}.transaction-header{flex-wrap:wrap}.transaction-body{flex-direction:column;gap:8px}.transaction-footer{flex-direction:column;align-items:flex-start;gap:10px}.additional-info{flex-direction:column}.customer-mode-grid{grid-template-columns:1fr}.cashier-modal-actions{flex-direction:column}}.login-page{--login-bg-top: #f4f7fb;--login-bg-bottom: #ebf1f8;--login-surface: #ffffff;--login-primary: #102133;--login-muted: #577089;--login-border: #d6e0ea;--login-accent: #1f5a8a;--login-accent-hover: #154769;max-width:980px;margin:0 auto;padding:18px;border:1px solid var(--login-border);border-radius:18px;background:radial-gradient(circle at 95% 8%,#dce8f5 0,transparent 36%),linear-gradient(180deg,var(--login-bg-top),var(--login-bg-bottom));box-shadow:0 20px 50px #0f274014}.login-shell{display:grid;grid-template-columns:1fr 1.2fr;gap:16px}.login-panel{border-radius:14px;border:1px solid rgba(224,236,248,.2);background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#edf4fc;padding:24px}.login-panel-badge{display:inline-block;margin-bottom:12px;padding:6px 11px;border-radius:999px;background:#d8e6f524;color:#d3e4f6;font-size:.77rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.login-panel h2{margin:0;font-size:1.75rem}.login-panel p{margin:12px 0 0;color:#cfe0f2;line-height:1.6}.login-card{border-radius:14px;border:1px solid var(--login-border);background:var(--login-surface);box-shadow:0 8px 24px #0b1f330f;padding:24px}.login-title{margin:0;color:var(--login-primary);font-size:1.6rem}.login-form{margin-top:16px}.login-role-group{margin:0 0 14px;padding:0;border:0}.login-role-group legend{margin-bottom:8px;color:var(--login-primary);font-weight:600}.login-role-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.login-role-option{display:flex;align-items:center;gap:8px;border:1px solid var(--login-border);border-radius:8px;padding:10px 12px;background:#f8fbff;color:var(--login-primary);font-weight:600;cursor:pointer}.login-role-option:hover{border-color:#8fb2d1;background:#f1f7ff}.login-role-option input[type=radio]{width:16px;height:16px;margin:0;accent-color:var(--login-accent)}.login-role-option:has(input[type=radio]:checked){border-color:#7ca3c5;background:#eaf3fc;box-shadow:0 0 0 2px #1f5a8a1f}.login-card .form-group{margin-bottom:12px}.login-card .form-group label{display:block;margin-bottom:6px;color:var(--login-primary);font-weight:600}.login-card .form-group select,.login-card .form-group input{width:100%;border:1px solid var(--login-border);border-radius:8px;padding:10px 12px;box-sizing:border-box;background:#f8fbff;color:var(--login-primary)}.login-card .form-group select:focus,.login-card .form-group input:focus{outline:none;border-color:#8fb2d1;box-shadow:0 0 0 3px #1f5a8a1f}.login-error{margin:8px 0 0;color:#b42318;font-size:.9rem}.login-submit{width:100%;margin-top:14px;border:none;border-radius:10px;min-height:44px;font-size:.98rem;font-weight:600;color:#fff;background:var(--login-accent);cursor:pointer;transition:background-color .2s ease,transform .2s ease}.login-submit:hover:not(:disabled){background:var(--login-accent-hover);transform:translateY(-1px)}.login-submit:disabled{cursor:not-allowed;opacity:.65}.login-hint{margin-top:16px;padding-top:14px;border-top:1px solid var(--login-border);font-size:.86rem;color:var(--login-muted)}.login-hint p{margin:0 0 6px}@media (max-width: 900px){.login-shell,.login-role-options{grid-template-columns:1fr}}.register-page{--register-bg-top: #f4f7fb;--register-bg-bottom: #ebf1f8;--register-surface: #ffffff;--register-primary: #102133;--register-muted: #577089;--register-border: #d6e0ea;--register-accent: #1f5a8a;--register-accent-hover: #154769;max-width:1050px;margin:0 auto;padding:18px;border:1px solid var(--register-border);border-radius:18px;background:radial-gradient(circle at 95% 8%,#dce8f5 0,transparent 36%),linear-gradient(180deg,var(--register-bg-top),var(--register-bg-bottom));box-shadow:0 20px 50px #0f274014}.register-shell{display:grid;grid-template-columns:1fr 1.3fr;gap:16px}.register-panel{border-radius:14px;border:1px solid rgba(224,236,248,.2);background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#edf4fc;padding:24px}.register-panel-badge{display:inline-block;margin-bottom:12px;padding:6px 11px;border-radius:999px;background:#d8e6f524;color:#d3e4f6;font-size:.77rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.register-panel h2{margin:0;font-size:1.7rem}.register-panel p{margin:12px 0 0;color:#cfe0f2;line-height:1.6}.register-card{border-radius:14px;border:1px solid var(--register-border);background:var(--register-surface);box-shadow:0 8px 24px #0b1f330f;padding:24px}.register-title{margin:0;color:var(--register-primary);font-size:1.5rem}.register-form{margin-top:14px}.register-card .form-group{margin-bottom:12px}.register-card .form-group label{display:block;margin-bottom:6px;color:var(--register-primary);font-weight:600}.register-card .form-group select,.register-card .form-group input{width:100%;border:1px solid var(--register-border);border-radius:8px;padding:10px 12px;box-sizing:border-box;background:#f8fbff;color:var(--register-primary)}.register-card .form-group select:focus,.register-card .form-group input:focus{outline:none;border-color:#8fb2d1;box-shadow:0 0 0 3px #1f5a8a1f}.register-error{margin:8px 0 0;color:#b42318;font-size:.9rem}.register-success{margin:8px 0 0;color:#146c43;font-size:.9rem}.register-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}.register-submit,.register-back{min-height:42px;border:none;border-radius:10px;padding:0 18px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .2s ease,transform .2s ease}.register-submit{color:#fff;background:var(--register-accent)}.register-submit:hover:not(:disabled){background:var(--register-accent-hover);transform:translateY(-1px)}.register-submit:disabled{opacity:.7;cursor:not-allowed}.register-back{color:var(--register-primary);background:#e8f1fb;border:1px solid #c7d8ea}.register-back:hover{background:#dceafa}@media (max-width: 900px){.register-shell{grid-template-columns:1fr}}.usersdb-page{--users-bg-top: #f4f7fb;--users-bg-bottom: #ebf1f8;--users-surface: #ffffff;--users-text: #102133;--users-muted: #5c7388;--users-border: #d6e0ea;max-width:1400px;margin:0 auto;padding:22px;border:1px solid var(--users-border);border-radius:18px;background:radial-gradient(circle at 94% 4%,#dce8f5 0,transparent 34%),linear-gradient(180deg,var(--users-bg-top),var(--users-bg-bottom));box-shadow:0 20px 50px #0f274014}.usersdb-header{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:10px}.usersdb-header .page-title{margin:0;color:var(--users-text)}.usersdb-header p{margin:8px 0 0;color:var(--users-muted)}.usersdb-count{margin:0 0 12px;color:var(--users-text)}.usersdb-form{margin:14px 0;background:var(--users-surface);border:1px solid var(--users-border);border-radius:12px;padding:14px;box-shadow:0 8px 24px #0b1f330f}.usersdb-form h3{margin:0 0 10px;color:var(--users-text)}.usersdb-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.usersdb-form-grid input,.usersdb-form-grid select{width:100%;box-sizing:border-box;border:1px solid var(--users-border);border-radius:8px;padding:10px 12px;background:#f8fbff;color:var(--users-text)}.usersdb-form-grid input:focus,.usersdb-form-grid select:focus{outline:none;border-color:#89abc9;box-shadow:0 0 0 3px #1f5a8a1f}.usersdb-active-toggle{display:flex;align-items:center;gap:6px;color:var(--users-text);font-weight:600}.usersdb-form-actions{margin-top:10px;display:flex;gap:8px}.usersdb-error{margin:0 0 12px;color:#b42318}.usersdb-loading{margin:0;padding:20px;color:var(--users-muted);border:1px solid var(--users-border);border-radius:10px;background:var(--users-surface)}.usersdb-table-wrap{background:var(--users-surface);border:1px solid var(--users-border);border-radius:12px;box-shadow:0 8px 24px #0b1f330f;overflow:auto}.usersdb-page table{margin:0}.usersdb-page table th{background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#fff}.usersdb-page table td{color:var(--users-text)}.usersdb-page table tbody tr:hover{background:#f7fbff}.usersdb-name{color:#1f5a8a}.usersdb-status{display:inline-block;min-width:74px;text-align:center;padding:5px 10px;border-radius:999px;font-size:.78rem;font-weight:700}.usersdb-status.active{background:#e4f5ef;color:#1f6a57}.usersdb-status.inactive{background:#fbe4e7;color:#8a2632}.usersdb-actions{display:flex;gap:8px;flex-wrap:wrap}.usersdb-page .btn{border-radius:8px;font-weight:600}.usersdb-page .btn:hover{transform:translateY(-1px)}.usersdb-page .btn:not(.btn-danger){background:#1f5a8a}.usersdb-page .btn:not(.btn-danger):hover{background:#154769}.usersdb-page .btn-danger{background:#b23a48}.usersdb-page .btn-danger:hover{background:#8a2632}.usersdb-page .btn-secondary{background:#496b89}.usersdb-page .btn-secondary:hover{background:#385370}@media (max-width: 768px){.usersdb-header{flex-direction:column;align-items:flex-start}.usersdb-form-actions{flex-direction:column}}.accounting-page{--acct-bg-top: #f4f7fb;--acct-bg-bottom: #ebf1f8;--acct-surface: #ffffff;--acct-text: #102133;--acct-muted: #5c7388;--acct-border: #d6e0ea;max-width:1320px;margin:0 auto;padding:22px;border:1px solid var(--acct-border);border-radius:18px;background:radial-gradient(circle at 94% 4%,#dce8f5 0,transparent 34%),linear-gradient(180deg,var(--acct-bg-top),var(--acct-bg-bottom));box-shadow:0 20px 50px #0f274014}.accounting-controls,.accounting-card{background:var(--acct-surface);border-radius:12px;padding:18px;margin-bottom:14px;box-shadow:0 8px 24px #0b1f330f;border:1px solid var(--acct-border)}.accounting-controls .accounting-inline-form label{font-weight:600;color:var(--acct-text)}.accounting-book-banner{border-left:4px solid #1f5a8a;background:linear-gradient(135deg,#f7fbff,#eef5fb)}.accounting-book-eyebrow{margin:0 0 6px;color:var(--acct-muted);font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.accounting-book-banner h3{margin:0 0 6px;color:var(--acct-text)}.accounting-book-banner p{margin:0;color:var(--acct-muted)}.accounting-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.accounting-kpi{background:linear-gradient(180deg,#fff,#f7fbff);border:1px solid var(--acct-border);border-radius:10px;padding:14px}.accounting-kpi h4{margin:0 0 6px;color:var(--acct-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.07em}.accounting-kpi p{margin:0;font-size:1.35rem;font-weight:700;color:var(--acct-text)}.accounting-table{width:100%;border-collapse:collapse}.accounting-table th,.accounting-table td{border-bottom:1px solid #e7eef6;padding:10px;text-align:left}.accounting-table th{background:linear-gradient(165deg,#16314c,#0f2740 55%);color:#fff;font-weight:600}.accounting-table td{color:var(--acct-text)}.accounting-table tbody tr:hover{background:#f7fbff}.accounting-inline-form{display:flex;flex-wrap:wrap;gap:10px}.accounting-inline-form input,.accounting-inline-form select{min-width:150px;border:1px solid var(--acct-border);border-radius:8px;padding:10px 12px;background:#f8fbff;color:var(--acct-text)}.accounting-inline-form input:focus,.accounting-inline-form select:focus{outline:none;border-color:#89abc9;box-shadow:0 0 0 3px #1f5a8a1f}.accounting-actions{display:flex;gap:8px}.accounting-error{color:#b42318;margin-top:8px}.accounting-success{color:#146c43;margin-top:8px}.accounting-page .btn{border-radius:8px;font-weight:600}.accounting-page .btn-primary{background:#1f5a8a}.accounting-page .btn-primary:hover{background:#154769}.accounting-page .btn-success{background:#2f7a68}.accounting-page .btn-success:hover{background:#245f51}.accounting-page .btn-danger{background:#b23a48}.accounting-page .btn-danger:hover{background:#8a2632}.analysis-container{padding:20px 40px;max-width:1600px;margin:0 auto}.analysis-container h1{color:#1a1a1a;margin-bottom:30px;font-size:2em;border-bottom:3px solid #007bff;padding-bottom:10px}.analysis-controls{display:flex;gap:15px;margin-bottom:30px;flex-wrap:wrap;align-items:flex-end;background:#f8f9fa;padding:15px;border-radius:8px}.control-group{display:flex;flex-direction:column;gap:5px}.control-group label{font-weight:600;color:#333;font-size:.95em}.control-select{padding:10px 12px;border:2px solid #ddd;border-radius:6px;font-size:.95em;background-color:#fff;cursor:pointer;min-width:180px;transition:border-color .3s}.control-select:hover{border-color:#007bff}.control-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.btn-generate{padding:10px 20px;background-color:#003a70;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:background-color .3s;font-size:.95em;white-space:nowrap}.btn-generate:hover:not(:disabled){background-color:#002650}.btn-generate:disabled{opacity:.6;cursor:not-allowed}.btn-export{padding:10px 20px;background-color:#28a745;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:background-color .3s;font-size:.95em;white-space:nowrap}.btn-export:hover{background-color:#218838}.btn-export-pdf{padding:10px 20px;background-color:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:background-color .3s;font-size:.95em;white-space:nowrap}.btn-export-pdf:hover{background-color:#c82333}.analysis-error{background-color:#f8d7da;border:2px solid #f5c6cb;color:#721c24;padding:15px;border-radius:6px;margin-bottom:20px;font-weight:500}.analysis-loading{text-align:center;padding:20px;color:#666;font-size:1.1em}.analysis-content{margin-top:20px}.analysis-panel-nav{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 16px}.analysis-panel-btn{border:1px solid #cbd5e1;background:#fff;color:#1e293b;border-radius:999px;padding:8px 12px;font-size:.84rem;font-weight:600;cursor:pointer;transition:all .2s ease}.analysis-panel-btn:hover{border-color:#2563eb;color:#1d4ed8}.analysis-panel-btn.active{background:#1d4ed8;border-color:#1d4ed8;color:#fff}.analysis-section{background-color:#fff;border:1px solid #ddd;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.analysis-section h2{color:#1a1a1a;margin-bottom:20px;font-size:1.5em;border-bottom:2px solid #e9ecef;padding-bottom:10px}.analysis-section h3{color:#333;margin-bottom:15px;font-size:1.2em;margin-top:0}.analysis-section h4{color:#1f2937;margin:0 0 10px;font-size:1.05em}.analysis-ai-insights{margin-top:12px;padding:12px;border:1px solid #dbeafe;border-radius:8px;background:#f8fbff}.analysis-ai-insights p{color:#1f2937;margin:0 0 6px;line-height:1.45}.analysis-ai-insights p:last-child{margin-bottom:0}.ai-insight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:10px}.ai-insight-card{border:1px solid #dbeafe;border-radius:10px;padding:10px;background:#fff}.ai-insight-card p{margin:8px 0;color:#1f2937;line-height:1.4}.ai-insight-card.demand{border-left:4px solid #0ea5e9}.ai-insight-card.stock{border-left:4px solid #14b8a6}.ai-insight-card.risk{border-left:4px solid #ef4444}.ai-insight-card.opportunity{border-left:4px solid #f59e0b}.ai-insight-card.other{border-left:4px solid #64748b}.ai-insight-meta{display:flex;justify-content:space-between;align-items:center;gap:8px}.ai-insight-tag{font-size:.75rem;font-weight:700;letter-spacing:.4px;color:#0f172a;background:#e2e8f0;border-radius:999px;padding:3px 8px}.ai-insight-score{font-size:.8rem;font-weight:700;color:#1d4ed8}.ai-meter{height:8px;border-radius:999px;background:#dbeafe;overflow:hidden}.ai-meter-fill{height:100%;background:linear-gradient(90deg,#38bdf8,#2563eb)}.ai-priority-chart{background:#f8fbff;border:1px solid #dbeafe;border-radius:10px;padding:10px;margin-bottom:10px}.ai-priority-row{display:grid;grid-template-columns:74px 1fr 34px;align-items:center;gap:10px;margin-bottom:8px}.ai-priority-row:last-child{margin-bottom:0}.priority-label{font-size:.84rem;font-weight:700}.priority-label.high{color:#b91c1c}.priority-label.medium{color:#a16207}.priority-label.low{color:#0f766e}.priority-bar-track{height:10px;border-radius:999px;overflow:hidden;background:#e5e7eb}.priority-bar-fill{height:100%}.priority-bar-fill.high{background:linear-gradient(90deg,#ef4444,#b91c1c)}.priority-bar-fill.medium{background:linear-gradient(90deg,#f59e0b,#b45309)}.priority-bar-fill.low{background:linear-gradient(90deg,#14b8a6,#0f766e)}.priority-value{font-size:.85rem;font-weight:700;color:#334155;text-align:right}.analysis-recommendations,.analysis-season-map{margin-top:14px}.analysis-season-map h4{margin-bottom:10px}.demand-pill{display:inline-block;border-radius:999px;padding:4px 8px;font-size:.74rem;font-weight:700;letter-spacing:.4px}.demand-pill.high{color:#991b1b;background:#fee2e2}.demand-pill.medium{color:#92400e;background:#fef3c7}.demand-pill.low{color:#065f46;background:#d1fae5}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:20px}.metric-card{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px;border-radius:8px;text-align:center;box-shadow:0 2px 8px #0000001a;transition:transform .3s,box-shadow .3s}.metric-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.metric-card.highlighted{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.metric-label{font-size:.9em;color:#555;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.metric-card.highlighted .metric-label{color:#ffffffe6}.metric-value{font-size:1.6em;font-weight:700;color:#1a1a1a}.metric-card.highlighted .metric-value{color:#fff}.table-wrapper{overflow-x:auto;border-radius:6px;border:1px solid #ddd;margin-top:15px}.analysis-table{width:100%;border-collapse:collapse;font-size:.95em;min-width:600px}.analysis-table thead{background-color:#f8f9fa;border-bottom:2px solid #dee2e6}.analysis-table th{padding:12px;text-align:left;font-weight:600;color:#333;text-transform:uppercase;font-size:.85em;letter-spacing:.5px}.analysis-table td{padding:12px;border-bottom:1px solid #e9ecef;color:#333}.analysis-table tbody tr:hover{background-color:#f8f9fa}.analysis-table tbody tr:nth-child(2n){background-color:#fafbfc}.analysis-table .high-profit{color:#28a745;font-weight:600}.analysis-table .low-profit{color:#dc3545;font-weight:600}.analysis-table .repeat{color:#28a745;font-weight:600}.analysis-table .one-time{color:#ffc107;font-weight:600}@media (max-width: 768px){.analysis-container{padding:15px 20px}.analysis-container h1{font-size:1.5em;margin-bottom:20px}.analysis-controls{flex-direction:column;gap:10px}.control-select{width:100%;min-width:unset}.btn-generate,.btn-export,.btn-export-pdf{width:100%}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.metric-card{padding:15px}.metric-label{font-size:.8em}.metric-value{font-size:1.3em}.analysis-table{font-size:.85em;min-width:500px}.analysis-table th,.analysis-table td{padding:8px}.analysis-section{padding:15px;margin-bottom:15px}.analysis-panel-nav{gap:6px}.analysis-panel-btn{width:100%;text-align:left}.analysis-section h2{font-size:1.2em;margin-bottom:15px}.analysis-section h3{font-size:1em;margin-bottom:10px}.ai-insight-grid{grid-template-columns:1fr}.ai-priority-row{grid-template-columns:64px 1fr 30px}}@media (max-width: 480px){.analysis-container{padding:10px 15px}.analysis-container h1{font-size:1.3em;margin-bottom:15px}.metrics-grid{grid-template-columns:1fr}.analysis-table{font-size:.75em;min-width:400px}.analysis-table th,.analysis-table td{padding:6px}.metric-value{font-size:1.1em}.analysis-section{padding:10px;margin-bottom:10px}}.stockclerk-page{display:flex;flex-direction:column;gap:18px}.stockclerk-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#09121e9e;display:flex;align-items:center;justify-content:center;padding:24px;z-index:40;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.stockclerk-modal{width:min(720px,100%);border-radius:18px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #d6dde7;box-shadow:0 24px 70px #040c1c47;padding:22px}.stockclerk-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.stockclerk-modal-kicker{margin:0 0 6px;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#b45309}.stockclerk-modal h2{margin:0;color:#102133}.stockclerk-modal-copy{margin:14px 0 18px;color:#425466;line-height:1.6}.stockclerk-modal-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.stockclerk-modal-item{border:1px solid #d9e2ec;border-radius:12px;background:#fff;padding:12px 14px;display:flex;flex-direction:column;gap:4px}.stockclerk-modal-item strong{color:#102133;font-size:.98rem}.stockclerk-modal-item span{color:#5c7084;font-size:.9rem}.stockclerk-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px;flex-wrap:wrap}.stockclerk-modal-close{border:1px solid #cbd5e1;border-radius:999px;background:#fff;color:#1f2937;padding:8px 14px;font-weight:700;cursor:pointer}.stockclerk-modal-close:hover{background:#f8fafc}.stockclerk-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.stockclerk-header h1{margin:0;color:#1f2937}.stockclerk-header p{margin:6px 0 0;color:#4b5563}.stockclerk-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.stockclerk-card{border:1px solid #d1d5db;border-radius:10px;background:#fff;padding:12px;display:flex;flex-direction:column;gap:8px}.stockclerk-card span{color:#6b7280;font-size:.88rem}.stockclerk-card strong{color:#111827;font-size:1.4rem}.stockclerk-card.warning{background:#fffbeb;border-color:#f59e0b}.stockclerk-card.danger{background:#fef2f2;border-color:#ef4444}.stockclerk-card input{width:80px;border:1px solid #cbd5e1;border-radius:6px;padding:6px 8px}.stockclerk-section{border:1px solid #e5e7eb;border-radius:10px;background:#fff;padding:14px}.stockclerk-menu{display:flex;gap:10px;flex-wrap:wrap}.stockclerk-menu-item{border:1px solid #cbd5e1;border-radius:999px;background:#f8fafc;color:#1f2937;padding:8px 14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.stockclerk-menu-item:hover{background:#eff6ff;border-color:#93c5fd}.stockclerk-menu-item.active{background:#1d4ed8;border-color:#1d4ed8;color:#fff}.stockclerk-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#dc2626;color:#fff;font-size:.72rem;font-weight:800;line-height:1;box-shadow:0 0 0 2px #ffffffd9}.stockclerk-alert-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.stockclerk-alert-pill{display:inline-flex;align-items:center;border-radius:999px;background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;padding:6px 10px;font-size:.78rem;font-weight:800;letter-spacing:.02em}.stockclerk-section h2{margin-top:0;color:#1f2937}.table-wrap{overflow-x:auto;border-radius:8px;border:1px solid #e5e7eb}.table-wrap table{width:100%;border-collapse:collapse;font-size:.95rem}.table-wrap table thead{background:linear-gradient(165deg,#16314c,#0f2740 55%);position:sticky;top:0}.table-wrap table th{color:#fff;font-weight:600;padding:14px 12px;text-align:left;white-space:nowrap;border-bottom:2px solid #0f2740}.table-wrap table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s ease}.table-wrap table tbody tr:hover{background:#f9fafb}.table-wrap table td{padding:14px 12px;color:#374151;word-break:break-word;max-width:250px}.table-wrap table td:nth-child(1){max-width:80px;font-family:monospace;font-weight:600;color:#1f2937}.table-wrap table td:nth-child(2){max-width:280px;font-weight:500;color:#1f2937;min-width:150px}.table-wrap table td:nth-child(3),.table-wrap table td:nth-child(4){text-align:center;max-width:120px}.table-wrap table td:nth-child(5){text-align:center;max-width:140px}.qty-input{width:100px;border:1px solid #cbd5e1;border-radius:6px;padding:6px 8px}.pill{display:inline-block;padding:3px 8px;border-radius:999px;font-size:.78rem;font-weight:700}.pill.warning{background:#fef3c7;color:#92400e}.pill.danger{background:#fee2e2;color:#991b1b}.pill.ok{background:#dcfce7;color:#166534}.stockclerk-error{color:#b91c1c;margin:0}.stockclerk-ok{color:#047857;margin:0}.promotions-page{max-width:1400px;margin:0 auto;padding:22px}.promotions-header,.promotions-panel{background:#fff;border:1px solid #d6e0ea;border-radius:16px;box-shadow:0 12px 30px #0f27400f}.promotions-header{padding:24px;margin-bottom:18px;background:linear-gradient(165deg,#16314c,#0f2740 58%);color:#f2f7fc}.promotions-eyebrow{margin:0 0 8px;letter-spacing:.12em;text-transform:uppercase;font-size:.74rem;color:#8ec2ef;font-weight:700}.promotions-header h1{margin:0 0 8px;font-size:clamp(1.8rem,2.4vw,2.3rem)}.promotions-subtitle{margin:0;max-width:900px;color:#d7e4f2;line-height:1.6}.promotions-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:16px;margin-bottom:16px}.promotions-panel{padding:20px}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.panel-header h2{margin:0;color:#102133}.panel-header span{color:#587085;font-size:.9rem}.promotion-form{display:grid;gap:14px}.promotion-form label{display:grid;gap:6px;color:#102133;font-weight:600}.promotion-form input,.promotion-form textarea,.promotion-search{width:100%;border:1px solid #cfd9e4;border-radius:10px;padding:12px 14px;font:inherit;background:#fff;color:#102133}.promotion-form textarea{resize:vertical;min-height:140px}.template-hint{padding:12px 14px;border-radius:10px;background:#f4f8fc;border:1px solid #dbe6f1;color:#587085;font-size:.92rem;line-height:1.5}.promotion-actions{display:flex;gap:10px;flex-wrap:wrap}.btn-preview,.btn-send{border:none;border-radius:10px;padding:12px 16px;font-weight:700;cursor:pointer;transition:transform .2s ease,opacity .2s ease}.btn-preview:hover,.btn-send:hover{transform:translateY(-1px)}.btn-preview{background:#1f5a8a;color:#fff}.btn-send{background:#2f7a68;color:#fff}.btn-preview:disabled,.btn-send:disabled{opacity:.55;cursor:not-allowed;transform:none}.promotion-message{margin-top:14px;padding:12px 14px;border-radius:10px;background:#eef7ff;border:1px solid #cfe4fb;color:#1f3b5a}.promotion-search{max-width:280px}.promotion-loading{padding:18px;color:#587085;background:#f8fbfe;border:1px dashed #cfd9e4;border-radius:12px}.product-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}.product-item{display:grid;gap:6px;padding:12px;border-radius:12px;border:1px solid #d8e2ec;background:linear-gradient(180deg,#fff,#f8fbfe);cursor:pointer}.product-item.selected{border-color:#1f5a8a;box-shadow:inset 0 0 0 1px #1f5a8a}.product-name{font-weight:700;color:#102133}.product-meta{font-size:.86rem;color:#587085}.product-filter-hint{margin-top:4px;font-size:.78rem;font-weight:600;color:#6a7f93}.product-filter-hint.active{color:#1f5a8a}.results-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.result-card{border:1px solid #d8e2ec;border-radius:12px;padding:14px;background:#fdfefe}.result-card{display:flex;align-items:flex-start;gap:12px;cursor:pointer;transition:all .2s ease}.result-card:hover{border-color:#1f5a8a;box-shadow:0 2px 8px #1f5a8a1a}.result-card.selected{border-color:#1f5a8a;background:#f0f7ff;box-shadow:inset 0 0 0 1px #1f5a8a}.result-checkbox-wrapper{flex-shrink:0;padding-top:2px}.result-checkbox-wrapper input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#1f5a8a}.result-content{flex:1;min-width:0}.result-card h3{margin:0 0 4px;color:#102133}.result-card p{margin:0 0 10px;color:#587085}.result-tags{display:flex;flex-wrap:wrap;gap:8px}.result-tag{padding:6px 10px;border-radius:999px;background:#eaf3fb;color:#1f5a8a;font-size:.82rem;font-weight:700}.filter-section{padding:12px 14px;margin-bottom:14px;background:#f8fbfe;border:1px solid #dbe6f1;border-radius:12px}.filter-label{display:flex;flex-direction:column;gap:8px;color:#102133;font-weight:600;font-size:.95rem}.filter-select{padding:10px 12px;border:1px solid #cfd9e4;border-radius:8px;background:#fff;color:#102133;font-weight:500;cursor:pointer}.filter-select:hover{border-color:#1f5a8a}.filter-select:focus{outline:none;border-color:#1f5a8a;box-shadow:0 0 0 3px #1f5a8a1a}.result-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px}.result-header h3{margin:0;color:#102133;flex:1}.result-email{font-size:.86rem;color:#587085;white-space:nowrap}.result-favorites{padding:8px 10px;margin-bottom:10px;border-radius:8px;background:#fef8f0;border-left:3px solid #d97a06;font-size:.92rem;color:#7d5318}.customers-preview{margin-top:16px;padding:12px 14px;background:#f0f7ff;border:1px solid #cfe4fb;border-radius:10px}.customers-preview h3{margin:0 0 12px;color:#102133;font-size:.95rem}.customers-list-compact{display:flex;flex-direction:column;gap:8px}.customer-item-compact{padding:8px 10px;background:#fff;border:1px solid #dbe6f1;border-radius:6px;font-size:.9rem}.customer-item-compact.more{text-align:center;color:#587085;font-style:italic;background:#f8fbfe;padding:10px}.customer-name-compact{font-weight:600;color:#102133}.customer-email-compact{font-size:.85rem;color:#587085;margin-top:2px}@media (max-width: 980px){.promotions-grid{grid-template-columns:1fr}.panel-header{align-items:flex-start;flex-direction:column}.promotion-search{max-width:none}}@media (max-width: 640px){.promotions-page{padding:14px}.promotions-header,.promotions-panel{border-radius:14px}.promotion-actions{flex-direction:column}.btn-preview,.btn-send{width:100%}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#ffffffde;background-color:#242424}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
