.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:var(--transition)}.header.scrolled{background:#fff;box-shadow:var(--shadow-md)}.header-container{max-width:1280px;margin:0 auto;padding:0 20px;height:72px;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:10px;text-decoration:none}.logo-icon{font-size:2rem;color:var(--primary-color)}.logo-text{display:flex;flex-direction:column}.logo-main{font-size:1.25rem;font-weight:700;color:var(--primary-color);line-height:1.2}.logo-sub{font-size:.75rem;color:var(--text-light);font-weight:400}.nav-list{display:flex;align-items:center;gap:8px}.nav-item{display:flex;align-items:center}.nav-link{padding:10px 20px;font-size:1rem;font-weight:500;color:var(--text-secondary);border-radius:8px;transition:var(--transition)}.nav-link:hover{color:var(--primary-color);background:#0066cc14}.nav-link.active{color:var(--primary-color);background:#0066cc1f}.more-menu{position:relative}.more-btn{display:flex;align-items:center;gap:6px;cursor:pointer;background:none;border:none;padding:10px 20px;font-size:1rem;font-weight:500;color:var(--text-secondary);border-radius:8px;transition:var(--transition)}.more-btn:hover{color:var(--primary-color);background:#0066cc14}.more-btn.active{color:var(--primary-color);background:#0066cc1f}.more-btn .arrow{font-size:.6rem;transition:transform .3s ease}.more-btn .arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:0;min-width:160px;background:var(--card-bg, white);border-radius:12px;box-shadow:0 8px 30px #00000026;padding:8px 0;z-index:100;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-link{display:block;padding:10px 20px;color:var(--text-secondary);font-size:.95rem;transition:all .2s ease}.dropdown-link:hover{background:#0066cc14;color:var(--primary-color)}.dropdown-link.active{color:var(--primary-color);background:#0066cc1f}.header-actions{display:flex;align-items:center;gap:6px}.theme-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--text-secondary);border-radius:50%;border:1px solid #e0e0e0;transition:var(--transition);flex-shrink:0}.theme-btn:hover{background:#0066cc14;border-color:var(--primary-color);color:var(--primary-color)}.lang-btn{display:flex;align-items:center;gap:3px;padding:6px 10px;font-size:.8rem;font-weight:500;color:var(--text-secondary);border-radius:16px;border:1px solid #e0e0e0;transition:var(--transition);flex-shrink:0}.lang-btn:hover{background:#0066cc14;border-color:var(--primary-color);color:var(--primary-color)}.search-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--text-secondary);border-radius:50%;transition:var(--transition);flex-shrink:0}.search-btn:hover{background:#0066cc14;color:var(--primary-color)}.login-btn{display:flex;align-items:center;gap:3px;padding:5px 10px;background:#fee500;color:#191919;border:none;border-radius:14px;font-size:.75rem;font-weight:600;cursor:pointer;transition:var(--transition)}.login-btn:hover{background:#f5dc00;transform:translateY(-1px);box-shadow:0 2px 8px #fee50066}.login-btn svg{flex-shrink:0;width:12px;height:12px}.user-menu-container{position:relative}.user-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:2px solid #e0e0e0;background:#fff;cursor:pointer;transition:var(--transition);overflow:hidden}.user-btn:hover{border-color:var(--primary-color)}.user-btn svg{font-size:1.2rem;color:var(--text-secondary)}.user-avatar{width:100%;height:100%;object-fit:cover}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;overflow:hidden;z-index:100}.user-dropdown .user-info{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-bottom:1px solid #e0e0e0}.user-dropdown-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid white;box-shadow:0 2px 8px #0000001a}.user-nickname{font-size:1rem;font-weight:600;color:#0f172a}.user-provider{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#fee500;color:#191919;border-radius:12px;font-size:.75rem;font-weight:500}.user-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;font-size:.9rem;color:#374151;text-decoration:none;transition:var(--transition);border:none;background:none;cursor:pointer;text-align:left}.user-dropdown-item:hover{background:#f3f4f6}.user-dropdown-item svg{font-size:1.1rem;color:#6b7280}.user-dropdown-item.logout-btn{border-top:1px solid #e5e7eb;color:#ef4444}.user-dropdown-item.logout-btn svg{color:#ef4444}.user-dropdown-item.logout-btn:hover{background:#fef2f2}.mobile-menu-btn{display:none;width:44px;height:44px;align-items:center;justify-content:center;font-size:1.5rem;color:var(--text-secondary)}@media (max-width: 768px){.header-container{height:64px}.nav{position:fixed;top:64px;left:0;right:0;bottom:0;background:#fff;padding:20px;transform:translate(100%);transition:transform .3s ease}.nav.open{transform:translate(0)}.nav-list{flex-direction:column;gap:4px}.nav-link{display:block;padding:16px 20px;font-size:1.125rem}.more-menu{position:static}.dropdown-menu{position:static;box-shadow:none;background:#0066cc0d;border-radius:8px;margin-top:4px}.mobile-menu-btn{display:flex}.login-btn span{display:none}.login-btn{width:30px;height:30px;padding:0;border-radius:50%;justify-content:center}.login-btn svg{width:14px;height:14px}.logo-main{font-size:1.1rem}.logo-sub{display:none}}.footer{background:var(--text-primary);color:#b4b4c8;padding:60px 0 30px}.footer-container{max-width:1280px;margin:0 auto;padding:0 20px}.footer-main{display:grid;grid-template-columns:1.5fr 2fr;gap:60px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}.footer-logo{display:flex;align-items:center;gap:10px;font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:16px}.footer-logo-icon{color:var(--accent-color)}.footer-desc{font-size:.95rem;line-height:1.7;margin-bottom:24px}.footer-contact{display:flex;flex-direction:column;gap:12px}.contact-item{display:flex;align-items:center;gap:10px;font-size:.95rem}.contact-item svg{color:var(--accent-color)}.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}.footer-link-group h4{color:#fff;font-size:1rem;font-weight:600;margin-bottom:20px}.footer-link-group ul{display:flex;flex-direction:column;gap:12px}.footer-link-group a{font-size:.95rem;transition:color .2s ease}.footer-link-group a:hover{color:#fff}.footer-bottom{padding-top:30px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.footer-social{display:flex;gap:12px}.social-link{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:#ffffff1a;border-radius:50%;transition:var(--transition)}.social-link:hover{background:var(--accent-color);color:#fff}.footer-copyright{display:flex;flex-direction:column;align-items:center;gap:8px;flex-wrap:wrap}.footer-copyright p{font-size:.875rem}.footer-data-source{font-size:.75rem!important;opacity:.7;max-width:600px;text-align:center;line-height:1.4}.footer-legal{display:flex;gap:16px}.footer-legal a{font-size:.875rem;transition:color .2s ease}.footer-legal a:hover{color:#fff}@media (max-width: 1024px){.footer-main{grid-template-columns:1fr;gap:40px}}@media (max-width: 768px){.footer{padding:40px 0 20px}.footer-links{grid-template-columns:repeat(2,1fr);gap:30px}.footer-bottom{flex-direction:column;text-align:center}.footer-copyright{flex-direction:column;gap:12px}}@media (max-width: 480px){.footer-links{grid-template-columns:1fr}}@font-face{font-family:swiper-icons;src:url(data:application/font-woff;charset=utf-8;base64,\ d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA);font-weight:400;font-style:normal}:root{--swiper-theme-color: #007aff}:host{position:relative;display:block;margin-left:auto;margin-right:auto;z-index:1}.swiper{margin-left:auto;margin-right:auto;position:relative;overflow:hidden;list-style:none;padding:0;z-index:1;display:block}.swiper-vertical>.swiper-wrapper{flex-direction:column}.swiper-wrapper{position:relative;width:100%;height:100%;z-index:1;display:flex;transition-property:transform;transition-timing-function:var(--swiper-wrapper-transition-timing-function, initial);box-sizing:content-box}.swiper-android .swiper-slide,.swiper-ios .swiper-slide,.swiper-wrapper{transform:translateZ(0)}.swiper-horizontal{touch-action:pan-y}.swiper-vertical{touch-action:pan-x}.swiper-slide{flex-shrink:0;width:100%;height:100%;position:relative;transition-property:transform;display:block}.swiper-slide-invisible-blank{visibility:hidden}.swiper-autoheight,.swiper-autoheight .swiper-slide{height:auto}.swiper-autoheight .swiper-wrapper{align-items:flex-start;transition-property:transform,height}.swiper-backface-hidden .swiper-slide{transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.swiper-3d.swiper-css-mode .swiper-wrapper{perspective:1200px}.swiper-3d .swiper-wrapper{transform-style:preserve-3d}.swiper-3d{perspective:1200px}.swiper-3d .swiper-slide,.swiper-3d .swiper-cube-shadow{transform-style:preserve-3d}.swiper-css-mode>.swiper-wrapper{overflow:auto;scrollbar-width:none;-ms-overflow-style:none}.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar{display:none}.swiper-css-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:start start}.swiper-css-mode.swiper-horizontal>.swiper-wrapper{scroll-snap-type:x mandatory}.swiper-css-mode.swiper-vertical>.swiper-wrapper{scroll-snap-type:y mandatory}.swiper-css-mode.swiper-free-mode>.swiper-wrapper{scroll-snap-type:none}.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:none}.swiper-css-mode.swiper-centered>.swiper-wrapper:before{content:"";flex-shrink:0;order:9999}.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide{scroll-snap-align:center center;scroll-snap-stop:always}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child{margin-inline-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper:before{height:100%;min-height:1px;width:var(--swiper-centered-offset-after)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child{margin-block-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper:before{width:100%;min-width:1px;height:var(--swiper-centered-offset-after)}.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top,.swiper-3d .swiper-slide-shadow-bottom{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;z-index:10}.swiper-3d .swiper-slide-shadow{background:#00000026}.swiper-3d .swiper-slide-shadow-left{background-image:linear-gradient(to left,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-right{background-image:linear-gradient(to right,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-top{background-image:linear-gradient(to top,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-bottom{background-image:linear-gradient(to bottom,#00000080,#0000)}.swiper-lazy-preloader{width:42px;height:42px;position:absolute;left:50%;top:50%;margin-left:-21px;margin-top:-21px;z-index:10;transform-origin:50%;box-sizing:border-box;border:4px solid var(--swiper-preloader-color, var(--swiper-theme-color));border-radius:50%;border-top-color:transparent}.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader{animation:swiper-preloader-spin 1s infinite linear}.swiper-lazy-preloader-white{--swiper-preloader-color: #fff}.swiper-lazy-preloader-black{--swiper-preloader-color: #000}@keyframes swiper-preloader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.swiper-pagination{position:absolute;text-align:center;transition:.3s opacity;transform:translateZ(0);z-index:10}.swiper-pagination.swiper-pagination-hidden{opacity:0}.swiper-pagination-disabled>.swiper-pagination,.swiper-pagination.swiper-pagination-disabled{display:none!important}.swiper-pagination-fraction,.swiper-pagination-custom,.swiper-horizontal>.swiper-pagination-bullets,.swiper-pagination-bullets.swiper-pagination-horizontal{bottom:var(--swiper-pagination-bottom, 8px);top:var(--swiper-pagination-top, auto);left:0;width:100%}.swiper-pagination-bullets-dynamic{overflow:hidden;font-size:0}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transform:scale(.33);position:relative}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active,.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main{transform:scale(1)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev{transform:scale(.33)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next{transform:scale(.33)}.swiper-pagination-bullet{width:var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));height:var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));display:inline-block;border-radius:var(--swiper-pagination-bullet-border-radius, 50%);background:var(--swiper-pagination-bullet-inactive-color, #000);opacity:var(--swiper-pagination-bullet-inactive-opacity, .2)}button.swiper-pagination-bullet{border:none;margin:0;padding:0;box-shadow:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.swiper-pagination-clickable .swiper-pagination-bullet{cursor:pointer}.swiper-pagination-bullet:only-child{display:none!important}.swiper-pagination-bullet-active{opacity:var(--swiper-pagination-bullet-opacity, 1);background:var(--swiper-pagination-color, var(--swiper-theme-color))}.swiper-vertical>.swiper-pagination-bullets,.swiper-pagination-vertical.swiper-pagination-bullets{right:var(--swiper-pagination-right, 8px);left:var(--swiper-pagination-left, auto);top:50%;transform:translate3d(0,-50%,0)}.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet{margin:var(--swiper-pagination-bullet-vertical-gap, 6px) 0;display:block}.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{top:50%;transform:translateY(-50%);width:8px}.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{display:inline-block;transition:.2s transform,.2s top}.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet{margin:0 var(--swiper-pagination-bullet-horizontal-gap, 4px)}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{left:50%;transform:translate(-50%);white-space:nowrap}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s left}.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s right}.swiper-pagination-fraction{color:var(--swiper-pagination-fraction-color, inherit)}.swiper-pagination-progressbar{background:var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, .25));position:absolute}.swiper-pagination-progressbar .swiper-pagination-progressbar-fill{background:var(--swiper-pagination-color, var(--swiper-theme-color));position:absolute;left:0;top:0;width:100%;height:100%;transform:scale(0);transform-origin:left top}.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill{transform-origin:right top}.swiper-horizontal>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-horizontal,.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite{width:100%;height:var(--swiper-pagination-progressbar-size, 4px);left:0;top:0}.swiper-vertical>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-vertical,.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite{width:var(--swiper-pagination-progressbar-size, 4px);height:100%;left:0;top:0}.swiper-pagination-lock{display:none}.swiper-fade.swiper-free-mode .swiper-slide{transition-timing-function:ease-out}.swiper-fade .swiper-slide{pointer-events:none;transition-property:opacity}.swiper-fade .swiper-slide .swiper-slide{pointer-events:none}.swiper-fade .swiper-slide-active,.swiper-fade .swiper-slide-active .swiper-slide-active{pointer-events:auto}.hero{position:relative;height:100vh;min-height:600px;max-height:900px}.hero.hero-loading{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e)}.hero.hero-loading .loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.hero-swiper{width:100%;height:100%}.hero-slide{width:100%;height:100%;background-size:cover;background-position:center;position:relative;display:flex;align-items:center}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to right,#000000b3,#0006,#0003)}.hero-content{position:relative;z-index:10;max-width:1280px;margin:0 auto;padding:72px 20px 0;color:#fff}.hero-badge{display:inline-block;padding:8px 16px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;font-size:.875rem;font-weight:500;margin-bottom:20px}.hero-title{font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:16px;max-width:600px}.hero-description{font-size:1.25rem;opacity:.9;margin-bottom:32px;max-width:500px}.hero-btn{display:inline-flex;align-items:center;gap:8px;padding:16px 32px;background:#fff;color:var(--text-primary);font-size:1rem;font-weight:600;border-radius:8px;transition:var(--transition)}.hero-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #0000004d}.dark-theme .hero-btn{background:#1a1a2e;color:#e8e8e8;border:1px solid rgba(255,255,255,.15)}.dark-theme .hero-btn:hover{background:#252542;box-shadow:0 10px 30px #00000080}.hero .swiper-pagination{bottom:40px!important}.hero .swiper-pagination-bullet{width:12px;height:12px;background:#ffffff80;opacity:1}.hero .swiper-pagination-bullet-active{background:#fff;width:36px;border-radius:6px}@media (max-width: 1024px){.hero-title{font-size:2.75rem}}@media (max-width: 768px){.hero{min-height:500px;max-height:700px}.hero-content{padding-top:64px}.hero-title{font-size:2rem}.hero-description{font-size:1rem}.hero-btn{padding:14px 24px}}@media (max-width: 480px){.hero-title{font-size:1.75rem}}.quick-menu{padding:80px 0;background:var(--bg-secondary)}.quick-menu-header{text-align:center;margin-bottom:48px}.quick-menu-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px}.quick-menu-item{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 16px;background:var(--card-bg, white);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);transition:var(--transition)}.quick-menu-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.quick-menu-item:hover .quick-menu-icon{background:var(--bg-gradient);color:#fff}.quick-menu-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#0066cc1a;color:var(--primary-color);border-radius:50%;font-size:1.5rem;transition:var(--transition)}.quick-menu-label{font-size:.95rem;font-weight:500;color:var(--text-primary)}@media (max-width: 1024px){.quick-menu-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.quick-menu{padding:60px 0}.quick-menu-grid{grid-template-columns:repeat(3,1fr);gap:12px}.quick-menu-item{padding:20px 12px}.quick-menu-icon{width:50px;height:50px;font-size:1.25rem}.quick-menu-label{font-size:.85rem}}@media (max-width: 480px){.quick-menu-grid{grid-template-columns:repeat(2,1fr)}}.dark-theme .quick-menu{background:var(--bg-tertiary)}.dark-theme .quick-menu-item{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .quick-menu-item:hover{border-color:var(--primary-color)}.dark-theme .quick-menu-icon{background:#4da6ff26;color:var(--primary-color)}.dark-theme .quick-menu-item:hover .quick-menu-icon{background:linear-gradient(135deg,#3385d6,#39c);color:#fff}.dark-theme .quick-menu-label{color:var(--text-primary)}.travel-card{display:block;background:var(--card-bg, white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition)}.travel-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}.travel-card-image{position:relative;height:200px;overflow:hidden}.travel-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.travel-card:hover .travel-card-image img{transform:scale(1.1)}.travel-card-category{position:absolute;top:12px;left:12px;padding:6px 12px;background:var(--primary-color);color:#fff;font-size:.75rem;font-weight:500;border-radius:4px}.travel-card-content{padding:20px}.travel-card-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:12px;line-height:1.4}.travel-card-info{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px}.info-item{display:flex;align-items:center;gap:6px;font-size:.875rem;color:var(--text-secondary)}.info-item svg{color:var(--primary-color);font-size:1rem}.travel-card-link{display:inline-flex;align-items:center;gap:4px;font-size:.875rem;font-weight:500;color:var(--primary-color);transition:gap .2s ease}.travel-card:hover .travel-card-link{gap:8px}.dark-theme .travel-card{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .travel-card-content{background:var(--card-bg)}.dark-theme .travel-card-title{color:var(--text-primary)}.dark-theme .travel-card-info{color:var(--text-secondary)}.dark-theme .info-item{color:var(--text-light);background:var(--bg-tertiary);padding:4px 8px;border-radius:4px}.dark-theme .info-item svg{color:var(--primary-color)}.dark-theme .travel-card-link{color:var(--primary-color)}.popular-spots{background:var(--bg-primary, white)}.spots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:48px}.spots-loading{display:flex;justify-content:center;align-items:center;min-height:300px}.spots-loading .loading-spinner{font-size:2.5rem;color:var(--primary-color);animation:spin 1s linear infinite}@media (max-width: 1200px){.spots-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 900px){.spots-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.spots-grid{grid-template-columns:1fr;gap:16px}}:root{--swiper-navigation-size: 44px}.swiper-button-prev,.swiper-button-next{position:absolute;top:var(--swiper-navigation-top-offset, 50%);width:calc(var(--swiper-navigation-size) / 44 * 27);height:var(--swiper-navigation-size);margin-top:calc(0px - (var(--swiper-navigation-size) / 2));z-index:10;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--swiper-navigation-color, var(--swiper-theme-color))}.swiper-button-prev.swiper-button-disabled,.swiper-button-next.swiper-button-disabled{opacity:.35;cursor:auto;pointer-events:none}.swiper-button-prev.swiper-button-hidden,.swiper-button-next.swiper-button-hidden{opacity:0;cursor:auto;pointer-events:none}.swiper-navigation-disabled .swiper-button-prev,.swiper-navigation-disabled .swiper-button-next{display:none!important}.swiper-button-prev svg,.swiper-button-next svg{width:100%;height:100%;object-fit:contain;transform-origin:center}.swiper-rtl .swiper-button-prev svg,.swiper-rtl .swiper-button-next svg{transform:rotate(180deg)}.swiper-button-prev,.swiper-rtl .swiper-button-next{left:var(--swiper-navigation-sides-offset, 10px);right:auto}.swiper-button-lock{display:none}.swiper-button-prev:after,.swiper-button-next:after{font-family:swiper-icons;font-size:var(--swiper-navigation-size);text-transform:none!important;letter-spacing:0;font-variant:initial;line-height:1}.swiper-button-prev:after,.swiper-rtl .swiper-button-next:after{content:"prev"}.swiper-button-next,.swiper-rtl .swiper-button-prev{right:var(--swiper-navigation-sides-offset, 10px);left:auto}.swiper-button-next:after,.swiper-rtl .swiper-button-prev:after{content:"next"}.festival-section{padding:80px 0;background:linear-gradient(180deg,#f0f7ff,#fff)}.festival-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px}.festival-title-area{text-align:left}.festival-title-area .section-title{text-align:left;margin-bottom:8px}.festival-title-area .section-subtitle{text-align:left}.festival-nav{display:flex;gap:8px}.nav-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--card-bg, white);border:1px solid var(--border-color, #e0e0e0);border-radius:50%;font-size:1.25rem;color:var(--text-secondary);transition:var(--transition)}.nav-btn:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.festival-loading{display:flex;justify-content:center;align-items:center;min-height:300px}.festival-loading .loading-spinner{font-size:2.5rem;color:var(--primary-color);animation:spin 1s linear infinite}.festival-swiper{margin-bottom:48px}.festival-card{display:block;background:var(--card-bg, white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition)}.festival-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}.festival-image{position:relative;height:220px;overflow:hidden}.festival-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.festival-card:hover .festival-image img{transform:scale(1.1)}.festival-status{position:absolute;top:12px;right:12px;padding:6px 12px;background:var(--secondary-color);color:#fff;font-size:.75rem;font-weight:600;border-radius:4px}.festival-content{padding:20px}.festival-name{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.festival-info{display:flex;flex-direction:column;gap:8px}.info-row{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-secondary)}.info-row svg{color:var(--primary-color)}@media (max-width: 768px){.festival-section{padding:60px 0}.festival-header{flex-direction:column;align-items:flex-start;gap:20px}.festival-image{height:180px}}.dark-theme .festival-card{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .festival-content{background:var(--card-bg)}.dark-theme .festival-name{color:var(--text-primary)}.dark-theme .info-row{color:var(--text-secondary)}.food-section{background:var(--bg-primary, white)}.food-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:48px}.food-loading{display:flex;justify-content:center;align-items:center;min-height:250px}.food-loading .loading-spinner{font-size:2.5rem;color:var(--primary-color);animation:spin 1s linear infinite}.food-card{display:flex;background:var(--card-bg, white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition)}.food-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.food-image{position:relative;width:200px;min-height:180px;flex-shrink:0}.food-image img{width:100%;height:100%;object-fit:cover}.food-rating{position:absolute;bottom:12px;left:12px;display:flex;align-items:center;gap:4px;padding:6px 10px;background:#000000b3;color:gold;font-size:.875rem;font-weight:600;border-radius:4px}.food-rating svg{fill:gold}.food-content{padding:20px;display:flex;flex-direction:column;justify-content:center}.food-header{margin-bottom:8px}.food-category{display:inline-block;padding:4px 8px;background:#0066cc1a;color:var(--primary-color);font-size:.75rem;font-weight:500;border-radius:4px;margin-bottom:8px}.food-name{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.food-description{font-size:.95rem;color:var(--text-secondary);line-height:1.6;margin-bottom:12px}.food-location{font-size:.875rem;color:var(--text-light)}.section-more{text-align:center}@media (max-width: 1024px){.food-grid{grid-template-columns:1fr}}@media (max-width: 600px){.food-card{flex-direction:column}.food-image{width:100%;height:200px}}.dark-theme .food-card{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .food-content{background:var(--card-bg)}.dark-theme .food-name{color:var(--text-primary)}.dark-theme .food-description{color:var(--text-secondary)}.dark-theme .food-location{color:var(--text-light)}.travel-course{background:var(--bg-secondary)}.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.course-card{display:block;background:var(--card-bg, white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition);cursor:pointer}.course-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}.course-image{position:relative;height:180px;overflow:hidden}.course-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.course-card:hover .course-image img{transform:scale(1.1)}.course-tag{position:absolute;top:12px;left:12px;padding:6px 12px;background:var(--secondary-color);color:#fff;font-size:.75rem;font-weight:600;border-radius:4px}.course-content{padding:20px}.course-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:16px;line-height:1.4}.course-spots{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.spot-badge{padding:4px 10px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.8rem;border-radius:12px}.course-footer{display:flex;justify-content:space-between;align-items:center}.course-duration{display:flex;align-items:center;gap:6px;font-size:.875rem;color:var(--text-secondary)}.course-duration svg{color:var(--primary-color)}.course-link{display:flex;align-items:center;gap:4px;font-size:.875rem;font-weight:500;color:var(--primary-color);transition:gap .2s ease}.course-card:hover .course-link{gap:8px}@media (max-width: 1024px){.course-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.course-grid{grid-template-columns:1fr}}.dark-theme .course-card{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .course-title{color:var(--text-primary)}.dark-theme .spot-badge{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.dark-theme .course-duration{color:var(--text-secondary)}.dark-theme .course-link{color:var(--primary-color)}.course-loading{display:flex;justify-content:center;align-items:center;min-height:200px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.published-course{border:2px solid transparent;transition:border-color .3s ease,transform .3s ease,box-shadow .3s ease}.published-course:hover{border-color:var(--primary-color)}.course-tag.user-tag{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color))}.course-author{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary);margin-bottom:12px}.course-author svg{color:var(--primary-color);font-size:.9rem}.course-stats{display:flex;gap:12px;font-size:.8rem;color:var(--text-secondary)}.course-stats span{display:flex;align-items:center;gap:4px}.course-stats svg{font-size:.85rem}.spot-badge.empty{background:var(--bg-secondary);color:var(--text-tertiary);font-style:italic}.spot-badge.clickable{cursor:pointer;transition:all .2s ease}.spot-badge.clickable:hover{background:var(--primary-color);color:#fff;transform:scale(1.05)}.spot-info-card{position:absolute;z-index:1000;width:260px;background:var(--card-bg, white);border-radius:var(--border-radius);box-shadow:0 8px 32px #00000026;padding:16px;animation:spotCardIn .2s ease}@keyframes spotCardIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.spot-card-close{position:absolute;top:8px;right:8px;background:none;border:none;padding:4px;cursor:pointer;color:var(--text-tertiary);transition:color .2s}.spot-card-close:hover{color:var(--text-primary)}.spot-card-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:8px;padding-right:24px}.spot-card-address{display:flex;align-items:flex-start;gap:6px;font-size:.85rem;color:var(--text-secondary);margin-bottom:8px;line-height:1.4}.spot-card-address svg{color:var(--secondary-color);flex-shrink:0;margin-top:2px}.spot-card-memo{font-size:.85rem;color:var(--text-tertiary);font-style:italic;padding:8px 10px;background:var(--bg-secondary);border-radius:6px;margin-bottom:12px}.spot-card-direction{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.spot-card-direction:hover{background:var(--primary-hover);transform:translateY(-2px)}.dark-theme .published-course:hover{border-color:var(--primary-color)}.dark-theme .course-author,.dark-theme .course-stats{color:var(--text-secondary)}.dark-theme .spot-info-card{background:var(--card-bg);border:1px solid var(--border-color);box-shadow:0 8px 32px #0006}.dark-theme .spot-card-memo{background:var(--bg-tertiary)}.weather-widget{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;padding:20px;color:#fff;box-shadow:0 10px 40px #667eea4d;max-width:360px;margin:0 auto}.weather-loading,.weather-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:16px}.weather-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.weather-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.weather-header-buttons{display:flex;gap:8px}.weather-title h3{font-size:1.25rem;font-weight:600;margin:0 0 4px}.weather-location{display:flex;align-items:center;gap:4px;font-size:.85rem;opacity:.85}.weather-header .refresh-btn,.weather-header .collapse-btn{background:#fff3;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#fff;font-size:1.5rem}.weather-header .refresh-btn:hover{background:#ffffff4d;transform:rotate(180deg)}.weather-header .collapse-btn{font-size:1.25rem}.weather-header .collapse-btn:hover{background:#ffffff4d}.weather-error .refresh-btn{background:#fff3;border:none;padding:8px 16px;border-radius:20px;display:flex;align-items:center;gap:6px;cursor:pointer;color:#fff;font-size:.9rem}.weather-main{text-align:center;margin-bottom:16px}.weather-main-content{display:flex;align-items:center;justify-content:center;gap:12px}.weather-icon-large{font-size:4rem;color:#ffffffe6}.weather-status{margin-top:4px;font-size:.95rem;opacity:.9}.temperature{display:flex;align-items:flex-start;justify-content:center;font-family:Noto Sans KR,sans-serif}.temp-icon{font-size:2.5rem;margin-right:-8px}.temp-value{font-size:3.5rem;font-weight:300;line-height:1}.temp-unit{font-size:1.25rem;font-weight:300;margin-top:6px}.weather-details{display:grid;grid-template-columns:1fr 1fr;gap:10px}.weather-item{display:flex;align-items:center;gap:8px;background:#ffffff26;padding:10px;border-radius:10px}.weather-icon{font-size:1.5rem;opacity:.9}.weather-info{display:flex;flex-direction:column}.weather-label{font-size:.7rem;opacity:.8}.weather-value{font-size:.85rem;font-weight:500}.weather-footer{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:16px;font-size:.75rem;opacity:.7}.dark-theme .weather-widget{background:linear-gradient(135deg,#434343,#2c3e50);box-shadow:0 10px 40px #0006}.weather-widget.collapsed{padding:16px 20px}.weather-widget.collapsed .weather-header{margin-bottom:0}.weather-collapsed-info{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.2)}.weather-icon-small{font-size:2rem;color:#ffffffe6}.collapsed-temp{font-size:1.75rem;font-weight:300}.collapsed-status{font-size:.9rem;opacity:.85}@media (max-width: 480px){.weather-widget{padding:20px}.temp-value{font-size:3.5rem}.weather-details{grid-template-columns:1fr}}.weather-sidebar{position:fixed;top:100px;right:20px;z-index:100;width:280px;transition:all .3s ease}.weather-sidebar .weather-widget{max-width:100%;box-shadow:0 8px 32px #667eea40}@media (max-width: 1400px){.weather-sidebar{width:260px;right:10px}}@media (max-width: 1200px){.weather-sidebar{position:static;width:100%;max-width:360px;margin:20px auto;padding:0 20px}}@media (max-width: 768px){.weather-sidebar{max-width:100%;margin:20px 0}.weather-sidebar .weather-widget{border-radius:0}}.dark-theme .weather-sidebar .weather-widget{box-shadow:0 8px 32px #0006}.travel-page{padding-top:72px}.page-hero{height:300px;background:linear-gradient(135deg,#0066cce6,#00b4d8e6),url(https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?w=1920) center/cover;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff}.loading-spinner{font-size:2rem;color:var(--primary-color);animation:spin 1s linear infinite}.district-btn:hover,.dong-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.district-btn.active,.dong-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.dark-theme .district-btn:hover,.dark-theme .dong-btn:hover{border-color:#64b5f6;color:#64b5f6}.dark-theme .district-btn.active,.dark-theme .dong-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.spots-count{margin:30px 0 24px;font-size:.95rem;color:var(--text-secondary)}.spots-count strong{color:var(--primary-color)}.spots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-bottom:40px}.spot-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #00000014;transition:var(--transition);height:100%;display:flex;flex-direction:column}.spot-card:hover{transform:translateY(-8px);box-shadow:0 12px 40px #00000026}.spot-image{position:relative;height:200px;overflow:hidden}.spot-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.spot-card:hover .spot-image img{transform:scale(1.1)}.spot-content{padding:20px;display:flex;flex-direction:column;flex:1}.spot-title{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin-bottom:8px;line-height:1.4}.spot-summary{color:var(--primary-color);font-size:.9rem;font-weight:500;margin-bottom:12px}.spot-info{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.spot-location,.spot-time{display:flex;align-items:center;gap:4px;font-size:.85rem;color:var(--text-secondary)}.spot-location svg,.spot-time svg{color:var(--primary-color)}.spot-address{font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.spot-phone{font-size:.85rem;color:var(--text-secondary);margin-bottom:12px}.spot-link{margin-top:auto;display:inline-flex;align-items:center;color:var(--primary-color);font-size:.9rem;font-weight:500;transition:var(--transition)}.spot-link:hover{color:var(--secondary-color)}.spot-nav-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;padding:.75rem 1rem;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:.9rem;transition:opacity .2s,transform .2s}.spot-nav-btn:hover{opacity:.9;transform:translateY(-2px)}.spot-nav-btn svg{font-size:1rem}.page-btn{padding:10px 20px;background:#fff;border:1px solid var(--primary-color);border-radius:8px;color:var(--primary-color);font-weight:500;transition:var(--transition)}.page-btn:hover:not(:disabled){background:var(--primary-color);color:#fff}.page-num:hover{border-color:var(--primary-color);color:var(--primary-color)}.page-num.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}@media (max-width: 1200px){.spots-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.travel-page{padding-top:64px}.page-hero{height:200px}.page-hero-content h1{font-size:1.75rem}.spots-grid{grid-template-columns:1fr}.pagination{flex-wrap:wrap}.page-numbers{order:-1;width:100%;justify-content:center;margin-bottom:16px}}.spot-image{position:relative;overflow:hidden}.spot-photographer{position:absolute;top:8px;left:8px;background:#0009;color:#fff;padding:4px 10px;border-radius:20px;display:flex;align-items:center;gap:5px;font-size:.75rem}.spot-photographer svg{font-size:.8rem}.spot-image-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);color:#fff;padding:20px 12px 12px;display:flex;align-items:center;gap:6px;font-size:.875rem;opacity:0;transition:opacity .3s ease}.spot-card-wrapper:hover .spot-image-overlay{opacity:1}.spot-card-wrapper{cursor:pointer}.spot-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto;box-sizing:border-box}.spot-modal{background:#fff;border-radius:16px;width:100%;max-width:900px;max-height:90vh;overflow-y:auto;overflow-x:hidden;position:relative}.modal-close-btn{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;border:none;cursor:pointer;z-index:10;transition:background .3s ease}.modal-close-btn:hover{background:#000000b3}.modal-image{position:relative;width:100%;height:400px;background:#000;display:flex;align-items:center;justify-content:center;border-radius:16px 16px 0 0;overflow:hidden}.modal-image img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.modal-content{padding:24px}.modal-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:12px}.modal-summary{color:var(--text-secondary);line-height:1.6;margin-bottom:24px}.modal-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.info-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--bg-secondary, #f8f9fa);border-radius:8px;min-width:0;overflow:hidden}.info-item>div{min-width:0;flex:1;overflow:hidden}.info-item svg,.info-item .icon-text{font-size:1.25rem;color:var(--primary-color);flex-shrink:0;margin-top:2px}.info-item strong{display:block;font-size:.75rem;color:var(--text-secondary);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.info-item p{color:var(--text-primary);font-size:.95rem;word-break:break-word;overflow-wrap:break-word}.modal-website-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--primary-color);color:#fff;border-radius:8px;font-weight:500;text-decoration:none;transition:background .3s ease;margin-bottom:16px}.modal-website-btn:hover{background:var(--primary-hover)}.photo-credit{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-secondary);padding-top:16px;border-top:1px solid #eee}.photo-credit svg{font-size:1rem;flex-shrink:0}.photo-credit-content{display:flex;align-items:center;gap:6px;min-width:0;flex:1;overflow:hidden}.credit-author{flex-shrink:0;white-space:nowrap}.credit-divider{flex-shrink:0;color:var(--text-tertiary, #999)}.credit-source{display:inline-flex;align-items:center;min-width:0;max-width:100%;cursor:pointer;transition:all .2s;overflow:hidden}.source-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px;color:var(--primary-color, #007bff);transition:color .2s}.source-link{display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px;color:var(--primary-color, #007bff);text-decoration:none;transition:color .2s}.source-link:hover,.credit-source:hover .source-text{color:var(--primary-hover, #0056b3);text-decoration:underline}.credit-source.expanded .source-text{white-space:normal;word-break:break-all;overflow:visible;max-width:none}.dark-mode .spot-modal{background:var(--card-bg)}.dark-mode .modal-close-btn{background:#fff3}.dark-mode .info-item,.dark-theme .info-item{background:var(--bg-tertiary, rgba(255, 255, 255, .05))}.dark-mode .photo-credit,.dark-theme .photo-credit{border-color:var(--border-color, rgba(255, 255, 255, .1))}@media (max-width: 768px){.spot-modal-overlay{padding:0;align-items:flex-end}.spot-modal{max-height:95vh;border-radius:16px 16px 0 0;width:100%}.modal-image{height:280px;border-radius:16px 16px 0 0}.modal-content{padding:20px 16px}.modal-title{font-size:1.4rem}.modal-info-grid{grid-template-columns:1fr}}.festival-page{padding-top:72px}.festival-hero{background:linear-gradient(135deg,#9c27b0e6,#673ab7e6),url(https://images.unsplash.com/photo-1492684223066-81342ee5ff30?w=1920) center/cover}.loading-spinner{font-size:2rem;color:#9c27b0;animation:spin 1s linear infinite}.filter-section{margin:24px 0;padding:20px;background:var(--card-bg, #f8f9fa);border-radius:12px;border:1px solid var(--border-color, #e9ecef)}.theme-filters,.place-filters{margin-bottom:16px}.theme-filters:last-child,.place-filters:last-child{margin-bottom:0}.theme-buttons,.place-buttons{display:flex;flex-wrap:wrap;gap:8px}.festival-theme-btn,.place-btn{padding:8px 16px;border:1px solid var(--border-color, #ddd);border-radius:20px;background:var(--card-bg, white);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:.85rem;white-space:nowrap}.festival-theme-btn:hover,.place-btn:hover{border-color:#9c27b0;color:#9c27b0}.festival-theme-btn.active,.place-btn.active{background:#9c27b0;color:#fff;border-color:#9c27b0}.dark-theme .filter-section{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .festival-theme-btn,.dark-theme .place-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-primary)}.dark-theme .festival-theme-btn:hover,.dark-theme .place-btn:hover{border-color:#ba68c8;color:#ba68c8}.dark-theme .festival-theme-btn.active,.dark-theme .place-btn.active{background:#9c27b0;color:#fff;border-color:#9c27b0}.events-count{margin:30px 0 24px;font-size:.95rem;color:var(--text-secondary)}.events-count strong{color:#9c27b0}.festival-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-bottom:40px}.event-card{background:var(--card-bg, white);border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #00000014;transition:var(--transition);display:flex;flex-direction:column}.event-card:hover{transform:translateY(-8px);box-shadow:0 12px 40px #00000026}.event-image{position:relative;height:180px;overflow:hidden}.event-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.event-card:hover .event-image img{transform:scale(1.1)}.event-badges{position:absolute;top:12px;left:12px;right:12px;display:flex;flex-wrap:wrap;gap:6px}.theme-badge{padding:4px 10px;background:#9c27b0;color:#fff;font-size:.75rem;font-weight:600;border-radius:4px}.hot-badge{padding:4px 10px;background:#ff5722;color:#fff;font-size:.75rem;font-weight:600;border-radius:4px}.rec-badge{padding:4px 10px;background:#ffc107;color:#333;font-size:.75rem;font-weight:600;border-radius:4px}.event-content{padding:20px;display:flex;flex-direction:column;flex:1}.event-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:16px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.event-info{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.info-item{display:flex;align-items:flex-start;gap:8px;font-size:.85rem;color:var(--text-secondary)}.info-item svg{color:#9c27b0;flex-shrink:0;margin-top:2px}.event-management{margin-top:auto;font-size:.8rem;color:var(--text-light);padding-top:12px;border-top:1px solid #eee}.page-btn{padding:10px 20px;background:#fff;border:1px solid #9c27b0;border-radius:8px;color:#9c27b0;font-weight:500;transition:var(--transition)}.page-btn:hover:not(:disabled){background:#9c27b0;color:#fff}.page-num:hover{border-color:#9c27b0;color:#9c27b0}.page-num.active{background:#9c27b0;border-color:#9c27b0;color:#fff}.event-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#9c27b0cc;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#fff;font-weight:500;opacity:0;transition:opacity .3s ease}.event-card:hover .event-overlay{opacity:1}.event-card{cursor:pointer}.info-icon{font-size:2rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.festival-modal .modal-content{background:#fff;border-radius:16px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:#ffffffe6;border:none;display:flex;align-items:center;justify-content:center;font-size:1.25rem;cursor:pointer;z-index:10;transition:var(--transition)}.modal-close:hover{background:#fff;transform:scale(1.1)}.modal-header{position:relative}.modal-image{position:relative;height:300px;overflow:hidden;border-radius:16px 16px 0 0}.modal-image img{width:100%;height:100%;object-fit:cover}.modal-badges{position:absolute;bottom:16px;left:16px;display:flex;gap:8px}.modal-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:24px;line-height:1.4}.modal-details{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.detail-row{display:flex;gap:16px}.detail-label{display:flex;align-items:flex-start;gap:8px;min-width:120px;font-weight:600;color:#9c27b0}.detail-label svg{margin-top:2px}.detail-value{flex:1}.detail-value p{color:var(--text-secondary);margin-bottom:4px}.time-info{font-weight:500;color:var(--text-primary)!important}.venue-main{font-weight:600;color:var(--text-primary)!important}.venue-detail{font-size:.9rem}.modal-actions{display:flex;gap:12px;padding-top:20px;border-top:1px solid #eee}.modal-actions .btn-primary{flex:1;padding:14px 24px;background:#9c27b0;color:#fff;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:var(--transition)}.modal-actions .btn-primary:hover{background:#7b1fa2}.modal-actions .btn-secondary{padding:14px 24px;background:#fff;color:var(--text-secondary);border:1px solid #ddd;border-radius:8px;font-weight:500;font-size:1rem;cursor:pointer;transition:var(--transition)}.modal-actions .btn-secondary:hover{border-color:#9c27b0;color:#9c27b0}@media (max-width: 1200px){.festival-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.festival-page{padding-top:64px}.page-hero{height:200px}.page-hero-content h1{font-size:1.75rem}.festival-grid{grid-template-columns:1fr}.pagination{flex-wrap:wrap}.page-numbers{order:-1;width:100%;justify-content:center;margin-bottom:16px}.modal-content{max-height:95vh}.modal-image{height:200px}.modal-title{font-size:1.25rem}.detail-row{flex-direction:column;gap:8px}.detail-label{min-width:auto}.modal-actions{flex-direction:column}}.dark-theme .event-card{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .event-content{background:var(--card-bg)}.dark-theme .event-title{color:var(--text-primary)}.dark-theme .info-item{color:var(--text-secondary)}.dark-theme .event-management{color:var(--text-light);border-top-color:var(--border-color)}.dark-theme .modal-content,.dark-theme .modal-body{background:var(--card-bg)}.dark-theme .modal-title{color:var(--text-primary)}.dark-theme .detail-row{border-bottom-color:var(--border-color)}.dark-theme .detail-label{color:var(--text-secondary)}.dark-theme .detail-value{color:var(--text-primary)}.dark-theme .page-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .page-btn:hover,.dark-theme .page-btn.active{background:#9c27b0;border-color:#9c27b0;color:#fff}.food-page{padding-top:72px}.food-hero{background:linear-gradient(135deg,#ff9a6be6,#ff6b35e6),url(https://images.unsplash.com/photo-1504674900247-0877df9cc836?w=1920) center/cover}.page-hero{height:300px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff}.page-hero-content h1{font-size:2.5rem;font-weight:700;margin-bottom:12px}.page-hero-content p{font-size:1.125rem;opacity:.9}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.loading-spinner{font-size:2rem;color:var(--secondary-color);animation:spin 1s linear infinite}.error-container{color:#e74c3c}.location-filters{margin:24px 0;padding:20px;background:var(--card-bg, #f8f9fa);border-radius:12px;border:1px solid var(--border-color, #e9ecef)}.district-filters,.dong-filters{margin-bottom:16px}.district-filters:last-child,.dong-filters:last-child{margin-bottom:0}.filter-label{display:block;font-weight:600;font-size:.9rem;color:var(--text-primary);margin-bottom:10px}.district-buttons,.dong-buttons{display:flex;flex-wrap:wrap;gap:8px}.district-btn,.dong-btn{padding:8px 16px;border:1px solid var(--border-color, #ddd);border-radius:20px;background:var(--card-bg, white);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:.85rem;white-space:nowrap}.district-btn:hover,.dong-btn:hover{border-color:var(--secondary-color);color:var(--secondary-color)}.district-btn.active,.dong-btn.active{background:var(--secondary-color);color:#fff;border-color:var(--secondary-color)}.dark-theme .location-filters{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .district-btn,.dark-theme .dong-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-primary)}.dark-theme .district-btn:hover,.dark-theme .dong-btn:hover{border-color:#ffab91;color:#ffab91}.dark-theme .district-btn.active,.dark-theme .dong-btn.active{background:var(--secondary-color);color:#fff;border-color:var(--secondary-color)}.food-count{margin:30px 0 24px;font-size:.95rem;color:var(--text-secondary)}.food-count strong{color:var(--secondary-color)}.food-grid-page{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;padding-bottom:40px}.food-card-large{display:flex;background:var(--card-bg, white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition)}.food-card-large:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.food-image-wrapper{position:relative;width:240px;min-height:280px;flex-shrink:0}.food-image-wrapper img{width:100%;height:100%;object-fit:cover}.food-info-wrapper{padding:24px;flex:1;display:flex;flex-direction:column}.food-header-section{margin-bottom:12px}.food-location-badge{display:inline-block;padding:4px 10px;background:#ff6b351a;color:var(--secondary-color);font-size:.8rem;font-weight:500;border-radius:4px;margin-bottom:8px}.food-info-wrapper h3{font-size:1.35rem;font-weight:600;color:var(--text-primary)}.food-summary{color:var(--primary-color);font-size:.95rem;font-weight:500;margin-bottom:12px;line-height:1.5}.food-menu{font-size:.9rem;color:var(--text-secondary);margin-bottom:16px;padding:10px 12px;background:var(--bg-secondary);border-radius:8px}.food-menu strong{color:var(--text-primary)}.food-details{display:flex;flex-direction:column;gap:8px;margin-top:auto}.detail-item{display:flex;align-items:flex-start;gap:8px;font-size:.875rem;color:var(--text-secondary)}.detail-item svg{color:var(--secondary-color);flex-shrink:0;margin-top:2px}.detail-item.holiday{color:#e74c3c;font-size:.8rem}.food-nav-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;padding:.875rem;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;text-decoration:none;border-radius:12px;font-weight:600;transition:opacity .2s,transform .2s}.food-nav-btn:hover{opacity:.9;transform:translateY(-2px)}.food-nav-btn svg{font-size:1.1rem}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;padding:40px 0 80px}.page-btn{padding:10px 20px;background:#fff;border:1px solid var(--secondary-color);border-radius:8px;color:var(--secondary-color);font-weight:500;transition:var(--transition)}.page-btn:hover:not(:disabled){background:var(--secondary-color);color:#fff}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-numbers{display:flex;gap:8px}.page-num{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #ddd;border-radius:8px;color:var(--text-secondary);font-weight:500;transition:var(--transition)}.page-num:hover{border-color:var(--secondary-color);color:var(--secondary-color)}.page-num.active{background:var(--secondary-color);border-color:var(--secondary-color);color:#fff}@media (max-width: 1200px){.food-grid-page{grid-template-columns:1fr}}@media (max-width: 768px){.food-page{padding-top:64px}.page-hero{height:200px}.page-hero-content h1{font-size:1.75rem}.food-card-large{flex-direction:column}.food-image-wrapper{width:100%;height:200px;min-height:auto}.pagination{flex-wrap:wrap}.page-numbers{order:-1;width:100%;justify-content:center;margin-bottom:16px}}.dark-theme .food-card-large{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .food-info-wrapper{background:var(--card-bg)}.dark-theme .food-info-wrapper h3{color:var(--text-primary)}.dark-theme .food-location-badge{background:#ff8c5a26}.dark-theme .food-summary{color:var(--primary-color)}.dark-theme .food-menu{background:var(--bg-tertiary);color:var(--text-secondary)}.dark-theme .food-menu strong{color:var(--text-primary)}.dark-theme .detail-item{color:var(--text-secondary)}.dark-theme .page-btn{background:var(--card-bg);border-color:var(--secondary-color)}.dark-theme .page-btn:hover:not(:disabled){background:var(--secondary-color);color:#fff}.dark-theme .page-num{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .page-num:hover{border-color:var(--secondary-color);color:var(--secondary-color)}.dark-theme .page-num.active{background:var(--secondary-color);border-color:var(--secondary-color);color:#fff}.search-page{min-height:100vh;background:#f8f9fa}.search-hero{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);padding:120px 0 50px;color:#fff}.search-hero h1{font-size:2rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.search-form{display:flex;gap:1rem;max-width:700px;margin:0 auto}.search-input-wrapper{flex:1;position:relative;display:flex;align-items:center}.search-input-wrapper .search-icon{position:absolute;left:1rem;font-size:1.25rem;color:#6c757d}.search-input-wrapper input{width:100%;padding:1rem 3rem;font-size:1.1rem;border:none;border-radius:12px;outline:none;box-shadow:0 4px 20px #00000026}.search-input-wrapper input::placeholder{color:#adb5bd}.clear-btn{position:absolute;right:1rem;background:none;border:none;color:#6c757d;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:color .2s}.clear-btn:hover{color:#343a40}.search-submit{padding:1rem 2rem;font-size:1.1rem;font-weight:600;background:#fff;color:var(--primary-color);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;white-space:nowrap}.search-submit:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 4px 15px #0003}.popular-keywords{margin-top:1.5rem;text-align:center}.popular-label{display:inline-flex;align-items:center;gap:8px;font-size:.95rem;font-weight:500;margin-bottom:1rem;color:#ffffffe6}.popular-label svg{font-size:1.1rem}.popular-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}.popular-tag{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:25px;color:#fff;font-size:.9rem;cursor:pointer;transition:all .2s ease}.popular-tag:hover{background:#ffffff40;transform:translateY(-2px)}.popular-tag .tag-rank{background:#ffffff4d;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.popular-tag .tag-text{font-weight:500}.search-page .container{padding:2rem 1rem}.loading-spinner{font-size:3rem;animation:spin 1s linear infinite;margin-bottom:1rem;color:var(--primary-color)}.search-summary{font-size:1.2rem;color:#343a40;margin-bottom:1.5rem;padding:1rem 1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.search-summary strong{color:var(--primary-color)}.result-count{float:right;color:#6c757d;font-weight:600}.search-tabs{display:flex;gap:.5rem;margin-bottom:2rem;overflow-x:auto;padding-bottom:.5rem}.tab-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fff;border:2px solid #e9ecef;border-radius:25px;cursor:pointer;font-size:.95rem;font-weight:500;color:#495057;transition:all .2s ease;white-space:nowrap}.tab-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.tab-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.tab-count{background:#0000001a;padding:.15rem .5rem;border-radius:10px;font-size:.85rem}.tab-btn.active .tab-count{background:#fff3}.result-section{margin-bottom:2.5rem}.section-title{font-size:1.3rem;font-weight:700;color:#343a40;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.section-title span{color:#6c757d;font-weight:400}.result-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.result-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #00000014;transition:all .3s ease;cursor:pointer}.result-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001f}.result-image{position:relative;height:180px;overflow:hidden}.result-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.result-card:hover .result-image img{transform:scale(1.05)}.result-badge{position:absolute;top:12px;left:12px;padding:.35rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;color:#fff}.result-badge.tour{background:linear-gradient(135deg,#10b981,#059669)}.result-badge.food{background:linear-gradient(135deg,#f59e0b,#d97706)}.result-badge.event{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}.result-content{padding:1.25rem}.result-content h3{font-size:1.1rem;font-weight:600;color:#343a40;margin-bottom:.5rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.result-summary{font-size:.9rem;color:#6c757d;margin-bottom:.75rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.result-menu{font-size:.85rem;color:#f59e0b;margin-bottom:.75rem}.result-meta{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#6c757d;margin-top:.5rem}.result-meta svg{color:var(--primary-color);flex-shrink:0}.see-more-btn{display:block;width:fit-content;margin:1.5rem auto 0;padding:.75rem 2rem;background:transparent;border:2px solid var(--primary-color);color:var(--primary-color);border-radius:25px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease}.see-more-btn:hover{background:var(--primary-color);color:#fff}.no-results{text-align:center;padding:5rem 2rem;background:#fff;border-radius:16px}.no-results-icon{font-size:4rem;margin-bottom:1.5rem}.no-results h3{font-size:1.5rem;color:#343a40;margin-bottom:.75rem}.no-results p{color:#6c757d}.search-placeholder{text-align:center;padding:5rem 2rem;background:#fff;border-radius:16px}.placeholder-icon{font-size:4rem;margin-bottom:1.5rem}.search-placeholder h3{font-size:1.5rem;color:#343a40;margin-bottom:.75rem}.search-placeholder p{color:#6c757d;margin-bottom:1.5rem}.search-suggestions{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem}.search-suggestions span{color:#6c757d;font-size:.9rem}.search-suggestions button{padding:.5rem 1rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:20px;color:#495057;font-size:.9rem;cursor:pointer;transition:all .2s ease}.search-suggestions button:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}@media (max-width: 768px){.search-hero{padding:100px 1rem 40px}.search-hero h1{font-size:1.5rem}.search-form{flex-direction:column}.search-submit{width:100%}.result-grid{grid-template-columns:1fr}.search-tabs{gap:.5rem}.tab-btn{padding:.5rem 1rem;font-size:.85rem}.popular-tags{gap:8px}.popular-tag{padding:6px 12px;font-size:.85rem}}.dark-theme .search-page{background:var(--bg-primary)}.dark-theme .search-hero{background:linear-gradient(135deg,#4338ca,#6d28d9)}.dark-theme .search-input-wrapper input::placeholder{color:var(--text-muted)}.dark-theme .search-input-wrapper .search-icon,.dark-theme .clear-btn{color:var(--text-muted)}.dark-theme .clear-btn:hover{color:var(--text-primary)}.dark-theme .search-submit{background:var(--card-bg);color:var(--primary-color)}.dark-theme .search-submit:hover{background:var(--bg-secondary)}.dark-theme .popular-tag{background:#ffffff1a;border-color:#fff3}.dark-theme .popular-tag:hover{background:#fff3}.dark-theme .search-summary{color:var(--text-primary)}.dark-theme .search-summary strong{color:var(--primary-color)}.dark-theme .result-count{background:var(--card-bg);color:var(--text-primary)}.dark-theme .tab-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .tab-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.dark-theme .tab-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.dark-theme .section-title{color:var(--text-primary)}.dark-theme .section-title span{color:var(--text-muted)}.dark-theme .result-card{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .result-card:hover{box-shadow:0 12px 40px #0000004d}.dark-theme .result-content h3{color:var(--text-primary)}.dark-theme .result-summary{color:var(--text-secondary)}.dark-theme .result-meta{color:var(--text-muted)}.dark-theme .result-link{color:var(--primary-color)}.dark-theme .loading-container{color:var(--text-secondary)}.dark-theme .loading-spinner{color:var(--primary-color)}.dark-theme .no-results{background:var(--card-bg)}.dark-theme .no-results h3{color:var(--text-primary)}.dark-theme .no-results p{color:var(--text-secondary)}.dark-theme .search-suggestions button{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .search-suggestions button:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.parking-page{min-height:100vh;background:#f8f9fa}.parking-hero{background:linear-gradient(135deg,#4f46e5,#7c3aed);padding:120px 0 60px;color:#fff;text-align:center}.parking-hero .hero-content{max-width:800px;margin:0 auto;padding:0 1rem}.parking-hero h1{font-size:2.5rem;font-weight:700;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:.75rem}.parking-hero .hero-icon{font-size:2.5rem}.parking-hero p{font-size:1.2rem;opacity:.9}.parking-page .container{max-width:1200px;margin:0 auto;padding:2rem 1rem}.filter-section{display:flex;gap:.75rem;margin-bottom:2rem;flex-wrap:wrap}.filter-btn{padding:.75rem 1.5rem;border:2px solid #e9ecef;background:#fff;border-radius:25px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.filter-btn:hover{border-color:#4f46e5;color:#4f46e5}.filter-btn.active{background:#4f46e5;border-color:#4f46e5;color:#fff}.district-select{padding:.75rem 1.5rem;border:2px solid #e9ecef;background:#fff;border-radius:25px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;outline:none;min-width:140px}.district-select:hover{border-color:#4f46e5}.district-select:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.stats-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:16px;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 12px #0000000f}.stat-icon{font-size:2.5rem;color:#4f46e5}.stat-icon.public{color:#10b981}.stat-icon.private{color:#f59e0b}.stat-info{display:flex;flex-direction:column}.stat-number{font-size:2rem;font-weight:700;color:#1f2937}.stat-label{font-size:.9rem;color:#6b7280}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 0;color:#6c757d}.loading-spinner{font-size:3rem;animation:spin 1s linear infinite;margin-bottom:1rem;color:#4f46e5}.error-container{text-align:center;padding:3rem;background:#fff;border-radius:16px}.error-container p{color:#ef4444;margin-bottom:1rem}.error-container button{padding:.75rem 2rem;background:#4f46e5;color:#fff;border:none;border-radius:8px;cursor:pointer}.parking-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.parking-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #00000014;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column}.parking-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001f}.parking-header{padding:1.25rem;border-bottom:1px solid #f3f4f6}.parking-type{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;margin-bottom:.5rem;margin-right:.5rem}.parking-category{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500;background:#e5e7eb;color:#374151;margin-bottom:.5rem}.parking-type.public{background:#d1fae5;color:#065f46}.charge-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;margin-bottom:.5rem}.charge-badge.free{background:#d1fae5;color:#065f46}.charge-badge.paid{background:#fee2e2;color:#991b1b}.parking-header h3{font-size:1.1rem;font-weight:600;color:#1f2937;line-height:1.4}.parking-body{padding:1.25rem;flex:1}.parking-info{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem;font-size:.9rem;color:#4b5563}.parking-info:last-child{margin-bottom:0}.info-icon{color:#4f46e5;flex-shrink:0;margin-top:2px}.parking-info.fee{background:#f3f4f6;padding:.75rem;border-radius:8px;margin-top:.5rem}.parking-info strong{color:#4f46e5}.parking-nav-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;text-decoration:none;font-weight:600;transition:opacity .2s}.parking-nav-btn:hover{opacity:.9}.no-data{text-align:center;padding:5rem 2rem;background:#fff;border-radius:16px}.no-data-icon{font-size:4rem;color:#d1d5db;margin-bottom:1rem}.no-data p{color:#6b7280;font-size:1.1rem}@media (max-width: 768px){.parking-hero h1{font-size:1.75rem}.parking-hero p{font-size:1rem}.parking-grid,.stats-section{grid-template-columns:1fr}}.dark-theme .parking-page{background:var(--bg-primary)}.dark-theme .filter-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-primary)}.dark-theme .filter-btn:hover{border-color:#818cf8;color:#818cf8}.dark-theme .filter-btn.active{background:#6366f1;border-color:#6366f1;color:#fff}.dark-theme .district-select{background:var(--card-bg);border-color:var(--border-color);color:var(--text-primary)}.dark-theme .district-select:hover,.dark-theme .district-select:focus{border-color:#818cf8}.dark-theme .district-select option{background:var(--card-bg);color:var(--text-primary)}.dark-theme .stat-card{background:var(--card-bg);box-shadow:0 2px 12px #0000004d}.dark-theme .stat-number{color:var(--text-primary)}.dark-theme .stat-label,.dark-theme .loading-container{color:var(--text-secondary)}.dark-theme .error-container{background:var(--card-bg)}.dark-theme .parking-card{background:var(--card-bg);box-shadow:0 2px 12px #0000004d}.dark-theme .parking-card:hover{box-shadow:0 8px 25px #0006}.dark-theme .parking-header{border-bottom-color:var(--border-color)}.dark-theme .parking-category{background:#374151;color:#d1d5db}.dark-theme .parking-header h3{color:var(--text-primary)}.dark-theme .parking-info{color:var(--text-secondary)}.dark-theme .parking-info.fee{background:#4f46e51a}.dark-theme .no-data{background:var(--card-bg)}.dark-theme .no-data p{color:var(--text-secondary)}.parking-page .pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding:1rem}.parking-page .pagination button{padding:.75rem 1.5rem;border:2px solid #4f46e5;background:#fff;color:#4f46e5;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.parking-page .pagination button:hover:not(:disabled){background:#4f46e5;color:#fff}.parking-page .pagination button:disabled{border-color:#d1d5db;color:#9ca3af;cursor:not-allowed}.parking-page .pagination span{font-weight:600;color:#374151;font-size:1rem}.dark-theme .parking-page .pagination button{background:var(--card-bg);border-color:#818cf8;color:#818cf8}.dark-theme .parking-page .pagination button:hover:not(:disabled){background:#6366f1;color:#fff}.dark-theme .parking-page .pagination button:disabled{border-color:#4b5563;color:#6b7280;background:var(--card-bg)}.dark-theme .parking-page .pagination span{color:var(--text-primary)}.map-page{min-height:100vh;display:flex;flex-direction:column;padding-top:70px}.map-tabs{display:flex;background:var(--bg-primary, white);border-bottom:1px solid var(--border-color, #e5e7eb);padding:0 1rem}.map-tab{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;font-size:1rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease}.map-tab:hover{color:var(--primary-color)}.map-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.tab-icon{font-size:1.25rem}.map-filter-section{background:var(--bg-primary, white);border-bottom:1px solid var(--border-color, #e5e7eb);padding:.75rem 1rem}.filter-group{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.filter-group.dong-group{margin-top:.5rem;padding-top:.5rem;border-top:1px dashed #e5e7eb}.filter-label{font-size:.85rem;font-weight:600;color:#374151;min-width:40px}.filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{padding:.4rem .75rem;border:1px solid #e5e7eb;border-radius:20px;background:#fff;font-size:.85rem;color:#6b7280;cursor:pointer;transition:all .2s ease}.filter-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.filter-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.map-container{flex:1;display:flex;position:relative;min-height:calc(100vh - 170px)}.map-sidebar{width:380px;background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;position:absolute;left:0;top:0;bottom:0;z-index:100;transform:translate(-100%);transition:transform .3s ease}.map-sidebar.open{transform:translate(0)}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.sidebar-header h3{font-size:1.1rem;font-weight:600;color:#1f2937;display:flex;align-items:center;gap:.5rem}.sidebar-header .count{font-weight:400;color:#6b7280}.close-btn{background:none;border:none;font-size:1.25rem;color:#6b7280;cursor:pointer;padding:.5rem}.close-btn:hover{color:#1f2937}.place-list{flex:1;overflow-y:auto}.list-loading{display:flex;justify-content:center;align-items:center;padding:3rem}.spinner{font-size:2rem;color:var(--primary-color);animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.place-item{padding:1rem 1.25rem;border-bottom:1px solid #f3f4f6;cursor:pointer;transition:background .2s ease}.place-item:hover{background:#f9fafb}.place-item.selected{background:#eff6ff;border-left:3px solid var(--primary-color)}.place-item h4{font-size:.95rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.place-address{display:flex;align-items:flex-start;gap:.5rem;font-size:.85rem;color:#6b7280;line-height:1.4}.place-address svg{flex-shrink:0;margin-top:2px}.place-menu,.place-capacity{font-size:.85rem;color:#4b5563;margin-top:.35rem}.map-area{flex:1;position:relative;background:#e5e7eb;min-height:calc(100vh - 170px)}.kakao-map{width:100%;height:100%;min-height:calc(100vh - 170px)}.map-placeholder{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;color:#6b7280}.map-placeholder .spinner{font-size:3rem;margin-bottom:1rem}.map-placeholder p{font-size:1.1rem;margin-bottom:.5rem}.map-notice{font-size:.9rem!important;color:#9ca3af;max-width:400px;text-align:center}.list-toggle{position:absolute;top:1rem;left:1rem;display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fff;border:none;border-radius:8px;box-shadow:0 2px 8px #00000026;font-size:.9rem;font-weight:500;cursor:pointer;z-index:50;transition:all .2s ease}.list-toggle:hover{background:#f3f4f6}.place-detail{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);width:calc(100% - 2rem);max-width:500px;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000026;padding:1.5rem;z-index:100}.close-detail{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.25rem;color:#6b7280;cursor:pointer}.place-detail h3{font-size:1.25rem;font-weight:700;color:#1f2937;margin-bottom:.75rem;padding-right:2rem}.detail-summary{font-size:.9rem;color:#4b5563;line-height:1.5;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.detail-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.info-row{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#4b5563}.info-row svg{color:var(--primary-color);flex-shrink:0}.info-row.fee{background:#fef3c7;padding:.5rem .75rem;border-radius:8px;color:#92400e}.nav-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;text-decoration:none;border-radius:12px;font-weight:600;transition:opacity .2s ease}.nav-btn:hover{opacity:.9}@media (max-width: 768px){.map-sidebar{width:100%;height:50%;top:auto;bottom:0;transform:translateY(100%);border-right:none;border-top:1px solid #e5e7eb;border-radius:16px 16px 0 0}.map-sidebar.open{transform:translateY(0)}.map-tabs{overflow-x:auto;white-space:nowrap;padding:0 .5rem}.map-tab{padding:.75rem 1rem;font-size:.9rem}.place-detail{bottom:0;left:0;right:0;transform:none;width:100%;max-width:none;border-radius:16px 16px 0 0;max-height:60vh;overflow-y:auto}}.dark-theme .map-tabs{background:var(--bg-secondary);border-bottom-color:var(--border-color)}.dark-theme .map-tab{color:var(--text-secondary)}.dark-theme .map-tab:hover,.dark-theme .map-tab.active{color:var(--primary-color)}.dark-theme .map-filter-select{background:var(--card-bg);border-color:var(--border-color);color:var(--text-primary)}.dark-theme .map-filter-select:hover,.dark-theme .map-filter-select:focus{border-color:#818cf8}.dark-theme .map-filter-select option{background:var(--card-bg);color:var(--text-primary)}.dark-theme .map-sidebar{background:var(--bg-primary);border-right-color:var(--border-color)}.dark-theme .sidebar-header{border-bottom-color:var(--border-color)}.dark-theme .sidebar-header h3{color:var(--text-primary)}.dark-theme .sidebar-header .count,.dark-theme .close-btn{color:var(--text-secondary)}.dark-theme .close-btn:hover{color:var(--text-primary)}.dark-theme .place-item{border-bottom-color:var(--border-color)}.dark-theme .place-item:hover,.dark-theme .place-item.selected{background:var(--bg-tertiary)}.dark-theme .place-item h4{color:var(--text-primary)}.dark-theme .place-info{color:var(--text-secondary)}.dark-theme .place-detail{background:var(--card-bg);box-shadow:0 -4px 30px #0000004d}.dark-theme .place-detail h3{color:var(--text-primary)}.dark-theme .detail-summary,.dark-theme .detail-info,.dark-theme .info-row{color:var(--text-secondary)}.dark-theme .info-row svg{color:#818cf8}.dark-theme .info-row.fee{background:#fbbf2433;color:#fbbf24}.dark-theme .close-detail{color:var(--text-secondary)}.dark-theme .close-detail:hover{color:var(--text-primary)}.culture-page{min-height:100vh;padding-top:80px}.culture-hero{background:linear-gradient(135deg,#6b5b95,#9b59b6);color:#fff;padding:60px 0;text-align:center}.culture-hero h1{font-size:2.5rem;margin-bottom:10px}.culture-hero p{font-size:1.1rem;opacity:.9}.culture-filters{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin:30px 0}.culture-filters .filter-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--card-bg, white);border:2px solid var(--border-color, #e0e0e0);border-radius:25px;cursor:pointer;transition:all .3s ease;font-size:.95rem;color:var(--text-secondary, #666)}.culture-filters .filter-btn:hover{border-color:#6b5b95;color:#6b5b95}.culture-filters .filter-btn.active{background:#6b5b95;border-color:#6b5b95;color:#fff}.culture-filters .filter-btn svg{font-size:1.2rem}.culture-page .location-filters{display:flex;flex-direction:column;gap:12px;align-items:center;margin-bottom:20px}.culture-page .district-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.culture-page .district-btn{padding:8px 16px;border:2px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .3s ease;color:var(--text-secondary, #666)}.culture-page .district-btn:hover{border-color:#6b5b95;color:#6b5b95}.culture-page .district-btn.active{background:#6b5b95;border-color:#6b5b95;color:#fff}.culture-page .dong-buttons{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;max-width:800px}.culture-page .dong-btn{padding:6px 12px;border:1px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:15px;font-size:.85rem;cursor:pointer;transition:all .3s ease;color:var(--text-secondary, #666)}.culture-page .dong-btn:hover{border-color:#9b59b6;color:#9b59b6}.culture-page .dong-btn.active{background:#9b59b6;border-color:#9b59b6;color:#fff}.culture-page .location-select{padding:10px 20px;border:2px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:25px;font-size:.95rem;cursor:pointer;transition:all .3s ease;color:var(--text-primary, #333);outline:none;min-width:140px}.culture-page .location-select:hover{border-color:#6b5b95}.culture-page .location-select:focus{border-color:#6b5b95;box-shadow:0 0 0 3px #6b5b951a}.culture-summary{text-align:center;color:var(--text-secondary, #666);margin-bottom:30px;font-size:.95rem}.culture-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;margin-bottom:40px}.culture-card{background:var(--card-bg, white);border-radius:16px;padding:20px;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000014;transition:all .3s ease;border:1px solid var(--border-color, #f0f0f0);overflow:hidden}.culture-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #6b5b9526}.culture-card-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.culture-icon{width:50px;height:50px;background:linear-gradient(135deg,#6b5b95,#9b59b6);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.culture-icon svg{font-size:24px;color:#fff}.culture-title{flex:1;min-width:0}.culture-title h3{font-size:1.1rem;color:var(--text-primary, #222);margin:0 0 4px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.culture-title .facility-type{display:inline-block;padding:2px 8px;background:#6b5b951a;color:#6b5b95;border-radius:10px;font-size:.75rem;margin:0}.facility-info{flex:1;padding:12px 0;border-top:1px solid var(--border-color, #f0f0f0);border-bottom:1px solid var(--border-color, #f0f0f0);margin-bottom:12px}.facility-info .info-item{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;font-size:.9rem;color:var(--text-secondary, #666)}.facility-info .info-item:last-child{margin-bottom:0}.facility-info .info-item svg{flex-shrink:0;margin-top:3px;color:#6b5b95}.navigate-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;background:#6b5b95;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .3s ease;width:100%}.navigate-btn:hover{background:#5a4a84}.culture-page .loading,.culture-page .no-results{text-align:center;padding:60px 0;color:var(--text-secondary, #666);font-size:1.1rem}.culture-page .pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin:40px 0}.culture-page .pagination button{padding:10px 24px;background:var(--card-bg, white);border:2px solid #6B5B95;color:#6b5b95;border-radius:8px;cursor:pointer;transition:all .3s ease}.culture-page .pagination button:hover:not(:disabled){background:#6b5b95;color:#fff}.culture-page .pagination button:disabled{opacity:.5;cursor:not-allowed}.culture-page .pagination span{color:var(--text-secondary, #666)}.dark-theme .culture-card{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .facility-type{background:#6b5b9533}.dark-theme .culture-page .location-select{background:var(--card-bg);border-color:var(--border-color);color:var(--text-primary)}.dark-theme .culture-page .district-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .culture-page .district-btn.active{background:#6b5b95;border-color:#6b5b95;color:#fff}.dark-theme .culture-page .dong-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .culture-page .dong-btn.active{background:#9b59b6;border-color:#9b59b6;color:#fff}@media (max-width: 768px){.culture-hero h1{font-size:2rem}.culture-grid{grid-template-columns:1fr}.culture-card{flex-direction:column;align-items:center;text-align:center}.facility-info .info-item{justify-content:center}.navigate-btn{width:100%;justify-content:center}}.medical-page{min-height:100vh;padding-top:80px}.medical-hero{background:linear-gradient(135deg,#00bcd4,#00acc1);color:#fff;padding:60px 0;text-align:center}.medical-hero h1{font-size:2.5rem;margin-bottom:10px}.medical-hero p{font-size:1.1rem;opacity:.9}.medical-search{display:flex;align-items:center;gap:12px;max-width:500px;margin:30px auto;padding:12px 20px;background:var(--card-bg, white);border:2px solid var(--border-color, #e0e0e0);border-radius:30px;transition:all .3s ease}.medical-search:focus-within{border-color:#00bcd4;box-shadow:0 4px 20px #00bcd426}.medical-search svg{color:#00bcd4;font-size:1.2rem}.medical-search input{flex:1;border:none;background:transparent;font-size:1rem;color:var(--text-primary, #333);outline:none}.medical-filters{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin:20px 0}.medical-filters .filter-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--card-bg, white);border:2px solid var(--border-color, #e0e0e0);border-radius:25px;cursor:pointer;transition:all .3s ease;font-size:.95rem;color:var(--text-secondary, #666)}.medical-filters .filter-btn:hover{border-color:#00bcd4;color:#00bcd4}.medical-filters .filter-btn.active{background:#00bcd4;border-color:#00bcd4;color:#fff}.medical-page .location-filters{display:flex;flex-direction:column;gap:12px;align-items:center;margin-bottom:20px}.medical-page .district-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.medical-page .district-btn{padding:8px 16px;border:2px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .3s ease;color:var(--text-secondary, #666)}.medical-page .district-btn:hover{border-color:#00bcd4;color:#00bcd4}.medical-page .district-btn.active{background:#00bcd4;border-color:#00bcd4;color:#fff}.medical-page .dong-buttons{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;max-width:800px}.medical-page .dong-btn{padding:6px 12px;border:1px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:15px;font-size:.85rem;cursor:pointer;transition:all .3s ease;color:var(--text-secondary, #666)}.medical-page .dong-btn:hover{border-color:#00acc1;color:#00acc1}.medical-page .dong-btn.active{background:#00acc1;border-color:#00acc1;color:#fff}.medical-page .location-select{padding:10px 20px;border:2px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:25px;font-size:.95rem;cursor:pointer;transition:all .3s ease;color:var(--text-primary, #333);outline:none;min-width:140px}.medical-page .location-select:hover{border-color:#00bcd4}.medical-page .location-select:focus{border-color:#00bcd4;box-shadow:0 0 0 3px #00bcd41a}.medical-summary{text-align:center;color:var(--text-secondary, #666);margin-bottom:30px;font-size:.95rem}.medical-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-bottom:40px}.medical-card{background:var(--card-bg, white);border-radius:16px;padding:20px;box-shadow:0 4px 20px #00000014;transition:all .3s ease;border:1px solid var(--border-color, #f0f0f0)}.medical-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #00bcd426}.medical-card-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px}.medical-icon{width:50px;height:50px;background:linear-gradient(135deg,#00bcd4,#00acc1);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.medical-icon svg{font-size:24px;color:#fff}.medical-title h3{font-size:1.05rem;color:var(--text-primary, #222);margin-bottom:6px;line-height:1.4}.medical-type{display:inline-block;padding:3px 10px;background:#00bcd41a;color:#00acc1;border-radius:12px;font-size:.8rem}.medical-info{margin-bottom:16px}.medical-info .info-item{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;font-size:.9rem;color:var(--text-secondary, #666)}.medical-info .info-item svg{flex-shrink:0;margin-top:3px;color:#00bcd4}.medical-info .info-item a{color:#00acc1;text-decoration:none}.medical-info .info-item a:hover{text-decoration:underline}.medical-card .navigate-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;background:#00bcd4;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .3s ease}.medical-card .navigate-btn:hover{background:#00acc1}.medical-page .loading,.medical-page .no-results{text-align:center;padding:60px 0;color:var(--text-secondary, #666);font-size:1.1rem}.medical-page .pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin:40px 0}.medical-page .pagination button{padding:10px 24px;background:var(--card-bg, white);border:2px solid #00BCD4;color:#00bcd4;border-radius:8px;cursor:pointer;transition:all .3s ease}.medical-page .pagination button:hover:not(:disabled){background:#00bcd4;color:#fff}.medical-page .pagination button:disabled{opacity:.5;cursor:not-allowed}.dark-theme .medical-card,.dark-theme .medical-search{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .medical-type{background:#00bcd433}.dark-theme .medical-page .location-select{background:var(--card-bg);border-color:var(--border-color);color:var(--text-primary)}.dark-theme .medical-page .district-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .medical-page .district-btn.active{background:#00bcd4;border-color:#00bcd4;color:#fff}.dark-theme .medical-page .dong-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .medical-page .dong-btn.active{background:#00acc1;border-color:#00acc1;color:#fff}@media (max-width: 768px){.medical-hero h1{font-size:2rem}.medical-grid{grid-template-columns:1fr}}.shopping-page{min-height:100vh;padding-top:80px}.shopping-hero{background:linear-gradient(135deg,#e91e63,#f06292);color:#fff;padding:60px 0;text-align:center}.shopping-hero h1{font-size:2.5rem;margin-bottom:10px}.shopping-hero p{font-size:1.1rem;opacity:.9}.shopping-search{display:flex;align-items:center;gap:12px;max-width:500px;margin:30px auto 20px;padding:12px 20px;background:var(--card-bg, white);border:2px solid var(--border-color, #e0e0e0);border-radius:30px;transition:all .3s ease}.shopping-search:focus-within{border-color:#e91e63;box-shadow:0 4px 20px #e91e6326}.shopping-search svg{color:#e91e63;font-size:1.2rem}.shopping-search input{flex:1;border:none;background:transparent;font-size:1rem;color:var(--text-primary, #333);outline:none}.shopping-page .location-filters{display:flex;flex-direction:column;gap:12px;align-items:center;margin-bottom:20px}.shopping-page .district-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.shopping-page .district-btn{padding:8px 16px;border:2px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .3s ease;color:var(--text-secondary, #666)}.shopping-page .district-btn:hover{border-color:#e91e63;color:#e91e63}.shopping-page .district-btn.active{background:#e91e63;border-color:#e91e63;color:#fff}.shopping-page .dong-buttons{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;max-width:800px}.shopping-page .dong-btn{padding:6px 12px;border:1px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:15px;font-size:.85rem;cursor:pointer;transition:all .3s ease;color:var(--text-secondary, #666)}.shopping-page .dong-btn:hover{border-color:#f06292;color:#f06292}.shopping-page .dong-btn.active{background:#f06292;border-color:#f06292;color:#fff}.shopping-page .location-select{padding:10px 20px;border:2px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:25px;font-size:.95rem;cursor:pointer;transition:all .3s ease;color:var(--text-primary, #333);outline:none;min-width:140px}.shopping-page .location-select:hover{border-color:#e91e63}.shopping-page .location-select:focus{border-color:#e91e63;box-shadow:0 0 0 3px #e91e631a}.shopping-summary{text-align:center;color:var(--text-secondary, #666);margin:30px 0;font-size:.95rem}.shopping-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;margin-bottom:40px}.shopping-card{background:var(--card-bg, white);border-radius:16px;padding:20px;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000014;transition:all .3s ease;border:1px solid var(--border-color, #f0f0f0);overflow:hidden}.shopping-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #e91e6326}.shopping-card-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.shopping-icon{width:50px;height:50px;background:linear-gradient(135deg,#e91e63,#f06292);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.shopping-icon svg{font-size:24px;color:#fff}.shopping-title{flex:1;min-width:0}.shopping-title h3{font-size:1.1rem;color:var(--text-primary, #222);margin:0 0 4px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shop-time{display:inline-block;padding:2px 8px;background:#e91e631a;color:#e91e63;border-radius:10px;font-size:.75rem}.shop-info{flex:1;padding:12px 0;border-top:1px solid var(--border-color, #f0f0f0);border-bottom:1px solid var(--border-color, #f0f0f0);margin-bottom:12px}.shop-info .info-item{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;font-size:.9rem;color:var(--text-secondary, #666)}.shop-info .info-item:last-child{margin-bottom:0}.shop-info .info-item svg{flex-shrink:0;margin-top:3px;color:#e91e63}.shop-info .info-item a{color:#e91e63;text-decoration:none}.shop-info .info-item a:hover{text-decoration:underline}.shop-desc{font-size:.85rem;color:var(--text-secondary, #888);line-height:1.5;margin-top:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.shopping-card .navigate-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;background:#e91e63;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .3s ease;width:100%}.shopping-card .navigate-btn:hover{background:#c2185b}.shopping-page .loading,.shopping-page .no-results{text-align:center;padding:60px 0;color:var(--text-secondary, #666);font-size:1.1rem}.shopping-page .pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin:40px 0}.shopping-page .pagination button{padding:10px 24px;background:var(--card-bg, white);border:2px solid #E91E63;color:#e91e63;border-radius:8px;cursor:pointer;transition:all .3s ease}.shopping-page .pagination button:hover:not(:disabled){background:#e91e63;color:#fff}.shopping-page .pagination button:disabled{opacity:.5;cursor:not-allowed}.shopping-page .pagination span{color:var(--text-secondary, #666)}.dark-theme .shopping-card{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .shop-type{background:#e91e6333}.dark-theme .shopping-search{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .shopping-page .location-select{background:var(--card-bg);border-color:var(--border-color);color:var(--text-primary)}.dark-theme .shopping-page .district-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .shopping-page .district-btn.active{background:#e91e63;border-color:#e91e63;color:#fff}.dark-theme .shopping-page .dong-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .shopping-page .dong-btn.active{background:#f06292;border-color:#f06292;color:#fff}@media (max-width: 768px){.shopping-hero h1{font-size:2rem}.shopping-grid{grid-template-columns:1fr}.shopping-card{flex-direction:column;align-items:center;text-align:center}.shop-info .info-item{justify-content:center}.shopping-card .navigate-btn{width:100%;justify-content:center}}.accommodation-page{min-height:100vh;padding-top:80px}.accommodation-hero{background:linear-gradient(135deg,#ff9800,#ffb74d);color:#fff;padding:60px 0;text-align:center}.accommodation-hero h1{font-size:2.5rem;margin-bottom:10px}.accommodation-hero p{font-size:1.1rem;opacity:.9}.accommodation-search{display:flex;align-items:center;gap:12px;max-width:500px;margin:30px auto 20px;padding:12px 20px;background:var(--card-bg, white);border:2px solid var(--border-color, #e0e0e0);border-radius:30px;transition:all .3s ease}.accommodation-search:focus-within{border-color:#ff9800;box-shadow:0 4px 20px #ff980026}.accommodation-search svg{color:#ff9800;font-size:1.2rem}.accommodation-search input{flex:1;border:none;background:transparent;font-size:1rem;color:var(--text-primary, #333);outline:none}.accommodation-filters{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin:30px 0}.accommodation-filters .filter-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--card-bg, white);border:2px solid var(--border-color, #e0e0e0);border-radius:25px;cursor:pointer;transition:all .3s ease;font-size:.95rem;color:var(--text-secondary, #666)}.accommodation-filters .filter-btn:hover{border-color:#ff9800;color:#ff9800}.accommodation-filters .filter-btn.active{background:#ff9800;border-color:#ff9800;color:#fff}.accommodation-filters .filter-btn svg{font-size:1.2rem}.accommodation-page .location-filters{display:flex;flex-direction:column;gap:12px;align-items:center;margin-bottom:20px}.accommodation-page .district-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.accommodation-page .district-btn{padding:8px 16px;border:2px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .3s ease;color:var(--text-secondary, #666)}.accommodation-page .district-btn:hover{border-color:#ff9800;color:#ff9800}.accommodation-page .district-btn.active{background:#ff9800;border-color:#ff9800;color:#fff}.accommodation-page .dong-buttons{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;max-width:800px}.accommodation-page .dong-btn{padding:6px 12px;border:1px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:15px;font-size:.85rem;cursor:pointer;transition:all .3s ease;color:var(--text-secondary, #666)}.accommodation-page .dong-btn:hover{border-color:#ffb74d;color:#ffb74d}.accommodation-page .dong-btn.active{background:#ffb74d;border-color:#ffb74d;color:#fff}.accommodation-page .location-select{padding:10px 20px;border:2px solid var(--border-color, #e0e0e0);background:var(--card-bg, white);border-radius:25px;font-size:.95rem;cursor:pointer;transition:all .3s ease;color:var(--text-primary, #333);outline:none;min-width:140px}.accommodation-page .location-select:hover{border-color:#ff9800}.accommodation-page .location-select:focus{border-color:#ff9800;box-shadow:0 0 0 3px #ff98001a}.accommodation-summary{text-align:center;color:var(--text-secondary, #666);margin-bottom:30px;font-size:.95rem}.accommodation-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-bottom:40px}.accommodation-card{background:var(--card-bg, white);border-radius:16px;padding:20px;box-shadow:0 4px 20px #00000014;transition:all .3s ease;border:1px solid var(--border-color, #f0f0f0)}.accommodation-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #ff980026}.accommodation-card-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px}.accommodation-icon{width:50px;height:50px;background:linear-gradient(135deg,#ff9800,#ffb74d);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.accommodation-icon svg{font-size:24px;color:#fff}.accommodation-title h3{font-size:1.05rem;color:var(--text-primary, #222);margin-bottom:6px;line-height:1.4}.room-type{display:inline-block;padding:3px 10px;background:#ff98001a;color:#f57c00;border-radius:12px;font-size:.8rem}.accommodation-info{margin-bottom:16px}.accommodation-info .info-item{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;font-size:.9rem;color:var(--text-secondary, #666)}.accommodation-info .info-item svg{flex-shrink:0;margin-top:3px;color:#ff9800}.accommodation-info .info-item a{color:#f57c00;text-decoration:none}.accommodation-info .info-item a:hover{text-decoration:underline}.room-desc{font-size:.85rem;color:var(--text-secondary, #888);line-height:1.5;margin-top:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.accommodation-card .navigate-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;background:#ff9800;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .3s ease}.accommodation-card .navigate-btn:hover{background:#f57c00}.accommodation-page .loading,.accommodation-page .no-results{text-align:center;padding:60px 0;color:var(--text-secondary, #666);font-size:1.1rem}.accommodation-page .pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin:40px 0}.accommodation-page .pagination button{padding:10px 24px;background:var(--card-bg, white);border:2px solid #FF9800;color:#ff9800;border-radius:8px;cursor:pointer;transition:all .3s ease}.accommodation-page .pagination button:hover:not(:disabled){background:#ff9800;color:#fff}.accommodation-page .pagination button:disabled{opacity:.5;cursor:not-allowed}.accommodation-page .pagination span{color:var(--text-secondary, #666)}.dark-theme .accommodation-card{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .room-type{background:#ff980033}.dark-theme .accommodation-search{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .accommodation-page .location-select{background:var(--card-bg);border-color:var(--border-color);color:var(--text-primary)}.dark-theme .accommodation-page .district-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .accommodation-page .district-btn.active{background:#ff9800;border-color:#ff9800;color:#fff}.dark-theme .accommodation-page .dong-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .accommodation-page .dong-btn.active{background:#ffb74d;border-color:#ffb74d;color:#fff}@media (max-width: 768px){.accommodation-hero h1{font-size:2rem}.accommodation-grid{grid-template-columns:1fr}}.admin-page{min-height:100vh;background:#f5f7fa;display:flex}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;width:100%}.loading-spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#1976d2;border-radius:50%;animation:spin 1s linear infinite}.admin-login-container{display:flex;align-items:center;justify-content:center;width:100%;padding:20px}.admin-login-card{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;padding:40px;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:1.75rem;color:#1a1a2e;margin-bottom:8px}.login-header p{color:#666;font-size:.9rem}.form-group{margin-bottom:20px;padding:16px;background:#f8fafc;border-radius:12px}.form-group label{display:block;font-weight:600;margin-bottom:8px;color:#333;font-size:.9rem}.form-group input{width:100%;padding:14px 16px;border:2px solid #e0e0e0;border-radius:10px;font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.login-error{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.9rem}.login-btn{width:100%;padding:14px;background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.login-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #1976d24d}.login-btn:disabled{background:#bdbdbd;cursor:not-allowed;transform:none}.login-footer{margin-top:24px;text-align:center}.back-btn{display:inline-flex;align-items:center;gap:8px;background:none;border:none;color:#666;cursor:pointer;font-size:.9rem;padding:8px 16px;border-radius:8px;transition:all .2s}.back-btn:hover{background:#f5f5f5;color:#1976d2}.admin-sidebar{width:260px;background:#1a1a2e;color:#fff;display:flex;flex-direction:column;transition:width .3s ease;position:fixed;height:100vh;z-index:100;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}.admin-sidebar::-webkit-scrollbar{display:none}.admin-sidebar.closed{width:70px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{font-size:1.25rem;white-space:nowrap}.admin-sidebar.closed .sidebar-header h2{display:none}.sidebar-toggle{background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:8px;transition:background .2s}.sidebar-toggle:hover{background:#ffffff1a}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.sidebar-nav .nav-section-title{font-size:.75rem;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.05em;padding:16px 16px 8px;margin-top:8px}.sidebar-nav .nav-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:none;border:none;color:#ffffffb3;cursor:pointer;border-radius:10px;transition:all .2s;font-size:.95rem;text-align:left;margin-bottom:4px}.sidebar-nav .nav-item:hover{background:#ffffff1a;color:#fff}.sidebar-nav .nav-item.active{background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff}.sidebar-nav .nav-item svg{font-size:1.25rem;flex-shrink:0}.admin-sidebar.closed .sidebar-nav .nav-item span{display:none}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1)}.user-info{margin-bottom:12px}.user-email{font-size:.85rem;color:#ffffffb3;word-break:break-all}.admin-sidebar.closed .user-email{display:none}.logout-btn{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:#f4433633;border:none;color:#f44336;cursor:pointer;border-radius:10px;transition:all .2s;font-size:.95rem}.logout-btn:hover{background:#f44336;color:#fff}.admin-sidebar.closed .logout-btn span{display:none}.admin-main{flex:1;margin-left:260px;transition:margin-left .3s ease;min-height:100vh;display:flex;flex-direction:column}.admin-main.expanded{margin-left:70px}.admin-header{display:flex;align-items:center;gap:16px;padding:20px 32px;background:#fff;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:50}.mobile-menu-btn{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:8px}.admin-header h1{font-size:1.5rem;color:#1a1a2e;font-weight:600}.admin-content{flex:1;padding:32px}.api-fetch-section{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#e0f2fe,#dbeafe);border:1px solid #93c5fd;border-radius:12px;padding:16px 24px;margin-bottom:20px}.api-fetch-info{display:flex;flex-direction:column;gap:4px}.api-fetch-label{font-weight:600;font-size:.95rem;color:#1e40af}.api-fetch-desc{font-size:.82rem;color:#3b82f6}.api-fetch-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.api-fetch-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.api-fetch-btn:disabled{opacity:.7;cursor:not-allowed}.api-fetch-btn.loaded{background:linear-gradient(135deg,#10b981,#059669)}.api-fetch-btn .spinning{animation:spin 1s linear infinite}.stat-value.not-loaded{color:#94a3b8;font-style:italic}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:32px;padding:20px;background:#f8fafc;border-radius:16px}.stat-card{background:#fff;border-radius:16px;padding:20px;display:flex;align-items:flex-start;gap:16px;box-shadow:0 4px 20px #0000000d;position:relative}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.stat-icon.users{background:#e3f2fd;color:#1976d2}.stat-icon.places{background:#e8f5e9;color:#388e3c}.stat-icon.events{background:#fff3e0;color:#f57c00}.stat-icon.visits{background:#fce4ec;color:#c2185b}.stat-info{display:flex;flex-direction:column;gap:8px;flex:1}.stat-label{font-size:.95rem;font-weight:600;color:#1a1a2e}.stat-values{display:flex;flex-direction:column;gap:6px}.stat-row{display:flex;align-items:center;gap:6px;font-size:.85rem}.stat-row .stat-type-icon{width:14px;height:14px;flex-shrink:0}.stat-row.api .stat-type-icon{color:#1976d2}.stat-row.db .stat-type-icon{color:#4caf50}.stat-row .stat-type-label{color:#888;width:26px;font-size:.75rem}.stat-row .stat-value{font-size:1.1rem;font-weight:700;color:#1a1a2e}.api-stats-section{background:#fff;border-radius:16px;padding:24px;margin-top:24px;box-shadow:0 4px 20px #0000000d}.api-stats-header h3{display:flex;align-items:center;gap:8px;font-size:1.1rem;color:#1a1a2e}.reset-stats-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid #ddd;border-radius:6px;background:#fff;color:#666;cursor:pointer;font-size:.85rem;transition:all .2s}.reset-stats-btn:hover{border-color:#f44336;color:#f44336}.top-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.top-stat-card{display:flex;flex-direction:column;gap:8px;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff}.top-stat-card .top-label{font-size:.85rem;opacity:.9}.top-stat-card .top-value{font-size:1.1rem;font-weight:600}.top-stat-card .top-value.empty{opacity:.7;font-style:italic}.top-stat-card .top-value strong{font-weight:700}.api-call-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;padding:20px;background:#f8fafc;border-radius:16px}.api-call-item{display:flex;align-items:center;gap:12px}.api-call-item .api-name{width:80px;font-size:.9rem;font-weight:500;color:#333}.api-bar-container{flex:1;height:24px;background:#f0f0f0;border-radius:12px;overflow:hidden}.api-bar{height:100%;border-radius:12px;transition:width .3s ease;min-width:4px}.api-call-item .api-count{width:50px;text-align:right;font-size:.9rem;font-weight:600;color:#1976d2}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.charts-empty{text-align:center;padding:40px 20px;color:#64748b;font-size:.95rem}.chart-card{background:#f8f9fa;border-radius:12px;padding:20px}.chart-card h4{font-size:.95rem;color:#333;margin-bottom:16px;text-align:center}.dashboard-info{margin-top:24px}.info-card{background:#fff;border-radius:16px;padding:32px;box-shadow:0 4px 20px #0000000d}.info-card h3{font-size:1.25rem;margin-bottom:12px;color:#1a1a2e}.info-card p{color:#666;line-height:1.6}.table-selector{background:#fff;border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:0 4px 20px #0000000d}.table-selector h3{margin-bottom:16px;color:#1a1a2e}.table-buttons{display:flex;flex-wrap:wrap;gap:12px}.table-btn{padding:10px 20px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;color:#333;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.table-btn:hover{border-color:#1976d2;color:#1976d2}.table-btn.active{background:#1976d2;border-color:#1976d2;color:#fff}.table-loading,.no-table-selected,.no-data{background:#fff;border-radius:16px;padding:48px;text-align:center;box-shadow:0 4px 20px #0000000d}.data-table-container{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #0000000d}.data-table-container h3{margin-bottom:16px;color:#1a1a2e}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table th,.data-table td{padding:12px;text-align:left;border-bottom:1px solid #e0e0e0}.data-table th{background:#f5f7fa;font-weight:600;color:#333;white-space:nowrap}.data-table td{color:#666;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table tr:hover td{background:#f8f9fa}.section-header{margin-bottom:24px}.section-header h2{font-size:1.25rem;color:#1a1a2e}.coming-soon{background:#fff;border-radius:16px;padding:64px;text-align:center;box-shadow:0 4px 20px #0000000d}.coming-soon svg{color:#bdbdbd;margin-bottom:16px}.coming-soon p{color:#666}.settings-content{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #0000000d}.setting-item{padding:20px;background:#f8fafc;border-radius:12px;margin-bottom:16px}.setting-item:last-child{margin-bottom:0}.setting-item h3{font-size:1.1rem;margin-bottom:16px;color:#1a1a2e}.setting-item p{margin-bottom:8px;color:#666}.setting-item p strong{color:#333}.stat-card.clickable{cursor:pointer;position:relative;transition:all .2s ease}.stat-card.clickable:hover{transform:translateY(-2px);box-shadow:0 8px 30px #0000001a}.stat-link{position:absolute;top:16px;right:16px;color:#999;opacity:0;transition:opacity .2s}.stat-card.clickable:hover .stat-link{opacity:1}.quick-links{display:flex;gap:12px;margin-top:20px}.quick-link{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;border:2px solid #e0e0e0;background:#fff;color:#333;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.quick-link:hover{border-color:#1976d2;color:#1976d2}.page-management{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000000d}.page-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #eee;background:#f8f9fa}.page-count{font-size:.95rem;color:#666}.page-count strong{color:#1976d2;font-weight:700}.view-page-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;background:#1976d2;color:#fff;text-decoration:none;font-size:.9rem;font-weight:500;transition:background .2s}.view-page-btn:hover{background:#1565c0}.page-loading{padding:60px;text-align:center}.page-info{color:#999;font-size:.9em}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:24px;background:#f8f9fa;border-top:1px solid #eee}.admin-pagination .page-btn{padding:8px 16px;border:1px solid #ddd;border-radius:6px;background:#fff;color:#333;cursor:pointer;font-size:.85rem;transition:all .2s}.admin-pagination .page-btn:hover:not(:disabled){border-color:#1976d2;color:#1976d2}.admin-pagination .page-btn:disabled{opacity:.5;cursor:not-allowed}.admin-pagination .page-numbers{display:flex;gap:4px}.admin-pagination .page-num{min-width:36px;padding:8px 12px;border:1px solid #ddd;border-radius:6px;background:#fff;color:#333;cursor:pointer;font-size:.9rem;transition:all .2s}.admin-pagination .page-num:hover{border-color:#1976d2;color:#1976d2}.admin-pagination .page-num.active{background:#1976d2;border-color:#1976d2;color:#fff}.dark-theme .admin-pagination{background:#0f172a;border-top-color:#334155}.dark-theme .admin-pagination .page-btn{background:#1e293b;color:#e2e8f0}.dark-theme .admin-pagination .page-btn:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6;background:#1e3a5f}.dark-theme .admin-pagination .page-btn:disabled{opacity:.4;color:#64748b}.dark-theme .admin-pagination .page-num{background:#1e293b;color:#e2e8f0}.dark-theme .admin-pagination .page-num:hover{border-color:#3b82f6;color:#3b82f6;background:#1e3a5f}.dark-theme .admin-pagination .page-num.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.supabase-link{display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:10px 16px;background:#3ecf8e;color:#fff;text-decoration:none;border-radius:8px;font-size:.9rem;font-weight:500;transition:background .2s}.supabase-link:hover{background:#38b880}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.admin-sidebar{position:fixed;left:-260px;transition:left .3s ease}.admin-sidebar.open{left:0}.admin-main,.admin-main.expanded{margin-left:0}.mobile-menu-btn{display:block}.api-fetch-section{flex-direction:column;gap:12px;text-align:center}.api-fetch-info{align-items:center}.api-fetch-btn{width:100%;justify-content:center}.stats-grid{grid-template-columns:1fr}.admin-content,.admin-header{padding:16px}.quick-links{flex-direction:column}.charts-grid,.top-stats{grid-template-columns:1fr}.api-call-item .api-name{width:60px;font-size:.8rem}}.save-cell{text-align:center;width:60px}.save-item-btn{background:#4caf50;color:#fff;border:none;border-radius:6px;padding:6px 10px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center}.save-item-btn:hover{background:#388e3c;transform:scale(1.05)}.save-item-btn svg{width:16px;height:16px}.saved-badge{color:#4caf50;display:inline-flex;align-items:center;justify-content:center}.saved-badge svg{width:18px;height:18px}.saving-spinner{width:18px;height:18px;border:2px solid #e0e0e0;border-top-color:#4caf50;border-radius:50%;animation:spin 1s linear infinite;display:inline-block}.save-success{color:#4caf50;animation:fadeIn .3s ease}.save-success svg{width:18px;height:18px}.save-error{color:#f44336;animation:fadeIn .3s ease}.save-error svg{width:18px;height:18px}.saved-row{background:#4caf500d!important}.saved-row:hover{background:#4caf501a!important}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.page-header-actions{display:flex;gap:12px;align-items:center}.bulk-save-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #4caf504d}.bulk-save-btn:hover:not(:disabled){background:linear-gradient(135deg,#45a049,#3d8b40);transform:translateY(-1px);box-shadow:0 4px 12px #4caf5066}.bulk-save-btn:active:not(:disabled){transform:translateY(0)}.bulk-save-btn:disabled{background:#ccc;cursor:not-allowed;box-shadow:none}.bulk-save-btn svg{width:18px;height:18px}.bulk-save-btn .saving-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff}.data-source-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:2px solid #eee;padding-bottom:12px}.source-tab{display:flex;align-items:center;gap:8px;padding:12px 24px;border:2px solid #e0e0e0;border-radius:8px 8px 0 0;background:#fff;color:#666;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease}.source-tab:hover:not(.active){background:#f5f5f5;border-color:#ccc}.source-tab.active{background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;border-color:#1976d2}.source-tab.active:first-child{background:linear-gradient(135deg,#2196f3,#1976d2);border-color:#2196f3}.source-tab.active:last-child{background:linear-gradient(135deg,#4caf50,#388e3c);border-color:#4caf50}.source-tab svg{width:18px;height:18px}.source-count{font-size:.8rem;opacity:.85;margin-left:4px}.page-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}@media (max-width: 768px){.data-source-tabs{flex-direction:column}.source-tab{border-radius:8px}.page-header-actions{width:100%;justify-content:flex-end}.bulk-save-btn{padding:8px 16px;font-size:.85rem}}.hero-management{display:flex;flex-direction:column;gap:24px}.hero-form-section{background:#f8fafc;border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000000d}.hero-form-section h3{margin:0 0 20px;font-size:1.1rem;color:#333;padding-bottom:12px;border-bottom:1px solid #eee}.hero-form{display:flex;flex-direction:column;gap:16px}.hero-form .form-row{display:flex;gap:16px}.hero-form .form-group{flex:1;display:flex;flex-direction:column;gap:6px}.hero-form .form-group.full-width{flex:1 1 100%}.hero-form .form-group.checkbox-group{flex:0 0 auto;flex-direction:row;align-items:center}.hero-form .form-group.checkbox-group label{display:flex;align-items:center;gap:8px;cursor:pointer}.hero-form .form-group.checkbox-group input[type=checkbox]{width:18px;height:18px}.hero-form label{font-size:.85rem;font-weight:500;color:#555}.hero-form input,.hero-form textarea{padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.hero-form input:focus,.hero-form textarea:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.hero-form textarea{resize:vertical;min-height:60px}.hero-form .image-preview{margin-top:8px;border-radius:8px;overflow:hidden;max-height:200px}.hero-form .image-preview img{width:100%;height:auto;max-height:200px;object-fit:cover}.hero-form .form-actions{display:flex;gap:12px;margin-top:8px}.hero-form .save-btn,.hero-form .cancel-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:8px;font-size:.95rem;cursor:pointer;transition:all .2s}.hero-form .save-btn{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.hero-form .save-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4caf504d}.hero-form .cancel-btn{background:#f5f5f5;color:#666}.hero-form .cancel-btn:hover{background:#e0e0e0}.hero-list-section{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000000d}.hero-list-section h3{margin:0 0 20px;font-size:1.1rem;color:#333}.hero-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.hero-card{background:#f9f9f9;border-radius:12px;overflow:hidden;border:1px solid #eee;transition:transform .2s,box-shadow .2s}.hero-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000014}.hero-card.inactive{opacity:.6}.hero-card-image{position:relative;height:150px;overflow:hidden}.hero-card-image img{width:100%;height:100%;object-fit:cover}.hero-card-image .inactive-badge{position:absolute;top:8px;right:8px;background:#000000b3;color:#fff;padding:4px 10px;border-radius:4px;font-size:.75rem}.hero-card-content{padding:16px}.hero-card-content h4{margin:0 0 6px;font-size:1rem;color:#333}.hero-card-content .subtitle{margin:0 0 8px;font-size:.85rem;color:#666}.hero-card-meta{display:flex;gap:12px;font-size:.8rem;color:#888}.hero-card-actions{display:flex;gap:8px;padding:12px 16px;border-top:1px solid #eee;background:#fff}.hero-card-actions button{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.hero-card-actions .edit-btn{background:#e3f2fd;color:#1976d2}.hero-card-actions .edit-btn:hover{background:#bbdefb}.hero-card-actions .delete-btn{background:#ffebee;color:#e53935}.hero-card-actions .delete-btn:hover{background:#ffcdd2}.hero-loading{display:flex;justify-content:center;padding:40px}.action-cell{display:flex;gap:6px;justify-content:center}.edit-item-btn,.delete-item-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.edit-item-btn{background:#e3f2fd;color:#1976d2}.edit-item-btn:hover{background:#bbdefb;transform:scale(1.05)}.delete-item-btn{background:#ffebee;color:#e53935}.delete-item-btn:hover{background:#ffcdd2;transform:scale(1.05)}.edit-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.edit-modal{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003}.edit-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #eee}.edit-modal-header h3{margin:0;font-size:1.2rem;color:#333}.edit-modal-header .close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;background:#f5f5f5;cursor:pointer;transition:all .2s}.edit-modal-header .close-btn:hover{background:#e0e0e0}.edit-modal-content{padding:24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.edit-modal-content .form-group{display:flex;flex-direction:column;gap:6px}.edit-modal-content .form-group label{font-size:.85rem;font-weight:500;color:#555}.edit-modal-content .form-group input{padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.edit-modal-content .form-group input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.edit-modal-content .image-preview-small{margin-top:8px;border-radius:8px;overflow:hidden;max-height:100px}.edit-modal-content .image-preview-small img{width:100%;height:auto;max-height:100px;object-fit:cover}.edit-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #eee;background:#fafafa}.edit-modal-footer button{padding:10px 24px;border:none;border-radius:8px;font-size:.95rem;cursor:pointer;transition:all .2s}.edit-modal-footer .cancel-btn{background:#f5f5f5;color:#666}.edit-modal-footer .cancel-btn:hover:not(:disabled){background:#e0e0e0}.edit-modal-footer .save-btn{background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff}.edit-modal-footer .save-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1976d24d}.edit-modal-footer button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.hero-form .form-row{flex-direction:column}.hero-cards{grid-template-columns:1fr}.edit-modal{max-height:85vh}}.supabase-usage-section{background:#fff;border-radius:12px;padding:24px;margin-top:24px;box-shadow:0 2px 8px #0000000d}.usage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.usage-header h3{margin:0;font-size:1.25rem;color:#1a1a2e;display:flex;align-items:center;gap:8px}.usage-header h3 svg{color:#3ecf8e}.usage-header .refresh-btn{padding:8px;border:none;background:#f0f0f0;border-radius:8px;cursor:pointer;transition:all .2s}.usage-header .refresh-btn:hover:not(:disabled){background:#e0e0e0}.usage-header .refresh-btn:disabled{opacity:.6;cursor:not-allowed}.usage-header .refresh-btn svg.spinning{animation:spin 1s linear infinite}.usage-loading{padding:40px;text-align:center;color:#666}.usage-empty{padding:40px;text-align:center;color:#999}.usage-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:24px}.usage-card{display:flex;align-items:flex-start;gap:16px;padding:20px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px}.usage-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3ecf8e,#2ebf7d);border-radius:12px;color:#fff;font-size:1.5rem}.usage-info{flex:1;display:flex;flex-direction:column;gap:4px}.usage-label{font-size:.875rem;color:#64748b}.usage-value{font-size:1.5rem;font-weight:700;color:#1a1a2e}.usage-bar-container{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin:4px 0}.usage-bar{height:100%;background:linear-gradient(90deg,#3ecf8e,#2ebf7d);border-radius:4px;transition:width .3s ease}.usage-bar.storage{background:linear-gradient(90deg,#6366f1,#4f46e5)}.usage-limit{font-size:.75rem;color:#94a3b8}.table-usage-list{margin-bottom:20px}.table-usage-list h4{margin:0 0 12px;font-size:1rem;color:#475569}.table-usage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.table-usage-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#f8fafc;border-radius:8px;font-size:.875rem}.table-name{color:#475569;font-family:SF Mono,Consolas,monospace}.table-rows{font-weight:600;color:#1e293b}.free-plan-notice{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:12px 16px;background:#fefce8;border:1px solid #fef08a;border-radius:8px;font-size:.875rem;color:#854d0e}.free-plan-notice a{display:inline-flex;align-items:center;gap:4px;color:#3ecf8e;text-decoration:none;font-weight:500;margin-left:auto}.free-plan-notice a:hover{text-decoration:underline}@media (max-width: 768px){.usage-summary{grid-template-columns:1fr}.table-usage-grid{grid-template-columns:repeat(2,1fr)}.free-plan-notice{flex-direction:column;align-items:flex-start}.free-plan-notice a{margin-left:0;margin-top:8px}}.visit-stats-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 12px #0000000f;margin-bottom:24px}.visit-stats-section h3{display:flex;align-items:center;gap:10px;font-size:1.2rem;color:#1e293b;margin-bottom:20px}.visit-stats-section h3 .loading-icon{font-size:1rem}.visit-stats-section h3 .spinning{animation:spin 1s linear infinite}.visit-stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.visit-stat-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px}.visit-label{font-size:.85rem;color:#64748b}.visit-value{font-size:1.1rem;color:#1e293b}.visit-value strong{color:#4f46e5}.visit-value.empty{color:#94a3b8;font-style:italic}.visit-chart-container{margin-bottom:24px;padding:24px;background:#f8fafc;border-radius:16px}.visit-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.visit-chart-header h4{font-size:1rem;color:#475569;margin:0}.visit-chart-container h4{font-size:1rem;color:#475569;margin-bottom:16px}.period-filter-tabs{display:flex;gap:4px;background:#f1f5f9;border-radius:8px;padding:4px}.period-tab{padding:6px 12px;border:none;background:transparent;color:#64748b;font-size:.85rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease}.period-tab:hover{color:#475569;background:#e2e8f0}.period-tab.active{background:#4f46e5;color:#fff}.visit-bar-chart{display:flex;flex-direction:column;gap:12px}.visit-bar-item{display:grid;grid-template-columns:100px 1fr 70px;align-items:center;gap:12px}.visit-page-name{font-size:.9rem;color:#374151;font-weight:500}.visit-bar-container{height:24px;background:#f1f5f9;border-radius:6px;overflow:hidden}.visit-bar{height:100%;border-radius:6px;transition:width .5s ease;min-width:2px}.visit-count{font-size:.9rem;color:#64748b;text-align:right;font-weight:500}.today-visits-container{margin-bottom:20px;padding:24px;background:#f8fafc;border-radius:16px}.today-visits-container h4{font-size:1rem;color:#475569;margin-bottom:16px}.today-visits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.today-visit-card{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border-radius:12px;padding:16px;text-align:center;display:flex;flex-direction:column;gap:8px}.today-page-name{font-size:.8rem;opacity:.9}.today-visit-count{font-size:1.5rem;font-weight:700}.visit-stats-section .refresh-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:#f1f5f9;border:none;border-radius:8px;font-size:.9rem;color:#475569;cursor:pointer;transition:all .2s}.visit-stats-section .refresh-btn:hover{background:#e2e8f0;color:#1e293b}@media (max-width: 768px){.visit-bar-item{grid-template-columns:80px 1fr 60px}.today-visits-grid{grid-template-columns:repeat(3,1fr)}}.search-stats-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 12px #0000000f;margin-bottom:24px}.search-stats-section h3{display:flex;align-items:center;gap:10px;font-size:1.2rem;color:#1e293b;margin-bottom:20px}.search-stats-section h3 .loading-icon{font-size:1rem}.search-stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.search-stat-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px}.search-label{font-size:.85rem;color:#92400e}.search-value{font-size:1.1rem;color:#78350f}.search-value strong{color:#b45309}.search-value.empty{color:#a16207;font-style:italic}.popular-searches-container{margin-bottom:24px;padding:24px;background:#f8fafc;border-radius:16px}.popular-searches-container h4,.today-searches-container h4{font-size:1rem;color:#475569;margin-bottom:16px}.popular-searches-list{display:flex;flex-direction:column;gap:8px}.popular-search-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-radius:10px;transition:transform .2s,box-shadow .2s}.popular-search-item:hover{transform:translate(4px);box-shadow:0 2px 8px #00000014}.search-rank{font-size:.9rem;font-weight:700;color:#f59e0b;min-width:30px}.search-query{flex:1;font-size:.95rem;color:#1e293b;font-weight:500}.search-count{font-size:.85rem;color:#64748b;background:#e2e8f0;padding:4px 10px;border-radius:12px}.today-searches-container{margin-bottom:20px;padding:24px;background:#f8fafc;border-radius:16px}.today-searches-list{display:flex;flex-wrap:wrap;gap:10px}.today-search-tag{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-radius:20px;font-size:.9rem}.tag-rank{font-size:.75rem;opacity:.85}.tag-query{font-weight:500}.dark-theme .period-filter-tabs{background:#374151}.dark-theme .period-tab{color:#9ca3af}.dark-theme .period-tab:hover{color:#e5e7eb;background:#4b5563}.dark-theme .period-tab.active{background:#6366f1;color:#fff}.dark-theme .visit-chart-header h4{color:#e5e7eb}.tag-count{background:#fff3;padding:2px 8px;border-radius:10px;font-size:.8rem}.no-data-text{color:#94a3b8;font-style:italic;font-size:.9rem;padding:20px;text-align:center;background:#f8fafc;border-radius:8px}.search-stats-section .refresh-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:#f1f5f9;border:none;border-radius:8px;font-size:.9rem;color:#475569;cursor:pointer;transition:all .2s}.search-stats-section .refresh-btn:hover{background:#e2e8f0;color:#1e293b}@media (max-width: 768px){.search-stats-summary{grid-template-columns:1fr}.today-searches-list{justify-content:center}}.external-api-stats-section{background:#fff;border-radius:12px;padding:24px;margin-top:24px;box-shadow:0 2px 8px #0000000d}.api-stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.api-stats-header h3{margin:0;font-size:1.25rem;color:#1a1a2e;display:flex;align-items:center;gap:8px}.api-stats-header h3 svg{color:#6366f1}.api-stats-header .refresh-btn{padding:8px;border:none;background:#f0f0f0;border-radius:8px;cursor:pointer;transition:all .2s}.api-stats-header .refresh-btn:hover:not(:disabled){background:#e0e0e0}.api-stats-header .refresh-btn:disabled{opacity:.6;cursor:not-allowed}.api-stats-header .refresh-btn svg.spinning{animation:spin 1s linear infinite}.api-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;margin-bottom:16px}.api-stat-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;overflow:hidden}.api-card-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid #e2e8f0}.api-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:1.2rem;color:#fff}.api-icon.kakao{background:linear-gradient(135deg,#ffe600,#ffcd00);color:#3c1e1e}.api-icon.odsay{background:linear-gradient(135deg,#00a8e8,#0077b6)}.api-card-header h4{margin:0;font-size:1rem;font-weight:600;color:#1e293b}.api-card-body{padding:16px 20px}.api-card-empty{padding:40px 20px;text-align:center;color:#94a3b8}.api-stat-card .stat-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.api-stat-card .stat-row.highlight{padding:12px;margin:8px -12px;background:#6366f10d;border-radius:8px}.api-stat-card .stat-row.small{padding:4px 0;font-size:.85rem}.api-stat-card .stat-label{color:#64748b;font-size:.875rem}.api-stat-card .api-stat-value{font-weight:600;color:#1e293b;display:flex;align-items:center;gap:6px}.api-stat-card .api-stat-value.warning{color:#f59e0b}.api-stat-card .api-stat-value.success{color:#10b981}.api-stat-card .api-stat-value.cache-value{color:#8b5cf6}.api-stat-card .api-stat-value svg{font-size:1rem}.usage-bar-wrapper{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin:12px 0}.api-stat-card .usage-bar{height:100%;border-radius:4px;transition:width .3s ease}.api-stat-card .usage-bar.normal{background:linear-gradient(90deg,#10b981,#34d399)}.api-stat-card .usage-bar.warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.api-stat-card .usage-bar.critical{background:linear-gradient(90deg,#ef4444,#f87171)}.endpoint-stats{margin-top:12px;padding-top:12px;border-top:1px solid #e2e8f0}.endpoint-title{display:block;font-size:.8rem;color:#94a3b8;margin-bottom:8px}.endpoint-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:.8rem}.endpoint-row span:first-child{color:#64748b;font-family:SF Mono,Consolas,monospace}.endpoint-row span:last-child{font-weight:500;color:#475569}.api-card-footer{padding:12px 20px;background:#f8fafc;border-top:1px solid #e2e8f0}.api-card-footer a{color:#6366f1;text-decoration:none;font-size:.85rem;font-weight:500}.api-card-footer a:hover{text-decoration:underline}.api-stats-notice{display:flex;align-items:flex-start;gap:8px;padding:12px 16px;background:#f1f5f9;border-radius:8px;font-size:.8rem;color:#64748b}.api-stats-notice svg{flex-shrink:0;margin-top:2px}.db-stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:20px;padding:16px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;border:1px solid #bae6fd}.db-summary-card{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000000d}.db-summary-card .summary-icon{font-size:1.5rem;color:#0ea5e9;flex-shrink:0}.db-summary-card .summary-icon.cache{color:#10b981}.db-summary-card .summary-icon.actual{color:#f59e0b}.db-summary-card .summary-icon.rate{color:#8b5cf6}.db-summary-card .summary-content{display:flex;flex-direction:column}.db-summary-card .summary-label{font-size:.75rem;color:#64748b;margin-bottom:2px}.db-summary-card .summary-value{font-size:1.25rem;font-weight:700;color:#1e293b}.db-summary-card .summary-value.highlight{color:#f59e0b}.db-summary-card .summary-value.success{color:#10b981}.week-stats-bar{display:flex;flex-wrap:wrap;align-items:center;gap:16px;padding:12px 16px;background:#f8fafc;border-radius:8px;margin-bottom:20px;font-size:.85rem}.week-stats-bar .week-label{color:#64748b;font-weight:500}.week-stats-bar .week-stat{color:#475569}.week-stats-bar .week-stat strong{color:#1e293b;margin-left:4px}.db-api-details{margin-bottom:20px}.db-api-details h4{display:flex;align-items:center;gap:8px;font-size:1rem;color:#475569;margin:0 0 12px}.api-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.api-detail-card{background:#f8fafc;border-radius:10px;padding:12px;border:1px solid #e2e8f0}.api-detail-card.kakao-geocoding,.api-detail-card.kakao-route{border-left:3px solid #ffe600}.api-detail-card.odsay-transit{border-left:3px solid #00a8e8}.api-detail-card.tour-api{border-left:3px solid #10b981}.api-detail-card.kto-photo{border-left:3px solid #f59e0b}.api-detail-header{margin-bottom:8px}.api-detail-header .api-type-name{font-size:.85rem;font-weight:600;color:#1e293b}.api-detail-stats{display:flex;flex-wrap:wrap;gap:8px}.api-detail-stats .detail-stat{display:flex;flex-direction:column;flex:1;min-width:50px;padding:6px 8px;background:#fff;border-radius:6px;text-align:center}.api-detail-stats .detail-label{font-size:.7rem;color:#94a3b8;margin-bottom:2px}.api-detail-stats .detail-value{font-size:.95rem;font-weight:600;color:#1e293b}.api-detail-stats .detail-value.success{color:#10b981}.api-detail-stats .detail-value.fail{color:#ef4444}.api-detail-stats .detail-value.cache{color:#8b5cf6}.dark-theme .external-api-stats-section{background:#1e293b}.dark-theme .api-stat-card{background:linear-gradient(135deg,#1e293b,#0f172a)}.dark-theme .api-card-header h4{color:#f1f5f9}.dark-theme .stat-label{color:#94a3b8}.dark-theme .api-stat-card .api-stat-value{color:#f1f5f9}.dark-theme .api-stat-card .api-stat-value.cache-value{color:#a78bfa}.dark-theme .usage-bar-wrapper{background:#334155}.dark-theme .endpoint-row span:first-child{color:#94a3b8}.dark-theme .endpoint-row span:last-child{color:#cbd5e1}.dark-theme .api-card-footer{background:#0f172a}.dark-theme .api-stats-notice{background:#0f172a;color:#94a3b8}.dark-theme .db-stats-summary{background:linear-gradient(135deg,#1e293b,#0f172a);border-color:#334155}.dark-theme .db-summary-card{background:#334155;box-shadow:0 2px 4px #0003}.dark-theme .db-summary-card .summary-label{color:#94a3b8}.dark-theme .db-summary-card .summary-value{color:#f1f5f9}.dark-theme .week-stats-bar{background:#0f172a}.dark-theme .week-stats-bar .week-label{color:#94a3b8}.dark-theme .week-stats-bar .week-stat{color:#cbd5e1}.dark-theme .week-stats-bar .week-stat strong{color:#f1f5f9}.dark-theme .db-api-details h4{color:#94a3b8}.dark-theme .api-detail-card{background:#0f172a;border-color:#334155}.dark-theme .api-detail-header .api-type-name{color:#f1f5f9}.dark-theme .api-detail-stats .detail-stat{background:#334155}.dark-theme .api-detail-stats .detail-label{color:#64748b}.dark-theme .api-detail-stats .detail-value{color:#f1f5f9}.dark-theme.admin-page{background:#0f172a}.dark-theme .admin-loading{color:#e2e8f0}.dark-theme .admin-login-card{background:#1e293b;box-shadow:0 10px 40px #0000004d}.dark-theme .login-header h1{color:#f1f5f9}.dark-theme .login-header p{color:#94a3b8}.dark-theme .form-group{background:#0f172a}.dark-theme .form-group label{color:#e2e8f0}.dark-theme .form-group input{background:#1e293b;border-color:#334155;color:#f1f5f9}.dark-theme .form-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.dark-theme .login-error{background:#450a0a;color:#fca5a5}.dark-theme .admin-sidebar{background:#0f172a;border-right:1px solid #1e293b}.dark-theme .sidebar-header{border-bottom-color:#1e293b}.dark-theme .nav-btn{color:#94a3b8}.dark-theme .nav-btn:hover{background:#1e293b;color:#f1f5f9}.dark-theme .nav-btn.active{background:#1e293b;color:#3b82f6}.dark-theme .admin-main{background:#0f172a}.dark-theme .admin-header{background:#1e293b;border-bottom-color:#334155}.dark-theme .page-title{color:#f1f5f9}.dark-theme .page-subtitle{color:#94a3b8}.dark-theme .admin-content{background:#0f172a}.dark-theme .stat-card{background:#1e293b}.dark-theme .stat-card .stat-label{color:#94a3b8}.dark-theme .stat-card .stat-value{color:#f1f5f9}.dark-theme .stat-card .stat-sublabel{color:#64748b}.dark-theme .data-table{background:#1e293b}.dark-theme .data-table th{background:#0f172a;color:#e2e8f0}.dark-theme .data-table td{color:#cbd5e1}.dark-theme .data-table tr:hover td,.dark-theme .stats-section,.dark-theme .chart-section{background:#1e293b}.dark-theme .stats-section h3,.dark-theme .chart-section h3{color:#f1f5f9}.dark-theme .hero-card{background:#1e293b;border-color:#475569}.dark-theme .hero-card .hero-title{color:#f1f5f9}.dark-theme .hero-card .hero-subtitle{color:#94a3b8}.dark-theme .hero-card-content .subtitle{color:#94a3b8}.dark-theme .hero-card-actions{background:#0f172a;border-top-color:#334155}.dark-theme .hero-card-actions .edit-btn{background:#1e3a5f;color:#60a5fa}.dark-theme .hero-card-actions .edit-btn:hover{background:#2563eb;color:#fff}.dark-theme .hero-card-actions .delete-btn{background:#450a0a;color:#fca5a5}.dark-theme .hero-card-actions .delete-btn:hover{background:#991b1b;color:#fff}.dark-theme .admin-input,.dark-theme .admin-textarea,.dark-theme .admin-select{background:#0f172a;color:#f1f5f9}.dark-theme .admin-input:focus,.dark-theme .admin-textarea:focus,.dark-theme .admin-select:focus{border-color:#3b82f6}.dark-theme .btn-secondary{background:#334155;color:#f1f5f9;border-color:#475569}.dark-theme .btn-secondary:hover{background:#475569}.dark-theme .modal-overlay{background:#000000b3}.dark-theme .modal-content{background:#1e293b}.dark-theme .modal-header{border-bottom-color:#334155}.dark-theme .modal-header h3{color:#f1f5f9}.dark-theme .modal-footer{border-top-color:#334155}.dark-theme .pagination{background:#1e293b}.dark-theme .pagination-btn{background:#0f172a;color:#94a3b8}.dark-theme .pagination-btn:hover:not(:disabled){background:#334155;color:#f1f5f9}.dark-theme .pagination-btn.active{background:#3b82f6;color:#fff}.dark-theme .supabase-stats-section{background:#1e293b}.dark-theme .supabase-stats-section h3{color:#f1f5f9}.dark-theme .supabase-stat-card{background:#0f172a}.dark-theme .supabase-stat-card .stat-label{color:#94a3b8}.dark-theme .supabase-stat-card .stat-value{color:#f1f5f9}.dark-theme .visit-stat-item{background:#0f172a}.dark-theme .visit-stat-item .page-name{color:#e2e8f0}.dark-theme .visit-stat-item .visit-count{color:#94a3b8}.dark-theme .search-item{background:#0f172a}.dark-theme .search-item .search-query{color:#e2e8f0}.dark-theme .search-item .search-count{color:#94a3b8}.dark-theme .section-header h3{color:#f1f5f9}.dark-theme .tab-btn{color:#94a3b8;border-color:transparent}.dark-theme .tab-btn:hover{color:#f1f5f9}.dark-theme .tab-btn.active{color:#3b82f6;border-color:#3b82f6}.dark-theme .back-btn{color:#94a3b8}.dark-theme .back-btn:hover{background:#1e293b;color:#3b82f6}.dark-theme .admin-header h1{color:#f1f5f9}.dark-theme .admin-header .header-actions button{color:#94a3b8}.dark-theme .admin-header .header-actions button:hover{background:#334155;color:#f1f5f9}.dark-theme .api-stats-section{background:#1e293b}.dark-theme .api-stats-section h3{color:#f1f5f9}.dark-theme .api-stats-section .chart-container,.dark-theme .api-stat-item{background:#0f172a}.dark-theme .api-stat-item .stat-name{color:#e2e8f0}.dark-theme .api-stat-item .stat-count{color:#94a3b8}.dark-theme .supabase-usage-section{background:#1e293b}.dark-theme .supabase-usage-section h3,.dark-theme .supabase-stats-section h3{color:#f1f5f9}.dark-theme .usage-card{background:#0f172a}.dark-theme .usage-card .usage-label{color:#94a3b8}.dark-theme .usage-card .usage-value{color:#f1f5f9}.dark-theme .usage-card .usage-limit{color:#64748b}.dark-theme .visit-stats-section{background:#1e293b}.dark-theme .visit-stats-section h3{color:#f1f5f9}.dark-theme .visit-stat-card .page-name{color:#e2e8f0}.dark-theme .visit-stat-card .visit-count{color:#94a3b8}.dark-theme .visit-chart-container{background:#0f172a}.dark-theme .dashboard-section{background:#1e293b}.dark-theme .dashboard-section h3,.dark-theme .section-title{color:#f1f5f9}.dark-theme .dashboard-card{background:#0f172a}.dark-theme .hero-form-section{background:#1e293b}.dark-theme .hero-form-section h3{color:#f1f5f9}.dark-theme .hero-form{background:#0f172a}.dark-theme .hero-form label{color:#e2e8f0}.dark-theme .hero-form input,.dark-theme .hero-form textarea,.dark-theme .hero-form select{background:#1e293b;color:#f1f5f9}.dark-theme .hero-form input:focus,.dark-theme .hero-form textarea:focus,.dark-theme .hero-form select:focus{border-color:#3b82f6}.dark-theme .hero-card .hero-info h4{color:#f1f5f9}.dark-theme .hero-card .hero-info p{color:#94a3b8}.dark-theme .page-management{background:#1e293b}.dark-theme .page-management h3{color:#f1f5f9}.dark-theme .page-tabs{background:#0f172a}.dark-theme .page-tab{color:#94a3b8;background:transparent}.dark-theme .page-tab:hover{background:#1e293b;color:#f1f5f9}.dark-theme .page-tab.active{background:#1e293b;color:#3b82f6;border-color:#3b82f6}.dark-theme .data-list{background:#0f172a}.dark-theme .data-item{background:#1e293b}.dark-theme .data-item:hover{background:#334155}.dark-theme .data-item .item-title{color:#f1f5f9}.dark-theme .data-item .item-desc{color:#94a3b8}.dark-theme .settings-content{background:#1e293b}.dark-theme .settings-content h3{color:#f1f5f9}.dark-theme .setting-item{background:#0f172a}.dark-theme .setting-item h4{color:#e2e8f0}.dark-theme .setting-item p{color:#94a3b8}.dark-theme .setting-item input,.dark-theme .setting-item select{background:#1e293b;color:#f1f5f9}.dark-theme .database-section{background:#1e293b}.dark-theme .database-section h3{color:#f1f5f9}.dark-theme .table-selector{background:#0f172a}.dark-theme .table-selector h4{color:#e2e8f0}.dark-theme .table-btn{background:#1e293b;color:#94a3b8}.dark-theme .table-btn:hover{background:#334155;color:#f1f5f9}.dark-theme .table-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.dark-theme .data-table-container{background:#0f172a}.dark-theme .data-table-container h4{color:#e2e8f0}.dark-theme .search-input,.dark-theme .filter-input{background:#1e293b;color:#f1f5f9}.dark-theme .search-input::placeholder,.dark-theme .filter-input::placeholder{color:#64748b}.dark-theme .info-card{background:#1e293b}.dark-theme .info-card h3,.dark-theme .info-card h4{color:#f1f5f9}.dark-theme .info-card p{color:#94a3b8}.dark-theme .coming-soon,.dark-theme .no-data,.dark-theme .no-table-selected,.dark-theme .table-loading{background:#1e293b;color:#94a3b8}.dark-theme .refresh-btn{background:#334155;color:#94a3b8;border-color:#475569}.dark-theme .refresh-btn:hover{background:#475569;color:#f1f5f9}.dark-theme .section-header{border-bottom-color:#334155}.dark-theme .section-header h2,.dark-theme .section-header h3{color:#f1f5f9}.dark-theme .action-btn{background:#334155;color:#94a3b8}.dark-theme .action-btn:hover{background:#475569;color:#f1f5f9}.dark-theme .action-btn.delete{color:#f87171}.dark-theme .action-btn.delete:hover{background:#450a0a;color:#fca5a5}.dark-theme .toggle-label{color:#e2e8f0}.dark-theme .badge{background:#334155;color:#94a3b8}.dark-theme .badge.success{background:#065f46;color:#6ee7b7}.dark-theme .badge.warning{background:#78350f;color:#fcd34d}.dark-theme .badge.error{background:#7f1d1d;color:#fca5a5}.dark-theme .page-header{background:#0f172a;border-bottom-color:#334155}.dark-theme .page-header h2,.dark-theme .page-header h3{color:#f1f5f9}.dark-theme .page-count{color:#94a3b8}.dark-theme .page-count strong{color:#3b82f6}.dark-theme .page-header-actions button{background:#334155;color:#e2e8f0;border-color:#475569}.dark-theme .page-header-actions button:hover{background:#475569;color:#f1f5f9}.dark-theme .hero-list-section{background:#1e293b;box-shadow:0 2px 8px #0003}.dark-theme .hero-list-section h3{color:#f1f5f9}.dark-theme .hero-card{background:#0f172a}.dark-theme .hero-card:hover{box-shadow:0 8px 20px #0000004d}.dark-theme .hero-card-content{background:#0f172a}.dark-theme .hero-card-content h4{color:#f1f5f9}.dark-theme .hero-card-content p{color:#94a3b8}.dark-theme .hero-card-meta{color:#64748b}.dark-theme .hero-card-actions button{background:#334155;color:#94a3b8}.dark-theme .hero-card-actions button:hover{background:#475569;color:#f1f5f9}.dark-theme .hero-card-actions button.delete:hover{background:#7f1d1d;color:#fca5a5}.dark-theme .api-bar-container{background:#334155}.dark-theme .api-call-item .api-name{color:#e2e8f0}.dark-theme .api-call-item .api-count{color:#3b82f6}.dark-theme .chart-card{background:#0f172a}.dark-theme .chart-card h4{color:#e2e8f0}.dark-theme .charts-grid{background:transparent}.dark-theme .charts-empty{color:#94a3b8}.dark-theme .visit-stats-header,.dark-theme .visit-stats-header h3{color:#f1f5f9}.dark-theme .period-filter-tabs{background:#0f172a}.dark-theme .period-tab{color:#94a3b8;background:transparent}.dark-theme .period-tab:hover{background:#1e293b;color:#f1f5f9}.dark-theme .period-tab.active{background:#3b82f6;color:#fff}.dark-theme .visit-chart-header{border-bottom-color:#334155}.dark-theme .visit-chart-header h4,.dark-theme .visit-chart-container h4{color:#f1f5f9}.dark-theme .visit-list{background:#0f172a}.dark-theme .visit-item{background:#1e293b}.dark-theme .visit-item:hover{background:#334155}.dark-theme .visit-item .page-label{color:#e2e8f0}.dark-theme .visit-item .visit-count{color:#3b82f6}.dark-theme .visit-item .visit-bar{background:#334155}.dark-theme .visit-item .visit-bar-fill{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.dark-theme .chart-legend{color:#94a3b8}.dark-theme .chart-tooltip{background:#1e293b;color:#f1f5f9}.dark-theme .total-visits-card{background:linear-gradient(135deg,#1e40af,#3b82f6)}.dark-theme .today-visits-card{background:linear-gradient(135deg,#065f46,#10b981)}.dark-theme .search-stats-header h3{color:#f1f5f9}.dark-theme .search-keyword-list{background:#0f172a}.dark-theme .search-keyword-item{background:#1e293b}.dark-theme .search-keyword-item:hover{background:#334155}.dark-theme .search-keyword-item .keyword{color:#e2e8f0}.dark-theme .search-keyword-item .count{color:#3b82f6}.dark-theme .sidebar-footer{background:#0f172a;border-top-color:#1e293b}.dark-theme .user-info{color:#94a3b8}.dark-theme .user-email{color:#e2e8f0}.dark-theme .logout-btn{background:#334155;color:#e2e8f0}.dark-theme .logout-btn:hover{background:#475569;color:#f1f5f9}.dark-theme .nav-section-title{color:#64748b}.dark-theme .nav-item{color:#94a3b8}.dark-theme .nav-item:hover{background:#1e293b;color:#f1f5f9}.dark-theme .nav-item.active{background:#3b82f6;color:#fff}.dark-theme .mobile-menu-btn{background:#334155;color:#e2e8f0}.dark-theme .mobile-menu-btn:hover{background:#475569}.dark-theme .api-fetch-section{background:linear-gradient(135deg,#1e3a5f,#1e293b);border-color:#3b82f6}.dark-theme .api-fetch-label{color:#93c5fd}.dark-theme .api-fetch-desc{color:#60a5fa}.dark-theme .stat-value.not-loaded{color:#64748b}.dark-theme .stats-grid{background:#0f172a}.dark-theme .top-stats{background:transparent}.dark-theme .top-stat-card{background:#0f172a}.dark-theme .top-stat-card .top-label{color:#94a3b8}.dark-theme .top-stat-card .top-value{color:#e2e8f0}.dark-theme .top-stat-card .top-value.empty{color:#64748b}.dark-theme .top-stat-card .top-value strong{color:#3b82f6}.dark-theme .api-call-list{background:#0f172a}.dark-theme .api-call-item{border-bottom-color:#334155}.dark-theme .api-stats-header h3{color:#f1f5f9}.dark-theme .reset-stats-btn{background:#334155;color:#94a3b8;border-color:#475569}.dark-theme .reset-stats-btn:hover{background:#475569;color:#f1f5f9}.dark-theme .visit-stats-summary{background:transparent}.dark-theme .visit-stat-card{background:#0f172a}.dark-theme .visit-stat-card .visit-label{color:#94a3b8}.dark-theme .visit-stat-card .visit-value{color:#e2e8f0}.dark-theme .visit-stat-card .visit-value.empty{color:#64748b}.dark-theme .visit-stat-card .visit-value strong{color:#3b82f6}.dark-theme .visit-bar-chart{background:#0f172a}.dark-theme .visit-bar-item{border-bottom-color:#334155}.dark-theme .visit-bar-item .visit-page-name{color:#e2e8f0}.dark-theme .visit-bar-item .visit-count{color:#3b82f6}.dark-theme .visit-bar-item .visit-bar-container{background:#334155}.dark-theme .today-visits-container{background:#0f172a}.dark-theme .today-visits-container h4{color:#f1f5f9}.dark-theme .today-visits-grid{background:transparent}.dark-theme .today-visit-card{background:#1e293b}.dark-theme .today-visit-card .today-page-name{color:#94a3b8}.dark-theme .today-visit-card .today-visit-count{color:#f1f5f9}.dark-theme .search-stats-section{background:#1e293b}.dark-theme .search-stats-section h3{color:#f1f5f9}.dark-theme .search-stats-summary{background:transparent}.dark-theme .search-stat-card{background:#0f172a}.dark-theme .search-stat-card .search-label{color:#94a3b8}.dark-theme .search-stat-card .search-value{color:#e2e8f0}.dark-theme .search-stat-card .search-value.empty{color:#64748b}.dark-theme .search-stat-card .search-value strong{color:#3b82f6}.dark-theme .popular-searches-container{background:#0f172a}.dark-theme .popular-searches-container h4{color:#f1f5f9}.dark-theme .popular-searches-list{background:transparent}.dark-theme .popular-search-item{background:#1e293b}.dark-theme .popular-search-item:hover{background:#334155}.dark-theme .popular-search-item .search-rank{color:#3b82f6}.dark-theme .popular-search-item .search-query{color:#e2e8f0}.dark-theme .popular-search-item .search-count{color:#94a3b8}.dark-theme .today-searches-container{background:#0f172a}.dark-theme .today-searches-container h4{color:#f1f5f9}.dark-theme .today-searches-list{background:transparent}.dark-theme .today-search-tag{background:#334155;border-color:#475569}.dark-theme .today-search-tag .tag-rank{color:#3b82f6}.dark-theme .today-search-tag .tag-query{color:#e2e8f0}.dark-theme .today-search-tag .tag-count{color:#94a3b8}.dark-theme .no-data-text{color:#64748b}.dark-theme .data-source-tabs{background:#0f172a}.dark-theme .source-tab{background:transparent;color:#94a3b8;border-color:transparent}.dark-theme .source-tab:hover{background:#1e293b;color:#f1f5f9}.dark-theme .source-tab.active{background:#1e293b;color:#3b82f6;border-color:#3b82f6}.dark-theme .source-tab .source-count{color:#64748b}.dark-theme .bulk-save-btn{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.dark-theme .bulk-save-btn:hover{background:linear-gradient(135deg,#2563eb,#1e40af)}.dark-theme .bulk-save-btn:disabled{background:#334155;color:#64748b}.dark-theme .quick-links{background:transparent}.dark-theme .quick-link{background:#334155;color:#e2e8f0;border-color:#475569}.dark-theme .quick-link:hover{background:#475569;color:#f1f5f9}.dark-theme .supabase-link{color:#3b82f6}.dark-theme .supabase-link:hover{color:#60a5fa}.dark-theme .table-wrapper{background:#0f172a}.dark-theme .users-section,.dark-theme .places-section,.dark-theme .events-section,.dark-theme .settings-section,.dark-theme .hero-management{background:transparent}.dark-theme .hero-loading{color:#94a3b8}.dark-theme .inactive-badge{background:#7f1d1d;color:#fca5a5}.dark-theme .image-preview{background:#0f172a}.dark-theme .form-actions{background:transparent}.dark-theme .save-btn{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.dark-theme .save-btn:hover{background:linear-gradient(135deg,#2563eb,#1e40af)}.dark-theme .cancel-btn{background:#334155;color:#e2e8f0}.dark-theme .cancel-btn:hover{background:#475569}.dark-theme .edit-btn{background:#334155;color:#3b82f6}.dark-theme .edit-btn:hover{background:#3b82f6;color:#fff}.dark-theme .delete-btn{background:#334155;color:#f87171}.dark-theme .delete-btn:hover{background:#7f1d1d;color:#fca5a5}.dark-theme .page-loading{color:#94a3b8}.dark-theme .saving-spinner{border-color:#475569;border-top-color:#3b82f6}.dark-theme .loading-icon{color:#3b82f6}@media (max-width: 768px){.api-stats-grid{grid-template-columns:1fr}}.courses-management{padding:0}.trip-stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.trip-stat-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000000d}.trip-stat-card .stat-icon{font-size:24px;color:#10b981;padding:12px;background:#ecfdf5;border-radius:10px}.trip-stat-card .stat-info{display:flex;flex-direction:column}.trip-stat-card .stat-value{font-size:1.5rem;font-weight:700;color:#1a1a2e}.trip-stat-card .stat-label{font-size:.85rem;color:#666}.trip-edit-form{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 2px 8px #0000000d}.trip-edit-form h3{margin-bottom:20px;color:#1a1a2e}.trip-edit-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.trip-edit-form .form-group{margin-bottom:16px;padding:0;background:transparent}.trip-edit-form .form-group label{font-weight:500;margin-bottom:8px;display:block}.trip-edit-form .form-group input,.trip-edit-form .form-group textarea{width:100%;padding:10px 14px;border:1px solid #e0e0e0;border-radius:8px;font-size:.95rem}.trip-edit-form .form-group textarea{resize:vertical}.trip-edit-form .form-actions{display:flex;gap:12px;margin-top:20px}.trip-edit-form .btn-save,.trip-edit-form .btn-cancel{padding:10px 20px;border:none;border-radius:8px;font-size:.95rem;cursor:pointer;display:flex;align-items:center;gap:8px}.trip-edit-form .btn-save{background:#10b981;color:#fff}.trip-edit-form .btn-save:hover{background:#059669}.trip-edit-form .btn-cancel{background:#f1f5f9;color:#64748b}.trip-edit-form .btn-cancel:hover{background:#e2e8f0}.trips-list{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.trips-table{width:100%;border-collapse:collapse}.trips-table th,.trips-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #f1f5f9}.trips-table th{background:#f8fafc;font-weight:600;color:#475569;font-size:.85rem;text-transform:uppercase}.trips-table tr:hover{background:#f8fafc}.trip-thumbnail{width:60px;height:40px;border-radius:6px;overflow:hidden;background:#f1f5f9}.trip-thumbnail img{width:100%;height:100%;object-fit:cover}.trip-thumbnail .no-thumbnail{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#94a3b8}.trip-title-link{color:#1a1a2e;text-decoration:none;font-weight:500}.trip-title-link:hover{color:#10b981;text-decoration:underline}.trip-actions{display:flex;gap:8px}.trip-actions button{padding:8px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.trip-actions .btn-edit{background:#f0f9ff;color:#0284c7}.trip-actions .btn-edit:hover{background:#e0f2fe}.trip-actions .btn-toggle{background:#fef3c7;color:#d97706}.trip-actions .btn-toggle.published{background:#ecfdf5;color:#10b981}.trip-actions .btn-toggle:hover{opacity:.8}.trip-actions .btn-delete{background:#fef2f2;color:#dc2626}.trip-actions .btn-delete:hover{background:#fee2e2}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#64748b}.loading-container .spinning{animation:spin 1s linear infinite}.dark-theme .trip-stat-card{background:#1e293b}.dark-theme .trip-stat-card .stat-icon{background:#10b98126}.dark-theme .trip-stat-card .stat-value{color:#f1f5f9}.dark-theme .trip-stat-card .stat-label{color:#94a3b8}.dark-theme .trip-edit-form{background:#1e293b}.dark-theme .trip-edit-form h3{color:#f1f5f9}.dark-theme .trip-edit-form .form-group input,.dark-theme .trip-edit-form .form-group textarea{background:#0f172a;border-color:#334155;color:#f1f5f9}.dark-theme .trip-edit-form .btn-cancel{background:#334155;color:#94a3b8}.dark-theme .trips-list{background:#1e293b}.dark-theme .trips-table th{background:#0f172a;color:#94a3b8}.dark-theme .trips-table td{border-color:#334155}.dark-theme .trips-table tr:hover,.dark-theme .trip-thumbnail{background:#334155}.dark-theme .trip-title-link{color:#f1f5f9}.dark-theme .trip-actions .btn-edit{background:#0284c726}.dark-theme .trip-actions .btn-toggle{background:#d9770626}.dark-theme .trip-actions .btn-toggle.published{background:#10b98126}.dark-theme .trip-actions .btn-delete{background:#dc262626}@media (max-width: 768px){.trip-stats-cards,.trip-edit-form .form-row{grid-template-columns:1fr}.trips-table{display:block;overflow-x:auto}}.my-trip-page{min-height:100vh;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);padding:96px 24px 24px}.my-trip-page.dark-theme{background:linear-gradient(135deg,#0f172a,#1e293b)}.trip-container{max-width:1400px;margin:0 auto}.trip-login-required{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:40px}.trip-login-required .login-icon{font-size:4rem;color:#0284c7;margin-bottom:20px}.dark-theme .trip-login-required .login-icon{color:#38bdf8}.trip-login-required h2{font-size:1.8rem;color:#0f172a;margin-bottom:12px}.dark-theme .trip-login-required h2{color:#f1f5f9}.trip-login-required p{color:#64748b;margin-bottom:24px}.trip-login-required .login-link{padding:12px 32px;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;text-decoration:none;border-radius:12px;font-weight:600;transition:all .3s ease}.trip-login-required .login-link:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0284c74d}.trip-login-required .kakao-login-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;background:#fee500;color:#191919;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:200px}.trip-login-required .kakao-login-btn:hover{background:#f5dc00;transform:translateY(-2px);box-shadow:0 8px 20px #fee50066}.trip-login-required .kakao-login-btn svg{flex-shrink:0}.auth-loading{display:flex;flex-direction:column;align-items:center;gap:16px}.auth-loading .loading-spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#0284c7;border-radius:50%;animation:spin 1s linear infinite}.auth-loading p{color:#64748b;margin:0}.trip-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding:24px;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014}.dark-theme .trip-header{background:#1e293b;box-shadow:0 4px 20px #0000004d}.trip-header-content h1{display:flex;align-items:center;gap:12px;font-size:1.8rem;color:#0f172a;margin:0 0 8px}.dark-theme .trip-header-content h1{color:#f1f5f9}.trip-header-content h1 svg{color:#0284c7}.trip-header-content p{color:#64748b;margin:0}.trip-header-actions{display:flex;gap:12px;align-items:center}.view-toggle{display:flex;background:#f1f5f9;border-radius:8px;padding:4px}.dark-theme .view-toggle{background:#374151}.view-toggle button{padding:8px 12px;border:none;background:transparent;color:#64748b;border-radius:6px;cursor:pointer;transition:all .2s ease}.view-toggle button.active{background:#fff;color:#0284c7;box-shadow:0 2px 8px #0000001a}.dark-theme .view-toggle button.active{background:#1e293b;color:#38bdf8}.create-trip-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease}.create-trip-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0284c74d}.trip-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.trip-modal{background:#fff;border-radius:20px;width:90%;max-width:500px;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease}.dark-theme .trip-modal{background:#1e293b}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0}.dark-theme .modal-header{border-bottom-color:#374151}.modal-header h2{margin:0;font-size:1.25rem;color:#0f172a}.dark-theme .modal-header h2{color:#f1f5f9}.modal-close{padding:8px;border:none;background:#f1f5f9;border-radius:8px;cursor:pointer;color:#64748b;transition:all .2s ease}.dark-theme .modal-close{background:#374151;color:#9ca3af}.modal-close:hover{background:#e2e8f0;color:#0f172a}.modal-body{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;color:#374151;margin-bottom:8px;font-size:.9rem}.dark-theme .form-group label{color:#e5e7eb}.form-group input,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;transition:border-color .2s ease;box-sizing:border-box}.dark-theme .form-group input,.dark-theme .form-group textarea{background:#374151;border-color:#4b5563;color:#f1f5f9}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#0284c7}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e2e8f0}.dark-theme .modal-footer{border-top-color:#374151}.cancel-btn{padding:10px 20px;border:2px solid #e2e8f0;background:#fff;color:#64748b;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s ease}.dark-theme .cancel-btn{background:#374151;border-color:#4b5563;color:#9ca3af}.cancel-btn:hover{border-color:#cbd5e1;color:#374151}.save-btn{display:flex;align-items:center;gap:8px;padding:10px 24px;border:none;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s ease}.save-btn:hover{box-shadow:0 4px 12px #0284c74d}.trip-main{display:grid;grid-template-columns:320px 1fr;gap:24px;min-height:500px}@media (max-width: 900px){.trip-main{grid-template-columns:1fr}}.trip-sidebar{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 20px #00000014;height:fit-content;max-height:calc(100vh - 200px);overflow-y:auto}.dark-theme .trip-sidebar{background:#1e293b;box-shadow:0 4px 20px #0000004d}.trip-sidebar h3{font-size:1rem;color:#374151;margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid #e2e8f0}.dark-theme .trip-sidebar h3{color:#e5e7eb;border-bottom-color:#374151}.trip-loading{display:flex;flex-direction:column;align-items:center;padding:40px;color:#64748b}.loading-spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top-color:#0284c7;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.no-trips{display:flex;flex-direction:column;align-items:center;padding:40px 20px;text-align:center}.no-trips svg{font-size:3rem;color:#cbd5e1;margin-bottom:16px}.no-trips p{color:#64748b;margin-bottom:16px}.no-trips button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#f1f5f9;border:2px dashed #cbd5e1;border-radius:10px;color:#64748b;font-weight:500;cursor:pointer;transition:all .2s ease}.no-trips button:hover{background:#e2e8f0;border-color:#0284c7;color:#0284c7}.trip-list{display:flex;flex-direction:column;gap:12px}.trip-list.grid{display:grid;grid-template-columns:1fr;gap:12px}.trip-card{background:#f8fafc;border:2px solid transparent;border-radius:12px;padding:16px;cursor:pointer;transition:all .2s ease}.dark-theme .trip-card{background:#374151}.trip-card:hover{border-color:#0284c7;transform:translateY(-2px);box-shadow:0 4px 12px #0284c726}.trip-card.selected{border-color:#0284c7;background:#f0f9ff}.dark-theme .trip-card.selected{background:#0284c733}.trip-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.trip-card-header h4{margin:0;font-size:1rem;color:#0f172a}.dark-theme .trip-card-header h4{color:#f1f5f9}.delete-trip-btn{padding:6px;border:none;background:transparent;color:#94a3b8;border-radius:6px;cursor:pointer;transition:all .2s ease}.delete-trip-btn:hover{background:#fee2e2;color:#ef4444}.trip-card-info{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.trip-dates{display:flex;align-items:center;gap:4px;font-size:.8rem;color:#64748b}.trip-duration{padding:2px 8px;background:#dbeafe;color:#1d4ed8;border-radius:20px;font-size:.75rem;font-weight:600}.dark-theme .trip-duration{background:#3b82f633;color:#60a5fa}.trip-description{font-size:.85rem;color:#64748b;margin:0 0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trip-card-stats{display:flex;gap:12px;font-size:.8rem;color:#64748b}.trip-card-stats span{display:flex;align-items:center;gap:4px}.trip-card-actions{display:flex;justify-content:flex-end;margin-top:12px;padding-top:12px;border-top:1px solid #e2e8f0}.dark-theme .trip-card-actions{border-top-color:#374151}.publish-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.publish-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.publish-btn:disabled{opacity:.5;cursor:not-allowed}.publish-btn.published{background:linear-gradient(135deg,#10b981,#059669)}.publish-btn.published:hover{background:linear-gradient(135deg,#ef4444,#dc2626)}.publish-modal{max-width:480px;width:90%}.publish-info{background:#e0f2fe;border:1px solid #7dd3fc;border-radius:8px;padding:12px 16px;color:#0369a1;font-size:.9rem;margin-bottom:20px}.dark-theme .publish-info{background:#1e3a5f;border-color:#3b82f6;color:#93c5fd}.publish-confirm-btn{display:flex;align-items:center;gap:8px;padding:10px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.publish-confirm-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.trip-detail{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014;flex:1}.dark-theme .trip-detail{background:#1e293b;box-shadow:0 4px 20px #0000004d}.trip-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid #e2e8f0}.dark-theme .trip-detail-header{border-bottom-color:#374151}.trip-detail-title h2{margin:0 0 8px;font-size:1.5rem;color:#0f172a}.dark-theme .trip-detail-title h2{color:#f1f5f9}.trip-period{display:flex;align-items:center;gap:8px;color:#64748b;font-size:.95rem}.close-detail{padding:8px;border:none;background:#f1f5f9;border-radius:8px;color:#64748b;cursor:pointer;transition:all .2s ease}.dark-theme .close-detail{background:#374151}.close-detail:hover{background:#e2e8f0;color:#0f172a}.place-search-section{background:#f8fafc;border-radius:12px;padding:20px;margin-bottom:24px}.dark-theme .place-search-section{background:#374151}.place-search-section h3{display:flex;align-items:center;gap:8px;margin:0 0 16px;font-size:1rem;color:#374151}.dark-theme .place-search-section h3{color:#e5e7eb}.search-controls{display:flex;gap:12px}.search-controls select{padding:10px 16px;border:2px solid #e2e8f0;border-radius:10px;background:#fff;font-size:.95rem;cursor:pointer}.dark-theme .search-controls select{background:#1e293b;border-color:#4b5563;color:#f1f5f9}.search-input-wrapper{flex:1;display:flex;gap:8px}.search-input-wrapper input{flex:1;padding:10px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:.95rem}.dark-theme .search-input-wrapper input{background:#1e293b;border-color:#4b5563;color:#f1f5f9}.search-input-wrapper input:focus{outline:none;border-color:#0284c7}.search-input-wrapper button{padding:10px 20px;border:none;background:#0284c7;color:#fff;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s ease}.search-input-wrapper button:hover{background:#0369a1}.search-input-wrapper button:disabled{background:#cbd5e1;cursor:not-allowed}.search-results{margin-top:16px;max-height:300px;overflow-y:auto}.search-result-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#fff;border-radius:8px;margin-bottom:8px}.dark-theme .search-result-item{background:#1e293b}.result-info{display:flex;align-items:center;gap:12px}.result-type{padding:8px;background:#dbeafe;border-radius:8px;color:#1d4ed8}.result-text strong{display:block;color:#0f172a;margin-bottom:2px}.dark-theme .result-text strong{color:#f1f5f9}.result-text small{color:#64748b;font-size:.8rem}.result-actions{display:flex;gap:6px}.add-to-day-btn{padding:6px 12px;border:none;background:#e0f2fe;color:#0284c7;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease}.add-to-day-btn:hover{background:#0284c7;color:#fff}.trip-days{display:flex;flex-direction:column;gap:12px}.trip-day{background:#f8fafc;border-radius:12px;overflow:hidden}.dark-theme .trip-day{background:#374151}.day-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;cursor:pointer;transition:background .2s ease}.day-header:hover{background:#f1f5f9}.dark-theme .day-header:hover{background:#4b5563}.day-info{display:flex;align-items:center;gap:12px}.day-number{font-weight:700;color:#0284c7;font-size:1rem}.day-date{color:#64748b;font-size:.9rem}.day-place-count{padding:2px 8px;background:#e2e8f0;border-radius:20px;font-size:.75rem;color:#64748b}.dark-theme .day-place-count{background:#4b5563}.day-header svg{color:#64748b;transition:transform .2s ease}.trip-day.expanded .day-header svg{transform:rotate(180deg)}.day-content{padding:0 20px 20px}.no-places{text-align:center;padding:24px;color:#64748b}.no-places p{margin:0 0 4px}.no-places small{font-size:.85rem}.places-list{display:flex;flex-direction:column;gap:12px}.place-item{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000d}.dark-theme .place-item{background:#1e293b}.place-order{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#0284c7;color:#fff;font-weight:700;font-size:.85rem;border-radius:50%;flex-shrink:0}.place-image{width:60px;height:60px;border-radius:8px;background-size:cover;background-position:center;flex-shrink:0}.place-info{flex:1;min-width:0}.place-info h5{display:flex;align-items:center;gap:6px;margin:0 0 4px;font-size:.95rem;color:#0f172a}.dark-theme .place-info h5{color:#f1f5f9}.place-info h5 svg{color:#0284c7;flex-shrink:0}.place-info p{margin:0;font-size:.8rem;color:#64748b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.place-info small{color:#94a3b8;font-size:.75rem}.remove-place{padding:8px;border:none;background:transparent;color:#94a3b8;border-radius:6px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.remove-place:hover{background:#fee2e2;color:#ef4444}.trip-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff;border-radius:16px;padding:60px 40px;text-align:center;box-shadow:0 4px 20px #00000014}.dark-theme .trip-placeholder{background:#1e293b}.trip-placeholder svg{font-size:4rem;color:#cbd5e1;margin-bottom:20px}.trip-placeholder h3{margin:0 0 12px;color:#374151}.dark-theme .trip-placeholder h3{color:#e5e7eb}.trip-placeholder p{color:#64748b;margin:0}@media (max-width: 768px){.my-trip-page{padding:16px}.trip-header{flex-direction:column;gap:16px}.trip-header-actions{width:100%;justify-content:space-between}.trip-main{grid-template-columns:1fr}.trip-sidebar{max-height:none}.trip-sidebar.collapsed{display:none}.form-row{grid-template-columns:1fr}.search-controls{flex-direction:column}.place-item{flex-wrap:wrap}.place-image{width:100%;height:120px}}.transport-connector{padding:8px 0;margin-left:20px;transition:all .3s ease;border-radius:8px}.transport-connector.highlighted{background:linear-gradient(90deg,#3b82f626,#3b82f60d);border-left:3px solid #3B82F6;padding-left:12px;margin-left:17px;animation:highlight-pulse 1.5s ease-in-out}@keyframes highlight-pulse{0%{background:#3b82f64d}50%{background:#3b82f626}to{background:linear-gradient(90deg,#3b82f626,#3b82f60d)}}.dark-theme .transport-connector.highlighted{background:linear-gradient(90deg,#3b82f640,#3b82f61a);border-left-color:#60a5fa}.transport-display{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease}.transport-display:hover{background:#f1f5f9}.dark-theme .transport-display:hover{background:#374151}.transport-line{flex:1;height:2px;background:linear-gradient(90deg,transparent,#cbd5e1,transparent)}.dark-theme .transport-line{background:linear-gradient(90deg,transparent,#475569,transparent)}.transport-icon-wrapper{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:20px;color:#64748b;transition:all .2s ease}.dark-theme .transport-icon-wrapper{background:#1e293b;border-color:#475569;color:#94a3b8}.transport-display:hover .transport-icon-wrapper{border-color:#0284c7;background:#e0f2fe;color:#0284c7}.dark-theme .transport-display:hover .transport-icon-wrapper{border-color:#38bdf8;background:#0c4a6e;color:#38bdf8}.transport-change-btn{position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;border:none;background:#f1f5f9;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;transition:all .2s ease;opacity:0}.transport-icon-wrapper{position:relative}.transport-icon-wrapper:hover .transport-change-btn{opacity:1}.transport-change-btn:hover{background:#0284c7;color:#fff}.dark-theme .transport-change-btn{background:#334155;color:#94a3b8}.dark-theme .transport-change-btn:hover{background:#38bdf8;color:#0f172a}.transport-icon{font-size:1.2rem;color:#0284c7}.dark-theme .transport-icon{color:#38bdf8}.transport-text{font-size:.85rem;font-weight:500}.transport-details{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.transport-time{font-size:.75rem;color:#0284c7;font-weight:600;display:flex;align-items:center;gap:4px}.dark-theme .transport-time{color:#38bdf8}.transport-time.loading{color:#94a3b8}.transport-time small{font-size:.65rem;color:#64748b;font-weight:400}.transport-time .estimate-note{color:#ff9800;font-weight:500;font-size:.7rem}.transport-add{font-size:1rem}.transport-hint{font-size:.8rem}.transport-selector{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border-radius:12px;border:2px solid #0284c7}.dark-theme .transport-selector{background:#1e293b;border-color:#38bdf8}.transport-label{font-size:.85rem;color:#475569;font-weight:500}.dark-theme .transport-label{color:#94a3b8}.transport-options{display:flex;gap:8px}.transport-option{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:2px solid #e2e8f0;border-radius:10px;background:#fff;color:#64748b;cursor:pointer;transition:all .2s ease;font-size:1.1rem}.dark-theme .transport-option{background:#0f172a;border-color:#475569;color:#94a3b8}.transport-option:hover{border-color:#0284c7;color:#0284c7;transform:scale(1.1)}.dark-theme .transport-option:hover{border-color:#38bdf8;color:#38bdf8}.transport-option.selected{background:#0284c7;border-color:#0284c7;color:#fff}.dark-theme .transport-option.selected{background:#0369a1;border-color:#38bdf8}.transport-cancel{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:#fee2e2;color:#dc2626;cursor:pointer;transition:all .2s ease}.dark-theme .transport-cancel{background:#450a0a;color:#f87171}.transport-cancel:hover{background:#dc2626;color:#fff}@media (max-width: 768px){.transport-selector{flex-wrap:wrap;gap:8px}.transport-options{flex-wrap:wrap}.transport-option{width:36px;height:36px}}.place-actions{display:flex;flex-direction:column;gap:8px}.parking-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#64748b;cursor:pointer;transition:all .2s ease}.dark-theme .parking-btn{background:#1e293b;border-color:#475569;color:#94a3b8}.parking-btn:hover,.parking-btn.active{border-color:#0284c7;background:#e0f2fe;color:#0284c7}.dark-theme .parking-btn:hover,.dark-theme .parking-btn.active{border-color:#38bdf8;background:#0c4a6e;color:#38bdf8}.parking-list{margin:8px 0 8px 40px;background:#f8fafc;border-radius:12px;padding:12px;border:1px solid #e2e8f0}.dark-theme .parking-list{background:#1e293b;border-color:#374151}.parking-header{display:flex;align-items:center;gap:8px;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid #e2e8f0;color:#0284c7;font-weight:600}.dark-theme .parking-header{border-bottom-color:#374151;color:#38bdf8}.parking-header button{margin-left:auto;background:none;border:none;color:#64748b;cursor:pointer;padding:4px}.parking-header button:hover{color:#dc2626}.parking-loading,.parking-empty{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px;color:#64748b}.dark-theme .parking-loading,.dark-theme .parking-empty{color:#94a3b8}.parking-item{padding:10px;margin-bottom:8px;background:#fff;border-radius:8px;border:1px solid #e2e8f0}.dark-theme .parking-item{background:#0f172a;border-color:#374151}.parking-item:last-child{margin-bottom:0}.parking-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.parking-info strong{font-size:.9rem;color:#1e293b}.dark-theme .parking-info strong{color:#f1f5f9}.parking-distance{font-size:.8rem;font-weight:600;color:#0284c7;background:#e0f2fe;padding:2px 8px;border-radius:10px}.dark-theme .parking-distance{color:#38bdf8;background:#0c4a6e}.parking-details{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:4px}.parking-type,.parking-charge,.parking-capacity{font-size:.75rem;padding:2px 6px;border-radius:4px}.parking-type{background:#f1f5f9;color:#475569}.parking-type.public{background:#dcfce7;color:#166534}.parking-type.private{background:#fef3c7;color:#92400e}.parking-charge{background:#f1f5f9;color:#475569}.parking-charge.free{background:#dbeafe;color:#1e40af}.parking-charge.paid{background:#fee2e2;color:#991b1b}.dark-theme .parking-type,.dark-theme .parking-charge,.dark-theme .parking-capacity{background:#374151;color:#94a3b8}.dark-theme .parking-type.public{background:#14532d;color:#86efac}.dark-theme .parking-type.private{background:#78350f;color:#fcd34d}.dark-theme .parking-charge.free{background:#1e3a5f;color:#93c5fd}.dark-theme .parking-charge.paid{background:#450a0a;color:#fca5a5}.parking-capacity{background:#f3e8ff;color:#7e22ce}.dark-theme .parking-capacity{background:#3b0764;color:#d8b4fe}.parking-addr{color:#64748b;font-size:.75rem;line-height:1.4;display:block}.dark-theme .parking-addr{color:#94a3b8}.place-wrapper{transition:all .2s ease}.place-wrapper.drag-over{transform:translateY(4px)}.place-wrapper.drag-over:before{content:"";display:block;height:4px;background:linear-gradient(90deg,transparent,#0284c7,transparent);border-radius:2px;margin-bottom:8px}.dark-theme .place-wrapper.drag-over:before{background:linear-gradient(90deg,transparent,#38bdf8,transparent)}.place-item{cursor:grab;transition:all .2s ease}.place-item:active{cursor:grabbing}.place-item.dragging{opacity:.5;transform:scale(.98);box-shadow:0 10px 30px #00000026}.dark-theme .place-item.dragging{box-shadow:0 10px 30px #0006}.drag-handle{display:flex;align-items:center;justify-content:center;width:24px;color:#94a3b8;cursor:grab;transition:color .2s ease}.drag-handle:active{cursor:grabbing}.drag-handle:hover{color:#0284c7}.dark-theme .drag-handle{color:#64748b}.dark-theme .drag-handle:hover{color:#38bdf8}.trip-map-panel{position:fixed;top:96px;right:24px;width:400px;height:calc(100vh - 120px);background:#fff;border-radius:16px;box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;z-index:100;transition:all .3s ease}.trip-map-panel.expanded{width:60vw;max-width:900px}.dark-theme .trip-map-panel{background:#1e293b;box-shadow:0 8px 32px #0006}.map-panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e2e8f0}.dark-theme .map-panel-header{border-bottom-color:#334155}.map-panel-header h3{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:600;color:#0f172a;margin:0}.dark-theme .map-panel-header h3{color:#f1f5f9}.map-panel-header h3 svg{color:#0284c7}.dark-theme .map-panel-header h3 svg{color:#38bdf8}.map-panel-actions{display:flex;gap:8px}.map-panel-actions button{width:32px;height:32px;border:none;border-radius:8px;background:#f1f5f9;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.map-panel-actions button:hover{background:#e2e8f0;color:#0284c7}.dark-theme .map-panel-actions button{background:#334155;color:#94a3b8}.dark-theme .map-panel-actions button:hover{background:#475569;color:#38bdf8}.map-container{flex:1;min-height:300px;border-radius:0 0 12px 12px;overflow:hidden}.map-legend{display:flex;gap:16px;padding:12px 20px;border-top:1px solid #e2e8f0;background:#f8fafc}.dark-theme .map-legend{border-top-color:#334155;background:#0f172a}.legend-item{display:flex;align-items:center;gap:8px;font-size:.8rem;color:#64748b}.dark-theme .legend-item{color:#94a3b8}.legend-marker{width:20px;height:20px;background:#ff6b6b;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600}.legend-line{width:30px;height:3px;background:#3b82f6;border-radius:2px}.map-tip{padding:12px 20px;font-size:.75rem;color:#64748b;background:#f8fafc;border-radius:0 0 16px 16px}.dark-theme .map-tip{color:#94a3b8;background:#0f172a}.show-map-btn{position:fixed;top:108px;right:24px;display:flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;border:none;border-radius:12px;font-weight:600;cursor:pointer;z-index:100;box-shadow:0 4px 16px #0284c74d;transition:all .3s ease}.show-map-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0284c766}.custom-map-marker{display:flex;flex-direction:column;align-items:center;cursor:pointer}.marker-pin{width:32px;height:32px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003}.marker-number{transform:rotate(45deg);color:#fff;font-size:.85rem;font-weight:700}.marker-label{margin-top:4px;padding:4px 8px;background:#fff;border-radius:4px;font-size:.7rem;font-weight:600;color:#0f172a;white-space:nowrap;box-shadow:0 2px 8px #00000026;max-width:120px;overflow:hidden;text-overflow:ellipsis}.my-trip-page .trip-detail{margin-right:420px;transition:margin-right .3s ease}@media (max-width: 1200px){.trip-map-panel{width:350px}.my-trip-page .trip-detail{margin-right:370px}}@media (max-width: 1024px){.trip-map-panel{position:relative;top:0;right:0;width:100%;height:350px;margin-top:20px;margin-bottom:20px}.trip-map-panel.expanded{width:100%;height:500px;max-width:none}.my-trip-page .trip-detail{margin-right:0}.show-map-btn{position:relative;top:0;right:0;width:100%;justify-content:center;margin-bottom:16px}}.accommodation-section{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;padding:16px 20px;margin-bottom:20px}.dark-theme .accommodation-section{background:linear-gradient(135deg,#78350f,#92400e)}.accommodation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.accommodation-header h3{display:flex;align-items:center;gap:8px;margin:0;font-size:1rem;color:#92400e}.dark-theme .accommodation-header h3{color:#fde68a}.accommodation-edit-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;border:none;border-radius:8px;font-size:.85rem;color:#92400e;cursor:pointer;transition:all .2s ease}.dark-theme .accommodation-edit-btn{background:#ffffff1a;color:#fde68a}.accommodation-edit-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.accommodation-info{background:#fff;border-radius:8px;padding:12px 16px}.dark-theme .accommodation-info{background:#0003}.accommodation-info strong{display:block;color:#0f172a;font-size:.95rem;margin-bottom:4px}.dark-theme .accommodation-info strong{color:#f1f5f9}.accommodation-info p{margin:0;font-size:.8rem;color:#64748b}.dark-theme .accommodation-info p{color:#94a3b8}.accommodation-empty{text-align:center;padding:8px}.accommodation-empty p{margin:0;font-size:.85rem;color:#92400e;opacity:.8}.dark-theme .accommodation-empty p{color:#fde68a}.accommodation-modal{max-width:480px}.accommodation-search-wrapper{display:flex;gap:8px}.accommodation-search-wrapper input{flex:1}.accommodation-search-wrapper button{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#0284c7;border:none;border-radius:8px;color:#fff;cursor:pointer}.accommodation-search-results{max-height:200px;overflow-y:auto;margin-top:8px;border:1px solid #e2e8f0;border-radius:8px}.dark-theme .accommodation-search-results{border-color:#334155}.accommodation-result-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .2s ease;border-bottom:1px solid #e2e8f0}.accommodation-result-item:last-child{border-bottom:none}.dark-theme .accommodation-result-item{border-bottom-color:#334155}.accommodation-result-item:hover{background:#f1f5f9}.dark-theme .accommodation-result-item:hover{background:#334155}.accommodation-result-item svg{color:#f59e0b;font-size:1.2rem}.accommodation-result-item strong{display:block;color:#0f172a;font-size:.9rem}.dark-theme .accommodation-result-item strong{color:#f1f5f9}.accommodation-result-item small{display:block;color:#64748b;font-size:.75rem}.dark-theme .accommodation-result-item small{color:#94a3b8}.form-divider{display:flex;align-items:center;margin:20px 0}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.dark-theme .form-divider:before,.dark-theme .form-divider:after{background:#334155}.form-divider span{padding:0 16px;font-size:.8rem;color:#94a3b8}.day-start-accommodation{margin-bottom:16px}.accommodation-start-marker{display:flex;align-items:center;gap:12px;padding:12px 16px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px}.dark-theme .accommodation-start-marker{background:linear-gradient(135deg,#78350f,#92400e)}.accommodation-start-marker .accommodation-icon{font-size:1.5rem;color:#f59e0b}.dark-theme .accommodation-start-marker .accommodation-icon{color:#fde68a}.accommodation-start-info{flex:1}.accommodation-start-info .start-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:#92400e;margin-bottom:2px}.dark-theme .accommodation-start-info .start-label{color:#fde68a}.accommodation-start-info strong{display:block;font-size:.95rem;color:#0f172a}.dark-theme .accommodation-start-info strong{color:#f1f5f9}.accommodation-start-info small{display:block;font-size:.75rem;color:#64748b}.dark-theme .accommodation-start-info small{color:#94a3b8}.accommodation-connector{display:flex;justify-content:center;padding:8px 0}.accommodation-connector .connector-line{width:2px;height:24px;background:linear-gradient(to bottom,#f59e0b,#3b82f6);border-radius:1px}.accommodation-marker .accommodation-pin{background-color:#f59e0b!important;width:36px;height:36px}.accommodation-marker .marker-icon{font-size:1rem;transform:rotate(45deg)}.accommodation-marker .accommodation-label{background:#fef3c7;color:#92400e;border:1px solid #f59e0b}.route-details{margin-top:10px;display:flex;flex-direction:column;gap:8px}.route-detail-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f8fafc;border-radius:8px;font-size:.85rem}.route-badge{padding:4px 10px;border-radius:20px;font-weight:600;font-size:.8rem;color:#fff;white-space:nowrap;min-width:60px;text-align:center}.route-badge.bus{background:#22c55e}.route-badge.subway{background:#3b82f6}.route-stations{display:flex;align-items:center;gap:6px;color:#374151;flex:1;font-size:.8rem}.route-stations .arrow{color:#9ca3af;font-size:.75rem}.route-stations .station-count{color:#6b7280;font-size:.75rem;margin-left:auto}.route-walk{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#fef9c3;border-radius:8px;font-size:.8rem;color:#92400e}.route-walk .walk-icon{font-size:1rem}.no-route-message{padding:10px 14px;background:#fee2e2;border-radius:8px;color:#991b1b;font-size:.85rem;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}.no-route-message .info-icon{font-size:1rem}.payment-info{margin-top:8px;padding:8px 12px;background:#dbeafe;border-radius:8px;font-size:.85rem;color:#1e40af;text-align:center;font-weight:500}@media (max-width: 768px){.route-detail-item{flex-wrap:wrap;padding:6px 10px}.route-stations{width:100%;margin-top:4px}.route-badge{font-size:.75rem;padding:3px 8px;min-width:50px}}.available-buses{display:flex;align-items:center;gap:4px;margin-top:4px}.available-buses small{display:flex;align-items:center;gap:4px;color:#64748b}.alt-bus{display:inline-block;padding:2px 6px;border-radius:10px;font-size:.65rem;font-weight:600;color:#fff}.more-buses{color:#94a3b8;font-size:.65rem;margin-left:2px}.route-alternatives{margin-top:12px;padding-top:12px;border-top:1px dashed #e2e8f0}.dark-theme .route-alternatives{border-top-color:#334155}.route-alternatives-header{margin-bottom:8px}.route-alternatives-header small{color:#64748b;font-weight:500}.route-alternatives-list{display:flex;flex-direction:column;gap:6px}.route-alternative-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.8rem;text-align:left}.dark-theme .route-alternative-item{background:#1e293b;border-color:#334155}.route-alternative-item:hover{background:#e0f2fe;border-color:#0284c7}.dark-theme .route-alternative-item:hover{background:#0c4a6e;border-color:#38bdf8}.route-alt-time{font-weight:600;color:#0284c7;min-width:50px}.dark-theme .route-alt-time{color:#38bdf8}.route-alt-summary{color:#64748b;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dark-theme .route-alt-summary{color:#94a3b8}.shared-trip-page{min-height:100vh;background:var(--bg-primary)}.shared-trip-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px}.shared-trip-loading .loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.shared-trip-loading p{color:var(--text-secondary)}.shared-trip-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:40px 20px}.shared-trip-error h2{font-size:1.5rem;color:var(--text-primary);margin-bottom:12px}.shared-trip-error p{color:var(--text-secondary);margin-bottom:24px}.back-home-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--primary-color);color:#fff;border-radius:var(--border-radius);font-weight:500;transition:var(--transition)}.back-home-btn:hover{background:var(--primary-hover);transform:translateY(-2px)}.shared-trip-hero{position:relative;min-height:300px;padding:100px 20px 40px;background-size:cover;background-position:center;display:flex;flex-direction:column;justify-content:flex-end}.back-btn{position:absolute;top:20px;left:20px;display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ffffffe6;color:var(--text-primary);border:none;border-radius:var(--border-radius);cursor:pointer;font-weight:500;transition:var(--transition)}.back-btn:hover{background:#fff;transform:translate(-4px)}.hero-content{max-width:800px;margin:0 auto;width:100%}.trip-title{font-size:2rem;font-weight:700;color:#fff;margin-bottom:16px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.trip-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px}.meta-item{display:flex;align-items:center;gap:6px;color:#ffffffe6;font-size:.95rem}.meta-item svg{font-size:1rem}.trip-actions{display:flex;gap:12px}.action-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#ffffffe6;color:var(--text-primary);border:none;border-radius:var(--border-radius);cursor:pointer;font-weight:500;transition:var(--transition)}.action-btn:hover{background:#fff;transform:translateY(-2px)}.action-btn.like-btn.liked{background:#ff4757;color:#fff}.action-btn.like-btn.liked svg{fill:#fff}.action-btn.like-btn svg.filled{fill:currentColor}.shared-trip-content{padding:40px 20px}.shared-trip-content .container{max-width:1200px;margin:0 auto}.trip-layout{display:grid;grid-template-columns:1fr 350px;gap:32px;align-items:start}.trip-schedule{flex:1}.day-section{margin-bottom:40px}.day-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--primary-color)}.day-number{font-size:1.25rem;font-weight:700;color:var(--primary-color)}.day-date{color:var(--text-secondary);font-size:.95rem}.places-timeline{position:relative;padding-left:30px}.places-timeline:before{content:"";position:absolute;left:10px;top:0;bottom:0;width:2px;background:var(--border-color)}.place-item{position:relative;display:flex;align-items:center;gap:12px;background:var(--card-bg);padding:14px 16px;border-radius:var(--border-radius);margin-bottom:12px;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.place-item:hover{background:var(--bg-secondary);transform:translate(4px)}.place-item.selected{border-color:var(--primary-color);background:rgba(var(--primary-rgb, 0, 122, 255),.05)}.place-item .place-order{position:absolute;left:-30px;width:20px;height:20px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600}.place-name-badge{flex:1;font-weight:500;color:var(--text-primary)}.place-info-icon{color:var(--text-tertiary);transition:color .2s}.place-item:hover .place-info-icon,.place-item.selected .place-info-icon{color:var(--primary-color)}.place-detail-panel{position:sticky;top:100px;min-height:200px}.place-detail-card{background:var(--card-bg);border-radius:var(--border-radius);padding:24px;box-shadow:var(--shadow-md);position:relative;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.close-detail-btn{position:absolute;top:12px;right:12px;background:none;border:none;padding:8px;cursor:pointer;color:var(--text-tertiary);transition:color .2s}.close-detail-btn:hover{color:var(--text-primary)}.detail-image{margin:-20px -20px 16px;border-radius:12px 12px 0 0;overflow:hidden;max-height:200px}.detail-image img{width:100%;height:200px;object-fit:cover}.detail-place-name{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:16px;padding-right:32px}.detail-loading{display:flex;align-items:center;gap:10px;padding:12px;margin-bottom:12px;background:var(--bg-secondary);border-radius:8px;color:var(--text-secondary);font-size:.9rem}.db-detail-section{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.detail-description{margin-bottom:12px}.detail-description p{color:var(--text-secondary);font-size:.9rem;line-height:1.6;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.detail-link{color:var(--primary-color);text-decoration:none;font-weight:500}.detail-link:hover{text-decoration:underline}.detail-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;color:var(--text-secondary);font-size:.95rem}.detail-row svg{color:var(--primary-color);flex-shrink:0;margin-top:2px}.detail-memo{margin-top:16px;padding:12px;background:var(--bg-secondary);border-radius:8px}.detail-memo strong{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:6px}.detail-memo p{color:var(--text-primary);font-size:.95rem;line-height:1.5}.detail-direction-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;margin-top:20px;background:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease}.detail-direction-btn:hover{background:var(--primary-hover);transform:translateY(-2px)}.transit-loading{display:flex;align-items:center;gap:10px;padding:16px;margin-top:16px;background:var(--bg-secondary);border-radius:8px;color:var(--text-secondary);font-size:.9rem}.loading-spinner.small{width:20px;height:20px;border-width:2px}.transit-info-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.transit-title{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:12px}.transit-title svg{color:var(--primary-color)}.transit-card{background:var(--bg-secondary);border-radius:10px;padding:14px;margin-bottom:10px}.transit-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.transit-icon{font-size:1.2rem}.transit-icon.bus{color:#52c41a}.transit-icon.subway{color:#1890ff}.transit-type{font-weight:600;color:var(--text-primary);flex:1}.transit-time{font-weight:700;color:var(--primary-color);font-size:1rem}.transit-routes{display:flex;flex-direction:column;gap:8px}.routes-label{font-size:.8rem;color:var(--text-tertiary)}.bus-routes,.subway-lines{display:flex;flex-wrap:wrap;gap:6px}.bus-badge,.subway-badge{display:inline-block;padding:4px 10px;color:#fff;font-size:.8rem;font-weight:600;border-radius:4px}.bus-badge{background:#52c41a}.subway-badge{background:#1890ff}.no-transit{display:flex;align-items:center;gap:10px;padding:14px;background:var(--bg-secondary);border-radius:10px;color:var(--text-secondary);font-size:.9rem}.no-transit svg{font-size:1.2rem;color:var(--text-tertiary)}.transit-details{display:flex;flex-direction:column;gap:12px}.transit-segment{display:flex;flex-direction:column;gap:6px}.segment-routes{display:flex;flex-wrap:wrap;gap:6px}.segment-stations{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:.85rem;color:var(--text-secondary);padding-left:4px}.station-name{font-weight:500;color:var(--text-primary)}.station-arrow{color:var(--text-tertiary);font-size:.8rem}.station-count{font-size:.75rem;color:var(--text-tertiary);margin-left:4px}.no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-tertiary);text-align:center;background:var(--card-bg);border-radius:var(--border-radius);border:2px dashed var(--border-color)}.no-selection svg{font-size:2rem;margin-bottom:12px;opacity:.5}.no-selection p{font-size:.95rem}.place-card{position:relative;display:flex;align-items:flex-start;gap:16px;background:var(--card-bg);padding:20px;border-radius:var(--border-radius);margin-bottom:16px;box-shadow:var(--shadow-sm);transition:var(--transition)}.place-card:hover{box-shadow:var(--shadow-md);transform:translate(4px)}.place-order{position:absolute;left:-30px;top:20px;width:24px;height:24px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;z-index:1}.place-info{flex:1}.place-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.place-address{display:flex;align-items:center;gap:6px;font-size:.9rem;color:var(--text-secondary);margin-bottom:4px}.place-address svg{color:var(--secondary-color);flex-shrink:0}.place-duration{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-tertiary);margin-bottom:8px}.place-duration svg{color:var(--primary-color)}.place-memo{font-size:.9rem;color:var(--text-secondary);font-style:italic;padding:10px;background:var(--bg-secondary);border-radius:8px;margin-top:8px}.direction-btn{padding:10px;background:var(--bg-secondary);color:var(--primary-color);border:none;border-radius:50%;cursor:pointer;transition:var(--transition)}.direction-btn:hover{background:var(--primary-color);color:#fff}.no-places,.empty-trip{display:flex;flex-direction:column;align-items:center;padding:40px;color:var(--text-tertiary);text-align:center}.no-places svg,.empty-trip svg{font-size:2.5rem;margin-bottom:12px;opacity:.5}.shared-trip-cta{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));padding:40px 20px;text-align:center}.shared-trip-cta .container{max-width:600px;margin:0 auto}.shared-trip-cta p{color:#fff;font-size:1.1rem;margin-bottom:16px}.create-trip-btn{display:inline-block;padding:14px 32px;background:#fff;color:var(--primary-color);border-radius:var(--border-radius);font-weight:600;transition:var(--transition)}.create-trip-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}@media (max-width: 1024px){.trip-layout{grid-template-columns:1fr}.place-detail-panel{position:fixed;top:auto;bottom:0;left:0;right:0;z-index:100;background:var(--bg-primary);padding:0;transform:translateY(100%);transition:transform .3s ease;max-height:60vh;overflow-y:auto;border-top-left-radius:20px;border-top-right-radius:20px;box-shadow:0 -4px 20px #00000026}.place-detail-panel.visible{transform:translateY(0)}.place-detail-card{border-radius:0;box-shadow:none}.no-selection{display:none}}@media (max-width: 768px){.shared-trip-hero{min-height:250px;padding:80px 16px 30px}.trip-title{font-size:1.5rem}.trip-meta{gap:12px}.meta-item{font-size:.85rem}.trip-actions{flex-wrap:wrap}.action-btn{padding:8px 16px;font-size:.9rem}.shared-trip-content{padding:24px 16px}.place-item{padding:12px 14px}.places-timeline{padding-left:24px}.place-item .place-order{left:-24px;width:20px;height:20px;font-size:.7rem}}.dark-theme .shared-trip-page{background:var(--bg-primary)}.dark-theme .back-btn{background:#1e1e28e6;color:var(--text-primary)}.dark-theme .back-btn:hover{background:var(--card-bg)}.dark-theme .action-btn{background:#1e1e28e6;color:var(--text-primary)}.dark-theme .action-btn:hover{background:var(--card-bg)}.dark-theme .action-btn.like-btn.liked{background:#ff4757;color:#fff}.dark-theme .day-header{border-bottom-color:var(--primary-color)}.dark-theme .place-item{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .place-item:hover{background:var(--bg-tertiary)}.dark-theme .place-item.selected{border-color:var(--primary-color);background:rgba(var(--primary-rgb, 0, 122, 255),.1)}.dark-theme .place-detail-card{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .detail-memo{background:var(--bg-tertiary)}.dark-theme .no-selection{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .place-card{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .place-memo,.dark-theme .direction-btn{background:var(--bg-tertiary)}.dark-theme .direction-btn:hover{background:var(--primary-color);color:#fff}@media (max-width: 1024px){.dark-theme .place-detail-panel{background:var(--bg-primary);box-shadow:0 -4px 20px #0006}}.trip-map-section{margin-bottom:32px}.trip-map-section .map-header{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px}.trip-map-section .map-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px;margin-right:auto}.day-selector{display:flex;flex-wrap:wrap;gap:8px}.day-btn{padding:8px 16px;background:var(--bg-secondary);color:var(--text-secondary);border:2px solid transparent;border-radius:20px;font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition)}.day-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.day-btn.active{background:var(--day-color, var(--primary-color));color:#fff;border-color:var(--day-color, var(--primary-color))}.trip-map-container{border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.trip-map{width:100%;height:400px}.map-legend{display:flex;flex-wrap:wrap;gap:16px;padding:12px 16px;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.legend-item{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-secondary)}.legend-color{width:16px;height:4px;border-radius:2px}.day-section{cursor:pointer;transition:var(--transition);border-left:4px solid transparent;padding-left:12px;margin-left:-16px}.day-section:hover{background:rgba(var(--primary-rgb, 0, 122, 255),.03)}.day-section.active{border-left-color:var(--day-color, var(--primary-color));background:rgba(var(--primary-rgb, 0, 122, 255),.05)}.day-header{position:relative}.day-header:before{content:"";position:absolute;left:-16px;top:0;width:4px;height:100%;background:var(--day-color, var(--primary-color));opacity:0;transition:var(--transition)}.day-section.active .day-header:before{opacity:1}.dark-theme .trip-map-container{border-color:var(--border-color)}.dark-theme .map-legend{background:var(--bg-tertiary);border-top-color:var(--border-color)}.dark-theme .day-btn{background:var(--bg-tertiary)}.dark-theme .day-btn:hover{background:var(--card-bg)}.dark-theme .day-section:hover{background:#ffffff08}.dark-theme .day-section.active{background:#ffffff0d}@media (max-width: 768px){.trip-map-section .map-header{flex-direction:column;align-items:flex-start}.trip-map-section .map-header h3{margin-right:0}.day-selector{width:100%}.day-btn{padding:6px 12px;font-size:.8rem}.trip-map{height:300px}.map-legend{gap:12px;padding:10px 12px}.legend-item{font-size:.8rem}}.policy-page{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:2rem 1rem}.policy-page.dark-theme{background:linear-gradient(135deg,#1a1a2e,#16213e)}.policy-container{max-width:900px;margin:0 auto;background:#fff;border-radius:20px;box-shadow:0 10px 40px #0000001a;padding:3rem}.policy-page.dark-theme .policy-container{background:#1e1e2e;box-shadow:0 10px 40px #0000004d}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:#6366f1;text-decoration:none;font-weight:500;margin-bottom:2rem;transition:all .3s ease}.back-link:hover{color:#4f46e5;transform:translate(-5px)}.policy-page.dark-theme .back-link{color:#818cf8}.policy-page.dark-theme .back-link:hover{color:#a5b4fc}.policy-header{text-align:center;margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #e2e8f0}.policy-page.dark-theme .policy-header{border-bottom-color:#374151}.policy-icon{font-size:3rem;color:#6366f1;margin-bottom:1rem}.policy-page.dark-theme .policy-icon{color:#818cf8}.policy-header h1{font-size:2.5rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.policy-page.dark-theme .policy-header h1{color:#f1f5f9}.last-updated{color:#64748b;font-size:.9rem}.policy-page.dark-theme .last-updated{color:#94a3b8}.policy-intro{font-size:1.1rem;line-height:1.8;color:#475569;margin-bottom:2.5rem;padding:1.5rem;background:#f8fafc;border-radius:12px;border-left:4px solid #6366f1}.policy-page.dark-theme .policy-intro{background:#1a1a2e;color:#cbd5e1;border-left-color:#818cf8}.policy-sections{display:flex;flex-direction:column;gap:2rem}.policy-section{background:#fafafa;border-radius:16px;padding:1.5rem 2rem;transition:all .3s ease}.policy-section:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000014}.policy-page.dark-theme .policy-section{background:#252536}.policy-page.dark-theme .policy-section:hover{box-shadow:0 8px 25px #0000004d}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.section-header svg{font-size:1.5rem;color:#6366f1;flex-shrink:0}.policy-page.dark-theme .section-header svg{color:#818cf8}.section-header h2{font-size:1.25rem;font-weight:600;color:#1e293b;margin:0}.policy-page.dark-theme .section-header h2{color:#f1f5f9}.section-content{color:#475569;line-height:1.8;white-space:pre-line;margin:0}.policy-page.dark-theme .section-content{color:#cbd5e1}.data-source-section{margin-top:3rem;padding-top:2rem;border-top:2px solid #e2e8f0}.policy-page.dark-theme .data-source-section{border-top-color:#374151}.data-source-section h2{font-size:1.5rem;font-weight:600;color:#1e293b;margin-bottom:1.5rem}.policy-page.dark-theme .data-source-section h2{color:#f1f5f9}.source-table{width:100%;border-collapse:collapse;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #0000000d}.policy-page.dark-theme .source-table{box-shadow:0 2px 10px #0003}.source-table thead{background:#6366f1}.source-table th{color:#fff;font-weight:600;padding:1rem;text-align:left}.source-table tbody tr{background:#fff;transition:background .3s ease}.source-table tbody tr:nth-child(2n){background:#f8fafc}.source-table tbody tr:hover{background:#eef2ff}.policy-page.dark-theme .source-table tbody tr{background:#252536}.policy-page.dark-theme .source-table tbody tr:nth-child(2n){background:#1e1e2e}.policy-page.dark-theme .source-table tbody tr:hover{background:#2d2d44}.source-table td{padding:1rem;color:#475569;border-bottom:1px solid #e2e8f0}.policy-page.dark-theme .source-table td{color:#cbd5e1;border-bottom-color:#374151}.source-table td a{color:#6366f1;display:flex;align-items:center;justify-content:center;transition:color .3s ease}.source-table td a:hover{color:#4f46e5}.policy-page.dark-theme .source-table td a{color:#818cf8}.policy-page.dark-theme .source-table td a:hover{color:#a5b4fc}@media (max-width: 768px){.policy-container{padding:1.5rem;border-radius:12px}.policy-header h1{font-size:1.75rem}.policy-icon{font-size:2.5rem}.policy-intro{font-size:1rem;padding:1rem}.policy-section{padding:1.25rem}.section-header h2{font-size:1.1rem}.section-content{font-size:.95rem}.source-table th,.source-table td{padding:.75rem .5rem;font-size:.85rem}}@media (max-width: 480px){.policy-page{padding:1rem .5rem}.policy-container{padding:1rem}.policy-header h1{font-size:1.5rem}.source-table{font-size:.8rem}}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1}*{margin:0;padding:0;box-sizing:border-box}:root,.light-theme{--primary-color: #0066cc;--primary-dark: #004499;--secondary-color: #ff6b35;--accent-color: #00b4d8;--text-primary: #1a1a2e;--text-secondary: #4a4a68;--text-light: #8b8ba3;--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #e9ecef;--bg-gradient: linear-gradient(135deg, #0066cc 0%, #00b4d8 100%);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .16);--border-color: #e9ecef;--card-bg: #ffffff;--border-radius: 12px;--transition: all .3s ease}.dark-theme{--primary-color: #4da6ff;--primary-dark: #0066cc;--secondary-color: #ff8c5a;--accent-color: #4dd4ec;--text-primary: #f0f0f5;--text-secondary: #b8b8c8;--text-light: #8888a0;--bg-primary: #121218;--bg-secondary: #1a1a24;--bg-tertiary: #252530;--bg-gradient: linear-gradient(135deg, #1a4d80 0%, #1a6d7d 100%);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--border-color: #2d2d3a;--card-bg: #1e1e28}html{scroll-behavior:smooth}body{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}ul,ol{list-style:none}button{cursor:pointer;border:none;background:none;font-family:inherit}img{max-width:100%;height:auto;display:block}.container{max-width:1280px;margin:0 auto;padding:0 20px}.section{padding:80px 0}.section-header{text-align:center;margin-bottom:48px}.section-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:12px}.section-subtitle{font-size:1.1rem;color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:500;transition:var(--transition)}.btn-primary{background:var(--bg-gradient);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-secondary{background:#fff;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-secondary:hover{background:var(--primary-color);color:#fff}.card{background:var(--card-bg);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.dark-theme .header{background:#121218f2}.dark-theme .header.scrolled,.dark-theme .nav{background:var(--bg-primary)}.dark-theme .lang-btn,.dark-theme .theme-btn{border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .lang-btn:hover,.dark-theme .theme-btn:hover{background:var(--bg-tertiary);color:var(--primary-color)}.dark-theme .food-card,.dark-theme .travel-card,.dark-theme .festival-card,.dark-theme .parking-card,.dark-theme .result-card{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .popular-spots,.dark-theme .food-section{background:var(--bg-secondary)}.dark-theme .nav-btn:hover{background:var(--primary-color)}.dark-theme .btn-secondary{background:var(--card-bg);color:var(--primary-color);border-color:var(--primary-color)}.dark-theme .btn-secondary:hover{background:var(--primary-color);color:#fff}.dark-theme .course-card,.dark-theme .food-card,.dark-theme .spot-card,.dark-theme .quick-menu-item{background:var(--card-bg);border:1px solid var(--border-color)}.dark-theme .course-content,.dark-theme .food-content,.dark-theme .festival-content{background:var(--card-bg)}.dark-theme .spot-badge{background:var(--bg-tertiary);color:var(--text-secondary)}.dark-theme .food-category{background:#4da6ff26;color:var(--primary-color)}.dark-theme .popular-spots{background:var(--bg-secondary)}.dark-theme .travel-course{background:var(--bg-tertiary)}.dark-theme .food-section{background:var(--bg-secondary)}.dark-theme .festival-section{background:linear-gradient(180deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%)}.dark-theme .btn-primary{background:linear-gradient(135deg,#3385d6,#39c)}.dark-theme .nav-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .nav-btn:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.dark-theme .section-more .btn{background:var(--card-bg);border:1px solid var(--border-color);color:var(--primary-color)}.dark-theme .section-more .btn:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.dark-theme .section-more .btn-primary{background:linear-gradient(135deg,#3385d6,#39c);border:none;color:#fff}.dark-theme .footer{background:var(--bg-secondary);border-top:1px solid var(--border-color)}.dark-theme .quick-menu-item{background:var(--card-bg)}.dark-theme .search-input-wrapper input{background:var(--card-bg);color:var(--text-primary);border:1px solid var(--border-color)}.dark-theme .search-summary,.dark-theme .tab-btn,.dark-theme .filter-btn{background:var(--card-bg);border-color:var(--border-color);color:var(--text-secondary)}.dark-theme .tab-btn.active,.dark-theme .filter-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.dark-theme .stat-card{background:var(--card-bg)}.dark-theme .map-sidebar{background:var(--bg-primary);border-color:var(--border-color)}.dark-theme .place-item{border-color:var(--border-color)}.dark-theme .place-item.selected{background:var(--bg-tertiary)}.dark-theme .place-detail,.dark-theme .modal-content{background:var(--card-bg)}@media (max-width: 1024px){.container{padding:0 16px}.section{padding:60px 0}.section-title{font-size:1.75rem}}@media (max-width: 768px){.section{padding:40px 0}.section-title{font-size:1.5rem}.section-subtitle{font-size:1rem}}
