@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f0f2f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.gm-style-iw-c{background:#0000!important;border-radius:16px!important;box-shadow:0 12px 28px #0003,0 4px 12px #0000001a!important;transform:translateY(-10px)}.gm-style-iw-c button[title=\95DC\9589]{display:none!important}.custom-info-window{backdrop-filter:blur(18px) saturate(180%);-webkit-backdrop-filter:blur(18px) saturate(180%);background:#fffc;border:1px solid #ffffff26;border-radius:16px;box-sizing:border-box;font-family:Helvetica Neue,Arial,PingFang TC,Microsoft JhengHei,sans-serif;overflow:hidden}.custom-info-window.is-single-shop{padding:4px}.custom-info-window.is-multi-shop{padding:16px}.popup-image-container,.popup-thumbnail-container{background-color:#f0f2f5;flex-shrink:0;overflow:hidden}.popup-image,.popup-thumbnail{display:block;height:100%;object-fit:cover;width:100%}.image-placeholder{align-items:center;color:#a0aec0;display:flex;height:100%;justify-content:center;width:100%}.shop-header{flex-direction:column;gap:6px}.shop-name{color:#1a202c;line-height:1.4;margin:0;word-break:break-word}.shop-category-tag{align-self:flex-start;background-color:#007aff1f;border-radius:8px;color:#007aff;font-size:11px;font-weight:600;margin:0;padding:3px 8px}.single-shop-popup{align-items:center;border:1px solid #0000;border-radius:12px;cursor:pointer;display:flex;gap:12px;padding:10px;transition:background-color .2s ease,border-color .2s ease}.single-shop-popup:hover{background-color:#ffffffe6;border-color:#007aff4d}.single-shop-popup .popup-main-content{display:flex;flex:1 1;flex-direction:column;gap:0;min-width:0}.single-shop-popup .shop-name{font-size:17px;font-weight:700}.single-shop-popup .popup-image-container{border-radius:10px;height:88px;width:88px}.multi-shop-popup h4{color:#1a202c;font-size:18px;font-weight:700;margin:0 0 12px}.multi-shop-scroll-container{display:flex;flex-direction:column;gap:12px;margin:0 -16px;max-height:260px;overflow-y:auto;padding:4px 16px;scrollbar-color:#d0d0d0 #0000;scrollbar-width:thin}.multi-shop-scroll-container::-webkit-scrollbar{width:5px}.multi-shop-scroll-container::-webkit-scrollbar-track{background:#0000}.multi-shop-scroll-container::-webkit-scrollbar-thumb{background:#d0d0d0;border-radius:3px}.multi-shop-item-card{align-items:center;background-color:#ffffff80;border:1px solid #0000;border-radius:12px;cursor:pointer;display:flex;gap:12px;padding:10px;transition:background-color .2s ease,border-color .2s ease}.multi-shop-item-card:hover{background-color:#ffffffe6;border-color:#007aff4d}.multi-shop-item-content{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;gap:8px;min-width:0}.multi-shop-item-card .shop-name{font-size:15px;font-weight:600}.multi-shop-item-card .popup-thumbnail-container{border-radius:10px;height:64px;width:64px}.advanced-search-container{font-family:Inter,sans-serif;max-width:300px;position:relative;width:100%}.search-input-wrapper{align-items:center;background-color:#f1f3f5;border-radius:20px;display:flex;height:40px;padding:0 8px 0 16px;transition:background-color .2s,box-shadow .2s}.search-input-wrapper:focus-within{background-color:#fff;box-shadow:0 0 0 2px #e87a5d80}.search-input-wrapper svg{color:var(--text-light-color)}.advanced-search-input{background:#0000;border:none;color:var(--text-color);flex-grow:1;font-size:.9rem;height:100%;outline:none;padding:0 8px}.advanced-search-input::placeholder{color:#868e96}.dropdown-toggle-btn{align-items:center;background:#0000;border:none;border-radius:50%;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:background-color .2s}.dropdown-toggle-btn:hover{background-color:#e9ecef}.search-dropdown{background-color:var(--panel-bg-color);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 25px #00000026;left:0;max-height:400px;overflow-y:auto;padding:8px;position:absolute;right:0;top:calc(100% + 8px);z-index:1010}.dropdown-main-label{background-color:#f8f9fa;border-radius:8px;color:#e87a5d;color:var(--primary-color,#e87a5d);font-size:.9rem;font-weight:700;margin-top:8px;padding:12px 8px 8px}.dropdown-main-label:first-child{margin-top:0}.dropdown-sub-label{border-bottom:1px solid #f1f3f5;color:var(--text-color);font-size:.85rem;font-weight:600;margin-bottom:4px;padding:12px 12px 4px}.search-result-item{border-radius:8px;cursor:pointer;font-size:.9rem;padding:9px 16px 9px 28px;transition:background-color .2s}.search-result-item:hover{background-color:#f1f3f5}.no-results{color:var(--text-light-color);padding:16px;text-align:center}.category-filter-container{align-items:center;background-color:#f1f3f5;border:1px solid #0000;border-radius:8px;display:flex;padding:0 12px;transition:border-color .2s ease,box-shadow .2s ease}.category-filter-container:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 2px #e87a5d4d}.category-filter-container svg{color:var(--text-light-color);margin-right:8px}.category-filter-select{-webkit-appearance:none;appearance:none;background:#0000;border:none;color:var(--text-color);cursor:pointer;font-family:Inter,sans-serif;font-size:.95rem;padding:10px 0;width:100%}.category-filter-select:focus{outline:none}.app-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 10px #0000001a;left:0;padding:8px 16px;pointer-events:auto;position:absolute;right:0;top:0;z-index:1001}@media (min-width:1024px){.app-header{padding:8px 5%}}.header-content{align-items:center;display:flex;flex-grow:1;gap:16px;justify-content:space-between;margin:0 auto;max-width:100%;width:100%}.header-group-left,.header-search-container{align-items:center;display:flex;gap:12px}.header-search-container{flex-grow:1;min-width:0}.header-group-right{align-items:center;display:flex;gap:16px}.header-title{color:#333;font-size:1.2rem;font-weight:700;text-decoration:none;white-space:nowrap}@media (min-width:900px){.header-title{font-size:1.5rem}}.header-search-container>div:first-child{flex-grow:1;min-width:150px}.category-filter-container{flex-basis:200px;flex-shrink:1}.header-icon-button{align-items:center;background:#0000;border:none;border-radius:50%;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:background-color .2s}.header-icon-button:hover{background-color:#0000000d}.header-icon-button svg{color:#333;height:24px;width:24px}.mobile-controls-group{align-items:center;display:flex;gap:8px}.mobile-filter-button,.mobile-search-button{align-items:center;background-color:#fff;border:1px solid var(--border-color);border-radius:8px;color:var(--text-color);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;padding:8px 14px;transition:background-color .2s,padding .2s;white-space:nowrap}.mobile-filter-button:hover,.mobile-search-button:hover{background-color:#f0f0f0}.mobile-filter-button svg,.mobile-search-button svg{color:var(--primary-color);height:20px;width:20px}.header-nav{align-items:center;display:flex;gap:16px}.nav-button,.nav-link{background:none;border:none;color:#555;cursor:pointer;font-size:1rem;font-weight:500;padding:0;text-decoration:none;transition:color .2s ease;white-space:nowrap}.nav-link:hover{color:#007bff}.logout-button{background-color:#dc3545;border-radius:8px;color:#fff;font-size:.9rem;font-weight:600;padding:8px 12px}.logout-button:hover{background-color:#c82333}.header-logo-link{align-items:center;display:flex;text-decoration:none}.header-logo{height:75px;width:auto}@media (max-width:420px){.mobile-filter-button span,.mobile-search-button span{display:none}.mobile-filter-button,.mobile-search-button{gap:0;padding:8px}.mobile-controls-group{gap:4px}.app-header{padding:8px 12px}}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{animation:slide-up .3s ease-out;background-color:#fff;box-shadow:0 5px 20px #0003;max-width:500px;padding:24px 32px;position:relative}.modal-close-button{color:#888;position:absolute;right:12px;top:12px;transition:background-color .2s,color .2s}.modal-close-button:hover{color:#333}.modal-header h2{color:var(--text-color);font-size:1.8rem;margin:0 0 16px}.modal-body p{color:var(--text-light-color);font-size:1rem;line-height:1.8;margin:0 0 16px}.modal-body p:last-child{margin-bottom:0}.modal-body strong{color:var(--primary-color);font-weight:700}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-footer{border-top:1px solid #eee;margin-top:20px;padding-top:15px}.modal-footer p{color:#888;font-size:12px;line-height:1.5;text-align:justify}.mission-modal-overlay{align-items:center;animation:mission-fade-in .3s ease;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background-color:#21252999;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.mission-modal-content{animation:mission-slide-up .4s ease;background:#fff;border-radius:16px;box-shadow:0 10px 30px #0003;display:flex;flex-direction:column;max-height:85vh;max-width:700px;overflow:hidden;position:relative;width:90%}.mission-modal-close-button{align-items:center;background:#00000014;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;height:32px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .2s ease;width:32px;z-index:10}.mission-modal-close-button:hover{background:#00000026;transform:scale(1.1)}.mission-modal-header{border-bottom:1px solid #e9ecef;padding:24px 32px}.mission-modal-header h2{color:#212529;font-size:1.8rem;font-weight:700;margin:0}.mission-modal-body{color:#495057;font-size:1.05rem;line-height:1.8;overflow-y:auto;padding:24px 32px}.mission-modal-body p{margin-bottom:1.5em;margin-top:0}.mission-modal-body strong{color:#e87a5d;color:var(--primary-color,#e87a5d);font-weight:700}.mission-modal-footer{background-color:#f8f9fa;border-top:1px solid #e9ecef;color:#6c757d;font-size:.85rem;height:20px;line-height:1.6;overflow-y:auto;padding:20px 32px}.mission-modal-footer p{margin:0}@keyframes mission-fade-in{0%{opacity:0}to{opacity:1}}@keyframes mission-slide-up{0%{opacity:.5;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.category-modal-overlay{align-items:flex-end;animation:fadeIn .3s ease;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1010}.category-modal-content{animation:slideUp .3s cubic-bezier(.25,.46,.45,.94);background-color:var(--panel-bg-color);border-top-left-radius:20px;border-top-right-radius:20px;display:flex;flex-direction:column;max-height:70vh;max-width:500px;width:100%}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.category-modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:16px 24px}.category-modal-header h4{font-size:1.2rem;font-weight:600;margin:0}.close-modal-btn{background:none;border:none;color:var(--text-light-color);cursor:pointer;font-size:2rem;line-height:1;padding:0}.category-modal-list{list-style:none;margin:0;overflow-y:auto;padding:8px 0}.category-modal-list li{align-items:center;cursor:pointer;display:flex;font-size:1.1rem;justify-content:space-between;padding:14px 24px;transition:background-color .2s ease}.category-modal-list li:hover{background-color:var(--bg-color)}.category-modal-list li.selected{color:var(--primary-color);font-weight:600}.category-modal-list li.selected svg{color:var(--primary-color)}.mobile-nav-overlay{animation:fadeIn .3s ease;background-color:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:2000}.mobile-nav-content{animation:slideInFromLeft .3s cubic-bezier(.25,.46,.45,.94) forwards;background-color:var(--panel-bg-color);bottom:0;box-shadow:4px 0 15px #0000001a;display:flex;flex-direction:column;left:0;max-width:300px;position:absolute;top:0;transform:translateX(-100%);width:80%}@keyframes slideInFromLeft{to{transform:translateX(0)}}.mobile-nav-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:16px 24px}.mobile-nav-header h3{font-size:1.2rem;font-weight:600;margin:0}.mobile-nav-close-btn{background:none;border:none;color:var(--text-light-color);cursor:pointer;padding:4px}.mobile-nav-links{display:flex;flex-direction:column;padding:16px 0}.mobile-nav-link{color:var(--text-color);font-size:1.1rem;font-weight:500;padding:16px 24px;text-decoration:none;transition:background-color .2s ease}.mobile-nav-link:hover{background-color:var(--bg-color)}.mobile-nav-link.primary-link{align-items:center;background-color:#e87a5d0d;border-bottom:1px solid var(--border-color);color:var(--primary-color);display:flex;font-weight:700;gap:12px;margin-bottom:8px}.modal-overlay{background-color:#0009;padding:20px 0;z-index:2000}.location-modal-content{animation:slide-down .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 5px 15px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:500px;padding:20px;transition:height .3s ease-out;width:auto}.location-modal-content.expanded{height:60%}.modal-header{border-bottom:1px solid #eee;flex-shrink:0;margin-bottom:16px;padding-bottom:12px}.modal-title{color:#333;font-size:1.2rem;font-weight:600;margin:0}.modal-close-button{align-items:center;background:#0000;border-radius:50%;display:flex;justify-content:center;padding:4px;transition:background-color .2s}.modal-close-button:hover{background-color:#f0f0f0}.modal-body{flex-grow:1;min-height:0}@keyframes slide-down{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}:root{--primary-color:#e87a5d;--bg-color:#f8f9fa;--panel-bg-color:#fff;--text-color:#212529;--text-light-color:#6c757d;--border-color:#dee2e6;--header-height:60px;--action-bar-height:56px;--button-save-bg:#198754;--button-cancel-bg:#6c757d}#root,body,html{background-color:#f8f9fa;background-color:var(--bg-color);color:#212529;color:var(--text-color);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100%;margin:0;overflow:hidden;padding:0}.app-main-content{box-sizing:border-box;height:100vh;overflow-y:auto}.app-container{background-color:#fff;background-color:var(--panel-bg-color);box-shadow:0 4px H25px #00000014;display:flex;flex-direction:column;height:100%;margin:0 auto;max-width:1800px;overflow:hidden;width:100%}.app-header{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background-color:#fffc;border-bottom:1px solid #0000000d;position:relative;z-index:1000}.main-content{display:flex;flex-grow:1;min-height:0}.map-wrapper{background-color:#fff;background-color:var(--panel-bg-color);flex-grow:1;position:relative}.homepage-actions{align-items:center;background-color:#fff;border-bottom:1px solid #dee2e6;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;height:56px;height:var(--action-bar-height);justify-content:flex-end;padding:0 24px}.action-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.9rem;font-weight:700;gap:8px;padding:8px 20px;transition:all .2s ease}.action-button.add{background-color:#198754;background-color:var(--button-save-bg);color:#fff}.action-button.add:hover{opacity:.85}.action-button.cancel{background-color:#e74c3c;color:#fff}.action-button.cancel:hover{opacity:.85}.error-bar,.info-bar,.info-bar-edit{border-radius:8px;box-shadow:0 4px 12px #00000026;color:#fff;font-weight:600;left:50%;max-width:90%;padding:10px 20px;pointer-events:none;position:absolute;text-align:center;top:16px;transform:translateX(-50%);width:auto;z-index:1000}.error-bar{background-color:#d9534f}.info-bar{background-color:#0275d8}.info-bar-edit{background-color:#f0ad4e;color:#212529;color:var(--text-color)}.shop-card-wrapper{bottom:0;height:85vh;left:0;pointer-events:none;position:fixed;right:0;transform:translateY(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);z-index:1001}.shop-card-wrapper.visible{pointer-events:auto;transform:translateY(0)}.panel-content-bg{background-color:#fff;background-color:var(--panel-bg-color);border-top-left-radius:20px;border-top-right-radius:20px;box-shadow:0 -5px 20px #0000001a;height:100%;overflow-y:auto;position:relative}.shop-card-close-btn{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#fffc;border:none;border-radius:50%;color:#6c757d;color:var(--text-light-color);cursor:pointer;display:flex;height:36px;justify-content:center;margin-left:auto;margin-right:12px;position:-webkit-sticky;position:sticky;right:12px;top:12px;transition:all .2s;width:36px;z-index:1002}.shop-card-close-btn:hover{background-color:#fff;transform:scale(1.1)}.shop-card,.shop-form-container{padding:24px 32px 60px}.shop-image{background-color:#dee2e6;background-color:var(--border-color);border-radius:12px;height:320px;margin-bottom:24px;object-fit:cover;width:100%}.shop-name{color:#212529;color:var(--text-color);font-size:2rem;font-weight:800}.shop-description{border-left:3px solid #e87a5d;border-left:3px solid var(--primary-color);color:#6c757d;color:var(--text-light-color);font-size:1rem;line-height:1.7;margin:16px 0;padding-left:16px}.shop-form-container h3{font-size:1.8rem;font-weight:800}.form-group input,.form-group select,.form-group textarea{border-radius:8px;font-family:Inter,sans-serif;padding:10px 12px}.form-actions .save-button{background-color:#198754;background-color:var(--button-save-bg)}.form-actions .cancel-button,.form-actions .save-button{border-radius:8px;color:#fff;font-weight:700;padding:10px 20px}.form-actions .cancel-button{background-color:#6c757d;background-color:var(--button-cancel-bg)}.shop-header{justify-content:space-between;margin-bottom:16px}.shop-header,.shop-title-group{align-items:center;display:flex;gap:16px}.shop-actions{align-items:center;display:flex;flex-shrink:0}.interaction-buttons{display:flex;gap:4px}.dislike-button,.like-button{align-items:center;background-color:#fff;border:1px solid #dee2e6;border:1px solid var(--border-color);border-radius:50%;color:#6c757d;color:var(--text-light-color);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s ease-out;width:40px}.like-button:hover{background-color:#e9f7ec;border-color:#a3d9b1;color:#28a745;transform:scale(1.1)}.dislike-button:hover{background-color:#fbebee;border-color:#f1b0b5;color:#dc3545;transform:scale(1.1)}.edit-button{background-color:#f0f0f0;border:1px solid #0000;border-radius:8px;color:#333;font-size:.8rem;font-weight:600;padding:8px 12px;transition:all .2s ease-out}.edit-button:hover{background-color:#e0e0e0;border-color:#ccc;color:#000}.shop-meta{border-bottom:1px solid #dee2e6;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:16px 24px;margin-bottom:16px;padding-bottom:16px}.shop-meta,.shop-stat{align-items:center;display:flex}.shop-stat{font-size:.95rem;gap:8px}.shop-stat svg{height:20px;width:20px}.shop-details{display:flex;flex-direction:column;flex-grow:1;gap:12px}.shop-detail-item{align-items:flex-start;color:#212529;color:var(--text-color);display:flex;gap:12px;margin:0}.shop-detail-item svg{color:#e87a5d;color:var(--primary-color);flex-shrink:0;margin-top:3px}.desktop-shop-list-wrapper{background-color:#f8f9fa;background-color:var(--bg-color);border-left:1px solid #dee2e6;border-left:1px solid var(--border-color);display:none;flex-shrink:0}.shop-list-container{height:100%}.shop-list-header{background-color:#fff;background-color:var(--panel-bg-color);border-bottom:1px solid #dee2e6;border-bottom:1px solid var(--border-color);flex-shrink:0;padding:16px 24px}.shop-list-header h3{color:#212529;color:var(--text-color);font-size:1.1rem;font-weight:600;margin:0 0 4px}.shop-list-header span{color:#6c757d;color:var(--text-light-color);font-size:.85rem}.shop-list{flex-grow:1;overflow-y:auto;padding:16px}.shop-list-item{background-color:#fff;background-color:var(--panel-bg-color);border:1px solid #dee2e6;border:1px solid var(--border-color);border-radius:12px;cursor:pointer;display:flex;gap:16px;margin-bottom:12px;padding:12px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.shop-list-item:last-child{margin-bottom:0}.shop-list-item:hover{box-shadow:0 4px 15px #00000014;transform:translateY(-3px)}.shop-list-item.selected{background-color:#fff9f7;border-color:#e87a5d;border-color:var(--primary-color);box-shadow:0 0 0 2px #e87a5d80}.shop-list-item-image{object-fit:cover}.shop-list-item-image,.shop-list-item-image-placeholder{background-color:#e9ecef;border-radius:8px;flex-shrink:0;height:70px;width:70px}.shop-list-item-image-placeholder{align-items:center;color:#adb5bd;display:flex;justify-content:center}.shop-list-item-info{display:flex;flex-direction:column;flex-grow:1;gap:6px;min-width:0}.shop-list-item-name{font-size:1rem;font-weight:600}.shop-list-item-category,.shop-list-item-name{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shop-list-item-category{color:#6c757d;color:var(--text-light-color);font-size:.8rem}.shop-list-item-distance{align-items:center;color:#212529;color:var(--text-color);display:flex;font-size:.85rem;font-weight:500;gap:6px;margin-top:auto}.shop-list-item-distance svg{color:#e87a5d;color:var(--primary-color);height:14px;width:14px}.shop-list-placeholder{color:#6c757d;color:var(--text-light-color);padding:60px 24px;text-align:center}.shop-list-placeholder-icon{font-size:3rem;margin-bottom:16px;opacity:.5}.pagination-container{background-color:#fff;background-color:var(--panel-bg-color);border-top:1px solid #dee2e6;border-top:1px solid var(--border-color);flex-shrink:0;padding:16px}.pagination-button,.pagination-container{align-items:center;display:flex;justify-content:center}.pagination-button{background-color:#fff;border:1px solid #dee2e6;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;font-weight:500;margin:0 4px;padding:6px 12px;transition:all .2s ease}.pagination-button:hover:not(:disabled){background-color:#f1f3f5;border-color:#adb5bd}.pagination-button:disabled{cursor:not-allowed;opacity:.5}.pagination-info{color:#6c757d;color:var(--text-light-color);font-size:.9rem;font-weight:500;margin:0 12px}.related-shops-container{border-top:1px solid #dee2e6;border-top:1px solid var(--border-color);display:none;margin-top:48px;padding-top:32px}.related-shops-title{color:#212529;color:var(--text-color);font-size:1.2rem;font-weight:700;margin:0 0 16px}.related-shops-list{display:flex;flex-direction:column;gap:12px}.related-shop-item{align-items:center;border:1px solid #0000;border-radius:10px;cursor:pointer;display:flex;gap:16px;padding:10px;transition:background-color .2s ease}.related-shop-item:hover{background-color:#f8f9fa;border-color:#dee2e6;border-color:var(--border-color)}.related-shop-image{object-fit:cover}.related-shop-image,.related-shop-image-placeholder{background-color:#e9ecef;border-radius:8px;flex-shrink:0;height:50px;width:50px}.related-shop-image-placeholder{align-items:center;color:#adb5bd;display:flex;justify-content:center}.related-shop-info{min-width:0}.related-shop-name{font-size:.95rem;font-weight:600;margin:0 0 4px}.related-shop-category,.related-shop-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.related-shop-category{color:#6c757d;color:var(--text-light-color);font-size:.85rem;margin:0}.shop-news-feed-container{border-top:1px solid #dee2e6;border-top:1px solid var(--border-color);display:none;margin-top:32px;padding-top:24px}.shop-news-feed-title{color:#212529;color:var(--text-color);font-size:1.2rem;font-weight:700;margin:0 0 16px}.shop-news-feed-list{display:flex;flex-direction:column;gap:16px}.shop-news-item{align-items:center;border:1px solid #0000;border-radius:10px;color:inherit;display:flex;gap:16px;justify-content:space-between;padding:12px;text-decoration:none;transition:background-color .2s ease}.shop-news-item:hover{background-color:#f8f9fa;border-color:#dee2e6;border-color:var(--border-color)}.shop-news-item-info{flex-grow:1;min-width:0}.shop-news-item-title{color:#212529;color:var(--text-color);font-size:.95rem;font-weight:600;margin:0 0 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shop-news-item-date{color:#6c757d;color:var(--text-light-color);font-size:.85rem}.shop-news-item-image{background-color:#e9ecef;border-radius:8px;flex-shrink:0;height:60px;object-fit:cover;width:80px}@media (min-width:1024px){.app-container.desktop-list-view .main-content{display:flex;flex-direction:row}.app-container.desktop-list-view .map-wrapper{flex:1 1}.app-container.desktop-list-view .desktop-shop-list-wrapper{display:block;width:460px}.app-container.desktop-list-view .shop-card-wrapper.desktop-panel{display:none}.app-container.split-view-mode .main-content{display:flex;flex-direction:row}.app-container.split-view-mode .map-wrapper{flex:0 0 60%}.app-container.split-view-mode .desktop-shop-list-wrapper{display:none}.app-container.split-view-mode .shop-card-wrapper.desktop-panel{border-left:1px solid #dee2e6;border-left:1px solid var(--border-color);box-sizing:border-box;display:block;flex:0 0 40%;height:100%;pointer-events:auto;position:relative;transform:none}.app-container.split-view-mode .panel-content-bg{border-radius:0;box-shadow:none;height:100%}.shop-card-wrapper.mobile-only{display:none!important}.related-shops-container,.shop-news-feed-container{display:block}.shop-card-close-btn{margin-left:0;margin-right:0;position:absolute;right:12px}}.leaflet-control a{align-items:center;background-color:#fff;border-radius:4px;box-shadow:0 1px 5px #0003;color:#212529;color:var(--text-color);display:flex;height:34px;justify-content:center;width:34px}.leaflet-control a:hover{background-color:#f4f4f4}.cluster-icon-container{height:41px;position:relative;width:25px}.cluster-badge{align-items:center;background-color:#e87a5d;background-color:var(--primary-color);border:2px solid #fff;border-radius:50%;box-shadow:0 0 5px #0006;color:#fff;display:flex;font-size:11px;font-weight:700;height:20px;justify-content:center;position:absolute;right:-8px;top:-4px;width:20px}.popup-cluster-container{min-width:240px}.popup-cluster-title{border-bottom:1px solid #dee2e6;border-bottom:1px solid var(--border-color);font-size:1rem;font-weight:700;margin:0 0 8px;padding-bottom:8px}.popup-cluster-list{list-style:none;margin:0;max-height:220px;overflow-y:auto;padding:0}.popup-cluster-item{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:12px;padding:8px;transition:background-color .2s ease}.popup-cluster-item:hover{background-color:#f0f0f0}.popup-item-image{background-color:#dee2e6;background-color:var(--border-color);object-fit:cover}.popup-item-image,.popup-item-placeholder{border-radius:4px;flex-shrink:0;height:45px;width:45px}.popup-item-placeholder{align-items:center;background-color:#e9ecef;color:#adb5bd;display:flex;justify-content:center}.popup-item-info{display:flex;flex-direction:column;min-width:0}.popup-item-name{color:#212529;color:var(--text-color);font-size:.95rem;font-weight:700}.popup-item-category,.popup-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.popup-item-category{color:#6c757d;color:var(--text-light-color);font-size:.8rem}.popup-hidden-tag{color:#e74c3c;font-size:.8rem;margin-left:8px}.setup-info{background-color:#e7f3fe;border:1px solid #bce8f1;border-radius:4px;color:#31708f;margin-bottom:20px;padding:15px;text-align:center}.error-message{background-color:#f2dede;border:1px solid #ebccd1;border-radius:4px;color:#a94442;margin-top:15px;padding:10px}.map-loading-overlay{align-items:center;bottom:0;display:flex;justify-content:center;left:0;opacity:0;pointer-events:none;position:absolute;right:0;top:0;transition:opacity .3s ease;z-index:1001}.map-loading-overlay.visible{opacity:1;pointer-events:none}.loading-spinner{animation:spin 1s linear infinite;border:5px solid #0000001a;border-left:5px solid var(--primary-color);border-radius:50%;height:50px;width:50px}.leaflet-control-recenter button{align-items:center;background-color:#fff;border:none;border-radius:50%;box-shadow:0 2px 6px #0003;color:#333;cursor:pointer;display:flex;height:36px;justify-content:center;padding:0;transition:all .2s ease-in-out;width:36px}.leaflet-control-recenter button:hover{background-color:#f4f4f4;color:#000;transform:scale(1.05)}.lightbox-close-btn,.lightbox-content{align-items:center;display:flex;justify-content:center}.shop-image.clickable{cursor:pointer;transition:opacity .2s ease-in-out}.shop-image.clickable:hover{opacity:.85}.filter-input-full{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:1rem;margin-bottom:20px;padding:10px;width:100%}.table-wrapper-full{overflow-x:auto;width:100%}.action-buttons{white-space:nowrap}.action-buttons .edit-button{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:6px 12px;transition:background-color .2s}.action-buttons .edit-button:hover{background-color:#0056b3}.admin-page{display:flex;height:calc(100vh - 60px)}.admin-sidebar{background-color:#f9f9f9;border-right:1px solid #ccc;display:flex;flex-direction:column;flex-shrink:0;width:450px}.admin-map-container{flex-grow:1;position:relative}.admin-form-container{border-bottom:1px solid #ccc;padding:20px}.form-placeholder{color:#666;padding:40px 20px;text-align:center}.form-placeholder h2{margin-top:0}.status-message{border-radius:4px;margin-top:15px;padding:10px;text-align:center}.status-message.success{background-color:#d4edda;color:#155724}.status-message.error{background-color:#f8d7da;color:#721c24}.shop-list-container{display:flex;flex-direction:column;flex-grow:1;overflow:hidden;padding:20px}.shop-list-container h3{margin-top:0}.filter-input{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;margin-bottom:15px;padding:8px;width:100%}.table-wrapper{border:1px solid #ddd;border-radius:4px;flex-grow:1;overflow-y:auto}.shop-table{border-collapse:collapse;width:100%}.shop-table td,.shop-table th{border-bottom:1px solid #ddd;padding:8px 12px;text-align:left}.shop-table th{background-color:#f2f2f2;position:-webkit-sticky;position:sticky;top:0}.shop-table tr.editing{background-color:#fffbe6}.shop-table tr:hover{background-color:#f5f5f5}.shop-list-buttons{display:flex;gap:8px}.shop-list-buttons button{background-color:#fff;border:1px solid #ccc;border-radius:4px;cursor:pointer;padding:4px 8px}.shop-list-buttons button.delete{border-color:#dc3545;color:#dc3545}.shop-list-buttons button.delete:hover{background-color:#dc3545;color:#fff}.shop-list-buttons button:hover{background-color:#e9e9e9}.admin-popup-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;max-width:280px;padding:5px}.admin-popup-shop-name{font-size:1rem;font-weight:700;margin:5px 0 10px}.admin-popup-title{color:#333;font-size:1rem;font-weight:700;margin:5px 0 8px}.admin-popup-list{list-style:none;margin:0;max-height:150px;overflow-y:auto;padding:0}.admin-popup-list li{border-bottom:1px solid #f0f0f0;border-radius:4px;cursor:pointer;font-size:.9rem;padding:8px 5px;transition:background-color .2s ease}.admin-popup-list li:last-child{border-bottom:none}.admin-popup-list li:hover{background-color:#f0f0f0}.admin-popup-separator{background-color:#e0e0e0;height:1px;margin:12px 0}.admin-popup-button{background-color:#007bff;border:1px solid #007bff;border-radius:5px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 12px;text-align:center;transition:background-color .2s ease;width:100%}.admin-popup-button:hover{background-color:#0056b3}.admin-popup-button.add-new{background-color:#28a745;border-color:#28a745}.admin-popup-button.add-new:hover{background-color:#218838}.gm-ui-hover-effect{display:none!important}.gm-style-iw-d{overflow:hidden!important}.gm-style-iw-c{border-radius:8px!important;box-shadow:0 2px 10px #0003!important;padding:0!important}.feedback-page-container{background-color:var(--bg-color);box-sizing:border-box;height:100vh;overflow-y:auto;width:100%}.feedback-form-wrapper{align-items:flex-start;display:flex;justify-content:center;padding:40px 24px}.feedback-card{background-color:var(--panel-bg-color);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 8px 30px #00000014;max-width:650px;padding:32px 40px;width:100%}.feedback-card h2{color:var(--text-color);font-size:2rem;font-weight:800;margin-bottom:8px;margin-top:0;text-align:center}.feedback-subtitle{color:var(--text-light-color);font-size:1rem;line-height:1.6;margin-bottom:32px;text-align:center}.feedback-message{border-radius:8px;font-weight:600;margin-bottom:24px;padding:12px 16px}.feedback-message.success{background-color:#e9f7ec;border:1px solid #a3d9b1;color:#28a745}.feedback-message.error{background-color:#fbebee;border:1px solid #f1b0b5;color:#dc3545}.feedback-card .form-group{margin-bottom:24px}.feedback-card .form-group label{display:block;font-size:.95rem;font-weight:700;margin-bottom:8px}.feedback-card .form-group input,.feedback-card .form-group textarea{border:1px solid #ccc;border-radius:8px;font-family:inherit;font-size:1rem;padding:12px 16px;transition:border-color .2s,box-shadow .2s;width:100%}.feedback-card .form-group input:focus,.feedback-card .form-group textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #e87a5d33;outline:none}.feedback-card .form-group textarea{resize:vertical}.feedback-card .form-actions{margin-top:32px;text-align:center}.feedback-card .submit-button{background-color:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;padding:14px 20px;transition:background-color .2s,transform .2s;width:100%}.feedback-card .submit-button:hover:not(:disabled){background-color:#d9684a;transform:translateY(-2px)}.feedback-card .submit-button:disabled{background-color:#bdbdbd;cursor:not-allowed}.form-group .error-message{color:#dc3545;font-size:.875rem;font-weight:600;margin-top:6px}.form-group input.error,.form-group textarea.error{border-color:#dc3545}.admin-submissions-page{display:flex;flex-direction:column;height:100vh}.admin-submissions-container{background-color:var(--bg-color);flex-grow:1;overflow-y:auto;padding:100px 24px 24px}.admin-submissions-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.admin-submissions-header h1{font-size:2rem;font-weight:800;margin:0}.filter-controls{align-items:center;display:flex;gap:8px}.filter-controls span{color:var(--text-light-color);font-weight:600}.action-dropdown,.filter-controls select{background-color:#fff;border:1px solid #ccc;border-radius:8px;cursor:pointer;font-size:.9rem;padding:8px 12px}.submissions-table-wrapper{background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #0000000d;overflow:hidden}.submissions-table{border-collapse:collapse;width:100%}.submissions-table td,.submissions-table th{border-bottom:1px solid var(--border-color);padding:16px 20px;text-align:left}.submissions-table th{background-color:#f8f9fa;color:var(--text-light-color);font-size:.85rem;font-weight:700;text-transform:uppercase}.submissions-table tbody tr:last-child td{border-bottom:none}.submissions-table tbody tr:hover{background-color:#f7f7f7}.suggestion-cell{line-height:1.5;max-width:350px;white-space:pre-wrap;word-break:break-word}.no-data-cell{color:var(--text-light-color);font-size:1.1rem;padding:40px;text-align:center}.status-badge{border-radius:12px;color:#fff;display:inline-block;font-size:.8rem;font-weight:700;padding:4px 10px;text-transform:capitalize}.status-badge.status-new{background-color:#3498db}.status-badge.status-read{background-color:#2ecc71}.status-badge.status-archived{background-color:#95a5a6}@media (max-width:768px){.submissions-table thead{display:none}.submissions-table tr{border:1px solid var(--border-color);border-radius:8px;display:block;margin-bottom:16px;overflow:hidden}.submissions-table td{display:block;padding-left:50%;position:relative;text-align:right}.submissions-table td:before{color:var(--text-color);content:attr(data-label);font-weight:700;left:16px;position:absolute;text-align:left;width:calc(50% - 32px)}.suggestion-cell{max-width:none}}.admin-page-error,.admin-page-loader{align-items:center;color:var(--text-light-color);display:flex;font-size:1.5rem;height:100vh;justify-content:center}.bulk-upload-page{background-color:#f4f7f6;display:flex;justify-content:center;min-height:calc(100vh - 60px);padding:2rem}.upload-container{background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000014;display:flex;flex-direction:column;max-width:900px;padding:2.5rem;width:100%}.upload-container h1{color:#333;margin-top:0;text-align:center}.instructions{background-color:#eef7ff;border-left:4px solid #007bff;border-radius:4px;color:#444;font-size:.9rem;line-height:1.6;margin:1.5rem 0;padding:1rem}.mode-selector{background-color:#fafafa;border:1px solid #ddd;border-radius:8px;margin:1.5rem 0;padding:1rem}.mode-selector h3{color:#555;font-size:1.1rem;margin-bottom:1rem;margin-top:0}.mode-options{display:flex;flex-direction:column;gap:.75rem}.mode-option{align-items:center;display:flex;gap:.5rem}.mode-option,.mode-option input[type=radio]{cursor:pointer}.mode-option label{color:#333;cursor:pointer;font-weight:700}.mode-option p{color:#666;font-size:.85rem;margin:0;padding-left:1.75rem}.upload-controls{align-items:center;border:2px dashed #ccc;border-radius:8px;display:flex;gap:1rem;justify-content:center;margin-top:1rem;padding:1.5rem}.upload-controls input[type=file]{font-size:1rem}.upload-controls button{background-color:#28a745;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:.75rem 1.5rem;transition:background-color .2s}.upload-controls button:hover:not(:disabled){background-color:#218838}.upload-controls button:disabled{background-color:#a5d6a7;cursor:not-allowed}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:5px;color:#721c24;margin-top:1.5rem;padding:1rem;text-align:center}.results-container{border-top:1px solid #eee;margin-top:2.5rem;padding-top:2rem}.results-container h2{margin-bottom:1.5rem;text-align:center}.summary{display:flex;font-size:1.2rem;gap:2rem;justify-content:center;margin-bottom:2rem}.summary-item.success{color:#155724}.summary-item.failure{color:#721c24}.failures-details h3{color:#721c24;margin-bottom:1rem}.failures-table{border-collapse:collapse;font-size:.9rem;width:100%}.failures-table td,.failures-table th{border:1px solid #ddd;padding:.8rem;text-align:left}.failures-table th{background-color:#f2f2f2}.failures-table tr:nth-child(2n){background-color:#f9f9f9}.interactive-mode-container{display:flex;gap:1.5rem;height:500px;margin-top:2rem}.interactive-map-wrapper{border:1px solid #ccc;border-radius:8px;flex:2 1;overflow:hidden}.interactive-controls{background-color:#f9f9f9;border-radius:8px;display:flex;flex:1 1;flex-direction:column;padding:1.5rem}.interactive-info{border-bottom:1px solid #eee;margin-bottom:1rem;padding-bottom:1rem}.interactive-info h3{color:#007bff;margin-top:0}.interactive-info p{font-size:.9rem;margin:.5rem 0}.interactive-info strong{color:#333}.interactive-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:auto}.interactive-actions button{border:none;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:700;padding:.75rem;transition:background-color .2s}.confirm-next-btn{background-color:#007bff;color:#fff}.confirm-next-btn:hover:not(:disabled){background-color:#0056b3}.confirm-next-btn:disabled{background-color:#a0cfff;cursor:not-allowed}.submit-all-btn{background-color:#28a745;color:#fff}.submit-all-btn:hover:not(:disabled){background-color:#218838}.skip-btn{background-color:#6c757d;color:#fff}.skip-btn:hover{background-color:#5a6268}.cancel-interactive-btn{background-color:#dc3545;color:#fff}.cancel-interactive-btn:hover{background-color:#c82333}.info-highlight{background-color:#fffbe6;border:1px solid #ffe58f;border-radius:4px;margin-top:1rem;padding:.5rem}.admin-page-container{background-color:#f4f7f9;min-height:calc(100vh - 60px);padding:32px}.admin-content-card{background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #0000000d;overflow:hidden}.admin-header-bar{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:20px 24px}.admin-header-bar h2{color:#212529;font-size:1.5rem;font-weight:700;margin:0}.add-new-button{background-color:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 18px;transition:all .2s ease}.add-new-button:hover{background-color:#0056b3;box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}.table-wrapper-full{padding:8px 24px 24px}.admin-shop-table{border-collapse:collapse;border-spacing:0;font-size:.95rem;width:100%}.admin-shop-table thead th{background-color:#f8f9fa;border-bottom:2px solid #dee2e6;color:#6c757d;font-weight:600;padding:16px 12px;text-align:left}.admin-shop-table tbody tr:hover{background-color:#f1f3f5}.admin-shop-table tbody td{border-bottom:1px solid #e9ecef;color:#495057;padding:16px 12px;vertical-align:middle}.admin-shop-table tbody tr:last-child td{border-bottom:none}.status-active,.status-inactive{border-radius:12px;display:inline-block;font-size:.8rem;font-weight:600;padding:4px 10px}.status-active{background-color:#e7f5ee;color:#28a745}.status-inactive{background-color:#f8d7da;color:#dc3545}.action-buttons{display:flex;gap:8px}.delete-button,.edit-button{background-color:#fff;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:pointer;font-weight:500;padding:6px 12px;transition:all .2s ease}.edit-button:hover{background-color:#e9ecef;border-color:#adb5bd}.delete-button{color:#dc3545}.delete-button:hover{background-color:#dc3545;border-color:#dc3545;color:#fff}.modal-overlay{align-items:center;animation:fadeIn .3s ease;background-color:#21252999;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:slideInUp .4s ease;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:600px;padding:0;width:90%}.modal-content.large{max-width:900px}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:16px 24px}.modal-header h3{font-size:1.25rem;margin:0}.modal-close-button{background:none;border:none;color:#6c757d;cursor:pointer;font-size:1.8rem;line-height:1;padding:0}.modal-body{overflow-y:auto;padding:24px}.modal-form-group{margin-bottom:16px}.modal-form-group label{color:#495057;display:block;font-weight:600;margin-bottom:8px}.modal-form-group input[type=number],.modal-form-group input[type=text],.modal-form-group textarea{border:1px solid #ced4da;border-radius:6px;padding:10px;width:100%}.modal-form-row{display:flex;gap:24px}.checkbox-group{align-items:center;display:flex;gap:8px;margin-top:24px}.modal-footer{background-color:#f8f9fa;border-top:1px solid #e9ecef;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.cancel-button,.save-button{border:1px solid #dee2e6;border-radius:8px;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s ease}.cancel-button{background-color:#fff}.cancel-button:hover{background-color:#e9ecef}.save-button{background-color:#007bff;border-color:#007bff;color:#fff}.save-button:hover{background-color:#0056b3;border-color:#0056b3}.modal-view-toggle{border-bottom:1px solid #dee2e6;display:flex;padding:0 24px}.toggle-button{background:none;border:none;border-bottom:3px solid #0000;color:#6c757d;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 16px;position:relative;top:1px}.toggle-button.active{border-bottom-color:#007bff;color:#007bff}.modal-preview-pane{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;min-height:400px;padding:24px;position:relative}.preview-close-button{background-color:#0003;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.5rem;height:32px;line-height:30px;position:absolute;right:12px;text-align:center;top:12px;transition:all .2s ease;width:32px;z-index:10}.preview-close-button:hover{background-color:#0006;transform:scale(1.1)}.modal-preview-pane .news-content-body{font-size:1rem;line-height:1.7}.modal-preview-pane .news-content-body img{border-radius:8px;height:auto;max-width:100%}.modal-preview-pane .news-content-body h2{font-size:1.5rem;margin-bottom:1em;margin-top:1.8em}.image-uploader-container{align-items:flex-start;border:1px solid #ccc;border-radius:8px;display:flex;gap:1rem;padding:1rem}.image-preview-box{align-items:center;border:1px dashed #ccc;border-radius:4px;display:flex;flex-shrink:0;height:150px;justify-content:center;overflow:hidden;width:150px}.image-preview{height:100%;object-fit:cover;width:100%}.image-placeholder{color:#888;font-size:.9rem}.image-upload-controls{display:flex;flex-direction:column;flex-grow:1;gap:.5rem}.image-url-input{border:1px solid #ccc;border-radius:4px;font-size:.9rem;padding:8px 12px;width:100%}.upload-button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 16px;transition:background-color .2s}.upload-button:hover{background-color:#0056b3}.upload-button:disabled{background-color:#aaa;cursor:not-allowed}.news-card{background-color:#e9ecef;border-radius:12px;box-shadow:0 4px 12px #0000001a;cursor:pointer;height:180px;overflow:hidden;position:relative;transition:transform .3s ease,box-shadow .3s ease}.news-card:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-5px)}.news-card-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.news-card:hover .news-card-image{transform:scale(1.05)}.news-card-overlay{background:linear-gradient(0deg,#000c 0,#0000);border-radius:0 0 12px 12px;bottom:0;height:70%;left:0;position:absolute;right:0}.news-card-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;bottom:12px;color:#fff;display:-webkit-box;font-size:1.1rem;font-weight:600;left:16px;line-height:1.4;margin:0;overflow:hidden;position:absolute;right:16px;text-overflow:ellipsis}.news-page-container{animation:fadeIn .5s ease-in-out;margin:0 auto;max-width:1200px;padding:24px}.news-page-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.news-page-header h1{flex-grow:1;font-size:2rem;font-weight:700;margin:0;text-align:right}.back-button{display:flex}.back-button:hover{background-color:#f1f3f5}.news-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.error-text,.loading-text{color:var(--text-light-color);font-size:1.1rem;padding:40px;text-align:center}.error-text{color:#d9534f}.news-card-link{border-radius:12px;color:inherit;display:block;text-decoration:none;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out}.news-card-link:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-5px)}.pagination-controls{gap:16px;justify-content:center;margin-top:32px;padding:16px;-webkit-user-select:none;user-select:none}.pagination-controls button{border:1px solid var(--border-color);border-radius:8px;color:var(--text-color);padding:8px 16px;transition:background-color .2s,color .2s}.pagination-controls button:hover:not(:disabled){background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.pagination-controls span{font-weight:500}.news-detail-container{animation:fadeIn .5s ease-in-out;background-color:#f8f9fa;min-height:100vh;padding:32px 24px}.news-detail-header{margin:0 auto 24px;max-width:800px}.back-button{align-items:center;border-radius:8px;color:var(--text-light-color);display:inline-flex;font-weight:500;gap:8px;padding:8px 12px;text-decoration:none;transition:background-color .2s ease}.back-button:hover{background-color:#e9ecef;color:var(--text-color)}.news-content-wrapper{background-color:#fff;border-radius:16px;box-shadow:0 8px 30px #00000014;margin:0 auto;max-width:800px;padding:40px}.news-content-wrapper h1{font-size:2.5rem;font-weight:800;line-height:1.2;margin-bottom:24px}.news-meta-bar{border-bottom:1px solid #e9ecef;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:32px;padding-bottom:24px}.author-date,.news-meta-bar{align-items:center;display:flex}.author-date{color:var(--text-light-color);font-size:.9rem;gap:8px}.author-date .separator{font-size:1.2rem;line-height:1}.share-buttons{gap:8px}.share-button,.share-buttons{align-items:center;display:flex}.share-button{background-color:#fff;border:1px solid #dee2e6;border-radius:50%;color:#6c757d;cursor:pointer;height:40px;justify-content:center;position:relative;transition:all .2s ease;width:40px}.share-button:hover{background-color:#f1f3f5;border-color:#ced4da;color:#212529;transform:translateY(-2px)}.copy-feedback{animation:fadeIn .3s;background-color:#212529;border-radius:4px;bottom:110%;color:#fff;font-size:.8rem;left:50%;padding:4px 8px;position:absolute;transform:translateX(-50%);white-space:nowrap}.news-detail-image{border-radius:12px;height:auto;margin-bottom:32px;object-fit:cover;width:100%}.news-content-body{font-size:1.1rem;line-height:1.8}.news-content-body p{margin-bottom:1.5em}.news-content-body h2{font-size:1.8rem;margin-bottom:1em;margin-top:2em}.news-content-body h3{font-size:1.5rem;margin-bottom:1em;margin-top:1.8em}.news-content-body ol,.news-content-body ul{margin-bottom:1.5em;padding-left:2em}.news-content-body li{margin-bottom:.5em}.news-content-body a{color:#007bff;text-decoration:underline}.news-content-body blockquote{border-left:4px solid #ced4da;color:#6c757d;font-style:italic;margin:1.5em 0;padding-left:1em}.media-upload-section{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.media-upload-section h3{margin-bottom:1rem;margin-top:0}.upload-new-button{background-color:#0d6efd;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px;transition:background-color .2s}.upload-new-button:hover{background-color:#0b5ed7}.upload-new-button:disabled{background-color:#6c757d;cursor:not-allowed}.upload-message{border-radius:.25rem;margin-top:1rem;padding:.75rem 1.25rem}.upload-message.error{background-color:#f8d7da;border-color:#f5c2c7;color:#842029}.upload-message.success{background-color:#d1e7dd;border-color:#badbcc;color:#0f5132}.spinner{animation:spin 1s ease-in-out infinite;border:3px solid #0000001a;border-radius:50%;border-top-color:#0d6efd;display:inline-block;height:20px;margin-left:1rem;vertical-align:middle;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.media-gallery-header{align-items:center;border-bottom:1px solid #dee2e6;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.media-gallery-header h3{margin:0;white-space:nowrap}.media-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem}.media-sort-container{align-items:center;display:flex;font-size:.9rem;gap:.5rem}.media-sort-select{background-color:#fff;border:1px solid #ced4da;border-radius:5px;font-size:.9rem;padding:8px 12px}.media-search-container{min-width:250px;position:relative}.media-search-input{border:1px solid #ced4da;border-radius:5px;font-size:.9rem;padding:8px 30px 8px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.media-search-input:focus{border-color:#86b7fe;box-shadow:0 0 0 .25rem #0d6efd40;outline:0}.clear-search-btn{background:#0000;border:none;color:#6c757d;cursor:pointer;font-size:1.5rem;line-height:1;padding:0 5px;position:absolute;right:5px;top:50%;transform:translateY(-50%)}.clear-search-btn:hover{color:#212529}.gallery-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.gallery-item{border:1px solid #dee2e6;border-radius:8px;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;overflow:hidden}.gallery-item-image-wrapper{align-items:center;background-color:#f8f9fa;cursor:pointer;display:flex;height:150px;justify-content:center;position:relative;transition:opacity .2s}.gallery-item-image-wrapper:hover{opacity:.8}.gallery-item-image-wrapper img{max-height:100%;max-width:100%;object-fit:contain}.gallery-item-info{background-color:#fff;border-top:1px solid #dee2e6;padding:.75rem}.gallery-item-info .filename{color:#495057;font-size:.8rem;margin:0 0 .75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.error-text{color:#dc3545}.button-group{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr 1fr}.copy-url-button,.delete-button{border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;padding:6px 12px;transition:background-color .2s;width:100%}.copy-url-button{background-color:#6c757d}.copy-url-button:hover{background-color:#5a6268}.delete-button{background-color:#dc3545}.delete-button:hover{background-color:#c82333}.pagination-controls{align-items:center;border-top:1px solid #e9ecef;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-top:2rem;padding-top:1.5rem}.total-files-info{color:#6c757d;font-size:.9rem}.pagination-nav{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.pagination-controls button{background-color:#fff;border:1px solid #ced4da;border-radius:5px;cursor:pointer;font-size:.9rem;padding:8px 12px;transition:background-color .2s}.pagination-controls button:hover:not(:disabled){background-color:#f8f9fa}.pagination-controls button:disabled{cursor:not-allowed;opacity:.5}.pagination-controls .page-info{align-items:center;color:#495057;display:flex;font-size:.9rem;gap:.25rem}.page-input{-moz-appearance:textfield;border:1px solid #ced4da;border-radius:4px;font-size:.9rem;padding:6px;text-align:center;width:50px}.page-input::-webkit-inner-spin-button,.page-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.go-button{background-color:#e9ecef;border-color:#ced4da}.go-button:hover{background-color:#dee2e6}.lightbox-overlay{align-items:center;animation:fadeIn .3s ease;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background-color:#000000d9;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:2000}.lightbox-content{max-height:90vh;max-width:90vw;position:relative}.lightbox-content img{border-radius:8px;box-shadow:0 10px 30px #00000080;max-height:100%;max-width:100%;object-fit:contain}.lightbox-close-btn{background-color:#fff;border:none;border-radius:50%;box-shadow:0 2px 10px #0000004d;color:#000;cursor:pointer;font-size:1.5rem;height:36px;line-height:36px;position:absolute;right:-15px;text-align:center;top:-15px;transition:transform .2s,background-color .2s;width:36px}.lightbox-close-btn:hover{background-color:#f0f0f0;transform:scale(1.1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:768px){.media-controls,.media-gallery-header{align-items:stretch;flex-direction:column}.pagination-controls{flex-direction:column}.pagination-controls,.pagination-nav{justify-content:center}}
/*# sourceMappingURL=main.45543f90.css.map*/