:root{--primary:#2563eb;--primary-light:rgba(37,99,235,.12);--primary-dark:#1d4ed8;--success:#10b981;--success-light:rgba(16,185,129,.12);--danger:#dc2626;--danger-light:rgba(239,68,68,.1);--warning:#f59e0b;--warning-light:rgba(245,158,11,.12);--dark:#1f2937;--light:#f3f4f6;--surface:#fff;--border:#e5e7eb;--text-muted:#6b7280;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--shadow-sm:0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-md:0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.06);--shadow-lg:0 12px 32px rgba(0,0,0,.12), 0 4px 8px rgba(0,0,0,.08);--font-mono:"SF Mono", "Fira Code", "Cascadia Code", "Consolas", monospace;--touch-min:44px;--text:#1f2937;--btn-neutral:#374151;--btn-neutral-text:#fff}[data-theme=dark]{--primary:#3b82f6;--primary-light:rgba(59,130,246,.15);--primary-dark:#2563eb;--success:#34d399;--success-light:rgba(52,211,153,.15);--danger:#b91c1c;--danger-light:rgba(248,113,113,.12);--warning:#fbbf24;--warning-light:rgba(251,191,36,.15);--dark:#f3f4f6;--light:#1e2433;--surface:#151a27;--border:#2d3548;--text-muted:#9ca3af;--text:#e5e7eb;--btn-neutral:#4b5563;--btn-neutral-text:#fff;--shadow-sm:0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.2);--shadow-md:0 4px 12px rgba(0,0,0,.3), 0 2px 4px rgba(0,0,0,.2);--shadow-lg:0 12px 32px rgba(0,0,0,.4), 0 4px 8px rgba(0,0,0,.3)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}body{background:var(--light);color:var(--text);min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5}input,select,button,textarea{font:inherit;-webkit-tap-highlight-color:transparent}input,select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);padding:.625rem .75rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}input:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}button{border-radius:var(--radius-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;color:var(--text);border:none;padding:.5rem 1rem;font-size:1rem;font-weight:600;transition:all .15s}button:hover{opacity:.92}button:active{transform:scale(.97)}button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.navbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;box-shadow:var(--shadow-sm);padding:0;position:sticky;top:0}.nav-container{padding:0 var(--space-lg);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.sitelogo{flex-shrink:0;height:2rem;margin:.75rem 0}.nav-links{scrollbar-width:none;gap:.25rem;display:flex;overflow-x:auto}.nav-links::-webkit-scrollbar{display:none}.nav-links a{color:var(--text);border-radius:var(--radius-sm);white-space:nowrap;padding:.75rem 1rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.nav-links a:hover{color:var(--primary);background:var(--primary-light)}.nav-links a[aria-current=page]{color:var(--primary);background:var(--primary-light);font-weight:700}.dark-mode-toggle{color:var(--text);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:.5rem;transition:background .15s,color .15s;display:flex}.dark-mode-toggle:hover{background:var(--primary-light);color:var(--primary);opacity:1}.container{max-width:1400px;margin:var(--space-md) auto;padding:0 var(--space-md)}.page-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.sale-page{background:var(--surface);border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-md)}.sale-grid{gap:var(--space-lg);grid-template-columns:5fr 3fr;min-height:calc(100dvh - 6rem);display:grid}.category-tabs{gap:var(--space-xs);margin-bottom:var(--space-md);scrollbar-width:none;padding-bottom:var(--space-xs);display:flex;overflow-x:auto}.category-tabs::-webkit-scrollbar{display:none}.category-tabs button{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-lg);cursor:pointer;white-space:nowrap;padding:.5rem 1.25rem;font-size:.9rem;font-weight:500;transition:all .15s}.category-tabs button:hover{border-color:var(--primary);color:var(--primary)}.category-tabs button.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 6px rgba(37,99,235,.3)}.items-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.item-card{padding:var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);cursor:pointer;box-shadow:var(--shadow-sm);min-height:var(--touch-min);flex-direction:column;justify-content:center;transition:all .2s;display:flex;position:relative;overflow:hidden}.item-card.item-card-has-image{aspect-ratio:1;justify-content:flex-end;padding:0}.item-card-img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.item-card-overlay{z-index:1;position:relative}.item-card-has-image .item-card-overlay{flex-direction:column;justify-content:flex-end;height:100%;display:flex}.item-price-badge{top:var(--space-xs);right:var(--space-xs);color:#fff;border-radius:var(--radius-sm);z-index:2;-webkit-backdrop-filter:blur(4px);background:rgba(0,0,0,.6);padding:.2rem .5rem;font-size:1rem;font-weight:700;position:absolute}.item-name-badge{color:#fff;-webkit-backdrop-filter:blur(4px);border-radius:0 0 var(--radius-md) var(--radius-md);background:rgba(0,0,0,.55);padding:.35rem .5rem;font-size:clamp(.75rem,1.6vw,.9rem);font-weight:600;line-height:1.2}.item-card:not(.item-card-has-image) .item-price-badge{color:var(--primary);-webkit-backdrop-filter:none;background:0 0;padding:0;font-size:1.05rem;position:static}.item-card:not(.item-card-has-image) .item-name-badge{color:var(--text);-webkit-backdrop-filter:none;margin-bottom:var(--space-xs);word-wrap:break-word;overflow-wrap:break-word;-webkit-line-clamp:2;background:0 0;border-radius:0;-webkit-box-orient:vertical;order:-1;padding:0;font-size:clamp(.8rem,1.8vw,.95rem);display:-webkit-box;overflow:hidden}.item-card:hover:not(:disabled){border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.item-card:active:not(:disabled){box-shadow:var(--shadow-sm);transform:scale(.97)}.item-card:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.4)}.out-of-stock{top:var(--space-sm);left:var(--space-sm);background:var(--danger);color:#fff;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.03em;z-index:2;padding:.15rem .5rem;font-size:.7rem;font-weight:600;position:absolute}.transaction-section{background:var(--light);padding:var(--space-md);border-radius:var(--radius-md);flex-direction:column;display:flex}.transaction-header{padding:var(--space-sm);background:var(--surface);border-radius:var(--radius-sm);margin-bottom:var(--space-sm)}.start-transaction{gap:var(--space-md);flex-direction:column;display:flex}.last-change-display{color:var(--text);padding:var(--space-sm) var(--space-md);background:var(--success-light);border-radius:var(--radius-sm);border-left:3px solid var(--success);font-size:1.15rem}.open-transactions-list{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);max-height:300px;overflow-y:auto}.open-transaction-item{padding:.75rem var(--space-md);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.open-transaction-item:last-child{border-bottom:none}.transaction-items{max-height:min(300px,30vh);margin-bottom:var(--space-sm);overflow-y:auto}.transaction-total{padding:var(--space-md);background:var(--surface);border-radius:var(--radius-sm);margin:var(--space-sm) 0;box-shadow:var(--shadow-sm);justify-content:space-between;font-size:1.35rem;font-weight:700;display:flex}.payment-change-wrapper{gap:var(--space-sm);margin:var(--space-sm) 0;display:flex}.payment-section,.change-section{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--surface);border-radius:var(--radius-sm);flex:1;font-size:1.15rem;display:flex}.payment-input,.change-input{text-align:right;font-size:1.3rem;font-family:var(--font-mono);background:0 0;border-width:0;width:100%;max-width:8rem}.payment-input:focus,.change-input:focus{box-shadow:none}.change-display{background:var(--success);color:#fff;padding:var(--space-md);border-radius:var(--radius-sm);text-align:center;margin-top:var(--space-sm);font-size:1.1rem}.keypad{gap:var(--space-xs);margin-top:var(--space-xs);grid-template-columns:repeat(3,1fr);display:grid}.keypad-btn{font-size:1.4rem;font-family:var(--font-mono);border-radius:var(--radius-sm);min-height:var(--touch-min);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:.75rem}.keypad-btn:active{background:var(--light);box-shadow:none}.action-buttons{gap:var(--space-sm);margin-top:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.action-button{border-radius:var(--radius-md);min-height:var(--touch-min);text-transform:uppercase;letter-spacing:.03em;padding:.85rem;font-size:1.25rem;font-weight:700}.action-button.cancel{background:var(--danger);color:#fff}.action-button.pause{background:var(--btn-neutral);color:var(--btn-neutral-text)}.action-button.sale{background:var(--success);color:#fff}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius-sm);padding:.75rem 1.25rem}.btn-primary-small{background:var(--primary);color:#fff;border-radius:var(--radius-sm);margin-left:auto;padding:.375rem .75rem;font-size:.875rem}.btn-secondary{background:var(--btn-neutral);color:var(--btn-neutral-text);border-radius:var(--radius-sm);padding:.75rem 1.25rem}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-small{margin:0 var(--space-xs);background:var(--btn-neutral);color:var(--btn-neutral-text);padding:.375rem .75rem;font-size:.875rem}.btn-small.btn-danger{background:var(--danger);color:#fff}.btn-remove{border-radius:var(--radius-sm);background:var(--danger);color:#fff;cursor:pointer;border:none;justify-content:center;align-items:center;width:2.5em;height:2em;font-size:1.1rem;font-weight:700;display:inline-flex}.data-table{background:var(--surface);border-radius:var(--radius-md);border-collapse:collapse;width:100%;box-shadow:var(--shadow-sm);overflow:hidden}.data-table th{background:var(--light);text-align:left;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);white-space:nowrap;padding:.75rem 1rem;font-size:.85rem;font-weight:700}.data-table td{border-top:1px solid var(--border);padding:.625rem 1rem}.data-table tbody tr:nth-child(2n){background:rgba(0,0,0,.016)}.data-table tbody tr:hover{background:var(--primary-light)}.data-table-actions{text-align:right;white-space:nowrap}.customer-table{background:var(--surface);border-radius:var(--radius-sm);border-collapse:collapse;width:100%;overflow:hidden}.customer-table td{padding:var(--space-xs) var(--space-sm)}.customer-table-actions{text-align:right}.status-open{background-color:rgba(34,197,94,.08)}.status-closed{background-color:rgba(156,163,175,.08)}.status-cancelled{background-color:rgba(239,68,68,.08)}.row-selected{outline:2px solid var(--primary);outline-offset:-2px}.transaction-detail-row td{border-top:none!important;padding:0!important}.transaction-detail-panel{padding:var(--space-md) var(--space-lg);background:var(--light);border-top:1px solid var(--border)}.detail-items-table{border-collapse:collapse;width:100%;margin:var(--space-sm) 0;font-size:.9rem}.detail-items-table th{text-align:left;padding:var(--space-xs) var(--space-sm);text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);border-bottom:1px solid var(--border);font-size:.75rem}.detail-items-table td{padding:var(--space-xs) var(--space-sm);border-bottom:1px solid var(--border)}.detail-summary{gap:var(--space-lg);margin-top:var(--space-sm);padding-top:var(--space-sm);font-size:.95rem;display:flex}.detail-field{margin-bottom:var(--space-xs)}.table-footer{background:var(--light);font-weight:700}.edit-form{background:var(--surface);padding:var(--space-lg);border-radius:var(--radius-md);margin-bottom:var(--space-xl);border:2px solid var(--primary);box-shadow:var(--shadow-md)}.form-grid{gap:var(--space-md);margin-bottom:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.form-group{flex-direction:column;display:flex}.form-group label{margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);font-size:.8rem;font-weight:600}.form-actions{gap:var(--space-md);display:flex}.reports-page{background:var(--surface);border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-md)}.report-controls{margin-bottom:var(--space-xl)}.report-type-selector{gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.date-range-selector{gap:var(--space-md);padding:var(--space-md);background:var(--light);border-radius:var(--radius-sm);flex-wrap:wrap;align-items:flex-end;display:flex}.summary-cards{gap:var(--space-md);margin:var(--space-xl) 0;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.summary-card{color:#fff;padding:var(--space-lg);border-radius:var(--radius-md);text-align:center;box-shadow:var(--shadow-sm);background:linear-gradient(135deg, var(--primary), var(--primary-dark))}.summary-card:nth-child(2){background:linear-gradient(135deg,#10b981,#059669)}.summary-card:nth-child(3){background:linear-gradient(135deg,#f59e0b,#d97706)}.summary-card:nth-child(4){background:linear-gradient(135deg,#1f2937,#111827)}.summary-card h4{margin:0 0 var(--space-sm) 0;opacity:.85;text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.summary-value{font-size:1.8rem;font-weight:800;font-family:var(--font-mono)}.report-header{background:var(--light);padding:var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-md)}.report-header h3{margin:0 0 var(--space-xs) 0}.report-highlights{gap:var(--space-xl);padding:var(--space-md);background:var(--light);border-radius:var(--radius-sm);margin-bottom:var(--space-xl);display:flex}.highlight{flex:1}.loading{text-align:center;padding:var(--space-xl);color:var(--primary);font-weight:500}.error-message{background:var(--danger-light);color:var(--danger);padding:var(--space-md);border-radius:var(--radius-sm);margin:var(--space-md) 0;border-left:4px solid var(--danger);font-weight:500}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);background:rgba(0,0,0,.45);justify-content:center;align-items:center;animation:.15s fade-in;display:flex;position:fixed;inset:0}.confirmation-modal{background:var(--surface);border-radius:var(--radius-md);padding:var(--space-xl);width:90%;max-width:400px;box-shadow:var(--shadow-lg);animation:.2s scale-in}.confirmation-modal h3{margin:0 0 var(--space-md) 0;color:var(--text)}.confirmation-modal p{margin:var(--space-sm) 0;line-height:1.6}.warning-text{color:var(--warning);font-size:.9rem;font-style:italic}.modal-actions{gap:var(--space-md);margin-top:var(--space-lg);justify-content:flex-end;display:flex}.modal-actions button{min-width:90px;padding:.625rem 1rem}.keypad-mode-toggle{gap:var(--space-xs);margin-bottom:var(--space-xs);grid-template-columns:1fr 1fr;display:grid}.keypad-toggle-btn{background:var(--btn-neutral);color:var(--btn-neutral-text);border-radius:var(--radius-sm);padding:.4rem .75rem;font-size:.875rem}.keypad-toggle-btn.active{background:var(--primary);color:#fff}.quick-cash-grid{gap:var(--space-sm);grid-template-columns:repeat(2,1fr);display:grid}.quick-cash-btn{font-size:1.3rem;font-weight:700;font-family:var(--font-mono);border-radius:var(--radius-sm);min-height:var(--touch-min);background:var(--surface);border:2px solid var(--border);color:var(--text);padding:.85rem}.quick-cash-btn:active{background:var(--primary-light);border-color:var(--primary)}.quick-cash-exact{background:var(--success-light);border-color:var(--success);color:var(--success)}.quick-cash-clear{background:var(--danger-light);border-color:var(--danger);color:var(--danger)}.stock-warning{bottom:var(--space-xs);left:var(--space-xs);background:var(--warning);color:#000;border-radius:var(--radius-sm);z-index:2;padding:.1rem .4rem;font-size:.7rem;font-weight:700;position:absolute}.text-muted{color:var(--text-muted);font-size:.85rem}.sale-tab-bar{gap:var(--space-xs);margin-bottom:var(--space-md);display:flex}.sale-tab{border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:var(--light);color:var(--text-muted);border:1px solid var(--border);border-bottom:none;padding:.5rem 1.5rem;font-weight:600}.sale-tab.active{background:var(--surface);color:var(--text);border-bottom:2px solid var(--surface);margin-bottom:-1px}.kitchen-status-panel{padding:var(--space-md)}.kitchen-status-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-md);margin-bottom:var(--space-sm)}.kitchen-status-header{margin-bottom:var(--space-sm);justify-content:space-between;display:flex}.kitchen-status-time{color:var(--text-muted);font-size:.85rem}.kitchen-status-items{padding:0;list-style:none}.kitchen-status-items li{padding:var(--space-xs) 0;border-bottom:1px solid var(--border)}.kitchen-status-items li:last-child{border-bottom:none}.kitchen-empty{color:var(--text-muted);text-align:center;padding:var(--space-xl)}.kitchen-page{padding:var(--space-md);background:var(--light);min-height:100dvh}.kitchen-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.kitchen-header h1{font-size:2rem}.kitchen-refresh-btn{padding:.75rem 1.5rem;font-size:1.2rem}.kitchen-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.kitchen-order-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-md)}.kitchen-order-header{margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:2px solid var(--border);justify-content:space-between;align-items:center;display:flex}.kitchen-customer{font-size:1.5rem;font-weight:700}.kitchen-time{color:var(--text-muted);font-size:1.2rem;font-family:var(--font-mono)}.kitchen-order-items{margin-bottom:var(--space-md)}.kitchen-item-row{align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;border-bottom:1px solid var(--border);display:flex}.kitchen-item-row:last-child{border-bottom:none}.kitchen-item-qty{font-size:1.4rem;font-weight:700;font-family:var(--font-mono);min-width:3rem}.kitchen-item-name{flex:1;font-size:1.4rem}.kitchen-done-btn{background:var(--success);color:#fff;border-radius:var(--radius-sm);min-height:var(--touch-min);padding:.5rem 1.25rem;font-size:1.1rem}.kitchen-complete-order-btn{background:var(--primary);color:#fff;border-radius:var(--radius-md);width:100%;min-height:56px;padding:.85rem;font-size:1.3rem;font-weight:700}.kitchen-empty-msg{text-align:center;padding:4rem var(--space-xl);color:var(--text-muted)}.kitchen-empty-msg h2{margin-bottom:var(--space-md);font-size:2rem}.kitchen-empty-msg p{font-size:1.2rem}.kitchen-header-actions{gap:var(--space-sm);display:flex}.kitchen-header-btn{padding:.6rem 1.25rem;font-size:1.1rem}.kitchen-section-title{margin:var(--space-xl) 0 var(--space-md);font-size:1.5rem}.kitchen-item-done .kitchen-item-qty,.kitchen-item-done .kitchen-item-name{opacity:.45;text-decoration:line-through}.kitchen-done-check{color:var(--success);text-align:center;min-width:4rem;font-size:1.1rem;font-weight:700}@keyframes kitchen-blink{0%,to{border-color:var(--success);box-shadow:0 0 0 3px var(--success-light)}50%{border-color:var(--border);box-shadow:none}}.kitchen-order-new{animation:.5s ease-in-out 6 kitchen-blink}.kitchen-order-all-done{border-color:var(--success);background:var(--success-light)}.kitchen-order-all-done .kitchen-complete-order-btn{background:var(--success)}.kitchen-order-completed{border-color:var(--text-muted);opacity:.65}.kitchen-order-completed .kitchen-item-qty,.kitchen-order-completed .kitchen-item-name{opacity:.7;text-decoration:line-through}.kitchen-status-item-done{opacity:.55;color:var(--success);text-decoration:line-through}.kitchen-status-card-done{border-color:var(--success);background:var(--success-light);opacity:.7}.kitchen-status-complete-badge{color:var(--success);font-weight:700}.image-preview-container{align-items:center;gap:var(--space-sm);margin-top:var(--space-sm);display:flex}.image-preview{object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border);width:80px;height:80px}.item-thumb-cell{width:48px}.item-thumb{object-fit:cover;border-radius:var(--radius-sm);width:40px;height:40px}@media (width<=1024px){.sale-grid{gap:var(--space-md);grid-template-columns:1fr 1fr}.items-grid{grid-template-columns:repeat(auto-fill,minmax(115px,1fr))}.nav-links{gap:0}.nav-links a{padding:.75rem .65rem;font-size:.9rem}.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.container{padding:0 var(--space-sm);margin:var(--space-sm) auto}.sale-page{padding:var(--space-sm);border-radius:var(--radius-sm)}.sale-grid{gap:var(--space-sm);grid-template-columns:1fr;min-height:auto}.items-grid{gap:var(--space-xs);grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.item-card{padding:var(--space-sm)}.transaction-section{border-top:2px solid var(--border);padding-top:var(--space-md);border-radius:0}.transaction-items{max-height:25vh}.payment-change-wrapper{flex-direction:column}.keypad-btn{padding:.6rem;font-size:1.2rem}.action-button{padding:.75rem;font-size:1.1rem}.nav-links a{padding:.65rem .6rem;font-size:.85rem}.form-grid{grid-template-columns:1fr}.report-type-selector{flex-direction:column}.date-range-selector{flex-direction:column;align-items:stretch}.summary-cards{grid-template-columns:1fr}.report-highlights{gap:var(--space-md);flex-direction:column}.data-table{display:block;overflow-x:auto}.confirmation-modal{margin:var(--space-md)}.page-header{align-items:flex-start;gap:var(--space-sm);flex-direction:column}}.login-page{background:var(--light);min-height:100dvh;padding:var(--space-md);justify-content:center;align-items:center;display:flex}.login-container{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-xl) var(--space-xl) var(--space-lg);width:100%;max-width:480px}.login-header{text-align:center;margin-bottom:var(--space-lg)}.login-header h1{color:var(--primary);font-size:2rem}.login-logo{object-fit:contain;max-height:3rem}.login-user-select h2{text-align:center;margin-bottom:var(--space-md);color:var(--text-muted);font-size:1.25rem}.user-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(120px,1fr));display:grid}.user-select-btn{align-items:center;gap:var(--space-xs);padding:var(--space-md);background:var(--light);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;min-height:var(--touch-min);flex-direction:column;transition:all .15s;display:flex}.user-select-btn:hover{border-color:var(--primary);background:var(--primary-light)}.user-select-icon{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;font-weight:700;display:flex}.user-select-name{font-size:.95rem;font-weight:600}.user-select-role{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.login-pin-screen{text-align:center}.login-welcome{margin-bottom:var(--space-xs);font-size:1.3rem}.login-subtitle{color:var(--text-muted);margin-bottom:var(--space-md)}.pin-display{justify-content:center;gap:var(--space-sm);min-height:48px;margin-bottom:var(--space-md);background:var(--light);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);align-items:center;display:flex}.pin-display-small{min-height:36px;margin-bottom:var(--space-sm)}.pin-dot{color:var(--text);font-size:1.75rem;font-weight:700;line-height:1}.login-error{color:var(--danger);background:var(--danger-light);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-md);font-size:.9rem}.pin-pad{gap:var(--space-sm);max-width:320px;margin:0 auto var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.pin-pad-small{max-width:260px}.pin-btn{padding:var(--space-md);background:var(--light);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;min-height:60px;color:var(--text);font-size:1.5rem;font-weight:600;transition:all .1s}.pin-btn:hover{background:var(--primary-light);border-color:var(--primary)}.pin-btn:active{background:var(--primary);color:#fff;transform:scale(.95)}.pin-btn-sm{padding:var(--space-sm);min-height:48px;font-size:1.2rem}.pin-btn-clear{background:var(--warning-light);color:var(--warning);font-size:1rem}.pin-btn-ok{background:var(--success);color:#fff;font-size:1rem}.pin-btn-ok:hover{background:#059669}.pin-btn-ok:disabled{opacity:.5;cursor:default}.login-back-btn{color:var(--text-muted);padding:var(--space-sm) var(--space-md);cursor:pointer;background:0 0;font-size:.9rem}.login-back-btn:hover{color:var(--primary)}.setup-screen{text-align:center}.setup-screen h2{margin-bottom:var(--space-md)}.setup-info{color:var(--text-muted);margin-bottom:var(--space-lg)}.setup-credentials{background:var(--light);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-lg)}.setup-field{padding:var(--space-sm) 0;justify-content:space-between;font-size:1.1rem;display:flex}.setup-label{color:var(--text-muted);font-weight:500}.setup-value{font-weight:700;font-family:var(--font-mono);font-size:1.25rem}.setup-warning{color:var(--warning);margin-bottom:var(--space-lg);font-size:.9rem}.setup-continue{width:100%;padding:var(--space-md);font-size:1.1rem}.logout-tab{margin-left:auto;color:var(--danger)!important;background:var(--danger-light)!important}.logout-tab:hover{background:var(--danger)!important;color:#fff!important}.admin-page{padding:var(--space-lg) 0}.admin-page h2{margin-bottom:var(--space-lg)}.admin-error{color:var(--danger);background:var(--danger-light);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-md)}.admin-user-list{gap:var(--space-sm);margin-bottom:var(--space-lg);flex-direction:column;display:flex}.admin-user-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);justify-content:space-between;align-items:center;display:flex}.admin-user-info{align-items:center;gap:var(--space-md);display:flex}.admin-user-name{font-size:1.1rem;font-weight:600}.admin-user-role{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--light);border-radius:var(--radius-sm);padding:2px 8px;font-size:.8rem}.admin-user-actions{gap:var(--space-sm);display:flex}.admin-add-btn{width:100%;padding:var(--space-md);font-size:1.1rem}.btn-primary-small{padding:var(--space-sm) var(--space-md);background:var(--primary);color:#fff;border-radius:var(--radius-sm);min-height:var(--touch-min);font-size:.85rem;font-weight:600}.btn-danger-small{padding:var(--space-sm) var(--space-md);background:var(--danger);color:#fff;border-radius:var(--radius-sm);min-height:var(--touch-min);font-size:.85rem;font-weight:600}.btn-secondary-small{padding:var(--space-sm) var(--space-md);background:var(--btn-neutral);color:var(--btn-neutral-text);border-radius:var(--radius-sm);min-height:var(--touch-min);font-size:.85rem;font-weight:600}.admin-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-lg)}.admin-form h3,.admin-form-field{margin-bottom:var(--space-md)}.admin-form-field label{margin-bottom:var(--space-xs);color:var(--text-muted);font-size:.9rem;font-weight:600;display:block}.admin-input-row{gap:var(--space-sm);align-items:center;display:flex}.admin-input-row input{flex:1}.admin-role-buttons{gap:var(--space-sm);display:flex}.role-btn{padding:var(--space-sm) var(--space-md);background:var(--light);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;min-height:var(--touch-min);color:var(--text);flex:1;font-weight:600;transition:all .15s}.role-btn:hover{border-color:var(--primary)}.role-btn-active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.admin-form-actions{gap:var(--space-sm);margin-top:var(--space-lg);display:flex}.admin-form-actions button{padding:var(--space-md);flex:1;font-size:1rem}.osk{background:var(--light);border-radius:var(--radius-md);padding:var(--space-sm);margin-bottom:var(--space-md)}.osk-row{justify-content:center;gap:4px;margin-bottom:4px;display:flex}.osk-key{min-width:36px;min-height:var(--touch-min);padding:var(--space-xs) var(--space-sm);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text);flex:0 auto;font-size:1rem;font-weight:500;transition:all .1s}.osk-key:hover{background:var(--primary-light);border-color:var(--primary)}.osk-key:active{background:var(--primary);color:#fff;transform:scale(.95)}.osk-key-wide{min-width:64px;font-size:.85rem}.osk-key-space{flex:1;min-width:200px}.osk-key-active{background:var(--primary);color:#fff;border-color:var(--primary-dark)}.osk-key-active:hover{background:var(--primary-dark)}.loading{text-align:center;padding:var(--space-xl);color:var(--text-muted)}.setup-wide{max-width:640px}.language-grid{gap:var(--space-md);margin-top:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.language-btn{justify-content:center;align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-sm);background:var(--light);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;min-height:60px;color:var(--text);flex-direction:column;font-size:1rem;font-weight:600;transition:all .15s;display:flex}.language-btn:hover{border-color:var(--primary);background:var(--primary-light)}.language-btn:active{transform:scale(.97)}.language-btn-active{border-color:var(--primary);background:var(--primary-light);color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.language-name{font-size:1rem}.admin-language-section{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--border)}.admin-language-section h3{margin-bottom:var(--space-md)}.currency-grid{gap:var(--space-sm);margin-top:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(110px,1fr));display:grid}.currency-btn{padding:var(--space-sm) var(--space-md);background:var(--light);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;min-height:var(--touch-min);color:var(--text);justify-content:center;align-items:center;font-size:.9rem;font-weight:600;transition:all .15s;display:flex}.currency-btn:hover{border-color:var(--primary);background:var(--primary-light)}.currency-btn:active{transform:scale(.97)}.currency-btn-active{border-color:var(--primary);background:var(--primary-light);color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.currency-btn-default{border-color:var(--success);background:var(--success-light)}.currency-custom{margin-top:var(--space-md)}.currency-custom label{margin-bottom:var(--space-xs);color:var(--text-muted);font-size:.9rem;font-weight:600;display:block}.currency-custom-row{gap:var(--space-sm);max-width:320px;display:flex}.currency-custom-row input{flex:1;min-width:0}.currency-custom-row button{white-space:nowrap}