*{margin:0;padding:0;box-sizing:border-box}:root{--bg:#0a0a0f;--surface:#141418;--surface2:#1e1e24;--surface3:#282830;--accent:#f59e0b;--accent-hover:#d97706;--accent-glow:rgba(245,158,11,0.15);--text:#e8e8ed;--text-muted:#6b6b80;--success:#22c55e;--danger:#ef4444;--radius:14px;--radius-sm:10px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}body,html{overscroll-behavior:none;-webkit-overflow-scrolling:touch;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);overflow:hidden;height:100dvh;width:100vw;line-height:1.4;-webkit-font-smoothing:antialiased}.drink-option,.request-card,button{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-touch-callout:none}.hidden{display:none!important}.welcome-screen{width:100%;height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:2rem;padding-top:calc(2rem + var(--safe-top));overflow-y:auto}.welcome-content{text-align:center;max-width:380px;width:100%}.welcome-content h1{font-size:2.2rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.4rem}.tagline{color:var(--text-muted);margin-bottom:2rem;font-size:1rem}.welcome-steps{text-align:left;display:flex;flex-direction:column;gap:.8rem;margin-bottom:1.5rem}.welcome-step{display:flex;align-items:center;gap:.8rem;background:var(--surface);padding:.8rem 1rem;border-radius:var(--radius-sm)}.welcome-step-icon{font-size:1.5rem;flex-shrink:0}.welcome-step strong{display:block;font-size:.9rem}.welcome-step p{color:var(--text-muted);font-size:.8rem;margin:0}.rules-box{text-align:left;background:var(--surface);padding:1rem 1.2rem;border-radius:var(--radius-sm);margin:1rem 0}.rules-title{font-weight:600;margin-bottom:.6rem;font-size:.9rem}.rules-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:.5rem;font-size:.85rem}.rules-list li:before{content:"• ";color:var(--accent)}.rules-note{color:var(--text-muted);font-size:.78rem;margin-top:.8rem;line-height:1.4}.rules-agree{margin:1rem 0;font-size:.85rem;justify-content:center}.ban-info{text-align:left;background:var(--surface);padding:1rem 1.2rem;border-radius:var(--radius-sm);margin:1rem 0;font-size:.9rem}.ban-info p{margin-bottom:.5rem}.ban-reason{color:var(--accent)}.ban-duration{color:var(--danger);font-size:.85rem}.ban-error{color:var(--danger);font-size:.8rem;margin-top:.4rem}.unban-form{text-align:left;margin-top:1.2rem}.unban-form h3{font-size:1rem;margin-bottom:.3rem}.unban-success{background:var(--surface);padding:1rem;border-radius:var(--radius-sm);margin-top:1rem;font-size:.9rem;color:var(--success)}.report-form h3{font-size:1.1rem;margin-bottom:.3rem}.report-done{text-align:center;padding:1rem 0}.report-done h3{margin-bottom:.5rem}.report-reasons{display:flex;flex-direction:column;gap:.4rem}.report-reason{display:flex;align-items:center;gap:.6rem;padding:.6rem .8rem;background:var(--surface);border-radius:var(--radius-sm);font-size:.85rem;cursor:pointer;border:1.5px solid transparent;transition:border-color .15s}.report-reason.selected{border-color:var(--accent);background:var(--accent-glow)}.report-reason input[type=radio]{display:none}.pin-actions-row{display:flex;gap:.5rem;margin-top:1rem}.btn-report{flex:1 1;padding:.6rem;border:1px solid var(--danger);background:transparent;color:var(--danger);border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer}.pin-actions-row .btn-block{flex:1 1;margin-top:0}.chat-header-right{display:flex;align-items:center;gap:.5rem}.chat-report-btn{background:none;border:none;font-size:1rem;cursor:pointer;padding:.2rem;opacity:.6}.chat-report-btn:active{opacity:1}.profile-form{display:flex;flex-direction:column;gap:.9rem}input[type=number],input[type=text],textarea{background:var(--surface2);border:1.5px solid transparent;color:var(--text);padding:.85rem 1rem;border-radius:var(--radius);font-size:.95rem;width:100%;outline:none;transition:border-color .2s,background .2s}input:focus,textarea:focus{border-color:var(--accent);background:var(--surface)}input::placeholder,textarea::placeholder{color:var(--text-muted)}textarea{resize:none;height:56px}.gender-select{display:flex;gap:.6rem;justify-content:center}.gender-select label{display:flex;align-items:center;gap:.4rem;cursor:pointer;padding:.55rem .9rem;background:var(--surface2);border-radius:var(--radius);border:1.5px solid transparent;transition:all .2s;font-size:.85rem;color:var(--text-muted)}.gender-select label:has(input:checked){border-color:var(--accent);background:var(--accent-glow);color:var(--text)}.gender-select input[type=radio]{accent-color:var(--accent);width:0;height:0;opacity:0;position:absolute}.btn-primary{background:var(--accent);color:#000;border:none;padding:.9rem;border-radius:var(--radius);font-size:1rem;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:background .2s,transform .1s}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.hint{color:var(--text-muted);font-size:.75rem;margin-top:2rem}.app-header{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;padding-top:calc(.5rem + var(--safe-top));background:rgba(10,10,15,.7);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.06)}.app-header h1{font-size:1.15rem;font-weight:700;letter-spacing:-.02em}.header-right{display:flex;align-items:center;gap:.7rem}.live-count{background:var(--accent-glow);padding:.25rem .7rem;border-radius:20px;font-size:.8rem;font-weight:600;color:var(--accent);letter-spacing:.01em}.btn-icon{background:none;border:none;font-size:1.3rem;cursor:pointer;padding:.25rem;transition:transform .1s}.btn-icon:active{transform:scale(.9)}.map-container{width:100%;height:100dvh;position:relative}.map-container .maplibregl-ctrl-top-right{top:calc(3rem + var(--safe-top));right:.5rem}.map-container .maplibregl-ctrl-group{background:var(--surface)!important;border:1px solid rgba(255,255,255,.08)!important;border-radius:var(--radius-sm)!important;box-shadow:0 2px 8px rgba(0,0,0,.4)!important;overflow:hidden}.map-container .maplibregl-ctrl-group button{background:transparent!important;border-color:rgba(255,255,255,.06)!important;width:36px!important;height:36px!important}.map-container .maplibregl-ctrl-group button+button{border-top:1px solid rgba(255,255,255,.06)!important}.map-container .maplibregl-ctrl-group button .maplibregl-ctrl-icon{filter:invert(1) brightness(.85)}.map-container .maplibregl-ctrl-group button:hover{background:var(--surface2)!important}.map-container .maplibregl-ctrl-attrib{display:none}.user-dot{width:14px;height:14px;border:2.5px solid #fff;box-shadow:0 0 12px rgba(245,158,11,.5)}.drink-marker,.own-drink-marker,.user-dot{background:var(--accent);border-radius:50%}.drink-marker,.own-drink-marker{width:40px;height:40px;border:2px solid #0a0a0f;display:flex;align-items:center;justify-content:center;color:#0a0a0f;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6));animation:popIn .25s cubic-bezier(.34,1.56,.64,1)}.drink-marker svg,.own-drink-marker svg{display:block}.own-drink-marker{filter:drop-shadow(0 0 10px rgba(245,158,11,.9));animation:pulse 2s infinite;border-color:#fff}@keyframes popIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.fab{position:fixed;bottom:calc(5.5rem + var(--safe-bottom));left:50%;transform:translateX(-50%);z-index:1000;background:var(--accent);color:#000;border:none;padding:.85rem 1.8rem;border-radius:50px;font-size:1rem;font-weight:700;letter-spacing:.02em;cursor:pointer;box-shadow:0 4px 24px rgba(245,158,11,.35);transition:transform .15s,box-shadow .15s;white-space:nowrap}.fab:active{transform:translateX(-50%) scale(.95);box-shadow:0 2px 12px rgba(245,158,11,.3)}.locate-btn{position:fixed;bottom:calc(5.5rem + var(--safe-bottom));right:1rem;width:3rem;height:3rem;border-radius:50%;border:none;background:var(--surface2);font-size:1.3rem;display:flex;box-shadow:0 2px 12px rgba(0,0,0,.4);cursor:pointer;z-index:400;transition:transform .15s}.locate-btn:active{transform:scale(.9)}.btn-notifications{position:fixed;bottom:calc(8rem + var(--safe-bottom));right:1rem;z-index:1000;background:var(--surface2);border:1px solid rgba(255,255,255,.08);color:var(--text);width:48px;height:48px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-notifications:active{transform:scale(.92)}.notif-badge{position:absolute;top:-3px;right:-3px;background:var(--danger);color:white;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px}.btn-chat-open{position:fixed;top:calc(3.5rem + var(--safe-top));left:50%;transform:translateX(-50%);z-index:1000;background:var(--success);color:#000;border:none;padding:.6rem 1.2rem;border-radius:50px;font-size:.85rem;font-weight:700;cursor:pointer;box-shadow:0 4px 15px rgba(34,197,94,.3);animation:slideDown .3s cubic-bezier(.34,1.56,.64,1);white-space:nowrap}@keyframes slideDown{0%{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.modal-overlay{position:fixed;inset:0;z-index:2000;display:flex;align-items:flex-end;justify-content:center;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border-radius:20px 20px 0 0;padding:1.2rem;padding-bottom:calc(1.2rem + var(--safe-bottom));width:100%;max-width:500px;max-height:85dvh;overflow-y:auto;animation:sheetUp .35s cubic-bezier(.32,.72,0,1)}.modal-sm{border-radius:20px;margin-bottom:calc(1rem + var(--safe-bottom));max-width:360px;padding-bottom:1.2rem}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.modal-header h2{font-size:1.1rem;font-weight:700;letter-spacing:-.01em}.modal-close{background:var(--surface2);border:none;color:var(--text-muted);font-size:1.3rem;cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s}.modal-close:active,.modal-content:before{background:var(--surface3)}.modal-content:before{content:"";display:block;width:36px;height:4px;border-radius:2px;margin:0 auto 1rem}.modal-sm:before{display:none}.drink-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:.7rem;gap:.7rem;margin-bottom:.9rem}.drink-option{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.9rem .5rem;background:var(--surface2);border:1.5px solid transparent;border-radius:var(--radius);font-size:1.8rem;cursor:pointer;transition:transform .12s,border-color .2s,background .2s}.drink-option span{font-size:.75rem;font-weight:500}.drink-option:active{transform:scale(.94)}.drink-option.selected{border-color:var(--accent);background:var(--accent-glow);color:var(--text)}.checkbox-label{display:flex;align-items:center;gap:.5rem;margin:.6rem 0;cursor:pointer;font-size:.9rem;color:var(--text-muted)}.checkbox-label input{accent-color:var(--accent);width:18px;height:18px;border-radius:4px}.pin-info{text-align:center;padding:.5rem 0}.pin-drink{font-size:2.8rem}.pin-selfie{width:5rem;height:5rem;border-radius:50%;overflow:hidden;margin:0 auto .6rem;border:2px solid var(--accent);cursor:pointer}.pin-selfie img{width:100%;height:100%;object-fit:cover}.pin-name{font-size:1.2rem;font-weight:700;letter-spacing:-.01em}.pin-meta{font-size:.8rem;margin:.25rem 0;letter-spacing:.01em}.pin-message,.pin-meta{color:var(--text-muted)}.pin-message{background:var(--surface2);padding:.5rem .9rem;border-radius:var(--radius-sm);margin:.7rem 0;font-style:italic;font-size:.85rem}.pin-distance{color:var(--accent);font-weight:600;font-size:.85rem}.fullscreen-selfie-overlay{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center}.fullscreen-selfie-overlay img{max-width:90vw;max-height:85vh;border-radius:var(--radius);object-fit:contain}.fullscreen-selfie-close{position:absolute;top:calc(1rem + var(--safe-top));right:1rem;background:rgba(255,255,255,.15);border:none;color:white;font-size:1.8rem;width:2.5rem;height:2.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.btn-join{width:100%;background:var(--accent);color:#000;border:none;padding:.8rem;border-radius:var(--radius);font-size:1rem;font-weight:700;cursor:pointer;margin-top:.8rem;transition:background .2s,transform .1s}.btn-join:hover{background:var(--accent-hover)}.btn-join:active{transform:scale(.97)}.btn-join:disabled{opacity:.4;cursor:not-allowed}.btn-block{margin-top:1rem;background:none;border:none;color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:color .15s}.btn-block:active{color:var(--danger)}.request-card{background:var(--surface2);border-radius:var(--radius);padding:.9rem;margin-bottom:.6rem;border:1px solid rgba(255,255,255,.04)}.request-name{font-weight:700;font-size:1rem}.request-drink{color:var(--text-muted);font-size:.8rem;margin-top:.15rem}.request-actions{display:flex;gap:.5rem;margin-top:.7rem}.btn-accept{padding:.55rem;border-radius:var(--radius-sm);font-size:.85rem}.btn-accept:active{transform:scale(.96)}.btn-decline{background:var(--surface3);border:none;padding:.55rem;border-radius:var(--radius-sm);font-size:.85rem}.btn-decline:active{transform:scale(.96)}.no-requests{text-align:center;color:var(--text-muted);padding:2rem 0;font-size:.9rem}.bottom-tabs{position:fixed;bottom:0;left:0;right:0;z-index:1500;display:flex;background:rgba(10,10,15,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.06);padding-bottom:var(--safe-bottom)}.tab{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.5rem 0;background:none;border:none;color:var(--text-muted);cursor:pointer;transition:color .15s;position:relative}.tab-active{color:var(--accent)}.tab-icon{font-size:1.3rem}.tab-label{font-size:.65rem;font-weight:600;letter-spacing:.03em}.tab-badge{position:absolute;top:2px;right:calc(50% - 18px);background:var(--danger);color:#fff;font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px}.inbox-screen{position:fixed;inset:0;z-index:1;background:var(--bg);overflow-y:auto;padding-bottom:calc(70px + var(--safe-bottom))}.inbox-header{padding:1rem 1.2rem .5rem;padding-top:calc(1rem + var(--safe-top))}.inbox-header h1{font-size:1.5rem;font-weight:800;letter-spacing:-.02em}.inbox-content{padding:.5rem 1rem}.inbox-section{margin-bottom:1.2rem}.inbox-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.5rem;padding-left:.2rem}.inbox-card{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border-radius:var(--radius);padding:.75rem;margin-bottom:.5rem;cursor:pointer;transition:background .15s;border:1px solid rgba(255,255,255,.04)}.inbox-card:active{background:var(--surface2)}.inbox-card-left{display:flex;align-items:center;gap:.7rem;flex:1 1;min-width:0}.inbox-avatar{font-size:1.6rem;flex-shrink:0}.inbox-selfie{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--surface3)}.inbox-name{font-weight:600;font-size:.9rem}.inbox-preview{color:var(--text-muted);font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.inbox-arrow{color:var(--text-muted);font-size:1.2rem;flex-shrink:0}.inbox-request-actions{display:flex;gap:.4rem;flex-shrink:0}.btn-accept-sm{background:var(--success);color:#000;border:none;padding:.4rem .9rem;border-radius:20px;font-weight:700;font-size:.78rem;cursor:pointer;transition:transform .1s}.btn-accept-sm:active{transform:scale(.95)}.btn-decline-sm{background:var(--surface2);color:var(--text-muted);border:none;width:32px;height:32px;border-radius:50%;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s}.btn-decline-sm:active{transform:scale(.9)}.request-modal{height:100dvh;display:flex;flex-direction:column;background:var(--bg)}.request-modal-header{display:flex;align-items:center;gap:.75rem;padding:.8rem 1rem;padding-top:calc(.8rem + var(--safe-top));background:var(--surface);border-bottom:1px solid rgba(255,255,255,.06)}.request-modal-header strong{font-size:1rem}.request-modal-body{flex:1 1;display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem;gap:.8rem}.request-modal-selfie{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid var(--accent);cursor:pointer;transition:transform .15s}.request-modal-selfie:active{transform:scale(.95)}.request-modal-emoji{font-size:4rem}.request-modal-name{font-size:1.3rem;font-weight:700}.request-modal-meta{color:var(--text-muted);font-size:.85rem}.request-modal-message{color:var(--text);font-size:1rem;text-align:center;font-style:italic;padding:1rem;background:var(--surface);border-radius:var(--radius);width:100%;max-width:320px}.request-modal-actions{display:flex;gap:.75rem;margin-top:1.5rem;width:100%;max-width:320px}.btn-accept{flex:1 1;background:var(--success);color:#000;border:none;padding:.8rem;border-radius:50px;font-weight:700;font-size:1rem;cursor:pointer;transition:transform .1s}.btn-accept:active{transform:scale(.95)}.btn-decline{flex:1 1;background:var(--surface2);color:var(--text-muted);border:1px solid rgba(255,255,255,.08);padding:.8rem;border-radius:50px;font-weight:600;font-size:1rem;cursor:pointer;transition:transform .1s}.btn-decline:active{transform:scale(.95)}.selfie-fullscreen{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;cursor:pointer}.selfie-fullscreen img{max-width:90vw;max-height:80dvh;border-radius:var(--radius);object-fit:contain}.selfie-fullscreen-close{position:absolute;top:calc(1rem + var(--safe-top));right:1rem;background:none;border:none;color:white;font-size:2rem;cursor:pointer;z-index:1}.profile-screen{position:fixed;inset:0;z-index:1;background:var(--bg);overflow-y:auto;padding-bottom:calc(70px + var(--safe-bottom))}.profile-header-section{padding:1rem 1.2rem .5rem;padding-top:calc(1rem + var(--safe-top))}.profile-header-section h1{font-size:1.5rem;font-weight:800;letter-spacing:-.02em}.profile-content{padding:.5rem 1rem}.profile-card{background:var(--surface);border-radius:var(--radius);padding:1.2rem;margin-bottom:.8rem;text-align:center;border:1px solid rgba(255,255,255,.04)}.profile-name-display{font-size:1.2rem;font-weight:700}.profile-gender{color:var(--text-muted);font-size:.8rem;margin-top:.2rem}.btn-edit{background:var(--surface2);color:var(--text);border:none;padding:.5rem 1.2rem;border-radius:20px;font-size:.8rem;font-weight:600;cursor:pointer;margin-top:.8rem;transition:transform .1s}.btn-edit:active{transform:scale(.96)}.profile-edit-form{display:flex;flex-direction:column;gap:.8rem;margin-top:.8rem}.profile-card-title{font-size:.8rem;font-weight:600;color:var(--text-muted);margin-bottom:.8rem}.session-info{display:flex;gap:.8rem}.session-drink-icon,.session-info{align-items:center;justify-content:center}.session-drink-icon{display:inline-flex;color:var(--accent);font-size:inherit}.session-drink-name{font-weight:600;font-size:.95rem}.session-time{color:var(--accent);font-size:.8rem;font-weight:600}.session-empty{color:var(--text-muted);font-size:.9rem}.btn-end-session{width:100%;background:none;border:1px solid var(--danger);color:var(--danger);padding:.6rem;border-radius:var(--radius);font-size:.8rem;font-weight:600;cursor:pointer;margin-top:.8rem;transition:background .15s}.btn-end-session:active{background:rgba(239,68,68,.1)}.btn-reset{width:100%;background:none;border:1px solid rgba(255,255,255,.06);color:var(--text-muted);padding:.7rem;border-radius:var(--radius);font-size:.8rem;cursor:pointer;margin-top:1rem}.chat-container{width:100%;max-width:500px;height:100dvh;display:flex;flex-direction:column;background:var(--bg);margin:0 auto;position:fixed;inset:0;z-index:1000}.chat-header{justify-content:space-between;padding:.6rem 1rem;padding-top:calc(.6rem + var(--safe-top));background:var(--surface);flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.06)}.chat-header,.chat-header-left{display:flex;align-items:center}.chat-header-left{gap:.6rem;min-width:0}.chat-partner-selfie{width:2.2rem;height:2.2rem;border-radius:50%;object-fit:cover;border:1.5px solid var(--accent);flex-shrink:0}.chat-partner-avatar{width:2.2rem;height:2.2rem;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.chat-header-info{display:flex;flex-direction:column;min-width:0}.chat-header-info strong{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header-status{font-size:.7rem;color:var(--success)}.chat-back{background:none;border:none;color:var(--text);font-size:1.3rem;cursor:pointer;padding:.2rem .3rem;flex-shrink:0}.chat-timer{color:var(--accent);font-size:.75rem;font-weight:600;background:var(--accent-glow);padding:.2rem .6rem;border-radius:6px;white-space:nowrap}.chat-progress{height:3px;background:var(--surface2);flex-shrink:0}.chat-progress-bar{height:100%;background:var(--accent);transition:width 1s linear}.chat-messages{flex:1 1;overflow-y:auto;overflow-x:hidden;padding:.6rem .8rem;display:flex;flex-direction:column;gap:.15rem;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.chat-messages-spacer{flex:1 1;min-height:0}.chat-system-msg{text-align:center;color:var(--text-muted);font-size:.75rem;padding:.5rem 1rem;margin-bottom:.3rem;background:rgba(255,255,255,.03);border-radius:12px}.chat-msg{display:flex;flex-direction:column;max-width:80%;margin-bottom:.1rem}.chat-msg-mine{align-self:flex-end;align-items:flex-end}.chat-msg-theirs{align-self:flex-start;align-items:flex-start}.chat-msg-bubble{padding:.5rem .85rem;border-radius:18px;font-size:.9rem;word-break:break-word;line-height:1.4}.chat-msg-mine .chat-msg-bubble{background:var(--accent);color:#000;border-bottom-right-radius:4px}.chat-msg-theirs .chat-msg-bubble{background:var(--surface2);color:var(--text);border-bottom-left-radius:4px}.chat-msg-time{font-size:.65rem;color:var(--text-muted);padding:.1rem .4rem;margin-top:.1rem;margin-bottom:.3rem}.chat-ended{text-align:center;padding:2rem 0}.chat-ended-icon{font-size:2.5rem}.chat-ended p{color:var(--text-muted);font-size:.9rem}.chat-input{display:flex;gap:.5rem;padding:.5rem .8rem;padding-bottom:calc(.5rem + var(--safe-bottom));background:var(--surface);border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}.chat-input input{flex:1 1;padding:.65rem .9rem;font-size:.9rem;border-radius:20px;background:var(--surface2);border:1px solid rgba(255,255,255,.08);color:var(--text);outline:none}.chat-input input:focus{border-color:var(--accent)}.chat-input button{background:var(--accent);color:#000;border:none;width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:transform .1s}.chat-input button:active{transform:scale(.9)}.chat-input button:disabled{opacity:.3}.empty-state{text-align:center;padding:3rem 1rem}.empty-icon{font-size:3rem}.empty-state p{color:var(--text-muted);font-size:.95rem}.empty-hint{font-size:.8rem!important;margin-top:.3rem}.empty-map-hint{top:calc(4rem + var(--safe-top));z-index:999;background:var(--surface);border:1px solid rgba(255,255,255,.06);color:var(--text-muted);padding:.7rem 1.2rem;border-radius:var(--radius);font-size:.8rem;text-align:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);line-height:1.4;max-width:calc(100% - 3rem)}.empty-map-hint,.toast{position:fixed;left:50%;transform:translateX(-50%)}.toast{top:calc(3.5rem + var(--safe-top));z-index:3000;background:var(--surface2);border:1px solid rgba(255,255,255,.08);color:var(--text);padding:.65rem 1.2rem;border-radius:50px;font-size:.85rem;font-weight:500;animation:toastIn .3s cubic-bezier(.34,1.56,.64,1),toastOut .25s ease 2.7s forwards;white-space:nowrap;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}@keyframes toastIn{0%{opacity:0;transform:translateX(-50%) translateY(-16px) scale(.95)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}@keyframes toastOut{to{opacity:0;transform:translateX(-50%) translateY(-8px)}}.location-prompt{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;background:var(--bg)}.location-prompt-content{text-align:center;padding:2rem}.location-prompt-content p{color:var(--text-muted);margin:1rem 0;font-size:.95rem}.spinner{width:36px;height:36px;border:2.5px solid var(--surface2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:1rem auto}@keyframes spin{to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;transition-duration:.01ms!important}}@media (min-width:768px){.modal-content{border-radius:20px;margin-bottom:2rem;padding-bottom:1.2rem}.modal-content:before{display:none}}.camera-overlay{position:fixed;inset:0;z-index:9999;background:#000;display:flex;flex-direction:column;align-items:center;justify-content:center}.camera-video{object-fit:cover;transform:scaleX(-1)}.camera-preview,.camera-video{width:100%;max-height:calc(100dvh - 100px)}.camera-preview{object-fit:contain}.camera-controls{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem calc(1.5rem + var(--safe-bottom));background:linear-gradient(transparent,rgba(0,0,0,.8))}.camera-cancel{background:none;border:none;color:white;font-size:1rem;cursor:pointer;padding:.5rem;min-width:60px}.camera-shutter{width:70px;height:70px;border-radius:50%;border:4px solid white;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s}.camera-shutter:active{transform:scale(.9)}.camera-shutter:disabled{opacity:.3}.camera-shutter-inner{width:56px;height:56px;border-radius:50%;background:white}.camera-confirm{background:var(--accent);color:#000;border:none;padding:.6rem 1.2rem;border-radius:50px;font-size:.95rem;font-weight:700;cursor:pointer}.camera-confirm:active{transform:scale(.95)}.camera-error{text-align:center;padding:2rem;color:var(--text)}.camera-error p{margin-bottom:1rem}.selfie-preview-small{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.selfie-preview-small img{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid var(--accent)}.selfie-retake{background:none;border:1px solid var(--text-muted);color:var(--text-muted);padding:.3rem .7rem;border-radius:20px;font-size:.8rem;cursor:pointer}.selfie-retake:active{opacity:.7}.btn-selfie{width:100%;padding:.9rem;border:2px dashed var(--accent);background:rgba(255,170,0,.08);color:var(--accent);border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:.8rem;transition:background .2s}.btn-selfie:hover{background:rgba(255,170,0,.15)}.btn-selfie:active{transform:scale(.97)}.btn-selfie:disabled{opacity:.4;cursor:not-allowed}.legal-page{position:fixed;inset:0;background:var(--bg);padding:1rem;padding-bottom:calc(2rem + var(--safe-bottom));overflow-y:auto;-webkit-overflow-scrolling:touch}.legal-content{max-width:720px;margin:0 auto;padding:1rem 0 4rem;color:var(--text);line-height:1.6}.legal-back{display:inline-block;color:var(--accent);text-decoration:none;font-size:.9rem;margin-bottom:1.5rem;padding:.4rem .8rem;border-radius:8px;background:var(--surface)}.legal-back:hover{background:var(--surface2)}.legal-content h1{font-size:1.8rem;margin:0 0 .3rem}.legal-content h2{font-size:1.15rem;margin:1.8rem 0 .6rem;color:var(--accent)}.legal-content p,.legal-content ul{margin:.6rem 0;font-size:.92rem}.legal-content ul{padding-left:1.2rem}.legal-content li{margin:.3rem 0}.legal-content a{color:var(--accent)}.legal-date{font-size:.8rem;opacity:.6;margin-bottom:1.5rem!important}.legal-links{display:flex;gap:.8rem;justify-content:center;margin-top:1rem;font-size:.82rem}.legal-links a{color:var(--accent);text-decoration:none;opacity:.8}.legal-links a:hover{opacity:1;text-decoration:underline}.modal-content{position:relative}.modal-warn{position:absolute;top:1.2rem;right:1.2rem;background:var(--surface2);border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:.95rem;display:flex;align-items:center;justify-content:center;padding:0;z-index:2;transition:background .15s}.modal-warn:hover{background:#3a3a3a}.modal-warn:active{transform:scale(.92)}.modal-xs{border-radius:20px;margin-bottom:calc(1rem + var(--safe-bottom));max-width:340px;padding:1.2rem;padding-bottom:calc(1.2rem + var(--safe-bottom));position:relative}.modal-xs .modal-close{position:absolute;top:.8rem;right:.8rem;z-index:2}.modal-xs h3{margin:0 2rem .3rem 0!important}.actions-row{display:flex;gap:.6rem}.actions-row .btn-block,.actions-row .btn-report{flex:1 1;margin:0;padding:.85rem;border-radius:12px;font-weight:600;cursor:pointer;font-size:.95rem}.legal-hero{text-align:center;padding:2rem 0 1.5rem;border-bottom:1px solid var(--surface2);margin-bottom:2rem}.legal-icon{font-size:3rem;margin-bottom:.8rem}.legal-hero h1{font-size:2rem!important;margin:0!important;background:linear-gradient(135deg,var(--accent),#ffcc55);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.legal-hero .legal-date{margin-top:.5rem!important;font-size:.82rem}.legal-intro{background:var(--surface);padding:1.2rem;border-radius:14px;margin-bottom:2rem;border-left:3px solid var(--accent)}.legal-intro p{margin:0!important;font-size:.95rem}.legal-section{margin-bottom:2rem}.legal-section h2{display:flex;align-items:center;gap:.6rem;margin:0 0 .8rem!important;font-size:1.1rem!important;color:var(--text)!important}.legal-num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--accent);color:#000;font-size:.85rem;font-weight:700;flex-shrink:0}.legal-rules{list-style:none!important;padding-left:0!important}.legal-rules li{position:relative;padding-left:1.4rem;margin:.55rem 0!important;font-size:.92rem;line-height:1.5}.legal-rules li:before{content:"→";position:absolute;left:0;color:var(--accent);font-weight:700}.legal-highlight{background:var(--surface);padding:1.2rem;border-radius:14px;border-left:3px solid var(--accent)}.legal-highlight h2{margin-top:0!important}.legal-warn{background:rgba(255,170,0,.1);padding:.8rem;border-radius:10px;font-size:.9rem!important}.legal-note,.legal-warn{margin-top:.8rem!important}.legal-note{font-size:.85rem!important;opacity:.75;font-style:italic}.legal-contact-box{background:var(--surface);padding:.9rem 1.2rem;border-radius:12px;margin-top:.6rem!important;text-align:center}.legal-contact-box a{font-size:1rem}.legal-contact{background:var(--surface);padding:1.5rem 1.2rem;border-radius:14px;text-align:center;margin-top:3rem}.legal-contact h2{justify-content:center}.welcome-logo{width:192px;height:192px;display:block;margin:0 auto .8rem;filter:drop-shadow(0 4px 20px rgba(255,170,0,.25))}.header-logo{width:24px;height:24px;vertical-align:middle}.app-header h1,.welcome-content h1{display:inline-flex;align-items:center;gap:.5rem}.app-header h1 svg,.welcome-content h1 svg{color:var(--accent)}.welcome-step-icon{color:var(--accent);width:2rem}.tab-icon,.welcome-step-icon{display:inline-flex;align-items:center;justify-content:center}.tab-icon{height:22px}.drink-option{color:var(--text-muted);font-size:inherit}.drink-option svg{transition:color .2s}.drink-option.selected,.drink-option.selected svg{color:var(--accent)}.pin-drink{display:flex;color:var(--accent);margin-bottom:.4rem;font-size:inherit}.chat-report-btn,.modal-warn,.pin-drink{align-items:center;justify-content:center}.chat-report-btn,.modal-warn{display:inline-flex;color:var(--text-muted)}.chat-report-btn svg,.modal-warn svg{display:block}.chat-back{display:inline-flex;align-items:center;justify-content:center}.chat-back svg{display:block}.chat-partner-avatar{color:var(--text-muted)}.chat-partner-avatar svg{display:block}.chat-ended-icon{margin-bottom:.5rem}.chat-ended-icon,.empty-icon{display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:inherit}.empty-icon{opacity:.7;margin-bottom:.8rem}.inbox-avatar{display:inline-flex;width:40px;height:40px;border-radius:50%;background:var(--surface2)}.inbox-avatar,.request-modal-emoji{align-items:center;justify-content:center;color:var(--accent);font-size:inherit}.request-modal-emoji{display:flex;margin-bottom:.5rem}.btn-join,.btn-primary,.btn-selfie,.fab{display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.fab{gap:.4rem}.btn-join svg,.btn-selfie svg,.fab svg{flex-shrink:0}.locate-btn{display:inline-flex;align-items:center;justify-content:center;color:var(--text)}.locate-btn svg{display:block}.admin-root{position:fixed;inset:0;background:#0a0a0f;color:#e8e8ee;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}.admin-topbar{position:-webkit-sticky;position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;padding:calc(12px + env(safe-area-inset-top)) 16px 12px;background:#12121a;border-bottom:1px solid #252533}.admin-topbar-title{flex:1 1;font-size:17px;font-weight:700;color:#e8e8ee;letter-spacing:-.01em}.admin-topbar-nav{display:none}.admin-logout-btn{background:transparent;border:none;color:#a0a0b0;padding:8px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.admin-logout-btn:hover{background:#1e1e2a;color:#e8e8ee}.admin-main{flex:1 1;padding:16px 16px calc(76px + env(safe-area-inset-bottom));width:100%}.admin-tabbar{position:fixed;bottom:0;left:0;right:0;z-index:20;display:flex;background:rgba(18,18,26,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid #252533;padding-bottom:env(safe-area-inset-bottom)}.admin-tab{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 4px 8px;color:#6a6a7a;text-decoration:none;font-size:10px;font-weight:500;transition:color .15s;-webkit-tap-highlight-color:transparent}.admin-tab.active{color:#ffaa00}.admin-tab:active{color:#ffaa00;opacity:.7}.admin-page h1{display:none}.admin-section{margin-bottom:24px}.admin-section h2{display:flex;align-items:center;gap:8px;margin:0 0 10px;padding:0 4px;font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.08em}.admin-section h3{margin:0 0 10px;font-size:13px;color:#a0a0b0;font-weight:600}.admin-stats-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.admin-stat-card{display:flex;align-items:flex-start;gap:10px;padding:14px;background:#12121a;border:1px solid #1e1e2a;border-radius:14px}.admin-stat-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(255,170,0,.1);border-radius:10px;color:#ffaa00;flex-shrink:0}.admin-stat-body{flex:1 1;min-width:0}.admin-stat-label{font-size:11px;color:#888;line-height:1.3}.admin-stat-value{font-size:20px;font-weight:700;margin-top:2px;letter-spacing:-.02em}.admin-stat-hint{font-size:10px;color:#666;margin-top:3px;line-height:1.3}.admin-funnel{gap:10px}.admin-funnel,.admin-funnel-row{display:flex;flex-direction:column}.admin-funnel-row{align-items:stretch;gap:6px}.admin-funnel-label{width:100%;font-size:12px;color:#a0a0b0;padding:0 2px}.admin-funnel-bar{position:relative;height:26px;background:#12121a;border:1px solid #1e1e2a;border-radius:8px;overflow:hidden}.admin-funnel-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#ffaa00,#ff6b00);border-radius:8px 0 0 8px;transition:width .3s}.admin-funnel-value{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:11px;font-weight:600;color:#fff;z-index:1;text-shadow:0 1px 2px rgba(0,0,0,.5)}@media (min-width:768px){.admin-topbar{padding:calc(12px + env(safe-area-inset-top)) 24px 12px}.admin-topbar-nav{display:flex;gap:4px;flex:1 1;justify-content:center}.admin-topbar-link{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:8px;color:#a0a0b0;text-decoration:none;font-size:13px;font-weight:500;transition:background .15s,color .15s}.admin-topbar-link:hover{background:#1e1e2a;color:#e8e8ee}.admin-topbar-link.active{background:#ffaa00;color:#0a0a0f;font-weight:600}.admin-topbar-title{flex:0 1 auto}.admin-tabbar{display:none}.admin-main{padding:24px;max-width:1200px;margin:0 auto}.admin-stats-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.admin-stat-card{padding:14px}.admin-stat-value{font-size:22px}.admin-funnel-row{flex-direction:row;align-items:center;gap:12px}.admin-funnel-label{width:160px;flex-shrink:0}.admin-funnel-bar{flex:1 1}.admin-section h2{font-size:12px;padding:0}}.admin-table{width:100%;border-collapse:collapse;font-size:13px;display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}@media (min-width:768px){.admin-table{display:table;white-space:normal;overflow-x:visible}}.admin-table th{text-align:left;padding:10px 12px;background:#1a1a24;color:#a0a0b0;font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.05em;border-bottom:1px solid #252533}.admin-table td{padding:10px 12px;border-bottom:1px solid #1e1e2a;vertical-align:top}.admin-table tr:hover td{background:#16161e}.admin-device{font-family:monospace;font-size:11px;color:#888}.admin-muted{color:#888}.admin-small{font-size:12px}.admin-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;background:#252533;color:#a0a0b0}.admin-badge-red{background:rgba(239,68,68,.2);color:#ef4444}.admin-badge-warn{background:rgba(245,158,11,.2);color:#f59e0b}.admin-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;margin-right:4px;background:#252533;border:1px solid #353545;border-radius:6px;color:#e8e8ee;font-size:12px;cursor:pointer;transition:background .15s}.admin-btn:hover{background:#353545}.admin-btn-sm{padding:4px 8px;font-size:11px}.admin-btn-warn{background:rgba(245,158,11,.2);border-color:#f59e0b;color:#f59e0b}.admin-btn-danger{background:rgba(239,68,68,.2);border-color:#ef4444;color:#ef4444}.admin-btn-ok{background:rgba(34,197,94,.2);border-color:#22c55e;color:#22c55e}.admin-appeals{display:flex;flex-direction:column;gap:12px}.admin-appeal-card{background:#1a1a24;border:1px solid #252533;border-radius:10px;padding:16px}.admin-appeal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;flex-wrap:wrap;gap:8px}.admin-appeal-msg{margin:0 0 12px;padding:10px 14px;background:#0a0a0f;border-left:3px solid #ffaa00;border-radius:0 6px 6px 0;font-size:13px;line-height:1.5;white-space:pre-wrap}.admin-appeal-actions{display:flex;gap:8px}.admin-demo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:20px;gap:20px}.admin-list{list-style:none;margin:0;padding:0}.admin-list li{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #1e1e2a;font-size:13px}.admin-list li:last-child{border-bottom:none}.admin-legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:12px;font-size:12px}.admin-legend-item{display:inline-flex;align-items:center;gap:6px;color:#a0a0b0}.admin-legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.admin-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0a0a0f;padding:20px;position:fixed;inset:0}.admin-login-card{background:#12121a;border:1px solid #252533;border-radius:12px;padding:32px;max-width:400px;width:100%}.admin-login-card h1{margin:0 0 16px;color:#ffaa00;font-size:22px}.admin-login-card p{color:#a0a0b0;margin:0 0 16px;font-size:14px;line-height:1.5}.admin-login-card button{width:100%;padding:12px;background:#ffaa00;color:#0a0a0f;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer}.admin-login-card button:disabled{opacity:.6;cursor:not-allowed}.admin-error{background:rgba(239,68,68,.15);color:#ef4444;padding:10px 14px;border-radius:8px;font-size:13px;border:1px solid rgba(239,68,68,.3)}.admin-sent{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);padding:14px;border-radius:8px}.admin-sent p:last-child{margin-bottom:0}