:root{
  --sand:#f5ead6;--sand2:#ede0c4;--sand3:#f9f4ec;
  --ocean:#1a6b8a;--ocean-d:#0c3346;--ocean-l:#4ab0d0;
  --snorkel:#1f7fef;--low:#22a35a;--mid:#d98a10;--high:#cc3b2e;
  --nature:#3d8b5a;--historic:#7a5230;--activity:#6a42a8;
  --river:#2aa0c0;--hotel:#c04070;--transport:#e67e22;
  --text:#16242e;--text2:#3a5a6a;--text3:#6a8a96;--white:#fff;
  --w1:#e8735a;--w2:#2aa0c0;--w3:#c04070;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;overflow:hidden;font-family:'DM Sans',sans-serif;color:var(--text);background:var(--ocean-d);display:flex;flex-direction:column}
body{min-height:0}

/* ── HEADER ── */
header{background:linear-gradient(110deg,#091e2b 0%,#1a5a78 50%,#2898c0 100%);padding:9px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid rgba(255,255,255,0.1);position:relative;overflow:hidden;flex-shrink:0}
header::after{content:'';position:absolute;right:-30px;top:-40px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,0.04)}
.hd{position:relative;z-index:1}
.hd-tag{font-size:9px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--ocean-l);margin-bottom:2px}
.home-link{color:var(--ocean-l);text-decoration:none;opacity:0.8;transition:opacity .15s}
.home-link:hover{opacity:1;text-decoration:underline}
h1{font-family:'Playfair Display',serif;font-size:17px;color:#fff;line-height:1.2}
h1 em{font-style:italic;color:var(--ocean-l)}
.hd-sub{font-size:10.5px;color:rgba(255,255,255,0.45);margin-top:1px}
.filters{display:flex;gap:4px;align-items:center;flex-wrap:wrap;position:relative;z-index:1}
.fb{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.18);border-radius:20px;padding:3px 10px;font-size:10px;font-family:'DM Sans',sans-serif;color:rgba(255,255,255,0.7);cursor:pointer;transition:all .15s;white-space:nowrap}
.fb:hover,.fb.on{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.45);color:#fff;font-weight:600}
.lang-btn{background:rgba(255,255,255,0.08)!important;border-color:rgba(255,255,255,0.3)!important;margin-left:4px;text-decoration:none;font-weight:700!important}
.lang-btn:hover{background:rgba(255,255,255,0.25)!important;color:#fff!important}

/* ── LAYOUT ── */
.wrap{display:flex;flex:1;min-height:0}
.sidebar{width:316px;flex-shrink:0;background:var(--sand);overflow-y:auto;display:flex;flex-direction:column}
.sidebar::-webkit-scrollbar{width:3px}
.sidebar::-webkit-scrollbar-thumb{background:var(--ocean-l);border-radius:2px}

/* ── ACCOM KEY ── */
.accom-key{padding:8px 14px;background:#fff;border-bottom:1px solid var(--sand2);flex-shrink:0}
.ak-title{font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--text3);margin-bottom:5px}
.ak-row{display:flex;gap:8px;flex-wrap:wrap}
.ak{display:flex;align-items:center;gap:5px;font-size:10.5px;color:var(--text2);background:var(--sand3);border-radius:6px;padding:3px 8px}
.ak-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ── LEGEND ── */
.legend{padding:7px 14px;background:#fff;border-bottom:1px solid var(--sand2);flex-shrink:0}
.lg-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:3px}
.lg-row:last-child{margin-bottom:0}
.li{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text2)}
.lg-filter{cursor:pointer;background:none;border:1px solid transparent;border-radius:12px;padding:2px 7px;font-family:inherit;transition:all .15s}
.lg-filter:hover{background:var(--sand2);border-color:var(--sand2)}
.lg-filter.active{background:var(--ocean);color:#fff;border-color:var(--ocean)}
.lg-filter.active .ld{border:1px solid rgba(255,255,255,0.5)}
.ld{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.lsep{border:none;border-top:1px solid var(--sand2);margin:4px 0}

/* ── GYG BANNER ── */
.gyg-banner{display:flex;align-items:center;gap:10px;padding:10px 14px;background:linear-gradient(135deg,#fff4e6 0%,#ffe8cc 100%);border-bottom:1px solid #f0d4a8;text-decoration:none;cursor:pointer;transition:all .15s;flex-shrink:0}
.gyg-banner:hover{background:linear-gradient(135deg,#ffe8cc 0%,#ffd9a8 100%)}
.gyg-icon{font-size:24px;flex-shrink:0}
.gyg-text{flex:1;min-width:0}
.gyg-title{font-size:12px;font-weight:700;color:var(--text);line-height:1.3}
.gyg-sub{font-size:10px;color:var(--text2);margin-top:1px}

/* ── SECTION HEADER ── */
.sh{font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--text3);padding:9px 14px 4px;display:flex;align-items:center;gap:6px}
.sh::after{content:'';flex:1;height:1px;background:var(--sand2)}

/* ── CARDS ── */
.cards-wrap{padding:5px 9px 20px}
.card{background:#fff;border-radius:9px;padding:9px 11px;margin-bottom:5px;cursor:pointer;transition:all .15s;border:2px solid transparent;box-shadow:0 1px 4px rgba(0,0,0,0.07);position:relative;overflow:hidden}
.card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:9px 0 0 9px}
.card.beach::before{background:var(--ocean)}
.card.snorkel::before{background:var(--snorkel)}
.card.river::before{background:var(--river)}
.card.nature::before{background:var(--nature)}
.card.historic::before{background:var(--historic)}
.card.activity::before{background:var(--activity)}
.card.accom::before{background:var(--hotel)}
.card.transport::before{background:var(--transport)}
.card.transport{background:linear-gradient(135deg,#fff9f0 0%,#fff 100%);border:2px solid #f0d4a8}
.card.hidden{display:none!important}

/* ── TRANSPORT CTA ── */
.transport-cta{display:flex;gap:5px;flex-wrap:wrap;margin-top:6px}
.cta-btn{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:6px 12px;border-radius:8px;text-decoration:none;transition:all .15s;white-space:nowrap}
.cta-car{background:var(--ocean);color:#fff}
.cta-car:hover{background:var(--ocean-d)}
.cta-flight{background:var(--activity);color:#fff}
.cta-flight:hover{background:#5a35a0}
.cta-ferry{background:var(--transport);color:#fff}
.cta-ferry:hover{background:#cf6d16}
.card:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,0.1);border-color:var(--ocean-l)}
.card.active{border-color:var(--ocean);background:#f0f8fc}

.ct{display:flex;align-items:flex-start;justify-content:space-between;gap:5px;margin-bottom:3px}
.cn{font-family:'Playfair Display',serif;font-size:13px;font-weight:700;color:var(--text);line-height:1.3}
.cm{display:flex;gap:3px;flex-wrap:wrap;flex-shrink:0;align-items:center}
.pill{font-size:9px;font-weight:500;padding:2px 6px;border-radius:20px;white-space:nowrap}
.p-free{background:#ecfdf3;color:var(--low)}
.p-paid{background:#fff7e6;color:#a06010}
.p-boat{background:#e8f4ff;color:var(--ocean)}
.p-reg{background:#f5eee8;color:var(--historic)}
.p-snork{background:#dbeeff;color:var(--snorkel)}
.p-secret{background:#fef3c7;color:#92400e}

/* ── DRIVE TIMES ── */
.drives{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:4px}
.dt{display:flex;align-items:center;gap:3px;font-size:10px;font-weight:500;padding:1px 6px;border-radius:12px;white-space:nowrap}
.dt-w1{background:#fde8e3;color:#b04030}
.dt-w2{background:#ddf0f7;color:#1a6b8a}
.dt-w3{background:#fce7f3;color:#9b2f5e}
.dt-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.dt-w1 .dt-dot{background:#e8735a}
.dt-w2 .dt-dot{background:#2aa0c0}
.dt-w3 .dt-dot{background:#c04070}

/* ── CROWD ── */
.crowd{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:500;margin-bottom:3px}
.cd{width:6px;height:6px;border-radius:50%}
.cl{color:var(--low)}.cl .cd{background:var(--low)}
.cmid{color:var(--mid)}.cmid .cd{background:var(--mid)}
.ch{color:var(--high)}.ch .cd{background:var(--high)}
.cs{color:var(--snorkel)}.cs .cd{background:var(--snorkel)}
.cd2{font-size:11px;color:var(--text2);line-height:1.5}
.cr2{margin-top:4px;font-size:10px;color:var(--text3);display:flex;align-items:center;justify-content:space-between}
.link-btn{display:inline-flex;align-items:center;gap:3px;font-size:9.5px;font-weight:500;color:var(--ocean);text-decoration:none;background:var(--sand3);border:1px solid var(--sand2);border-radius:12px;padding:2px 8px;transition:all .15s;white-space:nowrap;flex-shrink:0}
.link-btn:hover{background:var(--ocean);color:#fff;border-color:var(--ocean)}
.geo-dist{font-size:9px;font-weight:600;color:var(--ocean);background:#e0f2ff;padding:1px 6px;border-radius:10px;white-space:nowrap}
.plink{display:inline-block;margin-top:5px;font-size:11px;color:#1a6b8a;text-decoration:none;font-weight:500}
.plink:hover{text-decoration:underline}
.layer-ctrl{position:absolute;top:10px;right:10px;z-index:1000;background:#fff;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,0.2);overflow:hidden}
.layer-btn{display:block;padding:7px 12px;font-size:11px;font-family:'DM Sans',sans-serif;border:none;background:#fff;cursor:pointer;color:var(--text);white-space:nowrap;transition:all .12s}
.layer-btn:hover{background:var(--sand)}
.layer-btn.active{background:var(--ocean);color:#fff;font-weight:600}
.layer-sep{height:1px;background:#e8e8e8;margin:0}
.layer-btn.overlay-btn{color:#3d8b5a;font-size:10.5px}
.layer-btn.overlay-btn.active{background:#3d8b5a;color:#fff;font-weight:600}
.star{color:#f5a623}

/* ── MAP ── */
#map{flex:1;z-index:1}

/* ── POPUP ── */
.leaflet-popup-content-wrapper{border-radius:12px!important;box-shadow:0 8px 28px rgba(0,0,0,0.2)!important;padding:0!important;overflow:hidden}
.leaflet-popup-content{margin:0!important;width:auto!important}
.pb{height:4px}
.pi{padding:11px 14px;max-width:270px;min-width:210px}
.pn{font-family:'Playfair Display',serif;font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:2px}
.pm{font-size:10px;color:var(--text3);margin-bottom:5px}
.pd{font-size:11.5px;color:var(--text2);line-height:1.5}
.pdrives{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px}

@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:0.5}}
@media(max-width:680px){.wrap{flex-direction:column}.sidebar{width:100%;flex:0 0 42vh}#map{flex:0 0 58vh}header{flex-direction:column;align-items:flex-start;gap:5px;padding:7px 12px}h1{font-size:14px}.filters{gap:3px}.fb{padding:2px 7px;font-size:9px}}
