*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f0f1a;--bg-card: #1a1a2e;--bg-elevated: #222240;--primary: #e94560;--primary-glow: rgba(233, 69, 96, .3);--secondary: #7c5cbf;--accent: #f5a623;--text: #f0f0f0;--text-muted: #8888a0;--text-dim: #555570;--success: #2ecc71;--warning: #f39c12;--error: #e74c3c;--radius: 16px;--radius-sm: 10px;--radius-full: 999px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}html,body{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;user-select:none;-webkit-user-select:none;overscroll-behavior:none}#root{height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.connection-banner{position:fixed;top:0;left:0;right:0;padding:8px 16px;background:var(--error);color:#fff;text-align:center;font-size:13px;font-weight:600;z-index:100;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;padding-top:max(12px,env(safe-area-inset-top));background:var(--bg);position:sticky;top:0;z-index:50}.app-header__leave{background:none;border:1px solid rgba(255,255,255,.1);color:var(--text-muted);font-family:var(--font);font-size:13px;font-weight:600;padding:6px 14px;border-radius:var(--radius-full);cursor:pointer;-webkit-tap-highlight-color:transparent}.app-header__leave:active{opacity:.7}.app-header__room{font-size:13px;font-weight:700;color:var(--text-dim);letter-spacing:2px}.app-header__spacer{width:60px}.page{min-height:calc(100dvh - 48px);display:flex;flex-direction:column;align-items:center;padding:16px 20px 24px}.page--home{min-height:100dvh;padding-top:env(safe-area-inset-top,24px)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 28px;border:none;border-radius:var(--radius-full);font-family:var(--font);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn--primary{background:var(--primary);color:#fff;box-shadow:0 4px 20px var(--primary-glow)}.btn--primary:hover:not(:disabled){background:#d63550;box-shadow:0 6px 28px var(--primary-glow)}.btn--secondary{background:var(--bg-elevated);color:var(--text);border:1px solid rgba(255,255,255,.1)}.btn--ghost{background:transparent;color:var(--text-muted);border:1px solid rgba(255,255,255,.1)}.btn--large{width:100%;max-width:340px;padding:18px 32px;font-size:18px}.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;width:100%;max-width:340px;text-align:center;margin-bottom:16px}.alert--error{background:#e74c3c26;color:#e74c3c;border:1px solid rgba(231,76,60,.3)}.alert--warning{background:#f39c1226;color:#f39c12;border:1px solid rgba(243,156,18,.3)}.spinner{width:36px;height:36px;border:3px solid var(--bg-elevated);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.page--home{justify-content:center;gap:40px}.home-hero{text-align:center}.home-hero__title{font-size:32px;font-weight:800;line-height:1.2;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.home-hero__subtitle{font-size:16px;color:var(--text-muted)}.home-hero__location{font-size:13px;color:var(--text-dim);margin-top:8px}.home-actions{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%}.home-divider{display:flex;align-items:center;gap:16px;width:100%;max-width:340px;color:var(--text-dim);font-size:14px}.home-divider:before,.home-divider:after{content:"";flex:1;height:1px;background:#ffffff14}.zip-prompt{font-size:15px;color:var(--text-muted);text-align:center}.zip-input-group{display:flex;gap:10px;width:100%;max-width:340px}.zip-input__field{flex:1;padding:14px 18px;background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:20px;font-weight:700;letter-spacing:3px;text-align:center;outline:none;transition:border-color .2s}.zip-input__field::placeholder{font-weight:400;letter-spacing:0;font-size:14px;color:var(--text-dim)}.zip-input__field:focus{border-color:var(--primary)}.room-code-input{display:flex;flex-direction:column;gap:10px;width:100%;max-width:340px}.room-code-input .btn{width:100%;padding:14px}.room-code-input__field{flex:1;padding:14px 18px;background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:18px;font-weight:700;letter-spacing:3px;text-align:center;outline:none;transition:border-color .2s}.room-code-input__field::placeholder{font-weight:400;letter-spacing:0;font-size:14px;color:var(--text-dim)}.room-code-input__field:focus{border-color:var(--primary)}.page--lobby{justify-content:center;gap:48px}.room-code-display{text-align:center}.room-code-display__label{font-size:14px;color:var(--text-muted);margin-bottom:16px}.room-code-display__code{display:flex;gap:8px;justify-content:center;cursor:pointer;padding:8px}.room-code-display__letter{display:flex;align-items:center;justify-content:center;width:56px;height:68px;background:var(--bg-card);border:2px solid rgba(233,69,96,.3);border-radius:var(--radius-sm);font-size:32px;font-weight:800;color:var(--primary);transition:transform .15s}.room-code-display__code:active .room-code-display__letter{transform:scale(.95)}.room-code-display__hint{font-size:12px;color:var(--text-dim);margin-top:12px}.lobby-waiting{text-align:center;color:var(--text-muted)}.lobby-waiting p{font-size:15px}.page--filters{align-items:flex-start;gap:0;padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}.filters-title{font-size:26px;font-weight:800;margin-bottom:4px;width:100%}.filters-location{font-size:13px;color:var(--text-dim);margin-bottom:20px;width:100%}.filter-section{width:100%;margin-bottom:28px}.filter-section__title{font-size:16px;font-weight:700;margin-bottom:4px;color:var(--text)}.filter-section__hint{font-size:13px;color:var(--text-dim);margin-bottom:10px}.filter-chips{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:var(--bg-card);border:1.5px solid rgba(255,255,255,.08);border-radius:var(--radius-full);color:var(--text-muted);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;-webkit-tap-highlight-color:transparent}.filter-chip:active{transform:scale(.96)}.filter-chip--selected{background:#e9456026;border-color:var(--primary);color:var(--text)}.filter-chip__emoji{font-size:16px}.filters-submit{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);width:calc(100% - 40px);max-width:340px;z-index:10}.page--waiting{justify-content:center}.waiting-content{text-align:center}.waiting-content h2{font-size:22px;margin-bottom:8px}.waiting-content p{color:var(--text-muted);font-size:15px}.page--swipe{padding:16px 20px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));gap:12px;height:calc(100dvh - 48px);max-height:calc(100dvh - 48px);overflow:hidden}.swipe-header{text-align:center;width:100%}.swipe-header h2{font-size:18px;font-weight:700}.swipe-counter{font-size:14px;color:var(--text-muted);margin-top:2px}.swipe-partner-status{font-size:13px;color:var(--accent);margin-top:4px}.swipe-limited-notice{font-size:13px;color:var(--warning);margin-top:4px}.swipe-stack{flex:1;display:flex;flex-direction:column;align-items:center;width:100%;max-width:380px;gap:16px}.swipe-stack__cards{position:relative;width:100%;flex:1;min-height:0}.swipe-card{position:absolute;inset:0;background:var(--bg-card);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;cursor:grab;touch-action:none;box-shadow:0 4px 24px #0000004d}.swipe-card:active{cursor:grabbing}.swipe-card--behind{transform:scale(.95) translateY(12px);pointer-events:none}.swipe-card--exit-left{animation:exitLeft .3s ease forwards}.swipe-card--exit-right{animation:exitRight .3s ease forwards}@keyframes exitLeft{to{transform:translate(-120%) rotate(-15deg);opacity:0}}@keyframes exitRight{to{transform:translate(120%) rotate(15deg);opacity:0}}.swipe-card__indicator{position:absolute;top:24px;padding:8px 20px;border-radius:var(--radius-sm);font-size:24px;font-weight:800;z-index:5;letter-spacing:2px}.swipe-card__indicator--yes{right:20px;color:var(--success);border:3px solid var(--success);transform:rotate(15deg)}.swipe-card__indicator--nope{left:20px;color:var(--error);border:3px solid var(--error);transform:rotate(-15deg)}.swipe-card__photo{flex:1;min-height:0;overflow:hidden;background:var(--bg-elevated)}.swipe-card__photo img{width:100%;height:100%;object-fit:cover}.swipe-card__photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-elevated),var(--bg-card));font-size:64px}.swipe-card__info{padding:16px 20px 20px}.swipe-card__name{font-size:22px;font-weight:700;margin-bottom:6px}.swipe-card__meta{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--text-muted);margin-bottom:4px;flex-wrap:wrap}.swipe-card__stars{color:var(--accent);font-size:13px;letter-spacing:-1px}.swipe-card__rating{font-weight:600;color:var(--text)}.swipe-card__price{color:var(--success);font-weight:600}.swipe-card__distance{color:var(--secondary);font-weight:600}.swipe-card__address{font-size:13px;color:var(--text-dim)}.swipe-card__closed,.closed-tag{display:inline-block;font-size:11px;font-weight:600;color:var(--error);background:#e74c3c1f;padding:2px 8px;border-radius:var(--radius-full);margin-top:4px}.swipe-stack__buttons{display:flex;gap:32px;justify-content:center;padding:8px 0}.swipe-btn{width:64px;height:64px;border-radius:50%;border:2px solid;background:var(--bg-card);font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;-webkit-tap-highlight-color:transparent}.swipe-btn:active{transform:scale(.9)}.swipe-btn:disabled{opacity:.3;cursor:not-allowed}.swipe-btn--nope{border-color:var(--error);color:var(--error)}.swipe-btn--nope:hover:not(:disabled){background:#e74c3c1a;box-shadow:0 0 20px #e74c3c33}.swipe-btn--yes{border-color:var(--success);color:var(--success)}.swipe-btn--yes:hover:not(:disabled){background:#2ecc711a;box-shadow:0 0 20px #2ecc7133}.page--match{justify-content:center;gap:24px;text-align:center}.match-celebration{animation:matchPop .5s ease}@keyframes matchPop{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.match-title{font-size:40px;font-weight:900;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px}.match-subtitle{color:var(--text-muted);font-size:16px}.restaurant-details{width:100%;max-width:340px;background:var(--bg-card);border-radius:var(--radius);overflow:hidden}.restaurant-details__photo{height:180px;overflow:hidden;background:var(--bg-elevated)}.restaurant-details__photo img{width:100%;height:100%;object-fit:cover}.restaurant-details__photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-elevated),var(--bg-card));font-size:48px}.restaurant-details__name{font-size:24px;font-weight:700;padding:16px 20px 4px}.restaurant-details__meta{display:flex;align-items:center;gap:8px;padding:0 20px;font-size:14px;color:var(--text-muted)}.restaurant-details__stars{color:var(--accent)}.restaurant-details__address{padding:8px 20px 4px;font-size:14px;color:var(--text-dim)}.restaurant-details__directions{display:block;margin:16px 20px 20px;text-align:center;font-size:16px}.results-actions{display:flex;gap:12px;margin-top:12px}.page--results{gap:20px;padding-bottom:100px}.results-list{width:100%;max-width:400px;display:flex;flex-direction:column;gap:12px}.results-card{display:flex;align-items:center;gap:14px;width:100%;padding:12px;background:var(--bg-card);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);cursor:pointer;transition:all .15s ease;text-align:left;color:var(--text);font-family:var(--font);-webkit-tap-highlight-color:transparent}.results-card:active{transform:scale(.98);background:var(--bg-elevated)}.results-card__photo{width:64px;height:64px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;background:var(--bg-elevated)}.results-card__photo img{width:100%;height:100%;object-fit:cover}.results-card__photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px}.results-card__info{flex:1;min-width:0}.results-card__name{font-size:16px;font-weight:700;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.results-card__meta{display:flex;gap:8px;font-size:13px;color:var(--text-muted);margin-bottom:2px}.results-card__rating{color:var(--accent);font-weight:600}.results-card__address{font-size:12px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.results-card__arrow{font-size:24px;color:var(--text-dim);flex-shrink:0}.results-bracket{margin-top:16px;width:100%}.results-restart{margin-top:8px}.page--bracket{gap:12px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.bracket-header{text-align:center;width:100%}.bracket-header__title{font-size:24px;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.bracket-header__info{font-size:13px;color:var(--text-dim);margin-top:2px}.bracket-result-banner{padding:10px 20px;border-radius:var(--radius-full);font-size:16px;font-weight:700;text-align:center;animation:matchPop .4s ease}.bracket-result-banner--agree{background:#2ecc7126;color:var(--success);border:1px solid rgba(46,204,113,.3)}.bracket-result-banner--flip{background:#f5a62326;color:var(--accent);border:1px solid rgba(245,166,35,.3)}.bracket-result-banner--split{background:#7c5cbf26;color:var(--secondary);border:1px solid rgba(124,92,191,.3)}.bracket-matchup{display:flex;flex-direction:column;gap:0;width:100%;max-width:380px}.bracket-vs{text-align:center;font-size:18px;font-weight:900;color:var(--text-dim);padding:6px 0;letter-spacing:2px}.bracket-card{display:flex;align-items:center;gap:14px;width:100%;padding:12px;background:var(--bg-card);border:2px solid rgba(255,255,255,.06);border-radius:var(--radius);cursor:pointer;transition:all .2s ease;text-align:left;color:var(--text);font-family:var(--font);-webkit-tap-highlight-color:transparent}.bracket-card:active:not(:disabled){transform:scale(.97)}.bracket-card:disabled{cursor:default}.bracket-card--winner{border-color:var(--success);background:#2ecc711a;box-shadow:0 0 20px #2ecc7133}.bracket-card--loser{opacity:.35;transform:scale(.96)}.bracket-card__photo{width:72px;height:72px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;background:var(--bg-elevated)}.bracket-card__photo img{width:100%;height:100%;object-fit:cover}.bracket-card__photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:32px}.bracket-card__info{flex:1;min-width:0}.bracket-card__name{font-size:17px;font-weight:700;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bracket-card__meta{display:flex;gap:8px;font-size:13px;color:var(--text-muted)}.bracket-card__rating{color:var(--accent);font-weight:600}.bracket-status{text-align:center;color:var(--text-muted);font-size:15px;padding:8px 0}.bracket-status--waiting{background:var(--bg-card);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:20px;width:100%;max-width:380px}.bracket-status--waiting p{font-size:18px;font-weight:600;color:var(--text)}.bracket-final-text{text-align:center;font-size:18px;font-weight:700;color:var(--success);animation:matchPop .5s ease}.page--no-match{justify-content:center;gap:16px;text-align:center}.page--no-match h1{font-size:26px;font-weight:800}.page--no-match p{color:var(--text-muted);margin-bottom:16px}.detail-modal__backdrop{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:60;display:flex;align-items:center;justify-content:center;padding:24px 16px;animation:fadeIn .2s ease}.detail-modal__content{position:relative;width:100%;max-width:420px;max-height:85dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg-card);border-radius:var(--radius);animation:modalPop .25s ease}.detail-modal__close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;border:none;background:#00000080;color:#fff;font-size:22px;line-height:1;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.detail-modal__close:active{opacity:.7}.detail-modal__photo{height:200px;overflow:hidden;background:var(--bg-elevated)}.detail-modal__photo img{width:100%;height:100%;object-fit:cover}.detail-modal__photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-elevated),var(--bg-card));font-size:48px}.detail-modal__body{padding:16px 20px 20px}.detail-modal__name{font-size:22px;font-weight:700;margin-bottom:6px}.detail-modal__meta{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--text-muted);margin-bottom:12px;flex-wrap:wrap}.detail-modal__stars{color:var(--accent);font-size:13px;letter-spacing:-1px}.detail-modal__rating{font-weight:600;color:var(--text)}.detail-modal__price{color:var(--success);font-weight:600}.detail-modal__distance{color:var(--secondary);font-weight:600}.detail-modal__loading{padding:16px 0}.detail-modal__address{font-size:14px;color:var(--text-muted);margin-bottom:10px;line-height:1.4}.detail-modal__phone{display:inline-block;font-size:14px;color:var(--primary);text-decoration:none;font-weight:600;margin-bottom:12px}.detail-modal__phone:active{opacity:.7}.detail-modal__hours{margin-bottom:12px}.detail-modal__section-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:4px;text-transform:uppercase;letter-spacing:1px}.detail-modal__hours ul{list-style:none;font-size:13px;color:var(--text-muted);line-height:1.6}.detail-modal__website{display:inline-block;font-size:14px;color:var(--secondary);text-decoration:none;font-weight:600;margin-bottom:16px}.detail-modal__website:active{opacity:.7}.detail-modal__directions{display:block;text-align:center;font-size:16px;width:100%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalPop{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.swipe-card__tap-hint{font-size:12px;color:var(--text-dim);margin-top:4px}@media(min-width:480px){.home-hero__title{font-size:40px}.swipe-card__name{font-size:26px}}
