:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#222;background-color:#fffbe6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;place-items:center;min-width:320px;min-height:100vh;background:#fffbe6;color:#222}h1{font-size:3.2em;line-height:1.1;color:#ffb300;text-shadow:0 2px 8px #fffbe6cc}button{border-radius:8px;border:1px solid #ffe066;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#ffe066;color:#222;cursor:pointer;transition:border-color .25s,background .25s,color .25s;box-shadow:0 2px 8px #0001}button:hover{border-color:#ffb300;background:#ffec99}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.kakao-info-window,.kakao-info-window *{background:#fffbe6!important;color:#222!important}@media (prefers-color-scheme: dark){:root{color:#fffbe6;background-color:#222}body{background:#222;color:#fffbe6}h1{color:#ffe066;text-shadow:0 2px 8px #222c}button{background-color:#ffb300;color:#222;border:1.5px solid #ffe066;box-shadow:0 2px 8px #0006}button:hover{background:#ffe066;color:#222;border-color:#ffb300}.kakao-info-window,.kakao-info-window *{background:#222!important;color:#ffe066!important}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#333;background:#f8f9fa}.app{min-height:100vh;display:flex;flex-direction:column;max-width:1400px;margin:0 auto;padding:0 20px}.app-header{background:#fff;border-bottom:1px solid #e9ecef;padding:1.5rem 2rem;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:100;border-radius:0 0 16px 16px;margin-bottom:20px;max-width:1400px;margin-left:auto;margin-right:auto}.app-title{font-size:2rem;font-weight:700;color:#ff6b35;margin-bottom:1.5rem;text-align:center;text-shadow:0 2px 4px rgba(255,107,53,.2)}.search-form{display:flex;gap:.5rem;align-items:center;max-width:1600px;margin:0 auto;padding:.25rem;background:linear-gradient(135deg,#fffbe6,#ffe066);border-radius:16px;box-shadow:0 4px 15px #ffe0664d}.search-input{flex:1;padding:.75rem 1.5rem;border:2px solid #ffb300;border-radius:12px;font-size:1.1rem;outline:none;transition:all .3s ease;background:#ffffffe6;color:#333;font-weight:500}.search-input:focus{border-color:#ff6b35;background:#fff;box-shadow:0 0 0 3px #ff6b3533;transform:translateY(-1px)}.search-input::placeholder{color:#999;font-weight:400}.search-button{padding:.75rem 2rem;background:linear-gradient(135deg,#ff6b35,#ff8a50);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #ff6b354d;min-width:120px}.search-button:hover:not(:disabled){background:linear-gradient(135deg,#e55a2b,#ff6b35);transform:translateY(-2px);box-shadow:0 6px 16px #ff6b3566}.search-button:disabled{background:linear-gradient(135deg,#ccc,#ddd);cursor:not-allowed;transform:none;box-shadow:none}.clear-button{padding:.5rem .75rem;background:#6c757d;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;min-width:40px}.error-message{color:#dc3545;font-size:.9rem;margin-top:.5rem;text-align:center}.main-content{flex:1;padding:0 2rem 1.5rem}.content-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;max-width:1400px;margin:0 auto;height:calc(100vh - 200px)}.map-section{background:#fff;border-radius:16px;box-shadow:0 8px 25px #00000026;overflow:hidden;position:relative;border:2px solid #ff6b35;transition:all .3s ease}.map-section:hover{box-shadow:0 12px 35px #0003;transform:translateY(-2px)}.map-container{width:100%;height:100%;position:relative}.map-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#6c757d;font-size:1.1rem}.restaurant-section{background:#fff;border-radius:16px;box-shadow:0 8px 25px #00000026;overflow:hidden;display:flex;flex-direction:column;border:2px solid #ffe066;transition:all .3s ease;height:100%;min-height:500px}.category-filter{padding:1rem 1.5rem;border-bottom:1px solid #e9ecef;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.category-title-section{display:flex;align-items:center;gap:.5rem}.toggle-btn{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center}.toggle-btn:hover{background-color:#0000000d}.toggle-icon{font-size:.8rem;color:#666;transition:transform .3s ease;display:inline-block}.toggle-icon.collapsed{transform:rotate(-90deg)}.category-header h3{margin:0;color:#333;font-size:1.1rem;font-weight:600}.all-category-btn{background:linear-gradient(135deg,#ff6b35,#ff8a50);color:#fff;border:none;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #ff6b354d}.all-category-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff6b3566}.all-category-btn.active{background:linear-gradient(135deg,#e55a2b,#ff6b35);box-shadow:0 4px 12px #ff6b3580}.category-tags{display:flex;flex-wrap:wrap;gap:.5rem;transition:all .3s ease;overflow:hidden}.category-tags.collapsed{max-height:0;opacity:0;margin-bottom:0}.category-tags.expanded{max-height:200px;opacity:1}.category-tag{display:flex;align-items:center;gap:.25rem;padding:.4rem .8rem;border:2px solid var(--tag-color, #6c757d);border-radius:20px;background:#fff;color:var(--tag-color, #6c757d);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000001a}.category-tag:hover{background:var(--tag-color, #6c757d);color:#fff;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.category-tag.active{background:var(--tag-color, #6c757d);color:#fff;box-shadow:0 4px 12px #0003;transform:translateY(-1px)}.tag-name{font-weight:600}.tag-count{opacity:.8;font-size:.8rem}.restaurant-section:hover{box-shadow:0 12px 35px #0003;transform:translateY(-2px)}.restaurant-list{height:100%;display:flex;flex-direction:column}.restaurant-header{padding:1.5rem 2rem;border-bottom:1px solid #e9ecef;background:#f8f9fa;display:flex;justify-content:space-between;align-items:center;gap:2rem}.restaurant-header h2{margin:0;color:#333;font-size:1.25rem;flex:1}.today-pick-button{background:linear-gradient(135deg,#ff6b35,#ff8a50);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #ff6b354d;font-size:.95rem;white-space:nowrap;flex-shrink:0}.today-pick-button:hover:not(:disabled){background:linear-gradient(135deg,#e55a2b,#ff6b35);transform:translateY(-2px);box-shadow:0 6px 16px #ff6b3566}.today-pick-button:disabled{background:linear-gradient(135deg,#6c757d,#8a9ba8);cursor:not-allowed;transform:none;box-shadow:none}.restaurant-content{flex:1;overflow-y:auto;min-height:400px;height:100%}.empty-state{padding:2rem;text-align:center;color:#6c757d}.restaurant-items{list-style:none}.restaurant-item{padding:1rem 1.5rem;border-bottom:1px solid #f1f3f4;cursor:pointer;transition:all .3s ease;min-height:100px;display:flex;flex-direction:column;justify-content:center;position:relative;background:#fff;border-radius:8px;margin:4px 0;box-shadow:0 2px 8px #0000001a}.restaurant-item:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.restaurant-item:last-child{border-bottom:none}.restaurant-content-wrapper{display:flex;align-items:center;gap:1rem;width:100%}.restaurant-number{flex-shrink:0;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#ff6b35,#ff8a50);box-shadow:0 4px 12px #ff6b354d;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.restaurant-number .number-text{color:#fff;font-size:1.5rem;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.2)}.restaurant-item:hover .restaurant-number{transform:scale(1.1);box-shadow:0 6px 16px #ff6b3566}.restaurant-info{flex:1;min-width:0}.restaurant-info h3{margin:0 0 .25rem;color:#333;font-size:1.1rem;font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.restaurant-address{margin:0 0 .5rem;color:#6c757d;font-size:.9rem;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.restaurant-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.restaurant-distance{color:#ff6b35;font-size:.8rem;font-weight:600;background:#ff6b351a;padding:2px 8px;border-radius:12px;white-space:nowrap}.restaurant-category{color:#6c757d;font-size:.8rem;background:#f8f9fa;padding:2px 8px;border-radius:12px;white-space:nowrap;border:1px solid #e9ecef}.restaurant-phone{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.25rem 0}.phone-icon{font-size:1rem;opacity:.8}.phone-link{color:#007bff;text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s ease}.phone-link:hover{color:#0056b3;text-decoration:underline}.restaurant-link{color:#007bff;text-decoration:none;font-size:.9rem;margin-top:.5rem;display:inline-block}.restaurant-link:hover{text-decoration:underline}.restaurant-item.highlighted{background:linear-gradient(135deg,#ff6b35,#ff8a50);color:#fff;box-shadow:0 8px 25px #ff6b3566,0 0 0 2px #ff6b35;border-radius:12px;margin:4px 0;transition:all .2s ease;min-height:100px;position:relative;z-index:1}.restaurant-item.highlighted h3{color:#fff;font-weight:700}.restaurant-item.highlighted .restaurant-address{color:#ffffffe6}.restaurant-item.highlighted .restaurant-distance{color:#fffbe6;font-weight:700;background:#fff3}.restaurant-item.highlighted .restaurant-category{color:#ffffffe6;background:#fff3;border:1px solid rgba(255,255,255,.3)}.restaurant-item.highlighted .restaurant-number{background:linear-gradient(135deg,#fffbe6,#ffe066);box-shadow:0 4px 12px #ffffff4d}.restaurant-item.highlighted .restaurant-number .number-text{color:#ff6b35;text-shadow:0 1px 2px rgba(255,255,255,.5)}.restaurant-item.highlighted .phone-link{color:#fffbe6;background:#fff3;padding:2px 6px;border-radius:4px;text-decoration:none}.restaurant-item.highlighted .phone-link:hover{color:#fff;background:#ffffff4d}.restaurant-item.highlighted .restaurant-link{color:#fffbe6;background:#fff3;padding:4px 8px;border-radius:6px;text-decoration:none}.restaurant-item.spinning{transition:all .1s ease}@keyframes slotSpin{0%{box-shadow:0 2px 8px #0000001a;border-left:3px solid transparent}25%{box-shadow:0 4px 12px #ff6b354d;border-left:3px solid #ff6b35}50%{box-shadow:0 2px 8px #0000001a;border-left:3px solid transparent}75%{box-shadow:0 4px 12px #ff6b354d;border-left:3px solid #ff6b35}to{box-shadow:0 2px 8px #0000001a;border-left:3px solid transparent}}.restaurant-item.spinning{animation:slotSpin .1s ease-in-out infinite;transform:none}.today-pick-button:disabled{background:linear-gradient(135deg,#6c757d,#8a9ba8);cursor:not-allowed;transform:none;box-shadow:none;animation:buttonPulse .5s ease-in-out infinite alternate}@keyframes buttonPulse{0%{transform:scale(1)}to{transform:scale(1.05)}}.search-results{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;z-index:1000;max-width:500px;width:90vw;max-height:70vh;overflow:hidden}.search-results-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e9ecef;background:#f8f9fa}.search-results-header h3{margin:0;color:#333}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6c757d;padding:.25rem}.search-results-list{list-style:none;max-height:50vh;overflow-y:auto}.search-results-list li{border-bottom:1px solid #f1f3f4;cursor:pointer;transition:background .2s}.search-results-list li:hover{background:#f8f9fa}.result-item{padding:1rem 1.5rem}.result-item h4{margin:0 0 .25rem;color:#333;font-size:1.1rem}.result-item p{margin:0 0 .25rem;color:#6c757d;font-size:.9rem}.result-item span{color:#ff6b35;font-size:.8rem;font-weight:600}@media (min-width: 769px) and (max-width: 1024px){.content-grid{grid-template-columns:1.5fr 1fr}}@media (max-width: 768px){.app-header{padding:1rem 1.5rem;margin-left:0;margin-right:0;max-width:100%}.app-title{font-size:1.25rem;margin-bottom:.75rem}.search-form{flex-direction:column;gap:.5rem;max-width:100%;padding:.5rem}.search-input{width:100%;padding:.75rem 1.25rem;font-size:1rem}.search-button{padding:.75rem 1.5rem;font-size:1rem;min-width:100px}.main-content{padding:0 1.5rem 1rem}.content-grid{grid-template-columns:1fr;gap:1rem;height:auto}.map-section{height:350px}.restaurant-section{height:auto;min-height:400px}.restaurant-number{width:50px;height:50px}.restaurant-number .number-text{font-size:1.2rem}.restaurant-content-wrapper{gap:.75rem}.restaurant-meta{gap:.5rem}.category-filter{padding:.75rem 1rem}.category-header{flex-direction:column;gap:.5rem;align-items:flex-start}.category-title-section{width:100%;justify-content:space-between}.category-header h3{font-size:1rem}.all-category-btn{padding:.4rem .8rem;font-size:.8rem}.category-tags{gap:.4rem}.category-tag{padding:.3rem .6rem;font-size:.8rem}}@media (max-width: 480px){.app-header,.main-content{padding:.75rem}.content-grid{gap:.75rem}.map-section{height:250px}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){.app-header{border-bottom:2px solid #000}.map-section,.restaurant-section{border:2px solid #000}}.search-input:focus,.search-button:focus,.clear-button:focus{outline:2px solid #ff6b35;outline-offset:2px}.search-results-list::-webkit-scrollbar{width:6px}.search-results-list::-webkit-scrollbar-track{background:#f1f3f4}.search-results-list::-webkit-scrollbar-thumb{background:#c1c8cd;border-radius:3px}.search-results-list::-webkit-scrollbar-thumb:hover{background:#a8b2ba}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff6b35,#ff8a50);padding:2rem}.error-content{background:#fff;padding:3rem;border-radius:16px;box-shadow:0 8px 32px #0003;text-align:center;max-width:500px;width:100%}.error-content h2{color:#ff6b35;margin-bottom:1rem;font-size:1.5rem}.error-content p{color:#666;margin-bottom:2rem;font-size:1.1rem}.retry-button{background:linear-gradient(135deg,#ff6b35,#ff8a50);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #ff6b354d}.retry-button:hover{background:linear-gradient(135deg,#e55a2b,#ff6b35);transform:translateY(-2px);box-shadow:0 6px 16px #ff6b3566}.error-details{margin-top:2rem;text-align:left;background:#f8f9fa;padding:1rem;border-radius:8px;border:1px solid #e9ecef}.error-details summary{cursor:pointer;font-weight:600;color:#333;margin-bottom:.5rem}.error-details pre{background:#fff;padding:1rem;border-radius:6px;overflow-x:auto;font-size:.9rem;color:#dc3545;border:1px solid #f1f3f4}
