/* ==========================
   Museum Map Styles (Clean)
========================== */

/* Hide default Leaflet layers toggle */
.leaflet-control-layers-toggle{display:none}

/* Floating button */
#floating-map-button{position:fixed;right:20px;bottom:20px;z-index:2147483648;background:#06c;color:#fff;font-size:16px;font-weight:600;padding:12px 18px;border:none;border-radius:50px;cursor:pointer;box-shadow:0 4px 10px #0000004d;transition:background .2s,transform .2s}
#floating-map-button:hover{background:#004999}
button:focus,a:focus,#floating-map-button:focus,.museum-map-modal__close:focus,.reopen-marker-btn:focus,.hotel-sticky__btn:focus,.museum-map-toggle-btn:focus,.filter-toggle-btn:focus{outline:2px solid #06c;outline-offset:2px;box-shadow:0 0 0 3px #0066cc4d}

/* Modal wrapper */
#museum-map-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.85);z-index:2147483647;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s ease,visibility .3s ease}
#museum-map-modal.show{opacity:1;visibility:visible;pointer-events:auto}
body.modal-open{overflow:hidden}

/* Modal content */
.museum-map-modal__content{position:relative;display:flex;flex-direction:column;width:100%;max-width:100vw;height:100vh;background:#f5f0e6 url(/wp-content/themes/Newspaper-child/assets/images/paper-texture.png) repeat;box-sizing:border-box;border-radius:0;padding:0;overflow-x:hidden}

/* Modal title */
.museum-map-modal__title{margin:0;padding:10px 0;font-family:"Work Sans",serif;font-size:1.6rem;font-weight:700;text-align:center;color:#222;line-height:1.3;text-shadow:0 2px 4px #00000026}

/* Close button */
.museum-map-modal__close{position:absolute;top:12px;right:12px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#f5f0e6;border:1px solid #d8c9b6;border-radius:50%;color:#555;font-size:20px;font-weight:700;cursor:pointer;box-shadow:0 2px 6px #0003;transition:all .2s;z-index:2147483648}
.museum-map-modal__close:hover{background:#fff3f3;border-color:#c66;color:#a00;transform:scale(1.1)}
.museum-map-modal__close:active{transform:scale(0.95)}

/* Map container */
#museum-map-modal-container{flex:1;width:100%;height:auto;border-radius:0;overflow:hidden;margin:0 auto;box-sizing:border-box;position:relative;z-index:9999;pointer-events:auto}

/* Bottom bar */
.map-bottom-buttons{bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:600px;padding:8px 12px;background:#ffffffd9;box-shadow:0 -2px 8px #0000001a;border-radius:8px;display:flex;flex-direction:column;gap:10px;z-index:2147483647;box-sizing:border-box;overflow-x:hidden}
.map-bottom-actions{display:flex;gap:10px;justify-content:space-between;flex-wrap:wrap;width:100%}
.map-show-btn{flex:1;min-width:120px;padding:10px 14px;background:#06c;color:#fff;border:none;border-radius:6px;font:600 14px "Work Sans",sans-serif;cursor:pointer;box-shadow:0 3px 6px #00000040;transition:background .2s,transform .15s}
.map-show-btn:hover{background:#004999;transform:translateY(-1px)}
.map-show-btn:active{transform:translateY(0)}
.map-categories-wrapper{position:relative}
.map-categories-btn{padding:10px 14px;background:#f5f1e8;border:1px solid #d8cfc0;border-radius:6px;font:600 14px "Work Sans",sans-serif;cursor:pointer;box-shadow:0 2px 4px #00000026}
.map-categories-btn:hover{background:#ede6db}
.map-categories-menu{position:fixed;display:none;flex-direction:column;gap:6px;background:#fff;border:1px solid #ccc;border-radius:6px;padding:8px 10px;min-width:180px;box-shadow:0 4px 10px #0006;z-index:2147483647}
.map-categories-menu.open{display:flex}
.map-categories-menu button{background:#f9f9f9;color:#333;border:none;padding:6px 10px;border-radius:4px;text-align:left;font-size:14px;cursor:pointer}
.map-categories-menu button:hover{background:#eee}
.map-categories-menu button.active{background:#06c;color:#fff}

/* Search box */
.map-search-wrap{width:100%}
.map-search-inner{position:relative;display:flex;align-items:center}
.map-search-input{flex:1;height:34px;padding:0 30px 0 10px;font-size:14px;border:1px solid #bbb;border-radius:6px;outline:none;box-shadow:inset 0 1px 2px #0001}
.map-search-input:focus{border-color:#06c;box-shadow:0 0 0 3px #0066cc26}
.map-search-clear{position:absolute;right:8px;background:none;border:none;font-size:14px;color:#666;cursor:pointer;display:none}
.map-search-clear:hover{color:#000}
.map-search-results{position:fixed;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 6px 18px #0003;padding:6px;display:none;z-index:2147483647;max-height:50vh;overflow-y:auto}
.map-search-results.show{display:block}
.map-search-results:empty{display:none!important}
.map-search-results .explore-result{display:flex;align-items:center;gap:8px;padding:6px 8px;text-decoration:none;color:#333;border-bottom:1px solid #eee}
.map-search-results .explore-result:last-child{border-bottom:none}
.map-search-results .explore-result:hover{background:#f7f7f7}
.map-search-results .explore-result-thumb{width:36px;height:36px;object-fit:cover;border-radius:4px}
.map-search-results .explore-result-title{flex:1;font-size:14px}

/* Sticky hotel button */
.hotel-sticky{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);z-index:2147483646;display:flex;justify-content:center;width:100%;pointer-events:none}
.hotel-sticky__btn{background:#e63946;color:#fff;font-size:16px;font-weight:600;padding:12px 28px;border-radius:8px;box-shadow:0 4px 12px #00000040;text-decoration:none;transition:background .2s;pointer-events:auto}
.hotel-sticky__btn:hover{background:#c9182d}
.hotel-sticky.hidden{display:none}

/* Popups */
.leaflet-container .leaflet-popup-close-button{display:none!important}
.leaflet-container .leaflet-popup-content-wrapper{max-width:320px!important;border-radius:8px!important;box-shadow:0 4px 14px #00000040!important;padding:10px 12px!important}
.leaflet-container .mappopup-header{display:flex;justify-content:space-between;align-items:center;gap:8px;padding-bottom:6px;margin-bottom:0;position:relative}
.leaflet-container .mappopup-header::after{content:""!important;position:absolute!important;left:0;right:0;bottom:0;height:1px;background:linear-gradient(to right,transparent,#00000026,transparent)}
.leaflet-container .mappopup-header h3{margin:0!important;font-size:18px!important;font-weight:600!important;flex:1!important;min-width:0!important;line-height:1.2!important;padding-top:2px!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}
.leaflet-container .mappopup-body{font-size:14px!important;line-height:1.4!important;padding:4px 0!important}
.leaflet-container .mappopup p{font-size:14px!important;line-height:1.4!important;margin:6px 0 8px!important;color:#444!important}
.leaflet-container .mappopup img{display:block!important;width:100%!important;height:auto!important;max-width:100%!important;margin:0 0 8px!important;object-fit:cover!important;box-sizing:border-box!important}
.leaflet-container .mappopup-close{width:26px!important;height:26px!important;background:#333!important;color:#fff!important;font-size:16px!important;font-weight:900!important;border-radius:4px!important;border:none!important;display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;flex-shrink:0!important;transition:background .2s!important}
.leaflet-container .mappopup-close:hover{background:#000!important}

/* Responsive modal + popups */
@media(max-width:767px){
  .museum-map-modal__content{width:100%;height:100%;padding:0;border-radius:0;max-width:none;max-height:none}
  #museum-map-modal-container{height:90vh;border-radius:0}
  .leaflet-container .leaflet-popup-content-wrapper{max-width:220px!important;padding:6px 8px!important;border-radius:10px!important;box-shadow:0 3px 12px #00000040!important}
  .leaflet-container .leaflet-popup-tip{display:none!important}
  .leaflet-container .leaflet-popup-content{font-size:13px!important;line-height:1.1!important}
  .leaflet-container .leaflet-popup-content p,.leaflet-container .mappopup-body{font-size:13px!important;line-height:1.2!important;margin:0 0 6px!important}
  .mappopup-header{align-items:center}
  .mappopup-header h3{line-height:1.3;margin:0;display:flex;align-items:center}
}

/* Hotel cards */
.museum-map-button{display:inline-block;background:#4db2ec;color:#fff;font-weight:600;padding:.75em 1.5em;border:none;border-radius:5px;cursor:pointer;font-family:'Roboto',sans-serif;font-size:1rem;transition:background .2s,transform .2s;box-shadow:0 4px 12px #0006;text-decoration:none}
.museum-map-button:hover{background:#3b9bd6;transform:translateY(-1px)}
#hotel-presentation{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-top:24px}
.hotel-card{border:1px solid #eee;border-radius:8px;padding:12px;background:#fff;box-shadow:0 2px 8px #0002}
.hotel-card img{border-radius:6px}
.hotel-meta-top{display:flex;flex-wrap:wrap;gap:2px;font-size:1em;line-height:1.1;margin:6px 0 4px}
.hotel-meta-top span{margin-right:4px;color:#333}
.hotel-rating-avg strong{color:#0089CE}
.hotel-button{display:inline-block;padding:6px 12px;background:#0089CE;color:#fff;text-decoration:none;border-radius:4px;font-size:.9em;transition:background .2s;margin-top:6px}
.hotel-button:hover{background:#006fa8}
.mappopup .hotel-button:not(.hotel-only){display:inline-block;padding:6px 12px;background-color:#0089CE;color:#fff!important;text-decoration:none!important;border-radius:4px;font-size:.9em;font-weight:600;transition:background-color .2s ease;margin-top:6px}
.mappopup .hotel-button:not(.hotel-only):hover{background-color:#006fa8;color:#fff!important}
.mappopup .hotel-button.hotel-only{background-color:#D4AF37;color:#fff!important}
.mappopup .hotel-button.hotel-only:hover{background-color:#B68E2C;color:#fff!important;text-decoration:none}
.leaflet-container .mappopup:not(.hotel-popup) img{display:none!important}
.leaflet-container .mappopup.hotel-popup{height:140px!important;overflow:hidden!important;margin-bottom:8px!important}
.leaflet-container .mappopup.hotel-popup img{display:block!important;width:100%!important;height:100%!important;object-fit:cover!important}

/* Fullscreen control button */
.leaflet-control-fullscreen-button{background:url("../images/fullscreen.png") no-repeat center center;background-size:18px 18px;width:26px;height:26px}
