*{
box-sizing:border-box;
margin:0;
padding:0;
font-family:Arial, Helvetica, sans-serif;
}

html,
body{
width:100%;
height:100%;
margin:0;
padding:0;
background:#0b1720;
}

body{
color:#ffffff;
min-height:100vh;
}

.page-shell{
width:100%;
min-height:100vh;
margin:0;
padding:0;
background:#0b1720;
}

#app{
width:100%;
min-height:100vh;
margin:0;
padding:0;
}

.map-only-section{
width:100%;
position:relative;
}

#surf-map{
width:100%;
height:calc(100vh - 32px);
min-height:600px;
border-radius:16px;
overflow:hidden;
border:1px solid rgba(255,255,255,0.08);
box-shadow:0 14px 34px rgba(0,0,0,0.28);
}

/* PANEL SUPERIOR */

.top-badge{
position:absolute;
top:18px;
left:70px;
z-index:1000;
background:rgba(15, 23, 42, 0.92);
backdrop-filter:blur(8px);
border:1px solid rgba(255,255,255,0.08);
border-radius:14px;
padding:12px 14px;
box-shadow:0 10px 24px rgba(0,0,0,0.25);
min-width:220px;
max-width:260px;
}

.top-badge-label{
font-size:11px;
letter-spacing:1px;
color:#94a3b8;
margin-bottom:4px;
}

.top-badge-name{
font-size:20px;
font-weight:700;
color:#ffffff;
line-height:1.1;
margin-bottom:4px;
}

.top-badge-meta{
font-size:14px;
color:#facc15;
font-weight:700;
margin-bottom:6px;
}

.top-badge-extra{
font-size:13px;
color:#cbd5e1;
margin-bottom:4px;
}

.top-badge-back{
display:inline-block;
margin-top:6px;
font-size:13px;
color:#7dd3fc;
text-decoration:none;
font-weight:700;
}

.top-badge-back:hover{
text-decoration:underline;
}

/* CONTROLES MAPA */

.leaflet-control-zoom{
margin-top:18px !important;
margin-left:18px !important;
}

/* POPUP LEAFLET (QUITAR PANEL BLANCO) */

.leaflet-popup-content-wrapper{
background:rgba(15, 23, 42, 0.96);
color:#ffffff;
border-radius:14px;
box-shadow:0 10px 24px rgba(0,0,0,0.35);
}

.leaflet-popup-tip{
background:rgba(15, 23, 42, 0.96);
}

.leaflet-popup-content{
margin:12px 14px;
color:#ffffff;
}

/* CONTENIDO DEL POPUP */

.map-popup{
color:#ffffff;
min-width:140px;
}

.map-popup h3{
margin-bottom:4px;
font-size:16px;
}

.map-popup .popup-zone{
font-size:12px;
color:#94a3b8;
margin-bottom:8px;
}

.map-popup .popup-stars{
color:#facc15;
font-size:18px;
margin-bottom:4px;
}

.map-popup .popup-status{
font-size:13px;
font-weight:bold;
color:#e2e8f0;
}

/* MARCADORES */

.custom-marker{
display:flex;
align-items:center;
justify-content:center;
width:38px;
height:38px;
border-radius:50%;
border:2px solid #ffffff;
box-shadow:0 4px 10px rgba(0,0,0,0.32);
position:relative;
}

.marker-stars{
color:#ffffff;
font-size:15px;
font-weight:bold;
letter-spacing:-1px;
}

.marker-verde-oscuro{ background:#16a34a; }
.marker-verde{ background:#4ade80; }
.marker-amarillo{ background:#facc15; }
.marker-naranja{ background:#fb923c; }
.marker-rojo{ background:#ef4444; }

/* MÓVIL */

@media (max-width: 768px){

.page-shell{
padding:10px;
}

#surf-map{
height:calc(100vh - 20px);
min-height:520px;
border-radius:12px;
}

.top-badge{
top:58px;
left:12px;
right:12px;
min-width:auto;
max-width:none;
padding:10px 12px;
}

.top-badge-name{
font-size:18px;
}

.top-badge-meta{
font-size:13px;
}

.top-badge-extra{
font-size:12px;
}

.custom-marker{
width:30px;
height:30px;
}

.marker-stars{
font-size:13px;
}

}
