.layout{display:flex;min-height:100vh}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f121b8c;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:45}.sidebar-overlay.visible{opacity:1;pointer-events:auto}.sidebar{width:var(--sidebar-w);background:var(--color-bg-dark);color:var(--color-text-on-dark);padding:0;display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;z-index:50;transition:transform .28s cubic-bezier(.4,0,.2,1);box-shadow:2px 0 #00000005}.sidebar-brand{padding:16px 18px;font-size:15px;font-weight:700;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:8px;flex-shrink:0}.sidebar-brand-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-brand-tag{font-size:10px;font-weight:600;background:var(--color-primary);color:#fff;padding:2px 6px;border-radius:4px;flex-shrink:0}.sidebar-close{display:none;background:none;border:none;color:#ffffffa6;cursor:pointer;padding:4px;border-radius:6px;flex-shrink:0;align-items:center;justify-content:center}.sidebar-close:hover{background:#ffffff14;color:#fff}.sidebar-section{padding:14px 18px 6px;font-size:10px;font-weight:700;letter-spacing:.6px;color:#fff6;text-transform:uppercase}.sidebar-nav{flex:1;overflow-y:auto;padding-bottom:16px;-webkit-overflow-scrolling:touch}.sidebar-nav::-webkit-scrollbar{width:5px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 18px;color:#ffffffbf;text-decoration:none;font-size:13.5px;border-left:3px solid transparent;width:100%;background:none;border-top:none;border-right:none;border-bottom:none;text-align:left;font-family:inherit;cursor:pointer;transition:background .12s,color .12s}.sidebar-link-icon{flex-shrink:0;opacity:.85}.sidebar-link:hover{background:#ffffff0d;color:#fff;text-decoration:none}.sidebar-link.active{background:#2563eb33;color:#fff;border-left-color:var(--color-primary);font-weight:600}.sidebar-link.active .sidebar-link-icon{opacity:1;color:#93c5fd}.sidebar-logout{color:#ff7878d9}.sidebar-logout:hover{background:#dc26261f;color:#fca5a5}.layout-main{flex:1;margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column;width:calc(100% - var(--sidebar-w))}.topbar{height:var(--topbar-h);background:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:30;gap:12px}.topbar-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.topbar-business-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.topbar-right{display:flex;align-items:center;gap:14px;flex-shrink:0}.topbar-user{display:flex;align-items:center;gap:8px;font-size:13px}.topbar-user-name{font-weight:600;white-space:nowrap}.topbar-user-role{font-size:11px;color:var(--color-text-muted)}.content-area{flex:1;padding:24px;max-width:100%}.hamburger{display:none;background:none;border:none;color:var(--color-text);cursor:pointer;padding:6px;border-radius:8px;align-items:center;justify-content:center;flex-shrink:0}.hamburger:hover{background:var(--color-bg)}.footer{text-align:center;padding:10px;font-size:11px;color:var(--color-text-muted);border-top:1px solid var(--color-border);background:#fff}@media (max-width: 1024px){.sidebar{transform:translate(-100%);width:280px;box-shadow:4px 0 24px #0000002e}.sidebar.open{transform:translate(0)}.sidebar-close{display:flex}.layout-main{margin-left:0;width:100%}.hamburger{display:flex}}@media (max-width: 600px){.sidebar{width:min(85vw,300px)}.content-area{padding:14px}.topbar{padding:0 12px;height:56px}.topbar-user-role{display:none}.topbar-business-name{font-size:14px}.sidebar-brand{padding:14px}}@media (max-width: 380px){.topbar-user-name{font-size:12px;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.auth-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#1e293b,#2563eb)}.auth-card{background:#fff;border-radius:12px;width:100%;max-width:420px;padding:32px;box-shadow:0 20px 50px #0003}.auth-brand{text-align:center;margin-bottom:26px}.auth-brand-logo{font-size:36px;margin-bottom:6px}.auth-brand-name{font-size:22px;font-weight:800;letter-spacing:.5px}.auth-brand-tag{font-size:12px;color:var(--color-text-muted);margin-top:2px}.auth-title{font-size:16px;font-weight:600;margin:0 0 18px;text-align:center}.auth-links{display:flex;justify-content:space-between;margin-top:14px;font-size:12px}.auth-demo-box{margin-top:20px;padding:12px;background:#f1f5f9;border-radius:6px;font-size:12px}.auth-demo-title{font-weight:600;margin-bottom:6px}.auth-demo-row{color:var(--color-text-muted);margin-top:3px;font-family:monospace}.landing-root{--bg: #faf6f0;--bg-card: #ffffff;--ink: #1a1410;--ink-soft: #574c45;--accent: #d97706;--accent-strong: #b45309;--accent-soft: #fef3c7;--green: #047857;--green-soft: #d1fae5;--line: #e8dfd3;background:var(--bg);color:var(--ink);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.landing-nav{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;max-width:1200px;margin:0 auto}.landing-brand{display:flex;align-items:center;gap:8px;font-weight:800;font-size:18px;letter-spacing:-.4px}.landing-brand-icon{font-size:24px}.landing-brand-tag{background:var(--ink);color:var(--bg);font-size:10px;padding:2px 8px;border-radius:8px;font-weight:700;letter-spacing:.6px}.landing-nav-links{display:flex;gap:24px;align-items:center}.landing-nav-links a{color:var(--ink-soft);text-decoration:none;font-size:14px;font-weight:500}.landing-nav-links a:hover{color:var(--ink)}.btn-landing{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:10px;border:2px solid var(--ink);background:var(--bg-card);color:var(--ink);font-weight:600;font-size:14px;text-decoration:none;cursor:pointer;transition:all .15s;font-family:inherit}.btn-landing:hover{transform:translateY(-1px);box-shadow:0 4px 0 var(--ink);text-decoration:none}.btn-landing-primary,.btn-landing-primary:hover{background:var(--ink);color:var(--bg)}.btn-landing-lg{padding:14px 28px;font-size:16px}.landing-hero{max-width:1100px;margin:0 auto;padding:60px 32px 80px;text-align:center}.landing-hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--accent-soft);color:var(--accent-strong);font-size:13px;font-weight:600;padding:6px 14px;border-radius:20px;margin-bottom:24px}.landing-hero-title{font-size:clamp(36px,6vw,68px);font-weight:800;letter-spacing:-1.5px;line-height:1.05;margin:0 0 24px}.landing-hero-title em{font-style:italic;font-family:Georgia,serif;color:var(--accent)}.landing-hero-sub{font-size:18px;color:var(--ink-soft);max-width:620px;margin:0 auto 32px;line-height:1.55}.landing-hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.landing-hero-mock{margin:60px auto 0;max-width:900px;background:var(--ink);border-radius:20px;padding:14px;box-shadow:0 30px 80px -20px #00000040}.landing-hero-mock-inner{background:var(--bg-card);border-radius:12px;padding:24px;text-align:left;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.mock-card{background:var(--bg);border-radius:10px;padding:14px;border:1px solid var(--line)}.mock-card-num{font-size:22px;font-weight:800}.mock-card-label{font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.6px;margin-top:4px}.mock-card-1{border-top:3px solid var(--green)}.mock-card-2{border-top:3px solid var(--accent)}.mock-card-3{border-top:3px solid #2563eb}.mock-card-4{border-top:3px solid #db2777}.landing-section{max-width:1100px;margin:0 auto;padding:80px 32px}.landing-section-title{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-1px;text-align:center;margin:0 0 14px}.landing-section-title em{font-style:italic;font-family:Georgia,serif;color:var(--accent)}.landing-section-sub{text-align:center;color:var(--ink-soft);font-size:16px;max-width:600px;margin:0 auto 50px}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.landing-feature{background:var(--bg-card);padding:26px;border-radius:14px;border:1px solid var(--line)}.landing-feature-icon{font-size:28px;margin-bottom:10px}.landing-feature-title{font-size:16px;font-weight:700;margin-bottom:6px}.landing-feature-desc{color:var(--ink-soft);font-size:14px;line-height:1.5}.landing-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px;align-items:stretch}.landing-plan{background:var(--bg-card);border-radius:14px;padding:28px 24px;border:2px solid var(--line);display:flex;flex-direction:column;position:relative}.landing-plan.featured{border-color:var(--ink);transform:scale(1.02)}.landing-plan-tag{position:absolute;top:-10px;right:16px;background:var(--ink);color:var(--bg);font-size:10px;font-weight:700;padding:4px 10px;border-radius:8px;letter-spacing:.5px}.landing-plan-name{font-size:13px;font-weight:700;letter-spacing:.8px;color:var(--ink-soft);text-transform:uppercase;margin-bottom:8px}.landing-plan-price{font-size:42px;font-weight:800;letter-spacing:-1.5px;margin-bottom:4px}.landing-plan-price-currency{font-size:18px;vertical-align:top;margin-right:4px;color:var(--ink-soft)}.landing-plan-period{font-size:13px;color:var(--ink-soft);margin-bottom:6px}.landing-plan-save{display:inline-block;font-size:11px;font-weight:700;background:var(--green-soft);color:var(--green);padding:3px 8px;border-radius:8px;margin-bottom:18px}.landing-plan-features{list-style:none;padding:0;margin:0 0 20px;flex:1}.landing-plan-features li{padding:5px 0;font-size:13px;color:var(--ink-soft)}.landing-plan-features li:before{content:"✓ ";color:var(--green);font-weight:700}.landing-cta-final{background:var(--ink);color:var(--bg);border-radius:24px;padding:60px 32px;text-align:center;max-width:1000px;margin:40px auto}.landing-cta-final h2{font-size:clamp(28px,4vw,40px);margin:0 0 12px;font-weight:800;letter-spacing:-1px}.landing-cta-final h2 em{font-style:italic;font-family:Georgia,serif;color:var(--accent)}.landing-cta-final p{color:#ffffffb3;margin:0 0 26px;font-size:16px}.landing-cta-final .btn-landing{background:var(--bg);color:var(--ink);border-color:var(--bg)}.landing-footer{text-align:center;padding:30px 16px 40px;color:var(--ink-soft);font-size:13px;border-top:1px solid var(--line)}.register-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:30px 16px;background:var(--bg)}.register-card{background:var(--bg-card);border-radius:18px;padding:36px;max-width:480px;width:100%;border:1px solid var(--line)}.register-title{font-size:26px;font-weight:800;letter-spacing:-.6px;margin:0 0 6px}.register-sub{color:var(--ink-soft);font-size:14px;margin-bottom:24px}.register-card .form-group label{font-size:13px;font-weight:600}.register-card .form-group input{border:1.5px solid var(--line);background:var(--bg);border-radius:8px}.register-card .form-group input:focus{border-color:var(--ink);background:#fff}.register-success{background:var(--green-soft);border-radius:14px;padding:24px;text-align:center;border:2px solid var(--green)}@media (max-width: 600px){.landing-nav{padding:16px}.landing-nav-links{gap:12px}.landing-nav-links a:not(.btn-landing){display:none}.landing-hero{padding:40px 16px 60px}.landing-hero-mock{padding:8px;margin-top:40px}.landing-hero-mock-inner{padding:14px;gap:8px}.mock-card{padding:10px}.landing-section{padding:60px 16px}.landing-plan.featured{transform:none}}.sa-section{margin-bottom:28px}.sa-section-title{font-size:14px;font-weight:600;margin-bottom:10px;color:var(--color-text)}.tables-admin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media (max-width: 1100px){.tables-admin-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 780px){.tables-admin-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 460px){.tables-admin-grid{grid-template-columns:1fr}}.table-admin-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .15s,transform .15s}.table-admin-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.table-admin-card-top{height:6px;background:var(--color-text-muted)}.table-admin-card.available .table-admin-card-top{background:var(--color-success)}.table-admin-card.occupied .table-admin-card-top{background:var(--color-danger)}.table-admin-card.maintenance .table-admin-card-top{background:var(--color-warning)}.table-admin-card.reserved .table-admin-card-top{background:var(--color-info)}.table-admin-card.disabled .table-admin-card-top,.table-admin-card.cleaning .table-admin-card-top{background:var(--color-text-light)}.table-admin-card-body{padding:16px;flex:1}.table-admin-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.table-admin-card-name{font-weight:700;font-size:15px}.table-admin-card-type-badge{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:2px 7px;border-radius:5px;background:var(--color-bg);color:var(--color-text-muted)}.table-admin-card-type-badge.vip{background:#fef3c7;color:#b45309}.table-admin-card-type-badge.tournament{background:#ede9fe;color:#6d28d9}.table-admin-card-status-row{display:flex;align-items:center;gap:6px;margin:8px 0 4px;font-size:11.5px;font-weight:600}.table-admin-card.available .table-admin-card-status-row{color:var(--color-success)}.table-admin-card.occupied .table-admin-card-status-row{color:var(--color-danger)}.table-admin-card.maintenance .table-admin-card-status-row{color:var(--color-warning)}.table-admin-card.reserved .table-admin-card-status-row{color:var(--color-info)}.table-admin-card-rate{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--color-text-muted);margin-top:6px}.table-admin-card-rate strong{color:var(--color-text);font-weight:700}.table-admin-card-actions{display:flex;gap:6px;padding:10px 16px;border-top:1px solid var(--color-border);background:var(--color-bg)}.table-admin-card-actions .btn{flex:1;padding:6px 8px;font-size:12px}.table-admin-icon-btn{width:30px;height:30px;flex:0 0 auto!important;display:inline-flex;align-items:center;justify-content:center;padding:0!important}.session-running-time{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums;text-align:center;padding:16px;background:#f9fafb;border-radius:var(--radius-md);margin:12px 0}.cart-list{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px}.cart-item{display:flex;justify-content:space-between;padding:6px 4px;border-bottom:1px solid var(--color-border)}.cart-item:last-child{border-bottom:none}.total-summary{background:#f9fafb;padding:14px;border-radius:var(--radius-md);margin-top:14px}.total-summary-row{display:flex;justify-content:space-between;margin-bottom:4px;font-size:13px}.total-summary-total{font-size:18px;font-weight:700;padding-top:8px;border-top:1px solid var(--color-border)}.filters-bar{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:16px;display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.filters-bar-field{display:flex;flex-direction:column;gap:5px;min-width:140px}.filters-bar-field label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--color-text-muted);display:flex;align-items:center;gap:5px}.filters-bar-field select,.filters-bar-field input{padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;background:#fff}.filters-bar-field select:focus,.filters-bar-field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.filters-bar-clear{align-self:flex-end}@media (max-width: 700px){.filters-bar{flex-direction:column;align-items:stretch}.filters-bar-field{min-width:0;width:100%}}.responsive-table .data-table{display:table;width:100%}.responsive-table .list-cards{display:none}@media (max-width: 760px){.responsive-table .data-table{display:none}.responsive-table .list-cards{display:flex;flex-direction:column;gap:10px}}.list-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:14px;cursor:pointer;transition:box-shadow .12s}.list-card:hover{box-shadow:var(--shadow-md)}.list-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.list-card-title{font-weight:700;font-size:14px}.list-card-rows{display:flex;flex-direction:column;gap:5px}.list-card-row{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;color:var(--color-text-muted)}.list-card-row-label{display:flex;align-items:center;gap:6px}.list-card-row strong{color:var(--color-text);font-weight:700}.list-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--color-border)}.list-card-total{font-weight:800;font-size:15px}.session-detail-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:14px}.session-detail-meta{font-size:12.5px;color:var(--color-text-muted);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.session-detail-items{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;margin-top:12px}.session-detail-items-header{padding:10px 14px;font-weight:700;font-size:12.5px;background:var(--color-bg);border-bottom:1px solid var(--color-border)}.session-detail-item-row{display:flex;justify-content:space-between;padding:8px 14px;font-size:13px;border-bottom:1px solid var(--color-border)}.session-detail-item-row:last-child{border-bottom:none}.session-detail-empty{padding:16px 14px;text-align:center;color:var(--color-text-muted);font-size:12.5px}.sale-origin-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--color-bg);color:var(--color-text-muted)}.sale-origin-badge.table{background:var(--color-info-light);color:var(--color-info)}.sale-payment-methods{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.sale-payment-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--color-primary-light);color:var(--color-primary-dark)}.sale-detail-payment-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 0;border-bottom:1px solid var(--color-border);font-size:13px}.sale-detail-payment-row:last-child{border-bottom:none}.sale-detail-payment-row-label{display:flex;align-items:center;gap:7px}.shift-diff-badge{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:700;padding:2px 9px;border-radius:999px}.shift-diff-badge.ok{background:var(--color-success-light);color:var(--color-success)}.shift-diff-badge.over{background:var(--color-info-light);color:var(--color-info)}.shift-diff-badge.under{background:var(--color-danger-light);color:var(--color-danger)}.shift-detail-summary{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}@media (max-width: 480px){.shift-detail-summary{grid-template-columns:1fr}}.shift-detail-summary-item{background:var(--color-bg);border-radius:var(--radius-md);padding:10px 12px}.shift-detail-summary-label{font-size:10.5px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px;font-weight:700;margin-bottom:3px}.shift-detail-summary-value{font-size:15px;font-weight:700}.shift-detail-note{background:var(--color-warning-light);color:#92400e;border-radius:var(--radius-sm);padding:8px 10px;font-size:12.5px;margin-bottom:10px}.reservation-deposit-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;background:var(--color-success-light);color:var(--color-success)}.reservation-actor-note{font-size:11px;color:var(--color-text-muted);margin-top:4px;display:flex;align-items:flex-start;gap:4px}.reservation-actions{display:flex;flex-wrap:wrap;gap:6px}.reservation-actions .btn{padding:5px 9px;font-size:11.5px}.list-card-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--color-border)}.list-card-actions .btn{flex:1;min-width:90px;padding:6px 8px;font-size:11.5px}.product-thumb{width:38px;height:38px;border-radius:8px;object-fit:cover;background:var(--color-bg);flex-shrink:0}.product-thumb-placeholder{width:38px;height:38px;border-radius:8px;background:var(--color-bg);display:flex;align-items:center;justify-content:center;color:var(--color-text-light);flex-shrink:0}.product-name-cell{display:flex;align-items:center;gap:10px}.product-image-upload{display:flex;align-items:center;gap:14px;margin-bottom:16px}.product-image-preview{width:72px;height:72px;border-radius:10px;object-fit:cover;background:var(--color-bg);border:1px solid var(--color-border);flex-shrink:0}.product-image-preview-placeholder{width:72px;height:72px;border-radius:10px;background:var(--color-bg);border:1px dashed var(--color-border-strong);display:flex;align-items:center;justify-content:center;color:var(--color-text-light);flex-shrink:0}.product-image-upload-actions{display:flex;flex-direction:column;gap:6px}.product-image-upload-hint{font-size:11px;color:var(--color-text-muted)}.product-card-row-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600}.categories-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media (max-width: 1100px){.categories-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 780px){.categories-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 460px){.categories-grid{grid-template-columns:1fr}}.category-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:16px;display:flex;flex-direction:column;gap:10px;transition:box-shadow .12s,transform .12s}.category-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.category-card.inactive{opacity:.6}.category-card-icon-wrap{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);color:var(--color-primary)}.category-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.category-card-name{font-weight:700;font-size:15px;margin-top:2px}.category-card-count{font-size:12px;color:var(--color-text-muted);display:flex;align-items:center;gap:5px}.category-card-actions{display:flex;gap:6px;margin-top:auto}.category-card-actions .btn{flex:1;padding:6px 8px;font-size:11.5px}.movement-type-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:2px 9px;border-radius:999px}.movement-type-badge.in{background:var(--color-success-light);color:var(--color-success)}.movement-type-badge.out{background:var(--color-warning-light);color:var(--color-warning)}.movement-type-badge.adjustment{background:var(--color-info-light);color:var(--color-info)}.movement-type-badge.sale{background:var(--color-primary-light);color:var(--color-primary-dark)}.movement-type-badge.return{background:var(--color-info-light);color:var(--color-info)}.movement-qty{font-weight:700}.movement-qty.positive{color:var(--color-success)}.movement-qty.negative{color:var(--color-danger)}.inventory-action-buttons{display:flex;flex-wrap:wrap;gap:8px}@media (max-width: 600px){.inventory-action-buttons{width:100%}.inventory-action-buttons .btn{flex:1}}.pagination-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:14px 4px 4px}.pagination-info{font-size:12.5px;color:var(--color-text-muted)}.pagination-info strong{color:var(--color-text)}.pagination-controls{display:flex;align-items:center;gap:4px}.pagination-btn{min-width:30px;height:30px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--color-border);background:#fff;border-radius:7px;font-size:12.5px;font-weight:600;color:var(--color-text);cursor:pointer;font-family:inherit}.pagination-btn:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-border-strong)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.pagination-ellipsis{color:var(--color-text-muted);padding:0 2px;font-size:12.5px}.pagination-size{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--color-text-muted)}.pagination-size select{padding:5px 8px;border:1px solid var(--color-border);border-radius:7px;font-size:12.5px;font-family:inherit;background:#fff}@media (max-width: 600px){.pagination-bar{flex-direction:column;align-items:stretch}.pagination-controls{justify-content:center}}.scrollable-table-wrap{max-height:560px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg)}.scrollable-table-wrap .table-wrap{border:none;border-radius:0;margin:0}.scrollable-table-wrap .data-table thead th{position:sticky;top:0;z-index:5}.scrollable-table-wrap::-webkit-scrollbar{width:7px}.scrollable-table-wrap::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:4px}.customer-select{position:relative}.customer-select-input-wrap{position:relative;display:flex;align-items:center}.customer-select-input-wrap svg{position:absolute;left:11px;color:var(--color-text-muted);pointer-events:none}.customer-select-input-wrap input{width:100%;box-sizing:border-box;padding:9px 12px 9px 32px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13.5px;font-family:inherit;background:#fff}.customer-select-input-wrap input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.customer-select-chosen{display:flex;align-items:center;gap:9px;padding:8px 10px;border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:var(--color-primary-light)}.customer-select-chosen-icon{width:26px;height:26px;border-radius:50%;background:#fff;color:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.customer-select-chosen-info{flex:1;min-width:0}.customer-select-chosen-name{font-size:13.5px;font-weight:600;color:var(--color-primary-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.customer-select-chosen-phone{font-size:11px;color:var(--color-primary-dark);opacity:.75}.customer-select-clear{width:22px;height:22px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:#fff;color:var(--color-text-muted);cursor:pointer;padding:0}.customer-select-clear:hover{background:var(--color-danger-light);color:var(--color-danger)}.customer-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:240px;overflow-y:auto;z-index:50}.customer-select-option{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:9px 12px;border:none;background:none;text-align:left;font-size:13px;font-family:inherit;cursor:pointer;border-bottom:1px solid var(--color-border)}.customer-select-option:last-child{border-bottom:none}.customer-select-option:hover{background:var(--color-bg)}.customer-select-option-none{color:var(--color-text-muted);font-style:italic}.customer-select-option-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.customer-select-option-phone{font-size:11.5px;color:var(--color-text-muted);flex-shrink:0}.customer-select-empty{padding:14px 12px;text-align:center;color:var(--color-text-muted);font-size:12.5px}.customer-stat-pill{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:700;padding:2px 9px;border-radius:999px}.customer-stat-pill.hours{background:var(--color-info-light);color:var(--color-info)}.customer-stat-pill.points{background:var(--color-warning-light);color:#92400e}.customer-history-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--color-border)}.customer-history-avatar{width:44px;height:44px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;font-size:16px}.customer-history-name{font-weight:700;font-size:15px}.customer-history-phone{font-size:12.5px;color:var(--color-text-muted)}.customer-history-section{margin-bottom:16px}.customer-history-section-title{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:8px}.customer-history-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 0;border-bottom:1px solid var(--color-border);font-size:13px}.customer-history-row:last-child{border-bottom:none}.customer-history-row-meta{font-size:11.5px;color:var(--color-text-muted)}.receipt-row-number{font-weight:700;font-family:var(--font-mono, monospace)}.receipt-table-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--color-info-light);color:var(--color-info)}.profile-header-card{background:linear-gradient(135deg,#1e293b,#334155);border-radius:var(--radius-lg);padding:24px;color:#fff;display:flex;align-items:center;gap:18px;margin-bottom:18px}.profile-header-avatar{width:64px;height:64px;border-radius:50%;background:#ffffff26;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:24px;flex-shrink:0}.profile-header-info{min-width:0}.profile-header-name{font-size:19px;font-weight:700}.profile-header-email{font-size:13px;opacity:.8;margin-top:2px}.profile-header-role{display:inline-flex;align-items:center;gap:5px;margin-top:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:3px 10px;border-radius:999px;background:#ffffff26}.profile-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}@media (max-width: 600px){.profile-info-grid{grid-template-columns:1fr}}.profile-info-item{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px 14px;display:flex;align-items:center;gap:11px}.profile-info-icon-wrap{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);color:var(--color-primary);flex-shrink:0}.profile-info-label{font-size:10.5px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px;font-weight:700}.profile-info-value{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.password-strength-bar{display:flex;gap:4px;margin-top:8px}.password-strength-segment{height:4px;flex:1;border-radius:2px;background:var(--color-border)}.password-strength-segment.weak{background:var(--color-danger)}.password-strength-segment.medium{background:var(--color-warning)}.password-strength-segment.strong{background:var(--color-success)}.password-strength-label{font-size:11px;margin-top:5px;color:var(--color-text-muted)}.password-input-wrap{position:relative}.password-input-wrap input{width:100%;box-sizing:border-box;padding-right:38px}.password-toggle-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:none;background:none;color:var(--color-text-muted);cursor:pointer;padding:0}.password-toggle-btn:hover{color:var(--color-text)}.cashier-shift-banner{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;padding:18px 22px;border-radius:var(--radius-lg);margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;box-shadow:var(--shadow-md)}.cashier-shift-banner.closed{background:linear-gradient(135deg,#dc2626,#991b1b)}.cashier-shift-banner-icon-wrap{width:44px;height:44px;border-radius:12px;background:#ffffff2e;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cashier-shift-banner-content{display:flex;align-items:center;gap:14px;min-width:0}.cashier-shift-banner-title{font-weight:700;font-size:16px;display:flex;align-items:center;gap:6px}.cashier-shift-banner-sub{opacity:.9;font-size:12.5px;margin-top:3px}.cashier-shift-banner-btn{background:#fff;color:#1d4ed8;border:none;font-weight:600;display:inline-flex;align-items:center;gap:6px;flex-shrink:0}.shift-no-open{text-align:center;padding:50px 24px;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border)}.shift-no-open-icon{width:64px;height:64px;border-radius:16px;background:var(--color-bg);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--color-text-muted)}.shift-no-open h3{margin:0 0 6px;font-size:17px}.shift-no-open p{color:var(--color-text-muted);font-size:13.5px;margin:0 0 20px}.shift-actions-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}@media (max-width: 480px){.shift-actions-row{grid-template-columns:1fr}}.shift-action-btn{display:flex;align-items:center;gap:10px;padding:14px 16px;border-radius:var(--radius-md);border:none;cursor:pointer;font-family:inherit;font-weight:600;font-size:13.5px;color:#fff;transition:transform .1s,box-shadow .1s}.shift-action-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.shift-action-btn.in{background:linear-gradient(135deg,#16a34a,#15803d)}.shift-action-btn.out{background:linear-gradient(135deg,#d97706,#b45309)}.shift-action-icon-wrap{width:34px;height:34px;border-radius:9px;background:#fff3;display:flex;align-items:center;justify-content:center;flex-shrink:0}.shift-action-btn-text{text-align:left}.shift-action-btn-title{font-size:13.5px}.shift-action-btn-sub{font-size:11px;opacity:.85;font-weight:400;margin-top:1px}.cash-summary-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:18px 20px;margin-bottom:18px}.cash-summary-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cash-summary-title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14.5px;margin:0}.cash-summary-live-badge{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:700;color:var(--color-success);background:var(--color-success-light);padding:3px 8px;border-radius:999px}.cash-summary-live-dot{width:6px;height:6px;border-radius:50%;background:var(--color-success);animation:cash-live-pulse 1.6s ease-in-out infinite}@keyframes cash-live-pulse{0%,to{opacity:1}50%{opacity:.3}}.cash-summary-rows{display:flex;flex-direction:column}.cash-summary-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--color-border);font-size:13.5px}.cash-summary-row:last-of-type{border-bottom:none}.cash-summary-row-label{display:flex;align-items:center;gap:8px;color:var(--color-text-muted)}.cash-summary-row-label svg{flex-shrink:0}.cash-summary-row-value{font-weight:600}.cash-summary-row-value.positive{color:var(--color-success)}.cash-summary-row-value.negative{color:var(--color-danger)}.cash-summary-total{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:14px;border-top:2px solid var(--color-text)}.cash-summary-total-label{font-weight:700;font-size:14px}.cash-summary-total-value{font-weight:800;font-size:22px;color:var(--color-primary)}.movements-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.movements-card-header{padding:16px 20px;border-bottom:1px solid var(--color-border);font-weight:700;font-size:14.5px;display:flex;align-items:center;gap:8px}.movement-row{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--color-border)}.movement-row:last-child{border-bottom:none}.movement-icon-wrap{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.movement-icon-wrap.in{background:var(--color-success-light);color:var(--color-success)}.movement-icon-wrap.out{background:var(--color-warning-light);color:var(--color-warning)}.movement-info{flex:1;min-width:0}.movement-reason{font-size:13.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.movement-date{font-size:11.5px;color:var(--color-text-muted);margin-top:1px}.movement-amount{font-weight:700;font-size:14px;flex-shrink:0}.movement-amount.in{color:var(--color-success)}.movement-amount.out{color:var(--color-warning)}.movements-empty{text-align:center;padding:36px 20px;color:var(--color-text-muted);font-size:13px}.close-shift-preview{background:var(--color-bg);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:16px}.close-shift-preview-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;color:var(--color-text-muted)}.close-shift-preview-row strong{color:var(--color-text)}.close-shift-preview-divider{border-top:1px solid var(--color-border);margin:8px 0}.close-shift-diff-row{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;font-weight:700;margin-top:6px}.close-shift-diff-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px}.close-shift-diff-badge.ok{background:var(--color-success-light);color:var(--color-success)}.close-shift-diff-badge.over{background:var(--color-info-light);color:var(--color-info)}.close-shift-diff-badge.under{background:var(--color-danger-light);color:var(--color-danger)}.shift-closed-result{text-align:center;padding:30px 24px;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border)}.shift-closed-icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}.shift-closed-icon.ok{background:var(--color-success-light);color:var(--color-success)}.shift-closed-icon.over{background:var(--color-info-light);color:var(--color-info)}.shift-closed-icon.under{background:var(--color-danger-light);color:var(--color-danger)}.shift-closed-amount{font-size:28px;font-weight:800;margin:4px 0}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.product-card{background:#fff;border-radius:var(--radius-md);padding:12px;border:1px solid var(--color-border);cursor:pointer;text-align:center;transition:all .1s}.product-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.product-card.out{opacity:.5;cursor:not-allowed}.product-card-name{font-weight:600;font-size:13px;margin-bottom:4px}.product-card-price{color:var(--color-primary);font-weight:700;font-size:14px}.product-card-stock{font-size:10px;color:var(--color-text-muted);margin-top:4px}.session-panel{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 900px){.session-panel{grid-template-columns:1fr}}.quicksale-layout{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:16px;align-items:start}@media (max-width: 1100px){.quicksale-layout{grid-template-columns:1fr 1fr}.quicksale-col-payment{grid-column:1 / -1}}@media (max-width: 700px){.quicksale-layout{grid-template-columns:1fr}.quicksale-col-payment{grid-column:auto}}.quicksale-col{display:flex;flex-direction:column;min-height:0;height:100%}.quicksale-card{background:#fff;border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;min-height:0;overflow:hidden;height:640px;max-height:calc(100vh - 96px)}@media (min-width: 701px){.quicksale-card{position:sticky;top:76px}}@media (max-width: 1100px) and (min-width: 701px){.quicksale-card{height:520px}}@media (max-width: 700px){.quicksale-card{height:auto;max-height:70vh;position:static}}.quicksale-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 16px;border-bottom:1px solid var(--color-border);flex-shrink:0}.quicksale-card-title{margin:0;font-size:14.5px;font-weight:700;display:flex;align-items:center;gap:8px}.quicksale-card-body{padding:14px 16px;overflow-y:auto;overflow-x:hidden;min-height:0;flex:1;display:flex;flex-direction:column}.quicksale-card-body::-webkit-scrollbar{width:5px}.quicksale-card-body::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:4px}.quicksale-search{position:relative;padding:12px 14px 0;flex-shrink:0}.quicksale-search svg{position:absolute;left:26px;top:22px;color:var(--color-text-muted);pointer-events:none}.quicksale-search input{display:block;width:100%;box-sizing:border-box;padding:9px 12px 9px 36px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13.5px;font-family:inherit;background:#fff;color:var(--color-text)}.quicksale-search input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.quicksale-products-body{padding:12px 14px 14px;overflow-y:auto;overflow-x:hidden}.quicksale-cart-count{background:var(--color-primary-light);color:var(--color-primary-dark);font-size:11px;font-weight:700;padding:2px 9px;border-radius:999px}.quicksale-clear-btn{display:inline-flex;align-items:center;gap:4px;flex-shrink:0}.quicksale-cart-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 2px;border-bottom:1px solid var(--color-border)}.quicksale-cart-item:last-child{border-bottom:none}.quicksale-cart-item-info{flex:1;min-width:0}.quicksale-cart-item-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quicksale-cart-item-price{font-size:11px;color:var(--color-text-muted)}.quicksale-qty-controls{display:flex;align-items:center;gap:6px;flex-shrink:0}.quicksale-qty-btn{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid var(--color-border);background:#fff;cursor:pointer;padding:0;flex-shrink:0}.quicksale-qty-btn:hover{background:var(--color-bg)}.quicksale-qty-value{min-width:18px;text-align:center;font-weight:600;font-size:13px;flex-shrink:0}.quicksale-item-total{font-size:13px;font-weight:700;min-width:54px;text-align:right;flex-shrink:0}.quicksale-remove-btn{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;border:none;background:var(--color-danger-light);color:var(--color-danger);cursor:pointer;flex-shrink:0;padding:0}.quicksale-remove-btn:hover{background:var(--color-danger);color:#fff}.quicksale-cart-empty{text-align:center;padding:30px 10px;color:var(--color-text-muted);font-size:13px}.quicksale-payment-section+.quicksale-payment-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border)}.quicksale-payment-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-muted);margin-bottom:8px;display:flex;align-items:center;gap:5px}.quicksale-input-icon-group select,.quicksale-input-icon-group input{width:100%;box-sizing:border-box;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13.5px;font-family:inherit;background:#fff;color:var(--color-text)}.quicksale-input-icon-group select:focus,.quicksale-input-icon-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.quicksale-empty-note{text-align:center;padding:36px 14px;color:var(--color-text-muted);font-size:13px;margin:auto;grid-column:1 / -1}.quicksale-footer{padding:14px 16px;border-top:1px solid var(--color-border);flex-shrink:0}.btn-icon-inline{display:inline-flex;align-items:center;justify-content:center;gap:8px}.payment-widget{width:100%}.payment-mode-toggle{display:flex;background:var(--color-bg);border-radius:var(--radius-md);padding:3px;gap:3px;margin-bottom:12px}.payment-mode-btn{flex:1;padding:8px 10px;border:none;background:transparent;border-radius:6px;font-size:12.5px;font-weight:600;color:var(--color-text-muted);cursor:pointer;font-family:inherit;transition:all .15s}.payment-mode-btn.active{background:#fff;color:var(--color-text);box-shadow:var(--shadow-sm)}.payment-mode-btn:hover:not(.active){color:var(--color-text)}.payment-method-chips{display:grid;grid-template-columns:1fr 1fr;gap:8px}.payment-chip{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 8px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:#fff;color:var(--color-text-muted);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .12s}.payment-chip:hover{border-color:var(--color-border-strong)}.payment-chip.active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary-dark)}.payment-entries-list{display:flex;flex-direction:column;gap:8px}.payment-entry-row{display:flex;align-items:center;gap:6px}.payment-entry-method{position:relative;flex:1.2;display:flex;align-items:center}.payment-entry-icon{position:absolute;left:10px;color:var(--color-text-muted);pointer-events:none;z-index:1}.payment-entry-method select{width:100%;padding:8px 10px 8px 32px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;background:#fff;font-family:inherit}.payment-entry-amount{flex:1;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;width:0;min-width:0}.payment-entry-remove{width:30px;height:30px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:6px;background:var(--color-danger-light);color:var(--color-danger);cursor:pointer;padding:0}.payment-entry-remove:hover{background:var(--color-danger);color:#fff}.payment-entry-remove-spacer{width:30px;flex-shrink:0}.payment-add-method-btn{display:inline-flex;align-items:center;gap:6px;margin-top:10px;padding:7px 12px;border:1px dashed var(--color-border-strong);border-radius:var(--radius-sm);background:transparent;color:var(--color-primary);font-size:12.5px;font-weight:600;cursor:pointer;font-family:inherit}.payment-add-method-btn:hover{background:var(--color-primary-light)}.payment-mixed-summary{margin-top:14px;padding:12px;border-radius:var(--radius-md);background:var(--color-bg)}.payment-mixed-summary.ok{background:var(--color-success-light)}.payment-mixed-summary-row{display:flex;justify-content:space-between;font-size:12.5px;color:var(--color-text-muted);padding:2px 0}.payment-mixed-summary-row strong{color:var(--color-text)}.payment-mixed-summary-status{display:flex;align-items:center;gap:5px;margin-top:6px;padding-top:8px;border-top:1px solid rgba(0,0,0,.06);font-size:13px;font-weight:700;color:var(--color-danger)}.payment-mixed-summary.ok .payment-mixed-summary-status{color:var(--color-success)}.shift-report-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}@media (max-width: 900px){.shift-report-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.shift-report-grid{grid-template-columns:1fr}}.shift-report-hero{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border-radius:var(--radius-lg);padding:20px 22px;margin-bottom:18px;box-shadow:var(--shadow-md)}.shift-report-hero-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:4px}.shift-report-hero-label{font-size:12px;opacity:.85;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.shift-report-hero-value{font-size:30px;font-weight:800;margin-top:2px}.shift-report-hero-sub{font-size:12.5px;opacity:.9;margin-top:6px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.payment-method-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--color-border)}.payment-method-row:last-child{border-bottom:none}.payment-method-icon-wrap{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--color-primary-light);color:var(--color-primary)}.payment-method-info{flex:1}.payment-method-name{font-size:13.5px;font-weight:600}.payment-method-amount{font-weight:700;font-size:14.5px}.tables-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}@media (max-width: 1200px){.tables-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 980px){.tables-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 700px){.tables-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 420px){.tables-grid{grid-template-columns:1fr}}.table-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);cursor:pointer;transition:transform .12s,box-shadow .12s}.table-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.table-card-top{height:5px;background:var(--color-text-muted)}.table-card.available .table-card-top{background:var(--color-success)}.table-card.occupied .table-card-top{background:var(--color-danger)}.table-card.maintenance .table-card-top{background:var(--color-warning)}.table-card.reserved .table-card-top{background:var(--color-info)}.table-card-body{padding:14px}.table-card-name{font-weight:700;font-size:15px}.table-card-type{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.4px;margin-top:1px}.table-card-status-pill{display:inline-flex;align-items:center;gap:5px;margin-top:9px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px}.table-card.available .table-card-status-pill{background:var(--color-success-light);color:var(--color-success)}.table-card.occupied .table-card-status-pill{background:var(--color-danger-light);color:var(--color-danger)}.table-card.maintenance .table-card-status-pill{background:var(--color-warning-light);color:var(--color-warning)}.table-card.reserved .table-card-status-pill{background:var(--color-info-light);color:var(--color-info)}.table-card-rate{display:flex;align-items:center;gap:4px;font-size:11.5px;color:var(--color-text-muted);margin-top:8px}.table-card-timer{display:flex;align-items:center;gap:5px;margin-top:9px;font-size:12.5px;font-weight:700;color:var(--color-danger);font-variant-numeric:tabular-nums}.table-card-reservation-note{display:flex;align-items:center;gap:5px;margin-top:9px;font-size:11px;font-weight:600;padding-top:8px;border-top:1px solid var(--color-border)}.table-card-reservation-note.urgent{color:var(--color-danger)}.table-card-reservation-note.warning{color:var(--color-warning)}.table-card-reservation-note.info{color:var(--color-text-muted);font-weight:500}.table-card.reservation-urgent{animation:reservation-pulse 1.4s ease-in-out infinite}.table-card.reservation-warning{box-shadow:0 0 0 2px var(--color-warning) inset}@keyframes reservation-pulse{0%,to{box-shadow:0 0 0 3px var(--color-danger) inset}50%{box-shadow:0 0 0 3px var(--color-danger) inset,0 0 12px 2px #dc262673}}.table-session-layout{display:grid;grid-template-columns:1.1fr 1fr;gap:18px;align-items:start}@media (max-width: 760px){.table-session-layout{grid-template-columns:1fr}}.table-session-products-col{display:flex;flex-direction:column;max-height:560px}@media (max-width: 760px){.table-session-products-col{max-height:none}}.table-session-timer-card{text-align:center;padding:18px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#1e293b,#0f172a);color:#fff;margin-bottom:14px}.table-session-timer-card.paused{background:linear-gradient(135deg,#78716c,#57534e)}.table-session-timer-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;opacity:.85;margin-bottom:4px}.table-session-timer-value{font-size:32px;font-weight:800;font-variant-numeric:tabular-nums}.table-session-bill-card{background:var(--color-bg);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:14px}.table-session-bill-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;font-size:13px;color:var(--color-text-muted)}.table-session-bill-row-label{display:flex;align-items:center;gap:7px}.table-session-bill-row.success{color:var(--color-success)}.table-session-bill-total{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:10px;border-top:2px solid var(--color-text);font-weight:800;font-size:15px}.table-session-items-card{border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:14px;overflow:hidden;display:flex;flex-direction:column}.table-session-items-header{padding:10px 14px;font-weight:700;font-size:13px;background:var(--color-bg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:7px;flex-shrink:0}.table-session-items-header-title{display:flex;align-items:center;gap:7px}.table-session-items-count{font-size:10.5px;font-weight:700;color:var(--color-text-muted);background:#fff;padding:2px 8px;border-radius:999px}.table-session-items-list{max-height:230px;overflow-y:auto}.table-session-items-list::-webkit-scrollbar{width:5px}.table-session-items-list::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:4px}.table-session-item-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 14px;border-bottom:1px solid var(--color-border);font-size:13px}.table-session-item-row:last-child{border-bottom:none}.table-session-item-text{flex:1;min-width:0}.table-session-item-remove{width:24px;height:24px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:6px;background:var(--color-danger-light);color:var(--color-danger);cursor:pointer;padding:0}.table-session-item-remove:hover{background:var(--color-danger);color:#fff}.table-session-items-empty{padding:20px 14px;text-align:center;color:var(--color-text-muted);font-size:12.5px}.table-session-actions{display:flex;flex-wrap:wrap;gap:8px}.table-session-actions .btn{flex:1;min-width:140px}.table-session-products-header{display:flex;align-items:center;gap:7px;font-weight:700;font-size:13.5px;margin-bottom:10px;flex-shrink:0}.table-session-search{position:relative;margin-bottom:10px;flex-shrink:0}.table-session-search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.table-session-search input{width:100%;box-sizing:border-box;padding:8px 10px 8px 32px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;background:#fff}.table-session-search input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.table-session-category-filter{display:flex;gap:6px;overflow-x:auto;padding-bottom:8px;margin-bottom:4px;flex-shrink:0}.table-session-category-filter::-webkit-scrollbar{height:4px}.table-session-category-chip{flex-shrink:0;padding:6px 12px;border-radius:999px;border:1px solid var(--color-border);background:#fff;font-size:12px;font-weight:600;color:var(--color-text-muted);cursor:pointer;white-space:nowrap;font-family:inherit}.table-session-category-chip:hover{border-color:var(--color-border-strong)}.table-session-category-chip.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.table-session-top-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-muted);margin-bottom:8px;flex-shrink:0}.table-session-top-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--color-border);flex-shrink:0}@media (max-width: 480px){.table-session-top-grid{grid-template-columns:repeat(2,1fr)}}.product-card.top-pick{border-color:var(--color-warning);background:#fffbeb;position:relative}.product-card-badge{position:absolute;top:-7px;right:-6px;background:var(--color-warning);color:#fff;border-radius:999px;width:18px;height:18px;display:flex;align-items:center;justify-content:center}.table-session-products-body{flex:1;min-height:120px;overflow-y:auto;padding-right:4px}.table-session-products-body::-webkit-scrollbar{width:5px}.table-session-products-body::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:4px}.partial-checklist{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.partial-checklist-header{padding:10px 14px;font-weight:700;font-size:13px;background:var(--color-bg);border-bottom:1px solid var(--color-border)}.partial-checklist-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--color-border);cursor:pointer}.partial-checklist-row:last-child{border-bottom:none}.partial-checklist-row:hover{background:var(--color-bg)}.partial-checklist-row input[type=checkbox]{width:16px;height:16px;flex-shrink:0;accent-color:var(--color-primary)}.partial-checklist-row-label{flex:1;font-size:13px}.partial-checklist-row-amount{font-weight:700;font-size:13px}.partial-checklist-empty{padding:18px 14px;text-align:center;color:var(--color-text-muted);font-size:12.5px}:root{--color-bg: #f4f6fa;--color-bg-card: #ffffff;--color-bg-dark: #1f2533;--color-bg-darker: #161b27;--color-text: #1f2533;--color-text-muted: #5b6478;--color-text-light: #8b94a8;--color-text-on-dark: #e5e9f2;--color-primary: #2563eb;--color-primary-dark: #1d4ed8;--color-primary-light: #dbeafe;--color-success: #16a34a;--color-success-light: #dcfce7;--color-warning: #d97706;--color-warning-light: #fef3c7;--color-danger: #dc2626;--color-danger-light: #fee2e2;--color-info: #0891b2;--color-info-light: #cffafe;--color-border: #e2e6ee;--color-border-strong: #cbd2e0;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 2px 8px rgba(0,0,0,.06);--shadow-lg: 0 8px 24px rgba(0,0,0,.1);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--sidebar-w: 240px;--topbar-h: 60px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;color:var(--color-text);background:var(--color-bg)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:1px solid transparent;border-radius:var(--radius-sm);font-size:14px;font-weight:500;background:#fff;color:var(--color-text);border-color:var(--color-border);transition:all .15s}.btn:hover:not(:disabled){background:#f9fafb;border-color:var(--color-border-strong)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn-warning{background:var(--color-warning);color:#fff;border-color:var(--color-warning)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-ghost{background:transparent;border-color:transparent}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:11px 20px;font-size:15px}.btn-block{width:100%}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;font-size:13px;color:var(--color-text)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:#fff;color:var(--color-text);transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 600px){.form-row{grid-template-columns:1fr}}.form-hint{font-size:12px;color:var(--color-text-muted);margin-top:4px}.form-error{font-size:12px;color:var(--color-danger);margin-top:4px}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius-md);overflow:hidden}.data-table thead{background:#f6f8fc}.data-table th,.data-table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--color-border);font-size:13px}.data-table th{font-weight:600;color:var(--color-text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.4px}.data-table tbody tr:hover{background:#f9fafb}.data-table tbody tr:last-child td{border-bottom:none}.table-wrap{overflow-x:auto;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.card{background:var(--color-bg-card);border-radius:var(--radius-md);padding:18px;box-shadow:var(--shadow-sm)}.card-title{font-size:15px;font-weight:600;margin:0 0 14px}.card-grid{display:grid;gap:14px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media (max-width: 1200px){.stat-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 860px){.stat-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 420px){.stat-grid{grid-template-columns:1fr}}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);border-left:3px solid var(--color-primary);display:flex;align-items:flex-start;gap:12px;transition:box-shadow .15s,transform .15s}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card-icon-wrap{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--color-primary-light);color:var(--color-primary)}.stat-card-body{flex:1;min-width:0}.stat-card-label{font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px;font-weight:600}.stat-card-value{font-size:23px;font-weight:800;color:var(--color-text);line-height:1.1}.stat-card-sub{font-size:11.5px;color:var(--color-text-muted);margin-top:4px}.stat-card.success{border-left-color:var(--color-success)}.stat-card.success .stat-card-icon-wrap{background:var(--color-success-light);color:var(--color-success)}.stat-card.warning{border-left-color:var(--color-warning)}.stat-card.warning .stat-card-icon-wrap{background:var(--color-warning-light);color:var(--color-warning)}.stat-card.danger{border-left-color:var(--color-danger)}.stat-card.danger .stat-card-icon-wrap{background:var(--color-danger-light);color:var(--color-danger)}.stat-card.info{border-left-color:var(--color-info)}.stat-card.info .stat-card-icon-wrap{background:var(--color-info-light);color:var(--color-info)}@media (max-width: 600px){.stat-card{padding:13px 14px;gap:9px}.stat-card-icon-wrap{width:32px;height:32px;border-radius:8px}.stat-card-value{font-size:19px}}.quick-actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media (max-width: 860px){.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 560px){.quick-actions-grid{grid-template-columns:1fr}}.quick-action-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:18px;display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit;transition:box-shadow .15s,transform .15s,border-color .15s}.quick-action-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--color-primary);text-decoration:none}.quick-action-card>div:last-child{min-width:0;flex:1}.quick-action-icon-wrap{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--color-primary-light);color:var(--color-primary)}.quick-action-title{font-weight:700;font-size:14px;margin-bottom:2px}.quick-action-desc{font-size:12px;color:var(--color-text-muted)}.dash-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.dash-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:16px 18px;border-bottom:1px solid var(--color-border)}.dash-card-title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14.5px;margin:0}.dash-card-body{padding:8px 18px 14px}.dash-card-empty{text-align:center;padding:28px 14px;color:var(--color-text-muted);font-size:13px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 900px){.two-col{grid-template-columns:1fr}}.badge{display:inline-block;padding:3px 9px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;background:#f1f3f8;color:var(--color-text-muted)}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger)}.badge-info{background:var(--color-info-light);color:var(--color-info)}.badge-primary{background:var(--color-primary-light);color:var(--color-primary)}.page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:18px}.page-title{font-size:22px;margin:0;font-weight:700}.page-subtitle{font-size:13px;color:var(--color-text-muted);margin-top:2px}.alert{padding:12px 16px;border-radius:var(--radius-md);margin-bottom:14px;font-size:13px}.alert-info{background:var(--color-info-light);color:var(--color-info)}.alert-warning{background:var(--color-warning-light);color:var(--color-warning)}.alert-danger{background:var(--color-danger-light);color:var(--color-danger)}.alert-success{background:var(--color-success-light);color:var(--color-success)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.modal-header{padding:16px 20px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-title{margin:0;font-size:16px;font-weight:600}.modal-close-btn{width:30px;height:30px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;padding:0;border-radius:8px;border:none;background:var(--color-bg);color:var(--color-text-muted);cursor:pointer;transition:background .12s,color .12s}.modal-close-btn:hover{background:var(--color-danger-light);color:var(--color-danger)}.modal-body{padding:20px;overflow-y:auto;flex:1;min-height:0}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:4px}.modal-footer{padding:14px 20px;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;min-height:200px;flex-direction:column;gap:10px;color:var(--color-text-muted)}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-gap{display:flex;gap:10px}.flex-wrap{flex-wrap:wrap}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.text-muted{color:var(--color-text-muted)}.text-right{text-align:right}.text-center{text-align:center}.text-small{font-size:12px}@media print{body *{visibility:hidden}.printable,.printable *{visibility:visible}.printable{position:absolute;left:0;top:0;width:100%}.no-print{display:none!important}}
