:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#app{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}button{font:inherit;cursor:pointer;border:1px solid var(--accent-border);background:var(--accent-bg);color:var(--text-h);border-radius:6px;padding:8px 14px}button:hover:not(:disabled){box-shadow:var(--shadow)}button:disabled{cursor:not-allowed;opacity:.5}input{font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:6px;padding:8px 10px}.error{color:#e5484d}.success{color:#30a46c;font-weight:500}.loading{text-align:center;padding:32px}.auth{text-align:center;flex-direction:column;align-items:center;gap:16px;max-width:360px;margin:80px auto;padding:0 20px;display:flex}.auth-form{text-align:left;flex-direction:column;gap:12px;width:100%;display:flex}.auth-form label{flex-direction:column;gap:4px;font-size:14px;display:flex}.link{color:var(--accent);background:0 0;border:none;padding:4px 0;text-decoration:underline}.app-shell{text-align:left;flex-direction:column;min-height:100svh;display:flex}.navbar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;padding:14px 24px;display:flex}.navbar-brand{font-size:18px;font-weight:600}.navbar-links{gap:8px;display:flex}.navbar-links button{background:0 0;border:1px solid #0000}.navbar-links button.active{background:var(--accent-bg);border-color:var(--accent-border)}.navbar-user{align-items:center;gap:12px;font-size:14px;display:flex}.page{box-sizing:border-box;flex:1;width:100%;max-width:1100px;margin:0 auto;padding:24px}.poster{aspect-ratio:3/4;color:#fff;text-shadow:0 1px 3px #00000059;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex;position:relative;overflow:hidden}.poster-icon{opacity:.85;width:40px;height:40px}.poster-name{text-align:center;padding:0 8px;font-size:15px;font-weight:600}.concert-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px;display:grid}.concert-poster-card{text-align:left;color:inherit;background:0 0;border:none;flex-direction:column;gap:8px;padding:0;display:flex}.concert-poster-card:hover .poster{box-shadow:var(--shadow)}.concert-meta{flex-direction:column;gap:2px;font-size:13px;display:flex}.seat-page{flex-direction:column;gap:20px;display:flex}.seat-page-header{align-items:center;gap:20px;display:flex}.seat-page-header .poster{flex:none;width:110px}.seat-page-header h2{margin:0 0 4px}.seat-page-header p{margin:0;font-size:14px}.seat-legend{gap:20px;font-size:13px;display:flex}.seat-legend .swatch{vertical-align:middle;border-radius:3px;width:12px;height:12px;margin-right:6px;display:inline-block}.seat-legend .swatch.available{background:var(--accent-bg);border:1px solid var(--accent-border)}.seat-legend .swatch.selected{background:var(--accent)}.seat-legend .swatch.taken{background:var(--border)}.seat-grid{gap:8px;max-width:640px;display:grid}.seat{aspect-ratio:1;background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:6px;padding:0;font-size:12px}.seat.selected{background:var(--accent);color:#fff}.seat.taken{background:var(--border);border-color:var(--border);color:var(--text)}.seat-summary{justify-content:space-between;align-items:center;max-width:640px;font-weight:500;display:flex}.bookings-page{flex-direction:column;gap:16px;display:flex}.booking-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.booking-card{border:1px solid var(--border);border-radius:8px;align-items:center;gap:16px;padding:12px 16px;display:flex}.booking-swatch{border-radius:6px;flex:none;width:40px;height:40px}.booking-info{flex-direction:column;flex:1;gap:2px;display:flex}.booking-card.cancelled{opacity:.6}.status{text-transform:capitalize;font-size:13px}
