@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg:#0d0d0f;--surface:#1a1a2e;--card:#16213e;--accent:#7c4dff;--accent-soft:#7c4dff26;--success:#00e676;--success-soft:#00e6761f;--error:#ff5252;--warning:#ffb300;--info:#29b6f6;--border:#ffffff14;--text:#fff;--text-sec:#fff9;--text-muted:#ffffff59;--glass-bg:#1a1a2e99;--radius:16px;--radius-lg:24px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.w-full{width:100%}.text-center{text-align:center}.relative{position:relative}.absolute{position:absolute}h1{font-size:28px;font-weight:800}h2{font-size:22px;font-weight:700}h3{font-size:18px;font-weight:600}.glass{background:var(--glass-bg);border:1px solid var(--border);-webkit-backdrop-filter:blur(16px);border-radius:var(--radius-lg)}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#9b72ff;transform:translateY(-1px);box-shadow:0 8px 24px #7c4dff59}.btn-success{background:var(--success);color:#000}.btn-success:hover:not(:disabled){background:#00ff8a;transform:translateY(-1px)}.btn-ghost{color:var(--text-sec);border:1px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--border);color:var(--text)}.btn-danger{color:var(--error);background:0 0;border:1px solid #ff52524d}.btn-danger:hover:not(:disabled){background:#ff52521a}.btn-sm{padding:8px 16px;font-size:13px}.btn-lg{border-radius:var(--radius-lg);padding:16px 32px;font-size:16px}.btn-icon{aspect-ratio:1;border-radius:50%;padding:10px}.input-wrap{flex-direction:column;gap:6px;display:flex}.input-label{color:var(--text-sec);font-size:13px;font-weight:500}.input{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--radius);outline:none;width:100%;padding:13px 16px;font-family:inherit;font-size:15px;transition:border-color .2s}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--text-muted)}.auth-page{background:radial-gradient(ellipse at top, #7c4dff1f 0%, transparent 60%), radial-gradient(ellipse at bottom right, #00e6760f 0%, transparent 50%), var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:24px;width:100%;max-width:420px;padding:40px 36px;display:flex}.auth-logo{text-align:center}.auth-logo .logo-mark{background:linear-gradient(135deg, var(--accent), #b388ff);color:#fff;border-radius:18px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:12px;font-size:24px;font-weight:800;display:inline-flex;box-shadow:0 8px 32px #7c4dff66}.auth-logo h1{font-size:24px}.auth-logo p{color:var(--text-sec);margin-top:4px;font-size:14px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-footer{text-align:center;color:var(--text-sec);font-size:14px}.auth-footer a{color:var(--accent);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-error{color:var(--error);border-radius:var(--radius);background:#ff52521a;border:1px solid #ff52524d;padding:12px 16px;font-size:14px}.app-shell{flex-direction:column;min-height:100vh;display:flex}.top-bar{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;gap:16px;height:60px;padding:0 20px;display:flex;position:sticky;top:0}.top-bar-logo{align-items:center;gap:10px;font-size:17px;font-weight:700;display:flex}.top-bar-logo .mark{background:linear-gradient(135deg, var(--accent), #b388ff);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:800;display:flex}.top-bar-right{align-items:center;gap:8px;display:flex}.page-content{flex:1;width:100%;max-width:900px;margin:0 auto;padding:24px 20px}.events-header{margin-bottom:24px}.events-header h2{font-size:22px}.events-header p{color:var(--text-sec);margin-top:4px;font-size:14px}.events-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.event-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:transform .2s,box-shadow .2s;overflow:hidden}.event-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 12px 40px #0000004d}.event-card-cover{object-fit:cover;background:var(--surface);width:100%;height:140px;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.event-card-cover img{object-fit:cover;width:100%;height:100%}.event-card-body{padding:16px}.event-card-title{margin-bottom:6px;font-size:16px;font-weight:700}.event-card-meta{color:var(--text-sec);flex-direction:column;gap:4px;font-size:13px;display:flex}.event-card-badge{background:var(--accent-soft);color:var(--accent);border-radius:20px;align-items:center;gap:4px;margin-top:10px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.empty-state{text-align:center;color:var(--text-sec);flex-direction:column;justify-content:center;align-items:center;padding:64px 24px;display:flex}.empty-state svg{opacity:.4;margin-bottom:16px}.empty-state h3{color:var(--text);margin-bottom:8px}.scanner-page{flex-direction:column;height:calc(100vh - 60px);display:flex}.tabs{border-bottom:1px solid var(--border);background:var(--surface);display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.scanner-tab{background:#000;flex:1;position:relative;overflow:hidden}.qr-viewport{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}#qr-reader{width:100%;height:100%}#qr-reader video{object-fit:cover;width:100%!important;height:100%!important}#qr-reader img,#qr-reader button,#qr-reader select,#qr-reader span{display:none!important}.scan-overlay{pointer-events:none;background:linear-gradient(#0000008c 0%,#0000 25% 75%,#0000008c 100%);position:absolute;inset:0}.scan-frame-wrap{width:260px;height:260px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.scan-frame-corner{border-color:var(--accent);border-style:solid;border-radius:6px;width:36px;height:36px;position:absolute}.scan-frame-corner.tl{border-width:3px 0 0 3px;top:0;left:0}.scan-frame-corner.tr{border-width:3px 3px 0 0;top:0;right:0}.scan-frame-corner.bl{border-width:0 0 3px 3px;bottom:0;left:0}.scan-frame-corner.br{border-width:0 3px 3px 0;bottom:0;right:0}.scan-frame-corner{animation:1.5s ease-in-out infinite alternate pulse-glow}@keyframes pulse-glow{0%{box-shadow:0 0 8px #7c4dff99}to{box-shadow:0 0 20px #7c4dff,0 0 40px #7c4dff66}}.scan-laser{background:linear-gradient(to right, transparent, var(--accent), transparent);height:2px;box-shadow:0 0 8px var(--accent);animation:2s linear infinite laser-sweep;position:absolute;left:4px;right:4px}@keyframes laser-sweep{0%{top:4px}to{top:252px}}.stats-bar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:var(--radius-lg);pointer-events:none;background:#1a1a2eb3;border:1px solid #ffffff1a;justify-content:space-around;align-items:center;padding:12px 20px;display:flex;position:absolute;top:12px;left:12px;right:12px}.stats-divider{background:#ffffff1f;width:1px;height:36px}.stat-item{flex-direction:column;align-items:center;gap:2px;display:flex}.stat-val{font-size:22px;font-weight:800}.stat-label{color:var(--text-sec);font-size:11px;font-weight:500}.scan-error{background:var(--error);color:#fff;border-radius:var(--radius);text-align:center;pointer-events:none;padding:12px 16px;font-size:14px;font-weight:600;animation:.2s slide-down;position:absolute;top:100px;left:12px;right:12px}@keyframes slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.scan-controls{justify-content:center;align-items:center;gap:32px;display:flex;position:absolute;bottom:28px;left:0;right:0}.ctrl-btn{cursor:pointer;color:#fff;background:0 0;border:none;flex-direction:column;align-items:center;gap:8px;display:flex}.ctrl-btn-circle{border:1px solid var(--border);background:#1a1a2ecc;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:background .2s;display:flex}.ctrl-btn:hover .ctrl-btn-circle{background:#7c4dff33}.ctrl-btn span{font-size:12px;font-weight:600}.scan-loader{background:#0009;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.overlay{background:#000000e0;justify-content:center;align-items:center;padding:20px;animation:.2s fade-in;display:flex;position:absolute;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.guest-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;align-items:center;gap:0;width:100%;max-width:380px;padding:28px;animation:.25s cubic-bezier(.34,1.56,.64,1) pop-up;display:flex}@keyframes pop-up{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.guest-avatar{background:var(--accent-soft);border:2px solid var(--accent);width:72px;height:72px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;margin-bottom:16px;font-size:30px;font-weight:800;display:flex}.guest-name{text-align:center;font-size:22px;font-weight:800}.guest-phone{color:var(--text-sec);margin-top:4px;font-size:14px}.guest-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;margin-top:8px;padding:4px 14px;font-size:11px;font-weight:700}.badge-single{color:var(--accent);background:#7c4dff33}.badge-double{color:#b388ff;background:#b388ff33}.badge-custom{color:var(--success);background:#00e67626}.guest-divider{background:var(--border);width:100%;height:1px;margin:18px 0}.slot-row{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:16px;display:flex}.slot-item{flex-direction:column;align-items:center;gap:4px;display:flex}.slot-icon{font-size:20px}.slot-label{font-size:10px;font-weight:700}.slot-on{color:var(--success)}.slot-off{color:var(--text-muted)}.slot-count{color:var(--text-sec);margin-bottom:12px;font-size:12px}.guest-actions{gap:10px;width:100%;display:flex}.guest-actions .btn{flex:1}.checkout-btn{margin-top:10px}.log-tab{flex-direction:column;flex:1;gap:10px;padding:16px;display:flex;overflow-y:auto}.log-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:14px;padding:14px 16px;transition:border-color .2s;display:flex}.log-item:hover{border-color:var(--accent)}.log-avatar{background:var(--accent-soft);width:44px;height:44px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.log-info{flex:1;min-width:0}.log-name{font-size:15px;font-weight:600}.log-phone{color:var(--text-sec);margin-top:2px;font-size:13px}.log-slots{gap:6px;margin-top:6px;display:flex}.slot-badge{border-radius:8px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.slot-badge.on{background:var(--success-soft);color:var(--success);border:1px solid #00e67633}.slot-badge.off{color:var(--text-muted);border:1px solid var(--border);background:#ffffff0a}.log-status{white-space:nowrap;border-radius:10px;flex-shrink:0;padding:5px 10px;font-size:12px;font-weight:700}.log-status.full{background:var(--success-soft);color:var(--success);border:1px solid #00e67633}.log-status.partial{color:var(--warning);background:#ffb3001f;border:1px solid #ffb30033}.modal-backdrop{z-index:200;background:#000000b3;justify-content:center;align-items:flex-end;animation:.15s fade-in;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;flex-direction:column;width:100%;max-width:520px;max-height:80vh;padding:24px;animation:.25s cubic-bezier(.34,1.2,.64,1) slide-up;display:flex}@keyframes slide-up{0%{opacity:0;transform:translateY(60px)}to{opacity:1;transform:translateY(0)}}.modal-handle{background:var(--border);border-radius:2px;width:36px;height:4px;margin:0 auto 20px}.modal-title{text-align:center;margin-bottom:6px;font-size:20px;font-weight:700}.modal-subtitle{color:var(--text-sec);text-align:center;margin-bottom:20px;font-size:14px}.passcode-input{background:var(--surface);border:1px solid var(--border);color:var(--accent);border-radius:var(--radius);letter-spacing:10px;text-align:center;outline:none;width:100%;margin-bottom:16px;padding:16px;font-family:inherit;font-size:32px;font-weight:800;transition:border-color .2s}.passcode-input:focus{border-color:var(--accent)}.search-input-wrap{margin-bottom:16px;position:relative}.search-input-wrap svg{color:var(--text-muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-input{padding-left:40px}.search-results{flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.search-item{border-radius:var(--radius);cursor:pointer;align-items:center;gap:12px;padding:12px;transition:background .15s;display:flex}.search-item:hover{background:var(--surface)}.search-item-info{flex:1}.search-item-name{font-size:14px;font-weight:600}.search-item-phone{color:var(--text-sec);font-size:12px}.search-status{border-radius:8px;padding:3px 8px;font-size:11px;font-weight:700}.search-status.in{background:var(--success-soft);color:var(--success);border:1px solid #00e67633}.search-status.out{color:var(--warning);background:#ffb3001a;border:1px solid #ffb30033}.scanner-header{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 16px;display:flex}.scanner-header h3{flex:1;font-size:16px;font-weight:700}.scanner-header-actions{gap:8px;display:flex}.loading-full{height:100vh;color:var(--text-sec);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}@media (width<=600px){.auth-box{padding:28px 20px}.events-grid{grid-template-columns:1fr}.stat-val{font-size:18px}.guest-card{padding:20px}}
