.toast-container{position:fixed;top:80px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:16px 24px;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:10001;animation:toastSlideIn .3s ease-out;min-width:280px;max-width:90vw;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes toastSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.toast-icon-wrapper{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#fff3;border:2px solid rgba(255,255,255,.3)}.toast-icon-svg{font-size:20px;color:#fff}.toast-message{font-size:16px;font-weight:600;line-height:1.5;flex:1}.toast-container.info{background:linear-gradient(135deg,#2563ebf2,#1d4ed8f2);color:#fff;border:1px solid rgba(255,255,255,.2)}.toast-container.success{background:linear-gradient(135deg,#22c55ef2,#16a34af2);color:#fff;border:1px solid rgba(255,255,255,.2)}.toast-container.warning{background:linear-gradient(135deg,#f59e0bf2,#d97706f2);color:#fff;border:1px solid rgba(255,255,255,.2)}.toast-container.error{background:linear-gradient(135deg,#ef4444f2,#dc2626f2);color:#fff;border:1px solid rgba(255,255,255,.2)}@media (max-width: 480px){.toast-container{top:70px;min-width:260px;padding:14px 20px}.toast-icon-wrapper{width:36px;height:36px}.toast-icon-svg{font-size:18px}.toast-message{font-size:15px}}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;display:flex;justify-content:center;align-items:center;z-index:10000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-content{background:#fff;border-radius:24px;padding:32px;max-width:320px;width:90%;text-align:center;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-icon{font-size:48px;margin-bottom:16px}.modal-content h3{margin:0 0 12px;font-size:20px;font-weight:600;color:#333}.modal-content p{margin:0 0 24px;color:#666;line-height:1.5}.modal-buttons{display:flex;gap:12px;flex-direction:column}.retry-button,.back-button{padding:12px 24px;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:16px}.retry-button{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff}.retry-button:hover{transform:translateY(-1px);box-shadow:0 4px 16px #ff6b6b66}.back-button{background:#f8f9fa;color:#666;border:1px solid #e9ecef}.back-button:hover{background:#e9ecef;transform:translateY(-1px)}.dev-controls{position:fixed;top:20px;right:20px;z-index:9999;display:flex;gap:10px;flex-direction:column}.dev-btn{padding:8px 12px;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #0003;white-space:nowrap;opacity:.8}.dev-btn:hover{opacity:1;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.dev-btn-show{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.dev-btn-reset{background:linear-gradient(135deg,#ffc107,#fd7e14);color:#212529}.motion-swiper-container{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;justify-content:center;align-items:flex-start;background-color:#fff8f0;z-index:1;padding:5vw;box-sizing:border-box}.motion-card{position:absolute;width:90%;max-width:420px;height:75vh;max-height:640px;background:#fff;border-radius:20px;box-shadow:0 10px 30px #00000026;padding:12vh 5vw 3vh;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;box-sizing:border-box;text-align:center;transition:transform .3s ease}.motion-card:not(:last-child){transform:scale(.95);top:12px;z-index:2}.motion-card:last-child{z-index:3}.options-display{display:flex;font-size:1.4rem;justify-content:space-between;width:100%;margin-top:2rem;margin-bottom:2rem;position:relative}.options-display .left,.options-display .right{width:45%;text-align:center;font-weight:700;padding:16px 8px;transition:all .2s ease;background:transparent}.options-display:after{content:"或";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:#999;font-size:14px}.option-active{background:#007aff14;border-radius:12px;padding:12px 8px;transform:scale(1.05);transition:all .2s ease}.option-highlight-text{font-weight:700;color:#ff6b6b;transform:scale(1.12);transition:all .25s ease;text-shadow:0 1px 2px rgba(0,0,0,.1)}.question-wrapper{text-align:center;display:flex;flex-direction:column;align-items:center;width:100%}.vs-text{display:inline-block;position:relative;font-style:italic;color:#888;margin:.5rem auto;font-size:.9em;padding:0 15px}.vs-text:before,.vs-text:after{content:"";position:absolute;top:50%;height:1px;background-color:#ddd;width:30px}.vs-text:before{right:100%;margin-right:5px}.vs-text:after{left:100%;margin-left:5px}.question-text{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:.8rem}.restaurant-card.centered{position:relative;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;text-align:center;padding:3rem 1.5rem 2rem;color:#fff;text-shadow:0 0 6px rgba(0,0,0,.6);background-size:cover;background-position:center;border-radius:20px;overflow:hidden}.restaurant-info-blur{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border:1px solid rgba(255,255,255,.2);padding:1.5rem;border-radius:16px;position:relative;z-index:2;box-shadow:0 8px 32px #0000004d;margin:1rem;max-width:320px;transform:translateY(-10px)}.restaurant-info-blur h3{font-size:1.5rem;font-weight:700;margin-bottom:.8rem;margin-top:.5rem}.restaurant-info-blur p{font-size:1rem;margin:.5rem 0}.restaurant-info-blur small{font-size:.8rem;opacity:.9}.restaurant-rating{font-size:1rem;color:gold;margin:.5rem 0;justify-content:center}.price-range{font-size:1.1rem;color:#4caf50;font-weight:700;margin:.3rem 0}.restaurant-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.5rem;justify-content:center}.restaurant-tags .tag{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.2rem .5rem;border-radius:12px;font-size:.7rem;font-weight:500;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}margin-top: .5rem; } .motion-card{background-repeat:no-repeat;background-size:cover;background-position:center;position:absolute;transition:transform .3s ease,opacity .2s ease;will-change:transform}.mode-choice-row{display:flex;width:100%;justify-content:space-between;margin-top:2rem}.mode-choice{width:45%;padding:.5rem}.mode-choice-active,.option-active{transform:scale(1.05);transition:all .2s ease;background:transparent}.mode-choice p{font-size:1.3rem;font-weight:700;margin-bottom:.3rem}.mode-choice small.hint-text{font-size:.7rem;color:#888;margin-top:.4rem;display:block;line-height:1.4}.fixed-badge{position:fixed;top:120px;font-size:20px;font-weight:700;padding:10px 20px;border-radius:50px;z-index:100;box-shadow:0 4px 12px #0000002e;transform-origin:center center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);letter-spacing:.5px;opacity:0;visibility:hidden;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.badge-icon{font-size:22px;display:inline-flex;align-items:center;justify-content:center;margin-right:2px}.fixed-badge.like{right:30%;transform:translate(120px) rotate(8deg);color:#fff;background:linear-gradient(to right,#27ae60,#2ecc71);border:none}.fixed-badge.nope{left:30%;transform:translate(-120px) rotate(-8deg);color:#fff;background:linear-gradient(to right,#e74c3c,#ff6b6b);border:none}.fixed-badge.visible{opacity:1;visibility:visible;animation:badgePulse .6s ease-in-out}@keyframes badgePulse{0%{transform:translate(120px) scale(1) rotate(8deg)}50%{transform:translate(120px) scale(1.08) rotate(8deg)}to{transform:translate(120px) scale(1) rotate(8deg)}}@keyframes badgePulseNope{0%{transform:translate(-120px) scale(1) rotate(-8deg)}50%{transform:translate(-120px) scale(1.08) rotate(-8deg)}to{transform:translate(-120px) scale(1) rotate(-8deg)}}.fixed-badge.like.visible{animation:badgePulse .6s ease-in-out}.fixed-badge.nope.visible{animation:badgePulseNope .6s ease-in-out}@media (max-width: 480px){.fixed-badge{font-size:16px;padding:8px 16px}.badge-icon{font-size:18px}.fixed-badge.like{transform:translate(90px) rotate(8deg)}.fixed-badge.nope{transform:translate(-90px) rotate(-8deg)}@keyframes badgePulse{0%{transform:translate(90px) scale(1) rotate(8deg)}50%{transform:translate(90px) scale(1.08) rotate(8deg)}to{transform:translate(90px) scale(1) rotate(8deg)}}@keyframes badgePulseNope{0%{transform:translate(-90px) scale(1) rotate(-8deg)}50%{transform:translate(-90px) scale(1.08) rotate(-8deg)}to{transform:translate(-90px) scale(1) rotate(-8deg)}}}.welcome-screen,.recommend-screen{margin-top:40px;padding:0 1rem;box-sizing:border-box}@media (max-width: 768px){.recommend-screen{padding:1rem;font-size:.95rem}.recommend-screen h2{font-size:1.3rem}.recommend-screen h3{font-size:1.1rem}.recommend-screen img,.recommend-screen .btn-start,.recommend-screen .btn-restart{max-width:100%}.recommend-screen li{padding:1rem;font-size:.9rem}}.restaurant-like-button{position:absolute;top:16px;left:16px;width:48px;height:48px;border:none;border-radius:50%;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 12px #00000026;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:10;-webkit-user-select:none;user-select:none}.restaurant-like-button.liked{background:linear-gradient(135deg,#ff6b6bf2,#ff8e8ef2);box-shadow:0 4px 16px #ff6b6b66}.restaurant-like-button:hover{transform:scale(1.1);box-shadow:0 6px 16px #0003;background:#fff}.restaurant-like-button:active{transform:scale(.95)}.restaurant-like-button .heart-icon{font-size:24px;color:#ff6b6b;transition:all .3s ease}.restaurant-like-button.liked .heart-icon{color:#fff}.restaurant-like-button .heart-icon.filled{animation:heartBeat .3s ease}@keyframes heartBeat{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.restaurant-like-button,.motion-card{pointer-events:auto}@media (max-width: 768px){.restaurant-like-button{width:44px;height:44px;top:12px;left:12px}.restaurant-like-button .heart-icon{font-size:22px}}.recommend-screen{padding:1rem;max-width:900px;margin:0;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.empty-result{text-align:center;padding:2rem;background-color:#fff;border-radius:12px;box-shadow:0 4px 15px #00000014;margin:2rem 0}.empty-result h2{color:#330609;margin-bottom:1rem}.empty-result p{color:#666;margin-bottom:1.5rem}h2.result-title{text-align:center;margin:0 0 .5rem;color:#ff6b6b;font-size:1.5rem;font-weight:600}.featured-restaurant{background-size:cover;background-position:center;border-radius:12px;height:250px;position:relative;overflow:hidden;margin-bottom:1.5rem;box-shadow:0 4px 15px #0000001a;display:flex;align-items:flex-end}.votes-badge-top-right{position:absolute;top:12px;right:12px;background-color:#fd963df2;color:#fff;padding:.5rem .8rem;border-radius:20px;font-size:.9rem;font-weight:600;display:inline-flex;align-items:center;gap:.3rem;box-shadow:0 2px 8px #0003;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.featured-content{width:100%;padding:1.5rem;color:#fff;z-index:2}.featured-content h3{margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.restaurant-address{margin:.5rem 0;font-size:.9rem;color:#fff;opacity:.95}.rating-badge,.type-badge,.votes-badge{padding:.35rem .7rem;border-radius:6px;font-size:.85rem;display:inline-flex;align-items:center;font-weight:500}.rating-badge{background-color:#ffb70040;color:#ffb700}.star{margin-right:.3rem}.type-badge{background-color:#ffffff40}.votes-badge{background-color:#fd963d40;color:#fd963d}.vote-icon{margin-right:.3rem}.btn-navigate{background-color:#fd963d;color:#fff;border:none;padding:.6rem 1.2rem;border-radius:6px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background-color .2s ease}.btn-navigate:hover{background-color:#f5883f}.nav-icon{font-size:1.1rem}.alternatives-section{background-color:transparent;border-radius:0;padding:0;margin:1rem 0;box-shadow:none}.alternatives-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.alternatives-header h3{margin:0;color:#330609;font-size:1.15rem;font-weight:600}.btn-shuffle{background-color:#ff976b;color:#fff;border:none;padding:.4rem .8rem;border-radius:4px;font-size:.85rem;cursor:pointer;display:flex;align-items:center;gap:.3rem;transition:background-color .2s ease}.btn-shuffle:hover{background-color:#ff7f36}.btn-shuffle:disabled{background-color:#ffcdba;cursor:not-allowed}.alternatives-list{list-style:none;padding:0;margin:0}.alternative-item{padding:1rem;border-radius:12px;background-color:#fff;margin-bottom:1rem;transition:transform .2s ease,box-shadow .2s ease;border:none;box-shadow:0 2px 8px #0000000f;position:relative}.alternative-votes-badge-top-right{position:absolute;top:12px;right:12px;background-color:#fd963de6;color:#fff;padding:.35rem .65rem;border-radius:16px;font-size:.8rem;font-weight:600;display:inline-flex;align-items:center;gap:.25rem;box-shadow:0 2px 6px #00000026;z-index:5}.alternative-item:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001f}.alternative-content{display:flex;flex-direction:column;gap:.8rem}.alternative-info{width:100%}.alternative-info h4{margin:0 0 .4rem;font-size:1.05rem;color:#330609;font-weight:600;line-height:1.3;word-break:break-word}.alternative-info p{margin:0 0 .6rem;font-size:.8rem;color:#666;line-height:1.4;word-break:break-word}.alternative-badges{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center;margin-bottom:.6rem}.mini-badge{padding:.25rem .6rem;border-radius:6px;font-size:.8rem;font-weight:500;display:inline-flex;align-items:center;gap:.2rem;white-space:nowrap}.mini-badge.rating{background-color:#ffb70033;color:#d99c16;border:1px solid rgba(255,183,0,.3);margin:0}.mini-badge.type{background-color:#6c757d1a;color:#495057;border:1px solid rgba(108,117,125,.2)}.mini-badge.votes{background-color:#fd963d33;color:#fd963d;border:1px solid rgba(253,150,61,.3)}.btn-mini-navigate{background-color:#fd963d;color:#fff;border:none;padding:.7rem 1rem;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%;display:flex;align-items:center;justify-content:center;gap:.4rem}.btn-mini-navigate:hover{background-color:#f5883f}.btn-mini-navigate.secondary{background-color:#6874e8}.btn-mini-navigate.secondary:hover{background-color:#5965d9}.more-alternatives{text-align:center;font-size:.9rem;color:#777;margin:.8rem 0 .3rem;font-style:italic}.retry-container{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0}.btn-restart{background-color:#ff976b;color:#fff;border:none;padding:.8rem 1.2rem;border-radius:6px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background-color .2s ease}.btn-restart:hover{background-color:#ff7f36}.confetti-container{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:50;overflow:hidden}.confetti{position:absolute;width:12px;height:12px;opacity:.8;animation:confetti-fall linear forwards;transform:rotate(0)}@keyframes confetti-fall{0%{transform:translateY(-15px) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.other-alternatives{background-color:#f8f8f8}.other-alternatives h3{color:#330609}@media (max-width: 480px){.restaurant-details{flex-direction:column;align-items:flex-start;gap:.3rem}.alternative-badges{flex-wrap:wrap;margin-top:.5rem}.btn-navigate,.btn-restart{width:100%;justify-content:center}.alternative-item{padding:1rem}.alternative-info h4{font-size:1rem}.alternative-info p{font-size:.8rem}}.survey-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.survey-modal-container{background:#fff;border-radius:16px;max-width:900px;width:95%;max-height:95vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;margin:0 1rem}.survey-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb;border-radius:16px 16px 0 0}.survey-modal-header h3{margin:0;font-size:1.5rem;font-weight:600;color:#111827}.survey-modal-close{background:transparent;border:none;font-size:2rem;color:#6b7280;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s;line-height:1}.survey-modal-close:hover{background:#f3f4f6;color:#111827;transform:scale(1.1)}.survey-modal-content{flex:1;overflow:hidden;padding:0;border-radius:0 0 16px 16px}.survey-modal-content iframe{border-radius:0 0 16px 16px}@media (max-width: 768px){.survey-modal-container{max-width:98%;max-height:90vh;margin:0 .5rem}.survey-modal-header{padding:1rem}.survey-modal-header h3{font-size:1.25rem}.survey-modal-content iframe{height:600px}}.buddies-room{width:100%;margin:0;padding:0 1rem;text-align:center;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;display:flex;flex-direction:column;justify-content:center;box-sizing:border-box;overflow-x:hidden}.buddies-entrance-container{background:transparent;border-radius:0;padding:2rem 1.5rem;margin:0 auto;max-width:420px;width:90%;box-shadow:none;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;position:relative}.buddies-main-title{color:#ff6b6b;margin:0 0 2.5rem;font-size:1.8rem;font-weight:700;text-align:center}.buddies-toast-notification{position:fixed;top:20px;left:50%;transform:translate(-50%);min-width:220px;max-width:85%;background-color:#fff;color:#333;padding:14px 20px;border-radius:50px;box-shadow:0 6px 25px #0000002e;display:flex;align-items:center;justify-content:center;gap:12px;z-index:1000;animation:buddiestoastFadeInFromTop .3s ease-out,buddiestoastFloatFromTop .5s ease-in-out .3s;cursor:pointer;font-size:1rem;font-weight:500;border:none}.buddies-toast-notification.success{background-color:#f0fff4;border-left:6px solid #4CAF50}.buddies-toast-notification.error{background-color:#fff5f5;border-left:6px solid #F44336}.buddies-toast-icon{font-size:1.3rem;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background-color:#ffffff80;flex-shrink:0}.buddies-toast-notification.success .buddies-toast-icon{color:#4caf50}.buddies-toast-notification.error .buddies-toast-icon{color:#f44336}.buddies-toast-message{flex:1;text-align:left;line-height:1.4}@keyframes buddiestoastFadeInFromTop{0%{opacity:0;transform:translate(-50%,-50px)}to{opacity:1;transform:translate(-50%)}}@keyframes buddiestoastFloatFromTop{0%{transform:translate(-50%)}50%{transform:translate(-50%,5px)}to{transform:translate(-50%)}}.buddies-name-input,.buddies-room-input{display:block;margin:.5rem auto;padding:16px 20px;width:100%;max-width:320px;border:2px solid #E0E0E0;border-radius:20px;font-size:1.1rem;text-align:center;transition:all .3s ease;box-sizing:border-box;background:#fff;box-shadow:0 4px 15px #00000014}.buddies-name-input:focus,.buddies-room-input:focus{border-color:#ff6b6b;outline:none;box-shadow:0 0 0 3px #ff6b6b26,0 4px 20px #0000001a;transform:translateY(-2px)}.buddies-name-input:disabled,.buddies-room-input:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.buddies-button-group{display:flex;flex-direction:column;gap:16px;margin:2.5rem auto 1rem;width:100%;max-width:320px}.buddies-create-button,.buddies-join-button,.buddies-scan-button{width:100%;padding:16px 24px;border:none;border-radius:20px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 8px 24px #00000026}.buddies-create-button{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff}.buddies-create-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 32px #ff6b6b66}.buddies-create-button:disabled{background:#ccc;box-shadow:0 4px 12px #0000001a;cursor:not-allowed;transform:none}.buddies-join-button{background:linear-gradient(135deg,#ff976b,#ffab87);color:#fff}.buddies-join-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 32px #ff976b66}.buddies-join-button:disabled{background:#ccc;box-shadow:0 4px 12px #0000001a;cursor:not-allowed;transform:none}.buddies-scan-button{background:linear-gradient(135deg,#6874e8,#8b5cf6);color:#fff}.buddies-scan-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 32px #6874e866}.buddies-error-message{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;margin:1rem auto 0;max-width:280px;font-size:.9rem;border:1px solid #FECACA;display:flex;align-items:center;justify-content:center;gap:8px}.card-title{color:#333;margin:1.5rem 0;font-size:1.4rem;font-weight:600;text-align:center}.scan-button{background-color:#6874e8}.scan-button:hover{background-color:#5563d7}.copy-button-active,.share-button-active{margin:.5rem;padding:12px 20px;background-color:#ff6b6b;border:none;color:#fff;font-weight:600;border-radius:12px;cursor:pointer;font-size:1rem;transition:all .2s ease;box-shadow:0 4px 10px #ff6b6b33;position:relative;overflow:hidden}.copy-button-active:after,.share-button-active:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:copyingShimmer 1.5s infinite}.room-info{background-color:#fff;border-radius:16px;padding:1.5rem;margin:1rem 0;box-shadow:0 4px 15px #0000000d}.qr-container{background:#fff;padding:1rem;border-radius:10px;display:inline-block;margin:1rem auto;box-shadow:0 4px 10px #0000001a}.action-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:1rem 0}.start-button{width:100%;max-width:250px;margin-top:1.5rem;padding:15px;background-color:#2ecc71;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #2ecc7166}70%{box-shadow:0 0 0 10px #2ecc7100}to{box-shadow:0 0 #2ecc7100}}.waiting-message{background-color:#f9f9f9;border-radius:12px;padding:2rem;margin:2rem 0;box-shadow:0 4px 10px #0000000d}.connecting-message{background-color:#f4f9fd;border-radius:12px;padding:1rem;margin:1rem 0;box-shadow:0 4px 10px #0000000d;text-align:center;color:#3498db;animation:fadeInOut 1.5s infinite}@keyframes fadeInOut{0%{opacity:.7}50%{opacity:1}to{opacity:.7}}.loading-spinner{display:flex;justify-content:center;align-items:center;margin:2rem 0}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #FF9F68;border-radius:50%;animation:spin 1s linear infinite}.error-message{color:#e74c3c;font-weight:700;margin:1rem 0;padding:10px;background-color:#fdf1f0;border-radius:8px;border-left:4px solid #e74c3c;display:flex;align-items:center;justify-content:center}.qr-scanner-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.qr-scanner-modal .scanner-container{background:#fff;padding:1rem;border-radius:12px;max-width:90%;max-height:80%}.qr-scanner-modal .close-button{position:absolute;top:20px;right:20px;width:40px;height:40px;background:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;cursor:pointer;font-size:20px;color:#333}.toast-notification{position:fixed;top:20px;left:50%;transform:translate(-50%);min-width:220px;max-width:85%;background-color:#fff;color:#333;padding:14px 20px;border-radius:50px;box-shadow:0 6px 25px #0000002e;display:flex;align-items:center;justify-content:center;gap:12px;z-index:1000;animation:toastFadeInFromTop .3s ease-out,toastFloatFromTop .5s ease-in-out .3s;cursor:pointer;font-size:1rem;font-weight:500;border:none}.toast-notification.success{background-color:#f0fff4;border-left:6px solid #4CAF50}.toast-notification.error{background-color:#fff5f5;border-left:6px solid #F44336}.toast-icon{font-size:1.3rem;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background-color:#ffffff80;flex-shrink:0}.toast-notification.success .toast-icon{color:#4caf50}.toast-notification.error .toast-icon{color:#f44336}.toast-message{flex:1;text-align:left;line-height:1.4}@keyframes toastFadeInFromTop{0%{opacity:0;transform:translate(-50%,-50px)}to{opacity:1;transform:translate(-50%)}}@keyframes toastFloatFromTop{0%{transform:translate(-50%)}50%{transform:translate(-50%,5px)}to{transform:translate(-50%)}}@keyframes copyingShimmer{0%{left:-100%}to{left:100%}}.vote-trend-indicator{margin-top:.8rem;text-align:center}.vote-trend-text{font-size:.85rem;color:#444;margin-bottom:.3rem;font-weight:500}.vote-trend-bar{height:4px;background-color:#f0f0f0;border-radius:2px;overflow:hidden;position:relative}.vote-trend-progress{height:100%;width:0;transition:width 1s ease-in-out}.vote-participants{margin-top:1.2rem;text-align:center}.vote-participants-title{font-size:.85rem;color:#555;margin-bottom:.5rem}.vote-participants-avatars{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin-top:.5rem}.vote-participant-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;box-shadow:0 2px 5px #0000001a;animation:popIn .5s ease-out}@keyframes popIn{0%{transform:scale(0);opacity:0}60%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.waiting-animation{margin-top:0;margin-bottom:2rem;display:flex;flex-direction:column;align-items:center}.waiting-dots{display:flex;justify-content:center;gap:.6rem;margin:0 auto .6rem}.waiting-dots span{width:15px;height:15px;background-color:#ff6b6b;border-radius:50%;display:inline-block;animation:dotBounce 1.5s infinite ease-in-out}.waiting-dots span:nth-child(2){animation-delay:.2s;background-color:#ff9f68}.waiting-dots span:nth-child(3){animation-delay:.4s;background-color:#6874e8}@keyframes dotBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.buddies-waiting-container{background:transparent;width:100%;height:100%;margin:0;padding:2rem;display:flex;flex-direction:column;align-items:center;min-height:calc(100vh - 120px);justify-content:center;box-sizing:border-box;position:relative}.buddies-waiting-title{color:#ff6b6b;font-size:1.6rem;font-weight:700;margin:0 0 .8rem;text-align:center}.buddies-room-info{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 8px 24px #0000001a;margin-bottom:1.2rem;text-align:center;width:100%;max-width:350px;align-self:center}.buddies-room-number{color:#333;font-size:1.2rem;font-weight:600;margin:0}.buddies-qr-container{display:flex;justify-content:center;margin:0}.buddies-room-actions{display:flex;gap:12px;margin-bottom:.8rem;width:100%;max-width:260px}.buddies-copy-button,.buddies-share-button{flex:1;padding:12px 16px;border:none;border-radius:12px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:6px}.buddies-copy-button{background:linear-gradient(135deg,#ff976b,#ffab87);color:#fff}.buddies-copy-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #ff976b66}.buddies-share-button{background:linear-gradient(135deg,#6874e8,#8b5cf6);color:#fff}.buddies-share-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #6874e866}.buddies-copy-button-active,.buddies-share-button-active{background:#ccc;cursor:not-allowed;transform:none}.buddies-members-section{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 8px 24px #0000001a;margin-bottom:1.2rem;width:100%;max-width:350px;align-self:center}.buddies-members-title{color:#333;font-size:1.1rem;font-weight:600;margin:0 0 1rem;text-align:center}.buddies-members-list{display:flex;flex-direction:column;gap:12px}.buddies-member-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f8f9fa;border-radius:12px;transition:all .2s ease}.buddies-member-item:hover{background:#f1f3f4;transform:translateY(-1px)}.buddies-member-avatar{width:40px;height:40px;border-radius:50%;position:relative;overflow:hidden;flex-shrink:0}.buddies-avatar-image{width:100%;height:100%;object-fit:cover;border-radius:50%}.buddies-avatar-fallback{width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}.buddies-member-info{flex:1;display:flex;flex-direction:column;gap:4px}.buddies-member-name{color:#333;font-weight:600;font-size:1rem}.buddies-member-you{color:#ff6b6b;font-size:.9rem;font-weight:500}.buddies-host-badge{background:linear-gradient(135deg,#6874e8,#8b5cf6);color:#fff;padding:4px 8px;border-radius:8px;font-size:.8rem;font-weight:600;display:inline-block;margin-top:2px}.buddies-action-section{width:100%;max-width:280px;display:flex;justify-content:center}.buddies-start-button{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff;border:none;padding:14px 28px;border-radius:20px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 24px #ff6b6b4d;display:flex;align-items:center;justify-content:center;gap:8px;min-width:140px}.buddies-start-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 32px #ff6b6b80}.buddies-start-button:disabled{background:#ccc;box-shadow:0 4px 12px #0000001a;cursor:not-allowed;transform:none}.buddies-waiting-message{text-align:center;padding:1.5rem;background:#f8f9fa;border-radius:12px;border:2px dashed #E0E0E0}.buddies-waiting-message p{margin:0;color:#666;font-size:1rem;font-weight:500}.buddies-waiting-recommendations{text-align:center;padding:2rem 0}.buddies-loading-spinner{margin:2rem auto}@media (max-width: 480px){.buddies-room{width:100%;padding:0 .8rem;margin:0;overflow-x:hidden}.buddies-entrance-container{padding:1.5rem 0;width:100%;min-height:85vh}.buddies-main-title{font-size:1.6rem;margin-bottom:2rem}.buddies-name-input,.buddies-room-input{max-width:100%;font-size:1rem;padding:14px 18px}.buddies-button-group{max-width:100%;gap:14px;margin:2rem auto 1rem}.buddies-create-button,.buddies-join-button,.buddies-scan-button{font-size:1rem;padding:14px 20px}.action-buttons{flex-direction:column}.toast-notification,.buddies-toast-notification{top:10px;max-width:90%;font-size:.9rem;padding:12px 16px}.toast-icon,.buddies-toast-icon{font-size:1.1rem;width:24px;height:24px}.buddies-waiting-container{padding:1.5rem 1rem;width:100%;min-height:calc(100vh - 100px);justify-content:center}.buddies-waiting-title{font-size:1.4rem;margin-bottom:.6rem}.buddies-room-info{max-width:100%;padding:.8rem;margin-bottom:.6rem}.buddies-room-actions{max-width:100%;gap:8px;margin-bottom:.6rem}.buddies-copy-button,.buddies-share-button{font-size:.85rem;padding:10px 12px}.buddies-members-section{max-width:100%;padding:.8rem;margin-bottom:.8rem}.buddies-member-avatar{width:36px;height:36px}.buddies-avatar-fallback{font-size:1rem}.buddies-member-name{font-size:.9rem}.buddies-start-button{font-size:1.1rem;padding:14px 24px;min-width:140px}.buddies-action-section{max-width:100%}}.buddies-waiting-recommendations{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 8px 24px #0000001a;margin-bottom:1.2rem;width:100%;max-width:400px;align-self:center;text-align:center}.buddies-waiting-subtitle{color:#666;font-size:1rem;margin:0 0 2rem}.buddies-analysis-progress{display:flex;flex-direction:column;gap:1rem;margin:2rem 0}.analysis-step{display:flex;align-items:center;justify-content:flex-start;gap:1rem;padding:.8rem 1rem;background:#ff6b6b0d;border-radius:12px;border-left:4px solid #FF6B6B;animation:analysisStep 3s ease-in-out infinite}.step-icon{font-size:1.5rem;animation:bounce 2s infinite}.step-text{color:#333;font-weight:600;font-size:.95rem}.buddies-progress-text{margin-top:1.5rem}.buddies-progress-text p{color:#888;font-size:.9rem;font-style:italic;margin:0;animation:fadeInOut 2s ease-in-out infinite}@keyframes analysisStep{0%,to{background:#ff6b6b0d;border-left-color:#ff6b6b}50%{background:#ff6b6b26;border-left-color:#ff8e8e}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-5px)}60%{transform:translateY(-3px)}}@keyframes fadeInOut{0%,to{opacity:.7}50%{opacity:1}}.buddies-loading-spinner{display:flex;justify-content:center;align-items:center;margin:1.5rem 0}.spinner{width:40px;height:40px;border:4px solid rgba(255,107,107,.1);border-left:4px solid #FF6B6B;border-radius:50%;animation:spin 1s linear infinite}@keyframes holdPageOpen{0%,to{opacity:1}}.question-container{position:relative;width:100%;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding-top:0;overflow:hidden}.question-active-container{position:fixed;left:50%;transform:translate(-50%);width:100%;max-width:500px;z-index:5}.waiting-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#fff8f0;z-index:100;display:flex;justify-content:center;align-items:flex-start;padding-top:8vh}.question-progress{margin:1rem auto;width:90%;max-width:400px;display:none}.question-progress-text{font-size:.9rem;color:#666;margin-bottom:.5rem;text-align:center}.question-progress-bar{height:8px;background-color:#f0f0f0;border-radius:4px;overflow:hidden}.question-progress-fill{height:100%;background-color:#ff6b6b;border-radius:4px;transition:width .5s ease}.vote-bubbles-container{position:fixed;top:80px;right:20px;z-index:1000;pointer-events:none;display:flex;flex-direction:column;align-items:flex-end}.vote-bubble{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:12px;margin:8px;max-width:200px;opacity:0;transform:translateY(-20px);animation:bubbleAppear .3s ease forwards}.vote-bubble-content{background:#e3f2fd;border-radius:8px;padding:10px;position:relative}.vote-bubble-content:after{content:"";position:absolute;right:-8px;top:50%;transform:translateY(-50%);border-left:8px solid #E3F2FD;border-top:6px solid transparent;border-bottom:6px solid transparent}.vote-bubble-name{font-weight:600;font-size:14px;color:#4a90e2;margin-bottom:4px}.vote-bubble-choice{font-size:12px;color:#666}@keyframes bubbleAppear{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes bubbleDisappear{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.AnimatePresence{position:relative;z-index:1000}.live-vote-count{font-size:.8rem;color:#666;background-color:#6874e81a;padding:2px 6px;border-radius:10px;margin-top:5px;display:inline-block}.live-votes-indicator{display:flex;align-items:center;justify-content:center;gap:5px;font-size:.8rem;color:#666;margin-top:8px;background-color:#ffffffb3;padding:4px 10px;border-radius:15px;animation:pulseFade 2s infinite}.live-votes-icon{font-size:1rem}@keyframes pulseFade{0%,to{opacity:.7}50%{opacity:1}}.vote-distribution{display:flex;flex-direction:column;gap:1rem;margin:1.5rem auto;width:100%;max-width:340px}.vote-option-item{margin-bottom:.5rem}.vote-option-stats{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.vote-option-name{font-weight:500;color:#444;flex:1}.vote-percentage{font-weight:600;color:#333;margin:0 .5rem}.vote-count{color:#666;font-size:.75rem}.vote-bar-container{height:10px;background-color:#f0f0f0;border-radius:5px;overflow:hidden;display:flex}.vote-bar-left{height:100%;background:linear-gradient(to right,#6874e8,#8990ff);border-radius:5px 0 0 5px}.vote-bar-right{height:100%;background:linear-gradient(to right,#ff9f68,#ff6b6b);border-radius:0 5px 5px 0}.vote-progress-single{width:100%;margin-bottom:1rem}.vote-bar-container-single{position:relative;width:100%;height:20px;background:#f0f0f0;border-radius:10px;overflow:hidden;margin:10px 0}.vote-bar-left-single{position:absolute;left:0;height:100%;background:linear-gradient(90deg,#4a90e2,#357abd);border-radius:10px 0 0 10px;transition:width .5s ease}.vote-bar-right-single{position:absolute;right:0;height:100%;background:linear-gradient(90deg,#ff6b6b,#ff5252);border-radius:0 10px 10px 0;transition:width .5s ease}.vote-percentage-indicator{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:.8em;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.2);transition:left .5s ease}.vote-waiting-dots{display:flex;justify-content:center;gap:.4rem;margin-top:.5rem}.vote-waiting-dots span{width:8px;height:8px;background-color:#ff6b6b;border-radius:50%;display:inline-block;animation:dot-pulse 1.5s infinite ease-in-out}.vote-waiting-dots span:nth-child(2){animation-delay:.2s}.vote-waiting-dots span:nth-child(3){animation-delay:.4s}.swipe-hint,.vote-hint{text-align:center;margin-top:1rem;padding:.8rem;color:#777;font-size:.9rem;background-color:#ffffffb3;border-radius:12px}.vote-hint{color:#6874e8}.waiting-container{width:auto;max-width:90%;text-align:center;padding:0;margin:1rem auto}.vote-status-title{display:flex;align-items:center}.waiting-animation{margin:1rem 0 2rem;display:flex;flex-direction:column;align-items:center}.waiting-dots{display:flex;justify-content:center;gap:.6rem;margin:0 auto 1rem}.waiting-dots span{width:12px;height:12px;background-color:#ff6b6b;border-radius:50%;display:inline-block;animation:dotBounce 1.5s infinite ease-in-out}.waiting-dots span:nth-child(1){animation-delay:0s}.waiting-dots span:nth-child(2){animation-delay:.3s}.waiting-dots span:nth-child(3){animation-delay:.6s}@keyframes dotBounce{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-20px);opacity:1}}.waiting-text{color:#444;font-size:1.1rem;font-weight:500;margin-top:.8rem}.all-questions-done{position:fixed;top:20%;left:50%;transform:translate(-50%,-50%);width:100%;max-width:500px;display:flex;justify-content:center;align-items:center;padding:0 20px}.done-container{background-color:#fff;border-radius:16px;padding:2rem;text-align:center;box-shadow:0 4px 20px #00000014;max-width:90%;margin:0 auto}.done-icon{font-size:3rem;margin-bottom:1rem;color:#2ecc71}.done-container h3{margin-top:0;color:#444}.done-container p{color:#666}.loading-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}.loading-dots span{width:10px;height:10px;background-color:#ff6b6b;border-radius:50%;display:inline-block;animation:dot-pulse 1.5s infinite ease-in-out}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-pulse{0%,to{transform:scale(.7);opacity:.5}50%{transform:scale(1);opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes growWidth{0%{width:0}}@keyframes floatUp{0%{opacity:0;transform:translateY(20px)}10%{opacity:1;transform:translateY(0)}90%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes popUp{0%{opacity:0;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.question-swiper-container{position:fixed;top:20%;left:50%;transform:translate(-50%,-50%);width:100%;max-width:500px;display:flex;flex-direction:column;align-items:center;padding:0 20px;z-index:5}.question-swiper-container .motion-swiper-container{position:relative;width:100%;height:auto;padding:0;margin:0}.vote-ranking{background-color:#fff;border-radius:12px;padding:1rem;margin:1rem 0;box-shadow:0 2px 10px #0000000d}.vote-ranking h3{text-align:center;margin-top:0;color:#555;font-size:1.1rem;margin-bottom:1rem}.vote-bars{display:flex;flex-direction:column;gap:.8rem}.vote-rank-item{margin-bottom:.5rem}.vote-rank-header{display:flex;justify-content:space-between;margin-bottom:.3rem}.vote-rank-name{font-weight:600;font-size:.9rem;color:#333;display:flex;align-items:center}.vote-rank-position{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background-color:#6874e8;color:#fff;font-size:.7rem;margin-right:.5rem}.vote-rank-count{font-size:.8rem;color:#666}.vote-rank-bar-container{height:10px;background-color:#f0f0f0;border-radius:5px;overflow:hidden;position:relative}.vote-rank-bar{height:100%;background-color:#ff6b6b;border-radius:5px;transition:width .5s ease-out}.vote-rank-percentage{position:absolute;right:0;top:-18px;font-size:.7rem;color:#888}@media (max-width: 320px){.vote-option{width:35%;font-size:.8rem}.vote-count-number{font-size:.75rem}.done-container{padding:1.5rem}.vote-bubble-content{padding:.6rem .8rem;font-size:.8rem}.vote-status-container{padding:.8rem}.vote-status-text,.vote-option-name{font-size:.8rem}.vote-percentage,.vote-count{font-size:.7rem}.vote-option-label{font-size:.8rem}.vote-bar-container-single{height:12px}.vote-percentage-indicator{top:-26px;padding:2px 8px;font-size:.8rem}}.restaurant-details{display:flex;gap:.5rem;margin:.8rem 0 1.2rem;flex-wrap:wrap}.vote-status-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.8rem;border-bottom:1px solid #f0f0f0}.vote-status-icon{font-size:1.3rem;margin-right:.7rem;color:#6874e8}.vote-status-text{font-size:.95rem;color:#444;font-weight:600;flex:1}.vote-status-total{font-size:.85rem;color:#fff;background-color:#ff6b6b;padding:.3rem .7rem;border-radius:30px;box-shadow:0 2px 5px #ff6b6b4d;font-weight:600}.vote-options-labels{display:flex;justify-content:space-between;margin-bottom:1.2rem;font-size:.95rem}.vote-option-label{display:flex;justify-content:space-between;align-items:center;margin:5px 0;font-size:14px;color:#333}.vote-option-label.left{color:#4a90e2}.vote-option-label.right{color:#ff6b6b}.vote-count{font-weight:700;padding:4px 8px;border-radius:12px;font-size:12px;background:#f5f5f5}.vote-option-label.left .vote-count{color:#4a90e2}.vote-option-label.right .vote-count{color:#ff6b6b}@keyframes barGrow{0%{width:0}to{width:var(--target-width)}}@media (max-width: 480px){.vote-status-container{margin:10px;padding:15px}.vote-distribution{padding:0;max-width:300px}.vote-options-labels{font-size:.85rem}.vote-count{padding:2px 8px;font-size:.75rem}.vote-bar-container-single{height:16px}.vote-percentage-indicator{top:-28px;padding:3px 10px;font-size:.85rem}}@media (max-width: 320px){.vote-status-container{width:92%;max-width:300px;padding:1rem;margin:1rem auto}.vote-distribution{max-width:280px}.vote-bar-container-single{height:12px}.vote-percentage-indicator{top:-26px;padding:2px 8px;font-size:.8rem}}.vote-members-section{margin:1.5rem 0;padding:1rem;background:#fff;border-radius:16px;box-shadow:0 2px 10px #0000000d}.vote-members-title{font-size:.95rem;color:#444;font-weight:600;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.vote-members-list{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}.vote-member-item{display:flex;align-items:center;padding:8px 12px;margin:4px 0;background:#f5f5f5;border-radius:8px;transition:all .3s ease}.vote-member-item.voted{background:#e3f2fd}.vote-member-item.waiting{background:#fff3e0}.vote-member-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;margin-right:.5rem;border:2px solid #fff;box-shadow:0 1px 3px #0000001a}.vote-member-avatar-fallback{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;margin-right:.5rem;border:2px solid #fff;box-shadow:0 1px 3px #0000001a}.vote-member-icon{font-size:1.1rem;margin-right:.5rem}.vote-member-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.vote-member-choice{font-size:.8rem;color:#666;margin-left:.5rem;background:#0000000d;padding:2px 6px;border-radius:4px}.vote-member-status{font-size:.8rem;color:#ff6b6b;margin-left:.5rem;font-style:italic}.vote-status-container{background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a;margin:20px;padding:20px;width:90%;max-width:500px}@media (max-width: 480px){.vote-members-list{gap:.5rem}.vote-member-item{padding:.4rem .8rem;min-width:80px}.vote-member-name{max-width:100px}}.vote-complete-indicator{background:#e8f5e9;color:#2e7d32;padding:8px 16px;border-radius:20px;display:inline-flex;align-items:center;margin:10px 0;font-size:14px}@keyframes dotPulse{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}@keyframes barGrow{0%{width:0}}@media (max-width: 480px){.vote-status-container{margin:10px;padding:15px}.vote-bar-container-single{height:16px}.vote-option-label{font-size:12px}}.buddies-container{padding:1rem;max-width:800px;margin:0 auto;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.buddies-card{background-color:#fff;border-radius:12px;padding:1.5rem;margin:1rem 0;box-shadow:0 2px 10px #00000014}.buddies-card .card-title{text-align:center;margin-bottom:1rem;color:#330609;font-size:1.3rem;font-weight:600}.buddies-alternatives-section{background-color:#fff;border-radius:12px;padding:1rem;margin:1.5rem 0;box-shadow:0 2px 10px #0000000d}.buddies-alternatives-section h3{margin:0 0 1rem;color:#330609;font-size:1.15rem;font-weight:600}.buddies-alternative-restaurant-list{list-style:none;padding:0;margin:0}.buddies-alternative-restaurant-item{padding:1rem;border-radius:8px;background-color:#f9f9f9;margin-bottom:.8rem;transition:background-color .2s ease}.buddies-alternative-restaurant-item:hover{background-color:#f0f0f0}.buddies-alternative-restaurant-info{display:flex;justify-content:space-between;align-items:center}.buddies-alternative-restaurant-name{font-weight:600;color:#330609;font-size:1rem;margin-bottom:.3rem}.buddies-alternative-restaurant-details{display:flex;gap:.5rem;align-items:center;font-size:.8rem;color:#666}.qr-scanner-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.qr-scanner-modal{background:#fff;border-radius:16px;max-width:500px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 20px 60px #0000004d;margin:0 auto;position:relative}.qr-scanner-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.qr-scanner-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.qr-scanner-close{background:transparent;border:none;font-size:1.75rem;color:#6b7280;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background-color .2s,color .2s}.qr-scanner-close:hover{background:#f3f4f6;color:#111827}.qr-scanner-content{padding:1.5rem}#qr-reader{width:100%;min-height:300px}#qr-reader>div{width:100%!important}#qr-reader__dashboard_section_csr,#qr-reader__dashboard_section_fsr{display:none!important}#qr-reader__camera_selection{margin-bottom:1rem;width:100%}#qr-reader__camera_selection select{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem}#qr-reader__scan_region{width:100%!important;border:none!important}#qr-reader__scan_region video{width:100%!important;max-width:100%!important;height:auto!important;border-radius:12px;display:block!important}#qr-reader__scan_region canvas{display:block!important}#qr-reader__scan_region img,#qr-reader__dashboard_section_swaplink,#qr-reader__status_span,#qr-reader__header_message{display:none!important}.qr-scanner-hint{text-align:center;margin-top:1rem;margin-bottom:0;color:#6b7280;font-size:.875rem}.qr-scanner-error{text-align:center;padding:2rem 1rem}.qr-scanner-error .error-icon{font-size:3rem;margin-bottom:1rem}.qr-scanner-error .error-message{color:#dc2626;font-size:1rem;font-weight:600;margin-bottom:1.5rem}.qr-scanner-error .retry-button{background:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;margin-bottom:1rem}.qr-scanner-error .retry-button:hover{background:#2563eb}.qr-scanner-error .error-hint{color:#6b7280;font-size:.875rem;margin-top:1rem;line-height:1.5}@media (max-width: 640px){.qr-scanner-modal{max-width:95%}.qr-scanner-header{padding:1rem}.qr-scanner-header h3{font-size:1.125rem}.qr-scanner-content{padding:1rem}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background:transparent;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;justify-content:center;align-items:center;z-index:10000;overflow:hidden}.loading-content{text-align:center;color:#2d3748;max-width:300px;padding:2rem;background:#fffffff2;border-radius:16px;box-shadow:0 8px 32px #0003;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.loading-spinner{position:relative;width:120px;height:120px;margin:0 auto 2rem}.spinner-circle{position:absolute;width:100%;height:100%;border:4px solid rgba(255,255,255,.2);border-top:4px solid #ff6b6b;border-radius:50%}.spinner-inner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;background:#ffffff1a;border-radius:50%;display:flex;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2)}.spinner-icon{font-size:2rem;filter:grayscale(.3)}.loading-text{margin-bottom:2rem}.loading-message{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:#2d3748;text-shadow:none}.loading-sub-message{font-size:1rem;margin:0;color:#718096;line-height:1.4}.loading-dots{display:flex;justify-content:center;gap:8px}.loading-dot{width:8px;height:8px;background:#ff6b6b;border-radius:50%;box-shadow:0 0 10px #ff6b6b80}@media (max-width: 480px){.loading-content{padding:1.5rem;max-width:280px}.loading-spinner{width:100px;height:100px}.spinner-inner{width:70px;height:70px}.spinner-icon{font-size:1.8rem}.loading-message{font-size:1.3rem}.loading-sub-message{font-size:.9rem}}@media (prefers-color-scheme: dark){.loading-overlay{background:transparent}.loading-content{background:#2d3748f2;color:#f7fafc;border:1px solid rgba(255,255,255,.1)}.loading-message{color:#f7fafc}.loading-sub-message{color:#a0aec0}.spinner-inner{background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}}@media (prefers-reduced-motion: reduce){.loading-overlay,.loading-content,.loading-spinner,.loading-text,.loading-dots{animation:none;transition:none}}.swipe-onboarding{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:10000;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden;margin:0;padding:0}.onboarding-content{text-align:center;max-width:90vw;width:100%;height:100vh;padding:20px;position:relative;display:flex;flex-direction:column;justify-content:center;align-items:center;box-sizing:border-box}.skip-button{position:fixed;top:20px;right:20px;background:#fff3;color:#fff;border:none;padding:8px 16px;border-radius:20px;font-size:14px;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;z-index:10001}.skip-button:hover{background:#ffffff4d;transform:translateY(-1px)}.step-content{display:flex;flex-direction:column;justify-content:flex-start;align-items:center;width:100%;position:absolute;top:80px;left:0;right:0;height:calc(100vh - 220px)}.step-animation{position:relative;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;margin-bottom:20px;width:100%;max-height:50vh}.step-icon{font-size:4rem;margin-bottom:20px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.step-title{font-size:1.8rem;font-weight:700;margin:20px 0 10px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.step-subtitle{font-size:1.1rem;opacity:.9;line-height:1.5;margin-bottom:30px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.card-demo-container{position:relative;flex:1;display:flex;justify-content:center;align-items:center;width:100%;max-height:55vh;min-height:320px;margin-top:-30px}.demo-card-wrapper{position:relative;transform-origin:center center}.demo-card{width:min(320px,80vw);height:min(480px,55vh);max-width:360px;max-height:540px;padding:8vh 4vw 2vh;font-size:1rem;background:#fff;color:#333;border-radius:20px;box-shadow:0 10px 30px #00000026;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;text-align:center;box-sizing:border-box;aspect-ratio:21/32}.onboarding-demo-card .question-wrapper h2{font-size:1.6rem;margin-bottom:20px;color:#333;font-weight:600}.onboarding-demo-card .question-wrapper .question-text{color:#333;font-size:1.6rem;font-weight:600}.onboarding-demo-card .options-display{font-size:1.2rem;margin:20px 0}.onboarding-demo-card .options-display .left,.onboarding-demo-card .options-display .right{padding:12px 10px;font-size:1.1rem;font-weight:500;color:#333}.onboarding-demo-card .restaurant-info{width:100%;text-align:center}.onboarding-demo-card .restaurant-name{font-size:1.8rem;margin-bottom:12px;color:#333;font-weight:700}.onboarding-demo-card .restaurant-category{color:#666;margin-bottom:12px;font-size:1.1rem;font-weight:500}.onboarding-demo-card .restaurant-rating{color:#ffc107;margin-bottom:12px;font-weight:600;font-size:1.2rem}.onboarding-demo-card .restaurant-address{color:#fff;font-size:1rem;margin-bottom:16px}.onboarding-demo-card .restaurant-tags{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.onboarding-demo-card .tag{background:#e9ecef;color:#495057;padding:6px 12px;border-radius:16px;font-size:.9rem;font-weight:500}.swipe-indicators{position:absolute;width:100%;height:100%;pointer-events:none}.swipe-indicator{position:absolute;background:#000c;color:#fff;padding:8px 12px;border-radius:20px;font-size:.9rem;font-weight:600;white-space:nowrap;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 12px #0000004d}.right-indicator{top:35%;right:5px}.left-indicator{top:35%;left:5px}.like-indicator{top:10%;right:-50px;background:#ff6b6be6}.skip-indicator{top:10%;left:-50px;background:#6c757de6}.step-indicators{display:flex;justify-content:center;gap:10px;position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:10001;padding:15px 0;margin:10px 0}.step-indicator{width:12px;height:12px;border-radius:50%;background:#ffffff4d;transition:all .3s ease}.step-indicator.active{background:#fff;transform:scale(1.2);box-shadow:0 0 10px #ffffff80}.step-indicator.completed{background:#ffffffb3}.onboarding-actions{width:100%;position:fixed;bottom:20px;left:50%;transform:translate(-50%);max-width:90vw;padding:20px;box-sizing:border-box}.next-button,.start-button{width:100%;padding:16px 24px;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:50px;font-size:16px;font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.3)}.next-button:hover,.start-button:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 8px 25px #0003}.start-button{background:linear-gradient(45deg,#ff6b6b,#feca57);border:2px solid rgba(255,255,255,.5);font-weight:700}.start-button:hover{background:linear-gradient(45deg,#ff5252,#ffc107);transform:translateY(-3px);box-shadow:0 10px 30px #ff6b6b66}.swipe-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:10001;pointer-events:none;background:transparent}.finger-icon{font-size:2.5rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.4))}@media (max-width: 480px){.onboarding-content{max-width:100vw;padding:15px}.step-title{font-size:1.4rem}.step-subtitle{font-size:.95rem}.step-icon{font-size:3rem}.card-demo-container{min-height:280px;max-height:45vh}.demo-card{width:min(220px,70vw);height:min(330px,40vh);max-width:240px;max-height:360px;padding:6vh 3vw 1.5vh}.demo-card .restaurant-name{font-size:1.1rem}.demo-card .question-wrapper h2{font-size:1rem}.demo-card .options-display{font-size:.9rem}.right-indicator{right:10px;font-size:.8rem;padding:6px 10px}.left-indicator{left:10px;font-size:.8rem;padding:6px 10px}.like-indicator,.skip-indicator{font-size:.8rem;padding:6px 10px}.next-button,.start-button{padding:14px 20px;font-size:15px}}@media (max-height: 600px){.step-content{min-height:50vh;max-height:70vh}.step-animation{max-height:35vh}.step-icon{font-size:2.5rem;margin-bottom:10px}.step-title{font-size:1.3rem;margin:10px 0 5px}.step-subtitle{font-size:.9rem;margin-bottom:15px}.card-demo-container{min-height:200px;max-height:35vh}.demo-card{width:min(200px,65vw);height:min(300px,30vh);max-width:220px;max-height:330px;padding:4vh 2vw 1vh}}.step-animation.welcome .step-icon{animation:welcome-bounce 2s ease-in-out infinite}.step-animation.ready .step-icon{animation:ready-pulse 1.5s ease-in-out infinite}@keyframes welcome-bounce{0%,20%,50%,80%,to{transform:translateY(0) scale(1)}40%{transform:translateY(-20px) scale(1.1)}60%{transform:translateY(-10px) scale(1.05)}}@keyframes ready-pulse{0%,to{transform:scale(1);filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}50%{transform:scale(1.1);filter:drop-shadow(0 8px 16px rgba(0,0,0,.4)) brightness(1.2)}}.tutorial-swiper-container{position:relative;width:100%;flex:1;max-height:55vh;min-height:320px;display:flex;justify-content:center;align-items:flex-start;padding-top:0}.tutorial-swiper-container .motion-swiper-container{position:relative;width:min(360px,85vw);height:min(540px,55vh);padding:0;background:transparent}.tutorial-swiper-container .motion-card{width:min(320px,80vw);height:min(480px,55vh);max-width:360px;max-height:540px;padding:8vh 4vw 2vh;font-size:1rem;position:relative;border-radius:20px;box-shadow:0 10px 30px #00000026;box-sizing:border-box;aspect-ratio:21/32;background:#fff;color:#333}.tutorial-swiper-container .motion-card .question-wrapper h2,.tutorial-swiper-container .motion-card .question-text{color:#333;font-size:1.6rem;font-weight:600}.tutorial-swiper-container .motion-card .options-display .left,.tutorial-swiper-container .motion-card .options-display .right{color:#333;font-weight:500}.tutorial-swiper-container .motion-card .restaurant-name{color:#333;font-weight:700}.tutorial-swiper-container .motion-card .restaurant-category,.tutorial-swiper-container .motion-card .restaurant-address{color:#fff}.tutorial-swiper-container .motion-card .restaurant-rating{color:#ffc107}.tutorial-swiper-container .motion-card .tag{background:#e9ecef;color:#495057}.tutorial-swiper-container .motion-card:after{content:"滑動試試看！";position:absolute;bottom:10px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:4px 12px;border-radius:12px;font-size:.7rem;font-weight:600;opacity:.8;pointer-events:none;animation:tutorial-pulse 2s infinite}@keyframes tutorial-pulse{0%,to{opacity:.6;transform:translate(-50%) scale(1)}50%{opacity:1;transform:translate(-50%) scale(1.05)}}.swipe-onboarding:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 40% 80%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.idle-hint-container{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:9997;display:flex;align-items:center;justify-content:center}.idle-hint-container>*{pointer-events:auto}.idle-hint-container .idle-hint-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0006;z-index:9998;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);margin:0;padding:0;box-sizing:border-box}.idle-hint-container .idle-hint-modal{position:relative;background:#fff;border-radius:16px;padding:20px;width:280px;min-height:240px;text-align:center;box-shadow:0 10px 40px #0003;z-index:9999;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0;box-sizing:border-box}.hint-icon{font-size:3rem;margin-bottom:20px;display:inline-block}.hint-title{font-size:1.4rem;font-weight:700;color:#333;margin:0 0 12px}.hint-subtitle{font-size:1rem;color:#666;line-height:1.5;margin:0 0 25px;max-width:280px}.swipe-animation{position:relative;height:60px;margin:20px 0;display:flex;flex-direction:column;align-items:center;justify-content:center}.swipe-demo{font-size:2rem;z-index:2}.swipe-arrows{position:absolute;top:50%;transform:translateY(-50%);width:100%;display:flex;justify-content:space-between;padding:0 20px;pointer-events:none}.arrow-left,.arrow-right{font-size:1.5rem;color:#007bff;font-weight:700}.hint-action-button{width:100%;max-width:250px;background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;border-radius:12px;padding:14px 20px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:15px}.hint-action-button:hover{background:linear-gradient(135deg,#0056b3,#004085);transform:translateY(-1px);box-shadow:0 4px 12px #007bff4d}.hint-close{position:absolute;top:15px;right:15px;background:none;border:none;font-size:18px;color:#999;cursor:pointer;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.hint-close:hover{background:#f5f5f5;color:#333}@media (max-width: 768px){.idle-hint-modal{width:95%;max-width:420px;min-height:350px;padding:30px 20px}.hint-icon{font-size:4rem;margin-bottom:20px}.hint-title{font-size:1.8rem}.hint-subtitle{font-size:1.1rem}.swipe-animation{height:80px;margin:20px 0}.swipe-demo{font-size:2.8rem}.arrow-left,.arrow-right{font-size:2rem}.hint-action-button{padding:16px 24px;font-size:16px;max-width:260px}}@media (max-width: 480px){.idle-hint-modal{width:95%;max-width:320px;min-height:300px;padding:25px 15px}.hint-icon{font-size:3rem;margin-bottom:15px}.hint-title{font-size:1.5rem}.hint-subtitle{font-size:1rem}.swipe-animation{height:60px;margin:15px 0}.swipe-demo{font-size:2.2rem}.arrow-left,.arrow-right{font-size:1.6rem}.swipe-arrows{padding:0 20px}.hint-action-button{padding:14px 20px;font-size:15px;max-width:220px}.hint-close{top:15px;right:15px;width:35px;height:35px;font-size:20px}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.hint-action-button:active{animation:pulse .2s ease}.map-view-container{position:relative;width:100%;height:100%;background:#f5f5f5}.google-map{width:100%;height:100%}.map-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f5f5f5e6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000}.loading-spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top:3px solid #ff6b35;border-radius:50%;animation:mapSpinner 1s linear infinite;margin-bottom:16px}.map-loading p{color:#666;font-size:.9rem;font-weight:500}@keyframes mapSpinner{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.google-places-info-window .custom-close-btn{position:absolute;top:16px;right:16px;width:28px;height:28px;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s ease}.google-places-info-window .custom-close-btn:hover{background:#000000e6;transform:scale(1.1)}.google-places-info-window .info-place-photo{width:100%;height:160px;object-fit:cover;display:block;margin:0;border-radius:0}.google-places-info-window .info-place-content{padding:18px 20px 20px}.google-places-info-window .info-place-name{font-size:1.25rem;font-weight:700;color:#1a202c;margin:0 0 10px;line-height:1.3;letter-spacing:-.02em}.google-places-info-window .info-place-category{font-size:.8rem;color:#667eea;background:#667eea1f;padding:4px 12px;border-radius:16px;display:inline-block;margin:0 0 12px;font-weight:600;border:1px solid rgba(102,126,234,.2)}.google-places-info-window .info-place-rating{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding:8px 12px;background:#ffc10714;border-radius:12px;border:1px solid rgba(255,193,7,.2)}.google-places-info-window .info-rating-stars{color:#ffc107;font-size:.9rem;letter-spacing:1px}.google-places-info-window .info-rating-text{color:#666;font-size:.85rem}.google-places-info-window .info-place-address{color:#4a5568;font-size:.9rem;margin:0 0 8px;line-height:1.5;font-weight:500}.google-places-info-window .info-place-phone{color:#4a5568;font-size:.9rem;margin:0 0 16px;font-weight:500}.google-places-info-window .info-place-actions{display:flex;flex-direction:column;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid rgba(0,0,0,.08)}.google-places-info-window .favorite-section{display:flex;flex-direction:column;gap:8px;padding:12px;background:#ff6b350d;border-radius:12px;border:1px solid rgba(255,107,53,.15);box-sizing:border-box;width:100%;margin:0}.google-places-info-window .favorite-list-select{width:100%;padding:10px 40px 10px 14px;border:1px solid rgba(255,107,53,.3);border-radius:8px;font-size:.9rem;font-weight:500;background:#fff;color:#333;outline:none;transition:all .3s ease;cursor:pointer;box-shadow:0 2px 4px #0000000d;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:16px}.google-places-info-window .favorite-list-select:hover{border-color:#ff6b3580;box-shadow:0 2px 8px #ff6b351a}.google-places-info-window .favorite-list-select:focus{border-color:#ff6b35;box-shadow:0 0 0 3px #ff6b351a,0 2px 8px #ff6b3526}.restaurant-select-wrapper{position:relative;width:100%;box-sizing:border-box;max-width:100%}.restaurant-select{width:100%;max-width:100%;padding:10px 14px;border:1px solid rgba(255,107,53,.3);border-radius:8px;font-size:.9rem;font-weight:500;background:#fff;color:#333;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease;box-shadow:0 2px 4px #0000000d;box-sizing:border-box}.restaurant-select:hover{border-color:#ff6b3580;box-shadow:0 2px 8px #ff6b351a}.restaurant-select-text{flex:1;color:#333}.restaurant-select-arrow{font-size:.8rem;color:#666;transition:transform .3s ease;margin-left:8px}.restaurant-options{position:absolute;top:100%;left:0;width:100%;max-width:100%;background:#fff;border:1px solid rgba(255,107,53,.3);border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 12px #00000026;z-index:10000;max-height:120px;overflow-y:auto;box-sizing:border-box}.restaurant-option{padding:10px 14px;font-size:.9rem;color:#333;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid rgba(0,0,0,.05)}.restaurant-option:last-child{border-bottom:none}.restaurant-option:hover{background-color:#ff6b351a;color:#ff6b35}.restaurant-option.already-added{background-color:#4caf501a;color:#4caf50;font-weight:500}.restaurant-option.already-added:hover{background-color:#4caf5033;color:#4caf50}.google-places-info-window .add-to-list-btn{width:100%;padding:8px 12px;background:linear-gradient(135deg,#ff6b35,#e55a2b);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:6px}.google-places-info-window .add-to-list-btn:hover{background:linear-gradient(135deg,#e55a2b,#d14d1f);transform:translateY(-1px);box-shadow:0 4px 12px #ff6b354d}.google-places-info-window .favorite-btn{flex:1;padding:8px 12px;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:4px;background:#f0f0f0;color:#666}.google-places-info-window .favorite-btn:hover,.google-places-info-window .favorite-btn.favorited{background:#ff6b35;color:#fff}.google-places-info-window .info-navigate-btn{width:100%;padding:8px 12px;background:linear-gradient(135deg,#007aff,#0056cc);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:6px;margin-top:8px}.google-places-info-window .info-navigate-btn:hover{background:linear-gradient(135deg,#0056cc,#004299);transform:translateY(-1px);box-shadow:0 4px 12px #007aff4d}.google-places-info-window .info-navigate-btn svg{margin-right:0}.gm-style .gm-ui-hover-effect{display:none!important}.gm-style .gmnoprint[title],.gm-style .gm-bundled-control{bottom:140px!important}@media (max-width: 480px){.gm-style .gmnoprint[title],.gm-style .gm-bundled-control{bottom:120px!important}}.google-places-info-window{width:320px!important;max-width:320px!important;min-width:320px!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans TC,sans-serif!important;position:relative;box-sizing:border-box;overflow:hidden;margin:0;padding:0;background:linear-gradient(135deg,#fff,#f8fafc);border-radius:16px;box-shadow:0 12px 40px #0000002e}div.gm-style div.gm-style-iw-d:has(.google-places-info-window){width:320px!important;max-width:320px!important;min-width:320px!important;border-radius:16px!important;box-shadow:0 12px 40px #0000002e!important;overflow-y:auto!important;overflow-x:hidden!important;max-height:70vh!important;padding:0!important;margin:0!important;-webkit-overflow-scrolling:touch!important}div.gm-style div.gm-style-iw-c:has(.google-places-info-window){width:320px!important;max-width:320px!important;border-radius:16px!important;background:linear-gradient(135deg,#fff,#f8fafc)!important;border:1px solid rgba(0,0,0,.08)!important;backdrop-filter:blur(15px)!important;-webkit-backdrop-filter:blur(15px)!important;padding:0!important;margin:0!important}.gm-style .gm-style-iw-chr:has(.google-places-info-window){display:none!important}.gm-style .gm-style-iw-ch[style*="padding-top: 17px"]{padding-top:0!important}.google-places-photo{width:100%!important;height:160px!important;object-fit:cover;display:block;margin:0!important;border-radius:0!important}.google-places-content{padding:16px 20px 20px!important;background:linear-gradient(135deg,#fff,#f8fafc)}.google-places-name{font-size:1.2rem!important;font-weight:700!important;color:#1a202c!important;margin:0 0 8px!important;line-height:1.3!important;letter-spacing:-.02em!important}.google-places-category{font-size:.8rem!important;color:#667eea!important;background:linear-gradient(135deg,#667eea1f,#667eea14)!important;padding:4px 12px!important;border-radius:20px!important;display:inline-block!important;margin:0 0 10px!important;font-weight:600!important;border:1px solid rgba(102,126,234,.15)!important;backdrop-filter:blur(4px)!important;-webkit-backdrop-filter:blur(4px)!important}.google-places-rating{display:flex!important;align-items:center!important;gap:10px!important;margin-bottom:12px!important;padding:8px 12px!important;background:linear-gradient(135deg,#ffc10714,#ffc1070a)!important;border-radius:12px!important;border:1px solid rgba(255,193,7,.2)!important}.google-places-stars{color:#ffc107!important;font-size:1rem!important;letter-spacing:2px!important;text-shadow:0 1px 2px rgba(255,193,7,.3)!important}.google-places-rating-text{color:#4a5568!important;font-size:.9rem!important;font-weight:600!important;margin-left:auto!important}.google-places-address{color:#718096!important;font-size:.9rem!important;margin:0 0 6px!important;line-height:1.5!important;font-weight:500!important;display:flex!important;align-items:flex-start!important;gap:8px!important}.google-places-address:before{content:"📍";font-size:.8rem;margin-top:2px;flex-shrink:0}.google-places-phone{color:#718096!important;font-size:.9rem!important;margin:0 0 16px!important;font-weight:500!important;display:flex!important;align-items:center!important;gap:8px!important}.google-places-phone:before{content:"📞";font-size:.8rem;flex-shrink:0}.google-places-actions{display:flex!important;flex-direction:column!important;gap:12px!important;margin-top:16px!important;padding-top:16px!important;border-top:1px solid rgba(0,0,0,.08)!important}.google-places-favorite-section{display:flex!important;flex-direction:column!important;gap:10px!important;padding:16px!important;background:linear-gradient(135deg,#ff6b350f,#ff6b3508)!important;border-radius:16px!important;border:1px solid rgba(255,107,53,.2)!important;backdrop-filter:blur(8px)!important;-webkit-backdrop-filter:blur(8px)!important}.google-places-select{width:100%!important;padding:12px 16px!important;border:1px solid rgba(255,107,53,.3)!important;border-radius:12px!important;font-size:.9rem!important;font-weight:600!important;background:#ffffffe6!important;color:#333!important;outline:none!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;cursor:pointer!important;box-shadow:0 2px 8px #0000000f!important;backdrop-filter:blur(8px)!important;-webkit-backdrop-filter:blur(8px)!important}.google-places-select:hover{border-color:#ff6b3580!important;box-shadow:0 4px 12px #ff6b3526!important;transform:translateY(-1px)!important}.google-places-select:focus{border-color:#ff6b35!important;box-shadow:0 0 0 3px #ff6b3526,0 4px 16px #ff6b3533!important;transform:translateY(-1px)!important}.google-places-add-btn{width:100%!important;padding:12px 16px!important;background:linear-gradient(135deg,#ff6b35,#e55a2b)!important;color:#fff!important;border:none!important;border-radius:12px!important;font-size:.9rem!important;font-weight:700!important;cursor:pointer!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;box-shadow:0 4px 12px #ff6b354d!important}.google-places-add-btn:hover{background:linear-gradient(135deg,#e55a2b,#d14d1f)!important;transform:translateY(-2px)!important;box-shadow:0 6px 20px #ff6b3566!important}.google-places-favorite-btn{width:100%!important;padding:12px 16px!important;border:1px solid rgba(255,107,53,.3)!important;border-radius:12px!important;font-size:.9rem!important;font-weight:600!important;cursor:pointer!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;background:#ffffffe6!important;color:#666!important;backdrop-filter:blur(8px)!important;-webkit-backdrop-filter:blur(8px)!important;box-shadow:0 2px 8px #0000000f!important}.google-places-favorite-btn:hover{background:linear-gradient(135deg,#ff6b35,#e55a2b)!important;color:#fff!important;border-color:#ff6b35!important;transform:translateY(-1px)!important;box-shadow:0 4px 12px #ff6b354d!important}.google-places-favorite-btn.favorited{background:linear-gradient(135deg,#ff6b35,#e55a2b)!important;color:#fff!important;border-color:#ff6b35!important;box-shadow:0 4px 12px #ff6b354d!important}.google-places-navigate-btn{width:100%!important;padding:12px 16px!important;background:linear-gradient(135deg,#007aff,#0056cc)!important;color:#fff!important;border:none!important;border-radius:12px!important;font-size:.9rem!important;font-weight:700!important;cursor:pointer!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;box-shadow:0 4px 12px #007aff4d!important}.google-places-navigate-btn:hover{background:linear-gradient(135deg,#0056cc,#004299)!important;transform:translateY(-2px)!important;box-shadow:0 6px 20px #007aff66!important}@media (prefers-color-scheme: dark){.map-loading{background:#1e1e1ee6}.map-loading p{color:#ccc}.loading-spinner{border-color:#404040;border-top-color:#ff6b35}.google-places-info-window{background:linear-gradient(135deg,#1a202c,#2d3748)!important}div.gm-style div.gm-style-iw-c:has(.google-places-info-window){background:linear-gradient(135deg,#1a202c,#2d3748)!important;border:1px solid rgba(255,255,255,.1)!important}.google-places-content{background:linear-gradient(135deg,#1a202c,#2d3748)!important}.google-places-name{color:#f7fafc!important}.google-places-category{background:linear-gradient(135deg,#667eea26,#667eea1a)!important;border:1px solid rgba(102,126,234,.25)!important;color:#a0aec0!important}.google-places-rating{background:linear-gradient(135deg,#ffc1071a,#ffc1070d)!important;border:1px solid rgba(255,193,7,.25)!important}.google-places-rating-text,.google-places-address,.google-places-phone{color:#a0aec0!important}.google-places-actions{border-top:1px solid rgba(255,255,255,.1)!important}.google-places-favorite-section{background:linear-gradient(135deg,#ff6b3514,#ff6b350a)!important;border:1px solid rgba(255,107,53,.25)!important}.google-places-select,.google-places-favorite-btn{background:#2d3748e6!important;color:#f7fafc!important;border:1px solid rgba(255,255,255,.1)!important}.google-places-select:focus,.google-places-favorite-btn:hover{border-color:#ff6b3580!important}}@media (max-width: 480px){.google-places-info-window{width:280px!important;max-width:280px!important;min-width:280px!important}div.gm-style div.gm-style-iw-d:has(.google-places-info-window),div.gm-style div.gm-style-iw-c:has(.google-places-info-window){width:280px!important;max-width:280px!important}.google-places-content{padding:14px 16px 18px!important}.google-places-name{font-size:1.1rem!important}.google-places-favorite-section{padding:12px!important}}.map-search-container{position:relative;z-index:1000;width:100%;max-width:400px;margin:0 auto}.map-search-form{width:100%}.search-input-wrapper{position:relative;display:flex;align-items:center;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:18px;box-shadow:0 4px 20px #0000001a;border:1px solid rgba(255,255,255,.3);padding:16px 20px;transition:all .3s ease}.search-input-wrapper:focus-within{background:#fff;box-shadow:0 6px 24px #00000026;border-color:#ff6b35}.search-icon{font-size:1.4rem;color:#666;margin-right:14px;flex-shrink:0}.search-input{flex:1;border:none;outline:none;background:transparent;font-size:1.1rem;color:#333;font-weight:500;padding:0}.search-input::placeholder{color:#999;font-weight:400}.clear-search-btn{background:none;border:none;color:#999;font-size:1.1rem;cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-left:8px;flex-shrink:0;transition:all .2s ease}.clear-search-btn:hover{background:#ff6b351a;color:#ff6b35;transform:scale(1.1)}.search-suggestions{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 8px 32px #0000001f;border:1px solid rgba(255,255,255,.3);overflow:hidden;z-index:1001;max-height:300px;overflow-y:auto}.suggestion-item{display:flex;align-items:flex-start;padding:12px 16px;cursor:pointer;transition:all .2s ease;border-bottom:1px solid rgba(0,0,0,.05)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:#ff6b3514;transform:translate(2px)}.suggestion-item:active{transform:translate(1px);background:#ff6b351f}.suggestion-icon{font-size:1rem;color:#999;margin-right:12px;margin-top:2px;flex-shrink:0}.suggestion-text{flex:1;min-width:0}.suggestion-name{font-size:.95rem;font-weight:600;color:#333;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.suggestion-address{font-size:.85rem;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 375px){.map-search-container{max-width:100%}.search-input-wrapper{padding:12px 16px;border-radius:14px}.search-input{font-size:1rem}.search-icon{font-size:1.2rem;margin-right:12px}.clear-search-btn{font-size:1rem}}@media (max-width: 480px){.map-search-container{max-width:100%}.search-input-wrapper{padding:14px 18px;border-radius:16px}.search-input{font-size:1.05rem}.suggestion-item{padding:10px 14px}.suggestion-name{font-size:.9rem}.suggestion-address{font-size:.8rem}}@keyframes searchPulse{0%,to{opacity:1}50%{opacity:.7}}.search-input-wrapper.loading .search-icon{animation:searchPulse 1.5s ease-in-out infinite}.suggestion-category{padding:8px 16px;font-size:.75rem;font-weight:700;color:#ff6b35;background:#ff6b351a;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,107,53,.2)}.suggestion-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(0,0,0,.1),transparent);margin:4px 0}.restaurant-item{background:linear-gradient(90deg,rgba(255,107,53,.05),transparent)}.restaurant-item:hover{background:linear-gradient(90deg,#ff6b351f,#ff6b350d)}.restaurant-icon{font-size:1.2rem;margin-right:12px;margin-top:2px;flex-shrink:0}.suggestion-details{display:flex;align-items:center;gap:8px;margin-top:4px}.suggestion-category-tag{font-size:.75rem;background:#667eea1a;color:#667eea;padding:2px 6px;border-radius:4px;font-weight:500}.suggestion-rating{font-size:.8rem;color:#ff6b35;font-weight:500}.no-results{padding:24px 16px;text-align:center;color:#666}.no-results-icon{font-size:2rem;margin-bottom:8px;opacity:.6}.no-results-text{font-size:.95rem;font-weight:600;margin-bottom:4px;color:#333}.no-results-hint{font-size:.85rem;color:#999;font-style:italic}@media (max-width: 480px){.suggestion-category{padding:6px 14px;font-size:.7rem}.restaurant-icon{font-size:1.1rem}.suggestion-rating{font-size:.75rem}.no-results{padding:20px 14px}.no-results-icon{font-size:1.8rem}.no-results-text{font-size:.9rem}.no-results-hint{font-size:.8rem}}.location-button{position:relative;width:56px;height:56px;border-radius:16px;border:none;background:#fffffffa;-webkit-backdrop-filter:blur(16px) saturate(180%);backdrop-filter:blur(16px) saturate(180%);box-shadow:0 8px 32px #00000014,0 1px 2px #0000000d,inset 0 1px #ffffff80;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .4s cubic-bezier(.34,1.56,.64,1);overflow:hidden;border:1px solid rgba(255,255,255,.2)}.location-button:hover:not(:disabled){background:#fff;box-shadow:0 16px 48px #00000026,0 8px 16px #0000001a,inset 0 1px #ffffffb3;transform:translateY(-3px) scale(1.05);transition:all .3s cubic-bezier(.4,0,.2,1)}.location-button:active:not(:disabled){transform:translateY(-1px) scale(.95);box-shadow:0 6px 20px #0000001f,0 2px 4px #00000014;transition:all .1s cubic-bezier(.4,0,.6,1)}.location-button:disabled{cursor:not-allowed;opacity:.8}.location-icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.location-icon{font-size:1.6rem;color:#6b7280;transition:all .4s cubic-bezier(.34,1.56,.64,1);z-index:2;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.location-button:hover:not(:disabled) .location-icon{color:#ff6b35;transform:scale(1.1);filter:drop-shadow(0 2px 8px rgba(255,107,53,.4));animation:iconGlow 2s ease-in-out infinite}.location-button.locating{background:linear-gradient(135deg,#ff6b3526,#ff6b350d);box-shadow:0 8px 32px #ff6b3540,0 2px 4px #ff6b3526,inset 0 1px #ffffff80;border:1px solid rgba(255,107,53,.2)}.location-button.locating .location-icon{color:#ff6b35;animation:locatingBreath 2s ease-in-out infinite;filter:drop-shadow(0 2px 8px rgba(255,107,53,.6))}.location-button.relocating{background:linear-gradient(135deg,#3b82f626,#3b82f60d);box-shadow:0 8px 32px #3b82f640,0 2px 4px #3b82f626,inset 0 1px #ffffff80;border:1px solid rgba(59,130,246,.2)}.location-button.relocating .location-icon{color:#3b82f6;animation:relocatingSpin 3s linear infinite;filter:drop-shadow(0 2px 8px rgba(59,130,246,.6))}.location-button.location-found{background:linear-gradient(135deg,#22c55e26,#22c55e0d);box-shadow:0 8px 32px #22c55e40,0 2px 4px #22c55e26,inset 0 1px #ffffff80;border:1px solid rgba(34,197,94,.2)}.location-button.location-found .location-icon{color:#22c55e;transform:scale(1.2);filter:drop-shadow(0 2px 4px rgba(34,197,94,.4))}.location-button.location-found:hover:not(:disabled){background:linear-gradient(135deg,#3b82f633,#3b82f61a);box-shadow:0 12px 40px #3b82f64d,0 4px 8px #3b82f633,inset 0 1px #fff9;border:1px solid rgba(59,130,246,.3)}.location-button.location-found:hover:not(:disabled) .location-icon{color:#3b82f6;transform:scale(1.1);filter:drop-shadow(0 3px 8px rgba(59,130,246,.5));animation:foundPulse 1.5s ease-in-out infinite}.location-button.location-found:active:not(:disabled){transform:scale(.93);box-shadow:0 6px 20px #3b82f640,0 2px 4px #3b82f626;transition:all .1s cubic-bezier(.4,0,.6,1)}.location-pulse-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:30px;height:30px;border:2px solid #ff6b35;border-radius:50%;opacity:.6;animation:rippleEffect 2.5s ease-out infinite}.location-pulse-ring:nth-child(2){animation-delay:.5s;border-color:#ff6b3599}.location-pulse-ring:nth-child(3){animation-delay:1s;border-color:#ff6b3566}.location-pulse-ring:nth-child(4){animation-delay:1.5s;border-color:#ff6b3533}.location-pulse-ring.relocating-ring{border-color:#3b82f6;animation:relocatingRipple 3s ease-out infinite}.location-pulse-ring.relocating-ring:nth-child(2){animation-delay:.75s;border-color:#3b82f699}.location-pulse-ring.relocating-ring:nth-child(3){animation-delay:1.5s;border-color:#3b82f666}.location-pulse-ring.relocating-ring:nth-child(4){animation-delay:2.25s;border-color:#3b82f633}@keyframes rippleEffect{0%{transform:translate(-50%,-50%) scale(.5);opacity:.8}50%{opacity:.4}to{transform:translate(-50%,-50%) scale(2.5);opacity:0}}@keyframes locatingBreath{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.8}}@keyframes relocatingSpin{0%{transform:rotate(0) scale(1)}25%{transform:rotate(90deg) scale(1.05)}50%{transform:rotate(180deg) scale(1)}75%{transform:rotate(270deg) scale(1.05)}to{transform:rotate(360deg) scale(1)}}@keyframes iconGlow{0%,to{filter:drop-shadow(0 2px 8px rgba(255,107,53,.4))}50%{filter:drop-shadow(0 4px 16px rgba(255,107,53,.8))}}@keyframes foundPulse{0%,to{transform:scale(1.1);filter:drop-shadow(0 3px 8px rgba(59,130,246,.5))}50%{transform:scale(1.15);filter:drop-shadow(0 5px 20px rgba(59,130,246,.8))}}@keyframes relocatingRipple{0%{transform:translate(-50%,-50%) scale(.4) rotate(0);opacity:.9}50%{opacity:.5;transform:translate(-50%,-50%) scale(1.5) rotate(180deg)}to{transform:translate(-50%,-50%) scale(3) rotate(360deg);opacity:0}}@media (max-width: 768px){.location-button{width:52px;height:52px;border-radius:10px}.location-icon{font-size:1.4rem}}@media (max-width: 375px){.location-button{width:48px;height:48px;border-radius:12px;min-height:48px;min-width:48px}.location-icon{font-size:1.4rem}.location-button:before{content:"";position:absolute;top:-10px;left:-10px;right:-10px;bottom:-10px;z-index:-1;border-radius:20px}}@media (max-width: 480px){.location-button{width:48px;height:48px;border-radius:12px;min-height:48px;min-width:48px}.location-icon{font-size:1.4rem}.location-button:before{content:"";position:absolute;top:-10px;left:-10px;right:-10px;bottom:-10px;z-index:-1;border-radius:20px}}@media (prefers-contrast: high){.location-button{border:2px solid #333;background:#fff}.location-icon{color:#333}.location-button.locating{background:#fff4e6;border-color:#ff6b35}.location-button.location-found{background:#f0fdf4;border-color:#22c55e}}.map-favorite-lists-container{background:#fffffff2;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-radius:24px;border:1px solid rgba(255,255,255,.6);box-shadow:0 0 0 1px #ff6b3514,0 16px 64px #0000001f,0 8px 32px #ff6b350d;overflow:visible;transition:all .5s cubic-bezier(.25,.46,.45,.94);max-height:72px;position:relative}.map-favorite-lists-container.open{max-height:85vh;box-shadow:0 0 0 1px #ff6b351f,0 24px 80px #0000002e,0 12px 48px #ff6b3514;overflow:hidden}.map-favorite-lists-container:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(255,107,53,.4),rgba(255,107,53,.6),rgba(255,107,53,.4),transparent);border-radius:24px 24px 0 0}.map-favorite-lists-container:after{content:"";position:absolute;top:-1px;left:-1px;right:-1px;bottom:-1px;background:linear-gradient(135deg,rgba(255,107,53,.1) 0%,transparent 30%,transparent 70%,rgba(255,107,53,.05) 100%);border-radius:24px;z-index:-1;opacity:0;transition:opacity .3s ease}.map-favorite-lists-container:hover:after{opacity:1}.map-list-notification{position:absolute;top:-80px;left:0;right:0;background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;border:1px solid rgba(255,255,255,.4);box-shadow:0 8px 32px #00000026;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;z-index:1000;animation:slideDownFadeIn .4s cubic-bezier(.4,0,.2,1)}.map-list-notification.success{border-left:4px solid #22c55e;background:linear-gradient(135deg,#22c55e0d,#fffffffa)}.map-list-notification.error{border-left:4px solid #ef4444;background:linear-gradient(135deg,#ef44440d,#fffffffa)}.map-list-notification.warning{border-left:4px solid #f59e0b;background:linear-gradient(135deg,#f59e0b0d,#fffffffa)}.map-notification-content{display:flex;align-items:center;gap:8px;flex:1}.map-notification-icon{font-size:1.2rem}.map-list-notification.success .map-notification-icon{color:#22c55e}.map-list-notification.error .map-notification-icon{color:#ef4444}.map-list-notification.warning .map-notification-icon{color:#f59e0b}.map-notification-message{font-size:.9rem;font-weight:500;color:#333}.map-notification-dismiss{background:none;border:none;color:#666;font-size:1rem;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.map-notification-dismiss:hover{background:#0000000d;color:#333}@keyframes slideDownFadeIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.map-lists-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#666}.map-lists-loading .map-loading-spinner{width:32px;height:32px;border:3px solid #f0f0f0;border-top:3px solid #ff6b35;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.map-lists-loading span{font-size:.9rem;font-weight:500}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes glow{0%,to{box-shadow:0 0 5px #ff6b354d}50%{box-shadow:0 0 20px #ff6b3599}}@media (prefers-color-scheme: dark){.map-favorite-lists-container{background:#1a202cf2;border-color:#4a556866}.map-lists-header{background:linear-gradient(135deg,#2d3748cc,#1a202c99)}.map-header-title{color:#f7fafc}.map-lists-count{background:#374151cc;color:#d1d5db}.map-list-item{background:linear-gradient(135deg,#2d3748cc,#1a202c99)}.map-list-name{color:#f7fafc}.map-place-item{background:linear-gradient(135deg,#2d3748b3,#1a202c80)}.map-place-name{color:#f7fafc}.map-place-address{color:#a0aec0}}.map-lists-header{padding:22px 28px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:all .4s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;background:linear-gradient(135deg,#fffc,#fff6);border-radius:24px 24px 0 0}.map-lists-header:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(120deg,transparent 0%,rgba(255,107,53,.12) 40%,rgba(255,107,53,.18) 50%,rgba(255,107,53,.12) 60%,transparent 100%);transition:left .8s cubic-bezier(.25,.46,.45,.94)}.map-lists-header:hover:after{left:100%}.map-lists-header:hover{background:linear-gradient(135deg,#ff6b3514,#ff6b350a);transform:translateY(-1px)}.map-header-content{display:flex;align-items:center;gap:12px}.map-header-icon{font-size:1.4rem;color:#ff6b35;transition:all .4s cubic-bezier(.25,.46,.45,.94);filter:drop-shadow(0 2px 4px rgba(255,107,53,.2))}.map-lists-header:hover .map-header-icon{transform:scale(1.15) rotate(5deg);color:#e55a2b;filter:drop-shadow(0 4px 8px rgba(255,107,53,.3))}.map-header-title{margin:0;font-size:1.2rem;font-weight:800;color:#2d3748;letter-spacing:-.03em;text-shadow:0 1px 2px rgba(0,0,0,.05);transition:color .3s ease}.map-lists-header:hover .map-header-title{color:#1a202c}.map-lists-count{font-size:.8rem;color:#6b7280;font-weight:500;background:#f3f4f6;padding:2px 8px;border-radius:12px;margin-left:8px;transition:all .2s ease;min-width:20px;text-align:center}.map-lists-header:hover .map-lists-count{background:#e5e7eb;color:#4b5563}.map-chevron-icon{font-size:1.1rem;color:#718096;transition:all .4s cubic-bezier(.25,.46,.45,.94);filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.map-chevron-icon.rotated{transform:rotate(180deg) scale(1.1);color:#ff6b35}.map-lists-header:hover .map-chevron-icon{color:#ff6b35;transform:scale(1.1)}.map-lists-header:hover .map-chevron-icon.rotated{transform:rotate(180deg) scale(1.2)}.favorite-lists-container .map-lists-content{padding:4px 28px 28px;max-height:calc(85vh - 140px);overflow-y:auto;opacity:0;transform:translateY(-15px);transition:all .5s cubic-bezier(.25,.46,.45,.94) .1s;background:linear-gradient(180deg,rgba(255,255,255,.02) 0%,transparent 100%)}.map-favorite-lists-container.open .map-lists-content{opacity:1;transform:translateY(0)}.map-list-item{animation:slideInFromRight .4s cubic-bezier(.25,.46,.45,.94) forwards;opacity:0;transform:translate(20px)}.map-list-item:nth-child(1){animation-delay:.1s}.map-list-item:nth-child(2){animation-delay:.15s}.map-list-item:nth-child(3){animation-delay:.2s}.map-list-item:nth-child(4){animation-delay:.25s}.map-list-item:nth-child(5){animation-delay:.3s}@keyframes slideInFromRight{to{opacity:1;transform:translate(0)}}.map-place-item{animation:slideInFromLeft .4s cubic-bezier(.25,.46,.45,.94) forwards;opacity:0;transform:translate(-20px)}.map-place-item:nth-child(1){animation-delay:.1s}.map-place-item:nth-child(2){animation-delay:.15s}.map-place-item:nth-child(3){animation-delay:.2s}.map-place-item:nth-child(4){animation-delay:.25s}.map-place-item:nth-child(5){animation-delay:.3s}@keyframes slideInFromLeft{to{opacity:1;transform:translate(0)}}.map-lists-selector{margin-bottom:20px;padding-top:8px;overflow-x:hidden}.fav-list-item-wrapper{position:relative;margin:0 0 14px;overflow:hidden;border-radius:14px;background:linear-gradient(135deg,#3b82f608,#ffffffe6);box-shadow:0 2px 10px #0000000d;transition:all .3s cubic-bezier(.4,0,.2,1)}.fav-list-item-wrapper:hover{box-shadow:0 4px 18px #3b82f626;transform:translateY(-1px)}.fav-list-item{background:#fff;border-radius:14px;padding:16px;cursor:pointer;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .3s ease;border:2px solid transparent;position:relative;z-index:1;overflow:hidden}.fav-list-item.swiped{transform:translate(-106px)}.fav-list-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(59,130,246,.1) 40%,rgba(59,130,246,.15) 50%,rgba(59,130,246,.1) 60%,transparent 100%);transition:left .5s ease;pointer-events:none}.fav-list-item:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#3b82f60d,#3b82f605);opacity:0;transition:opacity .3s ease;pointer-events:none;border-radius:14px}.fav-list-item:hover:not(.swiped){transform:translateY(-1px);box-shadow:0 3px 14px #0000001a}.fav-list-item:hover.swiped{box-shadow:0 3px 14px #0000001a}.fav-list-item:hover:before{left:100%}.fav-list-item:hover:after{opacity:1}.fav-list-item.selected:not(.swiped){border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#fff);opacity:1!important;transform:none!important;animation:none!important;box-shadow:0 0 0 3px #3b82f61f,0 4px 14px #3b82f633}.fav-list-item.selected.swiped{border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#fff);opacity:1!important;animation:none!important;box-shadow:0 0 0 3px #3b82f61f,0 4px 14px #3b82f633}.fav-list-item.selected:after{opacity:1}.fav-list-card-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.fav-list-card-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0;padding-left:4px}.fav-list-card-details{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0;overflow:hidden}.fav-list-color-dot{width:15px;height:15px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 2px #ffffffe6,0 0 0 3px #00000014,0 4px 12px #00000026,inset 0 1px 3px #ffffff80,inset 0 -1px 2px #00000026;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative}.fav-list-color-dot:before{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:50%;background:linear-gradient(135deg,rgba(255,255,255,.4) 0%,transparent 50%,rgba(0,0,0,.1) 100%);pointer-events:none}.fav-list-color-dot:after{content:"";position:absolute;top:2px;left:3px;width:4px;height:4px;border-radius:50%;background:#fff9;filter:blur(1px);pointer-events:none}.fav-list-item:hover .fav-list-color-dot{transform:scale(1.2);box-shadow:0 0 0 3px #fff,0 0 0 4px #0000001f,0 6px 20px #00000040,inset 0 1px 3px #fff9,inset 0 -1px 2px #0003}.fav-list-item.selected .fav-list-color-dot{transform:scale(1.15);box-shadow:0 0 0 3px #fff,0 0 0 4px #3b82f64d,0 6px 18px #0003,0 0 12px #3b82f666,inset 0 1px 3px #fff9,inset 0 -1px 2px #0003}.fav-list-name{margin:0;font-size:.98rem;font-weight:650;color:#2d3748;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em}.fav-list-item:hover .fav-list-name{color:#1a202c}.fav-list-item.selected .fav-list-name{color:#1e40af;font-weight:700}.fav-list-count{margin:0;font-size:.78rem;color:#94a3b8;font-weight:500}.fav-list-item:hover .fav-list-count{color:#64748b}.fav-list-item.selected .fav-list-count{color:#3b82f6;font-weight:600}.fav-edit-input{border:none;outline:none;background:#3b82f60d;font-size:.98rem;font-weight:650;color:#2d3748;padding:5px 10px;border-radius:7px;border:2px solid #3b82f6;width:100%;transition:all .2s ease}.fav-edit-input:focus{background:#3b82f614;box-shadow:0 0 0 3px #3b82f626}.fav-list-card-menu{position:relative;flex-shrink:0;z-index:2}.fav-list-menu-trigger{background:transparent;border:none;padding:8px;border-radius:8px;cursor:pointer;font-size:1.05rem;color:#94a3b8;transition:all .2s ease;display:flex;align-items:center;justify-content:center;opacity:1;position:relative;width:30px;height:30px}.fav-list-menu-trigger:hover{background:#0000000d;color:#1a1a1a;transform:scale(1.1)}.fav-list-menu-trigger:active{transform:scale(.95);background:#00000014}.map-list-card-actions{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:100;min-width:120px;max-width:140px;opacity:0;visibility:hidden;transform:translate(10px);transition:all .2s ease}.map-list-card-actions.show{opacity:1;visibility:visible;transform:translate(0)}.map-list-action-btn .map-action-icon{font-size:.9rem;width:16px;text-align:center}.map-list-action-btn{background:none;border:none;padding:12px 16px;cursor:pointer;font-size:.9rem;transition:all .2s ease;display:flex;align-items:center;gap:8px;width:100%;text-align:left;border-radius:0}.map-list-action-btn:first-child{border-radius:8px 8px 0 0}.map-list-action-btn:last-child{border-radius:0 0 8px 8px}.map-list-action-btn:only-child{border-radius:8px}.map-list-action-btn:not(:last-child){border-bottom:1px solid #f0f0f0}.map-list-action-btn.map-edit-btn{color:#666}.map-list-action-btn.map-edit-btn:hover{background:#6666661a;color:#333}.map-list-action-btn.map-delete-btn{color:#ef4444}.map-list-action-btn.map-delete-btn:hover{background:#ef44441a;color:#dc2626}.fav-swipe-actions{position:absolute;top:0;right:0;bottom:0;width:106px;display:flex;gap:4px;z-index:0;border-radius:0 14px 14px 0;padding:10px 3px 10px 9px;align-items:center;justify-content:center}.fav-swipe-btn{flex:1;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 3px;border-radius:7px;transition:all .2s ease;font-size:.65rem;font-weight:600;color:#fff;min-height:52px;max-width:45px}.fav-swipe-btn svg{font-size:1.1rem;transition:transform .2s ease}.fav-swipe-btn:hover svg{transform:scale(1.15)}.fav-swipe-btn span{font-size:.65rem;letter-spacing:0;white-space:nowrap}.fav-swipe-btn.fav-edit-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 8px #3b82f64d}.fav-swipe-btn.fav-edit-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.fav-swipe-btn.fav-edit-btn:active{transform:translateY(0)}.fav-swipe-btn.fav-delete-btn{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef44444d}.fav-swipe-btn.fav-delete-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.fav-swipe-btn.fav-delete-btn:active{transform:translateY(0)}.map-add-list-btn{width:100%;padding:16px 20px;background:linear-gradient(135deg,#fffc,#f8fafc80);border:2px dashed rgba(255,107,53,.4);border-radius:18px;color:#718096;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .4s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #0000000a}.map-add-list-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,107,53,.12) 40%,rgba(255,107,53,.18) 50%,rgba(255,107,53,.12) 60%,transparent 100%);transition:left .8s ease}.map-add-list-btn:after{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(135deg,rgba(255,107,53,.2) 0%,transparent 30%,transparent 70%,rgba(255,107,53,.1) 100%);border-radius:18px;opacity:0;transition:opacity .4s ease;z-index:-1}.map-add-list-btn:hover{border-color:#ff6b35;color:#ff6b35;background:linear-gradient(135deg,#ff6b351a,#ff6b350d);transform:translateY(-3px) scale(1.02);box-shadow:0 8px 24px #ff6b352e,0 4px 12px #00000014}.map-add-list-btn:hover:before{left:100%}.map-add-list-btn:hover:after{opacity:1}.map-add-list-btn:active{transform:translateY(-1px) scale(1.01);transition:all .1s ease}.map-create-list-form{padding:16px;margin:0 0 12px;background:linear-gradient(135deg,#ff6b3514,#ff6b350a);border-radius:12px;border:1px solid rgba(255,107,53,.25);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 16px #ff6b351a,0 2px 8px #0000000d;position:relative;overflow:hidden}.map-create-list-form:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#ff6b3566,#ff6b35cc,#ff6b3566)}.map-new-list-input{width:100%;padding:12px 16px;border:2px solid rgba(255,107,53,.2);border-radius:12px;font-size:1rem;margin-bottom:16px;outline:none;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s cubic-bezier(.25,.46,.45,.94);font-weight:500;color:#2d3748;box-sizing:border-box}.map-new-list-input:focus{border-color:#ff6b35;background:#fff;box-shadow:0 0 0 3px #ff6b3526,0 4px 16px #ff6b351a;transform:translateY(-1px)}.map-new-list-input::placeholder{color:#a0aec0;font-weight:400}.map-form-actions{display:flex;gap:8px}.map-confirm-btn,.map-cancel-btn{flex:1;padding:12px 16px;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;box-sizing:border-box}.map-confirm-btn:before,.map-cancel-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.map-confirm-btn:hover:before,.map-cancel-btn:hover:before{left:100%}.map-confirm-btn{background:linear-gradient(135deg,#ff6b35,#e55a2b);color:#fff;box-shadow:0 4px 12px #ff6b354d}.map-confirm-btn:hover{background:linear-gradient(135deg,#e55a2b,#d14d1f);transform:translateY(-2px);box-shadow:0 6px 20px #ff6b3566}.map-cancel-btn{background:linear-gradient(135deg,#f8fafce6,#edf2f7cc);color:#718096;border:1px solid rgba(226,232,240,.8);box-shadow:0 2px 8px #0000000d}.map-cancel-btn:hover{background:linear-gradient(135deg,#edf2f7,#e2e8f0e6);color:#4a5568;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.map-current-list-content{border-top:1px solid #eee;padding-top:16px}.map-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.map-list-title{margin:0;font-size:1rem;font-weight:600;color:#333}.map-places-list{max-height:200px;overflow-y:auto;border-radius:14px;background:#ffffff80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px}.map-empty-list{text-align:center;padding:24px 16px;color:#666}.map-empty-icon{font-size:2rem;color:#ccc;margin-bottom:8px}.map-empty-list p{margin:4px 0;font-size:.9rem}.map-empty-hint{font-size:.8rem;color:#999}.map-place-item{display:flex;align-items:center;gap:16px;padding:14px 18px;margin-bottom:12px;background:linear-gradient(135deg,#fffc,#f8fafc99);border-radius:14px;border:1px solid rgba(255,255,255,.9);transition:all .4s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 1px 4px #00000005}.map-place-item:hover{background:linear-gradient(135deg,#fffffff2,#f8fafccc);transform:translateY(-2px);box-shadow:0 4px 12px #0000000f,0 2px 6px #0000000a;border-color:#00000026}.map-place-image{width:52px;height:52px;object-fit:cover;border-radius:14px;flex-shrink:0;border:2px solid rgba(255,255,255,.9);box-shadow:0 2px 8px #0000000f,0 1px 4px #0000000a;transition:all .4s cubic-bezier(.25,.46,.45,.94);position:relative}.map-place-item:hover .map-place-image{transform:scale(1.05);box-shadow:0 3px 12px #00000014,0 2px 6px #0000000f}.map-place-image-fallback{width:52px;height:52px;border-radius:14px;flex-shrink:0;border:2px solid rgba(255,255,255,.9);box-shadow:0 2px 8px #0000000f,0 1px 4px #0000000a;background:linear-gradient(135deg,#f8f9fa,#e9ecef);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#adb5bd;transition:all .4s cubic-bezier(.25,.46,.45,.94)}.map-place-item:hover .map-place-image-fallback{transform:scale(1.05);box-shadow:0 3px 12px #00000014,0 2px 6px #0000000f;background:linear-gradient(135deg,#e9ecef,#dee2e6);color:#868e96}.map-place-info{flex:1;min-width:0}.map-place-name{margin:0 0 3px;font-size:.95rem;font-weight:600;color:#2d3748;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em;transition:color .3s ease}.map-place-item:hover .map-place-name{color:#1a202c}.map-place-address{margin:0 0 6px;font-size:.8rem;color:#718096;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3;transition:color .3s ease}.map-place-item:hover .map-place-address{color:#4a5568}.map-place-rating{display:flex;align-items:center;gap:6px}.map-rating-stars{font-size:.75rem;color:#f6ad55;filter:drop-shadow(0 1px 2px rgba(246,173,85,.3));transition:all .3s ease}.map-place-item:hover .map-rating-stars{transform:scale(1.02)}.map-rating-value{font-size:.8rem;color:#718096;font-weight:600;transition:color .3s ease}.map-place-item:hover .map-rating-value{color:#4a5568}.map-remove-place-btn{background:#ffffffe6;border:1px solid rgba(239,68,68,.2);padding:8px;border-radius:10px;cursor:pointer;color:#e53e3e;font-size:.95rem;transition:all .3s cubic-bezier(.25,.46,.45,.94);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #ef44441a;position:relative;overflow:hidden}.map-remove-place-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s ease}.map-place-actions{display:flex;gap:8px;opacity:0;transform:translate(10px);transition:all .3s cubic-bezier(.25,.46,.45,.94)}.map-place-item:hover .map-place-actions{opacity:1;transform:translate(0)}.map-navigate-place-btn{background:#ffffffe6;border:1px solid rgba(0,122,255,.2);padding:8px;border-radius:10px;cursor:pointer;color:#007aff;font-size:.95rem;transition:all .3s cubic-bezier(.25,.46,.45,.94);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #007aff1a;position:relative;overflow:hidden}.map-navigate-place-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s ease}.map-navigate-place-btn:hover{background:linear-gradient(135deg,#007aff26,#007aff14);border-color:#007aff66;color:#005bb5;transform:translateY(-2px) scale(1.05);box-shadow:0 4px 16px #007aff33}.map-navigate-place-btn:hover:before{left:100%}.map-navigate-place-btn:active{transform:translateY(-1px) scale(1.02);transition:all .1s ease}.map-place-item:hover .map-remove-place-btn{opacity:1;transform:translate(0)}.map-remove-place-btn:hover{background:linear-gradient(135deg,#ef444426,#ef444414);color:#c53030;transform:translateY(-2px) scale(1.05);box-shadow:0 4px 16px #ef444433;border-color:#ef44444d}.map-remove-place-btn:hover:before{left:100%}.map-favorite-lists-container .map-lists-content::-webkit-scrollbar,.map-favorite-lists-container .map-places-list::-webkit-scrollbar{width:4px}.map-favorite-lists-container .map-lists-content::-webkit-scrollbar-track,.map-favorite-lists-container .map-places-list::-webkit-scrollbar-track{background:transparent}.map-favorite-lists-container .map-lists-content::-webkit-scrollbar-thumb,.map-favorite-lists-container .map-places-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.map-favorite-lists-container .map-lists-content::-webkit-scrollbar-thumb:hover,.map-favorite-lists-container .map-places-list::-webkit-scrollbar-thumb:hover{background:#999}@media (max-width: 768px){.map-favorite-lists-container{border-radius:20px;max-height:68px}.map-favorite-lists-container.open{max-height:90vh}.map-lists-header{padding:18px 22px}.map-header-title{font-size:1.1rem}.map-favorite-lists-container .map-lists-content{padding:4px 22px 22px;max-height:calc(90vh - 120px)}.map-list-item{padding:14px 16px}.map-place-item{padding:12px 14px;gap:14px}.map-place-image{width:46px;height:46px}.map-list-menu-trigger{opacity:1;padding:6px;font-size:.9rem}.map-create-list-form{padding:14px 16px}}@media (max-width: 480px){.map-favorite-lists-container{border-radius:18px;max-height:64px}.map-favorite-lists-container.open{max-height:95vh}.map-lists-header{padding:16px 20px}.map-header-icon{font-size:1.2rem}.map-header-title{font-size:1rem}.map-lists-count{font-size:.75rem;padding:2px 6px;margin-left:6px}.map-favorite-lists-container .map-lists-content{padding:4px 20px 20px;max-height:calc(95vh - 110px)}.map-list-item{padding:12px 14px;margin-bottom:10px;border-radius:14px}.map-list-color-dot{width:14px;height:14px}.map-list-name{font-size:.9rem}.map-list-count{font-size:.8rem;padding:1px 6px}.map-place-item{padding:10px 12px;gap:12px;border-radius:10px}.map-place-image{width:40px;height:40px;border-radius:10px}.map-place-name{font-size:.85rem}.map-place-address{font-size:.75rem}.map-rating-stars{font-size:.7rem}.map-rating-value{font-size:.75rem}.map-list-menu-trigger{opacity:1;padding:6px;font-size:.85rem}.map-add-list-btn{padding:14px 16px;font-size:.9rem;gap:10px}.map-new-list-input{padding:10px 14px;font-size:.9rem}.map-confirm-btn,.map-cancel-btn{padding:10px 14px;font-size:.85rem}.map-create-list-form{padding:12px 14px;margin-bottom:10px;border-radius:14px}.map-place-actions{opacity:1;transform:translate(0);gap:6px}.map-navigate-place-btn,.map-remove-place-btn{padding:6px;font-size:.85rem}.map-places-list{border-radius:10px;padding:6px}.map-place-image-fallback{width:40px;height:40px;border-radius:10px;font-size:1.2rem}.map-list-notification{top:-70px;padding:10px 14px}.map-notification-message{font-size:.85rem}}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .3s ease-out;box-sizing:border-box}.confirm-dialog{background:#fff;border-radius:20px;box-shadow:0 20px 40px #00000026;width:100%;max-width:420px;overflow:hidden;animation:modalSlideUp .3s ease-out;margin:0;box-sizing:border-box;border:1px solid rgba(102,126,234,.1)}.dialog-header{padding:28px 24px 18px;text-align:center;border-bottom:1px solid #f0f0f0;box-sizing:border-box;position:relative}.dialog-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:20px 20px 0 0}.dialog-icon-wrapper{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;box-shadow:0 6px 18px #0000001f;transition:all .3s ease;animation:iconPulse 2s ease-in-out infinite}.dialog-icon-svg{font-size:30px}@keyframes iconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.dialog-icon-wrapper.warning{background:linear-gradient(135deg,#fef3c7,#fde68a,#fcd34d);color:#d97706;border:2px solid rgba(217,119,6,.2)}.dialog-icon-wrapper.danger{background:linear-gradient(135deg,#fed7d7,#fecaca,#fca5a5);color:#dc2626;border:2px solid rgba(220,38,38,.2)}.dialog-icon-wrapper.info{background:linear-gradient(135deg,#dbeafe,#bfdbfe,#93c5fd);color:#2563eb;border:2px solid rgba(37,99,235,.2)}.dialog-icon-wrapper.logout-type{background:linear-gradient(135deg,#e0e7ff,#c7d2fe,#a5b4fc);color:#667eea;border:2px solid rgba(102,126,234,.2)}.dialog-title{font-size:20px;font-weight:700;color:#2d3748;margin:0;letter-spacing:-.02em}.dialog-content{padding:20px 32px 28px;box-sizing:border-box}.dialog-message{font-size:16px;color:#4a5568;line-height:1.7;text-align:center;margin:0;font-weight:400}.dialog-actions{display:flex;gap:16px;padding:0 32px 32px;box-sizing:border-box}.dialog-button{flex:1;padding:14px 24px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px;min-height:48px;box-shadow:0 2px 8px #0000001a}.cancel-button{background:#f7fafc;color:#4a5568;border:2px solid #e2e8f0}.cancel-button:hover{background:#edf2f7;color:#2d3748;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.confirm-button{color:#fff}.confirm-button.warning{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 12px #d977064d}.confirm-button.warning:hover{background:linear-gradient(135deg,#b45309,#92400e);transform:translateY(-2px);box-shadow:0 6px 16px #d9770666}.confirm-button.danger{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #dc26264d}.confirm-button.danger:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);transform:translateY(-2px);box-shadow:0 6px 16px #dc262666}.confirm-button.info{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #2563eb4d}.confirm-button.info:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-2px);box-shadow:0 6px 16px #2563eb66}.confirm-button.logout-type{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea4d}.confirm-button.logout-type:hover{background:linear-gradient(135deg,#5a6fd8,#6b4190);transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.dialog-button:active{transform:translateY(0)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(50px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 480px){.confirm-dialog-overlay{padding:16px}.confirm-dialog{max-width:none;width:100%;border-radius:12px}.dialog-header{padding:24px 20px 16px}.dialog-icon-wrapper{width:48px;height:48px;margin-bottom:10px}.dialog-icon-svg{font-size:24px}.dialog-title{font-size:18px}.dialog-content{padding:16px 24px 24px}.dialog-message{font-size:15px}.dialog-actions{padding:0 24px 24px;gap:12px}.dialog-button{padding:12px 20px;font-size:14px;min-height:44px}}@media (prefers-color-scheme: dark){.confirm-dialog{background:#2d3748}.dialog-header{border-bottom-color:#ffffff1a}.dialog-title{color:#f7fafc}.dialog-message{color:#e2e8f0}.cancel-button{background:#4a5568;color:#f7fafc;border-color:#ffffff1a}.cancel-button:hover{background:#2d3748}}.restaurant-reviews{width:100%;max-width:100%;padding:16px;background:#fff;box-sizing:border-box;overflow-x:hidden}.rating-summary-gmaps{display:flex;align-items:center;padding:24px 20px;background:#fff;border-bottom:1px solid #e8eaed;margin-bottom:20px;width:100%;max-width:100%;box-sizing:border-box}.rating-score{display:flex;flex-direction:column;align-items:center;gap:8px}.score-number{font-size:56px;font-weight:400;color:#202124;line-height:1}.rating-stars-large{display:flex;gap:2px}.rating-stars-large .stars{font-size:20px;gap:2px}.rating-stars-large .filled{color:#fbbc04}.rating-stars-large .empty{color:#e8eaed}.restaurant-reviews .rating-count-text{font-size:14px;color:#5f6368;margin-top:4px}.stars .filled{color:gold;filter:drop-shadow(0 1px 2px rgba(255,215,0,.3))}.stars .empty{color:#e0e0e0}.stars.interactive .filled,.stars.interactive .empty{transition:all .2s}.stars.interactive span:hover{transform:scale(1.2)}.review-form{background:#fff;padding:20px;margin-bottom:24px;border:1px solid #e8eaed;border-radius:8px;width:100%;max-width:100%;box-sizing:border-box}.form-header{display:flex;justify-content:center;align-items:center;margin-bottom:16px}.form-header h4{margin:0;font-size:16px;font-weight:500;color:#202124;text-align:center}.cancel-btn{background:none;border:none;color:#1a73e8;cursor:pointer;font-size:14px;padding:8px 16px;border-radius:4px;transition:all .2s;font-weight:500}.cancel-btn:hover{background:#e8f0fe}.rating-input{margin-bottom:16px}.rating-input label{display:block;margin-bottom:12px;font-size:14px;font-weight:500;color:#202124}.comment-input{position:relative;margin-bottom:16px;width:100%;box-sizing:border-box}.comment-input textarea{width:100%;max-width:100%;padding:12px 16px;border:1px solid #dadce0;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;transition:border-color .2s;color:#202124;line-height:1.5;box-sizing:border-box}.comment-input textarea:focus{outline:none;border-color:#1a73e8;border-width:2px;padding:11px 15px;box-sizing:border-box}.comment-input textarea::placeholder{color:#5f6368}.char-count{position:absolute;bottom:12px;right:16px;font-size:12px;color:#5f6368;background:#fffffff2;padding:2px 6px;border-radius:4px}.submit-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;background:#1a73e8;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;margin-left:auto}.submit-btn:hover:not(:disabled){background:#1765cc;box-shadow:0 1px 3px #0000001f,0 1px 2px #0000003d}.submit-btn:disabled{opacity:.5;cursor:not-allowed;background:#dadce0;color:#80868b}.login-prompt{text-align:center;padding:20px;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;margin-bottom:20px;font-size:14px}.already-reviewed-notice{display:flex;align-items:center;gap:16px;padding:20px;background:linear-gradient(135deg,#667eea14,#764ba214);border:1.5px solid rgba(102,126,234,.3);border-radius:12px;margin-bottom:20px;box-shadow:0 2px 8px #667eea1a}.notice-icon{flex-shrink:0;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;box-shadow:0 4px 12px #667eea40}.notice-content{flex:1}.notice-content h4{margin:0 0 8px;font-size:16px;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.notice-content p{margin:0;font-size:14px;color:#5f6368;line-height:1.5}.reviews-list{display:flex;flex-direction:column;gap:16px;width:100%;max-width:100%;box-sizing:border-box}.loading,.no-reviews{text-align:center;padding:40px 20px;color:#6c757d;font-size:14px}.review-item{padding:20px;background:#fff;border-radius:12px;border:1px solid rgba(102,126,234,.12);margin-bottom:16px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #667eea0a;position:relative;overflow:hidden}.review-item:before{display:none}.review-item:hover{background:#fff;border-color:#667eea59;box-shadow:0 0 0 3px #667eea1a,0 12px 32px #667eea2e;transform:scale(1.01)}.review-item:active{transform:scale(.98);box-shadow:0 2px 8px #667eea14}.review-item:last-child{margin-bottom:0}.review-header{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:space-between;align-items:flex-start;margin-bottom:16px;width:100%}.review-item .user-info{display:flex;gap:12px;align-items:flex-start;flex:1 1 auto;min-width:0;padding:0;background:transparent;border:none}.review-right-section{display:flex;flex-direction:column;align-items:flex-end;gap:10px;flex:0 0 auto;flex-shrink:0;margin-left:16px}.review-rating{display:flex;justify-content:flex-end;align-items:center}.user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(102,126,234,.15);box-shadow:0 2px 8px #667eea1a}.user-avatar-placeholder{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:15px;border:2px solid rgba(255,255,255,.3);box-shadow:0 2px 8px #667eea33}.user-details{display:flex;flex-direction:column;gap:2px}.user-name{font-weight:600;color:#202124;font-size:14.5px;letter-spacing:-.1px}.review-date{font-size:12px;color:#5f6368;font-weight:500}.review-item .delete-btn{background:#ef444414;border:1.5px solid transparent;cursor:pointer;padding:8px;border-radius:10px;transition:all .25s cubic-bezier(.4,0,.2,1);font-size:24px;color:#ef4444;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.review-item .delete-btn:hover{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#ef44444d;color:#dc2626;transform:scale(1.08);box-shadow:0 4px 12px #ef444433}.review-item .delete-btn:active{transform:scale(.95)}.review-content{margin-top:12px;padding:16px 20px;background:linear-gradient(135deg,#f8f9fa99,#f1f3f599);border-radius:12px;border:1px solid rgba(102,126,234,.08);position:relative;text-align:left}.review-content:before{content:'"';position:absolute;top:8px;left:16px;font-size:28px;color:#667eea26;font-family:Georgia,serif;font-weight:700;line-height:1}.review-comment{color:#4a5568;line-height:1.7;font-size:14px;white-space:pre-wrap;word-break:break-word;max-width:100%;overflow-wrap:break-word}.show-more-btn{background:linear-gradient(135deg,#667eea14,#764ba214);border:1px solid rgba(102,126,234,.2);color:#667eea;font-size:13px;font-weight:600;cursor:pointer;padding:6px 14px;margin-top:8px;border-radius:8px;transition:all .25s cubic-bezier(.4,0,.2,1);letter-spacing:.2px}@media (max-width: 768px){.restaurant-reviews{padding:12px}.rating-summary{flex-direction:column;align-items:flex-start;gap:12px}.review-header{flex-direction:row!important;flex-wrap:nowrap!important;gap:8px}.review-item .user-info{min-width:0;flex:1;padding:0;background:transparent;border:none}.review-right-section{flex-shrink:0;margin-left:8px}.review-item .delete-btn{width:40px;height:40px;font-size:24px;padding:8px}.stars{font-size:16px;gap:3px}}.restaurant-detail-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;overflow-y:auto;overflow-x:hidden;box-sizing:border-box}.restaurant-detail-modal{position:relative;background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;overflow-x:hidden;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out;box-sizing:border-box;-webkit-tap-highlight-color:transparent}.restaurant-detail-modal *{-webkit-tap-highlight-color:transparent}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.close-btn{position:absolute;top:16px;right:16px;background:#ffffffe6;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;color:#333;transition:all .2s;z-index:10;box-shadow:0 2px 8px #00000026}.close-btn:hover{background:#fff;transform:rotate(90deg)}.restaurant-image{width:100%;height:250px;overflow:hidden;border-radius:16px 16px 0 0}.restaurant-info{padding:24px;border-bottom:1px solid #e9ecef;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-tap-highlight-color:transparent}.restaurant-name{margin:0 0 16px;font-size:24px;font-weight:700;color:#333;user-select:text;-webkit-user-select:text}.restaurant-address{display:flex;align-items:center;gap:8px;margin-bottom:16px;color:#6c757d;font-size:14px;user-select:text;-webkit-user-select:text}.restaurant-address svg{font-size:18px;color:#667eea;user-select:none;-webkit-user-select:none}.rating-summary-in-info{display:flex;align-items:center;gap:16px;padding:16px 0;margin-bottom:16px;border-top:1px solid #f0f0f0;border-bottom:1px solid #f0f0f0;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.rating-summary-in-info .rating-score{display:flex;align-items:center;gap:12px;-webkit-user-select:none;user-select:none}.rating-summary-in-info .score-number{font-size:48px;font-weight:400;color:#202124;line-height:1;-webkit-user-select:none;user-select:none}.rating-summary-in-info .rating-stars-large{display:flex;flex-direction:column;gap:4px;-webkit-user-select:none;user-select:none}.rating-summary-in-info .rating-stars-large .stars{display:flex;gap:2px;font-size:20px;-webkit-user-select:none;user-select:none;pointer-events:none}.rating-summary-in-info .rating-stars-large .stars span{-webkit-user-select:none;user-select:none;pointer-events:none}.rating-summary-in-info .rating-stars-large .filled{color:gold;filter:drop-shadow(0 1px 2px rgba(255,215,0,.3))}.rating-summary-in-info .rating-stars-large .empty{color:#e0e0e0}.rating-summary-in-info .rating-count-text{font-size:14px;color:#5f6368;margin-left:auto;-webkit-user-select:none;user-select:none}.rating-summary-in-info *:active,.rating-summary-in-info *:focus{outline:none;background:transparent}.rating-summary-in-info::selection,.rating-summary-in-info *::selection{background:transparent;color:inherit}.rating-summary-in-info::-moz-selection,.rating-summary-in-info *::-moz-selection{background:transparent;color:inherit}.restaurant-detail-modal .navigate-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;width:100%;justify-content:center}.restaurant-detail-modal .navigate-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.reviews-section{max-height:400px;overflow-y:auto}@media (max-width: 768px){.restaurant-detail-modal-overlay{padding:0;align-items:flex-end}.restaurant-detail-modal{max-width:100%;max-height:95vh;border-radius:16px 16px 0 0;animation:modalSlideUp .3s ease-out}@keyframes modalSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.restaurant-image{height:200px}.restaurant-info{padding:20px}.restaurant-name{font-size:20px}}.restaurant-detail-modal::-webkit-scrollbar,.reviews-section::-webkit-scrollbar{width:6px}.restaurant-detail-modal::-webkit-scrollbar-track,.reviews-section::-webkit-scrollbar-track{background:#f1f1f1}.restaurant-detail-modal::-webkit-scrollbar-thumb,.reviews-section::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.restaurant-detail-modal::-webkit-scrollbar-thumb:hover,.reviews-section::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.map-page{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;flex-direction:column;background:#f5f5f5;overflow:hidden}.map-notification{position:fixed;top:90px;left:50%;transform:translate(-50%) translateY(-100px);background:#fffffffa;-webkit-backdrop-filter:blur(16px) saturate(180%);backdrop-filter:blur(16px) saturate(180%);border-radius:16px;box-shadow:0 8px 32px #00000014,0 1px 2px #0000000d,inset 0 1px #ffffff80;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:14px;z-index:10000;max-width:340px;width:calc(100% - 40px);opacity:0;transition:all .4s cubic-bezier(.34,1.56,.64,1);pointer-events:none;border:1px solid rgba(255,255,255,.2)}.map-notification.map-show{transform:translate(-50%) translateY(0);opacity:1;pointer-events:auto;animation:slideInBounce .6s cubic-bezier(.34,1.56,.64,1)}.map-notification.map-success{background:linear-gradient(135deg,#f0fdf4f2,#dcfce7f2);border-left:4px solid #22c55e;box-shadow:0 8px 32px #22c55e26,0 1px 2px #22c55e1a,inset 0 1px #ffffff80}.map-notification.map-error{background:linear-gradient(135deg,#fef2f2f2,#fce2e2f2);border-left:4px solid #ef4444;box-shadow:0 8px 32px #ef444426,0 1px 2px #ef44441a,inset 0 1px #ffffff80}.map-notification span{color:#1f2937;font-size:.9rem;font-weight:600;flex:1;line-height:1.4;letter-spacing:.01em}.map-notification-close{background:none;border:none;color:#6b7280;font-size:1.2rem;cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:.7;width:24px;height:24px}.map-notification-close:hover{background:#0000001a;color:#374151;opacity:1;transform:scale(1.1)}.map-controls{position:absolute;top:20px;left:20px;right:20px;display:flex;align-items:center;gap:12px;z-index:1000;max-width:calc(100vw - 40px);box-sizing:border-box}.search-container{flex:1;max-width:400px;min-width:200px}.control-buttons{display:flex;gap:8px;flex-shrink:0}.menu-button{width:56px;height:56px;border-radius:14px;border:none;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px #0000001a;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:#666;transition:all .3s ease}.menu-button:hover{background:#fff;box-shadow:0 6px 20px #00000026;transform:translateY(-1px);color:#ff6b35}.menu-button:active{transform:translateY(0);box-shadow:0 2px 8px #0000001a}.menu-button.active{background:#ff6b35;color:#fff;box-shadow:0 6px 20px #ff6b354d}.menu-button.active:hover{background:#e55a2b}.map-main{flex:1;position:relative;overflow:hidden}.map-sidebar{position:absolute;top:80px;right:20px;width:300px;max-height:calc(100vh - 160px);z-index:999;transform:translate(100%);opacity:0;transition:all .3s ease;pointer-events:none}.map-sidebar.open{transform:translate(0);opacity:1;pointer-events:auto}@media (max-width: 768px){.map-controls{top:16px;left:16px;right:16px;gap:10px;max-width:calc(100vw - 32px)}.search-container{max-width:none;min-width:160px}.menu-button{width:52px;height:52px;font-size:1.4rem}.map-sidebar{top:78px;right:16px;left:16px;width:auto;max-height:calc(100vh - 88px);transform:translate(100%);opacity:0;transition:all .3s ease}.map-sidebar.open{transform:translate(0);opacity:1}.map-notification{top:88px;max-width:280px;width:calc(100% - 32px);font-size:.9rem;padding:10px 14px}}@media (max-width: 480px){.map-controls{top:12px;left:12px;right:12px;gap:8px;max-width:calc(100vw - 24px)}.search-container{min-width:150px}.control-buttons{gap:6px}.menu-button{width:48px;height:48px;font-size:1.4rem;border-radius:12px}.map-sidebar{top:68px;right:12px;left:12px;width:auto;max-height:calc(100vh - 80px);transform:translate(100%);opacity:0;transition:all .3s ease}.map-sidebar.open{transform:translate(0);opacity:1}.map-notification{top:76px;max-width:280px;width:calc(100% - 24px);font-size:.85rem;padding:8px 12px}}@media (max-width: 375px){.map-controls{left:12px;right:12px;top:10px;gap:6px;max-width:calc(100vw - 24px)}.search-container{max-width:none;min-width:180px}.menu-button{width:48px;height:48px;font-size:1.4rem}.map-sidebar{top:64px;right:12px;left:12px;width:auto;max-height:calc(100vh - 76px);transform:translate(100%);opacity:0;transition:all .3s ease}.map-sidebar.open{transform:translate(0);opacity:1}}@media (max-width: 420px){.map-controls{left:16px;right:16px;max-width:calc(100vw - 32px)}.search-container{max-width:none}.menu-button{width:48px;height:48px;font-size:1.4rem}.map-sidebar{top:74px;right:16px;left:16px;width:auto;max-height:calc(100vh - 84px);transform:translate(100%);opacity:0;transition:all .3s ease}.map-sidebar.open{transform:translate(0);opacity:1}}@media (prefers-color-scheme: dark){.map-page{background:#1a1a1a}.map-notification.map-success{background:#064e3b;color:#d1fae5}.map-notification.map-error{background:#7f1d1d;color:#fecaca}}.info-place-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.info-place-title-section{flex:1;min-width:0}.info-reviews-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 8px;background:linear-gradient(135deg,#fff,#f8f9ff);border:1.5px solid #667eea;border-radius:10px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);flex-shrink:0;min-width:54px;box-shadow:0 2px 4px #667eea14}.info-reviews-btn svg{color:#667eea;transition:all .25s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 1px 2px rgba(102,126,234,.1))}.info-reviews-btn span{font-size:10.5px;font-weight:650;color:#667eea;transition:all .25s cubic-bezier(.4,0,.2,1);letter-spacing:.3px}.info-reviews-btn:hover{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#5a6fd8;transform:translateY(-2px) scale(1.02);box-shadow:0 6px 16px #667eea59}.info-reviews-btn:hover svg,.info-reviews-btn:hover span{color:#fff;filter:drop-shadow(0 2px 3px rgba(0,0,0,.15))}.info-reviews-btn:active{transform:translateY(0) scale(.98);box-shadow:0 3px 8px #667eea40}@media (prefers-contrast: high){.menu-button{border:2px solid #333;background:#fff}.menu-button.active{border-color:#ff6b35}.map-notification{border:2px solid #ccc}.map-notification.map-success{border-color:#22c55e}.map-notification.map-error{border-color:#ef4444}}.floating-nav-container{position:fixed;bottom:0;left:0;right:0;padding:0 8px 12px;display:flex;justify-content:center;z-index:1000;pointer-events:none;padding-bottom:calc(16px + env(safe-area-inset-bottom));transition:transform .2s ease-out;touch-action:pan-y;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-tap-highlight-color:transparent;transform:translateY(0)}.floating-nav-container.nav-hidden{transform:translateY(150%)!important;transition:transform .2s ease-out!important}.floating-bottom-nav{position:relative;display:flex;justify-content:space-between;align-items:center;background:#f6f6f6d9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:100px;padding:6px;width:75%;max-width:260px;box-shadow:0 6px 20px #0000001a;pointer-events:auto;transition:transform .3s cubic-bezier(.68,-.6,.32,1.6);user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-tap-highlight-color:transparent}.floating-bottom-nav *,.floating-bottom-nav *:before,.floating-bottom-nav *:after{-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}.floating-bottom-nav.initializing{opacity:.95}.nav-pill{position:relative;display:flex;align-items:center;justify-content:center;text-decoration:none;padding:6px 3px;color:#777;transition:all .3s cubic-bezier(.68,-.6,.32,1.6);flex:1;z-index:2;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.nav-pill:active,.nav-pill:focus{outline:none}.nav-pill::selection,.nav-pill *::selection{background:transparent;color:inherit}.nav-pill::-moz-selection,.nav-pill *::-moz-selection{background:transparent;color:inherit}.pill-content{display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:1;width:100%;transition:all .3s ease}.pill-icon{display:flex;font-size:18px;transition:transform .3s cubic-bezier(.68,-.6,.32,1.6);margin-bottom:2px;color:#4b4b4b}.pill-label{font-size:10px;font-weight:500;white-space:nowrap;transition:all .3s cubic-bezier(.68,-.6,.32,1.6);opacity:.9;color:#4b4b4b}.nav-pill.active{color:#fff}.nav-pill.active .pill-label,.nav-pill.active .pill-icon{color:#fff;opacity:1}.nav-pill-background{position:absolute;border-radius:50%;background:linear-gradient(135deg,#ff6b6b,#ff9f68);width:45px;height:45px;top:50%;transform:translateY(-50%);z-index:1;box-shadow:0 2px 10px #ff6b6b40;will-change:opacity,left}@keyframes slideUpNav{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.floating-bottom-nav{animation:slideUpNav .5s ease forwards;animation-delay:.05s}@media (prefers-color-scheme: dark){.floating-bottom-nav{background:#282828d9;border:1px solid rgba(80,80,80,.2)}.nav-pill .pill-icon,.nav-pill .pill-label{color:#aaa}.nav-pill.active .pill-label,.nav-pill.active .pill-icon{color:#fff}.nav-pill-background{background:linear-gradient(135deg,#ff9f68,#ff6b6b)}}@supports not (backdrop-filter: blur(10px)){.floating-bottom-nav{background:#f6f6f6f2}@media (prefers-color-scheme: dark){.floating-bottom-nav{background:#282828f2}}}.floating-nav-container.nav-collapsed{transform:translateY(0)}.floating-bottom-nav.collapsed{width:55px;height:55px;border-radius:27.5px;padding:0;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffd9;border:1px solid rgba(255,255,255,.3);box-shadow:0 8px 32px #0000001f;transition:all .4s cubic-bezier(.25,.8,.25,1);cursor:pointer;touch-action:pan-y}.floating-bottom-nav.collapsed .nav-pill{margin:0;width:auto;height:auto;min-width:auto;background:transparent;border-radius:0;transition:all .3s ease}.floating-bottom-nav.collapsed .nav-pill .pill-content{flex-direction:column;align-items:center;justify-content:center;gap:4px}.floating-bottom-nav.collapsed .nav-pill .pill-icon{font-size:18px;color:#333}.floating-bottom-nav.collapsed .nav-pill .pill-label{font-size:9px;font-weight:600;color:#333;opacity:.8}.floating-bottom-nav.collapsed .nav-pill-background{display:none}.nav-expand-indicator{position:absolute;top:-8px;left:50%;transform:translate(-50%);width:36px;height:4px;display:flex;justify-content:center;align-items:center}.expand-handle{width:24px;height:3px;background:#0000004d;border-radius:2px;animation:handlePulse 2s ease-in-out infinite}@keyframes handlePulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.floating-bottom-nav.collapsed:hover{transform:scale(1.05);box-shadow:0 12px 40px #00000029}.floating-bottom-nav.collapsed:active{transform:scale(.95)}@media (prefers-color-scheme: dark){.floating-bottom-nav.collapsed{background:#1e1e1ed9;border-color:#ffffff1a}.floating-bottom-nav.collapsed .nav-pill .pill-icon,.floating-bottom-nav.collapsed .nav-pill .pill-label{color:#f5f5f5}.expand-handle{background:#ffffff80}}.auth-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:0;animation:fadeIn .3s ease-out}.auth-modal{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;width:100%;max-width:320px;max-height:90vh;overflow-y:auto;animation:modalSlideUp .3s ease-out;margin:0 auto;position:relative}.auth-modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 0;margin-bottom:20px}.auth-modal-title{margin:0;font-size:1.5rem;font-weight:700;color:#333}.auth-modal-close{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.auth-modal-close:hover{background:#0000000d;color:#333}.auth-oauth-section{padding:0 24px;display:flex;flex-direction:column;gap:12px}.oauth-button{width:100%;padding:14px 16px;border:2px solid #e5e5e5;border-radius:12px;background:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:12px;min-height:52px}.google-button{color:#4285f4;border-color:#4285f4}.google-button:hover:not(:disabled){background:#4285f4;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #4285f44d}.apple-button{color:#000;border-color:#000}.apple-button:hover:not(:disabled){background:#000;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.oauth-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.oauth-icon{font-size:1.2rem}.auth-divider{margin:24px 24px 16px;position:relative;text-align:center}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e5e5e5}.divider-text{background:#fff;padding:0 16px;color:#666;font-size:.9rem;position:relative;z-index:1}.auth-form{padding:0 24px 24px}.form-label{display:block;margin-bottom:6px;font-size:.9rem;font-weight:600;color:#333}.input-wrapper{position:relative;display:flex;align-items:center;gap:12px}.input-icon{position:absolute;left:16px;font-size:1.1rem;color:#999;z-index:2}.auth-modal .form-input{width:100%;padding:14px 16px 14px 48px;border:2px solid #e5e5e5;border-radius:12px;font-size:1rem;color:#333;background:#fff;transition:all .2s ease;outline:none}.auth-modal .form-input:focus{border-color:#ff6b35;box-shadow:0 0 0 3px #ff6b351a}.auth-modal .form-input:disabled{background:#f9f9f9;cursor:not-allowed;opacity:.7}.auth-modal .form-input::placeholder{color:#999}.password-toggle{position:absolute;right:16px;background:none;border:none;font-size:1.1rem;color:#999;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color .2s ease;z-index:2}.password-toggle:hover:not(:disabled){color:#666}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;color:#dc2626;font-size:.85rem;font-weight:500;margin-bottom:20px;display:flex;align-items:center;animation:errorShake .5s ease-out}.submit-button{width:100%;padding:16px;background:#ff6b35;color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-height:56px}.submit-button:hover:not(:disabled){background:#e55a2b;transform:translateY(-1px);box-shadow:0 6px 20px #ff6b354d}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.submit-button.loading{background:#ff6b35;cursor:not-allowed}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.mode-switch{text-align:center;margin-top:24px;padding-top:20px;border-top:1px solid #f0f0f0}.mode-switch-text{color:#666;font-size:.9rem;margin-right:8px}.mode-switch-button{background:none;border:none;color:#ff6b35;font-size:.9rem;font-weight:600;cursor:pointer;transition:color .2s ease;text-decoration:underline}.mode-switch-button:hover:not(:disabled){color:#e55a2b}.mode-switch-button:disabled{color:#ccc;cursor:not-allowed}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@keyframes errorShake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@media (max-width: 480px){.auth-modal-overlay{padding:0}.auth-modal{width:calc(100vw - 40px);max-width:none;border-radius:16px;margin:0 auto}.auth-modal-header{padding:20px 20px 0}.auth-modal-title{font-size:1.3rem}.auth-oauth-section{padding:0 20px}.oauth-button{padding:12px 14px;font-size:.95rem;min-height:48px}.auth-divider{margin:20px 20px 12px}.auth-form{padding:0 20px 20px}.form-input{padding:12px 14px 12px 44px;font-size:.95rem}.input-icon{left:14px;font-size:1rem}.password-toggle{right:14px;font-size:1rem}.submit-button{padding:14px;font-size:.95rem;min-height:52px}}@media (prefers-color-scheme: dark){.auth-modal{background:#2a2a2a;color:#f5f5f5}.auth-modal-title{color:#f5f5f5}.oauth-button{background:#3a3a3a;border-color:#4a4a4a}.google-button{color:#4285f4;border-color:#4285f4}.apple-button{color:#f5f5f5;border-color:#f5f5f5}.apple-button:hover:not(:disabled){background:#f5f5f5;color:#2a2a2a}.auth-divider:before{background:#4a4a4a}.divider-text{background:#2a2a2a;color:#a3a3a3}.form-label{color:#f5f5f5}.form-input{background:#3a3a3a;border-color:#4a4a4a;color:#f5f5f5}.form-input:focus{border-color:#ff6b35}.form-input:disabled{background:#2a2a2a}.input-icon,.password-toggle{color:#a3a3a3}.mode-switch{border-top-color:#4a4a4a}.mode-switch-text{color:#a3a3a3}}.profile-header{position:relative;background:linear-gradient(135deg,#ff6b35,#f7931e);border-radius:20px;padding:32px 24px 24px;color:#fff;overflow:hidden;margin-bottom:24px}.header-background{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;opacity:.1}.bg-decoration{position:absolute;border-radius:50%;background:#fff}.bg-decoration-1{width:200px;height:200px;top:-100px;right:-50px}.bg-decoration-2{width:150px;height:150px;bottom:-75px;left:-30px}.bg-decoration-3{width:80px;height:80px;top:20px;left:20px}.avatar-section{display:flex;justify-content:center;margin-bottom:20px;position:relative;z-index:2}.avatar-container{position:relative;display:inline-block}.avatar-container .avatar-image{width:100px;height:100px;border-radius:50%!important;border:4px solid rgba(255,255,255,.3);box-shadow:0 8px 32px #0000001a;object-fit:cover!important;display:block!important;box-sizing:border-box!important}.avatar-upload-btn{position:absolute;bottom:0;right:0;width:36px;height:36px;border-radius:50%;background:#fff;border:3px solid #ff6b35;color:#ff6b35;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 4px 16px #0000001a}.avatar-upload-btn:hover:not(:disabled){background:#ff6b35;color:#fff;transform:scale(1.1)}.avatar-upload-btn:disabled{cursor:not-allowed;opacity:.7}.avatar-upload-btn.uploading{background:#fff;cursor:not-allowed}.upload-spinner{width:14px;height:14px;border:2px solid #ff6b35;border-top:2px solid transparent;border-radius:50%;animation:uploadSpin 1s linear infinite}.user-info-section{text-align:center;margin-bottom:24px;position:relative;z-index:2}.display-info{animation:fadeIn .3s ease-out}.user-name-section{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px}.user-name{margin:0;font-size:1.5rem;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.1)}.edit-profile-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:1rem;padding:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.edit-profile-btn:hover{background:#ffffff4d;transform:scale(1.05)}.user-details{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.detail-item{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.9rem;opacity:.9}.detail-icon{font-size:1rem;flex-shrink:0}.detail-text{font-weight:400}.user-bio{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:12px 16px;margin-top:16px}.bio-text{margin:0;font-size:.9rem;line-height:1.5;opacity:.95}.edit-form{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:20px;border:1px solid rgba(255,255,255,.2);animation:slideDown .3s ease-out}.edit-field{margin-bottom:16px;text-align:left}.edit-label{display:block;margin-bottom:6px;font-size:.85rem;font-weight:600;color:#ffffffe6}.edit-input,.edit-textarea{width:100%;padding:12px 16px;border:1px solid rgba(255,255,255,.3);border-radius:10px;background:#ffffffe6;color:#333;font-size:.9rem;outline:none;transition:all .2s ease;font-family:inherit}.edit-input:focus,.edit-textarea:focus{border-color:#fff;background:#fff;box-shadow:0 0 0 3px #fff3}.edit-textarea{resize:vertical;min-height:60px;line-height:1.5}.edit-actions{display:flex;gap:12px;margin-top:20px}.save-btn,.cancel-btn{flex:1;padding:12px 16px;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s ease}.save-btn{background:#fff;color:#22c55e}.save-btn:hover{background:#f0f9f0;transform:translateY(-1px);box-shadow:0 4px 16px #0000001a}.cancel-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.cancel-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.stats-section{display:flex;justify-content:space-around;gap:16px;position:relative;z-index:2}.stat-item{text-align:center;flex:1}.stat-number{font-size:1.8rem;font-weight:700;margin-bottom:4px;text-shadow:0 2px 8px rgba(0,0,0,.1)}.stat-label{font-size:.8rem;opacity:.8;font-weight:500}@keyframes uploadSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.profile-header{padding:24px 20px 20px;border-radius:16px;margin-bottom:20px}.avatar-container .avatar-image{width:80px;height:80px}.avatar-upload-btn{width:32px;height:32px;font-size:1rem}.user-name{font-size:1.3rem}.user-name-section{gap:8px}.edit-profile-btn{font-size:.9rem;padding:5px}.detail-item{font-size:.85rem}.stat-number{font-size:1.5rem}.stat-label{font-size:.75rem}.edit-form{padding:16px}.edit-actions{flex-direction:column;gap:8px}.bg-decoration-1{width:150px;height:150px;top:-75px;right:-40px}.bg-decoration-2{width:120px;height:120px;bottom:-60px;left:-25px}}@media (prefers-color-scheme: dark){.edit-input,.edit-textarea{background:#fffffff2}.edit-input:focus,.edit-textarea:focus{background:#fff}}@media (prefers-contrast: high){.profile-header{border:2px solid rgba(255,255,255,.5)}.avatar-container .avatar-image{border-width:3px}.edit-input,.edit-textarea{border-width:2px}}.my-lists-container{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:visible;margin:0;position:relative}.lists-notification{position:absolute;top:-80px;left:50%;transform:translate(-50%);background:#fffffffa;-webkit-backdrop-filter:blur(16px) saturate(180%);backdrop-filter:blur(16px) saturate(180%);border-radius:16px;box-shadow:0 8px 32px #00000014,0 1px 2px #0000000d,inset 0 1px #ffffff80;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:280px;max-width:400px;z-index:9999;opacity:1;pointer-events:auto;animation:slideInBounce .6s cubic-bezier(.34,1.56,.64,1)}.lists-notification.success{background:linear-gradient(135deg,#f0fdf4f2,#dcfce7f2);border-left:4px solid #22c55e;box-shadow:0 8px 32px #22c55e26,0 1px 2px #22c55e1a,inset 0 1px #ffffff80}.lists-notification.error{background:linear-gradient(135deg,#fef2f2f2,#fce2e2f2);border-left:4px solid #ef4444;box-shadow:0 8px 32px #ef444426,0 1px 2px #ef44441a,inset 0 1px #ffffff80}.lists-notification.warning{background:linear-gradient(135deg,#fffbebf2,#fef3c7f2);border-left:4px solid #f59e0b;box-shadow:0 8px 32px #f59e0b26,0 1px 2px #f59e0b1a,inset 0 1px #ffffff80}.notification-content{display:flex;align-items:center;gap:8px;flex:1}.lists-notification span{color:#1f2937;font-size:.9rem;font-weight:600;flex:1;line-height:1.4;letter-spacing:.01em}.notification-dismiss{background:none;border:none;color:#6b7280;font-size:1.2rem;cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:.7;width:24px;height:24px}.notification-dismiss:hover{background:#0000001a;color:#374151;opacity:1;transform:scale(1.1)}@keyframes slideInBounce{0%{transform:translate(-50%) translateY(-100px) scale(.8);opacity:0}50%{transform:translate(-50%) translateY(10px) scale(1.05);opacity:.8}to{transform:translate(-50%) translateY(0) scale(1);opacity:1}}.my-lists-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#666}.lists-header{padding:24px 24px 16px;border-bottom:1px solid #f0f0f0;background:#fafbfc;border-radius:16px 16px 0 0}.lists-title{display:flex;align-items:center;gap:12px;margin:0 0 8px;font-size:1.3rem;font-weight:700;color:#333}.lists-stats{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#666}.lists-content{display:flex;min-height:500px;overflow:visible;border-radius:0 0 16px 16px;background:#fff}.lists-sidebar{width:300px;min-width:300px;border-right:1px solid #f0f0f0;padding:20px;background:#fafafa;overflow-y:auto;overflow-x:hidden;max-height:500px}.mylists-card-wrapper{position:relative;margin:0 0 16px;overflow:hidden;border-radius:16px;background:linear-gradient(135deg,#ff6b3505,#fffc);box-shadow:0 2px 12px #0000000a;transition:all .3s cubic-bezier(.4,0,.2,1)}.mylists-card-wrapper:hover{box-shadow:0 4px 20px #ff6b351f;transform:translateY(-2px)}.mylists-card{background:#fff;border-radius:16px;padding:18px;cursor:pointer;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .3s ease;border:2px solid transparent;position:relative;z-index:1;overflow:hidden}.mylists-card.selected{border-color:#ff6b35;background:linear-gradient(135deg,#fff8f5,#fff);box-shadow:0 0 0 4px #ff6b351a}.mylists-card.swiped{transform:translate(-106px)}.mylists-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.mylists-color-indicator{width:16px;height:16px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 2px #ffffffe6,0 0 0 3px #00000014,0 4px 12px #00000026,inset 0 1px 3px #ffffff80,inset 0 -1px 2px #00000026;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative}.mylists-color-indicator:before{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:50%;background:linear-gradient(135deg,rgba(255,255,255,.4) 0%,transparent 50%,rgba(0,0,0,.1) 100%);pointer-events:none}.mylists-color-indicator:after{content:"";position:absolute;top:2px;left:3px;width:5px;height:5px;border-radius:50%;background:#fff9;filter:blur(1px);pointer-events:none}.mylists-card:hover .mylists-color-indicator{transform:scale(1.2);box-shadow:0 0 0 3px #fff,0 0 0 4px #0000001f,0 6px 20px #00000040,inset 0 1px 3px #fff9,inset 0 -1px 2px #0003}.mylists-card.selected .mylists-color-indicator{transform:scale(1.15);box-shadow:0 0 0 3px #fff,0 0 0 4px #ff6b354d,0 6px 18px #0003,0 0 12px #ff6b3566,inset 0 1px 3px #fff9,inset 0 -1px 2px #0003}.mylists-card-info{display:flex;align-items:center;gap:14px;flex:1;min-width:0;padding-left:4px}.mylists-card-details{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0;overflow:hidden}.mylists-card-name{margin:0;font-size:1.05rem;font-weight:700;color:#1a1a1a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.02em}.mylists-card-count{margin:0;font-size:.8rem;color:#999;font-weight:500}.mylists-edit-input{border:none;outline:none;background:#ff6b350d;font-size:1.05rem;font-weight:700;color:#1a1a1a;padding:6px 12px;border-radius:8px;border:2px solid #ff6b35;width:100%;transition:all .2s ease}.mylists-edit-input:focus{background:#ff6b3514;box-shadow:0 0 0 4px #ff6b3526}.mylists-card-menu{position:relative;flex-shrink:0;z-index:2}.mylists-menu-trigger{background:transparent;border:none;padding:8px;border-radius:8px;cursor:pointer;font-size:1.1rem;color:#94a3b8;transition:all .2s ease;display:flex;align-items:center;justify-content:center;opacity:1;position:relative;width:32px;height:32px}.mylists-menu-trigger:hover{background:#0000000d;color:#1a1a1a;transform:scale(1.1)}.mylists-menu-trigger:active{transform:scale(.95);background:#00000014}.mylists-swipe-actions{position:absolute;top:0;right:0;bottom:0;width:106px;display:flex;gap:4px;z-index:0;border-radius:0 16px 16px 0;padding:10px 3px 10px 9px;align-items:center;justify-content:center}.mylists-swipe-btn{flex:1;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 3px;border-radius:7px;transition:all .2s ease;font-size:.65rem;font-weight:600;color:#fff;min-height:52px;max-width:45px}.mylists-swipe-btn svg{font-size:1.1rem;transition:transform .2s ease}.mylists-swipe-btn:hover svg{transform:scale(1.15)}.mylists-swipe-btn span{font-size:.65rem;letter-spacing:0;white-space:nowrap}.mylists-swipe-btn.mylists-edit-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 8px #3b82f64d}.mylists-swipe-btn.mylists-edit-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.mylists-swipe-btn.mylists-edit-btn:active{transform:translateY(0)}.mylists-swipe-btn.mylists-delete-btn{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef44444d}.mylists-swipe-btn.mylists-delete-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.mylists-swipe-btn.mylists-delete-btn:active{transform:translateY(0)}.create-list-form{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000000a;margin:0 16px 12px}.create-list-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:.9rem;margin-bottom:12px;outline:none;transition:border-color .2s ease}.create-list-input:focus{border-color:#ff6b35}.create-list-actions{display:flex;gap:8px}.create-confirm-btn,.create-cancel-btn{flex:1;padding:8px 12px;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.create-confirm-btn{background:#ff6b35;color:#fff}.create-confirm-btn:hover{background:#e55a2b}.create-cancel-btn{background:#f5f5f5;color:#666}.create-cancel-btn:hover{background:#e5e5e5}.create-list-btn{width:calc(100% - 32px);margin:0 16px;padding:12px 16px;background:transparent;border:2px dashed #ccc;border-radius:12px;color:#666;font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease}.create-list-btn:hover{border-color:#ff6b35;color:#ff6b35;background:#ff6b350d}.list-content-area{flex:1;min-width:0;padding:20px;overflow-y:auto;max-height:500px}.list-content-header{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.list-info{margin-bottom:12px}.list-content-title{margin:0 0 8px;font-size:1.2rem;font-weight:600;color:#333}.list-meta{display:flex;gap:16px;font-size:.8rem;color:#999}.places-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.empty-list-message{grid-column:1 / -1;text-align:center;padding:60px 20px;color:#666}.empty-icon{font-size:3rem;color:#ddd;margin-bottom:16px}.empty-list-message h4{margin:0 0 8px;font-size:1.1rem;font-weight:600}.empty-list-message p{margin:0;font-size:.9rem;color:#999}.place-card{background:#fff;border-radius:12px;overflow:hidden;border:1px solid #f0f0f0;transition:all .2s ease;position:relative}.place-card:hover{box-shadow:0 4px 16px #00000014;border-color:#e0e0e0}.place-image-container{position:relative;height:120px;overflow:hidden}.place-image{width:100%;height:100%;object-fit:cover}.place-image-fallback{position:absolute;top:0;left:0;width:100%;height:100%;background:#f5f5f5;display:none;align-items:center;justify-content:center;font-size:2rem;color:#ccc}.place-card-content{padding:16px}.place-name{margin:0 0 6px;font-size:1rem;font-weight:600;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.place-address{margin:0 0 12px;font-size:.8rem;color:#666;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.place-rating{display:flex;align-items:center;gap:8px;margin-bottom:8px}.rating-stars{display:flex;gap:2px}.star-filled{color:#ffc107;font-size:.8rem}.star-empty{color:#e0e0e0;font-size:.8rem}.place-meta{display:flex;align-items:center;justify-content:space-between}.added-time{display:flex;align-items:center;gap:4px;font-size:.75rem;color:#999}.place-card-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px;opacity:0;transition:opacity .2s ease}.place-card:hover .place-card-actions{opacity:1}.place-action-btn{background:#fffffff2;border:none;border-radius:6px;padding:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.navigate-btn{color:#007aff}.navigate-btn:hover{background:#007aff1a;color:#005bb5}.remove-btn{color:#ef4444}.remove-btn:hover{background:#ef44441a;color:#dc2626}.no-list-selected{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:#666}.no-list-icon{font-size:4rem;color:#ddd;margin-bottom:20px}.no-list-selected h3{margin:0 0 8px;font-size:1.2rem;font-weight:600}.no-list-selected p{margin:0;font-size:.9rem;color:#999}.lists-sidebar::-webkit-scrollbar,.list-content-area::-webkit-scrollbar{width:4px}.lists-sidebar::-webkit-scrollbar-track,.list-content-area::-webkit-scrollbar-track{background:transparent}.lists-sidebar::-webkit-scrollbar-thumb,.list-content-area::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.lists-sidebar::-webkit-scrollbar-thumb:hover,.list-content-area::-webkit-scrollbar-thumb:hover{background:#999}@media (max-width: 768px){.lists-content{flex-direction:column;min-height:auto;overflow:visible}.lists-sidebar{width:100%;min-width:unset;max-height:250px;border-right:none;border-bottom:1px solid #f0f0f0;padding:16px 0;margin:0}.list-content-area{max-height:400px;min-width:unset}.places-grid{grid-template-columns:1fr;gap:12px}.place-card-actions,.list-menu-trigger{opacity:1}.create-list-input{width:calc(100% - 24px);box-sizing:border-box}}@media (max-width: 480px){.lists-header{padding:20px 16px 12px}.lists-sidebar{padding:12px 0}.list-content-area{padding:16px}.list-card,.place-card-content{padding:12px}.lists-title{font-size:1.2rem}.empty-list-message{padding:40px 16px}.create-list-input{width:calc(100% - 24px);padding:10px 12px;box-sizing:border-box}}.my-reviews-container{width:100%;max-width:800px;margin:0 auto;padding:0}.my-reviews-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:#6c757d}.loading-spinner{width:48px;height:48px;border:4px solid rgba(102,126,234,.1);border-top:4px solid #667eea;border-radius:50%;animation:spin 1s cubic-bezier(.4,0,.2,1) infinite;margin-bottom:20px;box-shadow:0 4px 12px #667eea26}.stars{display:flex;gap:4px;font-size:18px}.stars.interactive{cursor:pointer}.stars .filled{color:gold;filter:drop-shadow(0 1px 2px rgba(255,215,0,.3));transition:all .2s cubic-bezier(.4,0,.2,1)}.stars .empty{color:#e0e0e0;transition:all .2s cubic-bezier(.4,0,.2,1)}.stars.interactive span:hover{transform:scale(1.15);transition:transform .2s cubic-bezier(.4,0,.2,1)}.stars .filled:hover{filter:drop-shadow(0 2px 4px rgba(255,215,0,.5))}.reviews-list{display:flex;flex-direction:column;gap:20px}.no-reviews{text-align:center;padding:80px 20px;background:linear-gradient(135deg,#667eea08,#764ba208);border-radius:20px;border:2px dashed rgba(102,126,234,.2);margin:20px 0}.no-reviews-icon{font-size:72px;color:#667eea33;margin-bottom:20px;filter:drop-shadow(0 4px 8px rgba(102,126,234,.1));animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.no-reviews h3{margin:0 0 12px;font-size:22px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.no-reviews p{margin:0;font-size:15px;color:#6c757d;line-height:1.6}.review-card{background:#fff;border:1px solid rgba(102,126,234,.12);border-radius:16px;padding:24px;box-shadow:0 2px 8px #667eea0a;position:relative}.card-header{display:flex;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(102,126,234,.08);gap:10px}.restaurant-name{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:700;color:#2d3748;letter-spacing:-.2px;flex:1;min-width:0}.restaurant-name svg{font-size:22px;color:#667eea;filter:drop-shadow(0 2px 4px rgba(102,126,234,.2));flex-shrink:0}.my-reviews-container .delete-btn{background:#ef444414;border:1.5px solid transparent;cursor:pointer;padding:10px;border-radius:10px;transition:all .25s cubic-bezier(.4,0,.2,1);font-size:24px;color:#ef4444;display:flex;align-items:center;justify-content:center;width:42px;height:42px;flex-shrink:0;margin-left:auto}.my-reviews-container .delete-btn:hover{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#ef44444d;color:#dc2626;transform:scale(1.08);box-shadow:0 4px 12px #ef444433}.my-reviews-container .delete-btn:active{transform:scale(.95)}.my-reviews-container .navigate-btn{background:#667eea0d;border:1.5px solid transparent;cursor:pointer;padding:10px;border-radius:10px;transition:all .25s cubic-bezier(.4,0,.2,1);font-size:20px;color:#6c757d;display:flex;align-items:center;justify-content:center;width:42px;height:42px;flex-shrink:0}.my-reviews-container .navigate-btn:hover{background:linear-gradient(135deg,#e7f3ff,#e0edff);border-color:#0066cc4d;color:#06c;transform:scale(1.08);box-shadow:0 4px 12px #0066cc26}.my-reviews-container .navigate-btn:active{transform:scale(.95)}.card-content{display:flex;flex-direction:column;gap:16px}.review-rating-section{display:flex;flex-direction:column;gap:14px}.my-rating{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#667eea0d,#764ba20d);border-radius:12px;border:1px solid rgba(102,126,234,.1)}.rating-label{font-size:14px;color:#667eea;font-weight:600;letter-spacing:.2px}.rating-number{font-size:18px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-left:auto}.restaurant-overall-rating{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#ffd70014,#ffc10714);border-radius:12px;border:1px solid rgba(255,215,0,.2)}.overall-label{font-size:14px;color:#f59e0b;font-weight:600;letter-spacing:.2px}.overall-value{font-size:18px;font-weight:700;color:#f59e0b;margin-left:auto}.review-comment-section{padding:16px;background:linear-gradient(135deg,#f8f9fa99,#f1f3f599);border-radius:12px;border:1px solid rgba(102,126,234,.08);position:relative}.review-comment-section:before{content:'"';position:absolute;top:8px;left:12px;font-size:32px;color:#667eea26;font-family:Georgia,serif;font-weight:700;line-height:1}.review-comment{color:#4a5568;line-height:1.7;font-size:14.5px;white-space:pre-wrap;word-break:break-word;padding-left:20px;padding-top:6px}.show-more-btn{background:linear-gradient(135deg,#667eea14,#764ba214);border:1px solid rgba(102,126,234,.2);color:#667eea;font-size:13px;font-weight:600;cursor:pointer;padding:8px 16px;margin-top:8px;border-radius:8px;transition:all .25s cubic-bezier(.4,0,.2,1);letter-spacing:.2px}.show-more-btn:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;transform:translateY(-1px);box-shadow:0 4px 12px #667eea40}.show-more-btn:active{transform:translateY(0)}.review-meta{display:flex;align-items:center;gap:12px;font-size:12.5px;color:#718096;padding-top:4px}.review-date{display:flex;align-items:center;gap:6px;font-weight:500}.updated-badge{background:linear-gradient(135deg,#ffc10726,#f59e0b26);color:#d97706;padding:4px 10px;border-radius:8px;font-size:11px;font-weight:600;border:1px solid rgba(245,158,11,.2);letter-spacing:.3px}@media (max-width: 768px){.my-reviews-container{padding:0}.reviews-header{margin-bottom:18px;padding-bottom:14px}.reviews-count{font-size:13px;padding:8px 16px}.reviews-list{gap:16px}.review-card{padding:20px;border-radius:14px}.card-header{flex-direction:row;flex-wrap:nowrap;margin-bottom:16px;padding-bottom:14px;gap:10px}.restaurant-name{font-size:16px;flex:1;min-width:0}.restaurant-name svg{font-size:20px}.my-reviews-container .delete-btn{padding:9px;font-size:22px;width:40px;height:40px;margin-left:auto}.my-reviews-container .navigate-btn{padding:9px;font-size:18px;width:40px;height:40px}.card-content{gap:14px}.review-rating-section{flex-direction:column;gap:12px}.my-rating,.restaurant-overall-rating{padding:12px 14px}.rating-number,.overall-value{font-size:16px}.review-comment-section{padding:14px}.review-comment-section:before{font-size:28px;top:6px;left:10px}.review-comment{font-size:14px;padding-left:18px}.show-more-btn{padding:7px 14px;font-size:12.5px}.no-reviews{padding:60px 20px;border-radius:16px}.no-reviews-icon{font-size:64px;margin-bottom:16px}.no-reviews h3{font-size:20px}.no-reviews p{font-size:14px}}@media (max-width: 480px){.reviews-count{font-size:12px;padding:7px 14px}.review-card{padding:18px;border-radius:12px}.restaurant-name{font-size:15px}.my-rating,.restaurant-overall-rating{padding:11px 13px;gap:10px}.rating-label,.overall-label{font-size:13px}.rating-number,.overall-value{font-size:15px}.stars{font-size:16px;gap:3px}.review-comment{font-size:13.5px;line-height:1.6}}.swifttaste-history-container{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden;margin-bottom:24px}.swifttaste-history-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#666}.loading-spinner{width:32px;height:32px;border:3px solid #e0e0e0;border-top:3px solid #ff6b35;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.history-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid #f0f0f0;background:linear-gradient(135deg,#fff,#f8f9fa)}.header-left{display:flex;flex-direction:column;gap:8px}.history-title{display:flex;align-items:center;gap:12px;margin:0;font-size:1.3rem;font-weight:700;color:#333}.title-icon{font-size:1.4rem;color:#ff6b35}.history-stats{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#666}.header-actions{display:flex;align-items:center;gap:16px}.filter-buttons{display:flex;gap:4px;background:#f5f5f5;border-radius:10px;padding:4px}.filter-btn{background:none;border:none;padding:8px 16px;border-radius:8px;font-size:.85rem;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease}.filter-btn:hover{color:#333;background:#ffffffb3}.filter-btn.active{background:#ff6b35;color:#fff;box-shadow:0 2px 8px #ff6b354d}.clear-history-btn{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:1rem;padding:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.clear-history-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#b91c1c}.history-content{padding:20px 24px 24px}.empty-history{text-align:center;padding:60px 20px;color:#666}.empty-icon{font-size:4rem;color:#ddd;margin-bottom:20px}.empty-history h3{margin:0 0 8px;font-size:1.2rem;font-weight:600}.empty-history p{margin:0;font-size:.9rem;color:#999}.history-list{display:flex;flex-direction:column;gap:16px}.history-record{background:#fafafa;border-radius:12px;border:1px solid #f0f0f0;overflow:hidden;transition:all .2s ease}.history-record:hover{border-color:#e0e0e0;box-shadow:0 4px 16px #00000014}.record-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;background:#fff;border-bottom:1px solid #f0f0f0}.record-meta{display:flex;flex-direction:column;gap:4px}.record-mode{display:flex;align-items:center;gap:12px}.mode-badge{background:#ff6b35;color:#fff;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.mode-badge.buddies{background:#8b5cf6}.record-time{font-size:.85rem;color:#666;font-weight:500}.record-duration{font-size:.8rem;color:#999}.record-actions{display:flex;gap:8px}.retry-btn,.delete-record-btn{background:none;border:none;padding:6px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.retry-btn{color:#22c55e}.retry-btn:hover{background:#22c55e1a;color:#16a34a}.delete-record-btn{color:#ef4444}.delete-record-btn:hover{background:#ef44441a;color:#dc2626}.record-content{padding:20px;display:grid;grid-template-columns:1fr 1fr;gap:24px}.answers-summary{display:flex;flex-direction:column;gap:12px}.summary-title{margin:0 0 8px;font-size:1rem;font-weight:600;color:#333}.answers-grid{display:flex;flex-wrap:wrap;gap:8px}.answer-item{display:flex;align-items:center;gap:6px;background:#fff;padding:8px 12px;border-radius:8px;border:1px solid #e0e0e0;font-size:.85rem;color:#333}.answer-item svg{font-size:1rem;color:#ff6b35;flex-shrink:0}.answer-text{font-weight:500}.fun-answers{margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0}.fun-answers-header{font-size:.9rem;font-weight:600;color:#8b5cf6;margin-bottom:8px}.fun-answers-list{display:flex;flex-direction:column;gap:6px}.fun-answer-item{display:flex;align-items:center;justify-content:space-between;background:#8b5cf60d;padding:8px 12px;border-radius:8px;font-size:.8rem}.fun-question{color:#666;flex:1;margin-right:12px}.fun-answer{color:#8b5cf6;font-weight:600}.recommendation-result{display:flex;flex-direction:column;gap:12px}.result-title{margin:0 0 8px;font-size:1rem;font-weight:600;color:#333}.restaurant-card{position:relative;display:flex;gap:12px;background:#fff;border-radius:12px;padding:16px;border:1px solid #e0e0e0;transition:border-color .2s ease}.restaurant-image-container{position:relative;width:80px;height:80px;border-radius:8px;overflow:hidden;flex-shrink:0}.restaurant-image{width:100%;height:100%;object-fit:cover}.restaurant-image-fallback{position:absolute;top:0;left:0;width:100%;height:100%;background:#f5f5f5;display:none;align-items:center;justify-content:center;font-size:1.5rem;color:#ccc}.restaurant-info{flex:1;display:flex;flex-direction:column;gap:4px}.restaurant-name{margin:0;font-size:1rem;font-weight:600;color:#333}.restaurant-address{margin:0;font-size:.85rem;color:#666;line-height:1.4}.restaurant-rating{display:flex;align-items:center;gap:6px;margin:4px 0}.rating-stars{color:#ffc107;font-size:.8rem;letter-spacing:1px}.rating-value{font-size:.8rem;color:#666;font-weight:500}.recommendation-reason{margin:0;font-size:.8rem;color:#22c55e;font-weight:500;font-style:italic;line-height:1.4}.navigate-to-restaurant-btn{position:absolute;bottom:12px;right:12px;display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,#ff6b35,#ff8c5a);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #ff6b354d}.navigate-to-restaurant-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff6b3566}.navigate-to-restaurant-btn:active{transform:translateY(0) scale(.95);animation:click-ripple .6s ease-out}.navigate-to-restaurant-btn svg{font-size:1rem}@keyframes click-ripple{0%{box-shadow:0 2px 8px #ff6b354d,0 0 #ff6b35b3}50%{box-shadow:0 2px 8px #ff6b354d,0 0 0 10px #ff6b3500}to{box-shadow:0 2px 8px #ff6b354d,0 0 #ff6b3500}}@media (max-width: 768px){.history-header{flex-direction:column;align-items:stretch;gap:16px}.header-actions{justify-content:space-between}.filter-buttons{flex:1;justify-content:center}.record-content{grid-template-columns:1fr;gap:20px}.restaurant-card{flex-direction:column}.restaurant-image-container{width:100%;height:120px}}@media (max-width: 480px){.history-header{padding:20px 16px 12px}.history-content{padding:16px}.record-header{padding:12px 16px 8px}.record-content{padding:16px}.history-title{font-size:1.2rem}.filter-buttons{gap:2px;padding:2px}.filter-btn{padding:6px 12px;font-size:.8rem}.answers-grid{gap:6px}.answer-item{padding:6px 10px;font-size:.8rem}.restaurant-card{padding:12px}.empty-history{padding:40px 16px}}.settings-content{padding:0 20px 20px}.settings-items-container{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden;border:1px solid rgba(0,0,0,.05)}.settings-item{padding:20px;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f7fafc;position:relative}.settings-item:last-child{border-bottom:none}.settings-item:hover{background:#f8fafc;transform:translate(2px)}.settings-item:active{background:#edf2f7;transform:translate(0)}.settings-item-content{display:flex;align-items:center;justify-content:space-between}.settings-item-left{display:flex;align-items:center;gap:16px;flex:1}.settings-item-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#667eea;font-size:24px}.settings-item-label{font-size:17px;font-weight:500;color:#2d3748;line-height:1.4}.settings-item-right{display:flex;align-items:center}.settings-content .nav-arrow{color:#a0aec0;font-size:20px;transition:transform .2s ease}.settings-content .settings-item:hover .nav-arrow{transform:translate(2px);color:#667eea}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e0;transition:all .3s ease;border-radius:28px;box-shadow:inset 0 2px 4px #0000001a}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;transition:all .3s ease;border-radius:50%;box-shadow:0 2px 8px #00000026}input:checked+.toggle-slider{background:linear-gradient(135deg,#667eea,#764ba2)}input:checked+.toggle-slider:before{transform:translate(24px)}.logout-item,.logout-item .settings-item-icon,.logout-item .settings-item-label{color:#e53e3e}.delete-item,.delete-item .settings-item-icon,.delete-item .settings-item-label{color:#c53030}.login-item,.login-item .settings-item-icon,.login-item .settings-item-label{color:#3182ce}.register-item,.register-item .settings-item-icon,.register-item .settings-item-label{color:#38a169}.promotion-banner{margin:32px 20px 100px;background:linear-gradient(135deg,#ff6b6b,#ff8e8e);border-radius:20px;padding:20px;box-shadow:0 8px 25px #ff6b6b4d;position:relative;overflow:hidden;cursor:pointer;transition:transform .2s ease}.promotion-banner:hover{transform:translateY(-2px);box-shadow:0 12px 30px #ff6b6b66}.promotion-banner:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);transform:rotate(45deg)}.promotion-content{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}.promotion-title{font-size:22px;font-weight:700;color:#fff;letter-spacing:-.5px;flex:1}.promotion-mascot{font-size:40px;margin-left:16px;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@media (max-width: 768px){.settings-content{padding:0 16px 20px}.settings-items-container{border-radius:12px}.settings-item{padding:16px 18px}.settings-item-label{font-size:16px}.promotion-banner{margin:24px 16px 120px;padding:16px;border-radius:16px}.promotion-title{font-size:20px}.promotion-mascot{font-size:36px}}@media (prefers-color-scheme: dark){.settings-items-container{background:#2d3748;border-color:#ffffff1a}.settings-item{border-bottom-color:#ffffff1a}.settings-item:hover{background:#4a5568}.settings-item:active{background:#1a202c}.settings-item-label{color:#f7fafc}.toggle-slider{background-color:#4a5568}}@media (prefers-reduced-motion: reduce){.settings-content *,.settings-items-container *,.promotion-banner *{animation-duration:.01ms;animation-iteration-count:1;transition-duration:.01ms}}@media (prefers-contrast: high){.settings-items-container{border:2px solid #000}.settings-item{border-bottom:2px solid #000}}.profile-menu{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.user-profile-section{background:#fff;padding:32px 24px;border-radius:20px;box-shadow:0 4px 20px #00000014;margin:0 20px 24px;display:flex;align-items:center;gap:20px;position:relative;overflow:hidden}.user-profile-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2)}.user-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;position:relative;border:3px solid #ffffff;box-shadow:0 2px 8px #0000001a}.user-avatar .avatar-image{position:absolute!important;top:0!important;left:0!important;width:100%!important;height:100%!important;object-fit:cover!important;border-radius:50%!important;display:block!important;box-sizing:border-box!important}.default-avatar{font-size:32px;color:#fff}.profile-menu .user-info{flex:1;min-width:0}.user-name{font-size:24px;font-weight:700;color:#2d3748;margin:0 0 4px;letter-spacing:-.5px}.user-email{font-size:16px;color:#718096;margin:0;word-break:break-word}.menu-content{padding:0 20px 120px}.menu-items-container{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden;border:1px solid rgba(0,0,0,.05)}.menu-item{padding:20px;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f7fafc;position:relative}.menu-item:last-child{border-bottom:none}.menu-item:hover{background:#f8fafc;transform:translate(2px)}.menu-item:active{background:#edf2f7;transform:translate(0)}.menu-item-content{display:flex;align-items:center;justify-content:space-between}.menu-item-left{display:flex;align-items:center;gap:16px;flex:1}.menu-item-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#667eea;font-size:24px}.menu-item-label{font-size:17px;font-weight:500;color:#2d3748;line-height:1.4}.menu-item-right{display:flex;align-items:center}.profile-menu .nav-arrow{color:#a0aec0;font-size:20px;transition:transform .2s ease}.profile-menu .menu-item:hover .nav-arrow{transform:translate(2px);color:#667eea}@media (max-width: 768px){.profile-menu{padding-bottom:80px}.user-profile-section{margin:0 16px 20px;padding:24px 20px;border-radius:16px}.user-avatar{width:56px;height:56px}.default-avatar{font-size:28px}.user-name{font-size:20px}.user-email{font-size:14px}.menu-content{padding:0 16px 120px}.menu-items-container{border-radius:12px}.menu-item{padding:16px 18px}.menu-item-label{font-size:16px}}@media (prefers-color-scheme: dark){.profile-menu{background:linear-gradient(135deg,#1a202c,#2d3748)}.user-profile-section{background:#2d3748}.user-avatar{border-color:#4a5568}.user-name{color:#f7fafc}.user-email{color:#a0aec0}.menu-items-container{background:#2d3748;border-color:#ffffff1a}.menu-item{border-bottom-color:#ffffff1a}.menu-item:hover{background:#4a5568}.menu-item:active{background:#1a202c}.menu-item-label{color:#f7fafc}}.page-wrapper{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.page-header{background:#fff;padding:16px 20px;border-radius:0 0 24px 24px;box-shadow:0 4px 20px #00000014;margin-bottom:24px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between}.page-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2)}.back-button{background:none;border:none;color:#667eea;font-size:24px;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;min-width:40px}.back-button:hover{background:#667eea1a;transform:translate(-2px)}.back-button:active{background:#667eea33;transform:translate(0)}.page-title{font-size:24px;font-weight:700;color:#2d3748;margin:0;text-align:center;letter-spacing:-.5px;flex:1}.header-spacer{min-width:40px}.header-right-element{min-width:40px;display:flex;align-items:center;justify-content:flex-end}.header-right-element .reviews-count-badge{display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);padding:6px 12px;border-radius:16px;letter-spacing:.3px;box-shadow:0 2px 8px #667eea4d;min-width:32px}.page-content{padding:0 20px 120px;min-height:calc(100vh - 120px);overflow-y:auto;max-height:calc(100vh - 120px)}@media (max-width: 768px){.page-header{padding:12px 16px;border-radius:0 0 20px 20px;margin-bottom:20px}.page-title{font-size:20px}.back-button{font-size:22px;padding:6px;min-width:36px}.header-spacer{min-width:36px}.page-content{padding:0 16px 100px;overflow-y:auto;max-height:calc(100vh - 100px)}}@media (prefers-color-scheme: dark){.page-wrapper{background:linear-gradient(135deg,#1a202c,#2d3748)}.page-header{background:#2d3748}.page-title{color:#f7fafc}.back-button{color:#667eea}.back-button:hover{background:#667eea33}.back-button:active{background:#667eea4d}}.faq-content{padding:0 20px 20px}.faq-intro{margin-bottom:24px;text-align:center}.faq-title{font-size:24px;font-weight:700;color:#2d3748;margin:0 0 8px;letter-spacing:-.5px}.faq-description{font-size:16px;color:#718096;margin:0;line-height:1.5}.faq-list{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden;border:1px solid rgba(0,0,0,.05);margin-bottom:24px}.faq-item{border-bottom:1px solid #f7fafc}.faq-item:last-child{border-bottom:none}.faq-question{width:100%;padding:20px;background:none;border:none;text-align:left;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between;gap:16px}.faq-question:hover{background:#f8fafc}.faq-question-text{font-size:17px;font-weight:600;color:#2d3748;line-height:1.4;flex:1}.expand-icon{color:#667eea;font-size:20px;transition:transform .2s ease;flex-shrink:0}.faq-question:hover .expand-icon{color:#5a67d8}.faq-answer{padding:0 20px 20px;animation:fadeInDown .3s ease-out}.faq-answer p{font-size:15px;color:#4a5568;line-height:1.6;margin:0}.faq-footer{text-align:center;padding:20px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.faq-footer p{font-size:14px;color:#718096;margin:0 0 4px;line-height:1.5}.faq-footer p:last-child{margin:0;color:#667eea;font-weight:500}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.faq-content{padding:0 16px 20px}.faq-title{font-size:20px}.faq-description{font-size:14px}.faq-question{padding:16px 18px}.faq-question-text{font-size:16px}.faq-answer{padding:0 18px 16px}.faq-answer p{font-size:14px}}@media (prefers-color-scheme: dark){.faq-title{color:#f7fafc}.faq-description{color:#a0aec0}.faq-list{background:#2d3748;border-color:#ffffff1a}.faq-item{border-bottom-color:#ffffff1a}.faq-question:hover{background:#4a5568}.faq-question-text{color:#f7fafc}.faq-answer p{color:#e2e8f0}.faq-footer{background:#4a5568;border-color:#ffffff1a}.faq-footer p{color:#a0aec0}.faq-footer p:last-child{color:#667eea}}.contact-content{padding:0 20px 20px}.contact-intro{margin-bottom:24px;text-align:center}.contact-title{font-size:24px;font-weight:700;color:#2d3748;margin:0 0 8px;letter-spacing:-.5px}.contact-description{font-size:16px;color:#718096;margin:0;line-height:1.5}.contact-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:32px}.contact-info-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 20px #00000014;border:1px solid rgba(0,0,0,.05);display:flex;align-items:flex-start;gap:16px;transition:transform .2s ease}.contact-info-card:hover{transform:translateY(-2px)}.contact-info-icon{width:48px;height:48px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;flex-shrink:0}.contact-info-content{flex:1}.contact-info-title{font-size:16px;font-weight:600;color:#2d3748;margin:0 0 4px}.contact-info-main{font-size:15px;color:#4a5568;margin:0 0 4px;font-weight:500}.contact-info-desc{font-size:13px;color:#718096;margin:0}.contact-form-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014;border:1px solid rgba(0,0,0,.05);margin-bottom:24px}.form-section-title{font-size:20px;font-weight:600;color:#2d3748;margin:0 0 20px}.contact-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column}.form-label{font-size:14px;font-weight:600;color:#2d3748;margin-bottom:6px}.form-input,.form-textarea{padding:12px 16px;border:2px solid #e5e5e5;border-radius:8px;font-size:14px;color:#2d3748;background:#fff;transition:all .2s ease;outline:none;width:100%;box-sizing:border-box}.form-input:focus,.form-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input:disabled,.form-textarea:disabled{background:#f7fafc;cursor:not-allowed;opacity:.7}.form-textarea{resize:vertical;min-height:120px;font-family:inherit}.submit-success{background:#f0fff4;border:1px solid #68d391;border-radius:8px;padding:12px 16px;color:#2f855a;font-size:14px;font-weight:500}.submit-success p{margin:0}.submit-error{background:#fed7d7;border:1px solid #fc8181;border-radius:8px;padding:12px 16px;color:#c53030;font-size:14px;font-weight:500}.submit-error p{margin:0}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;padding:14px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;min-height:48px}.submit-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #667eea4d}.submit-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.social-section{text-align:center}.social-title{font-size:18px;font-weight:600;color:#2d3748;margin:0 0 16px}.social-links{display:flex;justify-content:center;gap:12px}.social-link{width:48px;height:48px;background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#667eea;font-size:24px;text-decoration:none;transition:all .2s ease}.social-link:hover{background:#667eea;color:#fff;transform:translateY(-2px)}@media (max-width: 768px){.contact-content{padding:0 16px 20px}.contact-title{font-size:20px}.contact-description{font-size:14px}.contact-info-grid{grid-template-columns:1fr;gap:12px}.contact-info-card{padding:16px}.contact-form-section{padding:20px}.form-row{grid-template-columns:1fr;gap:16px}.form-section-title{font-size:18px}}@media (prefers-color-scheme: dark){.contact-title{color:#f7fafc}.contact-description{color:#a0aec0}.contact-info-card{background:#2d3748;border-color:#ffffff1a}.contact-info-title{color:#f7fafc}.contact-info-main{color:#e2e8f0}.contact-info-desc{color:#a0aec0}.contact-form-section{background:#2d3748;border-color:#ffffff1a}.form-section-title,.form-label{color:#f7fafc}.form-input,.form-textarea{background:#4a5568;border-color:#4a5568;color:#f7fafc}.form-input:focus,.form-textarea:focus{border-color:#667eea}.form-input:disabled,.form-textarea:disabled{background:#2d3748}.social-title{color:#f7fafc}.social-link{background:#4a5568;border-color:#ffffff1a;color:#667eea}.social-link:hover{background:#667eea;color:#fff}}.about-content{padding:0 20px 20px}.about-intro{margin-bottom:32px;text-align:center}.about-title{font-size:24px;font-weight:700;color:#2d3748;margin:0 0 8px;letter-spacing:-.5px}.about-description{font-size:18px;color:#667eea;margin:0;line-height:1.5;font-weight:500}.section-title{font-size:20px;font-weight:600;color:#2d3748;margin:0 0 20px;text-align:center}.story-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014;border:1px solid rgba(0,0,0,.05);margin-bottom:32px}.story-content p{font-size:15px;color:#4a5568;line-height:1.7;margin:0 0 16px}.story-content p:last-child{margin-bottom:0}.features-section{margin-bottom:32px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.feature-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #00000014;border:1px solid rgba(0,0,0,.05);text-align:center;transition:transform .2s ease}.feature-card:hover{transform:translateY(-4px)}.feature-icon{width:56px;height:56px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;margin:0 auto 16px}.feature-title{font-size:18px;font-weight:600;color:#2d3748;margin:0 0 8px}.feature-description{font-size:14px;color:#718096;line-height:1.6;margin:0}.stats-section{margin-bottom:32px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:24px;text-align:center;color:#fff;transition:transform .2s ease}.stat-card:hover{transform:translateY(-2px)}.stat-icon{font-size:32px;margin-bottom:12px}.stat-number{font-size:32px;font-weight:700;margin-bottom:4px}.stat-label{font-size:14px;opacity:.9}.team-section{margin-bottom:32px}.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.team-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #00000014;border:1px solid rgba(0,0,0,.05);text-align:center;transition:transform .2s ease}.team-card:hover{transform:translateY(-2px)}.member-avatar{width:64px;height:64px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:600;margin:0 auto 16px}.member-name{font-size:18px;font-weight:600;color:#2d3748;margin:0 0 4px}.member-position{font-size:14px;color:#667eea;font-weight:500;margin:0 0 12px}.member-description{font-size:13px;color:#718096;line-height:1.5;margin:0}.mission-section{margin-bottom:32px}.mission-card{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:16px;padding:32px;text-align:center;border:1px solid #e2e8f0}.mission-icon{width:72px;height:72px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:18px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:36px;margin:0 auto 20px}.mission-title{font-size:22px;font-weight:600;color:#2d3748;margin:0 0 16px}.mission-description{font-size:16px;color:#4a5568;line-height:1.7;max-width:600px;margin:0 auto}.contact-cta{background:#fff;border-radius:16px;padding:32px;box-shadow:0 4px 20px #00000014;border:1px solid rgba(0,0,0,.05);text-align:center}.cta-title{font-size:20px;font-weight:600;color:#2d3748;margin:0 0 12px}.cta-description{font-size:15px;color:#4a5568;line-height:1.6;margin:0 0 16px}.cta-email{font-size:14px;color:#718096;margin:0}.cta-email a{color:#667eea;text-decoration:none;font-weight:500}.cta-email a:hover{text-decoration:underline}@media (max-width: 768px){.about-content{padding:0 16px 20px}.about-title{font-size:20px}.about-description{font-size:16px}.section-title{font-size:18px}.story-section{padding:20px}.features-grid{grid-template-columns:1fr;gap:16px}.feature-card{padding:20px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:20px}.stat-number{font-size:28px}.team-grid{grid-template-columns:1fr;gap:16px}.team-card{padding:20px}.mission-card{padding:24px}.mission-title{font-size:20px}.mission-description{font-size:15px}.contact-cta{padding:24px}}@media (prefers-color-scheme: dark){.about-title,.section-title{color:#f7fafc}.story-section{background:#2d3748;border-color:#ffffff1a}.story-content p{color:#e2e8f0}.feature-card{background:#2d3748;border-color:#ffffff1a}.feature-title{color:#f7fafc}.feature-description{color:#a0aec0}.team-card{background:#2d3748;border-color:#ffffff1a}.member-name{color:#f7fafc}.member-description{color:#a0aec0}.mission-card{background:linear-gradient(135deg,#4a5568,#2d3748);border-color:#ffffff1a}.mission-title{color:#f7fafc}.mission-description{color:#e2e8f0}.contact-cta{background:#2d3748;border-color:#ffffff1a}.cta-title{color:#f7fafc}.cta-description{color:#e2e8f0}.cta-email{color:#a0aec0}}.image-cropper-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .3s ease-out}.image-cropper-modal{background:#fff;border-radius:20px;width:90vw;max-width:500px;max-height:90vh;overflow:hidden;box-shadow:0 20px 40px #0000004d;animation:slideInUp .3s ease-out;display:flex;flex-direction:column}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.cropper-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb;background:#f8fafc}.cropper-header h3{display:flex;align-items:center;gap:10px;margin:0;font-size:18px;font-weight:600;color:#374151}.close-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:#e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;transition:all .2s ease}.close-button:hover{background:#d1d5db;color:#374151}.cropper-content{padding:24px;flex:1;display:flex;flex-direction:column}.image-container{position:relative;display:flex;align-items:center;justify-content:center;min-height:300px;flex:1;background:#f9fafb;border-radius:12px;border:2px dashed #d1d5db;margin-bottom:16px;-webkit-user-select:none;user-select:none;overflow:hidden}.image-container img{max-width:100%;max-height:100%;border-radius:8px;position:relative;z-index:1}.crop-overlay-fixed{position:absolute;border:3px solid #667eea;border-radius:12px;box-shadow:0 0 0 2px #667eea33,0 0 0 9999px #0009;pointer-events:none;z-index:3}.crop-overlay-fixed:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;border:1px solid rgba(255,255,255,.8);border-radius:10px}.image-container img{border-radius:8px;display:block}.cropper-hint{text-align:center;margin-bottom:8px}.cropper-hint p{margin:0;font-size:14px;color:#6b7280;line-height:1.4}.cropper-actions{display:flex;gap:12px;padding:20px 24px;border-top:1px solid #e5e7eb;background:#f8fafc}.cancel-button,.crop-button{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.cancel-button{background:#e5e7eb;color:#6b7280}.cancel-button:hover{background:#d1d5db;color:#374151}.crop-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.crop-button:hover{transform:translateY(-1px);box-shadow:0 6px 16px #667eea66}@media (max-width: 640px){.image-cropper-modal{width:95vw;max-width:400px;max-height:85vh;margin:20px}.image-container{min-height:250px}.cropper-header{padding:16px 20px}.cropper-header h3{font-size:16px}.cropper-content{padding:20px}.cropper-actions{padding:16px 20px;flex-direction:column}.cancel-button,.crop-button{padding:14px 20px}}@media (prefers-color-scheme: dark){.image-cropper-modal{background:#1f2937}.cropper-header{background:#111827;border-color:#374151}.cropper-header h3{color:#f9fafb}.close-button{background:#374151;color:#9ca3af}.close-button:hover{background:#4b5563;color:#f3f4f6}.image-container{background:#111827;border-color:#374151}.cropper-hint p{color:#9ca3af}.cropper-actions{background:#111827;border-color:#374151}.cancel-button{background:#374151;color:#9ca3af}.cancel-button:hover{background:#4b5563;color:#f3f4f6}.crop-overlay-fixed{border-color:#90cdf4;box-shadow:0 0 0 2px #90cdf433,0 0 0 9999px #000000b3}.crop-overlay-fixed:before{border-color:#ffffffe6}}.user-profile-edit{padding:20px;background:transparent;color:#333}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:16px;color:#666}.loading-spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.message{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:12px;margin-bottom:24px;font-weight:500;animation:slideInDown .3s ease-out;box-shadow:0 4px 12px #0000001a}.message.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.message.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.message.info{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.message-icon{font-size:20px;flex-shrink:0}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.profile-form{background:#fff;border-radius:20px;padding:32px;box-shadow:0 4px 20px #00000014;border:1px solid #e5e7eb}.form-section{margin-bottom:32px}.form-section:last-of-type{margin-bottom:24px}.form-section h3{font-size:18px;font-weight:600;margin:0 0 20px;color:#667eea;position:relative;padding-bottom:8px}.form-section h3:after{content:"";position:absolute;bottom:0;left:0;width:40px;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px}.avatar-upload-section{display:flex;align-items:center;gap:20px;padding:20px;background:#f8fafc;border-radius:16px;border:2px dashed #e5e7eb;transition:all .3s ease;cursor:pointer;-webkit-user-select:none;user-select:none}.avatar-upload-section:hover{border-color:#667eea;background:#f0f4ff;transform:translateY(-2px);box-shadow:0 4px 16px #667eea1a}.avatar-upload-section.uploading{cursor:not-allowed;opacity:.8}.avatar-upload-section.uploading:hover{transform:none;box-shadow:none}.avatar-preview{position:relative;flex-shrink:0}.avatar-circle{width:80px;height:80px;border-radius:50%;overflow:hidden;border:3px solid white;box-shadow:0 4px 12px #0000001a;background:#f3f4f6;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.preview-image{width:100%!important;height:100%!important;border-radius:0!important;object-fit:cover!important;border:none!important;box-shadow:none!important;transition:all .3s ease!important;display:block!important}.avatar-upload-section:hover .avatar-circle{transform:scale(1.05)}.avatar-upload-info{flex:1}.upload-title{font-size:16px;font-weight:600;color:#374151;margin:0 0 4px;transition:color .3s ease}.avatar-upload-section:hover .upload-title{color:#667eea}.upload-hint{font-size:14px;color:#6b7280;margin:0;line-height:1.4;transition:color .3s ease}.avatar-upload-section:hover .upload-hint{color:#667eea}.form-group label{display:flex;align-items:center;gap:8px;font-weight:500;margin-bottom:8px;color:#374151;font-size:14px}.field-icon{font-size:16px;color:#667eea}.form-group input,.form-group textarea{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;transition:all .3s ease;background:#fff;color:#333;box-sizing:border-box;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px;line-height:1.5}.form-group input.disabled-input{background:#f9fafb;color:#6b7280;cursor:not-allowed;border-color:#d1d5db}.field-note{display:block;margin-top:6px;font-size:12px;color:#6b7280;font-style:italic}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px}.stat-item{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:20px;text-align:center;color:#fff;box-shadow:0 4px 16px #667eea33;transition:transform .2s ease}.stat-item:hover{transform:translateY(-2px)}.stat-value{font-size:28px;font-weight:700;margin-bottom:4px;line-height:1}.stat-label{font-size:12px;opacity:.9;font-weight:500;line-height:1.3}.form-actions{display:flex;justify-content:center;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.save-button{display:flex;align-items:center;gap:10px;padding:14px 32px;background:#e5e7eb;color:#6b7280;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:not-allowed;transition:all .3s ease;min-width:160px;justify-content:center;box-shadow:0 2px 8px #0000001a}.save-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;box-shadow:0 4px 16px #667eea4d}.save-button.active:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.save-button:disabled{cursor:not-allowed;transform:none}.button-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 768px){.user-profile-edit{padding:16px}.profile-form{padding:24px;border-radius:16px}.form-section h3{font-size:16px}.avatar-upload-section{flex-direction:column;text-align:center;gap:16px;padding:16px}.preview-image{width:70px;height:70px}.stats-grid{grid-template-columns:1fr 1fr;gap:12px}.stat-item{padding:16px}.stat-value{font-size:24px}.gender-selection-compact{gap:6px}.gender-option-compact{padding:8px 12px;font-size:13px;min-width:60px}.select-button{padding:12px 14px;font-size:15px;height:48px}.select-option{padding:12px 14px;font-size:14px;height:48px}.select-dropdown{max-height:200px}.select-option:hover{padding-left:18px}.save-button{padding:12px 28px;font-size:15px}.form-group input,.form-group textarea{padding:12px 14px;font-size:15px}}@media (max-width: 480px){.user-profile-edit{padding:12px}.profile-form{padding:20px;border-radius:16px}.avatar-upload-section{padding:12px}.preview-image{width:60px;height:60px}.upload-title{font-size:14px}.upload-hint{font-size:12px}.stats-grid{grid-template-columns:1fr}.form-section{margin-bottom:24px}.form-group{margin-bottom:20px}.gender-selection-compact{gap:4px}.gender-option-compact{padding:8px 10px;font-size:12px;min-width:50px}.select-button{padding:12px 14px;font-size:15px;height:46px}.select-option{padding:10px 14px;font-size:14px;height:46px}.custom-occupation-input{padding:12px 14px;font-size:15px}.select-dropdown{max-height:180px}.select-option:hover{padding-left:16px}.select-arrow{font-size:12px}.form-actions{margin-top:24px;padding-top:20px}.save-button{width:100%;padding:14px 20px}}@media (prefers-color-scheme: dark){.user-profile-edit{color:#f7fafc}.profile-form{background:#2d3748;border-color:#4a5568}.form-section h3{color:#90cdf4}.form-group label{color:#e2e8f0}.field-icon{color:#90cdf4}.form-group input,.form-group textarea{background:#1a202c;border-color:#4a5568;color:#e2e8f0}.form-group input:focus,.form-group textarea:focus{border-color:#90cdf4;box-shadow:0 0 0 3px #90cdf41a}.form-group input.disabled-input{background:#2d3748;color:#a0aec0;border-color:#4a5568}.field-note{color:#a0aec0}.form-actions{border-color:#4a5568}.avatar-upload-section{background:#1a202c;border-color:#4a5568}.avatar-upload-section:hover{border-color:#90cdf4;background:#2d3748}.avatar-upload-section:hover .upload-title,.avatar-upload-section:hover .upload-hint{color:#90cdf4}.upload-title{color:#e2e8f0}.upload-hint{color:#a0aec0}.message.success{background:#064e3b;color:#6ee7b7;border-color:#047857}.message.error{background:#7f1d1d;color:#fca5a5;border-color:#dc2626}.message.info{background:#1e3a8a;color:#93c5fd;border-color:#3b82f6}}@media (prefers-contrast: high){.profile-form{border-width:2px;border-color:#374151}.form-group input,.form-group textarea{border-width:2px}.save-button.active{border:2px solid #667eea}.message{border-width:2px}.stat-item{border:2px solid rgba(255,255,255,.3)}}.gender-selection-compact{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.gender-option-compact{padding:10px 16px;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;font-family:inherit;font-size:14px;font-weight:500;color:#374151;min-width:70px;text-align:center}.gender-option-compact:hover{background:#f1f5f9;border-color:#cbd5e1}.gender-option-compact.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;box-shadow:0 2px 8px #667eea4d}.custom-select{position:relative;width:100%;outline:none!important;border:none!important;box-shadow:none!important;padding:0!important;margin:0!important}.custom-select:focus,.custom-select:focus-visible,.custom-select:focus-within{outline:none!important;border:none!important;box-shadow:none!important}.select-button{width:100%;padding:14px 16px;background:#fff;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;font-family:inherit;color:#333;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:space-between;text-align:left;box-sizing:border-box;height:52px;gap:12px}.select-button:hover{border-color:#d1d5db}.select-button:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.custom-select,.custom-select:focus,.custom-select:focus-within,.custom-select:focus-visible,.custom-select:active{outline:none!important;border:none!important;box-shadow:none!important;background:none!important}.custom-select *,.custom-select *:focus,.custom-select *:focus-within,.custom-select *:focus-visible{outline:none!important}.custom-select button{outline:none!important}.custom-select button:focus{outline:none!important}.select-value{flex:1;color:#374151;font-weight:500;padding:0;margin:0;border:0;background:none}.select-value:empty:before{content:attr(data-placeholder);color:#9ca3af;font-weight:400}.select-arrow{font-size:14px;color:#667eea;transition:all .3s ease;margin:0;padding:0;font-weight:600}.select-arrow.open{transform:rotate(180deg);color:#764ba2}.select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 25px #00000026;z-index:1000;max-height:240px;overflow:hidden;animation:dropdownSlideIn .2s ease-out}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.select-option-list{display:flex;flex-direction:column;max-height:240px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#e5e7eb #f8fafc}.select-option-list::-webkit-scrollbar{width:6px}.select-option-list::-webkit-scrollbar-track{background:#f8fafc;border-radius:3px}.select-option-list::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:3px}.select-option-list::-webkit-scrollbar-thumb:hover{background:#d1d5db}.select-option{padding:14px 16px;background:#fff;border:none;cursor:pointer;transition:all .2s ease;font-family:inherit;font-size:16px;color:#374151;text-align:left;border-bottom:1px solid #f1f5f9;font-weight:500;height:52px;display:flex;align-items:center;box-sizing:border-box}.select-option:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#667eea;padding-left:20px}.select-option.selected{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;position:relative}.select-option.selected:after{content:"✓";position:absolute;right:16px;top:50%;transform:translateY(-50%);font-weight:700;font-size:16px}.select-option:last-child{border-bottom:none;border-radius:0 0 10px 10px}.select-option:first-child{border-radius:10px 10px 0 0}.custom-occupation-input{margin-top:12px;width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;background:#fff;color:#333;box-sizing:border-box;font-family:inherit;transition:all .3s ease}.custom-occupation-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.error,.form-group textarea.error,.form-group select.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.field-error{display:block;margin-top:6px;font-size:12px;color:#ef4444;font-weight:500}.form-group select{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;background:#fff;color:#333;box-sizing:border-box;font-family:inherit;cursor:pointer;transition:all .3s ease}.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group select:hover{border-color:#d1d5db}.checkbox-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:8px}.checkbox-item{display:flex!important;align-items:center;gap:8px;padding:12px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;font-weight:400!important;margin:0!important;min-height:auto}.checkbox-item:hover{background:#f1f5f9;border-color:#cbd5e1}.checkbox-item input[type=checkbox]{width:auto!important;margin:0;padding:0;border:none;box-sizing:border-box;cursor:pointer}.checkbox-item input[type=checkbox]:checked+span{color:#667eea;font-weight:500}.checkbox-item span{font-size:14px;color:#374151;transition:color .2s ease}@media (prefers-color-scheme: dark){.form-group select{background:#374151;color:#f9fafb;border-color:#4b5563}.form-group select:focus{border-color:#667eea}.checkbox-item{background:#374151;border-color:#4b5563;color:#f9fafb}.checkbox-item:hover{background:#4b5563;border-color:#6b7280}.checkbox-item span{color:#f9fafb}.checkbox-item input[type=checkbox]:checked+span{color:#93c5fd}}.user-profile-page{position:fixed;width:100vw;height:100vh;background:linear-gradient(135deg,#fff8f0,#f0f9ff);padding:0;box-sizing:border-box}.profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top:4px solid #ff6b35;border-radius:50%;animation:profileSpin 1s linear infinite;margin-bottom:16px}.notification{position:fixed;top:30px;left:50%;transform:translate(-50%) translateY(-100px);background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001f;padding:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:10001;max-width:320px;width:calc(100% - 40px);opacity:0;transition:all .3s ease;pointer-events:none}.notification.show{transform:translate(-50%) translateY(0);opacity:1;pointer-events:auto}.notification.success{border-left:4px solid #22c55e;background:#f0fdf4}.notification.error{border-left:4px solid #ef4444;background:#fef2f2}.notification.info{border-left:4px solid #3b82f6;background:#eff6ff}.notification span{color:#333;font-size:.9rem;font-weight:500;flex:1}.notification-close{background:none;border:none;color:#666;font-size:1.1rem;cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.notification-close:hover{color:#333}.profile-auth-container{max-width:800px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:center;min-height:100vh}.auth-welcome{text-align:center;background:#fff;border-radius:20px;padding:60px 40px;box-shadow:0 8px 32px #00000014;margin-bottom:32px}.welcome-icon{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#ff6b35,#f7931e);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:3rem;color:#fff;box-shadow:0 8px 32px #ff6b354d}.welcome-title{margin:0 0 16px;font-size:2rem;font-weight:700;color:#333;text-shadow:0 2px 4px rgba(0,0,0,.05)}.welcome-description{font-size:1.1rem;color:#666;line-height:1.6;max-width:500px;margin:0 auto 32px}.auth-action-btn{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;border:none;border-radius:16px;padding:16px 32px;font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;margin:0 auto;transition:all .3s ease;box-shadow:0 6px 20px #ff6b354d}.auth-action-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #ff6b3566}.auth-action-btn:active{transform:translateY(0)}.auth-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.feature-item{background:#fff;border-radius:16px;padding:32px 24px;display:flex;align-items:flex-start;gap:20px;box-shadow:0 4px 20px #0000000d;transition:all .3s ease}.feature-item:hover{transform:translateY(-4px);box-shadow:0 8px 32px #0000001a}.feature-icon{width:48px;height:48px;background:#ff6b351a;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#ff6b35;flex-shrink:0}.feature-content{flex:1}.feature-title{margin:0 0 8px;font-size:1.1rem;font-weight:600;color:#333}.feature-description{margin:0;font-size:.9rem;color:#666;line-height:1.5}.profile-main-container{width:100%;margin:0;padding:0;display:flex;flex-direction:column;height:100vh;box-sizing:border-box}.profile-nav{background:#fff;border-radius:16px;padding:16px 20px;margin-bottom:20px;box-shadow:0 4px 20px #00000014;display:flex;align-items:center;justify-content:space-between}.nav-tabs{display:flex;gap:4px;background:#f5f5f5;border-radius:12px;padding:4px}.nav-tab{background:none;border:none;padding:12px 16px;border-radius:10px;font-size:.85rem;font-weight:500;color:#666;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s ease;white-space:nowrap;flex:1;justify-content:center}.nav-tab:hover{color:#333;background:#ffffffb3}.nav-tab.active{background:#ff6b35;color:#fff;box-shadow:0 4px 16px #ff6b354d}.nav-tab svg{font-size:1.1rem}.logout-btn{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#dc2626;font-size:1.1rem;padding:10px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.logout-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#b91c1c;transform:scale(1.05)}.profile-content{flex:1;overflow-y:auto;margin-bottom:80px}@keyframes profileSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.user-profile-page::-webkit-scrollbar,.profile-content::-webkit-scrollbar{width:8px}.user-profile-page::-webkit-scrollbar-track,.profile-content::-webkit-scrollbar-track{background:transparent}.user-profile-page::-webkit-scrollbar-thumb,.profile-content::-webkit-scrollbar-thumb{background:#0000001a;border-radius:4px}.user-profile-page::-webkit-scrollbar-thumb:hover,.profile-content::-webkit-scrollbar-thumb:hover{background:#0003}@media (max-width: 768px){.user-profile-page{padding:0}.profile-main-container{height:100vh}.auth-welcome{padding:40px 24px}.welcome-title{font-size:1.7rem}.welcome-description{font-size:1rem}.auth-features{grid-template-columns:1fr}.feature-item{padding:24px 20px}.nav-tab{padding:10px 16px;font-size:.85rem}.nav-tab svg{font-size:1rem}}@media (max-width: 480px){.user-profile-page{padding:0}.profile-main-container{height:100vh}.auth-welcome{padding:32px 20px}.welcome-icon{width:80px;height:80px;font-size:2.5rem}.welcome-title{font-size:1.5rem}.welcome-description{font-size:.95rem}.auth-action-btn{padding:14px 28px;font-size:1rem}.feature-item{flex-direction:column;text-align:center;padding:20px 16px}.feature-icon{width:40px;height:40px;font-size:1.3rem}.profile-nav{padding:12px 16px}.nav-tabs{flex:1;justify-content:center}.nav-tab{padding:8px 4px;font-size:.7rem;gap:4px;flex-direction:column;min-width:0}.nav-tab svg{font-size:1rem}.logout-btn{padding:8px;font-size:1rem}.notification{top:20px;max-width:280px;width:calc(100% - 24px)}}@media (prefers-color-scheme: dark){.user-profile-page{background:linear-gradient(135deg,#1a1a1a,#2d2d2d)}.auth-welcome,.feature-item,.profile-nav{background:#2a2a2a;color:#f5f5f5}.welcome-title,.feature-title{color:#f5f5f5}.welcome-description,.feature-description{color:#a3a3a3}.nav-tabs{background:#3a3a3a}.nav-tab{color:#a3a3a3}.nav-tab:hover{color:#f5f5f5;background:#ffffff1a}.notification.success{background:#064e3b;color:#d1fae5}.notification.error{background:#7f1d1d;color:#fecaca}}@media (prefers-contrast: high){.auth-welcome,.feature-item,.profile-nav{border:2px solid #ccc}.nav-tab.active{border:2px solid #ff6b35}.logout-btn{border-width:2px}.notification{border:2px solid #ccc}.notification.success{border-color:#22c55e}.notification.error{border-color:#ef4444}}.restaurant-image-upload{max-width:800px;margin:0 auto;padding:20px;border:2px dashed #ddd;border-radius:12px;background:#fafafa}.restaurant-image-upload h3{margin:0 0 20px;color:#333;text-align:center}.upload-mode-selection{margin-bottom:25px}.mode-btn{flex:1;padding:12px 20px;border:none;background:#fff;color:#666;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;position:relative}.url-upload-mode{margin-bottom:20px}.url-input-section{background:#fff;padding:20px;border-radius:8px;border:2px solid #ddd}.url-inputs{margin-bottom:15px}.url-input-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.url-input{flex:1;padding:12px;border:2px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s ease}.url-input:focus{outline:none;border-color:#007bff}.url-input:disabled{opacity:.6;background:#f8f9fa}.remove-url-btn{width:36px;height:36px;border:none;border-radius:50%;background:#dc3545;color:#fff;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease;flex-shrink:0}.remove-url-btn:hover:not(:disabled){background:#c82333}.remove-url-btn:disabled{opacity:.5;cursor:not-allowed}.add-url-btn{padding:10px 20px;border:2px dashed #007bff;border-radius:6px;background:transparent;color:#007bff;font-size:14px;cursor:pointer;transition:all .3s ease}.add-url-btn:hover:not(:disabled){background:#007bff1a;border-style:solid}.add-url-btn:disabled{opacity:.6;cursor:not-allowed}.file-input-section{margin-bottom:20px}.file-input{width:100%;padding:12px;border:2px solid #ddd;border-radius:8px;font-size:16px;cursor:pointer;background:#fff;transition:border-color .3s ease}.file-input:hover{border-color:#007bff}.file-input:disabled{opacity:.6;cursor:not-allowed}.upload-info{margin-top:10px;padding:10px;background:#e9ecef;border-radius:6px;font-size:14px;color:#666}.upload-info p{margin:5px 0}.preview-section{margin:20px 0}.preview-section h4{margin:0 0 15px;color:#333}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px}.preview-item{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease}.preview-image-container{position:relative;height:150px;overflow:hidden}.preview-image{width:100%;height:100%;object-fit:cover}.remove-preview-btn{position:absolute;top:8px;right:8px;width:30px;height:30px;border:none;border-radius:50%;background:#ff3b30e6;color:#fff;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.remove-preview-btn:hover{background:#ff3b30}.remove-preview-btn:disabled{opacity:.5;cursor:not-allowed}.preview-info{padding:10px}.file-name{margin:0 0 5px;font-weight:500;font-size:14px;color:#333;word-break:break-word}.file-size{margin:0;font-size:12px;color:#666}.primary-badge{display:inline-block;margin-top:5px;padding:2px 8px;background:#007bff;color:#fff;border-radius:12px;font-size:11px;font-weight:500}.upload-progress-section{margin:20px 0}.upload-progress-section h4{margin:0 0 15px;color:#333}.progress-item{display:flex;align-items:center;margin-bottom:10px;gap:15px}.progress-label{min-width:120px;font-size:14px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.progress-bar{flex:1;height:8px;background:#e9ecef;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);border-radius:4px;transition:width .3s ease}.progress-text{min-width:40px;text-align:right;font-size:14px;color:#666}.upload-actions{text-align:center;margin-top:20px}.upload-btn{padding:12px 30px;border:none;border-radius:8px;background:#007bff;color:#fff;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;min-width:150px}.upload-btn:hover:not(:disabled){background:#0056b3;transform:translateY(-1px);box-shadow:0 4px 12px #007bff4d}.upload-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.upload-btn.uploading{background:#28a745}.upload-btn.uploading:after{content:"";display:inline-block;width:16px;height:16px;margin-left:8px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.restaurant-image-upload{padding:15px}.preview-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.progress-item{flex-direction:column;align-items:stretch;gap:5px}.progress-label{min-width:auto}.progress-text{text-align:center}}@media (max-width: 480px){.preview-grid{grid-template-columns:1fr 1fr}.upload-btn{width:100%;padding:15px}}.add-file-btn{background:linear-gradient(135deg,#6c757d,#5a6268);color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;white-space:nowrap;margin:10px 0}.add-file-btn:hover:not(:disabled){background:linear-gradient(135deg,#5a6268,#495057);transform:translateY(-1px);box-shadow:0 2px 8px #6c757d4d}.add-file-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.download-url-mode{background:#fff;border:2px solid #e3f2fd;border-radius:12px;padding:25px;margin-bottom:20px}.download-url-mode h4{margin:0 0 15px;color:#1976d2;font-size:18px;font-weight:600}.mode-description{background:#e3f2fd;border:1px solid #bbdefb;border-radius:8px;padding:15px;margin-bottom:20px;color:#1565c0;font-size:14px;line-height:1.5}.download-info{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:15px;margin-top:15px}.download-info p{margin:8px 0;font-size:13px;color:#666;display:flex;align-items:center;gap:8px}.download-info p:before{content:"📥";font-size:12px}.batch-progress{background:#e8f5e8;border:1px solid #c8e6c9;border-radius:8px;padding:15px;margin-bottom:15px}.batch-progress .progress-label{color:#2e7d32;font-weight:500;margin-bottom:8px}.google-drive-mode{margin-bottom:20px}.google-drive-section{background:#fff;padding:20px;border-radius:8px;border:2px solid #ddd}.google-drive-login{text-align:center;padding:20px}.google-login-btn{background:#4285f4;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:16px;cursor:pointer;transition:background-color .3s ease;margin-top:10px}.google-login-btn:hover:not(:disabled){background:#3367d6}.google-login-btn:disabled{opacity:.6;cursor:not-allowed}.google-drive-logged-in{padding:10px 0}.google-drive-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #eee}.google-drive-header p{margin:0;color:#28a745;font-weight:500}.google-logout-btn{background:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .3s ease}.google-logout-btn:hover:not(:disabled){background:#c82333}.google-logout-btn:disabled{opacity:.6;cursor:not-allowed}.google-drive-select-btn{background:#34a853;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:16px;cursor:pointer;transition:background-color .3s ease;width:100%}.google-drive-select-btn:hover:not(:disabled){background:#2d8f47}.google-drive-select-btn:disabled{opacity:.6;cursor:not-allowed}.preview-item{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease;position:relative}.preview-item:hover{transform:translateY(-2px)}.preview-item .source-badge{position:absolute;top:8px;left:8px;background:#000000b3;color:#fff;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:500;z-index:2}.preview-item .source-badge.local{background:#007bffcc}.preview-item .source-badge.google-drive{background:#34a853cc}.preview-item .source-badge.url{background:#ffc107cc;color:#000}.file-input-section{margin-bottom:20px;position:relative}.file-input{display:none}.mode-buttons{display:flex;gap:0;border:2px solid #ddd;border-radius:8px;overflow:hidden;background:#fff}.mode-btn{flex:1;padding:12px 16px;border:none;background:#fff;color:#666;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;position:relative;border-right:1px solid #ddd}.mode-btn:last-child{border-right:none}.mode-btn:hover:not(:disabled){background:#f8f9fa;color:#333}.mode-btn.active{background:#007bff;color:#fff}.mode-btn:disabled{opacity:.6;cursor:not-allowed}.upload-progress-section{margin:20px 0;padding:15px;background:#f8f9fa;border-radius:8px}.upload-progress-section h4{margin:0 0 15px;color:#333;font-size:1.1rem}.progress-item{display:flex;align-items:center;margin-bottom:12px;gap:15px;padding:8px;background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a}.progress-label{min-width:140px;font-size:14px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.progress-bar{flex:1;height:10px;background:#e9ecef;border-radius:5px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);border-radius:5px;transition:width .3s ease;position:relative}.progress-fill:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background-image:linear-gradient(-45deg,rgba(255,255,255,.2) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.2) 50%,rgba(255,255,255,.2) 75%,transparent 75%,transparent);background-size:50px 50px;animation:move 2s linear infinite}@keyframes move{0%{background-position:0 0}to{background-position:50px 50px}}.progress-text{min-width:45px;text-align:right;font-size:14px;color:#666;font-weight:600}.upload-status{padding:8px 12px;border-radius:4px;font-size:14px;font-weight:500;text-align:center}.upload-status.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.upload-status.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.upload-status.uploading{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}@media (max-width: 768px){.restaurant-image-upload{padding:15px;margin:10px}.mode-buttons{flex-direction:column}.mode-btn{border-right:none;border-bottom:1px solid #ddd}.mode-btn:last-child{border-bottom:none}.google-drive-header{flex-direction:column;gap:10px;align-items:flex-start}.progress-item{flex-direction:column;align-items:stretch;gap:8px}.progress-label{min-width:auto;text-align:center}.progress-text{text-align:center}}@media (max-width: 480px){.add-file-btn{padding:14px 20px;font-size:15px}.google-login-btn,.google-drive-select-btn{font-size:14px;padding:10px 20px}}.quick-add-restaurant{background:#fff;border-radius:12px;margin:0 0 25px;box-shadow:0 2px 8px #0000001a;padding:25px 30px;border-left:4px solid #28a745}.quick-add-form{display:grid;grid-template-columns:200px 150px 1fr 100px 100px 80px 200px auto;gap:12px;align-items:flex-start}.quick-input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;outline:none;transition:border-color .2s ease;box-sizing:border-box}.quick-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.quick-input-wide,.quick-input-tags{grid-column:span 1}.quick-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;outline:none;background:#fff;cursor:pointer;transition:border-color .2s ease}.quick-select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.quick-image-btn{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;white-space:nowrap;box-shadow:0 2px 4px #17a2b84d;display:flex;align-items:center;gap:6px}.quick-image-btn:hover:not(:disabled){background:linear-gradient(135deg,#138496,#117a8b);transform:translateY(-1px);box-shadow:0 4px 8px #17a2b866}.quick-image-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.quick-submit-btn{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;white-space:nowrap}.quick-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#20c997,#17a2b8);transform:translateY(-1px);box-shadow:0 2px 8px #28a7454d}.quick-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.spicy-checkbox{display:flex;align-items:center;gap:6px;font-size:14px;cursor:pointer}.spicy-checkbox input[type=checkbox]{cursor:pointer}.quick-image-previews{grid-column:span 8;display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.quick-preview-item{position:relative;background:#fff;border:1px solid #dee2e6;border-radius:4px;overflow:hidden;width:80px;flex-shrink:0}.quick-preview-image{width:100%;height:60px;object-fit:cover;display:block}.quick-remove-image{position:absolute;top:2px;right:2px;width:18px;height:18px;border:none;border-radius:50%;background:#dc3545e6;color:#fff;font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.quick-remove-image:hover:not(:disabled){background:#dc3545}.quick-remove-image:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 1400px){.quick-add-form{grid-template-columns:180px 120px 1fr 90px 90px 70px 180px auto;gap:8px}.quick-input,.quick-select{font-size:13px;padding:6px 8px}.quick-submit-btn,.quick-image-btn{font-size:13px;padding:6px 12px}}@media (max-width: 1200px){.quick-add-form{grid-template-columns:1fr 1fr;gap:10px}.quick-input-wide,.quick-input-tags{grid-column:span 2}.quick-submit-btn{grid-column:span 2;justify-self:center;min-width:120px}.spicy-checkbox{grid-column:span 2;justify-self:center}.quick-image-previews{grid-column:span 2}}@media (max-width: 768px){.quick-add-form{grid-template-columns:1fr;gap:12px}.quick-input-wide,.quick-input-tags{grid-column:span 1}.quick-submit-btn,.spicy-checkbox{grid-column:span 1;width:100%}.quick-input,.quick-select{font-size:14px;padding:10px 12px}.quick-image-previews{grid-column:span 1}}.toast{position:fixed;top:20px;right:20px;z-index:9999;min-width:300px;max-width:400px;padding:0;border-radius:8px;box-shadow:0 4px 12px #00000026;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transform:translate(100%);transition:transform .3s ease-in-out,opacity .3s ease-in-out;opacity:0}.toast-show{transform:translate(0);opacity:1}.toast-hide{transform:translate(100%);opacity:0}.toast-content{display:flex;align-items:center;padding:16px 20px;gap:12px}.toast-icon{font-size:18px;font-weight:700;flex-shrink:0}.toast-message{font-size:14px;font-weight:500;line-height:1.4}.toast-success{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.toast-success .toast-icon{color:#fff;background:#fff3;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:14px}.toast-error{background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff}.toast-error .toast-icon{color:#fff;background:#fff3;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:14px}.toast-warning{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.toast-warning .toast-icon{color:#fff;background:#fff3;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:14px}.toast-info{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff}.toast-info .toast-icon{color:#fff;background:#fff3;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:14px}@media (max-width: 480px){.toast{right:10px;left:10px;min-width:auto;max-width:none}.toast-content{padding:14px 16px}.toast-message{font-size:13px}}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}.confirm-dialog{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;max-width:400px;width:90%;max-height:90vh;overflow:hidden;animation:slideIn .3s ease-out}.confirm-dialog-header{padding:24px 24px 16px;text-align:center}.confirm-dialog-icon{font-size:48px;margin-bottom:16px;line-height:1}.confirm-dialog-title{margin:0;font-size:20px;font-weight:600;color:#333;line-height:1.3}.confirm-dialog-content{padding:0 24px 24px;text-align:center}.confirm-dialog-message{margin:0;font-size:16px;color:#666;line-height:1.5}.confirm-dialog-actions{padding:16px 24px 24px;display:flex;gap:12px;justify-content:center}.confirm-dialog-btn{border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:100px}.confirm-dialog-btn-cancel{background:#f5f5f5;color:#666}.confirm-dialog-btn-cancel:hover{background:#e0e0e0;color:#333}.confirm-dialog-btn-confirm{color:#fff;font-weight:600}.confirm-dialog-btn-warning{background:linear-gradient(135deg,#ff9800,#f57c00)}.confirm-dialog-btn-warning:hover{background:linear-gradient(135deg,#f57c00,#ef6c00);transform:translateY(-1px)}.confirm-dialog-btn-error{background:linear-gradient(135deg,#f44336,#d32f2f)}.confirm-dialog-btn-error:hover{background:linear-gradient(135deg,#d32f2f,#c62828);transform:translateY(-1px)}.confirm-dialog-btn-success{background:linear-gradient(135deg,#4caf50,#45a049)}.confirm-dialog-btn-success:hover{background:linear-gradient(135deg,#45a049,#3d8b40);transform:translateY(-1px)}.confirm-dialog-btn-info{background:linear-gradient(135deg,#2196f3,#1976d2)}.confirm-dialog-btn-info:hover{background:linear-gradient(135deg,#1976d2,#1565c0);transform:translateY(-1px)}@keyframes slideIn{0%{transform:scale(.9) translateY(-20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}@media (max-width: 480px){.confirm-dialog{width:95%}.confirm-dialog-header{padding:20px 20px 12px}.confirm-dialog-icon{font-size:40px;margin-bottom:12px}.confirm-dialog-title{font-size:18px}.confirm-dialog-content{padding:0 20px 20px}.confirm-dialog-message{font-size:14px}.confirm-dialog-actions{padding:12px 20px 20px;flex-direction:column}.confirm-dialog-btn{width:100%;min-width:auto}}.restaurant-manager{max-width:1400px;margin:0 auto;padding:20px;background:#f8f9fa;min-height:100vh}.manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding:25px 30px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #007bff}.manager-header h1{margin:0;color:#333;font-size:2.2rem;font-weight:700}.manager-actions{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:25px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #007bff}.primary-actions{display:flex;gap:12px;align-items:center}.export-buttons{display:flex;gap:8px;align-items:center}.action-btn-group{display:flex;gap:8px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;align-items:center}.btn{padding:10px 18px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;box-shadow:0 2px 4px #0000001a;position:relative;overflow:hidden}.btn-icon{font-size:16px;display:inline-flex;align-items:center;justify-content:center}.btn:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.btn:active{transform:translateY(0);box-shadow:0 1px 3px #0000001a}.btn-primary{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#0056b3,#004085)}.btn-add-restaurant{font-size:15px;padding:12px 20px;font-weight:700}.btn-cancel{background:linear-gradient(135deg,#dc3545,#c82333)}.btn-cancel:hover{background:linear-gradient(135deg,#c82333,#bd2130)}.btn-success{background:linear-gradient(135deg,#28a745,#1e7e34);color:#fff}.btn-success:hover{background:linear-gradient(135deg,#1e7e34,#155724)}.btn-secondary{background:linear-gradient(135deg,#6c757d,#5a6268);color:#fff}.btn-secondary:hover{background:linear-gradient(135deg,#5a6268,#495057)}.btn-info{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff}.btn-info:hover{background:linear-gradient(135deg,#138496,#117a8b)}.btn-export{font-size:13px;padding:8px 16px;font-weight:600;min-width:120px;justify-content:center}.btn-warning{background:linear-gradient(135deg,#ffc107,#e0a800);color:#212529}.btn-warning:hover{background:linear-gradient(135deg,#e0a800,#d39e00)}.btn-danger{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#c82333,#bd2130)}.btn-photo{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff;border:none;border-radius:6px;padding:8px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;box-shadow:0 1px 3px #17a2b84d}.btn-photo:hover{background:linear-gradient(135deg,#138496,#117a8b);transform:translateY(-1px);box-shadow:0 2px 6px #17a2b866}.btn-outline{background:#fff;color:#495057;border:1.5px solid #dee2e6;box-shadow:0 1px 3px #0000001a}.btn-outline:hover{background:#f8f9fa;border-color:#adb5bd;color:#495057;box-shadow:0 2px 6px #00000026}.clear-filters{color:#6c757d;border-color:#ced4da}.clear-filters:hover{color:#dc3545;border-color:#dc3545;background:#fff5f5}.clear-filters-suggestion{margin-top:15px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:0 1px 3px #0000001a}.btn-sm{padding:6px 12px;font-size:12px;gap:4px}.btn-lg{padding:12px 24px;font-size:15px}.table-action-btn{min-width:70px;justify-content:center;font-weight:500}.edit-actions,.normal-actions{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}.edit-actions .btn,.normal-actions .btn{margin:1px}.add-restaurant-form{background:#fff;padding:30px;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:30px}.add-restaurant-form h2{margin:0 0 25px;color:#333;font-size:1.8rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:2px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#007bff}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:25px;padding-top:20px;border-top:1px solid #eee}.image-upload-section{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:30px;overflow:hidden}.upload-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;background:#f8f9fa;border-bottom:1px solid #eee}.upload-header h2{margin:0;color:#333}.restaurant-list{background:#fff;border-radius:12px;padding:25px 30px;box-shadow:0 4px 12px #0000001a;border-left:4px solid #007bff;overflow-x:auto}.restaurant-list h2{margin:0 0 20px;color:#333;font-size:1.8rem}.empty-state{text-align:center;padding:60px 20px;color:#666;font-size:18px}.restaurant-table{width:100%;min-width:1200px;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.restaurant-table th,.restaurant-table td{padding:12px 8px;text-align:left;border-bottom:1px solid #eee;font-size:14px;vertical-align:middle}.restaurant-table th{background:#f8f9fa;font-weight:600;color:#495057;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.restaurant-table tbody tr{transition:background-color .2s ease}.restaurant-table tbody tr:hover{background:#f8f9fa}.restaurant-table tbody tr:last-child td{border-bottom:none}.restaurant-table .image-cell{width:120px;padding:8px;text-align:center}.restaurant-table .image-cell img{width:60px;height:45px;object-fit:cover;border-radius:4px;display:block;margin:0 auto 8px}.restaurant-table .no-image-table{width:60px;height:45px;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;background:#f0f0f0;border-radius:4px;color:#999;font-size:12px}.btn-photo-small{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff;border:none;border-radius:4px;padding:4px 8px;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 1px 2px #17a2b84d}.btn-photo-small:hover{background:linear-gradient(135deg,#138496,#117a8b);transform:translateY(-1px);box-shadow:0 2px 4px #17a2b866}.restaurant-table .name-cell{font-weight:600;color:#333}.restaurant-table .category-cell,.restaurant-table .address-cell{color:#666;max-width:200px}.restaurant-table .tags-cell{max-width:250px}.restaurant-table .price-cell{text-align:center;font-weight:600;color:#28a745}.restaurant-table .rating-cell{text-align:center;color:#ffc107}.restaurant-table .actions-cell{width:140px;text-align:right}.restaurant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:25px}.restaurant-card{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.restaurant-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.restaurant-image{height:200px;overflow:hidden;background:#f0f0f0;display:flex;align-items:center;justify-content:center;position:relative}.image-container{position:relative;width:100%;height:100%}.restaurant-image img{width:100%;height:100%;object-fit:cover}.image-source-badge{position:absolute;top:8px;right:8px;background:#000000b3;color:#fff;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.no-image{color:#999;font-size:16px}.restaurant-info{padding:20px}.restaurant-info h3{margin:0 0 10px;color:#333;font-size:1.4rem}.category{display:inline-block;padding:4px 12px;background:#e9ecef;color:#495057;border-radius:20px;font-size:12px;margin-bottom:10px}.rating{color:#ffc107;margin-bottom:10px;font-weight:500}.address{margin:8px 0;color:#666;font-size:14px}.description{margin:10px 0;color:#666;font-size:14px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.tag{padding:2px 8px;background:#e9ecef;color:#495057;border-radius:12px;font-size:11px;font-weight:500;white-space:nowrap}.restaurant-table .tags{display:inline-flex;flex-wrap:wrap;gap:3px;margin:0}.restaurant-table .tag{padding:1px 6px;font-size:10px;background:#f1f3f4;color:#5f6368;border-radius:8px}.restaurant-actions{display:flex;gap:8px;padding:15px 20px;background:#f8f9fa;border-top:1px solid #eee}.restaurant-actions .btn{flex:1;padding:8px 12px;font-size:12px;text-align:center}.loading,.error{text-align:center;padding:60px 20px;font-size:18px}.loading{color:#666}.error{color:#dc3545}@media (max-width: 768px){.restaurant-manager{padding:15px}.manager-actions{flex-direction:column;gap:15px;padding:15px}.primary-actions,.export-buttons,.btn-add-restaurant{width:100%;justify-content:center}.export-buttons{flex-direction:column;gap:8px}.btn-export{width:100%}.filter-info{flex-direction:column;gap:10px;text-align:center}.search-controls{padding:15px;gap:12px}.search-header{padding:12px 15px}.search-header h3{font-size:14px}.mode-btn{padding:6px 12px;font-size:12px}.filter-controls{flex-direction:column;align-items:stretch;gap:10px}.tags-header{flex-direction:column;gap:8px;align-items:flex-start}.tags-title{font-size:13px}.category-grid{padding:12px 15px;gap:6px}.category-tag{font-size:12px;padding:5px 10px}.edit-actions,.normal-actions{flex-direction:column;gap:4px}.table-action-btn{min-width:60px;font-size:11px;padding:4px 8px}.manager-header{flex-direction:column;gap:15px;text-align:center}.manager-header h1{font-size:2rem}.add-restaurant-form{padding:20px}.form-row{grid-template-columns:1fr;gap:0}.form-actions{flex-direction:column}.restaurant-grid{grid-template-columns:1fr}.restaurant-actions{flex-direction:column}.restaurant-actions .btn{margin-bottom:8px}}.section-header{margin-bottom:20px}.section-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#333;display:flex;align-items:center;gap:8px}.section-icon{font-size:1.2rem}.filter-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding:12px 15px;background:#f8f9fa;border-radius:6px;border-left:3px solid #007bff}.filter-info span{color:#495057;font-size:14px;font-weight:500}.tag-search-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;border:1px solid #e9ecef;overflow:hidden}.search-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:15px 20px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6}.search-header h3{margin:0;font-size:16px;font-weight:600;color:#495057;display:flex;align-items:center;gap:8px}.search-icon{font-size:18px}.selected-count{background:#007bff;color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.search-controls{padding:20px;display:flex;flex-direction:column;gap:15px}.filter-controls{display:flex;justify-content:space-between;align-items:center;gap:15px;flex-wrap:wrap}.clear-all-tags{color:#dc3545;border-color:#dc3545}.clear-all-tags:hover{background:#dc3545;color:#fff}.search-input-wrapper{position:relative;display:flex;align-items:center}.tag-search-input{flex:1;padding:10px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:14px;font-weight:500;transition:all .2s ease;background:#f8f9fa}.tag-search-input:focus{outline:none;border-color:#007bff;background:#fff;box-shadow:0 0 0 3px #007bff1a}.tag-search-input::placeholder{color:#8d9498}.clear-search-btn{position:absolute;right:8px;width:24px;height:24px;border:none;background:#6c757d;color:#fff;border-radius:50%;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.clear-search-btn:hover{background:#dc3545;transform:scale(1.1)}.match-mode-toggle{display:flex;background:#f1f3f4;border-radius:8px;padding:4px;align-self:flex-start}.mode-btn{padding:8px 16px;border:none;background:transparent;color:#6c757d;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.mode-btn:hover{color:#495057;background:#ffffff80}.mode-btn.active{background:#007bff;color:#fff;box-shadow:0 2px 4px #007bff4d}.mode-btn.active:hover{background:#0056b3}.tags-section{border-top:1px solid #e9ecef;background:#fafbfc}.tags-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.tags-title{color:#495057;font-size:14px;font-weight:600}.tags-count{color:#6c757d;font-size:13px;background:#fff;padding:4px 8px;border-radius:12px;border:1px solid #dee2e6}.category-grid{padding:15px 20px;display:flex;flex-wrap:wrap;gap:8px;max-height:300px;overflow-y:auto}.category-tag{background:#fff;border:1.5px solid #dee2e6;color:#495057;padding:6px 12px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;display:inline-flex;align-items:center;gap:4px;box-shadow:0 1px 2px #0000000d}.category-tag:hover{background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.category-tag.selected{background:#007bff;color:#fff;border-color:#0056b3;box-shadow:0 2px 6px #007bff4d}.category-tag.selected:hover{background:#0056b3;border-color:#004085}.tag-name{font-weight:600}.tag-count{opacity:.8;font-size:12px}.tag-added-icon{font-size:12px;font-weight:700;margin-left:2px}.no-tags-found{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#6c757d;font-style:italic;padding:30px;text-align:center;width:100%;background:#fff;border:2px dashed #dee2e6;border-radius:8px}.no-tags-icon{font-size:24px;opacity:.5}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-width:800px;width:90%;max-height:80vh;overflow-y:auto;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #eee;background:#f8f9fa;border-radius:12px 12px 0 0}.modal-header h3{margin:0;color:#333;font-size:1.6rem;font-weight:600}.modal-close-btn{background:#dc3545;color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;font-weight:700;transition:all .2s ease}.modal-close-btn:hover{background:#c82333;transform:scale(1.1)}.modal-body{padding:25px}@media (max-width: 768px){.modal-content{width:95%;max-height:85vh}.modal-header{padding:15px 20px}.modal-header h3{font-size:1.4rem}.modal-body{padding:20px}}@media (max-width: 480px){.upload-header{flex-direction:column;gap:15px;text-align:center}.upload-header h2{font-size:1.4rem}.category-grid{gap:4px;padding:8px}.category-tag{font-size:11px;padding:3px 8px}.modal-content{width:100%;height:100%;max-height:100vh;border-radius:0}.modal-header{border-radius:0}}.analytics-page{min-height:100vh;background:#f8f9fa;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding:25px 30px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #007bff}.analytics-title-section h1{margin:0;color:#333;font-size:2.2rem;font-weight:700}.analytics-subtitle{font-size:.95rem;color:#6c757d;margin-top:8px}.analytics-controls{display:flex;gap:12px;align-items:center}.refresh-button,.export-button,.retry-button{padding:10px 18px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px;box-shadow:0 2px 4px #0000001a}.refresh-button{background:#007bff;color:#fff}.refresh-button:hover{background:#0056b3;transform:translateY(-1px);box-shadow:0 4px 8px #007bff4d}.refresh-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.export-button{background:#28a745;color:#fff}.export-button:hover{background:#218838;transform:translateY(-1px);box-shadow:0 4px 8px #28a7454d}.retry-button{background:#dc3545;color:#fff;margin:0 auto}.retry-button:hover{background:#c82333}.time-range-selector{display:flex;gap:8px;background:#fff;padding:4px;border-radius:8px;border:1px solid #dee2e6}.time-range-button{padding:8px 16px;border:none;background:transparent;color:#6c757d;border-radius:6px;cursor:pointer;transition:all .2s ease;font-weight:600;font-size:.9rem}.time-range-button.active{background:#007bff;color:#fff;box-shadow:0 2px 4px #007bff33}.time-range-button:hover:not(.active){background:#f8f9fa;color:#495057}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:25px}.stat-card{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #007bff;transition:all .3s ease;position:relative;overflow:hidden}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.stat-card.primary{border-left-color:#007bff}.stat-card.success{border-left-color:#28a745}.stat-card.info,.stat-card.warning{border-left-color:#17a2b8}.stat-card.danger{border-left-color:#dc3545}.stat-card.purple{border-left-color:#6f42c1}.stat-card.teal{border-left-color:#20c997}.stat-card.indigo{border-left-color:#6610f2}.stat-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.stat-icon-wrapper{width:50px;height:50px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.8rem}.stat-card.primary .stat-icon-wrapper{background:#007bff1a;color:#007bff}.stat-card.success .stat-icon-wrapper{background:#28a7451a;color:#28a745}.stat-card.info .stat-icon-wrapper,.stat-card.warning .stat-icon-wrapper{background:#17a2b81a;color:#17a2b8}.stat-card.danger .stat-icon-wrapper{background:#dc35451a;color:#dc3545}.stat-card.purple .stat-icon-wrapper{background:#6f42c11a;color:#6f42c1}.stat-card.teal .stat-icon-wrapper{background:#20c9971a;color:#20c997}.stat-card.indigo .stat-icon-wrapper{background:#6610f21a;color:#6610f2}.stat-change{font-size:.85rem;padding:4px 10px;border-radius:12px;font-weight:600}.stat-change.positive{background:#28a7451a;color:#28a745}.stat-change.negative{background:#dc35451a;color:#dc3545}.stat-label{font-size:.9rem;color:#6c757d;font-weight:600;letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px}.stat-value{font-size:2.5rem;font-weight:700;color:#333;margin:10px 0;line-height:1}.stat-description{font-size:.85rem;color:#6c757d;margin-top:8px}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:20px;margin-bottom:25px}@media (max-width: 1200px){.charts-grid{grid-template-columns:1fr}}.chart-card{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.chart-card:hover{box-shadow:0 4px 16px #00000026}.chart-header{margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f8f9fa;display:flex;justify-content:space-between;align-items:center}.chart-title{font-size:1.3rem;font-weight:600;color:#333;margin:0}.chart-subtitle{font-size:.9rem;color:#6c757d;margin:4px 0 0}.chart-container{width:100%;height:350px}.empty-chart{height:350px;display:flex;align-items:center;justify-content:center;color:#adb5bd;font-size:1.1rem;background:#f8f9fa;border-radius:8px;border:2px dashed #dee2e6}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:20px}.loading-spinner{width:60px;height:60px;border:4px solid #f8f9fa;border-top-color:#007bff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:1.1rem;color:#6c757d;font-weight:500}.error-icon{font-size:4rem;margin-bottom:15px;color:#dc3545}.error-title{font-size:1.5rem;color:#dc3545;font-weight:600;margin-bottom:15px}.chart-card.full-width{grid-column:1 / -1}.chart-card.full-width .chart-container{height:400px}.section-divider{margin:40px 0 30px;display:flex;align-items:center;gap:15px}.section-divider-line{flex:1;height:2px;background:linear-gradient(to right,transparent,#dee2e6,transparent)}.section-divider-text{font-size:1.5rem;font-weight:700;color:#333;padding:0 15px}.buddies-stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:25px}.buddies-metric{background:#fff;border-radius:12px;padding:20px;text-align:center;box-shadow:0 2px 8px #0000001a;border-top:3px solid #6f42c1;transition:all .3s ease}.buddies-metric:hover{transform:translateY(-3px);box-shadow:0 4px 12px #6f42c133}.buddies-metric-value{font-size:2.5rem;font-weight:700;color:#6f42c1;margin-bottom:8px}.buddies-metric-label{font-size:.9rem;color:#6c757d;text-transform:uppercase;letter-spacing:.5px;font-weight:600}@media (max-width: 768px){.analytics-page{padding:15px}.analytics-header{flex-direction:column;align-items:flex-start;gap:15px}.analytics-title-section h1{font-size:1.8rem}.analytics-controls{flex-direction:column;width:100%}.time-range-selector{width:100%}.time-range-button{flex:1}.stats-grid,.charts-grid{grid-template-columns:1fr}.stat-value{font-size:2rem}.chart-container{height:300px}}@media (max-width: 480px){.analytics-header,.stat-card,.chart-card{padding:20px}}.recharts-text{fill:#6c757d!important;font-size:.85rem}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:#dee2e6!important}.recharts-legend-wrapper{padding-top:15px!important}.recharts-legend-item-text{color:#495057!important;font-weight:500!important}.recharts-tooltip-wrapper{border-radius:8px!important;box-shadow:0 4px 12px #00000026!important}.info-card{background:#e7f3ff;border-left:4px solid #007bff;border-radius:8px;padding:15px 20px;margin-bottom:20px;display:flex;align-items:flex-start;gap:12px}.info-card-icon{font-size:1.5rem;color:#007bff;margin-top:2px}.info-card-content h4{margin:0 0 8px;color:#333;font-size:1.1rem;font-weight:600}.info-card-content p{margin:0;color:#495057;font-size:.9rem;line-height:1.5}.data-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:.85rem;font-weight:600;background:#f8f9fa;color:#495057;margin:4px 4px 0 0}.data-badge.highlight{background:#007bff;color:#fff}.data-badge.success{background:#28a745;color:#fff}.data-badge.warning{background:#17a2b8;color:#fff}.restaurant-rating-updater{max-width:1200px;margin:0 auto;padding:24px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014}.updater-header{text-align:center;margin-bottom:32px;padding-bottom:20px;border-bottom:2px solid #f0f0f0}.updater-title{display:flex;align-items:center;justify-content:center;gap:12px;font-size:28px;font-weight:700;color:#1a1a1a;margin:0 0 8px}.title-icon{font-size:32px;color:#ff6b35}.updater-description{font-size:16px;color:#666;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:linear-gradient(135deg,#ff6b35,#ff8f5a);color:#fff;padding:24px;border-radius:12px;text-align:center;box-shadow:0 4px 16px #ff6b3533}.stat-value{font-size:36px;font-weight:700;margin-bottom:8px}.stat-label{font-size:14px;opacity:.9;font-weight:500}.stat-card.cache-stat{background:linear-gradient(135deg,#28a745,#34ce57)}.stat-card.unmatched-stat{background:linear-gradient(135deg,#dc3545,#e74c3c)}.update-options{background:#f8f9fa;padding:24px;border-radius:12px;margin-bottom:24px}.update-options h3{margin:0 0 20px;font-size:20px;font-weight:600;color:#333}.options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.option-group{display:flex;flex-direction:column}.option-group label{font-weight:500;color:#555;margin-bottom:8px;font-size:14px}.option-group select{padding:10px 12px;border:2px solid #e1e5e9;border-radius:8px;font-size:14px;background:#fff;transition:border-color .2s}.option-group select:focus{outline:none;border-color:#ff6b35}.option-group select:disabled{background:#f5f5f5;cursor:not-allowed}.checkbox-label{display:flex!important;flex-direction:row!important;align-items:center;gap:8px;cursor:pointer;padding:10px 0}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:#ff6b35}.update-controls{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;min-height:44px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#ff6b35,#ff8f5a);color:#fff;box-shadow:0 4px 16px #ff6b354d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ff6b3566}.btn-secondary{background:#dc3545;color:#fff}.btn-secondary:hover:not(:disabled){background:#c82333}.btn-outline{background:#fff;border:2px solid #e1e5e9;color:#333}.btn-outline:hover:not(:disabled){border-color:#ff6b35;color:#ff6b35}.btn-icon{font-size:16px}.spinning{animation:spin 1s linear infinite}.progress-section{background:#f8f9fa;padding:24px;border-radius:12px;margin-bottom:24px;border-left:4px solid #ff6b35}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.progress-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.progress-stats{font-size:16px;font-weight:600;color:#ff6b35}.progress-bar{width:100%;height:8px;background:#e1e5e9;border-radius:4px;overflow:hidden;margin-bottom:16px}.progress-fill{height:100%;background:linear-gradient(90deg,#ff6b35,#ff8f5a);transition:width .3s ease}.progress-details{display:flex;gap:20px;margin-bottom:12px;flex-wrap:wrap}.detail-item{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500}.detail-item.success{color:#28a745}.detail-item.warning{color:#ffc107}.detail-item.error{color:#dc3545}.current-restaurant{font-size:14px;color:#666;font-style:italic;padding:8px 0;border-top:1px solid #e1e5e9}.results-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.results-modal{background:#fff;border-radius:12px;max-width:800px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e1e5e9}.modal-header h3{margin:0;font-size:20px;font-weight:600;color:#333}.close-btn{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:4px;border-radius:4px;transition:color .2s}.close-btn:hover{color:#333}.modal-content{padding:24px;flex:1;overflow-y:auto}.results-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}.summary-item{display:flex;justify-content:space-between;padding:12px 16px;background:#f8f9fa;border-radius:8px;border-left:4px solid #e1e5e9}.summary-item.success{border-left-color:#28a745;background:#f8fff9}.summary-item.warning{border-left-color:#ffc107;background:#fffdf5}.summary-item.error{border-left-color:#dc3545;background:#fff5f5}.summary-item .label{font-weight:500;color:#666}.summary-item .value{font-weight:700;font-size:16px}.results-details h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#333}.details-list{max-height:300px;overflow-y:auto;border:1px solid #e1e5e9;border-radius:8px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #f0f0f0}.detail-row:last-child{border-bottom:none}.detail-row.updated{background:#f8fff9}.detail-row.skipped{background:#fffdf5}.detail-row.failed{background:#fff5f5}.restaurant-name{font-weight:500;color:#333;flex:1}.detail-status{display:flex;align-items:center;gap:6px;font-size:14px;color:#666}.more-results{padding:12px 16px;text-align:center;color:#666;font-style:italic;background:#f8f9fa}.modal-footer{padding:20px 24px;border-top:1px solid #e1e5e9;display:flex;justify-content:flex-end}@media (max-width: 768px){.restaurant-rating-updater{padding:16px}.updater-title{font-size:24px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.options-grid{grid-template-columns:1fr}.update-controls{flex-direction:column}.progress-details{flex-direction:column;gap:8px}.results-modal{margin:10px;max-height:90vh}.results-summary{grid-template-columns:1fr}}.manual-match-info{margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:8px;border-left:4px solid #6f42c1}.manual-match-info h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#333}.restaurant-info p{margin:4px 0;font-size:14px;color:#666}.restaurant-info strong{color:#333;font-weight:500}.search-section{margin-bottom:24px}.search-section h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#333}.search-input-group{display:flex;gap:12px;align-items:stretch}.search-input-group input{flex:1;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:14px;transition:border-color .2s}.search-input-group input:focus{outline:none;border-color:#6f42c1}.search-input-group input:disabled{background:#f8f9fa;color:#999}.search-results{border-top:1px solid #e1e5e9;padding-top:24px}.search-results h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#333}.results-list{max-height:400px;overflow-y:auto;border:1px solid #e1e5e9;border-radius:8px}.place-result{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #f0f0f0;transition:background-color .2s}.place-result:last-child{border-bottom:none}.place-result:hover{background:#f8f9fa}.place-info{flex:1}.place-name{font-weight:600;font-size:16px;color:#333;margin-bottom:4px}.place-address{font-size:14px;color:#666;margin-bottom:8px}.place-stats{display:flex;gap:16px;flex-wrap:wrap;font-size:13px}.place-stats span{display:flex;align-items:center;gap:4px;color:#666}.place-stats .rating{color:#ffc107;font-weight:500}.place-stats .similarity{color:#28a745;font-weight:500}.place-stats .distance{color:#17a2b8}.btn-success{background:#28a745;border-color:#28a745;color:#fff;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;transition:all .2s}.btn-success:hover{background:#218838;border-color:#1e7e34;transform:translateY(-1px)}@media (max-width: 768px){.search-input-group{flex-direction:column}.place-result{flex-direction:column;align-items:stretch;gap:12px}.place-stats{justify-content:space-between}}.restaurant-selector-info{margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:8px;border-left:4px solid #6f42c1}.restaurant-selector-info p{margin:4px 0;color:#333}.restaurant-selector-info strong{color:#6f42c1}.unmatched-restaurants-list{max-height:500px;overflow-y:auto;border:1px solid #e1e5e9;border-radius:8px}.unmatched-restaurant-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #f0f0f0;transition:background-color .2s}.restaurant-actions{display:flex;gap:8px;flex-direction:column;min-width:120px}.unmatched-restaurant-item:last-child{border-bottom:none}.unmatched-restaurant-item:hover{background:#f8f9fa}.restaurant-basic-info{flex:1}.restaurant-basic-info .restaurant-name{font-weight:600;font-size:16px;color:#333;margin-bottom:6px}.restaurant-basic-info .restaurant-address{font-size:14px;color:#fff;margin-bottom:4px}.restaurant-basic-info .restaurant-current-rating{font-size:14px;color:#ffc107;margin-bottom:4px}.restaurant-basic-info .unmatch-reason{font-size:13px;color:#dc3545;font-style:italic}.no-unmatched-restaurants{text-align:center;padding:40px 20px;color:#666}.no-unmatched-restaurants p{margin:8px 0}@media (max-width: 768px){.unmatched-restaurant-item{flex-direction:column;align-items:stretch;gap:12px}.restaurant-basic-info{margin-bottom:12px}}.recommendation-tester{padding:20px;max-width:1400px;margin:0 auto}.recommendation-tester h2{font-size:24px;margin-bottom:20px;color:#2c3e50}.test-controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:25px;padding:20px;background:#f8f9fa;border-radius:8px}.control-group{display:flex;flex-direction:column;gap:8px}.control-group label{font-weight:600;font-size:14px;color:#555}.control-group select{padding:10px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.fun-questions-section{margin-bottom:25px;padding:20px;background:#f8f9fa;border-radius:8px}.fun-questions-section h3{font-size:18px;margin-bottom:20px;color:#2c3e50}.fun-questions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.fun-question-group{padding:15px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d}.fun-question-group label{display:block;font-weight:600;font-size:13px;color:#555;margin-bottom:10px;line-height:1.4}.fun-options{display:flex;gap:10px;flex-wrap:wrap}.fun-option{padding:8px 16px;border:2px solid #ddd;border-radius:6px;background:#fff;cursor:pointer;font-size:14px;transition:all .2s}.fun-option:hover{border-color:#ff6b6b;background:#fff5f5}.fun-option.selected{border-color:#ff6b6b;background:#ff6b6b;color:#fff}.fun-option:disabled{opacity:.5;cursor:not-allowed}.fun-option:disabled:hover{border-color:#ddd;background:#fff}.calculate-btn{width:100%;padding:15px;background:#ff6b6b;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .3s;margin-bottom:30px}.calculate-btn:hover:not(:disabled){background:#ff5252}.calculate-btn:disabled{background:#ccc;cursor:not-allowed}.results-section{margin-top:30px}.results-section h3{font-size:20px;margin-bottom:15px;color:#2c3e50}.results-table{overflow-x:auto;margin-bottom:30px}.results-table table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 2px 4px #0000001a;border-radius:8px;overflow:hidden}.results-table th{background:#2c3e50;color:#fff;padding:12px;text-align:left;font-weight:600;font-size:14px}.results-table td{padding:12px;border-bottom:1px solid #eee;font-size:14px}.results-table tr:hover{background:#f8f9fa}.detailed-breakdown{margin-top:30px}.detailed-breakdown h4{font-size:18px;margin-bottom:20px;color:#2c3e50}.restaurant-detail{background:#fff;padding:20px;margin-bottom:15px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.restaurant-detail h5{font-size:16px;margin-bottom:15px;color:#2c3e50;border-bottom:2px solid #ff6b6b;padding-bottom:8px}.score-components{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-bottom:15px}.component{display:flex;justify-content:space-between;padding:10px;background:#f8f9fa;border-radius:6px}.component .label{font-weight:600;color:#555}.component .value{color:#ff6b6b;font-weight:700}.match-details{margin-top:15px;padding-top:15px;border-top:1px solid #eee}.match-details strong{display:block;margin-bottom:10px;color:#555}.detail-item{display:inline-block;padding:5px 10px;margin:3px;border-radius:4px;font-size:13px}.detail-item.matched{background:#d4edda;color:#155724}.detail-item.not-matched{background:#f8d7da;color:#721c24}.fun-details-breakdown{grid-column:1 / -1;background:#fff5f0;border-left:3px solid #ff6b6b;padding:12px;border-radius:6px;margin-top:8px}.fun-detail-container{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #ffe0d6}.fun-detail-container:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.fun-detail-item{display:flex;justify-content:space-between;padding:6px 10px;margin-bottom:8px;background:#fff;border-radius:4px;font-size:13px}.fun-option-label{font-weight:500;color:#666}.fun-option-value{color:#ff6b6b;font-weight:600;font-family:monospace}.matched-tags-list,.unmatched-tags-list{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:8px 10px;margin-bottom:4px}.matched-tags-list{background:#f0fff4}.unmatched-tags-list{background:#fff5f5}.tags-label{font-size:12px;font-weight:600;margin-right:6px;color:#666}.tag-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500;white-space:nowrap}.tag-badge.matched{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.tag-badge.unmatched{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.restaurant-geocoder{padding:24px;max-width:1200px;margin:0 auto}.restaurant-geocoder h2{font-size:24px;font-weight:600;margin-bottom:24px;color:#1a1a1a}.geocoder-stats{display:flex;gap:20px;margin-bottom:24px;flex-wrap:wrap}.stat-item{background:#f5f5f5;padding:16px 24px;border-radius:8px;flex:1;min-width:200px}.stat-label{display:block;font-size:14px;color:#666;margin-bottom:8px}.stat-value{display:block;font-size:28px;font-weight:600;color:#1a1a1a}.stat-value.warn{color:#f59e0b}.stat-value.success{color:#22c55e}.geocoder-loading{text-align:center;padding:60px 20px;font-size:18px;color:#666}.geocoder-empty{text-align:center;padding:60px 20px;font-size:18px;color:#22c55e;background:#22c55e1a;border-radius:8px}.geocoder-actions{display:flex;gap:12px;margin-bottom:24px}.batch-update-btn,.refresh-btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.batch-update-btn{background:#3b82f6;color:#fff;flex:1}.batch-update-btn:hover:not(:disabled){background:#2563eb}.batch-update-btn:disabled{background:#cbd5e1;cursor:not-allowed}.refresh-btn{background:#f5f5f5;color:#1a1a1a}.refresh-btn:hover:not(:disabled){background:#e5e5e5}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.restaurants-list{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.restaurants-list table{width:100%;border-collapse:collapse}.restaurants-list thead{background:#f5f5f5}.restaurants-list th{padding:16px;text-align:left;font-weight:600;color:#1a1a1a;font-size:14px;border-bottom:2px solid #e5e5e5}.restaurants-list tbody tr{border-bottom:1px solid #e5e5e5}.restaurants-list tbody tr:hover{background:#fafafa}.restaurants-list td{padding:16px;color:#1a1a1a}.restaurants-list td.coords{font-family:monospace;font-size:13px;color:#666}.update-single-btn{padding:8px 16px;background:#22c55e;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.update-single-btn:hover:not(:disabled){background:#16a34a}.update-single-btn:disabled{background:#cbd5e1;cursor:not-allowed}.processing-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}.processing-message{background:#fff;padding:24px 48px;border-radius:12px;font-size:18px;font-weight:500;box-shadow:0 4px 6px #0000001a}@media (max-width: 768px){.restaurant-geocoder{padding:16px}.geocoder-stats{flex-direction:column}.stat-item{min-width:100%}.geocoder-actions{flex-direction:column}.restaurants-list{overflow-x:auto}.restaurants-list table{min-width:600px}}.custom-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.custom-modal{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-width:90vw;max-height:90vh;overflow:hidden;animation:slideIn .3s ease-out;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.custom-modal.small{width:400px}.custom-modal.medium{width:600px}.custom-modal.large{width:800px}.custom-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid #e9ecef}.custom-modal-title{margin:0;font-size:1.25rem;font-weight:600;color:#333}.custom-modal-close{background:none;border:none;font-size:24px;font-weight:300;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.custom-modal-close:hover{background:#f8f9fa;color:#666}.custom-modal-content{padding:20px 24px 24px}.input-group{margin-bottom:20px}.input-label{display:block;margin-bottom:8px;font-weight:500;color:#333;font-size:14px}.custom-input{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:6px;font-size:14px;transition:all .2s;background:#fff;box-sizing:border-box}.custom-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.custom-input.error{border-color:#dc3545}.custom-input.error:focus{border-color:#dc3545;box-shadow:0 0 0 3px #dc35451a}.input-error{color:#dc3545;font-size:12px;margin-top:4px;display:flex;align-items:center;gap:4px}.input-counter{text-align:right;font-size:12px;color:#6c757d;margin-top:4px}.confirm-content{text-align:center;padding:10px 0}.confirm-icon{font-size:48px;margin-bottom:16px}.confirm-message{font-size:16px;color:#333;margin:0 0 20px;line-height:1.5}.notification-content{text-align:center;padding:10px 0}.notification-icon{font-size:48px;margin-bottom:16px}.notification-message{font-size:16px;color:#333;margin:0 0 20px;line-height:1.5}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;position:relative;min-width:80px;text-align:center}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background:#0056b3}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#545b62}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333}.btn.loading:after{content:"";position:absolute;width:16px;height:16px;margin:auto;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin 1s linear infinite;top:50%;left:50%;transform:translate(-50%,-50%)}.btn.loading{color:transparent}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}@media (max-width: 768px){.custom-modal{margin:16px;width:calc(100vw - 32px);max-width:none}.custom-modal-header,.custom-modal-content{padding-left:16px;padding-right:16px}.modal-actions{flex-direction:column-reverse}.btn{width:100%}}.admin-form{max-width:100%}.admin-form .form-group{margin-bottom:20px}.admin-form label{display:block;margin-bottom:6px;font-weight:600;color:#333;font-size:14px}.admin-form input,.admin-form select{width:100%;padding:10px 12px;border:2px solid #e1e5e9;border-radius:6px;font-size:14px;transition:all .2s ease;background:#fff;font-family:inherit;box-sizing:border-box}.admin-form input:focus,.admin-form select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.admin-form input.error,.admin-form select.error{border-color:#dc3545;box-shadow:0 0 0 3px #dc35451a}.admin-form input:disabled,.admin-form select:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed;opacity:.7}.admin-form .error-message{display:block;color:#dc3545;font-size:12px;margin-top:4px;font-weight:500}.admin-form select{cursor:pointer;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:36px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.admin-form select:disabled{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%236c757d' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3E%3C/svg%3E")}@media (max-width: 576px){.admin-form label{font-size:13px}.admin-form input,.admin-form select{font-size:16px;padding:12px}}.admin-dashboard{width:100%;min-height:100vh;background:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-y:auto}.dashboard-header{background:#fff;padding:15px 25px;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center}.dashboard-header h1{margin:0;font-size:1.3rem;font-weight:600;color:#333;display:flex;align-items:center;gap:10px}.system-icon{font-size:1.2rem}.logout-btn{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500}.logout-btn:hover{background:#c82333}.admin-dashboard .user-info{background:#fff;padding:10px 25px;border-bottom:1px solid #dee2e6;font-size:.9rem;color:#666}.admin-status{color:#28a745;font-weight:500}.dashboard-tabs{display:flex;background:#fff;border-bottom:1px solid #dee2e6}.tab-button{flex:1;background:#e9ecef;border:none;padding:15px 20px;cursor:pointer;font-size:.95rem;color:#495057;border-radius:0;transition:all .2s ease}.tab-button.active{background:#28a745;color:#fff;font-weight:500}.tab-button:hover:not(.active){background:#dee2e6}.dashboard-content{padding:0;overflow-y:auto;max-height:calc(100vh - 200px)}.buddies-section{padding:20px 25px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-title{display:flex;align-items:center;gap:8px}.section-icon{font-size:1.1rem}.section-header h2{margin:0;font-size:1.2rem;font-weight:600;color:#333}.refresh-btn{background:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:.9rem}.refresh-btn:hover{background:#0056b3}.data-table{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.data-table table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:12px;text-align:left;border-bottom:1px solid #dee2e6;font-size:.9rem}.data-table th{background:#f8f9fa;font-weight:600;color:#495057}.status-waiting{color:#ffc107;font-weight:500}.status-voting{color:#6c757d;font-weight:500}.delete-btn{background:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.8rem}.admins-section{padding:20px 25px}.admin-status-info{color:#666;font-size:14px;display:flex;align-items:center}.separator{margin:0 8px;color:#ccc}.admin-info{display:flex;align-items:center;gap:8px}.status-indicator{width:8px;height:8px;border-radius:50%;display:inline-block}.status-indicator.online{background-color:#28a745;box-shadow:0 0 6px #28a74599}.status-indicator.offline{background-color:#9e9e9e}.current-user{color:#007bff;font-weight:700;font-size:12px}.role-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700;text-transform:uppercase}.role-badge.super-admin{background-color:#dc3545;color:#fff}.role-badge.admin{background-color:#6c757d;color:#fff}.status-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700}.status-badge.online{background-color:#d4edda;color:#28a745}.status-badge.offline{background-color:#f8f9fa;color:#6c757d}.action-buttons{display:flex;gap:6px;flex-wrap:wrap}.edit-btn,.reset-password-btn{background:#007bff;color:#fff;border:none;border-radius:4px;padding:4px 8px;font-size:12px;cursor:pointer;transition:background .3s}.edit-btn:hover:not(:disabled),.reset-password-btn:hover{background:#0056b3}.edit-btn:disabled{background:#6c757d;cursor:not-allowed}.reset-password-btn{background:#fd7e14}.admin-actions{margin-top:20px;padding-top:20px;border-top:1px solid #dee2e6;display:flex;gap:12px}.add-admin-btn{background:#28a745;color:#fff;border:none;border-radius:4px;padding:10px 16px;cursor:pointer;font-weight:500;transition:background .3s}.add-admin-btn:hover{background:#218838}.export-logs-btn{background:#6c757d;color:#fff;border:none;border-radius:4px;padding:10px 16px;cursor:pointer;font-weight:500;transition:background .3s}.export-logs-btn:hover{background:#5a6268}.sync-data-btn{background:#17a2b8;color:#fff;border:none;border-radius:4px;padding:10px 16px;cursor:pointer;font-weight:500;transition:background .3s}.sync-data-btn:hover:not(:disabled){background:#138496}.sync-data-btn:disabled{opacity:.6;cursor:not-allowed}.no-permission{color:#6c757d;font-size:12px;font-style:italic}.admin-action-btn{font-size:12px;padding:6px 12px;border-radius:4px;font-weight:500;border:none;cursor:pointer;transition:all .3s;min-width:80px;text-align:center}.update-name-btn{background:#28a745;color:#fff}.update-name-btn:hover{background:#218838}.reset-password-btn{background:#fd7e14;color:#fff}.reset-password-btn:hover{background:#e6701e}.delete-btn{background:#dc3545;color:#fff}.delete-btn:hover{background:#c82333}.edit-btn,.reset-password-btn,.delete-btn{font-size:12px;padding:6px 12px;border-radius:4px;font-weight:500}.add-admin-btn,.export-logs-btn{font-size:14px;padding:8px 16px;border-radius:6px}.admin-controls{display:flex;align-items:center;justify-content:space-between;width:100%;gap:16px}.admin-controls .refresh-btn{background:#17a2b8;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:background .3s;white-space:nowrap}.admin-controls .refresh-btn:hover:not(:disabled){background:#138496}.admin-controls .refresh-btn:disabled{opacity:.6;cursor:not-allowed}.admin-status-info{font-size:14px;color:#6c757d}.admin-login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f6f9fc,#e9f1f7);padding:20px}.admin-login-container{background-color:#fff;border-radius:16px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;padding:48px;max-width:420px;width:100%;margin:0 auto}.admin-login-header{text-align:center;margin-bottom:36px}.admin-logo{margin:0 auto 28px;width:50px;height:50px;animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.admin-login-header h2{font-size:28px;font-weight:700;color:#1f2937;margin-bottom:10px;animation:fadeIn .5s ease-in .1s backwards}.welcome-text{color:#6b7280;font-size:15px;animation:fadeIn .5s ease-in .2s backwards}.admin-login-form{margin-bottom:32px}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:10px;font-size:15px;font-weight:500;color:#374151}.input-wrapper{position:relative}.form-group input{width:100%;padding:12px 46px 12px 14px;border-radius:10px;border:1.5px solid #e5e7eb;background-color:#f9fafb;font-size:15px;color:#1f2937;transition:all .15s ease-in-out;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;background-color:#fff}.form-group input.error{border-color:#ef4444;background-color:#fef2f2}.password-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:opacity .2s ease;outline:none}.password-toggle:hover{opacity:.7}.password-toggle:focus{outline:2px solid #4f46e5;outline-offset:2px;border-radius:4px}.error-message{background-color:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:14px;margin-bottom:24px;display:flex;align-items:center;animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-message svg{flex-shrink:0;margin-right:10px}.error-message p{color:#ef4444;font-size:14px;margin:0}.login-button{width:100%;height:48px;background-color:#4f46e5;color:#fff;border-radius:10px;border:none;font-weight:600;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease-in-out;box-shadow:0 2px 4px #4f46e533}.login-button:hover:not(:disabled){background-color:#4338ca;transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{background-color:#9ca3af;cursor:not-allowed;box-shadow:none}.login-button.loading{background-color:#9ca3af}.loading-spinner{width:22px;height:22px;border:2px solid white;border-top:2px solid transparent;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-footer{border-top:1px solid #e5e7eb;padding-top:28px}.forgot-password-section{text-align:center}.help-text{color:#6b7280;font-size:14px;margin-bottom:10px}.forgot-link{color:#4f46e5;font-size:15px;font-weight:500;cursor:pointer;background:none;border:none;padding:0;transition:color .15s ease-in-out}.forgot-link:hover{color:#4338ca;text-decoration:underline}.forgot-link:focus{outline:2px solid #4f46e5;outline-offset:2px;border-radius:4px}.reset-form{margin-top:16px}.reset-actions{display:flex;gap:12px;justify-content:center}.reset-button{background-color:#10b981;color:#fff;border:none;padding:8px 20px;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color .15s ease-in-out}.reset-button:hover{background-color:#059669}.cancel-reset{background-color:#f3f4f6;color:#374151;border:none;padding:8px 20px;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color .15s ease-in-out}.cancel-reset:hover{background-color:#e5e7eb}.reset-status{margin-top:16px;padding:12px;border-radius:8px;font-size:14px;font-weight:500}.reset-status.success{background-color:#f0fdf4;color:#059669;border:1px solid #bbf7d0}.reset-status.error{background-color:#fef2f2;color:#dc2626;border:1px solid #fecaca}html,body{margin:0;padding:0;font-family:Arial,sans-serif;background-color:#fff8f0;height:100vh;width:100vw;overflow-x:auto}body{height:100vh;width:100vw}#root{min-height:100vh;width:100vw;overflow-x:auto}#root .app{min-height:100vh;width:100vw;display:flex;flex-direction:column;justify-content:space-between;overflow-x:auto;overflow-y:auto;position:relative}#root .page-container{flex:1;overflow-x:auto;overflow-y:auto;padding:1rem;padding-bottom:80px;box-sizing:border-box;position:relative}
