@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--dora-blue: #0097E6;--dora-blue-dark: #0077B6;--dora-blue-light: #52B8F2;--dora-red: #E74C3C;--dora-red-dark: #C0392B;--dora-yellow: #F4D03F;--dora-yellow-light: #FFEAA7;--dora-white: #FFFFFF;--dora-bg: #E8F6FF;--dora-bg-gradient: linear-gradient(180deg, #E8F6FF 0%, #D4EDFF 50%, #C0E4FF 100%);--dora-card: #FFFFFF;--dora-text: #2C3E50;--dora-text-light: #636E72;--dora-text-muted: #B2BEC3;--dora-border: rgba(0, 151, 230, .18);--dora-shadow: 0 4px 20px rgba(0, 151, 230, .12);--dora-shadow-lg: 0 8px 40px rgba(0, 151, 230, .18);--dora-radius: 16px;--dora-radius-sm: 10px;--dora-radius-pill: 999px;--dora-transition: .25s cubic-bezier(.4, 0, .2, 1);--nav-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:Outfit,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--dora-bg-gradient);color:var(--dora-text);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased}#root{min-height:100vh;display:flex;flex-direction:column}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,select,textarea{font-family:inherit;font-size:.95rem}.nav-bar{height:var(--nav-height);background:linear-gradient(135deg,var(--dora-blue) 0%,var(--dora-blue-dark) 100%);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:100;box-shadow:0 4px 20px #0077b64d}.nav-logo{display:flex;align-items:center;gap:10px;color:var(--dora-white);font-weight:800;font-size:1.4rem;letter-spacing:-.02em}.nav-logo .bell-icon{width:36px;height:36px;border-radius:50%;object-fit:contain;box-shadow:0 2px 8px #f4d03f66;animation:bellSwing 3s ease-in-out infinite}@keyframes bellSwing{0%,to{transform:rotate(0)}25%{transform:rotate(8deg)}75%{transform:rotate(-8deg)}}.nav-tabs{display:flex;gap:4px}.nav-tab{padding:10px 20px;color:#ffffffbf;font-weight:600;font-size:.95rem;border-radius:var(--dora-radius-pill);transition:var(--dora-transition);background:transparent}.nav-tab:hover{color:var(--dora-white);background:#ffffff1f}.nav-tab.active{color:var(--dora-blue);background:var(--dora-white);box-shadow:0 2px 8px #0000001a}.dora-card{background:var(--dora-card);border:2px solid var(--dora-border);border-radius:var(--dora-radius);box-shadow:var(--dora-shadow);padding:20px;transition:var(--dora-transition)}.dora-card:hover{box-shadow:var(--dora-shadow-lg);transform:translateY(-2px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:.9rem;padding:10px 20px;border-radius:var(--dora-radius-pill);transition:var(--dora-transition);white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--dora-blue) 0%,var(--dora-blue-dark) 100%);color:var(--dora-white);box-shadow:0 4px 15px #0097e659}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0097e673}.btn-primary:active{transform:translateY(0)}.btn-danger{background:linear-gradient(135deg,var(--dora-red) 0%,var(--dora-red-dark) 100%);color:var(--dora-white);box-shadow:0 4px 15px #e74c3c4d}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 6px 20px #e74c3c66}.btn-secondary{background:var(--dora-bg);color:var(--dora-blue);border:2px solid var(--dora-border)}.btn-secondary:hover{background:var(--dora-white);border-color:var(--dora-blue)}.btn-yellow{background:linear-gradient(135deg,var(--dora-yellow) 0%,#F0C419 100%);color:var(--dora-text);box-shadow:0 4px 15px #f4d03f59;font-weight:700}.btn-yellow:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f4d03f80}.btn-sm{padding:6px 14px;font-size:.82rem}.btn-lg{padding:14px 32px;font-size:1.1rem}.btn-icon{width:38px;height:38px;padding:0;border-radius:50%;font-size:1.1rem}.chip{display:inline-flex;align-items:center;padding:5px 14px;border-radius:var(--dora-radius-pill);font-size:.82rem;font-weight:500;background:var(--dora-bg);color:var(--dora-blue);border:1.5px solid transparent;cursor:pointer;transition:var(--dora-transition);-webkit-user-select:none;user-select:none}.chip:hover{border-color:var(--dora-blue-light);background:#0097e61a}.chip.active{background:var(--dora-blue);color:var(--dora-white);border-color:var(--dora-blue);box-shadow:0 2px 8px #0097e64d}.chip-group{display:flex;flex-wrap:wrap;gap:6px}.form-group{margin-bottom:16px}.form-label{display:block;font-weight:600;font-size:.85rem;color:var(--dora-text);margin-bottom:6px;letter-spacing:.02em}.form-input{width:100%;padding:10px 14px;border:2px solid var(--dora-border);border-radius:var(--dora-radius-sm);background:var(--dora-white);color:var(--dora-text);transition:var(--dora-transition)}.form-input:focus{border-color:var(--dora-blue);box-shadow:0 0 0 3px #0097e61f;outline:none}.form-input::placeholder{color:var(--dora-text-muted)}.toggle-container{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.toggle-label{font-size:.88rem;font-weight:500;color:var(--dora-text)}.toggle{position:relative;width:44px;height:24px;background:var(--dora-text-muted);border-radius:12px;cursor:pointer;transition:var(--dora-transition)}.toggle.active{background:var(--dora-blue)}.toggle:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:var(--dora-white);border-radius:50%;transition:var(--dora-transition);box-shadow:0 1px 3px #00000026}.toggle.active:after{left:23px}.stepper{display:flex;align-items:center;gap:12px}.stepper-btn{width:34px;height:34px;border-radius:50%;background:var(--dora-blue);color:var(--dora-white);font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:var(--dora-transition);box-shadow:0 2px 8px #0097e640}.stepper-btn:hover{background:var(--dora-blue-dark);transform:scale(1.1)}.stepper-btn:disabled{background:var(--dora-text-muted);cursor:not-allowed;transform:none}.stepper-value{font-size:1.3rem;font-weight:700;color:var(--dora-blue);min-width:30px;text-align:center}.wheel-page{flex:1;display:flex;gap:24px;padding:24px;max-width:1400px;margin:0 auto;width:100%}.filter-panel{width:300px;flex-shrink:0;overflow-y:auto;max-height:calc(100vh - var(--nav-height) - 48px);position:sticky;top:calc(var(--nav-height) + 24px)}.filter-panel .dora-card{padding:20px}.filter-section{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--dora-border)}.filter-section:last-child{border-bottom:none;margin-bottom:0}.filter-section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--dora-text-light);margin-bottom:10px}.candidate-count{text-align:center;padding:12px;background:linear-gradient(135deg,#0097e614,#f4d03f14);border-radius:var(--dora-radius-sm);font-weight:600;color:var(--dora-blue);margin-top:12px}.candidate-count span{font-size:1.4rem;font-weight:800;color:var(--dora-red)}.wheel-center{flex:1;display:flex;flex-direction:column;align-items:center;gap:20px;min-width:0}.wheel-container{position:relative;display:flex;align-items:center;justify-content:center}.wheel-pointer{position:absolute;top:-18px;left:50%;transform:translate(-50%);width:0;height:0;border-left:16px solid transparent;border-right:16px solid transparent;border-top:30px solid var(--dora-red);filter:drop-shadow(0 3px 6px rgba(231,76,60,.4));z-index:10}.spin-button{padding:16px 48px;font-size:1.3rem;font-weight:800;letter-spacing:.04em;background:linear-gradient(135deg,var(--dora-red) 0%,var(--dora-red-dark) 100%);color:var(--dora-white);border-radius:var(--dora-radius-pill);box-shadow:0 6px 25px #e74c3c66;transition:var(--dora-transition);position:relative;overflow:hidden}.spin-button:before{content:"";position:absolute;top:50%;left:50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 60%);transform:translate(-50%,-50%)}.spin-button:hover:not(:disabled){transform:translateY(-3px) scale(1.03);box-shadow:0 10px 35px #e74c3c80}.spin-button:active:not(:disabled){transform:translateY(0) scale(.98)}.spin-button:disabled{background:var(--dora-text-muted);box-shadow:none;cursor:not-allowed}.result-panel{width:340px;flex-shrink:0}.result-card{animation:slideInRight .4s ease-out}.result-card .restaurant-name{font-size:1.3rem;font-weight:700;color:var(--dora-text);margin-bottom:8px}.result-card .cuisine-chips{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}.result-card .cuisine-chip{font-size:.75rem;padding:3px 10px;background:var(--dora-bg);border-radius:var(--dora-radius-pill);color:var(--dora-blue);font-weight:500}.result-card .detail-row{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:.9rem;color:var(--dora-text-light)}.result-card .detail-row .icon{font-size:1.1rem}.result-card .notes{font-style:italic;color:var(--dora-text-muted);font-size:.85rem;padding:8px 0}.result-card .action-row{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}.result-empty{text-align:center;padding:40px 20px;color:var(--dora-text-muted)}.result-empty .empty-icon{font-size:3rem;margin-bottom:12px}.result-empty p{font-size:.95rem}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.history-bar{width:100%;max-width:1400px;margin:0 auto;padding:0 24px 24px}.history-title{font-size:.85rem;font-weight:700;text-transform:uppercase;color:var(--dora-text-light);letter-spacing:.06em;margin-bottom:10px}.history-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px}.history-scroll::-webkit-scrollbar{height:4px}.history-scroll::-webkit-scrollbar-thumb{background:var(--dora-blue-light);border-radius:2px}.history-item{flex-shrink:0;padding:10px 16px;background:var(--dora-white);border:1.5px solid var(--dora-border);border-radius:var(--dora-radius-sm);font-size:.85rem;font-weight:500;cursor:pointer;transition:var(--dora-transition);min-width:140px}.history-item:hover{border-color:var(--dora-blue);box-shadow:0 2px 8px #0097e626}.history-item .pick-time{font-size:.72rem;color:var(--dora-text-muted);margin-top:4px}.restaurant-page{flex:1;padding:24px;max-width:1200px;margin:0 auto;width:100%}.page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:24px}.page-title{font-size:1.5rem;font-weight:800;color:var(--dora-text)}.toolbar{display:flex;gap:8px;flex-wrap:wrap}.search-box{position:relative}.search-box input{padding:10px 14px 10px 38px;width:260px;border:2px solid var(--dora-border);border-radius:var(--dora-radius-pill);background:var(--dora-white);font-size:.9rem;transition:var(--dora-transition)}.search-box input:focus{border-color:var(--dora-blue);box-shadow:0 0 0 3px #0097e61a;outline:none}.search-box .search-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--dora-text-muted);font-size:.95rem}.restaurant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.restaurant-card{cursor:pointer;position:relative;overflow:hidden}.restaurant-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--dora-blue),var(--dora-yellow),var(--dora-red));opacity:0;transition:var(--dora-transition)}.restaurant-card:hover:before{opacity:1}.restaurant-card .card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}.restaurant-card .card-name{font-size:1.05rem;font-weight:700;color:var(--dora-text)}.restaurant-card .card-price{font-weight:700;color:var(--dora-yellow);font-size:1rem;text-shadow:0 0 8px rgba(244,208,63,.3)}.restaurant-card .card-cuisines{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.restaurant-card .card-meta{display:flex;gap:16px;font-size:.82rem;color:var(--dora-text-light)}.restaurant-card .card-actions{display:flex;gap:8px;margin-top:12px;justify-content:flex-end}.restaurant-card .fav-badge{color:var(--dora-red)}.drawer-overlay{position:fixed;inset:0;background:#0006;z-index:200;animation:fadeIn .2s ease}.drawer{position:fixed;top:0;right:0;width:440px;max-width:100vw;height:100vh;background:var(--dora-white);z-index:201;box-shadow:-8px 0 40px #00000026;animation:slideDrawerIn .3s ease-out;display:flex;flex-direction:column}.drawer-header{padding:20px 24px;border-bottom:2px solid var(--dora-border);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#0097e60d,#f4d03f0d)}.drawer-title{font-size:1.15rem;font-weight:700}.drawer-close{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--dora-text-light);background:transparent;transition:var(--dora-transition)}.drawer-close:hover{background:var(--dora-bg);color:var(--dora-red)}.drawer-body{flex:1;overflow-y:auto;padding:24px}.drawer-footer{padding:16px 24px;border-top:2px solid var(--dora-border);display:flex;gap:12px;justify-content:flex-end}@keyframes slideDrawerIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.empty-state{text-align:center;padding:60px 20px}.empty-state .empty-illustration{font-size:4rem;margin-bottom:16px}.empty-state h3{font-size:1.15rem;font-weight:700;color:var(--dora-text);margin-bottom:8px}.empty-state p{color:var(--dora-text-muted);font-size:.9rem;margin-bottom:20px}.star-rating{display:flex;gap:2px}.star{font-size:1.1rem;cursor:pointer;color:var(--dora-text-muted);transition:var(--dora-transition)}.star.filled{color:var(--dora-yellow);text-shadow:0 0 6px rgba(244,208,63,.4)}input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;background:var(--dora-border);border-radius:3px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--dora-blue);border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0097e64d}.clouds-bg{position:fixed;inset:0;pointer-events:none;z-index:-1;overflow:hidden}.cloud{position:absolute;background:#fff9;border-radius:50px;animation:floatCloud linear infinite}.cloud:nth-child(1){width:200px;height:60px;top:15%;animation-duration:35s}.cloud:nth-child(2){width:150px;height:45px;top:30%;animation-duration:28s;animation-delay:-10s}.cloud:nth-child(3){width:180px;height:50px;top:60%;animation-duration:40s;animation-delay:-20s}.cloud:nth-child(4){width:120px;height:35px;top:80%;animation-duration:32s;animation-delay:-5s}@keyframes floatCloud{0%{left:-250px}to{left:110%}}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:300;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.modal{background:var(--dora-white);border-radius:var(--dora-radius);width:520px;max-width:95vw;max-height:85vh;overflow-y:auto;box-shadow:var(--dora-shadow-lg);animation:scaleIn .25s ease}.modal-header{padding:20px 24px;border-bottom:2px solid var(--dora-border);display:flex;align-items:center;justify-content:space-between}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:2px solid var(--dora-border);display:flex;gap:12px;justify-content:flex-end}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media(max-width:1024px){.wheel-page{flex-direction:column;align-items:center}.filter-panel{width:100%;max-height:none;position:static}.result-panel{width:100%;max-width:400px}}@media(max-width:768px){.nav-bar{padding:0 16px}.nav-logo{font-size:1.1rem}.nav-tab{padding:8px 14px;font-size:.85rem}.wheel-page{padding:16px;gap:16px}.restaurant-page{padding:16px}.page-header{flex-direction:column;align-items:stretch}.toolbar{justify-content:center}.search-box input{width:100%}.restaurant-grid{grid-template-columns:1fr}.drawer{width:100vw}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--dora-blue-light);border-radius:3px}.text-center{text-align:center}.text-muted{color:var(--dora-text-muted)}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.gap-8{gap:8px}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}
