@import url(https://fonts.googleapis.com/css2?family=Fredoka:wght@300..700&display=swap);*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;height:var(--app-height,100%);min-height:100%;min-height:var(--app-height,100%);overflow:hidden;width:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#e0f2fe;background-color:var(--st-bg);color:#243447;color:var(--st-text);font-family:Be Vietnam Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;transition:background-color .3s ease,color .3s ease}#root{height:100%;height:var(--app-height,100%);min-height:100%;min-height:var(--app-height,100%);width:100%}body.dark-theme{--st-bg:#0f172a;--st-surface:#1e293b;--st-surface-muted:#0f172a;--st-text:#f8fafc;--st-text-muted:#94a3b8;--st-border:#334155;--st-shadow:0 8px 24px #00000059;--game-border-color:#0d131f;--podium-1-bg:#2e2610;--podium-2-bg:#1e293b;--podium-3-bg:#2b1d12}::-webkit-scrollbar{background:#0000;width:0}::-webkit-scrollbar-thumb{background:#0000}*{-ms-overflow-style:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;scrollbar-width:none;-webkit-user-select:none;user-select:none}button,input,select,textarea{font-family:inherit;font-size:16px}input,select,textarea{-webkit-touch-callout:default;-webkit-user-select:auto;user-select:auto}:root{--st-bg:#e0f2fe;--st-surface:#fff;--st-surface-muted:#f8fafc;--st-text:#243447;--st-text-muted:#64748b;--st-border:#cbd5e1;--st-primary:#2563eb;--st-success:#16a34a;--st-warning:#f59e0b;--st-danger:#ef4444;--st-radius:16px;--st-shadow:0 8px 24px #0f172a14;--game-border-color:#2c3e50;--game-border-width:3px;--game-shadow-offset:6px;--podium-1-bg:#fff9e6;--podium-2-bg:#f5f6fa;--podium-3-bg:#fff3eb;--game-yellow:#ffd32d;--game-yellow-dark:#e5b300;--game-orange:#ff9f1a;--game-orange-dark:#d37c00;--game-green:#2ed573;--game-green-dark:#26af5f;--game-blue:#1e90ff;--game-blue-dark:#0f75d8;--game-sky:#70a1ff;--game-red:#ff4757;--game-red-dark:#d63031;--game-purple:#9b59b6;--game-purple-dark:#8e44ad}.cartoon-card{background-color:#fff;background-color:var(--st-surface);border:3px solid #2c3e50;border:var(--game-border-width) solid var(--game-border-color);border-radius:24px;transition:transform .2s ease,box-shadow .2s ease,background-color .3s ease,border-color .3s ease}.cartoon-card,.squishy-btn{box-shadow:0 6px 0 #2c3e50;box-shadow:0 var(--game-shadow-offset) 0 var(--game-border-color)}.squishy-btn{align-items:center;background-color:#ff9f1a;background-color:var(--game-orange);border:3px solid #2c3e50;border:var(--game-border-width) solid var(--game-border-color);border-radius:20px;color:#fff;cursor:pointer;display:inline-flex;font-size:15px;font-weight:800;justify-content:center;outline:none;padding:12px 24px;position:relative;text-transform:uppercase;transition:transform .1s ease,box-shadow .1s ease}.squishy-btn:hover{box-shadow:0 4px 0 #2c3e50;box-shadow:0 calc(var(--game-shadow-offset) - 2px) 0 var(--game-border-color);transform:translateY(2px)}.squishy-btn:active{box-shadow:0 0 0 #2c3e50;box-shadow:0 0 0 var(--game-border-color);transform:translateY(6px);transform:translateY(var(--game-shadow-offset))}.squishy-btn.green{background-color:#2ed573;background-color:var(--game-green)}.squishy-btn.yellow{background-color:#ffd32d;background-color:var(--game-yellow);color:#2c3e50}.squishy-btn.blue{background-color:#1e90ff;background-color:var(--game-blue)}.squishy-btn.red{background-color:#ff4757;background-color:var(--game-red)}@keyframes float-bouncy{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-8px) rotate(1deg)}}@keyframes mascot-wiggle{0%,to{transform:rotate(0deg)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}@keyframes cloud-slide{0%{transform:translateX(-150px)}to{transform:translateX(500px)}}.board-title,.hud-player-name,.hud-player-tier,.plan-banner h3,.quest-reward,.section-title,.squishy-btn,.tour-title,h1,h2,h3,h4,h5,h6{font-family:Fredoka,Be Vietnam Pro,sans-serif}.app-outer{align-items:stretch;background-color:#e4e5e6;justify-content:center}.app-container,.app-outer{display:flex;height:100%;width:100%}.app-container{background-color:#fff;flex-direction:column;overflow:hidden;position:relative;transform:translate(0)}html.chat-ios-standalone-active .app-container,html.comments-ios-standalone-active .app-container,html.support-ios-standalone-active .app-container{transform:none}.app-main-screen{height:100%;min-height:0;position:relative;width:100%}.app-container-workmode{background:#f8fafc}.app-forbidden-screen{align-items:center;background:#f8fafc;color:#0f172a;display:flex;flex-direction:column;gap:12px;height:100%;justify-content:center;padding:32px 20px;text-align:center}.app-forbidden-screen h2{font-size:22px;margin:0}.app-forbidden-screen p{color:#64748b;line-height:1.45;margin:0}.app-forbidden-screen button{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;cursor:pointer;font-weight:700;min-height:40px;padding:0 16px}@media (min-width:768px){.app-outer{align-items:center;padding:10px 0}.app-container{border-radius:20px;box-shadow:0 20px 60px #00000026;height:100%;max-height:932px}.app-container,.app-container-adminmode,.app-container-workmode{max-width:430px}}.splash-container{height:100%;justify-content:flex-end;min-height:100%;position:relative}.splash-bottom-section,.splash-container{align-items:center;display:flex;flex-direction:column;width:100%}.splash-bottom-section{background:linear-gradient(0deg,#000000b3 0,#0000);padding-bottom:50px;padding-top:40px}.loading-text{color:#fff;font-family:Inter,sans-serif;font-size:15px;font-weight:700;letter-spacing:.5px;margin-bottom:12px;text-shadow:1px 1px 4px #000c}.progress-container{background-color:#fff3;border:1px solid #ffffff1a;border-radius:10px;box-shadow:0 2px 10px #0000004d;height:8px;max-width:300px;overflow:hidden;width:75%}.progress-bar{background:linear-gradient(90deg,#f59e0b,#fcd34d);border-radius:10px;box-shadow:0 0 10px #fcd34dcc;height:100%;transition:width .1s linear}.welcome-container{background:linear-gradient(180deg,#70a1ff,#1e90ff);box-sizing:border-box;display:flex;flex-direction:column;font-family:Fredoka,sans-serif;height:100%;margin:0 auto;min-height:100%;overflow:hidden;padding:calc(24px + env(safe-area-inset-top, 0px)) 24px 32px;position:relative;width:100%}.game-cloud{background-color:#ffffffb3;border-radius:40px;pointer-events:none;position:absolute;z-index:1}.game-cloud:after,.game-cloud:before{background-color:#ffffffb3;border-radius:50%;content:"";position:absolute}.cloud-1{animation:cloud-slide 25s linear infinite;height:40px;left:-20px;top:15%;width:120px}.cloud-1:before{height:50px;left:20px;top:-20px;width:50px}.cloud-1:after{height:40px;right:20px;top:-15px;width:40px}.cloud-2{animation:cloud-slide 32s linear infinite reverse;height:45px;right:-40px;top:45%;width:140px}.cloud-2:before{height:60px;left:25px;top:-25px;width:60px}.cloud-2:after{height:45px;right:25px;top:-15px;width:45px}.cloud-3{animation:cloud-slide 20s linear infinite;height:35px;left:20%;top:75%;width:100px}.cloud-3:before{height:45px;left:15px;top:-15px;width:45px}.cloud-3:after{height:35px;right:15px;top:-10px;width:35px}.skip-btn{align-self:flex-end;border-radius:16px!important;box-shadow:0 4px 0 #2c3e50!important;font-size:13px!important;height:auto!important;min-height:0!important;padding:6px 16px!important;z-index:10}.character-lobby-card{animation:float-bouncy 4s ease-in-out infinite;background-color:#fff;border:4px solid #2c3e50;border-radius:32px;box-shadow:0 8px 0 #2c3e50,0 15px 25px #00000026;flex-direction:column;height:200px;margin:30px auto 10px;padding:20px;width:180px;z-index:5}.character-avatar-wrapper,.character-lobby-card{align-items:center;display:flex;justify-content:center;position:relative}.character-avatar-wrapper{background:radial-gradient(circle,#ffeaa7 0,#ffd32d 100%);border:3px solid #2c3e50;border-radius:50%;height:110px;width:110px}.lobby-mascot-img{height:85px;object-fit:contain;width:85px}.level-badge-float{background-color:#ff4757;border:2px solid #2c3e50;border-radius:8px;bottom:-5px;box-shadow:0 2px 0 #2c3e50;color:#fff;font-size:11px;font-weight:900;padding:2px 8px;position:absolute;right:-5px}.character-stats-row{display:flex;gap:8px;margin-top:14px}.stat-pill{background-color:#f1f2f6;border:2px solid #2c3e50;border-radius:10px;color:#2c3e50;font-size:11px;font-weight:800;padding:2px 8px}.text-section{align-items:center;background:#ffffffe6;border:3px solid #2c3e50;border-radius:24px;box-shadow:0 6px 0 #2c3e50;display:flex;flex-direction:column;margin-top:15px;padding:16px 20px;text-align:center;z-index:5}.title-line{-webkit-text-stroke:1.5px #2c3e50;font-size:32px;font-weight:900;letter-spacing:-.5px;line-height:1.1;margin:0;text-shadow:1px 1px 0 #fff}.text-yellow{color:#ffd32d}.text-blue{align-items:center;color:#1e90ff;display:flex;gap:6px}.sparkle-icon{margin-bottom:2px}.sub-text{color:#57606f;font-size:13px;font-weight:600;line-height:1.4;margin-top:8px}.btn-group{display:flex;flex-direction:column;gap:14px;margin-bottom:5px;margin-top:auto;z-index:5}.btn-primary{background-color:#ff9f1a!important;color:#fff}.btn-outline,.btn-primary{font-size:16px!important;padding:14px!important}.btn-outline{background-color:#ffd32d!important;color:#2c3e50!important}@media (min-width:481px){.welcome-container{border:5px solid #2c3e50;border-radius:40px;box-shadow:0 10px 30px #0003;height:100%;max-width:480px;min-height:auto}}.login-container{background:#e0f2fe;background:var(--st-bg,#e0f2fe);box-sizing:border-box;font-family:Be Vietnam Pro,sans-serif;height:100%;min-height:100%;overflow-y:auto;padding:calc(24px + env(safe-area-inset-top, 0px)) 20px 20px;width:100%}.login-container form{background:#fff;background:var(--st-surface,#fff);border:3px solid #2c3e50;border-radius:22px;box-shadow:0 6px 0 #2c3e50;padding:18px 14px}.login-title{font-size:34px;margin-bottom:18px;text-align:center}.login-input,.login-title{color:#243447;color:var(--st-text,#243447)}.login-input{background:#fffde8;border:2px solid #2c3e50;border-radius:12px;box-sizing:border-box;font-size:16px;margin-bottom:12px;min-height:46px;padding:12px 14px;width:100%}.login-input:focus{border-color:#1e90ff;box-shadow:0 0 0 3px #1e90ff33;outline:none}.login-button{background-color:#1e90ff;border:3px solid #2c3e50;border-radius:12px;box-shadow:0 4px 0 #2c3e50;color:#fff;cursor:pointer;font-size:16px;font-weight:700;min-height:46px;padding:12px;width:100%}.login-button:active{box-shadow:0 1px 0 #2c3e50;transform:translateY(3px)}.error-msg{color:#ef4444;font-size:13px;font-weight:600;margin-top:10px;text-align:center}.auth-back{align-items:center;background:#fff;border:2px solid #2c3e50;border-radius:10px;box-shadow:0 3px 0 #2c3e50;color:#243447;color:var(--st-text,#243447);cursor:pointer;display:inline-flex;font-size:18px;font-weight:700;margin-bottom:14px;min-height:44px;padding:0 10px}.auth-google-row{display:flex;justify-content:center;margin-top:16px}.auth-link-row{display:flex;font-size:14px;gap:12px;justify-content:space-between;margin-top:16px}.auth-link{color:#0ea5e9;cursor:pointer;font-weight:700}.auth-center-link-row{font-size:14px;margin-top:20px;text-align:center}.auth-form-stack{display:flex;flex-direction:column;gap:15px}.auth-helper-text{color:#747d8c;font-size:14px;text-align:center}.auth-success-msg{color:green;font-size:14px}.auth-register-message,.auth-success-msg{font-weight:700;text-align:center}.auth-register-message.success{color:green}.auth-register-message.error{color:red}.auth-success-overlay{align-items:center;background:#24344761;display:flex;inset:0;justify-content:center;padding:22px;position:absolute;z-index:70}.auth-success-dialog{background:#fff;border:3px solid #2c3e50;border-radius:18px;box-shadow:0 8px 0 #2c3e50;color:#243447;color:var(--st-text,#243447);padding:24px 18px 18px;position:relative;text-align:center;width:min(100%,340px)}.auth-success-dialog.enterprise{background:#fff7df}.auth-success-close{align-items:center;background:#fff;border:2px solid #2c3e50;border-radius:10px;box-shadow:0 2px 0 #2c3e50;color:#2c3e50;cursor:pointer;display:inline-flex;height:34px;justify-content:center;position:absolute;right:10px;top:10px;width:34px}.auth-success-close:active,.auth-success-primary:active{box-shadow:0 1px 0 #2c3e50;transform:translateY(2px)}.auth-success-icon{align-items:center;background:#34d399;border:3px solid #2c3e50;border-radius:50%;box-shadow:0 4px 0 #2c3e50;color:#fff;display:inline-flex;height:68px;justify-content:center;margin:0 auto 12px;width:68px}.auth-success-dialog.enterprise .auth-success-icon{background:#f59e0b}.auth-success-dialog h3{font-size:22px;line-height:1.2;margin:0 0 8px}.auth-success-dialog p{color:#475569;font-size:14px;font-weight:700;line-height:1.45;margin:0}.auth-success-actions{margin-top:18px}.auth-success-primary{align-items:center;background:#1e90ff;border:3px solid #2c3e50;border-radius:12px;box-shadow:0 4px 0 #2c3e50;color:#fff;cursor:pointer;display:inline-flex;font-size:15px;font-weight:900;gap:7px;justify-content:center;min-height:46px;width:100%}.auth-success-primary.enterprise{background:#f59e0b}.role-toggle-row{display:flex;gap:10px;margin:15px 0 20px}.role-toggle-btn{border:2px solid #2c3e50;border-radius:10px;box-shadow:0 3px 0 #2c3e50;cursor:pointer;flex:1 1;font-weight:700;min-height:44px;padding:10px;transition:.3s}.role-toggle-btn.inactive{background-color:#fff;color:#2c3e50}.role-toggle-btn.user-active{background-color:#34d399;color:#fff}.role-toggle-btn.enterprise-active{background-color:#f59e0b;color:#fff}.role-toggle-btn:active{box-shadow:0 1px 0 #2c3e50;transform:translateY(2px)}.enterprise-profile-fields{background:#f8fafc;border:2px solid #2c3e50;border-radius:12px;margin:4px 0 12px;padding:12px}.enterprise-profile-fields h3{color:#243447;color:var(--st-text,#243447);font-size:16px;margin:0 0 10px}.enterprise-profile-fields .login-input:last-child{margin-bottom:0}.register-submit-btn{background-color:#2ed573}.forgot-submit-btn{background-color:#1e90ff}.reset-submit-btn{background-color:#22c55e}.auth-success-dialog.error{background:#fff5f5;border-color:#e53e3e;box-shadow:0 8px 0 #e53e3e;color:#9b2c2c}.auth-success-dialog.error .auth-success-close{border-color:#e53e3e;box-shadow:0 2px 0 #e53e3e;color:#e53e3e}.auth-success-dialog.error .auth-success-icon{border-color:#e53e3e;box-shadow:0 4px 0 #e53e3e}.auth-success-dialog.error p{color:#c53030}.auth-spinner{animation:auth-spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;flex-shrink:0;height:18px;width:18px}@keyframes auth-spin{to{transform:rotate(1turn)}}.login-error-alert{align-items:center;animation:errorSlideIn .3s cubic-bezier(.175,.885,.32,1.275);background:linear-gradient(135deg,#fff5f5,#ffe3e3);border:2.5px solid #2c3e50;border-radius:12px;box-shadow:0 3px 0 #2c3e50;display:flex;justify-content:space-between;margin-bottom:14px;padding:10px 12px}.login-error-alert .alert-content{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0}.login-error-alert .alert-icon{color:#e74c3c;flex-shrink:0}.login-error-alert .alert-text{color:#c0392b;font-size:12px;font-weight:700;line-height:1.4;overflow-wrap:break-word;text-align:left;word-break:break-word}.login-error-alert .alert-close-btn{align-items:center;background:#0000;border:none;color:#7f8c8d;cursor:pointer;display:flex;font-size:12px;font-weight:700;justify-content:center;padding:2px 6px;transition:color .15s ease,transform .1s ease}.login-error-alert .alert-close-btn:hover{color:#2c3e50;transform:scale(1.15)}.login-error-alert .alert-close-btn:active{transform:scale(.9)}@keyframes errorSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-shake{animation:errorShake .4s ease-in-out}@keyframes errorShake{0%,to{transform:translateX(0)}20%,60%{transform:translateX(-4px)}40%,80%{transform:translateX(4px)}}.password-input-container{margin-bottom:12px;position:relative;width:100%}.password-input-container .login-input{margin-bottom:0;padding-right:44px}.password-toggle-btn{align-items:center;background:#0000;border:none;color:#2c3e50;cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:color .2s ease,transform .1s ease;z-index:10}.password-toggle-btn:hover{color:#1e90ff;transform:translateY(-50%) scale(1.1)}.password-toggle-btn:active{transform:translateY(-50%) scale(.9)}body.dark-theme .login-container form{border-color:var(--game-border-color);box-shadow:0 6px 0 var(--game-border-color)}body.dark-theme .login-input{background:var(--st-surface-muted);border-color:var(--game-border-color)}body.dark-theme .login-button{border-color:var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .auth-back{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color)}body.dark-theme .password-toggle-btn{color:var(--st-text-muted)}body.dark-theme .auth-success-dialog{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 8px 0 var(--game-border-color)}body.dark-theme .auth-success-close{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 2px 0 var(--game-border-color);color:var(--st-text)}body.dark-theme .auth-success-primary{border-color:var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .role-toggle-btn.inactive{background-color:var(--st-surface);color:var(--st-text)}body.dark-theme .role-toggle-btn.inactive,body.dark-theme .role-toggle-btn:not(.inactive){border-color:var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color)}body.dark-theme .enterprise-profile-fields{background-color:var(--st-surface-muted);border-color:var(--game-border-color)}body.dark-theme .login-error-alert{background:linear-gradient(135deg,#2a1b1b,#3d1c1c);border-color:var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color)}.tutorial-container{background:linear-gradient(135deg,#1a2980,#26d0ce);box-sizing:border-box;height:100%;justify-content:center;min-height:100%;padding:20px}.tutorial-card,.tutorial-container{align-items:center;display:flex;width:100%}.tutorial-card{animation:fadeIn .5s ease-out;background:#fffffff2;border-radius:20px;box-shadow:0 20px 40px #0003;flex-direction:column;max-width:400px;padding:40px 30px;text-align:center}.tutorial-icon-wrapper{align-items:center;background:linear-gradient(135deg,#fdfbfb,#ebedee);border-radius:50%;box-shadow:0 10px 20px #0000000d;display:flex;height:100px;justify-content:center;margin-bottom:25px;width:100px}.tutorial-icon{font-size:50px}.tutorial-title{color:#1a2980;font-size:22px;font-weight:700;line-height:1.3;margin-bottom:15px}.tutorial-desc{color:#555;font-size:15px;line-height:1.6;margin-bottom:30px;min-height:72px}.tutorial-dots{display:flex;gap:8px;margin-bottom:30px}.tutorial-dot{background-color:#ddd;border-radius:50%;cursor:pointer;height:10px;transition:all .3s ease;width:10px}.tutorial-dot.active{background-color:#26d0ce;border-radius:5px;width:25px}.tutorial-btn{align-items:center;background:linear-gradient(135deg,#1a2980,#26d0ce);border:none;border-radius:12px;box-shadow:0 10px 20px #26d0ce4d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;padding:14px;transition:transform .2s,box-shadow .2s;width:100%}.tutorial-btn:hover{box-shadow:0 12px 25px #26d0ce66;transform:translateY(-2px)}.tutorial-btn:active{transform:translateY(0)}.trip-plan-screen{background:#0abde3;box-sizing:border-box;height:100%;min-height:100%;overflow-y:auto;padding:calc(14px + env(safe-area-inset-top, 0px)) 14px calc(88px + env(safe-area-inset-bottom, 0px))}.wizard-container{background-color:#fff;border:none;border-radius:28px;box-shadow:0 10px 30px #0000001a;box-sizing:border-box;margin:0 auto;max-width:430px;min-height:calc(100dvh - 116px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));outline:none;padding:56px 24px 24px;position:relative;width:100%}.back-wizard-btn{align-items:center;background-color:#fff;border:2.5px solid #2c3e50;border-radius:12px;box-shadow:0 3px 0 #2c3e50;color:#2c3e50;cursor:pointer;display:flex;font-size:12px;font-weight:900;height:34px;justify-content:center;left:12px;min-width:44px;padding:0 10px;position:absolute;top:12px;transition:transform .1s ease}.back-wizard-btn:active{box-shadow:0 0 0 #2c3e50;transform:translateY(3px)}.step-indicator{display:none}.wizard-title{-webkit-text-stroke:.5px #2c3e50;align-items:center;color:#2c3e50;display:flex;font-size:18px;font-weight:900;gap:8px;margin-bottom:16px;margin-top:0}.inline-icon{color:#ff9f1a;flex-shrink:0}.input-group{display:flex;flex-direction:column;margin-bottom:14px}.input-group label{color:#2c3e50;font-size:12px;font-weight:800;margin-bottom:6px;text-transform:uppercase}.cartoon-input,.cartoon-input-select{background-color:#fff;border:2.5px solid #2c3e50;border-radius:16px;box-shadow:inset 0 2px 4px #0000000d;box-sizing:border-box;color:#2c3e50;font-size:14px;font-weight:700;min-height:44px;outline:none;padding:12px 14px;width:100%}.cartoon-input-select:focus,.cartoon-input:focus{border-color:#1e90ff}.planning-date-input{align-items:center;background-color:#fff;border:2.5px solid #2c3e50;border-radius:16px;box-shadow:inset 0 2px 4px #0000000d;color:#2c3e50;display:flex;font-size:14px;font-weight:700;height:44px;line-height:1.2;max-height:44px;min-height:44px;min-width:0;overflow:hidden;padding:9px 14px;position:relative;width:100%}.planning-date-input span{display:block;max-width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.planning-date-input input[type=date]{cursor:pointer;height:100%;inset:0;opacity:0;position:absolute;width:100%}.planning-date-input:focus-within{border-color:#1e90ff}.input-row-grid,.input-row-grid-2{display:flex;gap:12px}.input-row-grid .input-group,.input-row-grid-2 .input-group{flex:1 1}.input-row-grid-2 .input-group label{align-items:flex-end;display:flex;min-height:30px}.cartoon-helper-text{color:#747d8c;font-size:10px;font-weight:700;line-height:1.3;margin-top:4px}.budget-preset-group{margin-top:10px}.budget-preset-label{color:#2c3e50;display:block;font-size:11px;font-weight:800;margin-bottom:6px;text-transform:uppercase}.budget-preset-buttons{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(5,minmax(0,1fr))}.budget-add-buttons{margin-top:8px}.budget-preset-btn{border:2px solid #2c3e50;border-radius:11px;box-shadow:0 3px 0 #2c3e50;color:#2c3e50;cursor:pointer;font-size:11px;font-weight:900;min-height:36px;min-width:0;padding:6px 2px;transition:transform .1s ease,box-shadow .1s ease,background-color .1s ease}.budget-preset-btn.add{background-color:#dff9fb}.budget-preset-btn.set{background-color:#fff}.budget-preset-btn.set.selected{background-color:#ff9f1a;color:#fff}.budget-preset-btn:active{box-shadow:none;transform:translateY(3px)}.tags-container{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.tag-btn-cartoon{background-color:#fff;border:2.5px solid #2c3e50;border-radius:16px;box-shadow:0 3px 0 #2c3e50;color:#2c3e50;cursor:pointer;font-size:12px;font-weight:800;min-height:38px;padding:8px 14px;transition:transform .1s ease,box-shadow .1s ease}.tag-btn-cartoon.selected{background-color:#ff9f1a;color:#fff}.tag-btn-cartoon:active{box-shadow:none;transform:translateY(3px)}.loading-tags{color:#747d8c;font-size:12px;font-weight:700}.btn-row{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-top:20px}.btn-back,.btn-next{border-radius:16px!important;font-size:12px!important;height:auto!important;min-height:0!important;padding:10px 16px!important}.btn-back,.btn-next{box-shadow:0 4px 0 #2c3e50!important}body.dark-theme .trip-plan-screen{background:var(--st-bg);color:var(--st-text)}body.dark-theme .wizard-container{background-color:var(--st-bg)}body.dark-theme .back-wizard-btn{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color);color:var(--st-text)}body.dark-theme .back-wizard-btn:active{box-shadow:0 0 0 var(--game-border-color)}body.dark-theme .wizard-title{-webkit-text-stroke:.5px var(--st-text);color:var(--st-text)}body.dark-theme .input-group label{color:var(--st-text)}body.dark-theme .cartoon-input,body.dark-theme .cartoon-input-select{background-color:var(--st-surface);border-color:var(--game-border-color);color:var(--st-text)}body.dark-theme .cartoon-input-select:focus,body.dark-theme .cartoon-input:focus{border-color:var(--st-primary)}body.dark-theme .cartoon-input::-webkit-calendar-picker-indicator{filter:invert(1)}body.dark-theme .cartoon-helper-text{color:var(--st-text-muted)}body.dark-theme .budget-preset-label{color:var(--st-text)}body.dark-theme .planning-date-input{background-color:var(--st-surface);border-color:var(--game-border-color);color:var(--st-text)}body.dark-theme .planning-date-input:focus-within{border-color:var(--game-blue)}body.dark-theme .budget-preset-btn{border-color:var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color);color:var(--st-text)}body.dark-theme .budget-preset-btn.add,body.dark-theme .budget-preset-btn.set{background-color:var(--st-surface)}body.dark-theme .budget-preset-btn.set.selected{background-color:var(--game-orange);color:#fff}body.dark-theme .budget-preset-btn:active{box-shadow:none}body.dark-theme .tag-btn-cartoon{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color);color:var(--st-text)}body.dark-theme .tag-btn-cartoon.selected{background-color:var(--game-orange);box-shadow:0 3px 0 var(--game-border-color);color:#fff}body.dark-theme .tag-btn-cartoon:active{box-shadow:0 0 0 var(--game-border-color)}body.dark-theme .loading-tags{color:var(--st-text-muted)}body.dark-theme .btn-back,body.dark-theme .btn-next{box-shadow:0 4px 0 var(--game-border-color)!important}.register-container{-webkit-overflow-scrolling:touch;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 4px 6px #0000001a;box-sizing:border-box;height:100%;margin:0 auto;max-width:48rem;min-height:0;overflow-x:hidden;overflow-y:auto;padding:calc(2rem + env(safe-area-inset-top, 0px)) 2rem calc(2rem + env(safe-area-inset-bottom, 0px));width:100%}.register-back-btn{align-items:center;background:#0000;border:none;color:#2563eb;cursor:pointer;display:inline-flex;font-weight:700;gap:.4rem;margin-bottom:1rem}.register-title{color:#2563eb;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.alert-message{border-radius:.375rem;margin-bottom:1.5rem;padding:1rem}.alert-success{background-color:#d1fae5;color:#047857}.alert-error{background-color:#fee2e2;color:#b91c1c}.form-section-title{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;font-size:1.125rem;font-weight:600;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem}.form-group{margin-bottom:1rem}.form-label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.form-control{border:1px solid #d1d5db;border-radius:.375rem;box-sizing:border-box;padding:.5rem;width:100%}textarea.form-control{min-height:5rem;resize:vertical}.form-control:focus{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6;outline:none}.grid-2-cols{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.choice-grid{grid-gap:.6rem;display:grid;gap:.6rem;grid-template-columns:repeat(auto-fit,minmax(9rem,1fr))}.choice-pill{align-items:center;background:#f9fafb;border:1px solid #d1d5db;border-radius:.5rem;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.45rem;padding:.6rem .7rem}.choice-pill input{accent-color:#2563eb}.form-help{color:#6b7280;display:block;font-size:.8rem;margin-top:.35rem}.gps-panel{background:#eff6ff;border:1px solid #bfdbfe;border-radius:.5rem;margin-bottom:1rem;padding:1rem}.gps-panel-header{align-items:flex-start;display:flex;gap:.75rem;justify-content:space-between;margin-bottom:.8rem}.gps-panel-header div{display:flex;flex-direction:column;gap:.2rem}.gps-panel-header strong{color:#1d4ed8;font-size:.95rem}.gps-panel-header span{color:#475569;font-size:.8rem;line-height:1.35}.gps-btn{background:#2563eb;border:1px solid #2563eb;border-radius:.45rem;color:#fff;cursor:pointer;flex-shrink:0;font-weight:700;min-height:38px;padding:0 .75rem}.gps-btn:disabled{cursor:not-allowed;opacity:.65}.submit-btn{background-color:#2563eb;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-weight:700;margin-top:1.5rem;padding:.75rem 1rem;transition:background-color .2s;width:100%}.submit-btn:hover{background-color:#1d4ed8}.submit-btn:disabled{background-color:#9ca3af;cursor:not-allowed}@media (max-width:640px){.register-container{border:none;border-radius:0;box-shadow:none;margin:0;padding:calc(1rem + env(safe-area-inset-top, 0px)) 1rem calc(2rem + env(safe-area-inset-bottom, 0px))}.grid-2-cols{grid-template-columns:1fr}.gps-panel-header{flex-direction:column}.gps-btn{width:100%}}.register-compact-time{align-items:center;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;box-sizing:border-box;color:#374151;display:flex;font-size:.875rem;height:40px;min-width:0;overflow:hidden;padding:.5rem;position:relative;width:100%}.register-compact-time span{display:block;max-width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.register-compact-time input[type=time]{background:#0000;border:none;cursor:pointer;height:100%;inset:0;margin:0;opacity:0!important;padding:0;position:absolute;width:100%}.register-compact-time:focus-within{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6}.main-layout{background-color:var(--st-bg);display:flex;flex-direction:column;inset:0;min-height:0;min-width:0;overflow:hidden;position:absolute;transition:background-color .3s ease;width:100%}.game-hud-header{align-items:center;background-color:var(--st-surface);border-bottom:4px solid var(--game-border-color);box-shadow:0 4px 10px #0000000d;box-sizing:border-box;cursor:pointer;display:flex;flex-shrink:0;gap:8px;height:calc(68px + env(safe-area-inset-top, 0px));justify-content:space-between;overflow:hidden;padding:calc(10px + env(safe-area-inset-top, 0px)) calc(16px + env(safe-area-inset-right, 0px)) 10px calc(20px + env(safe-area-inset-left, 0px));transition:background-color .3s ease,border-color .3s ease;-webkit-user-select:none;user-select:none;z-index:1010}.hud-player-info{align-items:center;display:flex;flex:1 1 auto;gap:10px;min-width:0}.hud-avatar-wrapper{align-items:center;background:radial-gradient(circle,#ffeaa7 0,#ffd32d 100%);border:3px solid var(--game-border-color);border-radius:50%;display:flex;flex-shrink:0;height:44px;justify-content:center;position:relative;width:44px}.hud-avatar-img{border-radius:50%;height:36px;object-fit:cover;width:36px}.hud-level-badge{background-color:#ff4757;border:2px solid var(--game-border-color);border-radius:6px;bottom:-2px;box-shadow:0 1.5px 0 var(--game-border-color);color:#fff;font-size:10px;font-weight:900;padding:0 5px;position:absolute;right:-2px}.hud-name-container{display:flex;flex-direction:column;line-height:1.1;min-width:0}.hud-player-name{color:var(--st-text);font-size:14px;font-weight:700;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hud-player-tier{color:var(--st-text-muted);font-size:10px;font-weight:700;margin-top:1px}.hud-stats-group{display:flex;flex:0 1 auto;gap:8px;max-width:58%;min-width:0}.hud-stat-pill{align-items:center;background-color:var(--st-surface);border:2.5px solid var(--game-border-color);border-radius:16px;box-shadow:0 3px 0 var(--game-border-color);box-sizing:border-box;display:flex;flex-shrink:0;height:32px;min-width:0;padding:2px 8px 2px 26px;position:relative;transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease}.pill-icon{align-items:center;display:inline-flex;filter:drop-shadow(0 2px 0 rgba(0,0,0,.1));font-size:20px;justify-content:center;left:6px;position:absolute;top:50%;transform:translateY(-50%)}.pill-value{color:var(--st-text);font-size:11px;font-weight:800}.exp-pill{max-width:104px;min-width:92px;width:auto}.coin-pill{min-width:58px}.pill-value-container{align-items:center;display:flex;flex-direction:column;margin-left:2px;width:100%}.hud-exp-progress-bar{background-color:var(--st-surface-muted);border:1px solid var(--game-border-color);border-radius:3px;height:5px;margin-top:1.5px;overflow:hidden;width:60px}.hud-exp-progress-fill{background:linear-gradient(90deg,#2ed573,#7bed9f);height:100%;transition:width .3s ease}.hud-tier-row{align-items:center;display:inline-flex;gap:4px}.pill-icon svg{color:var(--st-text);height:14px;width:14px}@media (max-width:380px){.game-hud-header{gap:6px;padding:calc(9px + env(safe-area-inset-top, 0px)) calc(12px + env(safe-area-inset-right, 0px)) 9px calc(12px + env(safe-area-inset-left, 0px))}.hud-player-name{max-width:72px}.hud-player-tier{display:none}.hud-stats-group{gap:6px;max-width:54%}.hud-stat-pill{padding:2px 6px 2px 22px}.hud-exp-progress-bar{width:48px}}.content-area{flex:1 1;min-height:0;min-width:0;overflow-y:auto;padding-bottom:calc(70px + env(safe-area-inset-bottom, 0px));width:100%}.content-area-map{overflow:hidden;padding-bottom:0;position:relative}html.chat-conversation-active .bottom-nav,html.chat-conversation-active .friends-sub-tabs,html.chat-conversation-active .game-hud-header{display:none!important}html.chat-conversation-active .content-area,html.chat-keyboard-visible .content-area{overflow:hidden;padding-bottom:0}html.chat-keyboard-visible .bottom-nav{display:none}.bottom-nav{align-items:center;background:var(--st-surface);border-radius:40px;bottom:8px;box-shadow:0 10px 30px #00000026;display:flex;height:64px;justify-content:space-between;left:20px;padding:0 20px;position:absolute;right:20px;transition:background-color .3s ease,border-color .3s ease;z-index:1000}body.dark-theme .bottom-nav{border:2px solid var(--st-border);box-shadow:0 10px 30px #00000080}.nav-item{-webkit-tap-highlight-color:transparent;align-items:center;border-radius:50%;color:#a4b0be;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .3s ease;width:44px}.nav-item:hover{color:#7bed9f}.nav-item.active{background:#3b82f6;box-shadow:0 4px 15px #3b82f666;color:#fff;transform:translateY(-2px)}.nav-icon{display:block}.nav-label{display:none}.quest-meta-info{flex-wrap:wrap;gap:8px}.quest-action-btn:disabled{box-shadow:none;transform:none}.quest-quiz-question{background:#ffffff05;border:1px solid #ffffff0d;border-radius:12px;color:#f1f2f6;font-size:13px;line-height:1.4;margin-bottom:12px;padding:12px}.photo-upload-placeholder{transition:border-color .2s,background-color .2s}.photo-upload-placeholder:hover{background:#6c5ce70d}.photo-reset{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.map-title-main{-webkit-text-stroke:.5px #fff;color:#2c3e50;text-shadow:1.5px 1.5px 0 #fff}.map-title-sub{background-color:#ffffffd9;border:1.5px solid #2c3e50;color:#2c3e50}.map-circle-btn{background:#fff;border:2.5px solid #2c3e50;box-shadow:0 3px 0 #2c3e50;color:#2c3e50;transition:transform .1s ease,box-shadow .1s ease}.map-circle-btn:hover{background:#f3f4f6}.map-my-location-btn{background:#fff;border:2.5px solid #2c3e50;box-shadow:0 4px 0 #2c3e50;transition:transform .1s ease,box-shadow .1s ease}.map-my-location-btn:hover{background:#f3f4f6}body.dark-theme .game-hud-header{background-color:var(--st-surface);border-bottom-color:var(--st-border);color:var(--st-text)}body.dark-theme .hud-player-name{color:var(--st-text)}body.dark-theme .hud-stat-pill{background-color:var(--st-surface-muted);border-color:var(--st-border);color:var(--st-text)}body.dark-theme .pill-value{color:var(--st-text)}body.dark-theme .bottom-nav{background-color:var(--st-surface);border-top:1px solid var(--st-border);box-shadow:var(--st-shadow)}.mascot-container{align-items:flex-start;bottom:96px;display:flex;flex-direction:column;left:24px;pointer-events:none;position:fixed;right:auto;z-index:999}.mascot-bubble{animation:bubblePop .3s cubic-bezier(.175,.885,.32,1.275);background:#fff;border:2px solid #74b9ff;border-radius:20px 20px 20px 0;box-shadow:0 4px 15px #0000001a;color:#2d3436;font-size:13px;font-weight:500;line-height:1.4;margin-bottom:15px;max-width:200px;padding:12px 18px;pointer-events:auto;position:relative}.mascot-bubble:after{border-right:15px solid #0000;border-top:10px solid #74b9ff;bottom:-10px;left:0}.mascot-bubble:after,.mascot-bubble:before{border-left:0;content:"";height:0;position:absolute;right:auto;width:0}.mascot-bubble:before{border-right:12px solid #0000;border-top:8px solid #fff;bottom:-6px;left:2px;z-index:1}@keyframes bubblePop{0%{opacity:0;transform:scale(0) translate(-20px,20px)}to{opacity:1;transform:scale(1) translate(0)}}.typing-cursor{animation:blink 1s infinite;color:#74b9ff;font-weight:700}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.mascot-character{filter:drop-shadow(0 5px 10px rgba(0,0,0,.2));height:100px;pointer-events:auto;transition:transform .3s ease;width:100px}.mascot-character img{height:100%;object-fit:contain;transform-origin:bottom center;width:100%}.mascot-character.idle img{animation:breathe 3s ease-in-out infinite}.mascot-character.talking img{animation:talkingBob .5s ease-in-out infinite alternate}.mascot-character.happy img{animation:jump .6s ease}.mascot-character.wiggle img{animation:wiggle 1s ease-in-out}.mascot-character.look-left img{transform:perspective(400px) rotateY(-20deg) scaleX(.95);transition:transform .4s ease}.mascot-character.look-right img{transform:perspective(400px) rotateY(20deg) scaleX(.95);transition:transform .4s ease}@keyframes breathe{0%,to{transform:scaleY(1)}50%{transform:scaleY(.96) scaleX(1.02)}}@keyframes talkingBob{0%{transform:translateY(0) rotate(-2deg)}to{transform:translateY(-5px) rotate(2deg)}}@keyframes jump{0%,to{transform:translateY(0)}50%{transform:translateY(-25px) scaleY(1.05)}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}50%{transform:rotate(10deg)}75%{transform:rotate(-5deg)}}.home-container{background:#0000;box-sizing:border-box;font-family:Be Vietnam Pro,sans-serif;min-height:100%;min-width:0;overflow-x:hidden;padding:12px 16px 16px;position:relative;width:100%}.ongoing-section{margin-bottom:24px}.section-title{align-items:center;color:#2c3e50;display:flex;font-size:15px;font-weight:900;justify-content:space-between;margin-bottom:12px;text-transform:uppercase}.history-link-btn{align-items:center;background:#fff;border:1.5px solid #2c3e50;border-radius:12px;color:#2c3e50;cursor:pointer;display:inline-flex;font-size:12px;font-weight:800;gap:6px;padding:6px 12px}.history-link-btn:active{transform:translateY(1px)}.ongoing-trips-list{display:flex;flex-direction:column;gap:12px}.ongoing-trip-card{grid-gap:12px;align-items:center;background:#fff;border:3px solid #2c3e50;border-radius:24px;box-shadow:0 6px 0 #2c3e50;cursor:pointer;display:grid;gap:12px;grid-template-areas:"info action";grid-template-columns:minmax(0,1fr) auto;padding:16px;position:relative;transition:transform .2s ease,box-shadow .2s ease}.ongoing-trip-card:hover{box-shadow:0 4px 0 #2c3e50;transform:translateY(2px)}.ongoing-trip-info{grid-area:info;min-width:0}.ongoing-trip-title{color:#2c3e50;font-size:15px;font-weight:900;line-height:1.3;margin:0 0 6px;overflow-wrap:anywhere;white-space:normal;word-break:normal}.ongoing-trip-meta{color:#747d8c;font-size:10px;font-weight:700;margin:0 0 6px}.ongoing-trip-stats{color:#2c3e50;display:flex;flex-wrap:wrap;font-size:11px;font-weight:800;gap:8px}.ongoing-stat-item{align-items:center;display:inline-flex;gap:4px}.enter-dungeon-action{flex-shrink:0;grid-area:action;justify-self:end;max-width:96px}.enter-btn{align-items:center!important;border-radius:12px!important;box-shadow:0 3px 0 #2c3e50!important;display:inline-flex!important;font-size:11px!important;gap:4px!important;height:auto!important;justify-content:center!important;max-width:100%;min-height:0!important;padding:8px 12px!important;white-space:nowrap}.enter-btn:hover{box-shadow:0 2px 0 #2c3e50!important;transform:translateY(1px)!important}.enter-btn:active{box-shadow:0 0 0 #2c3e50!important;transform:translateY(3px)!important}.plan-banner{align-items:center;background:linear-gradient(135deg,#ff9f1a,#ffc048);border:3px solid #2c3e50;border-radius:24px;box-shadow:0 6px 0 #2c3e50;color:#fff;display:flex;gap:10px;justify-content:space-between;margin-bottom:24px;padding:16px}.plan-banner h3{-webkit-text-stroke:.5px #2c3e50;font-size:16px;font-weight:900;margin:0;text-shadow:1.5px 1.5px 0 #2c3e50}.plan-banner p{color:#fffdec;font-size:11px;font-weight:700;line-height:1.3;margin:4px 0 0}.plan-banner-btn{background-color:#ffd32d!important;border-radius:12px!important;box-shadow:0 3px 0 #2c3e50!important;color:#2c3e50!important;font-size:11px!important;height:auto!important;min-height:0!important;padding:8px 12px!important;white-space:nowrap}.daily-quests-card{background-color:#fffdf0;border:3.5px solid #2c3e50;border-radius:24px;box-shadow:0 6px 0 #2c3e50;margin-bottom:24px;padding:16px}.board-title{-webkit-text-stroke:.5px #2c3e50;align-items:center;color:#ff9f1a;display:flex;font-size:14px;font-weight:900;gap:6px;justify-content:center;margin:0 0 12px;text-align:center}.quests-list{display:flex;flex-direction:column;gap:8px}.quest-item-row{align-items:center;background-color:#fff;border:2.5px solid #2c3e50;border-radius:16px;cursor:pointer;display:flex;gap:10px;padding:8px 12px;transition:transform .1s ease,background-color .2s ease}.quest-item-row:hover:not(.quest-done){background-color:#f5f6fa}.quest-item-row.quest-done{background-color:#f1f2f6;border-color:#bdc3c7;cursor:default;opacity:.8}.quest-item-row:active:not(.quest-done){transform:scale(.98)}.checkbox-cartoon{align-items:center;background-color:#fff;border:2px solid #2c3e50;border-radius:6px;color:#2ed573;display:flex;flex-shrink:0;font-size:13px;font-weight:900;height:20px;justify-content:center;width:20px}.quest-text-content{align-items:center;display:flex;flex:1 1;justify-content:space-between;min-width:0}.quest-label{align-items:center;color:#2c3e50;display:inline-flex;font-size:11px;font-weight:700;gap:4px;margin-right:6px;min-width:0;overflow-wrap:anywhere}.quest-reward{background-color:#e8f8f5;border:1.5px solid #2c3e50;border-radius:8px;color:#2ed573;font-size:9px;font-weight:900;padding:1px 6px;white-space:nowrap}.quest-done{opacity:.6}.quest-done .quest-label{color:#747d8c;text-decoration:line-through}.quest-done .checkbox-cartoon{background-color:#e8f8f5}.mini-leaderboard-card{background-color:#fff;border:3.5px solid #2c3e50;border-radius:24px;box-shadow:0 6px 0 #2c3e50;margin-bottom:24px;padding:16px}.mini-leaderboard-card .section-title{border-bottom:2px dashed #dfe6e9;margin-bottom:10px;padding-bottom:4px}.podium-preview{display:flex;flex-direction:column;gap:8px}.podium-row{align-items:center;border:2px solid #2c3e50;border-radius:16px;display:flex;padding:6px 12px}.podium-row.place-1{background-color:#fff9e6}.podium-row.place-2{background-color:#f5f6fa}.podium-row.place-3{background-color:#fff3eb}.place-medal{align-items:center;color:#2c3e50;display:inline-flex;font-size:12px;font-weight:900;gap:2px;margin-right:8px;min-width:26px}.player-podium-avatar{border:2px solid #2c3e50;border-radius:50%;height:24px;margin-right:8px;object-fit:cover;width:24px}.player-podium-name{color:#2c3e50;flex:1 1;font-size:11px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-podium-points{background-color:#fff2e6;border:1.5px solid #2c3e50;border-radius:8px;color:#e67e22;font-size:10px;font-weight:900;padding:1px 6px}.card-scroller{-webkit-overflow-scrolling:touch;cursor:grab;display:flex;gap:14px;overflow-x:auto;padding-bottom:12px;padding-right:8px;scroll-snap-type:x proximity;touch-action:pan-x;-webkit-user-select:none;user-select:none}.card-scroller:active{cursor:grabbing}.tour-card{background:#fff;border:3px solid #2c3e50;border-radius:24px;box-shadow:0 6px 0 #2c3e50;box-sizing:border-box;flex:0 0 180px;max-width:180px;min-width:180px;padding:10px;position:relative;scroll-snap-align:start}.zone-difficulty-badge{align-items:center;background-color:#ffffffe6;border:2px solid #2c3e50;border-radius:8px;display:inline-flex;font-size:9px;font-weight:900;gap:4px;left:14px;padding:1px 6px;position:absolute;top:14px;z-index:10}.zone-difficulty-badge.easy{color:#166534}.zone-difficulty-badge.medium{color:#b45309}.tour-image{border:2px solid #2c3e50;border-radius:16px;height:100px;margin-bottom:8px;object-fit:cover;width:100%}.tour-title{color:#2c3e50;font-size:14px;font-weight:900;margin:0 0 4px}.zone-rewards-row{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.reward-item-badge{align-items:center;border:1.5px solid #2c3e50;border-radius:8px;display:inline-flex;font-size:9px;font-weight:800;gap:4px;padding:2px 6px;width:fit-content}.reward-item-badge.star{background-color:#e3f2fd;color:#1e90ff}.reward-item-badge.coin{background-color:#fff9e6;color:#ff9f1a}.tour-footer{align-items:center;display:flex;justify-content:space-between}.tour-rating{background-color:#f1f2f6;border:1.5px solid #2c3e50;border-radius:8px;color:#2c3e50;font-size:10px;font-weight:900;padding:2px 6px}.explore-zone-btn{border-radius:10px!important;box-shadow:0 2px 0 #2c3e50!important;font-size:10px!important;height:auto!important;min-height:0!important;padding:4px 8px!important}.inline-loading{color:#747d8c;font-size:12px;font-weight:700;margin:15px 0;text-align:center}.inline-icon,.stat-icon{flex-shrink:0}.difficulty-dot{border:1px solid #2c3e50;border-radius:50%;display:inline-block;height:8px;width:8px}.difficulty-dot.easy{background:#22c55e}.difficulty-dot.medium{background:#f59e0b}@media (max-width:380px){.ongoing-trip-card{gap:8px;padding:14px}.enter-dungeon-action{max-width:88px}.enter-btn{font-size:10px!important;padding:7px 9px!important}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.daily-attendance-card{background-color:#fffdf0;border:3.5px solid #2c3e50;border-radius:24px;box-shadow:0 6px 0 #2c3e50;margin-bottom:24px;min-width:0;overflow:hidden;padding:16px}.attendance-guest-state{color:#7f8c8d;font-size:13px;font-weight:700;padding:16px 8px;text-align:center}.attendance-streak-header{color:#2c3e50;font-size:12px;font-weight:800;margin-bottom:12px;text-align:center}.attendance-days-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:16px;min-width:0;width:100%}.attendance-day-box{align-items:center;background-color:#fff;border:2.5px solid #2c3e50;border-radius:12px;box-sizing:border-box;display:flex;flex-direction:column;justify-content:space-between;min-height:72px;min-width:0;overflow:hidden;padding:8px 4px;pointer-events:none;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.attendance-day-box .day-name{color:#7f8c8d;font-size:9px;font-weight:800;min-width:0;white-space:nowrap}.attendance-day-box .day-status-icon{align-items:center;color:#bdc3c7;display:flex;height:20px;justify-content:center}.attendance-day-box .day-bonus{color:#7f8c8d;font-size:8px;font-weight:900;line-height:1.15;min-width:0;overflow-wrap:anywhere;text-align:center}.attendance-day-box.checked{background-color:#2ed573;border-color:#2c3e50}.attendance-day-box.checked .day-bonus,.attendance-day-box.checked .day-name,.attendance-day-box.checked .day-status-icon{color:#fff}.attendance-day-box.today{border-color:#ff9f1a;box-shadow:0 0 0 2px #ffeaa7;transform:scale(1.05)}.attendance-day-box.today .day-name{color:#ff9f1a}.attendance-day-box.milestone{background-color:#fff9e6;border-color:#2c3e50;flex-direction:row!important;gap:4px;grid-column:span 2;justify-content:space-around!important;padding:8px 12px!important}.attendance-day-box.milestone.checked{background-color:#ffd32d}.attendance-day-box.milestone .day-bonus{color:#ff9f1a}.attendance-day-box.milestone.checked .day-bonus{color:#fff}.attendance-action-btn{border-radius:14px!important;font-size:12px!important;font-weight:900!important;padding:10px 16px!important;text-transform:uppercase;width:100%}.attendance-action-btn.disabled{background-color:#bdc3c7!important;box-shadow:0 3px 0 #95a5a6!important;color:#7f8c8d!important;cursor:not-allowed;opacity:.7;pointer-events:none}.chest-rewards-container{border-top:2px dashed #dfe6e9;margin-top:16px;padding-top:16px}.chest-rewards-section{align-items:center;background-color:#fff;border:3px solid #2c3e50;border-radius:20px;box-sizing:border-box;display:flex;gap:16px;padding:12px 16px;position:relative}.chest-rewards-section.locked{background-color:#f5f6fa;opacity:.8}.chest-rewards-section.claimed{background-color:#e8f8f5}.chest-rewards-section.ready-to-claim{background-color:#fffdec;border-color:#ff9f1a;box-shadow:0 4px 0 #d35400}.chest-icon-wrapper{align-items:center;background-color:#fff;border:2.5px solid #2c3e50;border-radius:12px;display:flex;flex-shrink:0;height:48px;justify-content:center;position:relative;width:48px}.chest-icon-wrapper.locked{background-color:#dfe6e9;color:#7f8c8d}.chest-icon-wrapper.opened{background-color:#e8f8f5;border-color:#2ed573;color:#2ed573}.chest-icon-wrapper.glowing{animation:chestGlow 1.5s infinite alternate;background-color:#ffd32d;color:#2c3e50}.chest-info-meta{flex:1 1;min-width:0}.chest-info-meta h4{color:#2c3e50;font-size:12px;font-weight:900;margin:0 0 4px;text-transform:uppercase}.chest-rewards-section.ready-to-claim .chest-info-meta h4{color:#ff9f1a}.chest-info-meta p{color:#7f8c8d;font-size:10px;font-weight:700;line-height:1.3;margin:0}.claim-chest-btn{border-radius:10px!important;box-shadow:0 2px 0 #2c3e50!important;font-size:10px!important;height:auto!important;margin-top:8px;min-height:0!important;padding:6px 12px!important}@keyframes chestGlow{0%{box-shadow:0 0 5px #ffd32d,inset 0 0 5px #fff}to{box-shadow:0 0 15px #ffd32d,inset 0 0 10px #fff}}.shaking{animation:chestShake 1.2s ease-in-out infinite}@keyframes chestShake{0%{transform:translate(0) rotate(0deg)}10%{transform:translate(-2px,-1px) rotate(-3deg)}20%{transform:translate(-3px) rotate(3deg)}30%{transform:translateY(2px) rotate(0deg)}40%{transform:translate(1px,-1px) rotate(1deg)}50%{transform:translate(-1px,2px) rotate(-1deg)}60%{transform:translate(-3px,1px) rotate(0deg)}70%{transform:translate(2px,1px) rotate(-2deg)}80%{transform:translate(-1px,-1px) rotate(4deg)}90%{transform:translate(2px,2px) rotate(-2deg)}to{transform:translate(0) rotate(0deg)}}body.dark-theme .ongoing-trip-card{background-color:var(--st-surface);color:var(--st-text)}body.dark-theme .ongoing-trip-title{color:var(--st-text)}body.dark-theme .ongoing-trip-stats{color:var(--st-text-muted)}body.dark-theme .history-link-btn{color:var(--st-text)}body.dark-theme .daily-quests-card,body.dark-theme .history-link-btn{background-color:var(--st-surface)}body.dark-theme .quest-item-row{background-color:var(--st-surface-muted)}body.dark-theme .quest-item-row.quest-done{background-color:var(--st-bg)}body.dark-theme .quest-label{color:var(--st-text)}body.dark-theme .checkbox-cartoon,body.dark-theme .mini-leaderboard-card{background-color:var(--st-surface)}body.dark-theme .podium-row.place-1{background-color:var(--podium-1-bg)}body.dark-theme .podium-row.place-2{background-color:var(--podium-2-bg)}body.dark-theme .podium-row.place-3{background-color:var(--podium-3-bg)}body.dark-theme .player-podium-name{color:var(--st-text)}body.dark-theme .tour-card{background-color:var(--st-surface)}body.dark-theme .tour-title{color:var(--st-text)}body.dark-theme .tour-rating{background-color:var(--st-surface-muted);color:var(--st-text)}body.dark-theme .daily-attendance-card{background-color:var(--st-surface)}body.dark-theme .attendance-streak-header{color:var(--st-text)}body.dark-theme .attendance-day-box,body.dark-theme .chest-rewards-section{background-color:var(--st-surface-muted)}body.dark-theme .chest-icon-wrapper{background-color:var(--st-surface)}body.dark-theme .chest-info-meta h4{color:var(--st-text)}body.dark-theme .ongoing-trip-card{border-color:var(--game-border-color);box-shadow:0 6px 0 var(--game-border-color)}body.dark-theme .ongoing-trip-card:hover{box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .enter-btn{border-color:var(--game-border-color)!important;box-shadow:0 3px 0 var(--game-border-color)!important}body.dark-theme .enter-btn:hover{box-shadow:0 2px 0 var(--game-border-color)!important}body.dark-theme .plan-banner{border-color:var(--game-border-color);box-shadow:0 6px 0 var(--game-border-color)}body.dark-theme .plan-banner h3{-webkit-text-stroke:.5px var(--game-border-color);text-shadow:1.5px 1.5px 0 var(--game-border-color)}.leaderboard-container{background:#e0f2fe;background:var(--st-bg,#e0f2fe);color:#243447;color:var(--st-text,#243447);display:flex;flex-direction:column;min-height:100%;overflow-y:auto;padding-bottom:calc(96px + env(safe-area-inset-bottom, 0px))}.leaderboard-header{background:#fff;background:var(--st-surface,#fff);border:1px solid #cbd5e1;border:1px solid var(--st-border,#cbd5e1);border-radius:16px;border-radius:var(--st-radius,16px);box-shadow:0 8px 24px #0f172a14;box-shadow:var(--st-shadow,0 8px 24px #0f172a14);margin:16px;padding:16px}.leaderboard-title{align-items:center;display:flex;font-size:18px;font-weight:800;gap:8px;margin:0}.leaderboard-subtitle{color:#64748b;color:var(--st-text-muted,#64748b);font-size:12px;line-height:1.4;margin:6px 0 14px}.category-tabs{background:#f8fafc;background:var(--st-surface-muted,#f8fafc);border:1px solid #cbd5e1;border:1px solid var(--st-border,#cbd5e1);border-radius:12px;display:flex;gap:6px;padding:4px}.tab-btn{background:#0000;border-radius:8px;color:#64748b;color:var(--st-text-muted,#64748b);font-size:13px;font-weight:700;min-height:40px}.tab-btn.active{box-shadow:0 1px 6px #0f172a14;color:#243447;color:var(--st-text,#243447)}.filter-container,.tab-btn.active{background:#fff;background:var(--st-surface,#fff)}.filter-container{align-items:center;border:1px solid #cbd5e1;border:1px solid var(--st-border,#cbd5e1);border-radius:12px;display:flex;gap:10px;margin:0 16px 10px;padding:12px}.filter-label{color:#64748b;color:var(--st-text-muted,#64748b);font-size:13px;font-weight:700;white-space:nowrap}.filter-select{background:#fff;background:var(--st-surface,#fff);border:1px solid #cbd5e1;border:1px solid var(--st-border,#cbd5e1);border-radius:10px;color:#243447;color:var(--st-text,#243447);flex:1 1;min-height:40px;min-width:0;padding:8px 12px}.leaderboard-empty,.loaderboard-loading{align-items:center;background:#fff;background:var(--st-surface,#fff);border:1px dashed #cbd5e1;border:1px dashed var(--st-border,#cbd5e1);border-radius:14px;color:#64748b;color:var(--st-text-muted,#64748b);display:flex;flex-direction:column;gap:8px;margin:0 16px 14px;padding:20px 14px;text-align:center}.retry-btn{background:#fff;background:var(--st-surface,#fff);border:1px solid #cbd5e1;border:1px solid var(--st-border,#cbd5e1);border-radius:10px;color:#243447;color:var(--st-text,#243447);cursor:pointer;font-weight:700;min-height:38px;padding:6px 14px}.spinner{animation:spin .9s linear infinite;border:3px solid #dbeafe;border-top:3px solid var(--st-primary,#2563eb);height:28px;width:28px}.podium-container{grid-gap:10px;align-items:end;background:#fff;background:var(--st-surface,#fff);border:1px solid #cbd5e1;border:1px solid var(--st-border,#cbd5e1);border-radius:16px;box-shadow:0 8px 24px #0f172a14;box-shadow:var(--st-shadow,0 8px 24px #0f172a14);display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr));margin:0 16px 14px;padding:12px 10px}.podium-placeholder{min-height:140px}.podium-item{align-items:center;display:flex;flex-direction:column;min-width:0}.podium-avatar-wrapper{position:relative}.podium-avatar{background:#f8fafc;border:2px solid #cbd5e1;border-radius:50%;height:58px;object-fit:cover;width:58px}.place-1 .podium-avatar{border-color:#f59e0b;height:70px;width:70px}.podium-crown{color:#f59e0b;left:50%;position:absolute;top:-16px;transform:translateX(-50%)}.podium-rank-badge{align-items:center;background:#2563eb;background:var(--st-primary,#2563eb);border-radius:50%;bottom:-4px;color:#fff;display:flex;font-size:11px;font-weight:800;height:22px;justify-content:center;position:absolute;right:-4px;width:22px}.podium-name{color:#243447;color:var(--st-text,#243447);font-size:12px;font-weight:700;margin-top:8px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.podium-pts{color:#64748b;color:var(--st-text-muted,#64748b);font-size:11px;font-weight:700;margin-top:2px}.leaderboard-list{background:#fff;background:var(--st-surface,#fff);border:1px solid #cbd5e1;border:1px solid var(--st-border,#cbd5e1);border-radius:16px;box-shadow:0 8px 24px #0f172a14;box-shadow:var(--st-shadow,0 8px 24px #0f172a14);margin:0 16px 14px;overflow:hidden}.leaderboard-item{grid-gap:10px;align-items:center;border-bottom:1px solid #e2e8f0;display:grid;gap:10px;grid-template-columns:46px 44px minmax(0,1fr) auto;padding:12px 14px}.leaderboard-item:last-child{border-bottom:none}.item-rank{color:#64748b;color:var(--st-text-muted,#64748b);font-size:13px;font-weight:800}.item-avatar{background:#f8fafc;border:1px solid #cbd5e1;border-radius:50%;height:40px;object-fit:cover;width:40px}.item-details{display:flex;flex-direction:column;gap:3px;min-width:0}.item-name{color:#243447;color:var(--st-text,#243447);font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-meta{align-items:center;display:flex;flex-wrap:wrap;gap:6px;min-width:0}.tier-badge{border:1px solid;border-radius:999px;font-size:10px;font-weight:700;padding:2px 6px}.meta-pill{align-items:center;color:#64748b;color:var(--st-text-muted,#64748b);display:inline-flex;font-size:10px;gap:3px;min-width:0}.item-points{text-align:right}.pts-value{color:#243447;color:var(--st-text,#243447);font-size:14px;font-weight:800}.pts-label{color:#64748b;color:var(--st-text-muted,#64748b);font-size:10px}.my-rank-sticky-card{background:#eff6ff;border:1px solid #bfdbfe;border-radius:14px;justify-content:space-between;margin:0 16px 14px;padding:12px;position:static}.my-rank-left,.my-rank-sticky-card{align-items:center;display:flex;gap:10px}.my-rank-left{flex:1 1;min-width:0}.my-rank-number{align-items:center;background:#dbeafe;border-radius:50%;color:#1d4ed8;display:flex;font-size:12px;font-weight:800;height:34px;justify-content:center;min-width:34px}.my-rank-avatar{background:#f8fafc;border:1px solid #93c5fd;border-radius:50%;height:38px;object-fit:cover;width:38px}.my-rank-info{min-width:0}.my-rank-name{color:#243447;color:var(--st-text,#243447);font-size:13px;font-weight:800;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.my-rank-tier{align-items:center;color:#64748b;color:var(--st-text-muted,#64748b);display:flex;flex-wrap:wrap;font-size:10px;gap:4px;margin-top:2px}.meta-sep{opacity:.6}.my-rank-points{text-align:right}.my-rank-pts-value{color:#1d4ed8;font-size:15px;font-weight:800}.my-rank-pts-lbl{color:#64748b;color:var(--st-text-muted,#64748b);font-size:10px}@media (max-width:380px){.filter-container,.leaderboard-empty,.leaderboard-header,.leaderboard-list,.loaderboard-loading,.my-rank-sticky-card,.podium-container{margin-left:12px;margin-right:12px}.leaderboard-item{gap:8px;grid-template-columns:40px 38px minmax(0,1fr) auto;padding:10px}.item-meta{gap:4px}.my-rank-tier{gap:3px}}body.dark-theme .leaderboard-container{background:#0f172a;background:var(--st-bg,#0f172a);color:#f8fafc;color:var(--st-text,#f8fafc)}body.dark-theme .leaderboard-header{background:#1e293b;background:var(--st-surface,#1e293b);border-color:#334155;border-color:var(--st-border,#334155);box-shadow:0 8px 24px #0003}body.dark-theme .category-tabs{background:#0f172a;background:var(--st-surface-muted,#0f172a);border-color:#334155;border-color:var(--st-border,#334155)}body.dark-theme .tab-btn{color:#94a3b8;color:var(--st-text-muted,#94a3b8)}body.dark-theme .tab-btn.active{background:#1e293b;background:var(--st-surface,#1e293b);color:#f8fafc;color:var(--st-text,#f8fafc)}body.dark-theme .filter-container{background:#1e293b;background:var(--st-surface,#1e293b);border-color:#334155;border-color:var(--st-border,#334155)}body.dark-theme .filter-label{color:#94a3b8;color:var(--st-text-muted,#94a3b8)}body.dark-theme .filter-select{color:#f8fafc;color:var(--st-text,#f8fafc)}body.dark-theme .filter-select,body.dark-theme .leaderboard-empty,body.dark-theme .loaderboard-loading{background:#1e293b;background:var(--st-surface,#1e293b);border-color:#334155;border-color:var(--st-border,#334155)}body.dark-theme .leaderboard-empty,body.dark-theme .loaderboard-loading{color:#94a3b8;color:var(--st-text-muted,#94a3b8)}body.dark-theme .retry-btn{color:#f8fafc;color:var(--st-text,#f8fafc)}body.dark-theme .podium-container,body.dark-theme .retry-btn{background:#1e293b;background:var(--st-surface,#1e293b);border-color:#334155;border-color:var(--st-border,#334155)}body.dark-theme .podium-container{box-shadow:0 8px 24px #0003}body.dark-theme .podium-name{color:#f8fafc;color:var(--st-text,#f8fafc)}body.dark-theme .podium-pts{color:#94a3b8;color:var(--st-text-muted,#94a3b8)}body.dark-theme .leaderboard-list{background:#1e293b;background:var(--st-surface,#1e293b);border-color:#334155;border-color:var(--st-border,#334155);box-shadow:0 8px 24px #0003}body.dark-theme .leaderboard-item{border-bottom-color:#334155;border-bottom-color:var(--st-border,#334155)}body.dark-theme .item-rank{color:#94a3b8;color:var(--st-text-muted,#94a3b8)}body.dark-theme .item-name{color:#f8fafc;color:var(--st-text,#f8fafc)}body.dark-theme .meta-pill{color:#94a3b8;color:var(--st-text-muted,#94a3b8)}body.dark-theme .pts-value{color:#f8fafc;color:var(--st-text,#f8fafc)}body.dark-theme .pts-label{color:#94a3b8;color:var(--st-text-muted,#94a3b8)}body.dark-theme .my-rank-sticky-card{background:#0f172a;background:var(--st-surface-muted,#0f172a);border-color:#334155;border-color:var(--st-border,#334155)}body.dark-theme .my-rank-number{background:#1e293b;background:var(--st-surface,#1e293b);color:#3b82f6;color:var(--st-primary,#3b82f6)}body.dark-theme .my-rank-avatar{border-color:#334155;border-color:var(--st-border,#334155)}body.dark-theme .my-rank-name{color:#f8fafc;color:var(--st-text,#f8fafc)}body.dark-theme .my-rank-tier{color:#94a3b8;color:var(--st-text-muted,#94a3b8)}body.dark-theme .my-rank-pts-value{color:#3b82f6;color:var(--st-primary,#3b82f6)}body.dark-theme .my-rank-pts-lbl{color:#94a3b8;color:var(--st-text-muted,#94a3b8)}.social-feed-container{background-color:#e0f2fe;background-color:var(--st-bg,#e0f2fe);box-sizing:border-box;display:flex;flex-direction:column;font-family:Fredoka,Be Vietnam Pro,sans-serif;gap:16px;height:100%;overflow-y:auto;padding:16px}.social-feed-header{align-items:center;display:flex;justify-content:space-between;padding-bottom:8px}.feed-title{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-size:26px;font-weight:900;text-shadow:2px 2px 0 #fff}.feed-create-btn{font-size:13px;padding:8px 16px}.feed-loading{align-items:center;display:flex;flex-direction:column;gap:12px;height:200px;justify-content:center}.loader-hud{animation:spin 1s linear infinite;border:4px solid #2c3e50;border-top-color:#ffd32d;border:4px solid var(--game-border-color,#2c3e50);border-radius:50%;border-top-color:var(--game-yellow,#ffd32d);height:40px;width:40px}.feed-empty{align-items:center;background-color:#fff;gap:12px;margin-top:20px;padding:32px;text-align:center}.feed-empty,.posts-list{display:flex;flex-direction:column}.posts-list{gap:20px;padding-bottom:80px}.post-card{background-color:#fff;display:flex;flex-direction:column;gap:12px;padding:16px}.post-card-header{justify-content:space-between;position:relative}.author-info,.post-card-header{align-items:center;display:flex}.author-info{gap:12px}.author-avatar{background-color:#ffd32d;background-color:var(--game-yellow,#ffd32d);border:2.5px solid #2c3e50;border:2.5px solid var(--game-border-color,#2c3e50);border-radius:50%;height:44px;width:44px}.author-name{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-size:14px;font-weight:800}.post-meta{color:#747d8c;font-size:11px;font-weight:700;gap:8px}.post-location,.post-meta{align-items:center;display:flex}.post-location{color:#1e90ff;color:var(--game-blue,#1e90ff);gap:2px}.meta-icon{display:inline-block}.btn-menu{background:none;border:none;color:#2c3e50;color:var(--game-border-color,#2c3e50);cursor:pointer}.post-dropdown-menu{background-color:#fff;display:flex;flex-direction:column;min-width:140px;padding:6px;position:absolute;right:0;top:30px;z-index:100}.dropdown-item{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:11px;font-weight:700;gap:6px;padding:8px 12px;text-align:left}.dropdown-item:hover{background-color:#f1f2f6}.dropdown-item.red{color:#ff4757;color:var(--game-red,#ff4757)}.dropdown-item.orange{color:#ff9f1a;color:var(--game-orange,#ff9f1a)}.post-card-body{display:flex;flex-direction:column;gap:8px}.post-caption{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-size:13px;font-weight:600;line-height:1.4}.post-images-grid{grid-gap:8px;border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:16px;border-radius:var(--st-radius,16px);display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));overflow:hidden}.post-image{height:150px;object-fit:cover;width:100%}.post-card-footer{border-top:2px solid #f1f2f6;display:flex;justify-content:space-between;padding-top:10px}.post-action-btn{align-items:center;background:none;border:none;color:#2c3e50;color:var(--game-border-color,#2c3e50);cursor:pointer;display:flex;font-size:12px;font-weight:800;gap:6px;transition:transform .1s ease}.post-action-btn:active{transform:scale(.9)}.post-action-btn.active-like{color:#ff4757;color:var(--game-red,#ff4757)}.post-action-btn.active-save{color:#9b59b6;color:var(--game-purple,#9b59b6)}.modal-overlay{position:absolute;z-index:2000}.modal-content{max-width:400px;position:relative;width:100%}.comments-drawer-content,.modal-content{box-sizing:border-box;display:flex;flex-direction:column;gap:16px;padding:20px}.comments-drawer-content{animation:slideUpComments .3s cubic-bezier(.16,1,.3,1) forwards;background-color:#fff;border-bottom-left-radius:0!important;border-bottom-right-radius:0!important;bottom:12px;height:min(88%,820px);left:50%;max-height:calc(100% - env(safe-area-inset-top, 20px) - 24px);overflow:hidden;position:absolute;transform:translate(-50%);transition:box-shadow .2s ease,transform 0s;width:min(calc(100% - 24px),420px)}.modal-overlay.ios-standalone-comments{bottom:auto;height:100dvh;height:var(--comments-visual-height,100dvh);left:0;position:fixed;right:0;top:0;top:var(--comments-visual-offset-top,0);z-index:2000}.comments-modal-overlay.keyboard-visible .comments-drawer-content{border-radius:14px!important;bottom:6px;height:calc(100% - env(safe-area-inset-top, 20px) - 6px);max-height:100%}@keyframes slideUpComments{0%{transform:translate(-50%,100%)}to{transform:translate(-50%)}}.modal-header{align-items:center;border-bottom:2px solid #2c3e50;border-bottom:2px solid var(--game-border-color,#2c3e50);display:flex;justify-content:space-between;padding-bottom:8px}.modal-header h3{font-size:18px;font-weight:900;margin:0}.btn-close,.modal-header h3{color:#2c3e50;color:var(--game-border-color,#2c3e50)}.btn-close{background:none;border:none;cursor:pointer;font-weight:800}.post-input-text{border:2.5px solid #2c3e50;border:2.5px solid var(--game-border-color,#2c3e50);border-radius:12px;box-sizing:border-box;font-size:13px;font-weight:600;height:100px;outline:none;padding:10px;resize:none;width:100%}.images-preview-row{display:flex;gap:8px;overflow-x:auto;padding:4px 0}.preview-img-container{border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:8px;flex-shrink:0;height:70px;overflow:hidden;position:relative;width:70px}.btn-remove-preview{align-items:center;background-color:#ff4757;background-color:var(--game-red,#ff4757);border:1.5px solid #2c3e50;border:1.5px solid var(--game-border-color,#2c3e50);border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:8px;font-weight:700;height:16px;justify-content:center;position:absolute;right:2px;top:2px;width:16px}.form-actions-row{display:flex;gap:12px;margin-top:8px}.upload-label{flex:1 1}.hidden{display:none}.locate-btn{flex:1 1}.tag-location-display{align-items:center;background-color:#f1f2f6;border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:12px;color:#2c3e50;color:var(--game-border-color,#2c3e50);display:flex;font-size:11px;font-weight:800;gap:6px;padding:6px 12px;width:fit-content}.remove-loc{background:none;border:none;color:#ff4757;color:var(--game-red,#ff4757);cursor:pointer;font-weight:700}.privacy-select-row{align-items:center;color:#2c3e50;color:var(--game-border-color,#2c3e50);display:flex;font-size:12px;font-weight:800;gap:8px;margin-top:8px}.privacy-select-row select{border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:8px;font-weight:700;outline:none;padding:6px 12px}.submit-post-btn{margin-top:12px;width:100%}.comments-list{display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-x:hidden;overflow-y:auto;padding-bottom:20px}.comments-empty{color:#747d8c;font-size:12px;font-weight:600;padding:20px;text-align:center}.comment-item{align-items:flex-start;display:flex;gap:8px;min-width:0}.comment-avatar{border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:50%;height:32px;width:32px}.comment-bubble{background-color:#f8fafc;border-radius:16px!important;display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0;padding:10px}.comment-bubble-header{align-items:center;display:flex;justify-content:space-between}.commenter-name{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-size:11px;font-weight:800}.comment-time{color:#a4b0be;font-size:10px;font-weight:600;white-space:nowrap}.comment-text-content{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-size:12px;font-weight:600;line-height:1.3;overflow-wrap:anywhere;word-break:break-word}.add-comment-form{border-top:2px solid #2c3e50;border-top:2px solid var(--game-border-color,#2c3e50);display:flex;gap:8px;padding-top:12px}.add-comment-form input{border:2.5px solid #2c3e50;border:2.5px solid var(--game-border-color,#2c3e50);border-radius:12px;flex:1 1;font-size:12px;font-weight:600;min-width:0;outline:none;padding:10px 14px}@media (max-width:767px){.add-comment-form input{font-size:16px}}.send-comment-btn{border-radius:12px;padding:10px 14px}.comment-send-spinner{animation:spin .8s linear infinite;border:2px solid #ffffffd9;border-radius:50%;border-right-color:#0000;display:inline-block;height:14px;width:14px}.report-warning-desc{color:#747d8c;font-size:12px;font-weight:700;margin-bottom:8px}.modal-actions-row{display:flex;gap:12px;width:100%}.report-cancel-btn,.report-submit-btn{flex:1 1;font-size:13px;text-transform:none}.comment-meta-right{align-items:center;display:flex;gap:8px}.btn-delete-comment{align-items:center;background:none;border:none;color:#ff4757;color:var(--game-red,#ff4757);cursor:pointer;display:flex;justify-content:center;padding:0;transition:transform .1s ease}.btn-delete-comment:hover{transform:scale(1.15)}@keyframes skeleton-shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton-pulse{animation:skeleton-shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,#e8ecf1 25%,#f1f5f9 50%,#e8ecf1 75%);background-size:200px 100%;border-radius:8px}.skeleton-post{opacity:.7;pointer-events:none}.skeleton-avatar{border-radius:50%;flex-shrink:0;height:44px;width:44px}.skeleton-line{border-radius:6px;display:block}.skeleton-image{border-radius:12px;height:140px;width:100%}.skeleton-companion-card{align-items:center;display:flex;flex-direction:column;gap:16px;min-height:300px;padding:24px}.skeleton-companion-avatar{border-radius:50%;height:120px;width:120px}.skeleton-leaderboard-item{align-items:center;display:flex;gap:12px;padding:12px 16px}.skeleton-rank{border-radius:50%;height:30px;width:30px}.skeleton-lb-avatar{border-radius:50%;height:40px;width:40px}.pending-post{opacity:.75;pointer-events:none}body.dark-theme .post-card{background-color:var(--st-surface);color:var(--st-text)}body.dark-theme .author-name,body.dark-theme .post-caption{color:var(--st-text)}body.dark-theme .post-card-footer{border-top-color:var(--st-border)}body.dark-theme .post-action-btn{color:var(--st-text-muted)}body.dark-theme .post-dropdown-menu{background-color:var(--st-surface);border:2px solid var(--st-border)}body.dark-theme .dropdown-item{color:var(--st-text)}body.dark-theme .dropdown-item:hover{background-color:var(--st-surface-muted)}body.dark-theme .comments-drawer-content,body.dark-theme .modal-content{border-color:var(--st-border);color:var(--st-text)}body.dark-theme .comments-drawer-content{background-color:var(--st-surface)}body.dark-theme .comment-bubble{background-color:var(--st-surface-muted);color:var(--st-text)}body.dark-theme .comment-text-content,body.dark-theme .commenter-name{color:var(--st-text)}body.dark-theme .add-comment-form{border-top-color:var(--st-border)}body.dark-theme .add-comment-form input,body.dark-theme .post-input-text{background-color:var(--st-surface-muted);border-color:var(--st-border);color:var(--st-text)}body.dark-theme .tag-location-display{background-color:var(--st-surface-muted);color:var(--st-text)}body.dark-theme .feed-empty{background-color:var(--st-surface);color:var(--st-text)}body.dark-theme .feed-title{color:var(--st-text);text-shadow:2px 2px 0 var(--st-bg)}body.dark-theme .btn-close,body.dark-theme .btn-menu,body.dark-theme .modal-header h3,body.dark-theme .privacy-select-row{color:var(--st-text)}body.dark-theme .post-meta{color:var(--st-text-muted)}.guest-placeholder{margin-top:10vh;padding:40px 20px;text-align:center}.guest-placeholder-icon{font-size:60px;margin-bottom:20px}.guest-placeholder h2{color:#2c3e50;font-weight:900;margin-bottom:10px}.guest-placeholder p{color:#747d8c;font-weight:700;line-height:1.6;margin-bottom:30px}.guest-login-btn{background:#ffd32d;border:2.5px solid #2c3e50;border-radius:16px;box-shadow:0 4px 0 #2c3e50;color:#2c3e50;cursor:pointer;font-size:15px;font-weight:900;min-height:48px;padding:14px 30px;transition:transform .1s ease,box-shadow .1s ease}.guest-login-btn:active{box-shadow:none;transform:translateY(4px)}.leaflet-image-layer,.leaflet-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane,.leaflet-pane>canvas,.leaflet-pane>svg,.leaflet-tile,.leaflet-tile-container,.leaflet-zoom-box{left:0;position:absolute;top:0}.leaflet-container{overflow:hidden}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile{-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.leaflet-tile::selection{background:#0000}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{height:1600px;-webkit-transform-origin:0 0;width:1600px}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-height:none!important;max-width:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer{max-height:none!important;max-width:none!important;padding:0;width:auto}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{box-sizing:border-box;height:0;width:0;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{height:1px;width:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{pointer-events:visiblePainted;pointer-events:auto;position:relative;z-index:800}.leaflet-bottom,.leaflet-top{pointer-events:none;position:absolute;z-index:1000}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{clear:both;float:left}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-pan-anim .leaflet-tile,.leaflet-zoom-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-control,.leaflet-popup-pane{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:grabbing}.leaflet-image-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-image-layer.leaflet-interactive,.leaflet-marker-icon.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{background:#ffffff80;border:2px dotted #38f}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{border-radius:4px;box-shadow:0 1px 5px #000000a6}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;color:#000;display:block;height:26px;line-height:26px;text-align:center;text-decoration:none;width:26px}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:focus,.leaflet-bar a:hover{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom:none;border-bottom-left-radius:4px;border-bottom-right-radius:4px}.leaflet-bar a.leaflet-disabled{background-color:#f4f4f4;color:#bbb;cursor:default}.leaflet-touch .leaflet-bar a{height:30px;line-height:30px;width:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{background:#fff;border-radius:5px;box-shadow:0 1px 5px #0006}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);height:36px;width:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{height:44px;width:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{background:#fff;color:#333;padding:6px 10px 6px 6px}.leaflet-control-layers-scrollbar{overflow-x:hidden;overflow-y:scroll;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{border-top:1px solid #ddd;height:0;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{color:#333;line-height:1.4;padding:0 5px}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:focus,.leaflet-control-attribution a:hover{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;height:.6669em;vertical-align:initial!important;width:1em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{background:#fffc;border:2px solid #777;border-top:none;box-sizing:border-box;line-height:1.1;padding:2px 5px 1px;text-shadow:1px 1px #fff;white-space:nowrap}.leaflet-control-scale-line:not(:first-child){border-bottom:none;border-top:2px solid #777;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers{box-shadow:none}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-layers{background-clip:padding-box;border:2px solid #0003}.leaflet-popup{margin-bottom:20px;position:absolute;text-align:center}.leaflet-popup-content-wrapper{border-radius:12px;padding:1px;text-align:left}.leaflet-popup-content{font-size:13px;font-size:1.08333em;line-height:1.3;margin:13px 24px 13px 20px;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{height:20px;left:50%;margin-left:-20px;margin-top:-1px;overflow:hidden;pointer-events:none;position:absolute;width:40px}.leaflet-popup-tip{height:17px;margin:-10px auto 0;padding:1px;pointer-events:auto;transform:rotate(45deg);width:17px}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;box-shadow:0 3px 14px #0006;color:#333}.leaflet-container a.leaflet-popup-close-button{background:#0000;border:none;color:#757575;font:16px/24px Tahoma,Verdana,sans-serif;height:24px;position:absolute;right:0;text-align:center;text-decoration:none;top:0;width:24px}.leaflet-container a.leaflet-popup-close-button:focus,.leaflet-container a.leaflet-popup-close-button:hover{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678,M12=0.70710678,M21=-0.70710678,M22=0.70710678);margin:0 auto;width:24px}.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{background-color:#fff;border:1px solid #fff;border-radius:3px;box-shadow:0 1px 3px #0006;color:#222;padding:6px;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;white-space:nowrap}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before,.leaflet-tooltip-top:before{background:#0000;border:6px solid #0000;content:"";pointer-events:none;position:absolute}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{border-top-color:#fff;bottom:0;margin-bottom:-12px}.leaflet-tooltip-bottom:before{border-bottom-color:#fff;margin-left:-6px;margin-top:-12px;top:0}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{margin-top:-6px;top:50%}.leaflet-tooltip-left:before{border-left-color:#fff;margin-right:-12px;right:0}.leaflet-tooltip-right:before{border-right-color:#fff;left:0;margin-left:-12px}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.player-avatar-marker{align-items:center;display:flex;filter:drop-shadow(0 4px 12px rgba(108,92,231,.4));flex-direction:column;pointer-events:none}.player-avatar-ring{animation:avatar-glow 2.5s ease-in-out infinite;background:linear-gradient(135deg,#6c5ce7,#a29bfe);border-radius:50%;box-shadow:0 0 0 3px #6c5ce74d,0 0 20px #6c5ce766;height:40px;padding:3px;position:relative;width:40px}.player-avatar-img{background-color:#dfe6e9;border:2px solid #fff;border-radius:50%;height:100%;object-fit:cover;width:100%}.player-avatar-pulse{animation:avatar-pulse 2s ease-out infinite;border:2px solid #6c5ce780;border-radius:50%;bottom:-6px;left:-6px;position:absolute;right:-6px;top:-6px}.player-avatar-pointer{border-left:6px solid #0000;border-right:6px solid #0000;border-top:8px solid #6c5ce7;height:0;margin-top:-2px;width:0}.player-avatar-name{background:#6c5ce7e6;border-radius:10px;box-shadow:0 2px 8px #00000026;color:#fff;font-family:Inter,system-ui,sans-serif;font-size:10px;font-weight:700;letter-spacing:.3px;margin-top:2px;max-width:100px;overflow:hidden;padding:2px 8px;text-align:center;text-overflow:ellipsis;white-space:nowrap}@keyframes avatar-glow{0%,to{box-shadow:0 0 0 3px #6c5ce74d,0 0 20px #6c5ce766}50%{box-shadow:0 0 0 5px #6c5ce726,0 0 30px #6c5ce780}}@keyframes avatar-pulse{0%{opacity:.8;transform:scale(1)}70%{opacity:0;transform:scale(1.6)}to{opacity:0;transform:scale(1.6)}}.game-map-shell{--map-ink:#2c3e50;--map-cream:#fff9dd;--map-accent:#ffd32d;--map-aqua:#32d9d3;--map-hot:#ff5d5d;--map-grass:#58d68d;isolation:isolate;overflow:hidden;position:relative}.game-map-shell.card{background:radial-gradient(circle at 20% 14%,#ffffff75 0 8%,#0000 9%),linear-gradient(180deg,#f6df9d,#a9df9b 48%,#8fcce7);border:3px solid var(--map-ink);border-radius:24px;box-shadow:0 6px 0 var(--map-ink),0 14px 26px #22324833;height:350px;margin-bottom:25px;width:100%}.game-map-shell.full{background:radial-gradient(circle at 15% 14%,#fff5b86b 0 8%,#0000 9%),linear-gradient(180deg,#f6df9d,#a5df9b 50%,#8fcce7);border-radius:0;bottom:0;left:0;position:absolute;right:0;top:0;z-index:1}.game-map-shell:before{background:radial-gradient(circle at 18% 16%,#ffe87a2e 0 9%,#0000 10%),radial-gradient(circle at 82% 76%,#54d69224 0 11%,#0000 12%),linear-gradient(140deg,#ffffff1f,#3ecbff14);mix-blend-mode:soft-light}.game-map-shell:after,.game-map-shell:before{content:"";inset:0;pointer-events:none;position:absolute;z-index:2}.game-map-shell:after{background-image:linear-gradient(#2c3e5014 1px,#0000 0),linear-gradient(90deg,#2c3e5014 1px,#0000 0);background-size:96px 96px,96px 96px;opacity:.14}.game-map-frame{border:2px solid #2c3e5061;border-radius:inherit;inset:0;overflow:hidden;position:absolute;z-index:1}.game-map-shell.full .game-map-frame{border:0}.game-map-canvas,.game-map-canvas.leaflet-container{height:100%;width:100%}.game-map-canvas.leaflet-container{background:radial-gradient(circle at 20% 20%,#ffec8c33,#0000 24%),linear-gradient(180deg,#f6df9d,#a9df9b 48%,#8fcce7);font-family:Be Vietnam Pro,sans-serif}.game-map-shell .leaflet-tile-pane{transition:filter .25s ease;z-index:1}.game-map-shell .leaflet-overlay-pane,.game-map-shell .leaflet-shadow-pane{z-index:3}.game-map-shell .leaflet-marker-pane,.game-map-shell .leaflet-tooltip-pane{z-index:4}.game-map-shell .leaflet-control-container,.game-map-shell .leaflet-popup-pane{z-index:5}.game-map-shell.map-style-voyager .leaflet-tile-pane{filter:saturate(1.18) contrast(1.02) brightness(1.04) hue-rotate(-5deg)}.game-map-shell.map-style-satellite .leaflet-tile-pane{filter:saturate(1.8) contrast(1.2) brightness(.9)}.game-map-shell.map-style-traffic .leaflet-tile-pane{filter:saturate(1.55) contrast(1.28) brightness(1.12) hue-rotate(14deg)}.custom-div-icon.game-stop-icon,.hidden-task-icon.game-hidden-task-icon{background:#0000;border:0}.game-stop-marker{align-items:center;background:radial-gradient(circle at 32% 26%,#fffffff5 0 12%,#0000 13%),linear-gradient(180deg,#fff176,#2196f3 42%,#145ea8);background:radial-gradient(circle at 32% 26%,#fffffff5 0 12%,#0000 13%),linear-gradient(180deg,#fff176 0,var(--marker-color,#2196f3) 42%,#145ea8 100%);border:3px solid #fff;border-radius:11px 11px 16px 16px;box-shadow:0 0 0 2px #2c3e50f2,0 6px 0 #2c3e50a6,0 0 18px #2196f3;box-shadow:0 0 0 2px #2c3e50f2,0 6px 0 #2c3e50a6,0 0 18px var(--marker-color,#2196f3);color:#1d2d44;display:flex;font-size:13px;font-weight:900;height:34px;justify-content:center;position:relative;transform:translateY(-8px) rotate(-4deg);width:34px}.game-stop-marker:after{background:inherit;border-bottom:3px solid #fff;border-right:3px solid #fff;bottom:-10px;box-shadow:2px 2px 0 #2c3e50f2;content:"";height:14px;left:50%;position:absolute;transform:translateX(-50%) rotate(45deg);width:14px;z-index:-1}.game-stop-marker.status-next{animation:pulse-next-stop 1.35s ease-in-out infinite}.game-stop-marker.status-completed{opacity:.9}.game-hidden-task-marker{align-items:center;animation:map-float 2s ease-in-out infinite;background:radial-gradient(circle at 32% 26%,#ffffffeb 0 13%,#0000 14%),linear-gradient(145deg,#fff176,#7f8c8d 58%,#202a44);background:radial-gradient(circle at 32% 26%,#ffffffeb 0 13%,#0000 14%),linear-gradient(145deg,#fff176 0,var(--task-color,#7f8c8d) 58%,#202a44 100%);border:3px solid #fff;border-radius:50%;box-shadow:0 0 0 2px #2c3e50e6,0 7px 0 #2c3e508c,0 0 24px #7f8c8d;box-shadow:0 0 0 2px #2c3e50e6,0 7px 0 #2c3e508c,0 0 24px var(--task-color,#7f8c8d);color:#fff;cursor:pointer;display:flex;height:42px;justify-content:center;position:relative;width:42px}.game-hidden-task-orbit{animation:map-spin 8s linear infinite;border:2px dashed #7f8c8d;border:2px dashed var(--task-color,#7f8c8d);border-radius:50%;height:52px;left:-8px;opacity:.85;position:absolute;top:-8px;width:52px}.game-map-popup .leaflet-popup-content-wrapper{background:var(--map-cream);border:2px solid var(--map-ink);border-radius:14px;box-shadow:0 6px 0 #2c3e5080}.game-map-popup .leaflet-popup-content{color:var(--map-ink);font-family:Be Vietnam Pro,sans-serif;font-size:12px;line-height:1.45;margin:10px 12px}.game-map-popup .leaflet-popup-content b{font-size:13px}.game-map-popup .leaflet-popup-tip{background:var(--map-cream);box-shadow:2px 2px 0 #2c3e5066}.game-map-popup .leaflet-popup-close-button{color:#576574;font-size:16px;right:8px;top:6px}.game-map-shell .leaflet-bar{border:2px solid var(--map-ink);border-radius:14px;box-shadow:0 4px 0 #2c3e50bf;overflow:hidden}.game-map-shell .leaflet-bar a{background:#fffef5;border-bottom:2px solid #2c3e501f;color:var(--map-ink);font-size:18px;font-weight:900;height:34px;line-height:34px;width:34px}.game-map-shell .leaflet-bar a:hover{background:var(--map-accent);color:#243447}.game-map-shell .leaflet-control-attribution{background:#1a2636c7;border:1px solid #fff3;border-bottom:0;border-right:0;border-top-left-radius:8px;color:#dff2ff;font-size:10px;padding:2px 6px}.game-map-shell .leaflet-control-attribution a{color:#f8cb2e}@keyframes map-float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-4px) scale(1.05)}}@keyframes map-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes pulse-next-stop{0%,to{box-shadow:0 0 0 2px #2c3e50f2,0 6px 0 #2c3e5099,0 0 14px #ff9800;box-shadow:0 0 0 2px #2c3e50f2,0 6px 0 #2c3e5099,0 0 14px var(--marker-color,#ff9800);transform:scale(1)}50%{box-shadow:0 0 0 2px #2c3e50f2,0 6px 0 #2c3e5099,0 0 20px #ff9800;box-shadow:0 0 0 2px #2c3e50f2,0 6px 0 #2c3e5099,0 0 20px var(--marker-color,#ff9800);transform:scale(1.16)}}@media (max-width:768px){.game-map-shell:after{background-size:84px 84px,84px 84px;opacity:.1}}.location-screen-full{border-radius:0;font-family:Inter,sans-serif;height:100%;left:0;margin:0;overflow:hidden;padding:0;position:absolute;top:0;width:100%}.map-overlay-top{align-items:flex-start;display:flex;justify-content:space-between;left:20px;pointer-events:none;position:absolute;right:20px;top:16px;z-index:10}.map-title-box{background:#0000}.map-title-main{-webkit-text-stroke:.5px var(--st-surface);color:var(--st-text);font-family:Fredoka,sans-serif;font-size:32px;font-weight:900;letter-spacing:-1px;line-height:1.1;margin:0;text-shadow:1.5px 1.5px 0 var(--st-surface)}.map-title-sub{align-items:center;background-color:var(--st-surface);border:1.5px solid var(--game-border-color);border-radius:8px;color:var(--st-text);display:flex;font-size:11px;font-weight:800;gap:8px;letter-spacing:1px;margin-top:4px;padding:2px 8px;width:fit-content}.dot-blue{background-color:#3b82f6;border-radius:50%;display:inline-block;height:6px;width:6px}.map-top-actions{display:flex;gap:12px;pointer-events:auto}.map-circle-btn{align-items:center;background:var(--st-surface);border:2.5px solid var(--game-border-color);border-radius:50%;box-shadow:0 3px 0 var(--game-border-color);color:var(--st-text);cursor:pointer;display:flex;height:44px;justify-content:center;transition:transform .1s ease,box-shadow .1s ease,background-color .2s ease;width:44px}.map-circle-btn:hover{background:var(--st-surface-muted)}.map-circle-btn:active{box-shadow:none;transform:translateY(3px)}.map-my-location-btn{align-items:center;background:var(--st-surface);border:2.5px solid var(--game-border-color);border-radius:50%;bottom:110px;box-shadow:0 4px 0 var(--game-border-color);cursor:pointer;display:flex;height:50px;justify-content:center;position:absolute;right:20px;transition:transform .1s ease,box-shadow .1s ease,background-color .2s ease;width:50px;z-index:10}.map-my-location-btn:hover{background:var(--st-surface-muted)}.map-my-location-btn:active{box-shadow:none;transform:translateY(4px)}.placeholder-screen{background-color:var(--st-bg);min-height:100%;padding:20px}.map-search-result-item{fontSize:13px;background-color:var(--st-surface-muted);border:1.5px solid var(--st-border);border-radius:8px;color:var(--st-text);cursor:pointer;font-weight:600;padding:8px 12px;transition:background-color .2s,color .2s}.map-search-result-item:hover{background-color:var(--game-yellow)!important;color:#2c3e50!important}.find-companions-container{background-color:#e0f2fe;background-color:var(--st-bg,#e0f2fe);box-sizing:border-box;display:flex;flex-direction:column;font-family:Fredoka,Be Vietnam Pro,sans-serif;gap:16px;height:100%;overflow-y:auto;padding:16px}.matching-header{align-items:center;display:flex;justify-content:space-between;padding-bottom:8px}.matching-title{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-size:26px;font-weight:900;text-shadow:2px 2px 0 #fff}.matching-subtitle{color:#747d8c;font-size:11px;font-weight:700;margin-top:2px}.matching-header-icon{align-items:center;background-color:#fff;border:2.5px solid #2c3e50;border:2.5px solid var(--game-border-color,#2c3e50);border-radius:50%;box-shadow:0 4px 0 #2c3e50;box-shadow:0 4px 0 var(--game-border-color,#2c3e50);display:flex;height:44px;justify-content:center;width:44px}.spin-compass{animation:spin 8s linear infinite;color:#1e90ff;color:var(--game-blue,#1e90ff)}.tabs-row{background-color:#fff;display:flex;padding:4px}.tab-btn{background:none;border:none;border-radius:18px;color:#747d8c;cursor:pointer;flex:1 1;font-size:12px;font-weight:900;padding:10px;text-transform:uppercase;transition:all .2s ease}.tab-btn.active-tab{background-color:#1e90ff;background-color:var(--game-blue,#1e90ff);box-shadow:inset 0 -3px 0 #00000026;color:#fff}.discover-area{flex:1 1;padding-bottom:60px;position:relative}.discover-area,.matching-loading{align-items:center;display:flex;justify-content:center}.matching-loading{flex-direction:column;gap:12px}.match-card{background-color:#fff;display:flex;flex-direction:column;max-width:340px;overflow:hidden;position:relative;width:100%}.match-image-wrapper{background-color:#f1f2f6;border-bottom:3px solid #2c3e50;border-bottom:3px solid var(--game-border-color,#2c3e50);height:280px;position:relative;width:100%}.match-avatar{height:100%;object-fit:cover;width:100%}.match-percentage-badge{align-items:center;background-color:#2ed573;background-color:var(--game-green,#2ed573);border:2.5px solid #2c3e50;border:2.5px solid var(--game-border-color,#2c3e50);border-radius:12px;box-shadow:0 3px 0 #2c3e50;box-shadow:0 3px 0 var(--game-border-color,#2c3e50);color:#fff;display:flex;font-size:11px;font-weight:900;gap:4px;left:16px;padding:4px 10px;position:absolute;top:16px}.match-info{display:flex;flex-direction:column;gap:8px;padding:16px}.match-name{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-size:20px;font-weight:900}.match-location-row{align-items:center;color:#747d8c;display:flex;font-size:12px;font-weight:800;gap:4px}.loc-pin-icon{color:#ff4757;color:var(--game-red,#ff4757)}.match-bio{color:#57606f;font-size:12px;font-style:italic;font-weight:600;line-height:1.4}.tinder-actions{display:flex;gap:24px;justify-content:center;margin-top:-8px;padding:16px}.action-swipe-btn{border-radius:50%!important;box-shadow:0 4px 0 #2c3e50!important;box-shadow:0 4px 0 var(--game-border-color,#2c3e50)!important;height:56px;padding:0!important;width:56px}.empty-companions{align-items:center;background-color:#fff;display:flex;flex-direction:column;gap:16px;max-width:320px;padding:40px 20px;width:100%}.empty-icon{animation:rotate 12s linear infinite;color:#ff9f1a;color:var(--game-orange,#ff9f1a)}@keyframes rotate{to{transform:rotate(1turn)}}.pending-area{gap:16px}.empty-pending,.pending-area{display:flex;flex-direction:column}.empty-pending{align-items:center;background-color:#fff;color:#747d8c;font-size:13px;font-weight:800;gap:8px;padding:32px}.empty-icon-warning{color:#ffd32d;color:var(--game-yellow,#ffd32d)}.pending-card,.pending-list{display:flex;flex-direction:column;gap:12px}.pending-card{background-color:#fff;padding:16px}.pending-card-info{align-items:center;display:flex;gap:12px}.pending-avatar{background-color:#ffd32d;background-color:var(--game-yellow,#ffd32d);border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:50%;height:40px;width:40px}.pending-name{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-size:13px;font-weight:800}.pending-time{color:#a4b0be;font-size:10px;font-weight:600}.pending-actions{display:flex;gap:12px}.respond-btn{border-radius:12px;flex:1 1;font-size:11px;padding:8px 12px}body.dark-theme .matching-header-icon,body.dark-theme .tabs-row{background-color:var(--st-surface);border-color:var(--st-border)}body.dark-theme .match-card{background-color:var(--st-surface);border:3px solid var(--game-border-color);box-shadow:0 6px 0 var(--game-border-color);color:var(--st-text)}body.dark-theme .match-name{color:var(--st-text)}body.dark-theme .match-bio{color:var(--st-text-muted)}body.dark-theme .empty-companions,body.dark-theme .empty-pending{background-color:var(--st-surface);border-color:var(--st-border);color:var(--st-text)}body.dark-theme .pending-card{background-color:var(--st-surface);border:3px solid var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color);color:var(--st-text)}body.dark-theme .pending-name{color:var(--st-text)}body.dark-theme .matching-title{color:var(--st-text);text-shadow:2px 2px 0 var(--st-bg)}.chat-container{background-color:#e0f2fe;background-color:var(--st-bg,#e0f2fe);box-sizing:border-box;display:flex;flex-direction:column;font-family:Fredoka,Be Vietnam Pro,sans-serif;height:100%;min-height:0;overflow-y:auto;padding:16px}.chat-container.active-chat-container{overflow:hidden;padding-top:calc(16px + env(safe-area-inset-top, 0px))}.chat-container.active-chat-container.ios-standalone-chat{background-color:#e0f2fe;background-color:var(--st-bg,#e0f2fe);height:100dvh;height:var(--chat-visual-height,100dvh);left:0;padding-bottom:0;position:fixed;right:0;top:0;top:var(--chat-visual-offset-top,0);width:100%;z-index:1100}@media (max-width:600px){.chat-container.active-chat-container.ios-standalone-chat{padding-top:max(env(safe-area-inset-top,0px),54px)}.ios-standalone-chat .chat-input-box{font-size:16px}}.chat-friends-view{gap:16px;height:100%}.chat-friends-view,.chat-header{display:flex;flex-direction:column}.chat-header{padding-bottom:8px}.chat-title{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-size:26px;font-weight:900;text-shadow:2px 2px 0 #fff}.chat-subtitle{color:#747d8c;font-size:11px;font-weight:700;margin-top:2px}.chat-loading{gap:12px;justify-content:center;margin-top:40px}.chat-loading,.empty-friends{align-items:center;display:flex;flex-direction:column}.empty-friends{background-color:#fff;gap:16px;margin-top:20px;padding:40px 20px}.friends-list{display:flex;flex-direction:column;gap:12px;padding-bottom:80px}.friend-item-card{align-items:center;background-color:#fff;cursor:pointer;display:flex;gap:12px;padding:12px;transition:transform .2s ease}.friend-item-card:active{transform:scale(.98)}.friend-avatar{background-color:#ffd32d;background-color:var(--game-yellow,#ffd32d);border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:50%;height:48px;width:48px}.friend-info{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.friend-info-header{align-items:center;display:flex;gap:8px}.friend-name{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-size:14px;font-weight:900}.friend-rank-badge{background-color:#ff9f1a;background-color:var(--game-orange,#ff9f1a);border-radius:6px;color:#fff;font-size:8px;font-weight:900;padding:2px 6px}.friend-bio{color:#747d8c;font-size:11px;font-weight:600}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-arrow{color:#cbd5e1;font-size:20px;font-weight:900}.active-chat-view{display:flex;flex-direction:column;height:100%;min-height:0;position:relative}.active-chat-header{align-items:center;background-color:#fff;display:flex;flex-shrink:0;gap:12px;padding:12px;z-index:10}.chat-back-btn{align-items:center;background:none;border:none;color:#2c3e50;color:var(--game-border-color,#2c3e50);cursor:pointer;display:flex;justify-content:center}.active-friend-info{align-items:center;display:flex;flex:1 1;gap:10px}.active-friend-avatar{border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:50%;height:36px;width:36px}.active-friend-name{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-size:13px;font-weight:900;margin:0}.chat-clear-btn{background:none;border:none;color:#ff4757;color:var(--game-red,#ff4757);cursor:pointer}.chat-messages-area{-webkit-overflow-scrolling:touch;display:flex;flex:1 1;flex-direction:column;margin-bottom:74px;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding:16px 0}.chat-empty-history{color:#747d8c;font-size:12px;font-weight:700;line-height:1.4;margin:auto;max-width:220px}.messages-list{display:flex;flex-direction:column;gap:12px}.message-bubble-row{align-items:flex-end;display:flex;gap:8px;max-width:80%}.message-bubble-row.me{align-self:flex-end;flex-direction:row-reverse}.message-bubble-row.them{align-self:flex-start}.bubble-avatar{border:1.5px solid #2c3e50;border:1.5px solid var(--game-border-color,#2c3e50);border-radius:50%;height:28px;width:28px}.message-bubble{background-color:#fff;border-radius:16px!important;display:flex;flex-direction:column;gap:4px;padding:10px 12px}.message-bubble.blue{background-color:#70a1ff;background-color:var(--game-sky,#70a1ff);color:#fff}.message-bubble.blue .message-time{color:#ffffffb3}.message-content-text{font-size:12px;font-weight:700;line-height:1.4}.message-time{align-self:flex-end;color:#a4b0be;font-size:8px;font-weight:800}.chat-input-row,.message-time{align-items:center;display:flex}.chat-input-row{background-color:#fff;bottom:8px;gap:8px;left:0;padding:6px;position:absolute;right:0;z-index:10}.ios-standalone-chat .chat-messages-area{margin-bottom:98px}.ios-standalone-chat .chat-input-row{bottom:max(calc(env(safe-area-inset-bottom, 0px) + 8px),24px)}html.chat-keyboard-visible .chat-container.active-chat-container{padding:calc(8px + env(safe-area-inset-top, 0px)) 8px 8px}@media (max-width:600px){html.chat-keyboard-visible .chat-container.active-chat-container.ios-standalone-chat{padding-top:max(env(safe-area-inset-top,0px),54px)}}html.chat-keyboard-visible .active-chat-header{padding:8px 10px}html.chat-keyboard-visible .chat-messages-area{margin-bottom:66px;padding:8px 0}html.chat-keyboard-visible .chat-input-row{bottom:4px}.chat-input-box{background-color:#f1f2f6;border:none;border-radius:16px;flex:1 1;font-size:12px;font-weight:700;outline:none;padding:10px 14px}.send-msg-btn{border-radius:16px!important;height:auto!important;padding:10px 14px!important}.friend-last-message{color:#747d8c;font-size:11px;font-weight:600}.friend-last-message.unread-bold{color:#2c3e50;color:var(--game-border-color,#2c3e50);font-weight:900}.friend-time-col{align-items:flex-end;display:flex;flex-direction:column;gap:6px;min-width:55px}.friend-time{color:#a4b0be;font-size:9px;font-weight:800}.unread-badge{background-color:#70a1ff;background-color:var(--game-sky,#70a1ff);border-radius:50%;display:inline-block;height:8px;width:8px}body.dark-theme .empty-friends,body.dark-theme .friend-item-card{background-color:var(--st-surface);border:3px solid var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color);color:var(--st-text)}body.dark-theme .friend-name{color:var(--st-text)}body.dark-theme .active-chat-header{background-color:var(--st-surface);border-bottom:2px solid var(--st-border);color:var(--st-text)}body.dark-theme .message-bubble{background-color:var(--st-surface);border:2px solid var(--st-border);color:var(--st-text)}body.dark-theme .message-bubble.blue{background-color:var(--game-sky);border-color:var(--game-border-color);color:#fff}body.dark-theme .chat-input-row{background-color:var(--st-surface);border-top:2px solid var(--st-border)}body.dark-theme .chat-input-box{background-color:var(--st-surface-muted);border:2px solid var(--st-border);color:var(--st-text)}body.dark-theme .chat-title{color:var(--st-text);text-shadow:2px 2px 0 var(--st-bg)}body.dark-theme .active-friend-name,body.dark-theme .chat-back-btn,body.dark-theme .friend-last-message.unread-bold{color:var(--st-text)}.favorite-location-list{grid-gap:10px;display:grid;gap:10px;margin-bottom:22px}.favorite-location-list h3{color:var(--st-text);font-size:13px;margin:0 0 2px;text-transform:uppercase}.favorite-location-card{align-items:center;background:var(--st-surface);border:2px solid var(--game-border-color);border-radius:16px;box-shadow:0 3px 0 var(--game-border-color);color:var(--st-text);cursor:pointer;display:flex;gap:10px;padding:8px;text-align:left;width:100%}.favorite-location-card>span{grid-gap:4px;display:grid;flex:1 1;gap:4px;min-width:0}.favorite-location-card strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.favorite-location-card small{align-items:center;color:var(--st-text-muted);display:flex;gap:3px}.favorite-location-card>svg{color:#e74c3c;margin-right:5px}.favorite-location-image{background-color:var(--st-surface-muted);background-position:50%;background-size:cover;border-radius:12px;color:var(--st-text-muted);display:grid;flex:0 0 58px;height:58px;place-items:center;width:58px}.favorite-location-state{background:var(--st-surface);border:2px dashed var(--st-border);border-radius:16px;color:var(--st-text-muted);display:grid;font-size:12px;font-weight:700;min-height:68px;padding:12px;place-items:center;text-align:center}.favorite-location-state--empty{display:flex;gap:8px;justify-content:center}.favorites-filter-tabs{display:flex;gap:8px;margin-bottom:8px}.favorites-filter-btn{background:var(--st-surface);border:2px solid var(--game-border-color);border-radius:12px;box-shadow:0 3px 0 var(--game-border-color);color:var(--st-text);cursor:pointer;flex:1 1;font-size:11px;font-weight:850;padding:8px 10px;text-align:center;transition:transform .1s ease,box-shadow .1s ease}.favorites-filter-btn:active{box-shadow:0 1px 0 var(--game-border-color);transform:translateY(2px)}.favorites-filter-btn.active{border-color:var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color)}.favorites-filter-btn.active,body.dark-theme .favorites-filter-btn.active{background:#ff4757;color:#fff}.vouchers-list{grid-gap:12px;display:grid;gap:12px}.voucher-item-card{align-items:center;background-color:var(--st-surface);border:2px solid #dbe3ee;border:2px solid var(--st-border,#dbe3ee);border-radius:18px;box-shadow:0 8px 22px #24344714;color:var(--st-text);cursor:pointer;display:flex;gap:12px;overflow:hidden;padding:10px;position:relative;transition:transform .15s,box-shadow .15s,background-color .3s ease,border-color .3s ease}.voucher-item-card:before{border-left:1px dashed #dbe3ee;border-left:1px dashed var(--st-border,#dbe3ee);bottom:12px;content:"";left:102px;position:absolute;top:12px}.voucher-item-card:active{box-shadow:0 3px 10px #24344714;transform:scale(.985)}.voucher-item-card.disabled{background-color:var(--st-surface-muted);border-color:var(--st-border);box-shadow:none;cursor:not-allowed;opacity:.6}.voucher-item-img-container{align-items:center;background:linear-gradient(145deg,#fff4d6,#ffd979);border:0;border-radius:14px;color:#c77700;display:flex;flex-shrink:0;height:88px;justify-content:center;overflow:hidden;width:80px}.voucher-item-img-container img{height:100%;object-fit:cover;width:100%}.voucher-item-info{display:flex;flex:1 1;flex-direction:column;gap:5px;min-width:0;padding-left:8px}.voucher-brand{color:var(--st-text-muted);font-size:10px;font-weight:900;letter-spacing:.5px;text-transform:uppercase}.voucher-title{color:var(--st-text);font-size:15px;font-weight:900;line-height:1.2}.voucher-cost{align-items:center;color:var(--st-text-muted);display:flex;flex-wrap:wrap;font-size:12px;font-weight:600;gap:4px}.voucher-cost b{color:#e67e22}.voucher-stock{background:var(--st-surface-muted);border-radius:999px;color:var(--st-text-muted);font-size:10px;margin-left:auto;padding:2px 7px}.voucher-btn{align-self:flex-start;border-radius:999px;font-size:13px!important;margin-top:4px;padding:6px 16px!important}.voucher-wallet{display:flex;flex-direction:column;gap:18px}.voucher-wallet-hero{align-items:center;background:linear-gradient(135deg,#1455d9,#2094f3);border-radius:22px;box-shadow:0 12px 30px #1e90ff40;color:#fff;display:flex;gap:14px;padding:18px}.voucher-wallet-hero-icon{background:#ffffff2e;border:1px solid #ffffff59;border-radius:18px;display:grid;height:54px;place-items:center;width:54px}.voucher-wallet-hero p,.voucher-wallet-hero span{font-size:11px;margin:0;opacity:.82}.voucher-wallet-hero h2{font-size:24px;margin:2px 0}.voucher-wallet-section h3{align-items:center;color:var(--st-text);display:flex;font-size:13px;gap:7px;letter-spacing:.4px;margin:0 0 10px;text-transform:uppercase}.voucher-wallet-section h3 span{background:var(--st-surface-muted);border-radius:999px;color:var(--st-text-muted);margin-left:auto;padding:3px 8px}.voucher-empty-state,.voucher-state-card{align-items:center;background:#f8fafc;background:var(--st-surface-muted,#f8fafc);border:1.5px dashed #cbd5e1;border:1.5px dashed var(--st-border,#cbd5e1);border-radius:18px;color:#64748b;color:var(--st-text-muted,#64748b);display:flex;flex-direction:column;gap:6px;justify-content:center;min-height:120px;padding:18px;text-align:center}.voucher-empty-state span,.voucher-state-card span{font-size:12px}.voucher-state-card--error{background:#fff3f2;color:#c0392b}.voucher-detail-box{background-color:var(--st-surface);border:0;border-radius:20px;box-shadow:0 14px 34px #00000029;padding:20px;text-align:left}.voucher-detail-title{color:var(--st-text);font-size:22px;font-weight:900;line-height:1.3;margin-bottom:8px}.voucher-detail-desc{color:var(--st-text);font-size:15px;font-weight:500;margin-bottom:12px}.voucher-detail-discount{color:#e67e22;font-size:24px;font-weight:900;margin-bottom:12px}.voucher-code-label{color:var(--st-text-muted);display:block;font-size:10px;letter-spacing:.8px;text-transform:uppercase}.voucher-detail-meta{align-items:center;color:var(--st-text);display:flex;font-size:13px;font-weight:700;gap:6px;margin-bottom:6px}body.dark-theme .voucher-wallet-hero{background:linear-gradient(135deg,#17428d,#1769aa)}.profile-screen{font-family:Be Vietnam Pro,sans-serif;min-height:100%;padding:20px 20px calc(100px + env(safe-area-inset-bottom, 0px))}.profile-player-card{background:linear-gradient(135deg,#ffd32d,#ff9f1a);border-radius:24px;margin-bottom:16px;padding:24px 20px;text-align:center}.profile-avatar-frame{height:80px;margin:0 auto 12px;position:relative;width:80px}.profile-avatar-frame .profile-avatar{border:4px solid #2c3e50;border-radius:50%;box-shadow:0 4px 0 #2c3e50;height:80px;object-fit:cover;width:80px}.profile-level-badge{background-color:#ff4757;border:2.5px solid #2c3e50;border-radius:10px;bottom:-6px;color:#fff;font-size:11px;padding:2px 8px;position:absolute;right:-6px}.profile-level-badge,.profile-player-name{font-family:Fredoka,sans-serif;font-weight:700}.profile-player-name{-webkit-text-stroke:.3px #2c3e50;color:#2c3e50;font-size:20px;margin:0}.profile-player-tier{background:#ffffff80;border:1.5px solid #2c3e50;border-radius:8px;color:#2c3e50;display:inline-block;font-size:12px;font-weight:700;margin-top:4px;padding:2px 10px}.profile-exp-section{background:#0000001a;border-radius:12px;margin-top:16px;padding:8px 12px}.profile-exp-label{color:#2c3e50;display:flex;font-size:11px;font-weight:700;justify-content:space-between;margin-bottom:4px}.profile-exp-bar{background-color:#00000026;border:1.5px solid #2c3e50;border-radius:5px;height:10px;overflow:hidden;width:100%}.profile-exp-fill{background:linear-gradient(90deg,#2ed573,#7bed9f);border-radius:5px;height:100%;transition:width .5s ease}.profile-stats-row{display:flex;gap:10px;margin-bottom:16px}.profile-stat-box{background-color:#fff;border:3px solid #2c3e50;border-radius:20px;flex:1 1;padding:14px 8px;text-align:center}.stat-box-icon{font-size:24px;margin-bottom:4px}.stat-box-value{color:#2c3e50;font-family:Fredoka,sans-serif;font-size:18px;font-weight:700}.stat-box-label{color:#747d8c;font-size:10px;font-weight:600;margin-top:2px}.stat-stack-item{align-items:center;background-color:#3498db26;border:2px solid #2c3e50;border-radius:12px;box-shadow:0 3px 0 #2c3e50;color:#2c3e50;display:flex;font-family:Be Vietnam Pro,sans-serif;font-size:14px;font-weight:800;justify-content:center;padding:10px 16px;text-align:center;width:100%}.profile-menu-btn{gap:12px;margin-bottom:10px;padding:14px 16px}.menu-btn-icon{flex-shrink:0;font-size:20px}.menu-btn-arrow{color:#a4b0be;font-size:18px;font-weight:700;margin-left:auto}.profile-menu-list{display:flex;flex-direction:column}.achievements-card{background-color:#fffdf0;border-radius:24px;margin-bottom:20px;padding:20px}.achievements-title{-webkit-text-stroke:.5px #2c3e50;align-items:center;color:#ff9f1a;display:flex;font-size:16px;font-weight:900;gap:8px;margin:0 0 15px}.achievements-filter-row{display:flex;gap:8px;margin-bottom:20px}.achievements-filter-btn{border:2.5px solid #2c3e50;border-radius:12px;cursor:pointer;flex:1 1;font-size:12px;font-weight:900;min-height:44px;padding:10px 6px;transition:transform .1s ease,box-shadow .1s ease}.achievements-filter-btn:active{box-shadow:none;transform:translateY(3px)}.achievements-filter-btn.active{background-color:#ffd32d;color:#2c3e50}.achievements-filter-btn.inactive{background-color:#fff;color:#576574}.achievements-list{display:flex;flex-direction:column;gap:15px}.achievement-item{align-items:center;border:2.5px solid #2c3e50;border-radius:16px;box-shadow:0 4px 0 #2c3e50;display:flex;gap:15px;padding:12px}.achievement-item.unlocked{background-color:#fff}.achievement-item.locked{background-color:#f1f2f6;filter:grayscale(.8);opacity:.65}.achievement-icon{align-items:center;border-radius:50%;box-shadow:0 2.5px 0 #2c3e50;display:flex;flex-shrink:0;font-size:28px;height:48px;justify-content:center;width:48px}.achievement-icon.unlocked{background-color:#ffd32d}.achievement-icon.locked{background-color:#a4b0be}.achievement-details{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.achievement-header{align-items:center;display:flex;gap:8px;justify-content:space-between}.achievement-name{color:#2c3e50;font-size:14px;font-weight:900}.achievement-badge{border:1.5px solid #2c3e50;border-radius:8px;font-size:10px;font-weight:900;padding:2px 8px;white-space:nowrap}.achievement-badge.unlocked{background-color:#2ed573;color:#fff}.achievement-badge.locked{background-color:#ff4757;color:#fff}.achievement-desc{color:#747d8c;font-size:12px;font-weight:700;text-align:left}.achievement-progress{margin-top:5px}.achievement-progress-header{color:#747d8c;display:flex;font-size:10px;font-weight:700;justify-content:space-between;margin-bottom:2px}.achievement-progress-bar{background-color:#dfe6e9;border:1.5px solid #2c3e50;border-radius:4px;height:8px;overflow:hidden;width:100%}.achievement-progress-fill{background-color:#2ed573;border-radius:4px;height:100%}.achievement-unlock-date{align-items:center;color:#2ed573;display:flex;font-size:11px;font-weight:900;gap:4px}.profile-empty,.profile-loading{color:#747d8c;font-weight:700;padding:10px;text-align:center}.profile-menu-btn{align-items:center;background-color:#fff;border-radius:16px;cursor:pointer;display:flex;gap:15px;margin-bottom:12px;min-height:52px;padding:16px 20px;text-align:left;width:100%}.profile-menu-btn:hover{background-color:#f8f9fa}.profile-menu-icon{font-size:20px}.profile-menu-icon.settings{color:#2c3e50}.profile-menu-label{color:#2c3e50;font-size:14px;font-weight:900}.profile-logout-btn{background-color:#ff4757!important;border:2.5px solid #2c3e50!important;margin-top:10px}.profile-logout-btn span.logout-text{color:#fff;font-weight:900}.quest-action-btn.with-top-margin{margin-top:15px}.photo-camera-icon{font-size:32px}.photo-helper-text{color:#a4b0be}.success-reward-icon{font-size:24px}.profile-screen{background-color:#e0f2fe}.profile-player-card{background:linear-gradient(180deg,#fff,#f8fbff);border:3px solid #2c3e50;box-shadow:0 6px 0 #2c3e50}.profile-avatar-frame .profile-avatar{border:3px solid #2c3e50;box-shadow:0 3px 0 #2c3e50}.profile-level-badge{border:2px solid #2c3e50;box-shadow:0 2px 0 #2c3e50}.profile-player-name{-webkit-text-stroke:0}.profile-player-tier{background:#eaf2ff;border:2px solid #2c3e50;color:#1f3a5f}.profile-tier-row{align-items:center;display:inline-flex;gap:4px}.profile-exp-section{background:#eef6ff;border:1.5px solid #2c3e50}.profile-exp-title{align-items:center;display:inline-flex;gap:4px}.profile-stats-row{gap:12px}.profile-stat-box{border:2.5px solid #2c3e50;box-shadow:0 4px 0 #2c3e50}.stat-box-icon{align-items:center;color:#334155;display:inline-flex;justify-content:center}.achievements-card{background-color:#fff;border:3px solid #2c3e50;box-shadow:0 6px 0 #2c3e50}.achievements-title{-webkit-text-stroke:0;color:#1e293b}.achievements-filter-btn{font-weight:800}.achievement-item,.achievements-filter-btn{border:2px solid #2c3e50;box-shadow:0 3px 0 #2c3e50}.achievement-item.locked{filter:none;opacity:.72}.achievement-icon{border:2px solid #2c3e50;box-shadow:0 2px 0 #2c3e50}.achievement-icon-svg{color:#334155}.profile-menu-btn{border:2.5px solid #2c3e50;box-shadow:0 4px 0 #2c3e50;transition:transform .1s ease,box-shadow .1s ease}.profile-menu-btn:active{box-shadow:none;transform:translateY(4px)}.menu-btn-icon{align-items:center;background:#e9f2ff;border-radius:50%;color:#334155;display:inline-flex;height:28px;justify-content:center;width:28px}.profile-admin-dashboard-btn{border-color:#b91c1c!important;border-left:6px solid #dc2626!important;color:#b91c1c}.profile-admin-dashboard-btn .menu-btn-icon{background:#fee2e2;color:#b91c1c}.profile-admin-dashboard-btn .menu-btn-arrow,.profile-admin-dashboard-btn .profile-menu-label{color:#b91c1c}.profile-logout-btn{background-color:#ef4444!important;border-color:#2c3e50!important}.profile-logout-btn .menu-btn-icon{background:#fff3;color:#fff}@media (max-width:380px){.profile-stats-row{gap:8px}.profile-stat-box{padding:12px 6px}.stat-box-value{font-size:15px}.profile-player-name{font-size:18px}}body.dark-theme .profile-screen{background-color:var(--st-bg)}body.dark-theme .profile-player-card{background:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 6px 0 var(--game-border-color)}body.dark-theme .profile-player-name{color:var(--st-text)}body.dark-theme .profile-stat-box{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .profile-stat-box .stat-box-value{color:var(--st-text)}body.dark-theme .profile-stat-box .stat-box-label{color:var(--st-text-muted)}body.dark-theme .stat-stack-item{background-color:#3498db40;border-color:var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color);color:var(--st-text)}body.dark-theme .achievements-card{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 6px 0 var(--game-border-color)}body.dark-theme .achievements-title{color:var(--st-text)}body.dark-theme .achievement-item{border-color:var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color)}body.dark-theme .achievement-item.unlocked{background-color:var(--st-surface)}body.dark-theme .achievement-item.locked{background-color:var(--st-surface-muted)}body.dark-theme .achievement-name{color:var(--st-text)}body.dark-theme .profile-menu-btn{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .profile-menu-label{color:var(--st-text)}.modal-overlay{align-items:center;animation:fadeInFeedback .25s ease;background-color:#0a0f1eb3;bottom:0;display:flex;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;z-index:3000}.modal-content{background-color:#fff;border:3.5px solid #2c3e50;box-shadow:0 8px 0 #2c3e50;transition:transform .2s ease}body.dark-theme .modal-content{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 8px 0 var(--game-border-color)}.feedback-field select,.feedback-field textarea{font-family:Be Vietnam Pro,sans-serif;font-size:14px}@keyframes fadeInFeedback{0%{opacity:0}to{opacity:1}}.chest-modal-overlay{animation:fadeIn .4s cubic-bezier(.25,.8,.25,1) forwards;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0a0f1ed9;bottom:0;box-sizing:border-box;color:var(--st-text);font-family:Outfit,Inter,sans-serif;left:0;opacity:0;padding:calc(16px + env(safe-area-inset-top, 0px)) 16px calc(16px + env(safe-area-inset-bottom, 0px));position:fixed;right:0;top:0;-webkit-user-select:none;user-select:none;z-index:9999}.chest-modal-container,.chest-modal-overlay{align-items:center;display:flex;justify-content:center}.chest-modal-container{background:var(--st-surface);border:1px solid var(--st-border);border-radius:28px;box-shadow:var(--st-shadow);flex-direction:column;max-height:calc(100dvh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 20px);max-width:450px;overflow:hidden;overflow-y:auto;padding:30px;position:relative;text-align:center;transition:background-color .3s ease,border-color .3s ease;width:90%}.chest-glow-bg{animation:pulseGlow 3s ease-in-out infinite;border-radius:50%;filter:blur(60px);height:250px;opacity:.35;pointer-events:none;position:absolute;top:15%;width:250px;z-index:1}@keyframes pulseGlow{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.55;transform:scale(1.2)}}.glow-COMMON{background:radial-gradient(circle,#7f8c8d 0,#0000 70%)}.glow-RARE{background:radial-gradient(circle,#0abde3 0,#0000 70%)}.glow-EPIC{background:radial-gradient(circle,#af70ff 0,#0000 70%)}.glow-LEGENDARY{background:radial-gradient(circle,#ffca28 0,#0000 70%)}.particle-canvas{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:2}.chest-wrapper{align-items:center;cursor:pointer;display:flex;height:180px;justify-content:center;margin:20px 0;position:relative;width:180px;z-index:3}.chest-floating{animation:floatChest 3s ease-in-out infinite}@keyframes floatChest{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-10px) rotate(1deg)}}.chest-shaking{animation:shakeChest .5s infinite}@keyframes shakeChest{0%{transform:translate(1px,1px) rotate(0deg)}10%{transform:translate(-1px,-2px) rotate(-1deg)}20%{transform:translate(-3px) rotate(1deg)}30%{transform:translateY(2px) rotate(0deg)}40%{transform:translate(1px,-1px) rotate(1deg)}50%{transform:translate(-1px,2px) rotate(-1deg)}60%{transform:translate(-3px,1px) rotate(0deg)}70%{transform:translate(2px,1px) rotate(-1deg)}80%{transform:translate(-1px,-1px) rotate(1deg)}90%{transform:translate(2px,2px) rotate(0deg)}to{transform:translate(1px,-2px) rotate(-1deg)}}.chest-open-animation{animation:openChest .8s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes openChest{0%{transform:scale(1)}30%{transform:scale(1.15) rotate(-3deg)}50%{transform:scale(.9) translateY(10px)}to{opacity:0;transform:scale(1.2) translateY(-20px)}}.rarity-badge{border:1px solid #ffffff40;border-radius:20px;box-shadow:0 4px 10px #0003;font-size:13px;font-weight:800;letter-spacing:1.5px;margin-bottom:10px;padding:6px 16px;text-transform:uppercase;z-index:5}.badge-COMMON{background:linear-gradient(135deg,#7f8c8d,#95a5a6);color:#fff}.badge-RARE{background:linear-gradient(135deg,#0984e3,#00cec9);color:#fff}.badge-EPIC{background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff}.badge-LEGENDARY{animation:goldGlowPulse 2s infinite;background:linear-gradient(135deg,#f1c40f,#e67e22);color:#fff}@keyframes goldGlowPulse{0%,to{box-shadow:0 0 8px #f1c40f80}50%{box-shadow:0 0 20px #f1c40fe6}}.chest-title{-webkit-text-fill-color:#0000;background:linear-gradient(to right,var(--st-text),var(--st-text-muted));-webkit-background-clip:text;font-size:24px;font-weight:800;margin:5px 0 10px;z-index:5}.chest-subtitle{color:var(--st-text-muted);font-size:14px;line-height:1.5;margin-bottom:20px;max-width:320px;z-index:5}.reward-card-container{height:340px;margin:20px 0;perspective:1000px;width:260px;z-index:10}.reward-card{cursor:pointer;height:100%;position:relative;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.175,.885,.32,1.275);width:100%}.reward-card.flipped{transform:rotateY(180deg)}.card-face{align-items:center;backface-visibility:hidden;border-radius:24px;box-shadow:0 15px 35px #00000080;display:flex;flex-direction:column;height:100%;justify-content:center;position:absolute;width:100%}.card-front{background:var(--st-surface-muted);border:2px solid var(--st-border);color:var(--st-text)}.card-front-content{align-items:center;display:flex;flex-direction:column;gap:15px}.card-logo{animation:pulseLogo 2s ease-in-out infinite;font-size:60px}@keyframes pulseLogo{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.tap-to-reveal{animation:flashText 1.5s infinite;color:#0abde3;font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase}@keyframes flashText{0%,to{opacity:.4}50%{opacity:1}}.card-back{border:3px solid #0000;transform:rotateY(180deg)}.card-back.card-COMMON{background:linear-gradient(135deg,#2d3436,#1e272e);border-color:#7f8c8d}.card-back.card-RARE{background:linear-gradient(135deg,#1e3c72,#2a5298);border-color:#0abde3;box-shadow:0 10px 30px #0abde34d}.card-back.card-EPIC{background:linear-gradient(135deg,indigo,#191970);border-color:#6c5ce7;box-shadow:0 10px 30px #6c5ce773}.card-back.card-LEGENDARY{background:linear-gradient(135deg,#d4af37,#8b6508);border-color:gold;box-shadow:0 15px 40px #f1c40f80}.reward-heading{color:#ffffffb3;font-size:16px;font-weight:800;letter-spacing:1px;margin-bottom:20px;text-transform:uppercase}.reward-row{align-items:center;background:var(--st-surface-muted);border:1.5px solid var(--st-border);border-radius:14px;display:flex;gap:15px;justify-content:flex-start;margin:12px 0;padding:10px 20px;width:80%}.reward-icon{font-size:24px}.chest-reward-text{display:flex;flex-direction:column;text-align:left}.chest-reward-val{font-size:20px;font-weight:800}.chest-reward-label{color:var(--st-text-muted);font-size:11px}.multiplier-tag{background:#0000004d;border:1px solid #ffd7004d;border-radius:10px;color:gold;font-size:12px;font-weight:700;margin-top:15px;padding:4px 10px}.claim-btn{background:linear-gradient(135deg,#0abde3,#22a6b3);border:none;border-radius:16px;box-shadow:0 8px 25px #0abde366;color:#fff;cursor:pointer;font-size:16px;font-weight:800;margin-top:25px;padding:14px 40px;transition:all .3s ease;z-index:10}.claim-btn:hover{box-shadow:0 12px 30px #0abde399;transform:translateY(-2px)}.claim-btn:active{transform:translateY(0)}.support-chatbot-root{align-items:flex-end;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a8c;display:flex;font-family:Be Vietnam Pro,sans-serif;inset:0;padding:calc(20px + env(safe-area-inset-top, 0px)) 12px calc(24px + env(safe-area-inset-bottom, 0px));position:absolute;z-index:10001}.support-chatbot-root.keyboard-visible{padding:calc(6px + env(safe-area-inset-top, 0px)) 8px 6px}.support-chatbot-root.ios-standalone-support{bottom:auto;height:100dvh;height:var(--support-visual-height,100dvh);left:0;position:fixed;right:0;top:0;top:var(--support-visual-offset-top,0);z-index:10001}.support-chatbot-panel{animation:support-chatbot-open .2s ease-out;background:#fff;background:var(--st-surface,#fff);border:3px solid #2c3e50;border:3px solid var(--game-border-color,#2c3e50);border-radius:22px;box-shadow:0 8px 0 #2c3e50,0 24px 55px #0f172a4d;box-shadow:0 8px 0 var(--game-border-color,#2c3e50),0 24px 55px #0f172a4d;display:flex;flex-direction:column;height:100%;max-height:100%;min-height:0;overflow:hidden;width:100%}.support-chatbot-root.keyboard-visible .support-chatbot-panel{border-radius:14px;box-shadow:0 3px 0 #2c3e50,0 12px 30px #0f172a40;box-shadow:0 3px 0 var(--game-border-color,#2c3e50),0 12px 30px #0f172a40}@keyframes support-chatbot-open{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.support-chatbot-header{align-items:center;background:linear-gradient(135deg,#2563eb,#1e90ff);border-bottom:2px solid #cbd5e1;border-bottom:2px solid var(--st-border,#cbd5e1);color:#fff;display:flex;flex-shrink:0;gap:9px;min-height:62px;padding:10px 10px 10px 12px}.support-chatbot-root.keyboard-visible .support-chatbot-header{min-height:50px;padding:6px 8px 6px 10px}.support-chatbot-root.keyboard-visible .support-chatbot-avatar{height:32px;width:32px}.support-chatbot-avatar,.support-message-avatar{align-items:center;background:#fff;border-radius:50%;color:#2563eb;display:inline-flex;flex-shrink:0;justify-content:center}.support-chatbot-avatar{border:2px solid #fff;height:38px;width:38px}.support-chatbot-heading{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.support-chatbot-heading strong{font-size:14px}.support-chatbot-heading span{align-items:center;display:flex;font-size:10px;font-weight:700;gap:5px;opacity:.9}.support-chatbot-heading i{background:#7bed9f;border-radius:50%;height:7px;width:7px}.support-chatbot-icon-btn{align-items:center;background:#ffffff29;border:0;border-radius:50%;color:#fff;cursor:pointer;display:inline-flex;height:34px;justify-content:center;width:34px}.support-chatbot-messages{background:#e0f2fe;background:var(--st-bg,#e0f2fe);display:flex;flex:1 1 auto;flex-direction:column;gap:10px;min-height:0;overflow-y:auto;padding:14px 12px}.support-message-row{align-items:flex-end;display:flex;gap:7px;max-width:88%;min-width:0}.support-message-row.user{align-self:flex-end}.support-message-row.assistant{align-self:flex-start}.support-message-avatar{border:1.5px solid #2c3e50;border:1.5px solid var(--game-border-color,#2c3e50);height:25px;width:25px}.support-message-bubble{background:#fff;background:var(--st-surface,#fff);border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:15px 15px 15px 5px;box-shadow:0 2px 0 #2c3e50;box-shadow:0 2px 0 var(--game-border-color,#2c3e50);color:#243447;color:var(--st-text,#243447);font-size:12px;font-weight:600;line-height:1.5;min-width:0;overflow-wrap:anywhere;padding:9px 11px;white-space:pre-wrap}.support-message-row.user .support-message-bubble{background:#2563eb;border-radius:15px 15px 5px 15px;color:#fff}.support-message-bubble.error{background:#fff1f2;color:#be123c}.support-typing{align-items:center;color:#64748b;color:var(--st-text-muted,#64748b);display:flex;gap:7px}.support-typing svg{animation:support-spinner .8s linear infinite}@keyframes support-spinner{to{transform:rotate(1turn)}}.support-chatbot-suggestions{background:#fff;background:var(--st-surface,#fff);border-top:1px solid #cbd5e1;border-top:1px solid var(--st-border,#cbd5e1);display:flex;flex-shrink:0;gap:6px;overflow-x:auto;padding:8px 10px}.support-chatbot-suggestions button{background:#eff6ff;border:1.5px solid #60a5fa;border-radius:14px;color:#1d4ed8;cursor:pointer;flex-shrink:0;font-size:10px;font-weight:700;line-height:1.3;padding:6px 9px;white-space:nowrap}.support-chatbot-suggestions button:disabled{opacity:.55}.support-chatbot-form{background:#fff;background:var(--st-surface,#fff);border-top:2px solid #cbd5e1;border-top:2px solid var(--st-border,#cbd5e1);display:flex;flex-shrink:0;gap:7px;padding:9px 10px 7px}.support-chatbot-form input{background:#f8fafc;background:var(--st-surface-muted,#f8fafc);border:2px solid #cbd5e1;border:2px solid var(--st-border,#cbd5e1);border-radius:15px;color:#243447;color:var(--st-text,#243447);flex:1 1;font-size:12px;height:42px;min-width:0;outline:none;padding:0 12px}.support-chatbot-form input:focus{border-color:#3b82f6}.support-chatbot-form button{align-items:center;background:#2563eb;border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:14px;color:#fff;cursor:pointer;display:inline-flex;height:42px;justify-content:center;width:42px}.support-chatbot-form button:disabled{cursor:default;opacity:.45}.support-chatbot-disclaimer{background:#fff;background:var(--st-surface,#fff);color:#64748b;color:var(--st-text-muted,#64748b);flex-shrink:0;font-size:8px;line-height:1.35;padding:0 10px 8px;text-align:center}.support-chatbot-root.keyboard-visible .support-chatbot-disclaimer,.support-chatbot-root.keyboard-visible .support-chatbot-suggestions{display:none}.support-chatbot-root.keyboard-visible .support-chatbot-form{padding:7px 8px}@media (max-width:767px){.support-chatbot-form input{font-size:16px}}body.dark-theme .support-chatbot-suggestions button{background:#172554;color:#bfdbfe}body.dark-theme .support-message-bubble.error{background:#4c0519;color:#fecdd3}.support-chatbot-tabs{background:#fff;background:var(--st-surface,#fff);border-bottom:2px solid #cbd5e1;border-bottom:2px solid var(--st-border,#cbd5e1);display:flex;flex-shrink:0}.support-tab-btn{align-items:center;background:#0000;border:0;border-bottom:3px solid #0000;color:#64748b;color:var(--st-text-muted,#64748b);cursor:pointer;display:inline-flex;flex:1 1;font-size:12px;font-weight:700;height:44px;justify-content:center;transition:all .2s ease}.support-tab-btn:hover{background:#2563eb0a;color:#2563eb}.support-tab-btn.active{background:#2563eb05;border-bottom-color:#2563eb;color:#2563eb}.support-ticket-container{background:#e0f2fe;background:var(--st-bg,#e0f2fe);display:flex;flex:1 1 auto;flex-direction:column;gap:18px;min-height:0;overflow-y:auto;padding:16px 14px}.support-ticket-login-required{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center;margin:auto 0;padding:40px 20px;text-align:center}.support-ticket-login-required .lock-icon{animation:bounce-lock 2s ease-in-out infinite;color:#3b82f6}@keyframes bounce-lock{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.support-ticket-login-required h3{color:#1e293b;color:var(--st-text,#1e293b);font-size:16px;font-weight:700;margin:0}.support-ticket-login-required p{color:#64748b;color:var(--st-text-muted,#64748b);font-size:12px;line-height:1.5;margin:0;max-width:260px}.support-ticket-form-tab{background:#fff;background:var(--st-surface,#fff);border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:16px;box-shadow:0 4px 0 #2c3e50;box-shadow:0 4px 0 var(--game-border-color,#2c3e50);display:flex;flex-direction:column;gap:12px;padding:14px}.support-ticket-form-tab h4,.support-ticket-history h4{color:#1e293b;color:var(--st-text,#1e293b);font-size:13px;font-weight:800;letter-spacing:.5px;margin:0 0 4px;text-transform:uppercase}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:#475569;color:var(--st-text-muted,#475569);font-size:11px;font-weight:700}.ticket-type-selector{display:flex;gap:6px}.type-chip{background:#f8fafc;background:var(--st-surface-muted,#f8fafc);border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:10px;box-shadow:0 2px 0 #2c3e50;box-shadow:0 2px 0 var(--game-border-color,#2c3e50);color:#64748b;color:var(--st-text-muted,#64748b);cursor:pointer;flex:1 1;font-size:10px;font-weight:700;padding:8px 6px;text-align:center;transition:all .15s ease}.type-chip:hover{background:#e2e8f0}.type-chip.active{background:#2563eb;box-shadow:0 2px 0 #2c3e50;box-shadow:0 2px 0 var(--game-border-color,#2c3e50);color:#fff}.support-ticket-form-tab textarea{background:#f8fafc;background:var(--st-surface-muted,#f8fafc);border:2px solid #cbd5e1;border:2px solid var(--st-border,#cbd5e1);border-radius:12px;color:#1e293b;color:var(--st-text,#1e293b);font-family:inherit;font-size:12px;font-weight:600;line-height:1.5;min-height:90px;outline:none;padding:10px 12px;resize:none;transition:border-color .2s ease;width:100%}.support-ticket-form-tab textarea:focus{border-color:#2563eb}.char-counter{align-self:flex-end;color:#94a3b8;color:var(--st-text-muted,#94a3b8);font-size:9px;font-weight:600}.ticket-submit-btn{align-items:center;background:#2563eb;border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:12px;box-shadow:0 3px 0 #2c3e50;box-shadow:0 3px 0 var(--game-border-color,#2c3e50);color:#fff;cursor:pointer;display:inline-flex;font-size:12px;font-weight:700;gap:8px;height:42px;justify-content:center;transition:all .15s ease}.ticket-submit-btn:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 0 #2c3e50;box-shadow:0 4px 0 var(--game-border-color,#2c3e50);transform:translateY(-1px)}.ticket-submit-btn:active:not(:disabled){box-shadow:0 1px 0 #2c3e50;box-shadow:0 1px 0 var(--game-border-color,#2c3e50);transform:translateY(2px)}.ticket-submit-btn:disabled{box-shadow:0 2px 0 #2c3e50;box-shadow:0 2px 0 var(--game-border-color,#2c3e50);cursor:not-allowed;opacity:.5}.ticket-alert{border-radius:8px;font-size:11px;font-weight:600;line-height:1.4;padding:8px 12px}.ticket-alert.success{background:#dcfce7;border:1px solid #bbf7d0;color:#15803d}.ticket-alert.error{background:#fee2e2;border:1px solid #fecaca;color:#b91c1c}.spinner-animation{animation:support-spinner 1s linear infinite}.support-ticket-history{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.history-loading{align-items:center;display:flex;font-size:12px;gap:8px;justify-content:center;padding:24px}.history-empty,.history-loading{color:#64748b;color:var(--st-text-muted,#64748b);font-weight:600}.history-empty{background:#fff6;border:2px dashed #cbd5e1;border:2px dashed var(--st-border,#cbd5e1);border-radius:12px;font-size:11px;padding:20px;text-align:center}.ticket-list{display:flex;flex-direction:column;gap:10px}.ticket-item-card{background:#fff;background:var(--st-surface,#fff);border:2px solid #2c3e50;border:2px solid var(--game-border-color,#2c3e50);border-radius:14px;box-shadow:0 3px 0 #2c3e50;box-shadow:0 3px 0 var(--game-border-color,#2c3e50);cursor:pointer;padding:12px;transition:all .2s ease}.ticket-item-card:hover{box-shadow:0 5px 0 #2c3e50;box-shadow:0 5px 0 var(--game-border-color,#2c3e50);transform:translateY(-2px)}.ticket-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.ticket-type-badge{border:1px solid #0000;border-radius:6px;font-size:9px;font-weight:700;padding:2px 6px;text-transform:uppercase}.ticket-type-badge.bug{background:#fee2e2;border-color:#fca5a5;color:#ef4444}.ticket-type-badge.suggestion{background:#dbeafe;border-color:#93c5fd;color:#3b82f6}.ticket-type-badge.report{background:#f3e8ff;border-color:#d8b4fe;color:#a855f7}.ticket-status-badge{border-radius:6px;color:#fff;font-size:9px;font-weight:800;padding:2px 6px}.ticket-status-badge.pending{background:#f59e0b}.ticket-status-badge.processing{background:#3b82f6}.ticket-status-badge.resolved{background:#10b981}.ticket-card-content{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#334155;color:var(--st-text,#334155);display:-webkit-box;font-size:11px;font-weight:600;line-height:1.45;margin:0 0 8px;overflow:hidden;text-overflow:ellipsis;white-space:pre-wrap}.ticket-item-card.expanded .ticket-card-content{-webkit-line-clamp:unset;display:block;overflow:visible}.ticket-card-footer{align-items:center;color:#94a3b8;color:var(--st-text-muted,#94a3b8);display:flex;font-size:9px;font-weight:600;justify-content:space-between}.expand-trigger{color:#2563eb;font-weight:700}.enterprise-dashboard{box-sizing:border-box;color:#0f172a;display:flex;flex-direction:column;gap:18px;max-width:100%;overflow-x:hidden;padding:20px;width:100%}.enterprise-dashboard *,.enterprise-dashboard :after,.enterprise-dashboard :before{box-sizing:border-box}.enterprise-state{align-items:center;color:#64748b;font-weight:700;justify-content:center;min-height:240px;text-align:center}.enterprise-state-error{color:#b91c1c}.enterprise-dashboard-header{align-items:flex-start;background:linear-gradient(135deg,#fffffffa,#e0f2feeb 52%,#f0f9fffa);border:1px solid #94a3b838;border-radius:8px;box-shadow:0 20px 45px #0f172a1f;display:flex;gap:16px;justify-content:space-between;min-width:0;overflow:hidden;padding:18px;position:relative}.enterprise-dashboard-header:after{background:linear-gradient(90deg,#0ea5e9,#38bdf8,#f59e0b);bottom:0;content:"";height:3px;left:18px;position:absolute;right:18px}.enterprise-dashboard-header h2{color:#0f172a;font-size:26px;margin:2px 0;overflow-wrap:anywhere}.enterprise-dashboard-header span{color:#475569;font-size:13px;font-weight:700}.enterprise-eyebrow{color:#0369a1;font-size:12px;font-weight:900;margin:0;text-transform:uppercase}.enterprise-status-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:800;gap:5px;padding:6px 10px;white-space:nowrap}.enterprise-status-badge.active{background:linear-gradient(135deg,#dbeafe,#cffafe);box-shadow:0 10px 20px #0ea5e924;color:#0369a1}.enterprise-status-badge.pending{background:linear-gradient(135deg,#fef3c7,#ffedd5);box-shadow:0 10px 20px #92400e1a;color:#92400e}.enterprise-stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr))}.enterprise-panel,.enterprise-stat-card{background:#fffffff5;border:1px solid #94a3b83d;border-radius:8px;box-shadow:0 18px 38px #0f172a17}.enterprise-stat-card{display:flex;flex-direction:column;gap:7px;overflow:hidden;padding:14px;position:relative;transition:transform .18s ease,box-shadow .18s ease}.enterprise-stat-card:before{background:#0ea5e9;content:"";height:4px;inset:0 0 auto;position:absolute}.enterprise-stat-card:nth-child(2):before{background:#f59e0b}.enterprise-stat-card:nth-child(3):before{background:#3b82f6}.enterprise-stat-card:nth-child(4):before{background:#fb7185}.enterprise-stat-card:hover{box-shadow:0 24px 48px #0f172a21;transform:translateY(-2px)}.enterprise-stat-icon{align-items:center;background:#e0f2fe;border-radius:8px;color:#0369a1;display:inline-flex;height:34px;justify-content:center;width:34px}.enterprise-stat-card:nth-child(2) .enterprise-stat-icon{background:#fef3c7;color:#92400e}.enterprise-stat-card:nth-child(3) .enterprise-stat-icon{background:#dbeafe;color:#1d4ed8}.enterprise-stat-card:nth-child(4) .enterprise-stat-icon{background:#ffe4e6;color:#be123c}.enterprise-stat-card h3{font-size:24px;margin:0}.enterprise-stat-card p{color:#64748b;font-size:12px;font-weight:700;margin:0}.enterprise-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;flex-direction:column;gap:14px;padding:16px}.enterprise-panel-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;min-width:0}.enterprise-panel-header h3,.enterprise-panel-header p{margin:0}.enterprise-panel-header h3{color:#0f172a;font-size:17px}.enterprise-panel-header p{color:#64748b;font-size:12px;margin-top:3px}.enterprise-empty{background:#ffffffb3;padding:22px}.enterprise-flow-chart{grid-gap:10px;align-items:end;display:grid;gap:10px;grid-template-columns:repeat(7,minmax(0,1fr));height:180px}.enterprise-flow-column{align-items:center;display:flex;flex-direction:column;gap:6px;min-width:0}.enterprise-flow-bar-wrap{align-items:end;background:linear-gradient(180deg,#f8fafc,#e2e8f0);border-radius:8px;box-shadow:inset 0 1px 3px #0f172a14;display:flex;height:120px;overflow:hidden;width:100%}.enterprise-flow-bar{background:linear-gradient(180deg,#38bdf8,#0369a1);border-radius:8px 8px 0 0;box-shadow:0 -8px 18px #0ea5e933;width:100%}.enterprise-flow-column strong{font-size:12px}.enterprise-flow-column span{color:#64748b;font-size:12px;font-weight:800}.enterprise-mini-list{display:flex;flex-direction:column;gap:10px}.enterprise-mini-list article{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #94a3b838;border-radius:8px;box-shadow:0 10px 22px #0f172a0f;display:flex;gap:12px;justify-content:space-between;padding:12px}.enterprise-mini-list article div{display:flex;flex-direction:column;gap:4px;min-width:0}.enterprise-mini-list article strong{font-size:14px;overflow-wrap:anywhere}.enterprise-mini-list article span{color:#64748b;font-size:12px}.enterprise-mini-meta{align-items:center;display:inline-flex;flex-wrap:wrap;gap:5px}.enterprise-mini-list article>span{border-radius:999px;font-weight:800;padding:4px 8px;white-space:nowrap}.enterprise-mini-list article>span.active{background:linear-gradient(135deg,#dbeafe,#cffafe);color:#0369a1}.enterprise-mini-list article>span.inactive{background:linear-gradient(135deg,#f1f5f9,#fff);color:#64748b}@media (max-width:820px){.enterprise-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:560px){.enterprise-dashboard{padding:16px}.enterprise-dashboard-header,.enterprise-mini-list article,.enterprise-panel-header{align-items:stretch;flex-direction:column}.enterprise-mini-list article>span,.enterprise-status-badge{align-self:flex-start}}.enterprise-layout{background:linear-gradient(180deg,#e0f2feeb,#f8fafcfa 44%,#f0f9fff5);box-sizing:border-box;color:#0f172a;display:flex;flex-direction:column;font-family:Inter,Be Vietnam Pro,Arial,sans-serif;height:100%;max-width:100%;overflow-x:hidden;overflow-y:hidden;position:relative;width:100%}.enterprise-content{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding-bottom:calc(92px + env(safe-area-inset-bottom, 0px));padding-top:calc(12px + env(safe-area-inset-top, 0px))}.enterprise-layout *,.enterprise-layout :after,.enterprise-layout :before{box-sizing:border-box}.enterprise-message{border-radius:8px;box-shadow:0 12px 28px #0f172a14;font-size:13px;font-weight:800;margin:16px 20px 0;padding:10px 12px}.enterprise-message.success{background:linear-gradient(135deg,#e0f2fe,#fff);border:1px solid #0ea5e93d;color:#0369a1}.enterprise-message.error{background:linear-gradient(135deg,#fef2f2,#fff);border:1px solid #f8717147;color:#b91c1c}.enterprise-section{display:flex;flex-direction:column;gap:16px;padding:20px}.enterprise-section-header{align-items:flex-start;background:linear-gradient(135deg,#fffffffa,#e0f2fee6 58%,#f0f9fff5);border:1px solid #94a3b838;border-radius:8px;box-shadow:0 18px 42px #0f172a1a;display:flex;gap:12px;justify-content:space-between;padding:16px}.enterprise-section-header h2,.enterprise-section-header p{margin:0}.enterprise-section-header p{color:#0369a1;font-size:12px;font-weight:900;text-transform:uppercase}.enterprise-section-header h2{color:#0f172a;font-size:24px;margin-top:3px}.enterprise-subtitle{color:#334155;font-size:15px;margin:6px 0 -4px}.enterprise-danger-btn,.enterprise-primary-btn,.enterprise-secondary-btn{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:800;gap:7px;justify-content:center;min-height:40px;padding:0 12px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;white-space:nowrap}.enterprise-primary-btn{background:linear-gradient(135deg,#0369a1,#0ea5e9);border-color:#0369a1;box-shadow:0 12px 22px #0ea5e93d;color:#fff}.enterprise-secondary-btn{background:#fff;border-color:#94a3b85c;box-shadow:0 8px 18px #0f172a12;color:#0f172a}.enterprise-danger-btn{background:linear-gradient(135deg,#e11d48,#fb7185);border-color:#be123c;box-shadow:0 12px 22px #e11d4833;color:#fff}.enterprise-danger-btn:hover:not(:disabled),.enterprise-primary-btn:hover:not(:disabled),.enterprise-secondary-btn:hover:not(:disabled){transform:translateY(-1px)}.enterprise-danger-btn:active:not(:disabled),.enterprise-primary-btn:active:not(:disabled),.enterprise-secondary-btn:active:not(:disabled){transform:translateY(0)}.enterprise-danger-btn:disabled,.enterprise-primary-btn:disabled,.enterprise-secondary-btn:disabled{cursor:not-allowed;opacity:.62}.enterprise-campaign-card,.enterprise-form-panel,.enterprise-location-card,.enterprise-submission-card{background:#fffffff5;border:1px solid #94a3b83d;border-radius:8px;box-shadow:0 16px 34px #0f172a14}.enterprise-form-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;flex-direction:column;gap:14px;padding:16px}.enterprise-form-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.enterprise-form-grid label{color:#334155;display:flex;flex-direction:column;font-size:12px;font-weight:800;gap:6px}.enterprise-form-grid input,.enterprise-form-grid select,.enterprise-form-grid textarea{background:#fff;border:1px solid #94a3b873;border-radius:8px;box-shadow:inset 0 1px 0 #0f172a08;color:#0f172a;font:inherit;min-height:40px;min-width:0;padding:8px 10px;transition:border-color .18s ease,box-shadow .18s ease;width:100%}.enterprise-form-grid input:focus,.enterprise-form-grid select:focus,.enterprise-form-grid textarea:focus{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e929;outline:none}.enterprise-form-grid textarea{min-height:88px;resize:vertical}.enterprise-form-wide{grid-column:1/-1}.enterprise-selected-location{align-items:center;background:linear-gradient(135deg,#f8fafc,#e0f2fe);border:1px solid #0ea5e93d;border-radius:8px;color:#334155;display:flex;gap:10px;min-height:46px;min-width:0;padding:10px 12px}.enterprise-selected-location svg{color:#0369a1;flex:0 0 auto}.enterprise-selected-location div{display:flex;flex-direction:column;gap:2px;min-width:0}.enterprise-selected-location span,.enterprise-selected-location strong{overflow-wrap:anywhere}.enterprise-selected-location strong{color:#0f172a;font-size:13px}.enterprise-selected-location span{color:#0369a1;font-size:12px;font-weight:800}.enterprise-action-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.enterprise-card-list{display:flex;flex-direction:column;gap:14px}.enterprise-campaign-card,.enterprise-location-card,.enterprise-submission-card{display:flex;flex-direction:column;gap:12px;padding:14px;transition:transform .18s ease,box-shadow .18s ease}.enterprise-campaign-card:hover,.enterprise-location-card:hover,.enterprise-submission-card:hover{box-shadow:0 22px 44px #0f172a1f;transform:translateY(-2px)}.enterprise-card-main{display:flex;gap:12px;justify-content:space-between;min-width:0}.enterprise-card-main h3,.enterprise-location-card h3{font-size:16px;margin:0;overflow-wrap:anywhere}.enterprise-card-main p,.enterprise-location-card p,.enterprise-submission-card p{color:#64748b;font-size:13px;line-height:1.45;margin:5px 0 0;overflow-wrap:anywhere}.enterprise-meta-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.enterprise-meta-grid span{align-items:center;background:linear-gradient(135deg,#f8fafc,#e0f2fe);border-radius:8px;color:#334155;display:inline-flex;font-size:12px;font-weight:800;gap:6px;min-height:34px;min-width:0;overflow:hidden;padding:0 9px;text-overflow:ellipsis;white-space:nowrap}.enterprise-meta-grid span svg{flex:0 0 auto}.enterprise-meta-grid span.enterprise-meta-time{align-items:flex-start;line-height:1.35;padding-bottom:7px;padding-top:7px;white-space:normal}.enterprise-badge{align-self:flex-start;border-radius:999px;font-size:11px;font-weight:900;padding:4px 8px;white-space:nowrap}.enterprise-badge.active,.enterprise-badge.approved{background:linear-gradient(135deg,#dbeafe,#cffafe);color:#0369a1}.enterprise-badge.inactive,.enterprise-badge.rejected{background:linear-gradient(135deg,#f1f5f9,#fff);color:#64748b}.enterprise-badge.pending{background:linear-gradient(135deg,#fef3c7,#ffedd5);color:#92400e}.enterprise-qr-row{align-items:center;background:linear-gradient(135deg,#e0f2fe,#f0f9ff);border:1px solid #0ea5e93d;border-radius:8px;display:flex;gap:10px;justify-content:space-between;padding:10px}.enterprise-qr-preview{align-items:center;background:#fff;border:1px solid #0ea5e933;border-radius:8px;box-shadow:0 8px 18px #0f172a14;display:flex;flex:0 0 78px;height:78px;justify-content:center;padding:6px;position:relative;width:78px}.enterprise-qr-preview img{display:block;height:100%;object-fit:contain;width:100%}.enterprise-qr-fallback{color:#0369a1;display:none}.enterprise-qr-fallback.visible{display:inline-flex}.enterprise-qr-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.enterprise-qr-info strong{color:#0f172a;font-size:13px}.enterprise-qr-info span{color:#0369a1;font-size:12px;font-weight:700;line-height:1.35;overflow-wrap:anywhere}.enterprise-qr-info small{color:#475569;font-size:11px;font-weight:700;line-height:1.35}.enterprise-location-qr{margin-top:12px}.enterprise-qr-row button{align-items:center;align-self:center;background:#fff;border:1px solid #0ea5e961;border-radius:50%;box-shadow:0 8px 16px #0ea5e91f;color:#0369a1;cursor:pointer;display:inline-flex;flex:0 0 36px;gap:5px;height:36px;justify-content:center;width:36px}.enterprise-location-card span{color:#334155;font-size:13px;font-weight:800}.enterprise-location-meta{display:flex;flex-wrap:wrap;gap:8px}.enterprise-location-meta span{align-items:center;background:linear-gradient(135deg,#f8fafc,#e0f2fe);border-radius:8px;display:inline-flex;gap:6px;min-height:32px;overflow-wrap:anywhere;padding:0 9px}.enterprise-location-meta svg{color:#0369a1;flex:0 0 auto}.enterprise-submission-card{align-items:start;display:grid;grid-template-columns:minmax(0,1fr) auto}.enterprise-submission-card div{display:flex;flex-direction:column;gap:4px}.enterprise-submission-card span{color:#64748b;font-size:12px}.enterprise-empty{background:#ffffffc7;border:1px dashed #94a3b880;border-radius:8px;box-shadow:0 12px 26px #0f172a0f;color:#64748b;font-weight:700;padding:26px 18px;text-align:center}.enterprise-bottom-nav{align-items:center;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffeb;border:1px solid #94a3b83d;border-radius:999px;bottom:calc(12px + env(safe-area-inset-bottom, 0px));box-shadow:0 22px 48px #0f172a29,inset 0 1px 0 #ffffffe6;display:flex;gap:8px;justify-content:space-between;left:50%;padding:8px;position:absolute;transform:translateX(-50%);width:min(342px,calc(100% - 32px));z-index:20}.enterprise-bottom-nav button{align-items:center;background:#0000;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;flex:0 0 46px;height:46px;justify-content:center;transition:transform .18s ease,color .18s ease,background .18s ease,box-shadow .18s ease;width:46px}.enterprise-bottom-nav button.active{background:linear-gradient(135deg,#0369a1,#0ea5e9);box-shadow:0 12px 24px #0ea5e952;color:#fff}.enterprise-bottom-nav button:hover{color:#0369a1;transform:translateY(-2px)}.enterprise-bottom-nav button.active:hover{color:#fff}@media (max-width:760px){.enterprise-section-header{align-items:stretch;flex-direction:column}.enterprise-section{padding:16px}.enterprise-form-grid,.enterprise-meta-grid,.enterprise-submission-card{grid-template-columns:1fr}.enterprise-card-main,.enterprise-qr-row{align-items:stretch;flex-direction:column}.enterprise-section-header .enterprise-primary-btn{width:100%}}.enterprise-layout.keyboard-visible .enterprise-bottom-nav{display:none}.enterprise-layout.keyboard-visible .enterprise-content{padding-bottom:20px}.enterprise-compact-date{align-items:center;background:#fff;border:1px solid #94a3b873;border-radius:8px;box-shadow:inset 0 1px 0 #0f172a08;color:#0f172a;display:flex;font-size:14px;min-height:40px;min-width:0;overflow:hidden;padding:8px 10px;position:relative;width:100%}.enterprise-compact-date span{display:block;max-width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.enterprise-compact-date input[type=date],.enterprise-compact-date input[type=datetime-local]{background:#0000;border:none;cursor:pointer;height:100%;inset:0;margin:0;opacity:0!important;padding:0;position:absolute;width:100%}.enterprise-compact-date:focus-within{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e929}.ios-pwa-prompt-overlay{align-items:flex-end;animation:fadeInPromptOverlay .3s ease-out;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0f172a66;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:9999}.ios-pwa-prompt-card{animation:slideUpPromptCard .45s cubic-bezier(.16,1,.3,1);background:#fffffff2;border:1px solid #fffc;border-radius:20px;box-shadow:0 20px 50px #0f172a38;box-sizing:border-box;color:#1e293b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;margin-bottom:max(12px,env(safe-area-inset-bottom,0px));max-width:400px;padding:20px;position:relative;width:100%}@keyframes fadeInPromptOverlay{0%{backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0);background:#0f172a00}to{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0f172a66}}@keyframes slideUpPromptCard{0%{transform:translateY(120%) scale(.95)}to{transform:translateY(0) scale(1)}}.ios-pwa-prompt-close{align-items:center;background:#f1f5f9;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;height:28px;justify-content:center;position:absolute;right:14px;top:14px;transition:background-color .2s,transform .15s;width:28px}.ios-pwa-prompt-close:active{background:#e2e8f0;transform:scale(.9)}.ios-pwa-prompt-header{align-items:center;display:flex;gap:14px;padding-right:24px}.ios-pwa-app-icon{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0f172a1a;display:flex;flex-shrink:0;height:54px;justify-content:center;overflow:hidden;width:54px}.ios-pwa-app-icon img{height:100%;object-fit:cover;width:100%}.ios-pwa-app-title h3{color:#0f172a;font-size:16px;font-weight:700;margin:0}.ios-pwa-app-title p{color:#64748b;font-size:12px;line-height:1.4;margin:3px 0 0}.ios-pwa-divider{background:#e2e8f0;border:0;height:1px;margin:16px 0}.ios-pwa-instructions{display:flex;flex-direction:column;gap:14px}.ios-pwa-step{align-items:flex-start;display:flex;gap:12px}.ios-pwa-step-number{align-items:center;background:#2563eb;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:22px;justify-content:center;width:22px}.ios-pwa-step-text{color:#334155;font-size:13px;line-height:1.45;margin:0}.ios-pwa-step-text strong{color:#0f172a}.ios-pwa-icon-wrapper{align-items:center;background:#eff6ff;border-radius:6px;color:#2563eb;display:inline-flex;justify-content:center;margin:0 2px;padding:3px;vertical-align:middle}.prompt-svg-icon{display:block}.ios-pwa-arrow-pointer{border-left:10px solid #0000;border-right:10px solid #0000;border-top:10px solid #fffffff2;bottom:-10px;filter:drop-shadow(0 4px 2px rgba(15,23,42,.05));height:0;left:50%;pointer-events:none;position:absolute;transform:translateX(-50%);width:0}@media (min-width:768px){.ios-pwa-prompt-overlay{align-items:center}.ios-pwa-prompt-card{margin-bottom:0}.ios-pwa-arrow-pointer{display:none}}.ios-pwa-footer{align-items:center;display:flex;justify-content:flex-start}.ios-pwa-checkbox-container{align-items:center;color:#64748b;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;-webkit-user-select:none;user-select:none}.ios-pwa-checkbox-container input{accent-color:#2563eb;cursor:pointer;height:16px;margin:0;width:16px}.ios-pwa-checkbox-label-text{line-height:1}.user-profile-screen{background-color:#e0f2fe;background-color:var(--st-bg,#e0f2fe);box-sizing:border-box;flex:1 1;font-family:Be Vietnam Pro,sans-serif;min-height:0;overflow-y:auto;padding:calc(20px + env(safe-area-inset-top, 0px)) 20px 20px}.user-profile-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.user-profile-back-btn,.user-profile-edit-btn{border:2px solid #2c3e50;border-radius:10px;box-shadow:0 3px 0 #2c3e50;cursor:pointer;font-size:13px;font-weight:700;min-height:40px;padding:0 12px;transition:transform .1s,box-shadow .1s}.user-profile-back-btn{background:#fff;color:#2c3e50}.user-profile-edit-btn{background:#1e90ff;color:#fff}.user-profile-back-btn:active,.user-profile-edit-btn:active{box-shadow:0 1px 0 #2c3e50;transform:translateY(2px)}.user-profile-title{color:#243447;color:var(--st-text,#243447);font-size:24px;font-weight:800;margin:0 0 16px;text-align:center}.user-profile-points-card{background-color:#fffde8;border-radius:16px;box-shadow:0 4px 0 #2c3e50;gap:12px;margin-bottom:20px;padding:14px}.user-profile-points-card,.user-profile-points-icon{align-items:center;border:2px solid #2c3e50;display:flex}.user-profile-points-icon{background-color:#fff;border-radius:50%;box-shadow:0 2px 0 #2c3e50;height:36px;justify-content:center;width:36px}.user-profile-points-label{color:#57606f;font-size:12px;font-weight:700}.user-profile-points-value{color:#243447;color:var(--st-text,#243447);font-size:20px;font-weight:800}.user-profile-points-unit{color:#57606f;font-size:13px;font-weight:700}.user-profile-wallet-btn{align-items:center;background:linear-gradient(135deg,#fff8dc,#ffe08a);border:2px solid #2c3e50;border-radius:18px;box-shadow:0 4px 0 #2c3e50;color:#243447;cursor:pointer;display:flex;gap:12px;margin:0;min-height:68px;padding:12px 14px;text-align:left;width:100%}.user-profile-wallet-btn>span:nth-child(2){display:flex;flex:1 1;flex-direction:column;gap:2px}.user-profile-wallet-btn strong{font-size:15px}.user-profile-wallet-btn small{color:#6b7280;font-size:11px;font-weight:600}.user-profile-wallet-btn-icon{background:#f59e0b;border-radius:14px;color:#fff;display:grid;height:42px;place-items:center;width:42px}.user-profile-wallet-btn:active{box-shadow:0 1px 0 #2c3e50;transform:translateY(3px)}.user-profile-wallet-view{padding-bottom:28px}.user-profile-wallet-back{align-items:center;background:none;border:none;color:#64748b;color:var(--st-text-muted,#64748b);cursor:pointer;display:flex;font-weight:700;gap:5px;margin-bottom:10px;padding:8px 0}.user-profile-avatar-section{display:flex;justify-content:center;margin-bottom:20px}.user-profile-avatar-wrapper{position:relative}.user-profile-avatar-img{background:#fff;border:3px solid #2c3e50;border-radius:50%;box-shadow:0 4px 0 #2c3e50;height:96px;object-fit:cover;width:96px}.user-profile-avatar-edit-btn{background:#1e90ff;border:2px solid #2c3e50;border-radius:50%;bottom:-4px;box-shadow:0 2px 0 #2c3e50;color:#fff;cursor:pointer;height:32px;min-height:32px;position:absolute;right:-4px;transition:transform .1s,box-shadow .1s;width:32px}.user-profile-avatar-edit-btn:active{box-shadow:0 1px 0 #2c3e50;transform:translateY(1px)}.user-profile-form{background:#fff;border:3px solid #2c3e50;border-radius:22px;box-shadow:0 6px 0 #2c3e50;display:flex;flex-direction:column;margin-bottom:30px;padding:16px}.user-profile-field{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}.user-profile-field label{color:#2c3e50;font-size:13px;font-weight:700}.user-profile-field input,.user-profile-field select,.user-profile-field textarea{box-sizing:border-box;display:block;font-family:Be Vietnam Pro,sans-serif;max-width:100%;padding:12px}.user-profile-compact-date,.user-profile-field input,.user-profile-field select,.user-profile-field textarea{background:#fffde8;border:2px solid #2c3e50;border-radius:12px;color:#243447;color:var(--st-text,#243447);font-size:15px;min-height:44px;min-width:0;width:100%}.user-profile-compact-date{align-items:center;display:flex;overflow:hidden;padding:10px 12px;position:relative}.user-profile-compact-date input[type=date]{cursor:pointer;height:100%;inset:0;opacity:0;position:absolute;width:100%}.user-profile-field input:focus,.user-profile-field select:focus,.user-profile-field textarea:focus{border-color:#1e90ff;box-shadow:0 0 0 3px #1e90ff33;outline:none}.user-profile-field textarea{min-height:90px;resize:none}.user-profile-field .view-value{align-items:center;background-color:#f8fafc;border:2px solid #2c3e50;border-radius:12px;box-sizing:border-box;color:#243447;color:var(--st-text,#243447);display:flex;min-height:44px;padding:11px 12px}.user-profile-field-row{display:flex;gap:12px}.user-profile-field-row>div{flex:1 1;min-width:0}.user-profile-actions{display:flex;gap:12px;margin-top:14px}.user-profile-cancel-btn,.user-profile-save-btn{align-items:center;border:2px solid #2c3e50;border-radius:12px;box-shadow:0 4px 0 #2c3e50;cursor:pointer;display:inline-flex;flex:1 1;font-size:15px;font-weight:800;gap:6px;justify-content:center;min-height:46px;transition:transform .1s,box-shadow .1s}.user-profile-save-btn{background:#2ed573;color:#fff}.user-profile-cancel-btn{background:#ff4757;color:#fff}.user-profile-cancel-btn:active,.user-profile-save-btn:active{box-shadow:0 2px 0 #2c3e50;transform:translateY(2px)}@media (max-width:380px){.user-profile-field-row{flex-direction:column;gap:0}}.user-profile-section-divider{background-color:#2c3e50;border:none;height:2px;margin:20px 0}.user-profile-section-title{color:#2c3e50;font-size:16px;font-weight:800;margin:0 0 14px;text-transform:uppercase}body.dark-theme .user-profile-form{background-color:var(--st-surface);border-color:var(--st-border)}body.dark-theme .user-profile-field label{color:var(--st-text)}body.dark-theme .user-profile-field .view-value,body.dark-theme .user-profile-field input,body.dark-theme .user-profile-field select,body.dark-theme .user-profile-field textarea{background-color:var(--st-surface-muted);border-color:var(--st-border);color:var(--st-text)}body.dark-theme .user-profile-section-title{color:var(--st-text)}.user-profile-change-pw-btn{background:#1e90ff;border:1.5px solid #2c3e50;border-radius:8px;box-shadow:0 2px 0 #2c3e50;color:#fff;cursor:pointer;font-size:11px;font-weight:700;margin-left:10px;padding:4px 10px}.user-profile-change-pw-btn:active{box-shadow:0 1px 0 #2c3e50;transform:translateY(1px)}body.dark-theme .user-profile-back-btn{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color);color:var(--st-text)}body.dark-theme .user-profile-back-btn:active{box-shadow:0 1px 0 var(--game-border-color)}body.dark-theme .user-profile-edit-btn{border-color:var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color)}body.dark-theme .user-profile-edit-btn:active{box-shadow:0 1px 0 var(--game-border-color)}body.dark-theme .user-profile-avatar-img{border-color:var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .user-profile-avatar-edit-btn{border-color:var(--game-border-color);box-shadow:0 2px 0 var(--game-border-color)}body.dark-theme .user-profile-avatar-edit-btn:active{box-shadow:0 1px 0 var(--game-border-color)}body.dark-theme .user-profile-form{box-shadow:0 6px 0 var(--game-border-color)}body.dark-theme .user-profile-field .view-value,body.dark-theme .user-profile-field input,body.dark-theme .user-profile-field select,body.dark-theme .user-profile-field textarea,body.dark-theme .user-profile-form{border-color:var(--game-border-color)}body.dark-theme .user-profile-cancel-btn,body.dark-theme .user-profile-save-btn{border-color:var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .user-profile-cancel-btn:active,body.dark-theme .user-profile-save-btn:active{box-shadow:0 2px 0 var(--game-border-color)}body.dark-theme .user-profile-section-divider{background-color:var(--game-border-color)}body.dark-theme .user-profile-change-pw-btn{border-color:var(--game-border-color);box-shadow:0 2px 0 var(--game-border-color)}body.dark-theme .user-profile-change-pw-btn:active{box-shadow:0 1px 0 var(--game-border-color)}body.dark-theme .user-profile-points-card{background-color:var(--podium-1-bg);border-color:#ffd32d;border-color:var(--game-yellow,#ffd32d);box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .user-profile-points-icon{background-color:#ffd32d;background-color:var(--game-yellow,#ffd32d);border-color:#ffd32d;border-color:var(--game-yellow,#ffd32d);box-shadow:0 2px 0 var(--game-border-color)}body.dark-theme .user-profile-points-label{color:#ffd32d;color:var(--game-yellow,#ffd32d)}body.dark-theme .user-profile-points-value{color:var(--st-text)}body.dark-theme .user-profile-points-unit{color:#d8c290}body.dark-theme .user-profile-wallet-btn{background:var(--podium-1-bg);border-color:var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color);color:var(--st-text)}body.dark-theme .user-profile-field input::placeholder,body.dark-theme .user-profile-field textarea::placeholder{color:var(--st-text-muted)}body.dark-theme .user-profile-compact-date{background:var(--st-surface-muted);border-color:var(--st-border);color:var(--st-text)}.history-detail-screen{background:var(--st-bg);box-sizing:border-box;color:var(--st-text);display:flex;flex-direction:column;gap:18px;height:100%;min-height:100dvh;overflow-y:auto;padding:calc(16px + env(safe-area-inset-top, 0px)) 16px calc(32px + env(safe-area-inset-bottom, 0px));transition:background-color .3s ease,color .3s ease}.history-detail-screen.error,.history-detail-screen.loading{align-items:center;justify-content:center;text-align:center}.history-detail-screen.error h3,.history-detail-screen.error p{color:var(--st-text);margin:0}.history-detail-spinner{animation:history-detail-spin .9s linear infinite;border:4px solid var(--st-border);border-radius:50%;border-top-color:var(--game-blue);height:44px;width:44px}@keyframes history-detail-spin{to{transform:rotate(1turn)}}.history-detail-header{grid-gap:12px;align-items:center;background:var(--st-surface);border:3px solid var(--game-border-color);border-radius:18px;box-shadow:0 4px 0 var(--game-border-color);display:grid;gap:12px;grid-template-columns:44px minmax(0,1fr);padding:12px}.history-detail-title-group{align-items:flex-start;display:flex;flex-direction:column;gap:7px;min-width:0}.history-detail-title-group h2{color:var(--st-text);font-size:18px;font-weight:900;line-height:1.3;margin:0;overflow-wrap:anywhere;width:100%}.history-detail-back-btn{align-items:center;background:var(--game-yellow);border:2.5px solid var(--game-border-color);border-radius:12px;box-shadow:0 3px 0 var(--game-border-color);color:#2c3e50;cursor:pointer;display:inline-flex;height:44px;justify-content:center;padding:0;transition:transform .1s ease,background-color .1s ease,box-shadow .1s ease;width:44px}.history-detail-back-btn:hover{background:#ffdf55}.history-detail-back-btn:active{box-shadow:0 0 0 var(--game-border-color);transform:translateY(3px)}.status-badge-history{align-items:center;border:2px solid var(--game-border-color);border-radius:10px;display:inline-flex;font-size:11px;font-weight:800;gap:4px;padding:4px 9px}.status-badge-history[data-status=COMPLETED]{background:#dcfce7;color:#166534}.status-badge-history[data-status=CANCELLED]{background:#fee2e2;color:#991b1b}.status-badge-history:not([data-status=COMPLETED]):not([data-status=CANCELLED]){background:#dbeafe;color:#1d4ed8}.history-detail-screen .trip-itinerary{display:flex;flex-direction:column;gap:20px;margin-top:4px}.history-detail-screen .trip-itinerary h3{color:var(--st-text);font-size:15px;font-weight:900;margin:0;text-transform:uppercase}.history-detail-screen .day-group{display:flex;flex-direction:column;gap:14px}.history-detail-screen .day-header{align-items:center;align-self:flex-start;background:var(--game-orange);border:2.5px solid var(--game-border-color);border-radius:12px;box-shadow:0 3px 0 var(--game-border-color);color:#fff;display:inline-flex;font-size:11px;font-weight:900;gap:6px;padding:5px 12px}.history-detail-screen .day-date{font-size:10px;font-weight:700;opacity:.95}.history-detail-screen .timeline{display:flex;flex-direction:column;padding-left:8px}.history-detail-screen .timeline-item{display:flex;gap:12px;position:relative}.history-detail-screen .time-col{align-items:center;display:flex;flex-direction:column;flex-shrink:0;position:relative;width:55px}.history-detail-screen .time{background:var(--st-surface);border:2px solid var(--game-border-color);border-radius:8px;color:var(--st-text);font-size:11px;font-weight:800;padding:3px 6px;text-align:center;white-space:nowrap;z-index:2}.history-detail-screen .time-col .line{background:var(--game-border-color);bottom:0;left:50%;position:absolute;top:24px;transform:translateX(-50%);width:3px;z-index:1}.history-detail-screen .timeline-item:last-child .time-col .line{bottom:auto;height:30px}.history-detail-screen .content-col{flex:1 1;min-width:0;padding-bottom:16px}.history-detail-screen .stop-card{background:var(--st-surface);border:2.5px solid var(--game-border-color);border-radius:16px;box-shadow:0 3px 0 var(--game-border-color);padding:12px}.history-detail-screen .stop-card.stop-completed{background:linear-gradient(#2ed57314,#2ed57314),var(--st-surface);border-color:var(--game-green-dark)}.history-detail-screen .stop-card.stop-skipped{background:var(--st-surface-muted);border-color:var(--st-border)}.history-detail-screen .stop-card-header h4{color:var(--st-text);font-size:14px;font-weight:800;margin:0 0 6px;overflow-wrap:anywhere}.history-detail-screen .stop-card p{color:var(--st-text-muted);font-weight:700}body.dark-theme .history-detail-header{border-color:var(--st-border);box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .history-detail-title-group h2{color:#fff}body.dark-theme .history-detail-screen .stop-card,body.dark-theme .history-detail-screen .time{border-color:var(--st-border)}body.dark-theme .history-detail-screen .time-col .line{background:var(--st-border)}@media (max-width:360px){.history-detail-header{gap:10px;grid-template-columns:40px minmax(0,1fr);padding:10px}.history-detail-back-btn{height:40px;width:40px}.history-detail-title-group h2{font-size:16px}.history-detail-screen .timeline{padding-left:0}.history-detail-screen .timeline-item{gap:8px}}.history-container{background:linear-gradient(135deg,#f8f9fa,#e9ecef);height:100%;overflow-y:auto;padding:calc(24px + env(safe-area-inset-top, 0px)) 20px calc(24px + env(safe-area-inset-bottom, 0px))}.history-header{align-items:center;display:flex;gap:15px;margin-bottom:30px}.history-back-btn{align-items:center;background:#e3f2fd;border:none;border-radius:12px;box-shadow:0 4px 12px #0000000d;color:#1976d2;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:44px;justify-content:center;min-width:44px;padding:0;transition:all .2s ease;width:44px}.history-back-btn:hover{background:#bbdefb;transform:translateX(-3px)}.back-btn{align-items:center;background:#e3f2fd;border:none;border-radius:12px;box-shadow:0 4px 12px #0000000d;color:#1976d2;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;min-height:44px;padding:0 15px;transition:all .2s ease;width:auto}.back-btn:hover{background:#bbdefb;transform:translateX(-3px)}.history-header h1{color:#1a1a1a;font-size:22px;font-weight:700;margin:0;min-width:0}.filter-bar{background:#fff;border:1px solid #0000000d;border-radius:16px;box-shadow:0 4px 12px #0000000d;gap:15px;margin-bottom:25px;padding:15px}.filter-bar,.filter-group{display:flex;flex-direction:column;min-width:0}.filter-group{flex:0 0 auto;gap:6px;max-width:100%;width:100%}.filter-group label{align-items:center;color:#6c757d;display:flex;font-size:12px;font-weight:600;gap:6px}.filter-date,.filter-select{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:10px;color:#212529;display:block;font-size:16px;max-width:100%;min-height:44px;min-width:0;padding:10px 12px;transition:all .2s ease;width:100%}.filter-date{cursor:pointer;height:100%;inset:0;opacity:0;position:absolute}.date-input-wrapper:focus-within,.filter-select:focus{background-color:#fff;border-color:#007bff;outline:none}.date-input-wrapper{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:10px;color:#212529;display:flex;max-width:100%;min-height:44px;min-width:0;overflow:hidden;padding:10px 12px;position:relative;width:100%}.compact-date-value{font-size:16px;line-height:1.25;white-space:nowrap}.clear-date{align-items:center;background:#e9ecef;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:12px;height:18px;justify-content:center;min-height:24px;min-width:24px;position:absolute;right:8px;width:18px;z-index:2}.reset-filter-btn{background:#007bff;border:none;border-radius:8px;cursor:pointer;font-size:14px;margin-top:15px;min-height:44px;padding:8px 16px}.empty-state,.loading-state{align-items:center;color:#6c757d;display:flex;flex-direction:column;height:60%;justify-content:center}.spinner{animation:spin 1s linear infinite;border:3px solid #007bff1a;border-radius:50%;border-top-color:#007bff;height:40px;margin-bottom:15px;width:40px}.empty-state i{font-size:60px;margin-bottom:20px;opacity:.3}.history-list{display:flex;flex-direction:column;gap:18px}.history-card{background:#fff;border:1px solid #00000005;border-radius:20px;box-shadow:0 8px 24px #0000000a;padding:20px;position:relative;transition:transform .3s ease,box-shadow .3s ease}.history-card:hover{box-shadow:0 12px 30px #00000014;transform:translateY(-5px)}.card-status{border-radius:20px;font-size:11px;font-weight:600;padding:6px 12px;position:absolute;right:20px;text-transform:uppercase;top:20px}.card-status[data-status=COMPLETED]{background:#e7f5ee;color:#2fb344}.card-status[data-status=CANCELLED]{background:#fff0f0;color:#d63939}.card-status[data-status=ONGOING]{background:#e3f2fd;color:#1976d2}.history-card .card-info h3{color:#212529;font-size:17px;margin:0 0 8px;padding-right:112px}.card-date{align-items:center;color:#adb5bd;display:flex;font-size:13px;gap:6px;margin-bottom:15px}.card-stats{display:flex;gap:20px}.card-stats span{align-items:center;color:#495057;display:flex;font-size:13px;font-weight:500;gap:8px}.card-stats i{color:#007bff;font-size:14px}.history-container{background:#e0f2fe;padding:calc(16px + env(safe-area-inset-top, 0px)) 16px calc(88px + env(safe-area-inset-bottom, 0px))}.history-header{background:#fff;border:3px solid #2c3e50;border-radius:18px;box-shadow:0 4px 0 #2c3e50;margin-bottom:14px;padding:10px 12px}.back-btn,.history-back-btn{background:#ffd32d;border:2.5px solid #2c3e50;box-shadow:0 3px 0 #2c3e50;color:#2c3e50}.back-btn:hover,.history-back-btn:hover{background:#ffdf55;transform:none}.back-btn:active,.history-back-btn:active{box-shadow:0 0 0 #2c3e50;transform:translateY(3px)}.history-header h1{color:#2c3e50;font-weight:900}.filter-bar{background:#fffdf0;border:3px solid #2c3e50;border-radius:18px;box-shadow:0 4px 0 #2c3e50;margin-bottom:16px}.filter-group label{color:#2c3e50;font-weight:800}.filter-date,.filter-select{background-color:#fff;border:2px solid #2c3e50;border-radius:12px;color:#2c3e50;font-weight:700}.filter-date:focus,.filter-select:focus{border-color:#1e90ff;box-shadow:0 0 0 2px #1e90ff33}.clear-date{background:#fff;border:1.5px solid #2c3e50}.reset-filter-btn{background:#1e90ff;border:2.5px solid #2c3e50;border-radius:12px;box-shadow:0 3px 0 #2c3e50;color:#fff;font-weight:800}.empty-state,.loading-state{background:#fffdf0;border:3px solid #2c3e50;border-radius:18px;box-shadow:0 4px 0 #2c3e50;min-height:280px}.spinner{border:3px solid #ffeaa7;border-top-color:#1e90ff}.history-list{gap:12px}.history-card{background:#fffdf0;border:3px solid #2c3e50;border-radius:18px;box-shadow:0 4px 0 #2c3e50;padding:16px}.history-card:hover{box-shadow:0 4px 0 #2c3e50;transform:none}.card-status{border:2px solid #2c3e50;border-radius:12px;font-weight:800;justify-content:center;line-height:1.2;max-width:112px;min-height:30px;min-width:34px;padding:4px 8px;text-transform:none}.card-status[data-status=COMPLETED]{background:#dcfce7;color:#166534}.card-status[data-status=CANCELLED]{background:#fee2e2;color:#991b1b}.card-status[data-status=ONGOING]{background:#dbeafe;color:#1d4ed8}.history-card .card-info h3{color:#2c3e50;font-weight:900;max-width:calc(100% - 110px)}.card-date,.card-stats span{color:#475569;font-weight:700}@media (max-width:380px){.card-status{margin-bottom:8px;position:static;width:fit-content}.history-card .card-info h3{max-width:100%}.card-stats{flex-direction:column;gap:6px}}body.dark-theme .history-container{background:var(--st-bg);color:var(--st-text)}body.dark-theme .empty-state,body.dark-theme .filter-bar,body.dark-theme .history-card,body.dark-theme .history-header,body.dark-theme .loading-state{background:var(--st-surface);border-color:var(--st-border);box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .filter-group label,body.dark-theme .history-card .card-info h3,body.dark-theme .history-header h1{color:var(--st-text)}body.dark-theme .clear-date,body.dark-theme .date-input-wrapper,body.dark-theme .filter-select{background-color:var(--st-surface-muted);border-color:var(--st-border);color:var(--st-text);color-scheme:dark}body.dark-theme .date-input-wrapper:focus-within,body.dark-theme .filter-select:focus{background-color:var(--st-surface)}body.dark-theme .history-card .card-date,body.dark-theme .history-card .card-stats span,body.dark-theme .history-container .empty-state,body.dark-theme .history-container .loading-state{color:var(--st-text-muted)}body.dark-theme .history-card .card-status{border-color:var(--st-border)}.recommend-screen{background:#fffdf0;border:none;border-radius:0;box-sizing:border-box;display:flex;flex-direction:column;height:100%;min-height:100%;outline:none;overflow-y:auto;padding:calc(14px + env(safe-area-inset-top, 0px)) 14px 14px;position:relative}.recommend-header{align-items:center;background:#fffdf0;border:2.5px solid #2c3e50;border-radius:16px;box-shadow:0 4px 0 #2c3e50;display:flex;flex-shrink:0;gap:15px;margin-bottom:10px;padding:10px 12px}.recommend-header h2{color:#2d3436;font-size:22px;margin:0}.btn-back-icon{background:none;font-size:20px;min-width:44px;padding:5px}.recommend-subtitle{color:#636e72;color:#2c3e50;flex-shrink:0;font-size:14px;font-weight:700;margin-bottom:20px}.plan-recommend-error-state,.plan-recommend-loading-state{align-items:center;background:#0000;border:none;border-radius:0;box-shadow:none;display:flex;flex-direction:column;height:100%;justify-content:center;padding:20px;text-align:center}.plan-recommend-error-state h2,.plan-recommend-error-state p,.plan-recommend-loading-state h2,.plan-recommend-loading-state p{color:inherit}.location-browser{display:flex;flex:1 1 auto;flex-direction:column;margin-top:4px;min-height:0}.location-tab-strip{align-items:flex-end;border-bottom:2.5px solid #2c3e50;display:flex;flex-shrink:0;gap:4px;padding:0 6px}.location-tab{align-items:center;background:#fff6c9;border:2.5px solid #2c3e50;border-bottom:none;border-radius:12px 12px 0 0;box-shadow:inset 0 -3px 0 #2c3e5014;color:#2c3e50;cursor:pointer;display:inline-flex;flex:1 1;font-size:13px;font-weight:900;gap:7px;justify-content:center;min-height:42px;min-width:0;padding:8px 10px;transform:translateY(2.5px)}.location-tab span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.location-tab strong,.location-tab svg{flex:0 0 auto}.location-tab strong{align-items:center;background:#2c3e501f;border-radius:999px;display:inline-flex;font-size:12px;height:22px;justify-content:center;min-width:24px;padding:0 7px}.location-tab.active{background:#fffdf0;box-shadow:none;position:relative;transform:translateY(2.5px);z-index:2}.location-tab-panel{background:#fffdf0;border:2.5px solid #2c3e50;border-radius:0 0 16px 16px;border-top:none;box-shadow:0 4px 0 #2c3e50;padding:12px}.location-tab-panel,.locations-list{display:flex;flex:1 1 auto;flex-direction:column;gap:10px;min-height:0}.locations-list{overflow-y:auto;padding:2px 2px 2px 0}.location-card{align-items:stretch;background:#fffdf0;border:2.5px solid #2c3e50;border-radius:10px;box-shadow:0 3px 0 #2c3e50;cursor:pointer;display:flex;flex-shrink:0;gap:10px;justify-content:space-between;min-height:94px;padding:10px;transition:all .2s}.location-card.selected{background:#fff3a6;border-color:#2c3e50}.loc-info h4{color:#2d3436;font-size:16px;line-height:1.25;margin:0 0 5px}.loc-info{flex:1 1;min-width:0}.loc-thumb{align-items:center;align-self:stretch;background:#dff9fb;border:2px solid #2c3e50;border-radius:8px;display:flex;justify-content:center;min-width:76px;overflow:hidden;width:76px}.loc-thumb img{display:block;height:100%;object-fit:cover;width:100%}.loc-thumb span{color:#0c6670;font-size:24px;font-weight:900}.loc-title-row{align-items:flex-start;display:flex;gap:8px;justify-content:space-between}.loc-title-row h4{min-width:0}.manual-source-badge{background:#dff9fb;border:2px solid #2c3e50;border-radius:999px;color:#0c6670;flex:0 0 auto;font-size:11px;font-weight:900;line-height:1.2;padding:2px 7px}.loc-tags{color:#0abde3;font-size:12px;font-weight:500}.loc-price,.loc-tags{line-height:1.3;margin:0 0 5px}.loc-price{color:#636e72;font-size:13px}.loc-score{background:#ffd32a;border-radius:20px;color:#806500;display:inline-block;font-size:12px;font-weight:700;padding:3px 8px}.loc-checkbox{flex:0 0 auto;font-size:24px;line-height:1;margin-top:2px}.manual-section-header{align-items:center;display:flex;gap:12px;justify-content:flex-end;min-height:18px}.manual-section-header span{color:#636e72;font-size:12px;font-weight:800}.manual-search-box{align-items:center;background:#fff;border:2px solid #2c3e50;border-radius:12px;display:flex;flex-shrink:0;gap:8px;min-height:44px;padding:0 10px}.manual-search-box svg{color:#2c3e50;flex:0 0 auto}.manual-search-box input{background:#0000;border:none;color:#2d3436;font-size:14px;font-weight:700;min-width:0;outline:none;width:100%}.manual-sort-row{display:flex;flex-direction:column;flex-shrink:0;gap:7px}.manual-sort-row>span{color:#636e72;font-size:12px;font-weight:900}.manual-sort-controls{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(3,minmax(0,1fr))}.manual-sort-controls button{background:#fff;border:2px solid #2c3e50;border-radius:10px;box-shadow:0 2px 0 #2c3e50;color:#2c3e50;cursor:pointer;font-size:11px;font-weight:900;min-height:36px;min-width:0;padding:7px 6px}.manual-sort-controls button.active{background:#ff9f1a;color:#fff}.manual-sort-controls button:active{box-shadow:none;transform:translateY(2px)}.manual-locations-list{display:flex;flex:1 1 auto;flex-direction:column;gap:10px;min-height:0;overflow-y:auto;padding:0 2px 2px 0}.manual-location-card{box-shadow:0 3px 0 #2c3e50;min-height:86px}.manual-empty{background:#fff;border:2px dashed #b2bec3;border-radius:12px;color:#636e72;font-weight:800;padding:14px;text-align:center}.recommend-footer{background:#fffdf0;border:2.5px solid #2c3e50;border-radius:16px;box-shadow:0 4px 0 #2c3e50;display:flex;flex-direction:column;flex-shrink:0;gap:10px;margin-top:10px;padding:12px 12px calc(10px + env(safe-area-inset-bottom, 0px))}.plan-loader-spinner{animation:plan-spin .9s linear infinite;border:4px solid #ffeaa7;border-radius:50%;border-top-color:#f59e0b;height:44px;margin:0 auto 10px;width:44px}@keyframes plan-spin{to{transform:rotate(1turn)}}.plan-creating-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0e192b61;display:flex;inset:0;justify-content:center;padding:20px;position:absolute;z-index:40}.plan-creating-card{background:#fff;border:3px solid #2c3e50;border-radius:18px;box-shadow:0 6px 0 #2c3e50;max-width:320px;padding:18px 14px;text-align:center;width:100%}.plan-creating-card h3{color:#2c3e50;font-size:18px;margin:0 0 8px}.plan-creating-card p{color:#64748b;font-size:13px;line-height:1.4;margin:0}.budget-tracker{display:flex;flex-direction:column;gap:8px}.budget-info{align-items:center;color:#2d3436;display:flex;font-size:13px;gap:8px;justify-content:space-between}.budget-status{border-radius:12px;font-size:11px;font-weight:700;padding:2px 8px;white-space:nowrap}.status-ok{background:#e3fcef;color:#00875a}.status-over{background:#ffebe6;color:#de350b}.budget-bar-container{background:#f1f2f6;border-radius:4px;height:8px;overflow:hidden}.budget-bar{height:100%;transition:width .3s ease,background-color .3s ease}.bar-ok{background:linear-gradient(90deg,#55efc4,#00b894)}.bar-over{background:linear-gradient(90deg,#ff7675,#d63031)}.action-bar{align-items:center;display:flex;gap:12px;justify-content:space-between}.selected-count{color:#636e72;font-size:14px}.btn-create-trip{background:#2ed573;border:2.5px solid #2c3e50;border-radius:25px;box-shadow:0 4px 0 #2c3e50;color:#2c3e50;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:700;min-height:44px;padding:10px 20px;transition:all .2s}.btn-create-trip:disabled{background:#b2bec3;box-shadow:none;cursor:not-allowed}.btn-create-trip:hover:not(:disabled){background:#2ed573;transform:none}.btn-create-trip:active:not(:disabled){box-shadow:0 1px 0 #2c3e50;transform:translateY(3px)}.loc-view-detail{color:#1e90ff;cursor:pointer;display:inline-block;font-size:13px;font-weight:700;margin-top:8px;transition:color .2s}.loc-view-detail:hover{color:#09a1c1;text-decoration:underline}body.dark-theme .recommend-screen{background-color:var(--st-bg);color:var(--st-text)}body.dark-theme .recommend-header{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .recommend-header h2{color:var(--st-text)}body.dark-theme .recommend-subtitle{color:var(--st-text-muted)}body.dark-theme .location-tab-strip{border-bottom-color:var(--game-border-color)}body.dark-theme .location-tab{background-color:var(--st-surface-muted);border-color:var(--game-border-color);box-shadow:inset 0 -3px 0 #ffffff0a;color:var(--st-text-muted)}body.dark-theme .location-tab strong{background-color:#ffffff1a;color:var(--st-text)}body.dark-theme .location-tab.active{background-color:var(--st-surface);box-shadow:none;color:var(--st-text)}body.dark-theme .location-tab-panel{box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .location-card,body.dark-theme .location-tab-panel{background-color:var(--st-surface);border-color:var(--game-border-color)}body.dark-theme .location-card{box-shadow:0 3px 0 var(--game-border-color)}body.dark-theme .location-card.selected{background-color:#2ed5731f;border-color:var(--game-green);box-shadow:0 3px 0 var(--game-border-color),0 0 10px #2ed57333}body.dark-theme .loc-thumb{background-color:var(--st-surface-muted);border-color:var(--game-border-color)}body.dark-theme .loc-thumb span{color:var(--game-sky)}body.dark-theme .manual-section-header span{color:var(--st-text-muted)}body.dark-theme .manual-search-box{background-color:var(--st-surface-muted);border-color:var(--game-border-color)}body.dark-theme .manual-search-box input{color:var(--st-text)}body.dark-theme .manual-search-box svg,body.dark-theme .manual-sort-row>span{color:var(--st-text-muted)}body.dark-theme .manual-sort-controls button{background-color:var(--st-surface-muted);border-color:var(--game-border-color);box-shadow:0 2px 0 var(--game-border-color);color:var(--st-text)}body.dark-theme .manual-sort-controls button.active{background-color:#ff9f1a;color:#fff}body.dark-theme .manual-source-badge{background-color:#0ea5e929;border-color:var(--game-border-color);color:var(--game-sky)}body.dark-theme .manual-empty{background-color:var(--st-surface-muted);border-color:var(--st-border);color:var(--st-text-muted)}body.dark-theme .loc-info h4{color:var(--st-text)}body.dark-theme .loc-price{color:var(--st-text-muted)}body.dark-theme .loc-nights-control span{color:var(--st-text)!important}body.dark-theme .loc-nights-control button{background-color:var(--st-surface-muted);border-color:var(--st-border);color:var(--st-text)}body.dark-theme .recommend-footer{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color)}body.dark-theme .budget-info{color:var(--st-text)}body.dark-theme .selected-count{color:var(--st-text-muted)}body.dark-theme .btn-create-trip{border-color:var(--game-border-color);box-shadow:0 4px 0 var(--game-border-color);color:#2c3e50}body.dark-theme .btn-create-trip:active:not(:disabled){box-shadow:0 1px 0 var(--game-border-color)}body.dark-theme .plan-creating-card{background-color:var(--st-surface);border-color:var(--game-border-color);box-shadow:0 6px 0 var(--game-border-color)}body.dark-theme .plan-creating-card h3{color:var(--st-text)}body.dark-theme .plan-creating-card p{color:var(--st-text-muted)}body.dark-theme .status-ok{background-color:#2ecc7133;color:#2ecc71}body.dark-theme .status-over{background-color:#e74c3c33;color:#e74c3c}body.dark-theme .budget-bar-container{background-color:var(--st-surface-muted)}body.dark-theme .loc-view-detail{color:var(--game-sky)}@media (max-width:420px){.recommend-screen{padding:calc(10px + env(safe-area-inset-top, 0px)) 10px 10px}.recommend-header{gap:8px;padding:8px 10px}.recommend-header h2{font-size:19px}.recommend-subtitle{font-size:13px;margin-bottom:14px}.location-tab{font-size:12px;gap:5px;padding:8px 7px}.location-tab-panel{padding:10px}.location-card{gap:8px;padding:8px}.loc-thumb{min-width:62px;width:62px}.loc-info h4{font-size:14px}.loc-score,.loc-tags{font-size:11px}.loc-price,.loc-view-detail{font-size:12px}}.island-map-container{-webkit-touch-callout:none;background:#e0f7fa;border:none;border-radius:0;box-shadow:none;flex:1 1;height:100%;min-height:400px;overflow:hidden;position:relative;-webkit-user-select:none;user-select:none;width:100%}.island-background{background:radial-gradient(ellipse at center,#dcedc1 0,#a8e6cf 70%,#0000 100%);filter:brightness(.85) contrast(1.05);height:100%;left:0;top:0;transition:filter .3s ease;width:100%;z-index:1}.island-background,.island-hotspot{align-items:center;display:flex;justify-content:center;position:absolute}.island-hotspot{flex-direction:column;transition:opacity .3s ease;z-index:10}.island-hotspot.completed .hotspot-image-wrapper{opacity:.6}.hotspot-image-wrapper{cursor:pointer;height:100%;left:0;position:absolute;top:0;transition:transform .25s cubic-bezier(.34,1.56,.64,1);width:100%}.hotspot-image-wrapper:hover{transform:scale(1.15) translateY(-5px);z-index:20}.hotspot-image{-webkit-user-drag:none;user-drag:none;filter:drop-shadow(0 8px 10px rgba(0,0,0,.5)) drop-shadow(0 2px 4px rgba(0,0,0,.3)) saturate(1.25) contrast(1.15) brightness(1.15);height:100%;object-fit:contain;pointer-events:none;transform:scale(1.6);transform-origin:bottom center;width:100%}.island-hotspot:not(.completed) .hotspot-image{animation:glowPulse 2s ease-in-out infinite alternate}@keyframes glowPulse{0%{filter:drop-shadow(0 8px 10px rgba(0,0,0,.5)) drop-shadow(0 0 5px rgba(255,235,59,.5)) saturate(1.25) contrast(1.15) brightness(1.15)}to{filter:drop-shadow(0 8px 10px rgba(0,0,0,.5)) drop-shadow(0 0 20px rgba(255,235,59,1)) saturate(1.35) contrast(1.2) brightness(1.3)}}.hotspot-click-fallback{background-color:initial;border-radius:8px;height:100%;pointer-events:auto;width:100%}.hotspot-click-fallback:hover{background-color:#fff3;border:2px solid #fff9}.building-name{background:#fff;border:1.5px solid #2d3436;border-radius:6px;box-shadow:2px 4px 6px #00000026;color:#111;font-size:12px;font-weight:700;max-width:180px;opacity:0;overflow:hidden;padding:6px 12px;position:absolute;text-overflow:ellipsis;transform:translateY(5px);transition:opacity .2s ease-in-out,visibility .2s,transform .2s ease-in-out;visibility:hidden;white-space:nowrap;z-index:30}.building-name.show-label{opacity:1;transform:translateY(0);visibility:visible}.building-name.show-label:hover{transform:scale(1.05) translateY(0)}.bubble-tr{bottom:calc(100% + 8px);left:40%}.bubble-tr:before{border-color:#2d3436 #0000 #0000;border-style:solid;border-width:14px 10px 0 0;bottom:-14px;content:"";left:12px;position:absolute}.bubble-tr:after{border-color:#fff #0000 #0000;border-style:solid;border-width:12px 8px 0 0;bottom:-11px;content:"";left:13px;position:absolute}.bubble-tl{bottom:calc(100% + 8px);right:40%}.bubble-tl:before{border-color:#2d3436 #0000 #0000;border-style:solid;border-width:14px 0 0 10px;bottom:-14px;content:"";position:absolute;right:12px}.bubble-tl:after{border-color:#fff #0000 #0000;border-style:solid;border-width:12px 0 0 8px;bottom:-11px;content:"";position:absolute;right:13px}.bubble-br{left:40%;top:calc(100% + 8px)}.bubble-br:before{border-color:#0000 #0000 #2d3436;border-style:solid;border-width:0 10px 14px 0;content:"";left:12px;position:absolute;top:-14px}.bubble-br:after{border-color:#0000 #0000 #fff;border-style:solid;border-width:0 8px 12px 0;content:"";left:13px;position:absolute;top:-11px}.bubble-bl{right:40%;top:calc(100% + 8px)}.bubble-bl:before{border-color:#0000 #0000 #2d3436;border-style:solid;border-width:0 0 14px 10px;content:"";position:absolute;right:12px;top:-14px}.bubble-bl:after{border-color:#0000 #0000 #fff;border-style:solid;border-width:0 0 12px 8px;content:"";position:absolute;right:13px;top:-11px}.checkin-flag{animation:bounce 2s ease-in-out infinite;color:#b30000;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));font-size:28px;pointer-events:none;position:absolute;right:-10px;top:-20px;z-index:3}body.dark-theme .island-map-container{background-color:#0b0f19}body.dark-theme .island-background{background:radial-gradient(ellipse at center,#1e3a5f 0,#0f172a 70%,#0000 100%);filter:brightness(.65) contrast(1.1)}body.dark-theme .building-name{background:var(--st-surface);border-color:var(--st-border);color:var(--st-text)}body.dark-theme .bubble-tl:after,body.dark-theme .bubble-tr:after{border-color:var(--st-surface) #0000 #0000 #0000}body.dark-theme .bubble-bl:after,body.dark-theme .bubble-br:after{border-color:#0000 #0000 var(--st-surface) #0000}body.dark-theme .bubble-tl:before,body.dark-theme .bubble-tr:before{border-color:var(--st-border) #0000 #0000 #0000}body.dark-theme .bubble-bl:before,body.dark-theme .bubble-br:before{border-color:#0000 #0000 var(--st-border) #0000}.location-tasks-drawer{display:flex;flex-direction:column;inset:0;justify-content:flex-end;overflow:hidden;position:absolute;z-index:1000}.drawer-overlay{animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0f172a66;inset:0;position:absolute}.drawer-content{animation:slideUp .35s cubic-bezier(.16,1,.3,1);background:var(--st-surface);border-radius:30px 30px 0 0;border-top:1px solid var(--st-border);box-shadow:var(--st-shadow);box-sizing:border-box;color:var(--st-text);display:flex;flex-direction:column;max-height:85%;max-width:100%;padding:20px 20px calc(20px + env(safe-area-inset-bottom, 0px));position:relative;transition:transform .22s ease,background-color .3s ease,border-color .3s ease,color .3s ease;width:100%;z-index:10}.drawer-content.is-dragging{transition:none}.drawer-drag-zone{align-items:center;background:#0000;border:none;cursor:grab;display:flex;justify-content:center;margin:-12px 0 3px;min-height:36px;padding:12px 0 10px;touch-action:none;width:100%}.drawer-drag-zone:active{cursor:grabbing}.drawer-handle{background-color:var(--st-border);border-radius:10px;display:block;height:5px;pointer-events:none;width:40px}.drawer-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.header-info .location-tag{color:#10b981;display:block;font-size:10px;font-weight:800;letter-spacing:.1em;margin-bottom:2px}.header-info h3{color:var(--st-text);font-size:18px;font-weight:800;margin:0}.btn-close-drawer{align-items:center;background:var(--st-surface-muted);border:1px solid var(--st-border);border-radius:50%;color:var(--st-text-muted);cursor:pointer;display:flex;font-size:14px;justify-content:center;min-height:44px;min-width:44px;transition:all .2s}.btn-close-drawer:hover{background:var(--st-surface);color:var(--st-text)}.drawer-body{flex:1 1;min-height:0;overflow-y:auto;padding-bottom:20px}.location-info-section{display:flex;flex-direction:column;gap:12px;margin-bottom:15px}.hero-img-container{border:1px solid var(--st-border);border-radius:16px;height:140px;overflow:hidden;position:relative}.location-hero-img{height:100%;object-fit:cover;width:100%}.location-category-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172ad9;border:1px solid #ffffff14;border-radius:8px;bottom:10px;color:#10b981;font-size:10px;font-weight:800;left:10px;padding:4px 10px;position:absolute}.location-meta-content{display:flex;flex-direction:column;gap:6px}.location-description{color:var(--st-text-muted);font-size:12px;line-height:1.45;margin:0}.location-rating-row{align-items:center;display:flex;font-size:11px;justify-content:space-between}.location-rating{color:#fbbf24;font-weight:700}.location-open-status{font-weight:700}.divider-line{background:var(--st-border);height:1px;margin:15px 0}.tasks-section-title{color:var(--st-text);font-size:12px;font-weight:800;letter-spacing:.05em;margin:0 0 6px}.drawer-intro{color:var(--st-text-muted);font-size:11px;line-height:1.4;margin:0 0 15px}.tasks-list{display:flex;flex-direction:column;gap:12px}.task-card-item{background:var(--st-surface-muted);border:1px solid var(--st-border);border-radius:18px;cursor:pointer;min-height:44px;padding:15px;transition:all .25s cubic-bezier(.4,0,.2,1)}.task-card-item:hover{background:var(--st-surface);border-color:var(--st-text-muted);transform:translateY(-2px)}.task-card-item.completed{background:#10b9810f;border-color:#10b98140;cursor:default}.task-card-item.completed:hover{transform:none}.task-card-item.in_progress{background:#f59e0b0f;border-color:#f59e0b40}.task-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.task-badge-reward{background:#fbbf2426;border:1px solid #fbbf2440;border-radius:8px;color:#fbbf24;font-size:11px;font-weight:800;padding:3px 8px}.difficulty-badge{border-radius:6px;font-size:10px;font-weight:700;padding:2px 6px}.difficulty-badge.easy{background:#10b98126;color:#34d399}.difficulty-badge.medium{background:#f59e0b26;color:#fbbf24}.difficulty-badge.hard{background:#ef444426;color:#f87171}.task-item-title{color:var(--st-text);font-size:14px;font-weight:700;margin:0 0 6px}.task-card-item.completed .task-item-title{color:var(--st-text-muted);text-decoration:line-through}.task-item-desc{color:var(--st-text-muted);font-size:12px;line-height:1.4;margin:0 0 12px}.task-item-footer{align-items:center;border-top:1px solid var(--st-border);color:var(--st-text-muted);display:flex;font-size:10px;justify-content:space-between;padding-top:10px}.task-status-text{font-weight:700;transition:color .2s}.task-card-item:hover .task-status-text.not_started{color:#60a5fa}.task-card-item:hover .task-status-text.in_progress{color:#fbbf24}.task-status-text.completed{color:#10b981}.task-status-text.in_progress{color:#f59e0b}.task-status-text.not_started{color:#3b82f6}.drawer-loading{align-items:center;display:flex;flex-direction:column;gap:15px;justify-content:center;padding:40px 0}.drawer-loading .spinner{animation:spin 1s linear infinite;border:3px solid var(--st-border);border-radius:50%;border-top:3px solid #10b981;height:36px;width:36px}.drawer-empty,.drawer-error{color:var(--st-text-muted);padding:45px 20px;text-align:center}.drawer-error span{display:block;font-size:24px;margin-bottom:8px}.drawer-empty span{display:block;font-size:28px;margin-bottom:8px}.drawer-empty p,.drawer-error p{font-size:13px;margin:0}@keyframes spin{to{transform:rotate(1turn)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.task-card-item.cancelled{background:#ef44440a;border-color:#ef444440}.task-status-text.cancelled{color:#f87171}.task-card-main-row{align-items:flex-start;display:flex;gap:12px}.task-checkbox-container{align-items:center;display:flex;justify-content:center;padding-top:10px}.task-status-indicator{font-size:18px;-webkit-user-select:none;user-select:none}.task-card-details{flex:1 1}.task-detail-screen-gami{background-color:var(--st-bg);color:var(--st-text);display:flex;flex-direction:column;inset:0;position:absolute;transition:background-color .3s ease,color .3s ease;z-index:1001}.task-detail-header-gami{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:var(--st-surface);border-bottom:1px solid var(--st-border);display:flex;padding:calc(18px + env(safe-area-inset-top, 0px)) 20px 18px;transition:background-color .3s ease,border-color .3s ease}.btn-back-gami{align-items:center;background:none;border:none;color:#10b981;cursor:pointer;display:flex;font-size:14px;font-weight:700;gap:5px;min-height:44px;padding:0}.header-title-gami{color:var(--st-text-muted);font-size:13px;font-weight:800;letter-spacing:.1em;margin-left:20px}.task-detail-body-gami{display:flex;flex:1 1;flex-direction:column;gap:20px;overflow-y:auto;padding:20px 20px calc(40px + env(safe-area-inset-bottom, 0px))}.task-target-card{background:var(--st-surface);border:1px solid var(--st-border);border-radius:24px;box-shadow:var(--st-shadow);flex-shrink:0;overflow:hidden;transition:background-color .3s ease,border-color .3s ease}.target-img-container{height:160px;position:relative}.target-img{height:100%;object-fit:cover;width:100%}.reward-overlay{background:#fbbf24f2;border-radius:10px;box-shadow:0 4px 12px #fbbf244d;color:#0b0f19;font-size:11px;font-weight:900;padding:4px 10px;position:absolute;right:15px;top:15px}.target-info{padding:18px}.diff-badge{background:var(--st-surface-muted);border:1px solid var(--st-border);border-radius:6px;display:inline-block;font-size:10px;font-weight:700;margin-bottom:8px;padding:2px 6px}.target-info h3{color:var(--st-text);font-size:18px;font-weight:800;margin:0 0 6px}.task-desc{color:var(--st-text-muted);font-size:12px;line-height:1.4;margin:0}.gps-status-box{background:var(--st-surface);border:1px solid var(--st-border);border-radius:24px;display:flex;flex-direction:column;flex-shrink:0;gap:15px;padding:18px;transition:background-color .3s ease,border-color .3s ease}.gps-status-header{align-items:center;display:flex;justify-content:space-between}.gps-status-header h4{color:var(--st-text-muted);font-size:11px;font-weight:800;letter-spacing:.05em;margin:0}.gps-pill{border-radius:20px;font-size:10px;font-weight:800;padding:3px 8px;text-transform:uppercase}.gps-pill.loading{background:#3b82f626;color:#3b82f6}.gps-pill.valid{background:#10b98126;color:#10b981}.gps-pill.invalid{background:#f59e0b26;color:#f59e0b}.gps-error-alert{background:#ef444414;border:1px solid #ef444426;border-radius:12px;color:#f87171;font-size:12px;line-height:1.4;padding:10px 14px}.gps-grid-data{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.gps-stat-item{background:var(--st-surface-muted);border:1px solid var(--st-border);border-radius:14px;display:flex;flex-direction:column;padding:12px;transition:background-color .3s ease,border-color .3s ease}.stat-label{color:var(--st-text-muted);font-size:9px;font-weight:700;margin-bottom:2px;text-transform:uppercase}.stat-value{color:var(--st-text);font-size:18px;font-weight:900;margin-bottom:2px}.stat-value.good{color:#10b981}.stat-value.warning{color:#f59e0b}.stat-hint{color:var(--st-text-muted);font-size:9px}.btn-navigate-gps{align-items:center;background:var(--st-surface-muted);border:1px solid var(--st-border);border-radius:12px;color:var(--st-text);display:flex;font-size:11px;font-weight:700;gap:8px;justify-content:center;min-height:44px;padding:10px 0;text-decoration:none;transition:all .2s}.btn-navigate-gps:hover{background:var(--st-surface);color:var(--st-text)}.camera-interact-box{background:var(--st-surface);border:1px solid var(--st-border);border-radius:24px;display:flex;flex-direction:column;flex-shrink:0;gap:15px;padding:18px;transition:background-color .3s ease,border-color .3s ease}.camera-interact-box h4{color:var(--st-text-muted);font-size:11px;font-weight:800;letter-spacing:.05em;margin:0}.qa-option-button{background:var(--st-surface-muted);border:1px solid var(--st-border);border-radius:12px;color:var(--st-text);cursor:pointer;font-size:13px;padding:12px 15px;text-align:left;transition:background-color .2s ease,border-color .2s ease}.qa-option-button.selected{background:#10b98126;border:2px solid #10b981}.camera-dash-upload{border:2px dashed var(--st-border);border-radius:18px;padding:30px 15px;text-align:center;transition:all .25s}.camera-dash-upload.unlocked{background:#10b98105;border-color:#10b9814d;cursor:pointer}.camera-dash-upload.unlocked:hover{background:#10b9810d;border-color:#10b981}.camera-dash-upload.locked{cursor:not-allowed;opacity:.55}.hidden-file-input{display:none}.camera-upload-label{align-items:center;cursor:pointer;display:flex;flex-direction:column;width:100%}.camera-icon-circle{align-items:center;background:var(--st-surface-muted);border-radius:50%;display:flex;font-size:24px;height:52px;justify-content:center;margin-bottom:12px;transition:all .25s;width:52px}.camera-dash-upload.unlocked .camera-icon-circle{background:#10b9811a;color:#10b981}.camera-upload-label h5{color:var(--st-text);font-size:14px;font-weight:800;margin:0 0 4px}.camera-upload-label p{color:var(--st-text-muted);font-size:11px;line-height:1.4;margin:0;max-width:80%}.image-preview-card{border:1px solid var(--st-border);border-radius:18px;height:200px;overflow:hidden;position:relative}.preview-img{height:100%;object-fit:cover;width:100%}.btn-capture-again{background:#ef4444e6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:11px;font-weight:700;min-height:32px;padding:5px 12px;position:absolute;right:12px;top:12px;transition:all .2s}.btn-capture-again:hover{background:#ef4444}.submit-error-banner{background:#ef444414;border:1px solid #ef444426;border-radius:12px;color:#f87171;font-size:12px;line-height:1.4;padding:10px 14px}.btn-submit-verification{align-items:center;background:#10b981;border:none;border-radius:14px;box-shadow:0 4px 15px #10b98133;color:#0b0f19;cursor:pointer;display:flex;font-size:14px;font-weight:800;gap:8px;justify-content:center;min-height:48px;padding:14px 0;transition:all .2s;width:100%}.btn-submit-verification:hover{background:#34d399;box-shadow:0 4px 20px #10b98159}.btn-submit-verification.loading{background:#10b98180;cursor:wait}.mini-spinner{animation:spin .8s linear infinite;border:2px solid #0000001a;border-radius:50%;border-top-color:#000;height:16px;width:16px}.success-gami-modal{align-items:center;box-sizing:border-box;display:flex;inset:0;justify-content:center;padding:calc(20px + env(safe-area-inset-top, 0px)) 20px calc(20px + env(safe-area-inset-bottom, 0px));position:fixed;z-index:1050}.success-gami-modal:before{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#090d16d9;content:"";inset:0;position:absolute}.modal-card{animation:bounceIn .55s cubic-bezier(.175,.885,.32,1.275);background:var(--st-surface);border:1px solid var(--st-border);border-radius:30px;box-shadow:var(--st-shadow);max-width:340px;padding:25px;position:relative;text-align:center;width:100%;z-index:10}.modal-glow-back{background:#fbbf24;filter:blur(40px);height:60px;left:20%;opacity:.15;position:absolute;top:-20px;width:60%}.badge-3d-hexagon{align-items:center;animation:pulseGold 2s infinite;background:linear-gradient(135deg,#fbbf24,#d97706);border-radius:50%;box-shadow:0 8px 24px #fbbf2466;display:flex;font-size:38px;height:80px;justify-content:center;margin:0 auto 15px;width:80px}.modal-card h2{color:#fbbf24;font-size:20px;font-weight:900;letter-spacing:.05em;margin:0 0 8px}.success-congrats-msg{color:var(--st-text);font-size:13px;line-height:1.5;margin:0 0 20px}.score-reward-summary{display:flex;gap:10px;margin-bottom:20px}.reward-score-pill{background:var(--st-surface-muted);border:1px solid var(--st-border);border-radius:16px;display:flex;flex:1 1;flex-direction:column;padding:10px}.score-label{color:var(--st-text-muted);font-size:8px;font-weight:700;margin-bottom:2px;text-transform:uppercase}.score-val{color:#fbbf24;font-size:14px;font-weight:900}.level-progression-bar{background:var(--st-surface-muted);border:1px solid var(--st-border);border-radius:18px;margin-bottom:22px;padding:12px;text-align:left}.lvl-labels{color:var(--st-text);display:flex;font-size:10px;font-weight:800;justify-content:space-between;margin-bottom:6px}.lvl-track-progress{background:#ffffff0f;border-radius:10px;height:8px;margin-bottom:4px;overflow:hidden}.lvl-fill-progress{background:linear-gradient(90deg,#10b981,#34d399);border-radius:10px;height:100%;transition:width 1s ease-out}.lvl-exp-detail{color:var(--st-text-muted);display:block;font-size:8px}.btn-close-modal-gami{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:14px;box-shadow:0 4px 15px #10b98133;color:#fff;cursor:pointer;font-size:13px;font-weight:800;min-height:44px;padding:12px 0;transition:all .2s;width:100%}.btn-close-modal-gami:hover{background:linear-gradient(135deg,#34d399,#10b981);box-shadow:0 4px 20px #10b98159}@keyframes bounceIn{0%,20%,40%,60%,80%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:scale3d(.3,.3,.3)}20%{transform:scale3d(1.1,1.1,1.1)}40%{transform:scale3d(.9,.9,.9)}60%{opacity:1;transform:scale3d(1.03,1.03,1.03)}80%{transform:scale3d(.97,.97,.97)}to{opacity:1;transform:scaleX(1)}}@keyframes pulseGold{0%{box-shadow:0 0 0 0 #fbbf2466}70%{box-shadow:0 0 0 10px #fbbf2400}to{box-shadow:0 0 0 0 #fbbf2400}}.btn-cancel-task-body-gami{align-items:center;background:#ef444414;border:1px solid #ef444440;border-radius:8px;color:#f87171;cursor:pointer;display:inline-flex;font-size:11px;font-weight:700;gap:4px;margin-top:12px;min-height:44px;padding:6px 12px;transition:all .25s ease}.btn-cancel-task-body-gami:hover{background:#ef444433;border-color:#ef4444;color:#fff}body.scanner-active,body.scanner-active #root,body.scanner-active .App,body.scanner-active .task-detail-screen-gami{background:#0000!important}body.scanner-active .task-detail-body-gami,body.scanner-active .task-detail-header-gami{display:none!important}.trip-detail-screen{background:#f8f9fa;box-sizing:border-box;display:flex;flex-direction:column;height:100%;min-height:100dvh;overflow-y:auto;padding:0}.trip-detail-screen.location-detail-mode{background:#fff}.location-detail-content{display:flex;flex-direction:column;padding-bottom:calc(82px + env(safe-area-inset-bottom, 0px))}.location-cover-image{background:#dbeafe;flex-shrink:0;height:clamp(170px,28vh,220px);overflow:hidden;position:relative}.location-cover-image--empty{background:linear-gradient(145deg,#dbeafe,#e0f7fa);height:150px}.location-cover-photo{height:100%;inset:0;object-fit:cover;position:absolute;width:100%}.location-cover-placeholder{align-items:center;color:#52708f;display:flex;flex-direction:column;font-size:12px;font-weight:800;gap:5px;inset:0;justify-content:center;padding:calc(48px + env(safe-area-inset-top, 0px)) 70px 16px;position:absolute;text-align:center}.location-cover-credit{background:#0000009e;border-radius:6px;bottom:24px;color:#fff;font-size:9px;line-height:1.3;max-width:calc(100% - 16px);overflow:hidden;padding:4px 7px;position:absolute;right:8px;text-decoration:none;text-overflow:ellipsis;white-space:nowrap;z-index:5}.status-badge{background:#ffffffe6;border-radius:20px;box-shadow:0 2px 8px #00000026;font-size:.85rem;font-weight:600;padding:5px 12px;position:absolute;right:15px;top:calc(12px + env(safe-area-inset-top, 0px))}.checked-in-badge{border:1px solid #00b894;color:#00b894}.location-info-card{background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -4px 12px #0000000d;margin-top:-20px;padding:20px;position:relative;z-index:2}.location-title-row{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:10px}.location-title-row h3{color:#2d3436;flex:1 1;font-size:1.4rem;margin:0}.rating-mock{color:#fdcb6e;font-size:.9rem;font-weight:600;margin-left:10px;white-space:nowrap}.rating-mock span{color:#636e72;font-size:.8rem;font-weight:400}.location-desc-mock{color:#636e72;font-size:.95rem;line-height:1.6;margin-bottom:15px}.location-meta{color:#2d3436;display:flex;flex-direction:column;font-size:.9rem;gap:8px}.location-meta span i{color:#0984e3;text-align:center;width:20px}.location-map-section{margin-top:10px;padding:0 20px}.location-map-section h4{color:#2d3436;font-size:1.1rem;margin:0 0 10px}.location-action-bar{background:#fff;border-top:1px solid #eee;bottom:0;box-shadow:0 -2px 10px #0000000d;left:50%;max-width:430px;padding:8px 12px calc(8px + env(safe-area-inset-bottom, 0px));position:fixed;right:auto;transform:translateX(-50%);width:100%;z-index:100}.location-detail-back-btn{align-items:center;background-color:#fffffff0;border:2.5px solid #2c3e50;border-radius:50%;box-shadow:0 3px 0 #2c3e50;color:#2c3e50;cursor:pointer;display:flex;height:44px;justify-content:center;left:calc(12px + env(safe-area-inset-left, 0px));position:absolute;top:calc(12px + env(safe-area-inset-top, 0px));width:44px;z-index:10}.location-detail-back-btn:active{box-shadow:none;transform:translateY(3px)}.btn-checkin-tab{align-items:center;background:#00b894;display:flex;font-size:1.1rem;font-weight:600;justify-content:center;min-height:48px;padding:14px;transition:all .2s;width:100%}.btn-checkin-tab:active{transform:scale(.98)}.btn-checkin-tab:disabled{transform:none}.btn-already-checked{background:#dfe6e9!important;color:#2d3436!important}.detail-header{align-items:center;display:flex;justify-content:center;margin:20px 20px 15px;position:relative}.detail-header h2{flex:1 1;font-size:18px;margin:0;padding:0 50px;text-align:center}.btn-back-icon{align-items:center;background:#e3f2fd;border:none;border-radius:12px;box-shadow:0 4px 12px #0000000d;color:#1976d2;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;min-height:44px;padding:0 15px;transition:all .2s ease;width:auto}.btn-back-icon:hover{background:#bbdefb;transform:translateX(-3px)}.trip-summary{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;display:flex;justify-content:space-between;margin-bottom:15px;padding:15px}.summary-item{align-items:center;display:flex;gap:8px}.summary-item .icon{background:#f0faff;border-radius:8px;font-size:20px;padding:8px}.summary-item div{display:flex;flex-direction:column}.summary-item small{color:#636e72;font-size:11px}.summary-item strong{color:#2d3436;font-size:14px}.color-legend{background:#fff;border-radius:10px;box-shadow:0 2px 4px #00000008;display:flex;gap:15px;margin-bottom:20px;padding:10px 15px}.legend-item{align-items:center;color:#636e72;display:flex;font-size:11px;gap:6px}.legend-dot{border-radius:50%;display:inline-block;height:10px;width:10px}.legend-blue{background:#0abde3}.legend-orange{background:#f39c12}.legend-green{background:#00b894}.island-map-section{background:#fff;border-radius:0;box-shadow:none;display:flex;flex:1 1;flex-direction:column;margin-bottom:0;padding:0}.map-instruction{color:#636e72;font-size:13px;font-style:italic;margin:0 0 15px;text-align:center}.blank-location-tab{align-items:center;animation:fadeIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000000d;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:30px 20px;text-align:center}.blank-tab-content p{color:#636e72;font-size:16px;line-height:1.5}.btn-checkin-tab{background:linear-gradient(135deg,#00b894,#55efc4);border:none;border-radius:12px;box-shadow:0 4px 15px #00b8944d;color:#fff;cursor:pointer;font-size:15px;font-weight:700;padding:14px 24px;transition:all .2s ease}.btn-checkin-tab:hover:not(:disabled){box-shadow:0 6px 20px #00b89466;transform:translateY(-2px)}.btn-checkin-tab:disabled{background:#b2bec3;box-shadow:none;cursor:not-allowed}.trip-status-badge{align-items:center;border-radius:20px;display:flex;font-size:12px;font-weight:700;padding:5px 12px;white-space:nowrap}.trip-status-badge.status-ongoing{background:#e3f2fd;border:1.5px solid #1976d2;color:#1976d2}.trip-status-badge.status-completed{background:#e8f5e9;border:1.5px solid #2e7d32;color:#2e7d32}.trip-status-badge.status-cancelled{background:#ffebee;border:1.5px solid #c62828;color:#c62828}.trip-action-section{background:#0000;border-radius:0;box-shadow:none;gap:12px;margin:0 20px 15px;padding:0}.btn-complete-trip{background:linear-gradient(135deg,#00b894,#55efc4);border:none;border-radius:10px;box-shadow:0 4px 15px #00b8944d;color:#fff;cursor:pointer;flex:1 1;font-size:14px;font-weight:700;min-height:44px;padding:12px 20px;transition:all .3s ease}.btn-complete-trip:hover:not(:disabled){box-shadow:0 6px 20px #00b89466;transform:translateY(-2px)}.btn-complete-trip:disabled{background:#b2bec3;box-shadow:none;cursor:not-allowed;transform:none}.btn-cancel-trip{background:linear-gradient(135deg,#e74c3c,#fd79a8);border:none;border-radius:10px;box-shadow:0 4px 15px #e74c3c4d;cursor:pointer;flex:1 1;font-size:14px;font-weight:700;min-height:44px;padding:12px 20px;transition:all .3s ease}.btn-cancel-trip:hover:not(:disabled){box-shadow:0 6px 20px #e74c3c66;transform:translateY(-2px)}.btn-cancel-trip:disabled{background:#b2bec3;box-shadow:none;cursor:not-allowed;transform:none}.action-toast{animation:fadeSlide .3s ease;background:linear-gradient(135deg,#2d3436,#636e72);border-radius:10px;box-shadow:0 4px 15px #00000026;color:#fff;font-size:14px;font-weight:600;margin-bottom:15px;padding:12px 18px;text-align:center}.gps-indicator{color:#74b9ff;font-size:10px;margin-top:3px}.budget-warning-banner{align-items:center;animation:fadeSlide .3s ease;background:linear-gradient(135deg,#fff9db,#fff3bf);border:1px solid #ffe066;border-radius:12px;box-shadow:0 4px 6px #0000000d;color:#e67e22;display:flex;font-size:13px;font-weight:600;gap:10px;line-height:1.4;margin-bottom:15px;padding:12px 15px}.cloud-transition-container{bottom:0;left:0;overflow:hidden;pointer-events:none;position:fixed;right:0;top:0;z-index:9999}.cloud-transition-container.idle{display:none}.cloud{background:#fff;bottom:0;position:absolute;top:0;transition:transform .6s cubic-bezier(.4,0,.2,1);width:55%}.cloud-left{left:0;transform:translateX(-150%)}.cloud-left:before{background:#fff;border-radius:50%;box-shadow:10px 100px 0 20px #fff,20px 220px 0 40px #fff,5px 360px 0 10px #fff,25px 480px 0 30px #fff,10px 620px 0 50px #fff,15px 760px 0 20px #fff,0 900px 0 40px #fff;content:"";height:120px;position:absolute;right:-30px;top:-50px;width:120px}.cloud-right{right:0;transform:translateX(150%)}.cloud-right:before{background:#fff;border-radius:50%;box-shadow:-10px 110px 0 30px #fff,-25px 250px 0 10px #fff,-5px 380px 0 40px #fff,-20px 520px 0 20px #fff,-10px 660px 0 50px #fff,-15px 800px 0 30px #fff,0 940px 0 40px #fff;content:"";height:130px;left:-30px;position:absolute;top:-20px;width:130px}.cloud-transition-container.in .cloud-left,.cloud-transition-container.in .cloud-right{transform:translateX(0)}.cloud-transition-container.out .cloud-left{transform:translateX(-150%)}.cloud-transition-container.out .cloud-right{transform:translateX(150%)}@keyframes float-effect{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-4px) scale(1.05)}}@keyframes spin-circle{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.quest-modal-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0f1ed9;bottom:0;display:flex;justify-content:center;left:0;padding:calc(20px + env(safe-area-inset-top, 0px)) 20px calc(20px + env(safe-area-inset-bottom, 0px));position:fixed;right:0;top:0;z-index:2000}.quest-modal-content{animation:scaleUp .3s cubic-bezier(.34,1.56,.64,1);background:linear-gradient(135deg,#131931,#0d1225);border:1px solid #ffffff1a;border-radius:24px;box-shadow:0 15px 35px #00000080,0 0 25px #6c5ce733;color:#fff;max-height:calc(100dvh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 24px);max-width:350px;overflow:hidden;width:100%}.quest-modal-header{align-items:center;border-bottom:1px solid #ffffff14;display:flex;justify-content:space-between;padding:16px 20px}.quest-modal-header h3{font-size:16px;font-weight:700;margin:0}.quest-close-btn{background:none;border:none;color:#a4b0be;cursor:pointer;font-size:18px;transition:color .2s}.quest-close-btn:hover{color:#fff}.quest-modal-body{max-height:calc(100dvh - 260px);overflow-y:auto;padding:20px}.quest-desc{color:#dcdde1;font-size:13px;line-height:1.5;margin:0 0 15px}.quest-meta-info{background:#ffffff0a;border-radius:12px;color:#a29bfe;display:flex;font-size:12px;font-weight:600;justify-content:space-between;margin-bottom:20px;padding:10px 12px}.quest-action-area{display:flex;flex-direction:column;gap:12px}.quest-instruction{color:#a4b0be;font-size:12px;margin:0 0 8px}.quest-input{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;box-sizing:border-box;color:#fff;font-size:14px;outline:none;padding:12px;transition:border-color .2s,box-shadow .2s;width:100%}.quest-input:focus{border-color:#6c5ce7;box-shadow:0 0 8px #6c5ce74d}.quest-action-btn{background:linear-gradient(135deg,#6c5ce7,#a29bfe);border:none;border-radius:12px;box-shadow:0 4px 15px #6c5ce74d;color:#fff;cursor:pointer;font-size:14px;font-weight:700;min-height:44px;padding:12px;transition:transform .2s,filter .2s;width:100%}.quest-action-btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.quest-action-btn:disabled{cursor:not-allowed;opacity:.5}.quest-qr-scan-panel{display:flex;flex-direction:column;gap:10px}.quest-action-btn svg{vertical-align:middle}.quest-qr-reader-wrap{background:#ffffff0a;border:1px solid #a29bfe47;border-radius:12px;color:#dfe6e9;display:flex;flex-direction:column;gap:8px;padding:10px}.quest-qr-reader{min-height:260px;overflow:hidden;width:100%}.quest-qr-reader,.quest-qr-reader video{border-radius:10px}.quest-qr-error,.quest-qr-result{align-items:center;border-radius:10px;display:flex;font-size:12px;font-weight:700;gap:6px;padding:9px 10px}.quest-qr-result{background:#2ed57329;color:#7bed9f}.quest-qr-error{background:#ff475724;color:#ffb8b8}.quiz-options-grid{display:flex;flex-direction:column;gap:8px}.quiz-option-card{align-items:center;background:#ffffff0a;border:1px solid #ffffff14;border-radius:12px;color:#fff;cursor:pointer;display:flex;gap:12px;min-height:44px;padding:10px 14px;text-align:left;transition:all .2s ease;width:100%}.quiz-option-card:hover{background:#ffffff14;border-color:#fff3}.quiz-option-card.selected{background:#6c5ce726;border-color:#6c5ce7;box-shadow:0 0 10px #6c5ce733}.option-code{align-items:center;background:#ffffff1a;border-radius:6px;color:#a29bfe;display:flex;font-size:12px;font-weight:700;height:24px;justify-content:center;width:24px}.quiz-option-card.selected .option-code{background:#6c5ce7;color:#fff}.option-text{font-size:13px;font-weight:500}.photo-upload-placeholder{align-items:center;background:#ffffff05;border:2px dashed #ffffff26;border-radius:16px;color:#dcdde1;cursor:pointer;display:flex;flex-direction:column;font-size:12px;gap:8px;height:120px;justify-content:center;transition:border-color .2s}.photo-upload-placeholder:hover{border-color:#6c5ce7}.photo-preview-box{border:1px solid #ffffff1a;border-radius:16px;height:120px;overflow:hidden;position:relative}.photo-preview-box img{height:100%;object-fit:cover;width:100%}.photo-reset{background:#e84118d9;border:none;border-radius:6px;bottom:8px;color:#fff;cursor:pointer;font-size:10px;font-weight:700;min-height:30px;padding:4px 8px;position:absolute;right:8px}.quest-error-msg{background:#eb4d4b26;border:1px solid #eb4d4b4d;border-radius:10px;color:#ff7675;font-size:12px;font-weight:600;margin-top:12px;padding:10px}.quest-success-screen{align-items:center;display:flex;flex-direction:column;padding:10px 0;text-align:center}.success-icon{animation:bounce 1s infinite alternate;font-size:48px;margin-bottom:12px}.quest-success-screen h4{color:#2ecc71;font-size:18px;font-weight:800;margin:0 0 8px}.quest-success-screen p{color:#dcdde1;font-size:13px;margin:0 0 20px}.success-reward-card{display:flex;gap:15px;margin-bottom:24px;width:100%}.success-reward-item{align-items:center;background:#ffffff0a;border:1px solid #ffffff14;border-radius:16px;display:flex;flex:1 1;flex-direction:column;font-size:13px;gap:6px;padding:12px}.success-reward-item strong{color:#fdcb6e;font-size:16px}.quest-close-success-btn{background:#2ecc71;border:none;border-radius:12px;box-shadow:0 4px 15px #2ecc714d;color:#fff;cursor:pointer;font-size:14px;font-weight:700;min-height:44px;padding:12px;width:100%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-8px)}}.trip-detail-screen,.trip-detail-screen.location-detail-mode{background:#e0f2fe;background:var(--st-bg,#e0f2fe)}.detail-header{background:var(--st-surface);border:3px solid var(--game-border-color);border-radius:18px;box-shadow:0 4px 0 var(--game-border-color);padding:10px 12px}.detail-header h2{color:var(--st-text);font-weight:800}.detail-header .btn-back-icon{background:var(--game-yellow);border:2.5px solid var(--game-border-color);box-shadow:0 3px 0 var(--game-border-color);color:#2c3e50;left:12px;position:absolute}.btn-back-icon:hover{background:#ffdf55;transform:none}.btn-back-icon:active{box-shadow:0 0 0 #2c3e50;transform:translateY(3px)}.trip-action-section{display:flex;gap:10px;padding:0 20px}.btn-cancel-trip,.btn-complete-trip{border:2.5px solid #2c3e50;border-radius:12px;box-shadow:0 4px 0 #2c3e50;flex:1 1;font-weight:800;min-height:44px}.btn-complete-trip{background:#2ed573;color:#2c3e50}.btn-cancel-trip{background:#ff6b6b;color:#fff}.btn-cancel-trip:active,.btn-complete-trip:active{box-shadow:0 1px 0 #2c3e50;transform:translateY(3px)}.location-info-card{border:3px solid #2c3e50;border-radius:20px;box-shadow:0 6px 0 #2c3e50}.location-map-section{margin-top:14px}.location-map-section h4{color:#2c3e50;font-weight:800}.location-action-bar{background:#e3f2fd;border-top:3px solid #2c3e50;box-shadow:0 -3px 0 #2c3e50}.btn-checkin-tab,.btn-location-task{border:2.5px solid #2c3e50!important;box-shadow:0 4px 0 #2c3e50!important;font-weight:800!important}.btn-checkin-tab:active,.btn-location-task:active{box-shadow:0 1px 0 #2c3e50!important;transform:translateY(3px)}.action-toast,.checkin-toast{background:#fff;border:2px solid #2c3e50;border-radius:12px;box-shadow:0 3px 0 #2c3e50;color:#2c3e50;font-weight:700;line-height:1.45;margin:0 20px 10px}.trip-detail-screen.error,.trip-detail-screen.loading{align-items:center;background:#e0f2fe;background:var(--st-bg,#e0f2fe);display:flex;flex-direction:column;gap:10px;height:100%;justify-content:center;min-height:100%;padding:20px}.trip-detail-screen.error .spinner,.trip-detail-screen.loading .spinner{animation:trip-spin .9s linear infinite;border:4px solid #dbeafe;border-radius:50%;border-top-color:#2563eb;height:48px;width:48px}.trip-detail-screen.error p,.trip-detail-screen.loading p{color:#334155;font-size:14px;font-weight:700;margin:0}.trip-detail-screen.error h3{color:#2c3e50;font-size:20px;font-weight:800;margin:0}.trip-detail-screen.error .btn-back{background:#ffd32d;border:2.5px solid #2c3e50;border-radius:12px;box-shadow:0 4px 0 #2c3e50;color:#2c3e50;font-weight:800;margin-top:8px;min-height:44px;padding:0 14px}@keyframes trip-spin{to{transform:rotate(1turn)}}.image-btn-effect{transition:transform .15s ease,filter .15s ease}.image-btn-effect:hover:not(:disabled){filter:brightness(1.1);transform:scale(1.05)}.image-btn-effect:active:not(:disabled){filter:brightness(.9);transform:scale(.95)}body.dark-theme .trip-detail-screen{background:var(--st-bg);color:var(--st-text)}body.dark-theme .trip-detail-screen.location-detail-mode{background:var(--st-bg)}body.dark-theme .location-info-card{background:var(--st-surface);box-shadow:0 -4px 12px #0000004d;color:var(--st-text)}body.dark-theme .location-title-row h3{color:var(--st-text)}body.dark-theme .location-desc-mock{color:var(--st-text-muted)}body.dark-theme .location-map-section h4,body.dark-theme .location-meta{color:var(--st-text)}body.dark-theme .location-action-bar{background:var(--st-surface);border-top:1px solid var(--st-border);box-shadow:0 -2px 10px #0000004d}body.dark-theme .btn-already-checked{background:var(--st-surface-muted)!important;border:1px solid var(--st-border);color:var(--st-text-muted)!important}body.dark-theme .detail-header h2{color:var(--st-text)}body.dark-theme .btn-back-icon{background:var(--st-surface-muted);border:1.5px solid var(--game-border-color);color:var(--st-text)}body.dark-theme .btn-back-icon:hover{background:var(--st-surface)}body.dark-theme .trip-summary{background:var(--st-surface);box-shadow:0 4px 6px #0003}body.dark-theme .summary-item .icon{background:var(--st-surface-muted);border:1px solid var(--st-border)}body.dark-theme .summary-item small{color:var(--st-text-muted)}body.dark-theme .summary-item strong{color:var(--st-text)}body.dark-theme .color-legend{background:var(--st-surface);box-shadow:0 2px 4px #0003}body.dark-theme .legend-item{color:var(--st-text-muted)}body.dark-theme .island-map-section{background:var(--st-bg)}body.dark-theme .blank-location-tab{background:var(--st-surface);box-shadow:0 4px 12px #0003}body.dark-theme .blank-tab-content p{color:var(--st-text-muted)}body.dark-theme .budget-warning-banner{background:linear-gradient(135deg,#e67e2226,#d3540026);border:1px solid #e67e224d;box-shadow:0 4px 6px #0003;color:#e67e22}.trip-detail-screen>.trip-overview-header{grid-gap:8px;align-items:center;background:var(--st-surface);border:3px solid var(--game-border-color);border-radius:18px;box-shadow:0 4px 0 var(--game-border-color);display:grid;gap:8px;grid-template-columns:44px minmax(0,1fr) 44px;margin:calc(12px + env(safe-area-inset-top, 0px)) calc(16px + env(safe-area-inset-right, 0px)) 12px calc(16px + env(safe-area-inset-left, 0px));min-height:62px;padding:8px 10px}.trip-detail-screen>.trip-overview-header:after{content:"";width:44px}.trip-overview-header h2{color:var(--st-text);font-size:17px;font-weight:900;line-height:1.25;margin:0;min-width:0;overflow-wrap:anywhere;text-align:center}.trip-overview-back-btn{align-items:center;background:var(--game-yellow);border:2.5px solid var(--game-border-color);border-radius:12px;box-shadow:0 3px 0 var(--game-border-color);color:#2c3e50;cursor:pointer;display:inline-flex;height:44px;justify-content:center;padding:0;transition:transform .1s ease,background-color .1s ease,box-shadow .1s ease;width:44px}.trip-overview-back-btn:hover{background:#ffdf55}.trip-overview-back-btn:active{box-shadow:0 0 0 var(--game-border-color);transform:translateY(3px)}.trip-detail-screen>.trip-action-section{gap:10px;margin:4px 16px 16px;padding:0}.trip-detail-screen>.trip-action-section .btn-cancel-trip,.trip-detail-screen>.trip-action-section .btn-complete-trip{font-size:13px;padding:10px 8px}body.dark-theme .trip-detail-screen>.trip-overview-header{border-color:var(--st-border)}body.dark-theme .trip-overview-header h2{color:#fff}@media (max-width:360px){.trip-detail-screen>.trip-action-section{flex-direction:column}}.location-detail-map-wrapper{background:radial-gradient(circle at 18% 16%,#fff6a46b 0 8%,#0000 9%),linear-gradient(180deg,#f6df9d,#a9df9b 48%,#8fcce7);border:3px solid #2c3e50;border-radius:20px;box-shadow:0 7px 0 #2c3e50,0 16px 26px #2c3e5038;height:60vh;isolation:isolate;margin:15px 0 20px;min-height:400px;overflow:hidden;position:relative;width:100%}.location-detail-map-wrapper:after,.location-detail-map-wrapper:before{content:"";inset:0;pointer-events:none;position:absolute;z-index:2}.location-detail-map-wrapper:before{background:radial-gradient(circle at 18% 18%,#ffd32d24 0 10%,#0000 11%),radial-gradient(circle at 82% 72%,#2ed5731f 0 11%,#0000 12%),linear-gradient(135deg,#ffffff1f,#32d9d30f);mix-blend-mode:soft-light}.location-detail-map-wrapper:after{background-image:linear-gradient(#2c3e5012 1px,#0000 0),linear-gradient(90deg,#2c3e5012 1px,#0000 0);background-size:88px 88px,88px 88px;opacity:.12}.location-detail-map{height:100%;position:relative;width:100%;z-index:1}.location-detail-map.leaflet-container{background:radial-gradient(circle at 24% 20%,#ffec8c2e,#0000 24%),linear-gradient(180deg,#f6df9d,#a9df9b 48%,#8fcce7);font-family:Be Vietnam Pro,sans-serif}.location-detail-map .leaflet-tile-pane{filter:saturate(1.18) contrast(1.02) brightness(1.04) hue-rotate(-5deg)}.detail-game-stop-icon,.detail-game-user-icon{background:#0000!important;border:0!important}.detail-game-pin{align-items:center;background:radial-gradient(circle at 32% 26%,#fffffff5 0 12%,#0000 13%),linear-gradient(180deg,#fff176,#ff5d5d 48%,#9f2f43);border:3px solid #fff;border-radius:12px 12px 17px 17px;box-shadow:0 0 0 2px #2c3e50f5,0 6px 0 #2c3e509e,0 0 18px #ff5d5dcc;display:flex;height:36px;justify-content:center;position:relative;transform:translateY(-8px) rotate(-4deg);width:36px}.detail-game-pin:after{background:inherit;border-bottom:3px solid #fff;border-right:3px solid #fff;bottom:-10px;box-shadow:2px 2px 0 #2c3e50f5;content:"";height:14px;left:50%;position:absolute;transform:translateX(-50%) rotate(45deg);width:14px;z-index:-1}.detail-game-user-dot{animation:detail-user-pulse 1.45s ease-in-out infinite;background:radial-gradient(circle at 34% 28%,#fffffff2 0 16%,#0000 17%),linear-gradient(145deg,#32d9d3,#1e90ff);border:3px solid #fff;border-radius:50%;box-shadow:0 0 0 2px #2c3e50f5,0 0 20px #1e90ffd9;height:22px;width:22px}.detail-game-popup .leaflet-popup-content-wrapper{background:#fff9dd!important;border:2px solid #2c3e50!important;border-radius:14px!important;box-shadow:0 6px 0 #2c3e5080!important}.detail-game-popup .leaflet-popup-tip{background:#fff9dd!important;box-shadow:2px 2px 0 #2c3e5066!important}.location-detail-my-location-btn{align-items:center;background:#fff;border:3px solid #2c3e50;border-radius:50%;bottom:14px;box-shadow:0 5px 0 #2c3e50,0 10px 20px #2c3e502e;cursor:pointer;display:flex;height:46px;justify-content:center;position:absolute;right:14px;transition:transform .12s ease,box-shadow .12s ease;width:46px;z-index:4}.location-detail-my-location-btn:hover{transform:translateY(-2px)}.location-detail-my-location-btn:active{box-shadow:0 2px 0 #2c3e50,0 7px 14px #2c3e5029;transform:translateY(3px)}.location-detail-directions-btn{align-items:center;background:#fff;border:3px solid #2c3e50;border-radius:50%;box-shadow:0 5px 0 #2c3e50,0 10px 20px #2c3e502e;cursor:pointer;display:flex;height:46px;justify-content:center;position:absolute;right:14px;top:14px;transition:transform .12s ease,box-shadow .12s ease;width:46px;z-index:4}.location-detail-directions-btn:hover{background:#f8cb2e;transform:translateY(-2px)}.location-detail-directions-btn:active{box-shadow:0 2px 0 #2c3e50,0 7px 14px #2c3e5029;transform:translateY(3px)}.location-detail-map-wrapper .leaflet-control-zoom{border:2px solid #2c3e50!important;border-radius:14px!important;box-shadow:0 4px 0 #2c3e50bf;overflow:hidden}.location-detail-map-wrapper .leaflet-control-zoom a{background:#fffef5!important;border-radius:0!important;color:#2c3e50!important;font-weight:950}.location-detail-map-wrapper .leaflet-control-zoom a:hover{background:#ffd32d!important}.location-detail-map-wrapper .leaflet-control-attribution{background:#1a2636c7!important;border-top-left-radius:8px!important;color:#dff2ff!important}.location-detail-map-wrapper .leaflet-control-attribution a{color:#f8cb2e!important}@keyframes detail-user-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.18)}}.treasure-overlay{align-items:center;animation:fadeInOverlay .3s forwards;background:#000000d9;bottom:0;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center;left:0;padding:calc(16px + env(safe-area-inset-top, 0px)) 16px calc(16px + env(safe-area-inset-bottom, 0px));pointer-events:auto;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.treasure-chest{align-items:center;display:flex;font-size:100px;justify-content:center;margin-bottom:20px;position:relative}.treasure-chest.shaking .chest-emoji{animation:intenseShake .4s infinite}.treasure-chest.open .chest-emoji{animation:popOpenChest .6s cubic-bezier(.175,.885,.32,1.275) forwards;text-shadow:0 0 40px #ffd700cc}@keyframes intenseShake{0%{transform:rotate(-10deg) scale(1)}25%{transform:rotate(10deg) scale(1.1)}50%{transform:rotate(-10deg) scale(1)}75%{transform:rotate(10deg) scale(1.1)}to{transform:rotate(-10deg) scale(1)}}@keyframes popOpenChest{0%{opacity:0;transform:scale(.5)}50%{opacity:1;transform:scale(1.5) translateY(-20px)}to{opacity:1;transform:scale(1.2) translateY(0)}}.reward-text{color:#fff;font-family:sans-serif;opacity:0;text-align:center}.reward-text p{font-size:18px;margin:5px 0}.reward-text .location-name{color:#4cd137;font-size:22px;font-weight:700;margin-bottom:15px}.reward-text .points-earned{-webkit-text-fill-color:#0000;animation:floatUp 2s ease-out forwards;background:linear-gradient(135deg,#fbc531,#e1b12c);-webkit-background-clip:text;color:#fbc531;font-size:36px;font-weight:900;text-shadow:0 4px 10px #fbc53180}.reward-text.show{animation:slideUpFade .6s ease-out forwards}@keyframes slideUpFade{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes floatUp{0%{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1.1)}to{transform:translateY(-20px) scale(1)}}.location-detail-container{background-color:#f8f9fb;display:flex;flex-direction:column;font-family:Inter,sans-serif;height:100%;overflow-y:auto;position:relative}.detail-banner{background-position:50%;background-size:cover;flex-shrink:0;height:280px;position:relative;width:100%}.detail-banner--empty{background:linear-gradient(145deg,#dbeafe,#ecfeff)}.detail-banner-image{height:100%;inset:0;object-fit:cover;position:absolute;width:100%}.detail-banner-placeholder{align-items:center;color:#52708f;display:flex;flex-direction:column;gap:7px;inset:0;justify-content:center;padding:64px 40px 30px;pointer-events:none;position:absolute;text-align:center}.detail-banner-placeholder i{color:#0abde3;font-size:32px}.detail-banner-placeholder strong{font-size:18px}.detail-banner-placeholder span{font-size:12px}.banner-overlay{display:flex;justify-content:space-between;padding:calc(12px + env(safe-area-inset-top, 0px)) calc(16px + env(safe-area-inset-right, 0px)) 12px calc(16px + env(safe-area-inset-left, 0px));position:relative;z-index:4}.banner-btn{align-items:center;background-color:#fff;border:2.5px solid var(--game-border-color);border-radius:50%;box-shadow:0 3px 0 var(--game-border-color);color:var(--game-border-color);cursor:pointer;display:flex;font-size:16px;justify-content:center;min-height:44px;min-width:44px;transition:transform .1s ease,box-shadow .1s ease}.banner-btn:active{box-shadow:none;transform:translateY(3px)}.external-image-credit{background:#0000009e;border-radius:6px;bottom:8px;color:#fff;font-size:9px;line-height:1.3;max-width:calc(100% - 16px);overflow:hidden;padding:4px 7px;position:absolute;right:8px;text-decoration:none;text-overflow:ellipsis;white-space:nowrap;z-index:3}.external-image-credit.with-thumbnails{bottom:58px}.fav-btn.active{background:#fff1f2;color:#e74c3c}.banner-btn:disabled{cursor:wait;opacity:.65}.detail-content{background-color:#fff;border:var(--game-border-width) solid var(--game-border-color);border-bottom:none;border-top-left-radius:28px;border-top-right-radius:28px;flex:1 1;margin-top:-24px;padding:24px 20px 20px;position:relative;z-index:2}.header-info{margin-bottom:15px}.loc-title{color:#2c2c2c;font-size:26px;font-weight:800;margin:0 0 10px}.loc-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.loc-address{color:#6a6a6a;font-weight:600;margin-right:auto}.loc-address,.loc-rating{align-items:center;display:flex;font-size:15px}.loc-rating{color:#333;font-weight:700}.loc-rating-star{color:#f39c12;margin-right:4px}.loc-rating-count{color:#888;font-size:12px;margin-left:4px}.loc-match-score{align-items:center;background:#e8f7ff;border-radius:999px;color:#087ba5;display:inline-flex;flex-shrink:0;font-size:11px;font-weight:800;gap:5px;padding:4px 8px}.desc-section{margin-bottom:20px}.loc-desc{color:#4a4a4a;font-size:14px;line-height:1.5;margin:0}.read-more{color:#2c2c2c;cursor:pointer;font-weight:700}.btn-directions{align-items:center;background-color:var(--game-blue);border:var(--game-border-width) solid var(--game-border-color);border-radius:16px;box-shadow:0 4px 0 var(--game-border-color);color:#fff;cursor:pointer;display:inline-flex;font-size:13px;font-weight:800;margin-bottom:25px;min-height:44px;padding:8px 16px;text-transform:uppercase;transition:transform .1s ease,box-shadow .1s ease}.btn-directions:active{box-shadow:none;transform:translateY(4px)}.section{margin-bottom:25px}.section-title{color:#1a1a1a;font-size:18px;font-weight:800;margin:0 0 15px}.luxuries-list{display:flex;gap:15px}.luxury-item{align-items:center;background-color:#f7f8fa;border-radius:20px;box-shadow:0 2px 5px #00000005;color:#333;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 15px}.luxury-item.active{background-color:#e8f0fe;color:#333}.lux-icon{font-size:14px}.review-card{background-color:#f5f5f5;border:2px solid var(--game-border-color);border-radius:16px;box-shadow:0 3px 0 var(--game-border-color);margin-bottom:10px;padding:12px 14px}.review-header{align-items:center;display:flex;margin-bottom:10px}.reviewer-avatar{border-radius:50%;height:40px;margin-right:12px;object-fit:cover;width:40px}.reviewer-info{flex:1 1}.reviewer-name{color:#333;font-size:15px;margin:0 0 3px}.review-meta{align-items:center;display:flex;font-size:12px;gap:8px}.stars{color:#f39c12;letter-spacing:2px}.review-time{color:#888}.btn-options{background:none;border:none;color:#333;cursor:pointer;padding:5px}.review-text{color:#666;font-size:13px;line-height:1.5;margin:0}.bottom-fixed-bar{background:var(--st-surface);box-sizing:border-box;display:flex;flex-shrink:0;justify-content:center;padding:12px 16px calc(12px + env(safe-area-inset-bottom, 0px));position:static;width:100%}.btn-write-review{background-color:var(--game-orange);border:var(--game-border-width) solid var(--game-border-color);border-radius:16px;box-shadow:0 4px 0 var(--game-border-color);color:#fff;cursor:pointer;font-size:15px;font-weight:800;min-height:44px;padding:12px;text-transform:uppercase;transition:transform .1s ease,box-shadow .1s ease;width:100%}.btn-write-review:active{box-shadow:none;transform:translateY(4px)}.map-overlay-backdrop{align-items:flex-end;animation:fadeInBackdrop .25s ease;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#0000008c;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}@keyframes fadeInBackdrop{0%{opacity:0}to{opacity:1}}.map-overlay-sheet{animation:slideUpSheet .3s cubic-bezier(.34,1.56,.64,1);background:#fff;border:var(--game-border-width) solid var(--game-border-color);border-bottom:none;border-top-left-radius:24px;border-top-right-radius:24px;box-shadow:0 -4px 30px #00000040;max-width:480px;overflow:hidden;width:100%}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}.map-overlay-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:16px 20px 12px}.map-overlay-title{color:#2c3e50;font-weight:700;gap:8px}.map-overlay-close,.map-overlay-title{align-items:center;display:flex;font-size:16px}.map-overlay-close{background:#f0f0f0;border:none;border-radius:50%;color:#555;cursor:pointer;height:32px;justify-content:center;width:32px}.map-overlay-close:hover{background:#e0e0e0}.map-overlay-footer{display:flex;gap:10px;padding:12px 20px}.map-open-btn{align-items:center;background:linear-gradient(135deg,var(--game-blue),var(--game-blue-dark));border:2.5px solid var(--game-border-color);border-radius:12px;box-shadow:0 3px 0 var(--game-border-color);color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:800;gap:8px;justify-content:center;padding:12px}.map-open-btn:active{box-shadow:none;transform:translateY(3px)}.ambassador-section{background-color:var(--st-surface-muted)!important;border:2.5px solid var(--game-border-color)!important;border-radius:16px!important;box-shadow:0 4px 0 var(--game-border-color)!important;margin-bottom:20px!important;padding:12px!important}.ambassador-title{align-items:center;color:var(--st-text)!important;display:flex;font-size:15px;font-weight:700;gap:6px;margin:0 0 10px}.ambassador-item{align-items:center;background-color:var(--st-surface);border:2px solid var(--game-border-color);border-radius:12px;box-shadow:0 2px 0 var(--game-border-color);display:flex;justify-content:space-between;padding:8px 10px}.ambassador-avatar{border:1.5px solid var(--game-border-color);border-radius:50%;height:32px;width:32px}.ambassador-name{color:var(--st-text);font-size:13px;font-weight:700}.ambassador-count{background-color:var(--st-surface-muted);border:1px solid var(--st-border);border-radius:8px;color:var(--st-primary);font-size:11px;font-weight:700;padding:3px 8px}.rating-summary-box{align-items:center;background:linear-gradient(135deg,#fff9f01a,#fff3e026);background-color:var(--st-surface-muted);border:2px solid var(--game-border-color);border-radius:16px;box-shadow:0 3px 0 var(--game-border-color);display:flex;gap:16px;margin-bottom:16px;padding:14px 18px}.review-modal-overlay{align-items:flex-end;animation:fadeInBackdrop .2s ease;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;position:fixed;z-index:1200}.review-modal-sheet{animation:slideUpSheet .25s cubic-bezier(.34,1.56,.64,1);background-color:var(--st-surface);border:var(--game-border-width) solid var(--game-border-color);border-bottom:none;border-top-left-radius:24px;border-top-right-radius:24px;box-shadow:0 -5px 25px #00000059;box-sizing:border-box;color:var(--st-text);max-height:calc(100% - env(safe-area-inset-top, 0px) - 12px);overflow-y:auto;padding:24px 20px calc(20px + env(safe-area-inset-bottom, 0px));width:100%}.review-modal-title{color:var(--st-text);font-size:18px;font-weight:800;margin:0 0 16px}.review-textarea{border:2px solid var(--game-border-color);border-radius:12px;box-sizing:border-box;font-family:inherit;margin-bottom:14px;outline:none;padding:10px 12px;resize:none;width:100%}.btn-modal-cancel,.review-textarea{background-color:var(--st-surface-muted);color:var(--st-text);font-size:14px}.btn-modal-cancel{border:2.5px solid var(--game-border-color);border-radius:14px;box-shadow:0 3px 0 var(--game-border-color);cursor:pointer;flex:1 1;font-weight:800;padding:12px 0;transition:transform .1s,box-shadow .1s}.btn-modal-cancel:active{box-shadow:none;transform:translateY(3px)}.btn-modal-submit{background-color:var(--game-green);border:2.5px solid var(--game-border-color);border-radius:14px;box-shadow:0 3px 0 var(--game-border-color);color:#fff;cursor:pointer;flex:2 1;font-size:14px;font-weight:800;padding:12px 0;transition:transform .1s,box-shadow .1s}.btn-modal-submit:active:not(:disabled){box-shadow:none;transform:translateY(3px)}.btn-modal-submit:disabled{background-color:var(--st-border);box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.thumbnail-strip{bottom:8px;display:flex;gap:6px;justify-content:center;left:0;padding:0 12px;position:absolute;right:0;z-index:3}.thumbnail-item{background-position:50%;background-size:cover;border:1px solid #ffffff80;border-radius:8px;cursor:pointer;flex-shrink:0;height:42px;transition:border-color .15s ease;width:42px}.thumbnail-item.active{border:2px solid #fff}.loc-info-row{color:#636e72;display:flex;flex-direction:column;font-size:13px;gap:4px;margin-bottom:12px}.loc-info-icon{margin-right:6px}.loc-info-icon--blue{color:#0abde3}.loc-info-icon--green{color:#00b894}.section-loading-text{color:#7f8c8d;font-size:12px;padding:10px;text-align:center}.section-empty-text{color:#747d8c;font-size:12px;font-weight:700;padding:12px 0;text-align:center}.section-empty-sub{color:#95a5a6;font-size:10px;font-weight:400;margin-top:4px}.ambassador-list{display:flex;flex-direction:column;gap:8px}.ambassador-item-left{align-items:center;display:flex;gap:10px}.ambassador-medal{font-size:16px;font-weight:700}.section--reviews{padding-bottom:0}.reviews-list{display:flex;flex-direction:column;gap:10px}.rating-summary-left{text-align:center}.rating-big-number{color:#f39c12;font-size:36px;font-weight:900;line-height:1}.rating-count-label{color:#888;font-size:11px;margin-top:2px}.rating-bars{flex:1 1}.rating-bar-row{align-items:center;display:flex;gap:6px;margin-bottom:3px}.rating-bar-label{color:#888;font-size:11px;width:8px}.rating-bar-star{color:#f39c12;font-size:11px}.rating-bar-track{background:#f0f0f0;border-radius:3px;flex:1 1;height:6px;overflow:hidden}.rating-bar-fill{background:#f39c12;border-radius:3px;height:100%}.rating-bar-count{color:#888;font-size:10px;width:16px}.submit-msg{font-size:13px;margin-top:8px;text-align:center}.submit-msg--success{color:#00b894}.submit-msg--error{color:#e17055}.star-picker{display:flex;gap:8px;justify-content:center;margin-bottom:16px}.star-picker-btn{background:none;border:none;color:#f39c12;cursor:pointer;font-size:32px;opacity:.3;padding:4px;transition:opacity .15s}.star-picker-btn.active{opacity:1}.modal-actions{display:flex;gap:10px}body.dark-theme .location-detail-container{background-color:var(--st-bg);color:var(--st-text)}body.dark-theme .detail-content{background-color:var(--st-surface);border-color:var(--game-border-color)}body.dark-theme .loc-title{color:var(--st-text)}body.dark-theme .loc-address{color:var(--st-text-muted)}body.dark-theme .loc-rating{color:var(--st-text)}body.dark-theme .loc-rating-count{color:var(--st-text-muted)}body.dark-theme .detail-banner--empty{background:linear-gradient(145deg,#17243a,#193c48)}body.dark-theme .detail-banner-placeholder{color:var(--st-text-muted)}body.dark-theme .loc-match-score{background:#173c4c;color:#72d7f7}body.dark-theme .loc-desc,body.dark-theme .loc-info-row{color:var(--st-text-muted)}body.dark-theme .section-title{color:var(--st-text)}body.dark-theme .section-empty-sub,body.dark-theme .section-empty-text,body.dark-theme .section-loading-text{color:var(--st-text-muted)}body.dark-theme .reviewer-name{color:var(--st-text)}body.dark-theme .review-text,body.dark-theme .review-time{color:var(--st-text-muted)}body.dark-theme .review-card{background-color:var(--st-surface-muted);border-color:var(--game-border-color)}body.dark-theme .rating-big-number{color:#f39c12}body.dark-theme .rating-bar-label,body.dark-theme .rating-count-label{color:var(--st-text-muted)}body.dark-theme .rating-bar-track{background:var(--st-border)}body.dark-theme .rating-bar-count{color:var(--st-text-muted)}body.dark-theme .banner-btn{background-color:var(--st-surface);color:var(--st-text)}body.dark-theme .bottom-fixed-bar{background:var(--st-surface)}body.dark-theme .map-overlay-sheet{background-color:var(--st-surface);border-color:var(--game-border-color);color:var(--st-text)}body.dark-theme .map-overlay-header{border-bottom-color:var(--st-border)}body.dark-theme .map-overlay-title{color:var(--st-text)}body.dark-theme .map-overlay-close{background:var(--st-surface-muted);color:var(--st-text)}.admin-moderation-container{background:#eef2f6;box-sizing:border-box;color:#0f172a;display:flex;flex-direction:column;font-family:Inter,Be Vietnam Pro,Arial,sans-serif;height:100%;max-width:100%;overflow:hidden;width:100%}.admin-moderation-container *,.admin-moderation-container :after,.admin-moderation-container :before{box-sizing:border-box}.admin-topbar{grid-gap:10px;align-items:center;background:#fff;border-bottom:1px solid #dbe3ec;display:grid;flex-shrink:0;gap:10px;grid-template-columns:40px minmax(0,1fr) 40px;min-height:calc(64px + env(safe-area-inset-top, 0px));padding:calc(10px + env(safe-area-inset-top, 0px)) calc(12px + env(safe-area-inset-right, 0px)) 10px calc(12px + env(safe-area-inset-left, 0px))}.admin-title-block{min-width:0}.admin-title-block h1{font-size:20px;letter-spacing:0;line-height:1.1;margin:0;white-space:nowrap}.admin-title-block p{align-items:center;color:#b91c1c;display:flex;font-size:11px;font-weight:900;gap:6px;margin:0 0 3px;text-transform:uppercase}.admin-operator-card span,.admin-title-block>span{color:#64748b;font-size:12px;font-weight:700}.admin-operator-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:none;flex-direction:column;gap:2px;justify-self:end;min-width:0;padding:8px 10px}.admin-operator-card strong{color:#0f172a;font-size:13px;max-width:210px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-back-btn,.admin-modal-header button,.admin-refresh-btn{align-items:center;background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;cursor:pointer;display:inline-flex;height:38px;justify-content:center;transition:border-color .18s ease,background .18s ease,color .18s ease,transform .18s ease;width:38px}.admin-back-btn:hover,.admin-modal-header button:hover,.admin-refresh-btn:hover{background:#eff6ff;border-color:#2563eb;color:#1d4ed8}.admin-refresh-btn:disabled{cursor:not-allowed;opacity:.55}.admin-scroll-shell{min-width:0;position:relative}.admin-tabs-shell{background:#fff;border-bottom:1px solid #dbe3ec;flex-shrink:0}.admin-tabs-row{-webkit-overflow-scrolling:touch;background:#fff;display:flex;flex-shrink:0;gap:8px;justify-content:space-between;overflow-x:auto;overscroll-behavior-x:contain;padding:10px calc(14px + env(safe-area-inset-right, 0px)) 8px calc(14px + env(safe-area-inset-left, 0px));scroll-behavior:smooth;scroll-snap-type:x proximity;scrollbar-width:none;touch-action:pan-x;width:100%}.admin-summary-grid::-webkit-scrollbar,.admin-tabs-row::-webkit-scrollbar{display:none}.admin-tabs-row button{align-items:center;background:#fff;border:1px solid #d6dee8;border-radius:8px;color:#475569;cursor:pointer;display:inline-flex;font-size:13px;font-weight:800;gap:7px;height:42px;justify-content:center;min-height:42px;min-width:54px;padding:0;position:relative;scroll-snap-align:center;transition:border-color .18s ease,background .18s ease,color .18s ease,box-shadow .18s ease;white-space:nowrap;width:54px}.admin-tabs-row button.active{background:#eff6ff;border-color:#2563eb;box-shadow:inset 0 -2px 0 #2563eb;color:#1d4ed8}.admin-tab-count{align-items:center;background:#e2e8f0;border-radius:999px;color:#334155;display:inline-flex;font-size:10px;font-weight:900;height:20px;justify-content:center;min-width:20px;padding:0 6px;position:absolute;right:-5px;top:-7px}.admin-tabs-row button.active .admin-tab-count{background:#dbeafe;color:#1d4ed8}.admin-content-body{-webkit-overflow-scrolling:touch;display:flex;flex:1 1;flex-direction:column;gap:12px;min-height:0;overflow-x:hidden;overflow-y:auto;overscroll-behavior-y:contain;padding:14px calc(14px + env(safe-area-inset-right, 0px)) calc(14px + env(safe-area-inset-bottom, 0px)) calc(14px + env(safe-area-inset-left, 0px));scroll-padding-bottom:calc(18px + env(safe-area-inset-bottom, 0px));scrollbar-width:thin}.admin-overview-panel{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #cbd5e1;border-radius:8px;box-shadow:0 10px 25px #0f172a0d;color:#0f172a;display:flex;flex-shrink:0;gap:12px;min-height:82px;overflow:hidden;padding:14px;position:relative}.admin-overview-copy{align-items:center;display:flex;gap:10px;min-width:0}.admin-overview-copy h2,.admin-overview-copy p,.admin-overview-copy small{margin:0}.admin-overview-copy p{color:#2563eb;font-size:12px;font-weight:900;text-transform:uppercase}.admin-overview-copy h2{font-size:23px;line-height:1.1;overflow-wrap:anywhere}.admin-overview-copy small{color:#64748b;display:block;font-size:12px;font-weight:700;margin-top:6px}.admin-overview-icon{background:#dbeafe;flex-shrink:0;height:38px;width:38px}.admin-item-icon,.admin-overview-icon,.admin-stat-icon,.admin-user-avatar{align-items:center;border-radius:8px;color:#1d4ed8;display:inline-flex;justify-content:center}.admin-item-icon,.admin-stat-icon,.admin-user-avatar{background:#eff6ff;height:32px;width:32px}.admin-list-item:nth-child(2n) .admin-item-icon{background:#ecfdf5;color:#047857}.admin-message{border-radius:8px;font-size:13px;font-weight:800;padding:11px 12px}.admin-message.error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.admin-message.success{background:#ecfdf5;border:1px solid #bbf7d0;color:#047857}.admin-empty,.admin-loading{align-items:center;background:#fff;border:1px dashed #cbd5e1;border-radius:8px;color:#64748b;display:flex;flex-direction:column;font-weight:800;gap:10px;justify-content:center;min-height:220px;text-align:center}.admin-empty p{line-height:1.4;margin:0;padding:0 12px}.admin-list,.admin-stack{display:flex;flex-direction:column;gap:12px;min-height:0}.admin-inline-form,.admin-list-item,.admin-panel,.admin-report-row,.admin-stat-card,.admin-user-row{background:#fff;border:1px solid #dbe3ec;border-radius:8px;box-shadow:0 10px 24px #0f172a0d}.admin-list-item{grid-gap:12px;align-items:center;color:#0f172a;cursor:pointer;display:grid;gap:12px;grid-template-columns:36px minmax(0,1fr) auto;min-width:0;padding:12px;text-align:left;transition:border-color .18s ease,background .18s ease,transform .18s ease;width:100%}.admin-list-item:hover{background:#fbfdff;border-color:#93c5fd;transform:translateY(-1px)}.admin-list-copy,.admin-report-row div,.admin-user-row div:nth-child(2){display:flex;flex-direction:column;gap:4px;min-width:0}.admin-list-item strong,.admin-report-row strong,.admin-user-row strong{font-size:14px;line-height:1.25;overflow-wrap:anywhere}.admin-list-item small,.admin-list-meta,.admin-report-row small,.admin-user-row small{color:#64748b;font-size:12px;line-height:1.35;overflow-wrap:anywhere}.admin-list-meta{font-weight:700;max-width:190px;text-align:right}.admin-role-pill,.admin-status-pill{align-items:center;background:#fef3c7;border-radius:999px;color:#92400e;display:inline-flex;font-size:11px;font-weight:900;justify-content:center;min-height:28px;padding:0 10px;text-transform:uppercase;white-space:nowrap}.admin-role-pill{background:#e0f2fe;color:#0369a1}.admin-role-pill.locked{background:#ffe4e6;color:#be123c}.admin-panel{display:flex;flex-direction:column;gap:16px;padding:18px}.admin-panel-header{align-items:flex-start;border-bottom:1px solid #e2e8f0;display:flex;gap:12px;justify-content:space-between;min-width:0;padding-bottom:14px}.admin-panel-header p{color:#64748b;font-size:12px;font-weight:900;margin:0 0 4px;text-transform:uppercase}.admin-panel-header h2{font-size:20px;line-height:1.2;margin:0;overflow-wrap:anywhere}.admin-fields-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.admin-field{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:5px;min-width:0;padding:12px}.admin-field span{color:#64748b;font-size:12px;font-weight:800}.admin-field strong{color:#0f172a;font-size:14px;word-break:break-word}.admin-action-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.admin-danger-btn,.admin-primary-btn,.admin-secondary-btn{align-items:center;border-radius:8px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:900;gap:6px;justify-content:center;min-height:38px;padding:0 12px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease}.admin-primary-btn{background:#2563eb;border:1px solid #1d4ed8;box-shadow:0 8px 18px #2563eb2e;color:#fff}.admin-danger-btn{background:#e11d48;border:1px solid #be123c;box-shadow:0 8px 18px #e11d4829;color:#fff}.admin-secondary-btn{background:#fff;border:1px solid #cbd5e1;color:#0f172a}.admin-danger-btn:hover,.admin-primary-btn:hover,.admin-secondary-btn:hover{transform:translateY(-1px)}.admin-danger-btn:disabled,.admin-primary-btn:disabled,.admin-secondary-btn:disabled{cursor:not-allowed;opacity:.62;transform:none}.admin-warning-box{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;color:#92400e;display:flex;gap:10px;padding:12px}.admin-warning-box p,.admin-warning-box strong{font-size:13px;line-height:1.45;margin:0}.admin-toolbar{display:flex;justify-content:space-between}.admin-search{align-items:center;background:#fff;border:1px solid #cbd5e1;border-radius:8px;box-shadow:0 8px 20px #0f172a0a;display:flex;gap:8px;min-height:42px;padding:0 11px;width:min(100%,440px)}.admin-search input{border:none;color:#0f172a;flex:1 1;font-size:14px;min-width:0;outline:none}.admin-search input::placeholder{color:#94a3b8}.admin-inline-form{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:minmax(0,1fr) 140px auto auto;padding:12px}.admin-inline-form strong{min-width:0;overflow-wrap:anywhere}.admin-inline-form input{border:1px solid #cbd5e1;border-radius:8px;min-height:38px;min-width:0;padding:0 10px;width:100%}.admin-user-row{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:34px minmax(0,1fr) auto auto;min-width:0;padding:12px}.admin-user-avatar{background:#f1f5f9;color:#334155}.admin-icon-action-btn{align-items:center;background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;cursor:pointer;display:inline-flex;height:38px;justify-content:center;width:38px}.admin-action-menu{display:flex;flex-direction:column;gap:10px}.admin-action-menu button{grid-gap:10px;align-items:center;background:#fff;border:1px solid #dbe3ec;border-radius:8px;color:#0f172a;cursor:pointer;display:grid;gap:10px;grid-template-columns:34px minmax(0,1fr);min-height:58px;padding:10px;text-align:left;width:100%}.admin-action-menu button>svg{background:#eff6ff;border-radius:8px;color:#1d4ed8;height:34px;padding:8px;width:34px}.admin-action-form label,.admin-action-menu span{display:flex;flex-direction:column;gap:3px;min-width:0}.admin-action-menu strong{font-size:14px}.admin-action-menu small{color:#64748b;font-size:12px}.admin-user-action-modal .admin-modal-header>div{min-width:0}.admin-user-action-modal .admin-modal-header h3{overflow-wrap:anywhere}.admin-user-action-modal .admin-modal-header span{color:#64748b;font-size:12px;font-weight:700;overflow-wrap:anywhere}.admin-action-form{display:flex;flex-direction:column;gap:12px}.admin-current-points{align-items:center;background:#f8fafc;border:1px solid #dbe3ec;border-radius:8px;display:flex;gap:12px;justify-content:space-between;min-height:54px;padding:10px 12px}.admin-current-points span{color:#64748b;font-size:12px;font-weight:800}.admin-current-points strong{color:#0f172a;font-size:24px;line-height:1}.admin-action-form label>span{color:#64748b;font-size:12px;font-weight:800}.admin-action-form input{border:1px solid #cbd5e1;border-radius:8px;font:inherit;min-height:40px;padding:0 11px;width:100%}.admin-stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.admin-stat-card{display:flex;flex-direction:column;gap:8px;min-height:132px;overflow:hidden;padding:14px;position:relative}.admin-stat-card:before{background:#2563eb;content:"";height:4px;inset:0 0 auto;position:absolute}.admin-stat-card:nth-child(2):before{background:#16a34a}.admin-stat-card:nth-child(3):before{background:#f59e0b}.admin-stat-card:nth-child(4):before{background:#e11d48}.admin-stat-card>span:not(.admin-stat-icon){color:#64748b;font-size:12px;font-weight:900}.admin-stat-card strong{font-size:28px;line-height:1;margin-top:auto}.admin-report-row{display:flex;flex-direction:column;gap:12px;padding:14px}.admin-report-row p{color:#334155;font-size:13px;line-height:1.45;margin:6px 0 0;overflow-wrap:anywhere}.admin-modal-overlay{align-items:center;background:#0f172a7a;display:flex;inset:0;justify-content:center;padding:20px;position:absolute;z-index:50}.admin-modal{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 24px 60px #0f172a42;display:flex;flex-direction:column;gap:14px;padding:18px;width:min(100%,480px)}.admin-modal-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.admin-modal h3,.admin-modal p{margin:0}.admin-modal h3{font-size:18px}.admin-modal p{color:#475569;line-height:1.45}.admin-modal textarea{border:1px solid #cbd5e1;border-radius:8px;font:inherit;min-height:110px;padding:10px;resize:vertical}@media (max-width:900px){.admin-topbar{grid-template-columns:40px minmax(0,1fr) 40px}.admin-operator-card{display:none}.admin-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:720px){.admin-topbar{gap:10px;min-height:calc(64px + env(safe-area-inset-top, 0px));padding:calc(10px + env(safe-area-inset-top, 0px)) calc(12px + env(safe-area-inset-right, 0px)) 10px calc(12px + env(safe-area-inset-left, 0px))}.admin-title-block h1{font-size:20px}.admin-title-block>span{display:none}.admin-tabs-row{padding:10px calc(14px + env(safe-area-inset-right, 0px)) 8px calc(14px + env(safe-area-inset-left, 0px))}.admin-content-body{gap:12px;padding:14px calc(14px + env(safe-area-inset-right, 0px)) calc(14px + env(safe-area-inset-bottom, 0px)) calc(14px + env(safe-area-inset-left, 0px))}.admin-overview-panel{grid-template-columns:minmax(0,1fr) auto;min-height:82px;padding:14px}.admin-overview-copy{align-items:center}.admin-overview-copy h2{font-size:22px}.admin-queue-card{flex-direction:column;justify-content:center;min-height:56px;padding:0;width:82px}.admin-queue-card strong{font-size:26px}.admin-list-item{grid-template-columns:38px minmax(0,1fr)}.admin-list-meta,.admin-status-pill{grid-column:2;justify-self:start;max-width:100%;text-align:left}.admin-fields-grid,.admin-inline-form,.admin-report-row{grid-template-columns:1fr}.admin-role-pill{justify-self:start}.admin-panel-header{align-items:stretch;flex-direction:column}}@media (max-width:380px){.admin-content-body{padding:12px calc(12px + env(safe-area-inset-right, 0px)) calc(12px + env(safe-area-inset-bottom, 0px)) calc(12px + env(safe-area-inset-left, 0px))}.admin-stats-grid{grid-template-columns:1fr}.admin-summary-card{min-height:80px}}.admin-report-row .admin-action-row{display:flex!important;flex-direction:row!important;gap:8px!important;justify-content:flex-end!important;width:100%!important}.admin-report-row .admin-action-row .admin-danger-btn{flex:none!important;font-size:13px!important;min-height:36px!important;padding:0 12px!important;width:auto!important}.admin-report-row .ticket-badge-group{align-items:center;display:flex;gap:8px;margin-bottom:8px;margin-top:4px}.admin-report-row .feedback-type-badge{border-radius:6px;font-size:11px;font-weight:700;padding:3px 8px;text-transform:uppercase}.admin-report-row .feedback-type-badge.bug{background:#fee2e2;color:#ef4444}.admin-report-row .feedback-type-badge.suggestion{background:#dbeafe;color:#3b82f6}.admin-report-row .feedback-type-badge.report{background:#f3e8ff;color:#a855f7}.admin-report-row .feedback-status-badge{border-radius:6px;font-size:11px;font-weight:800;padding:3px 8px;text-transform:uppercase}.admin-report-row .feedback-status-badge.pending{background:#fef3c7;color:#d97706}.admin-report-row .feedback-status-badge.processing{background:#e0f2fe;color:#0284c7}.admin-report-row .feedback-status-badge.resolved{background:#dcfce7;color:#16a34a}.feedback-item-card{display:flex;flex-direction:column;gap:12px;padding:16px}.feedback-card-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;gap:10px;justify-content:space-between;padding-bottom:8px}.feedback-type-badge{border-radius:6px;font-size:11px;font-weight:800;padding:4px 10px;text-transform:uppercase}.feedback-type-badge.bug{background:#ffe4e6;color:#e11d48}.feedback-type-badge.suggestion{background:#e0f2fe;color:#0284c7}.feedback-status-badge{border-radius:6px;font-size:11px;font-weight:800;padding:4px 10px;text-transform:uppercase}.feedback-status-badge.pending{background:#fef3c7;color:#d97706}.feedback-status-badge.processing{background:#dbeafe;color:#2563eb}.feedback-status-badge.resolved{background:#dcfce7;color:#16a34a}.feedback-card-content{min-height:40px}.feedback-text{color:#1e293b;font-size:14px;font-weight:500;line-height:1.5;margin:0;word-break:break-word}.feedback-card-footer{align-items:flex-end;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding-top:10px}.feedback-user-info{display:flex;flex-direction:column;gap:4px;min-width:150px}.feedback-user-info strong{color:#334155;font-size:13px}.feedback-user-info small{color:#64748b;font-size:11px}.feedback-actions{display:flex;gap:8px}.feedback-btn{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:12px;font-weight:700;min-height:32px;padding:0 12px;transition:background .15s ease,transform .15s ease}.feedback-btn:hover{transform:translateY(-1px)}.feedback-btn.btn-processing{background:#2563eb;border-color:#1d4ed8;color:#fff}.feedback-btn.btn-resolved{background:#16a34a;border-color:#15803d;color:#fff}.feedback-btn.btn-pending{background:#f59e0b;border-color:#d97706;color:#fff}.feedback-btn.btn-reopen{background:#fff;border-color:#cbd5e1;color:#475569}@media (max-width:600px){.feedback-card-footer{align-items:stretch;flex-direction:column}.feedback-actions{justify-content:flex-end}}.audio-control-btn{align-items:center;border:2px solid #2c3e50;border-radius:50%;box-shadow:0 4px 0 #2c3e50;cursor:pointer;display:flex;height:44px;justify-content:center;left:20px;position:absolute;top:calc(20px + env(safe-area-inset-top, 0px));transition:all .2s ease;width:44px;z-index:9999}.audio-control-btn:active{box-shadow:0 0 0 #2c3e50;transform:translateY(4px)}.audio-control-btn.on{background-color:#2ed573;color:#2c3e50}.audio-control-btn.off{background-color:#ff4757;color:#fff}