:root{--bg: #ffffff;--surface: #f6f6f7;--border: #e0e3e8;--text: #1a1a1a;--muted: #5c6370;--accent: #b91c1c;--accent-dim: #7f1111;--ok: #15803d;--warn: #b45309;color-scheme:light;font-family:DM Sans,system-ui,sans-serif;line-height:1.45;color:var(--text);background:var(--bg)}*{box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-nav{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:.5rem 1rem;background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.app-nav-brand{display:flex;align-items:center;gap:.65rem;min-width:0}.app-nav-logo{height:2.25rem;width:auto;max-width:7.5rem;object-fit:contain;object-position:left center;flex-shrink:0;border-radius:4px}.app-nav-title{font-weight:700;color:var(--accent);letter-spacing:.02em;white-space:nowrap}.app-nav-tabs{display:flex;gap:.25rem;flex-wrap:wrap}.nav-tab{padding:.45rem .85rem;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--muted);font-weight:600;font-size:.9rem}.nav-tab:hover{color:var(--text);background:#0000000d}.nav-tab.active{color:var(--accent);background:#b91c1c1a;border-color:#b91c1c59}.field-label{display:block;margin-bottom:.35rem;color:var(--muted);font-size:.88rem}.field{width:100%;padding:.65rem .85rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:.95rem}.hit-list{list-style:none;margin:0;padding:0;max-height:200px;overflow:auto;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.hit-list li button{display:block;width:100%;text-align:left;padding:.5rem .75rem;border:none;background:transparent;color:var(--text);border-bottom:1px solid var(--border)}.hit-list li:last-child button{border-bottom:none}.hit-list li button:hover{background:#0000000a}.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .65rem;background:#15803d1a;border:1px solid rgba(21,128,61,.45);border-radius:999px;font-size:.9rem}.chip-x{border:none;background:transparent;color:var(--text);font-size:1.1rem;line-height:1;padding:0 .15rem;cursor:pointer}.muted{color:var(--muted)}.muted.small,.small{font-size:.82rem}.ticket-line{padding:.65rem 0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;gap:.75rem;align-items:flex-start}.qty-row{display:flex;align-items:center;gap:.35rem;margin-top:.35rem}.qty-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-weight:700}.qty-input{width:72px;padding:.25rem .35rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem;text-align:center}.ticket-total{margin-top:.75rem;padding-top:.85rem;border-top:2px solid var(--border);display:flex;justify-content:space-between;align-items:center}.total-num{font-size:1.35rem;font-weight:700;color:var(--ok);font-variant-numeric:tabular-nums}.btn-primary{padding:.65rem 1.1rem;border-radius:8px;border:none;background:linear-gradient(180deg,var(--accent) 0%,var(--accent-dim) 100%);color:#fff;font-weight:600}.btn-pay{margin-top:.75rem;padding:.75rem;border-radius:8px;border:none;background:var(--ok);color:#fff;font-weight:700}.btn-secondary{padding:.45rem .85rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-weight:600;font-size:.88rem}.btn-ghost{margin-top:.45rem;padding:.55rem;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted)}.btn-ghost.small{margin-top:0;padding:.25rem .5rem;font-size:.8rem}.btn-small{padding:.3rem .55rem;font-size:.85rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem;max-width:520px;width:100%;max-height:90vh;overflow:auto}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table th,.data-table td{padding:.5rem .65rem;text-align:left;border-bottom:1px solid var(--border)}.data-table th{color:var(--muted);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1rem}.stat-label{font-size:.8rem;color:var(--muted);margin-bottom:.35rem}.stat-value{font-size:1.35rem;font-weight:700;font-variant-numeric:tabular-nums}
