:root{--primary-blue: #0059FF;--white: #FFFFFF;--text-dark: #333333;--text-light: #666666;--border: #E0E0E0;--shadow: rgba(0, 0, 0, .1);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;min-width:320px;min-height:100vh;min-height:-webkit-fill-available;background-color:var(--white);color:var(--text-dark);overflow:hidden;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}#root{width:100vw;height:100vh;height:-webkit-fill-available;overflow:hidden}button{font-family:inherit;cursor:pointer;border:none;background:none;transition:all .2s}button:disabled{opacity:.5;cursor:not-allowed}a{color:var(--primary-blue);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.filter-bar{display:flex;gap:9.6px;align-items:center;padding:9.6px 19.2px}.filter-button{padding:9.6px 19.2px;background:var(--white);border:1px solid var(--border);border-radius:24px;font-size:16.8px;font-weight:500;color:var(--text-dark);white-space:nowrap;transition:all .2s;box-shadow:0 2px 8px #0000001a}.filter-button:hover{background:#0059ff;color:var(--white);border-color:#0059ff}.filter-button.active{background:var(--primary-blue);color:var(--white);border-color:var(--primary-blue)}@media(max-width:768px){.filter-bar{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:8.4px 16.8px;border-radius:28px}.filter-bar::-webkit-scrollbar{display:none}.filter-button{font-size:18.2px;padding:8.4px 16.8px;border-radius:28px}}.header{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:1000}@media(max-width:768px){.header{top:12px}}.location-detail-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:999;animation:fadeIn .3s ease}.location-detail-card{position:fixed;background:#fff;border-radius:16px;overflow-y:auto;box-shadow:0 8px 32px #0000004d}.location-detail-card:not(.mobile-centered){top:50%;right:40px;transform:translateY(-50%);max-width:380px;width:380px;max-height:70vh;z-index:500}.location-detail-card.mobile-centered{top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:400px;max-height:80vh;z-index:1000;animation:centerFadeIn .3s cubic-bezier(.4,0,.2,1)}@keyframes centerFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.detail-image-container{position:relative;width:100%;height:180px;overflow:hidden;border-radius:16px 16px 0 0}.detail-image{width:100%;height:100%;object-fit:cover}.close-button{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:#0009;color:#fff;border:none;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.close-button:hover{background:#000c}.detail-content{padding:16px}.detail-name{font-size:24px;font-weight:700;margin:0 0 8px;color:#000}.detail-rating{display:flex;align-items:center;gap:6px;margin-bottom:6px}.rating-number{font-size:16px;font-weight:600;color:#000}.star{font-size:14px}.star.filled{color:gold}.star.half{background:linear-gradient(90deg,gold 50%,#e0e0e0 50%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.star.empty{color:#e0e0e0}.review-count{font-size:14px;color:#666}.detail-category{font-size:14px;color:#666;margin:4px 0}.detail-address{font-size:13px;color:#333;margin:4px 0}.detail-opening{font-size:13px;margin:4px 0;color:#ffb800;font-weight:600}.detail-description{font-size:13px;color:#666;margin:12px 0}.detail-actions{display:flex;gap:12px;align-items:center;margin-top:16px}.go-button{background:#0059ff;color:#fff;border:none;padding:12px 40px;border-radius:50px;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s;flex:1}.go-button:hover{background:#0047cc}.go-button:active{transform:scale(.98)}.chat-button{width:48px;height:48px;border-radius:50%;background:#9e9e9e;border:none;font-size:24px;cursor:pointer;box-shadow:0 2px 8px #00000026;display:flex;align-items:center;justify-content:center;transition:transform .2s;flex-shrink:0}.chat-button:hover{transform:scale(1.05)}@media(max-width:768px){.location-detail-card:not(.mobile-centered){right:16px;width:calc(100% - 32px);max-width:320px}.detail-name{font-size:22px}.detail-content{padding:16px}.go-button{padding:10px 32px;font-size:15px}.detail-image-container{height:200px}}.map-container{position:relative;width:100%;height:100%}.map{width:100%;height:100%}.map-loading,.map-error{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:20px;text-align:center;background:#f5f5f5}.map-error{color:#d32f2f}.map-error p{margin:8px 0}.location-button{position:absolute;top:16px;right:20px;bottom:auto;width:52.8px;height:52.8px;background:transparent;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:10;cursor:pointer;transition:all .2s;padding:0}.location-button .location-btn-icon{width:52.8px;height:52.8px;object-fit:contain}.location-button:hover{transform:scale(1.05)}.location-button:active{transform:scale(.95)}.map-logo{position:absolute;bottom:20px;right:20px;top:auto;z-index:10;display:flex;align-items:center;justify-content:center}.map-logo img{height:32px;width:auto}@media(max-width:768px){.location-button{bottom:calc(80px + env(safe-area-inset-bottom));right:16px;top:auto;width:56px;height:56px}.location-button .location-btn-icon{width:56px;height:56px}.map-logo{bottom:calc(90px + env(safe-area-inset-bottom));left:16px;right:auto;top:auto}.map-logo img{height:33.6px}}.shop-card{position:relative;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.shop-card-bg{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;object-fit:cover;object-position:center 100%;z-index:1}.shop-card-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,#0000004d,#0000 20% 60%,#000c);z-index:2}.mute-indicator{position:absolute;top:20px;right:20px;z-index:11;background:#0009;border-radius:50%;width:56px;height:56px;display:flex;align-items:center;justify-content:center;transition:opacity .3s;pointer-events:none}.mute-indicator svg{width:32px;height:32px}@media(min-width:769px){.mute-indicator{top:20px;right:20px}}.shop-description{position:absolute;top:100px;left:50%;transform:translate(-50%);z-index:10}.description-text{background:#000000d9;color:#fff;padding:12px 24px;font-size:24px;font-weight:700;white-space:nowrap;border-radius:8px}.shop-info{position:absolute;bottom:90px;left:20px;z-index:10;color:#fff;max-width:calc(100% - 120px);cursor:pointer;transition:transform .2s ease}.shop-info:active{transform:scale(.98)}.shop-category{font-size:14px;font-weight:500;opacity:.9;margin-bottom:4px}.shop-name{font-size:32px;font-weight:700;margin:0 0 8px;line-height:1.2}.shop-location{font-size:14px;margin:4px 0;opacity:.9}.shop-open-time{font-size:14px;margin:4px 0;color:#ffb800;font-weight:600}.shop-rating{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:16px}.stars{display:flex;gap:2px}.full-star{color:gold}.half-star{background:linear-gradient(90deg,gold 50%,#ffd7004d 50%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.empty-star{color:gold;opacity:.3}.rating-count{opacity:.8;font-size:14px}.shop-actions{position:absolute;bottom:200px;right:16px;z-index:10;display:flex;flex-direction:column;gap:20px;align-items:center}.action-button{background:transparent;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:transform .2s;padding:8px}.action-button:hover{transform:scale(1.1)}.action-button:active{transform:scale(.95)}.action-button.liked svg path{animation:heartbeat .3s ease}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.action-count{color:#fff;font-size:13px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.5)}@media(max-width:768px){.shop-card-bg,.shop-card-overlay{transform:translateY(-70px)}.description-text{font-size:20px;padding:10px 20px}.shop-info{bottom:110px;left:16px;max-width:calc(100% - 100px)}.shop-name{font-size:24px}.shop-category,.shop-location,.shop-open-time{font-size:13px}.shop-rating{font-size:14px}.shop-actions{bottom:160px;right:12px;gap:16px}.action-button svg{width:28px;height:28px}.action-count{font-size:12px}.mute-indicator{position:absolute;top:80px;right:20px;width:48px;height:48px;z-index:11;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);pointer-events:auto}.mute-indicator svg{width:24px;height:24px}}.shorts-feed{position:relative;width:100%;height:100%;overflow:hidden;background:#000;touch-action:none;-webkit-user-select:none;user-select:none;cursor:grab}.shorts-feed:active{cursor:grabbing}.shorts-container{width:100%;height:100%}.shorts-item{width:100%;height:100%;position:relative}.shorts-indicator{position:absolute;top:20px;left:50%;transform:translate(-50%);background:#0009;color:#fff;padding:6px 16px;border-radius:20px;font-size:13px;font-weight:500;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media(max-width:768px){.shorts-indicator{top:12px;font-size:12px;padding:4px 12px}}.comment-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.comment-modal{background:#fff;border-radius:16px;width:90%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 10px 40px #0000004d}.comment-modal-header{display:flex;align-items:center;gap:8px;padding:20px;border-bottom:1px solid #eee;position:relative}.comment-modal-header h3{margin:0;font-size:18px;font-weight:700;color:#000}.comment-count{font-size:16px;color:#666;font-weight:500}.comment-close-button{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:#f0f0f0;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:#666;transition:background .2s}.comment-close-button:hover{background:#e0e0e0}.comment-list{flex:1;overflow-y:auto;padding:16px 20px}.comment-item{display:flex;gap:12px;margin-bottom:20px}.comment-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;flex-shrink:0}.comment-content{flex:1}.comment-header-info{display:flex;align-items:center;gap:8px;margin-bottom:4px}.comment-username{font-weight:700;font-size:14px;color:#000}.comment-timestamp{font-size:12px;color:#999}.comment-text{margin:0;font-size:14px;color:#333;line-height:1.5}.comment-input-container{display:flex;align-items:center;gap:12px;padding:16px 20px;border-top:1px solid #eee;background:#fafafa}.comment-input-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.comment-input{flex:1;border:1px solid #ddd;border-radius:20px;padding:10px 16px;font-size:14px;outline:none;background:#fff}.comment-input::placeholder{color:#aaa}.comment-list::-webkit-scrollbar{width:6px}.comment-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.comment-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:10px}.comment-list::-webkit-scrollbar-thumb:hover{background:#999}@media(max-width:768px){.comment-modal{width:95%;max-height:85vh}.comment-modal-header{padding:16px}.comment-list,.comment-input-container{padding:12px 16px}}.mobile-view-toggle{position:fixed;bottom:0;left:0;right:0;width:100%;z-index:1000;background:#fff;border-top:1px solid rgba(0,0,0,.1);padding:6px 0;padding-bottom:max(2px,env(safe-area-inset-bottom));display:flex;justify-content:space-around;align-items:center;gap:0}.toggle-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 12px;border:none;background:transparent;color:#606060;font-size:11px;font-weight:600;cursor:pointer;border-radius:0;transition:color .2s ease;position:relative;overflow:hidden;min-width:60px;flex:1;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;touch-action:manipulation}.toggle-button.active{color:#000}.toggle-icon{width:24px;height:24px;stroke-width:2.5;flex-shrink:0;transition:color .2s ease;color:inherit}.toggle-button.active .toggle-icon{color:#000}.toggle-button span{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;letter-spacing:.2px;line-height:1.2;white-space:nowrap}@media(min-width:769px){.mobile-view-toggle{display:none!important}}.toggle-button:active{opacity:.7}.toggle-button:focus{outline:none}.shop-detail-modal-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:flex-end;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.shop-detail-modal{width:100%;max-width:600px;max-height:85vh;margin:0 auto;background:#fff;border-radius:24px 24px 0 0;overflow-y:auto;animation:slideUp .4s cubic-bezier(.4,0,.2,1);position:relative}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-close-button{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:#00000080;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:none;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-button:hover{background:#000000b3;transform:scale(1.1)}.modal-close-button:active{transform:scale(.95)}.modal-close-button svg{width:20px;height:20px;stroke:#fff}.modal-image{width:100%;height:240px;overflow:hidden;background:#f5f5f5}.modal-image img{width:100%;height:100%;object-fit:cover}.modal-content{padding:24px}.modal-header{margin-bottom:20px}.modal-category-badge{display:inline-block;padding:6px 14px;background:#0059ff;color:#fff;border-radius:20px;font-size:13px;font-weight:500;margin-bottom:12px}.modal-title{font-size:26px;font-weight:700;color:#333;margin:0;line-height:1.3}.modal-meta{display:flex;gap:20px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #eee}.meta-item{display:flex;align-items:center;gap:6px;font-size:14px;color:#666}.meta-icon{width:18px;height:18px;color:#0059ff}.modal-section{margin-bottom:24px}.section-title{font-size:16px;font-weight:600;color:#333;margin:0 0 12px}.opening-hours,.location-info{display:flex;align-items:center;gap:10px;font-size:15px;color:#666}.section-icon{width:20px;height:20px;color:#999;flex-shrink:0}.description{font-size:15px;color:#666;line-height:1.6;margin:0}.like-info{display:flex;align-items:center;gap:8px}.like-icon{width:24px;height:24px;stroke-width:2}.like-count{font-size:15px;color:#666;font-weight:500}.modal-go-button{width:100%;padding:16px;background:linear-gradient(135deg,#0059ff,#0041cc);color:#fff;border:none;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s ease;box-shadow:0 4px 12px #0059ff4d;margin-top:32px}.modal-go-button:hover{background:linear-gradient(135deg,#0041cc,#002d99);box-shadow:0 6px 20px #0059ff66;transform:translateY(-2px)}.modal-go-button:active{transform:translateY(0)}.modal-go-button svg{width:24px;height:24px}.shop-detail-modal::-webkit-scrollbar{width:4px}.shop-detail-modal::-webkit-scrollbar-track{background:#f5f5f5}.shop-detail-modal::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}@media(min-width:769px){.shop-detail-modal-overlay{align-items:center;justify-content:center}.shop-detail-modal{border-radius:24px;max-height:90vh}@keyframes slideUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}}.app{width:100vw;height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-content{display:flex;flex:1;overflow:hidden}.video-section{width:33.33%;height:100%;background:#000;overflow:hidden}.video-placeholder{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:20px;text-align:center}.placeholder-text{font-size:32px;margin-bottom:8px}.placeholder-subtitle{font-size:16px;color:var(--text-light);margin-bottom:24px}.selected-info{margin-top:24px;padding:16px;background:var(--white);border-radius:12px;box-shadow:0 2px 8px var(--shadow)}.selected-info p{margin:4px 0}.map-section{width:66.67%;height:100%;overflow:hidden}.hidden{display:none!important}@media(max-width:768px){.app-content{flex-direction:column}.app-content.mobile-video .video-section,.app-content.mobile-map .map-section{width:100%;height:100vh}.video-section,.map-section{width:100%}.placeholder-text{font-size:24px}.placeholder-subtitle{font-size:14px}}
