

:root{
  --bg:#06131a;
  --panel:rgba(255,255,255,.12);
  --panel2:rgba(255,255,255,.17);
  --line:rgba(255,255,255,.18);
  --gold:#ffd166;
  --orange:#ff9f1c;
  --teal:#2dd4bf;
  --text:#edf8fb;
  --muted:#cfe0e6;
  --dark:#06131a;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  background:var(--bg);
  color:white;
}
a{text-decoration:none;color:inherit}
.nav{
  position:sticky;
  top:0;
  z-index:1000;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  padding:13px 7%;
  background:rgba(5,19,26,.86);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(18px);
}
.nav a{
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid var(--line);
  font-weight:900;
  font-size:14px;
  transition:.2s;
}
.nav a:hover,.nav a.active{
  background:linear-gradient(135deg,var(--gold),var(--orange));
  color:var(--dark);
  transform:translateY(-1px);
}
.hero{
  min-height:620px;
  display:flex;
  align-items:flex-end;
  padding:90px 8%;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 20% 20%,rgba(45,212,191,.18),transparent 30%),
    linear-gradient(rgba(0,0,0,.30),rgba(0,0,0,.80)),
    var(--hero-img);
  background-size:cover;
  background-position:center;
}
.hero::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:160px;
  background:linear-gradient(transparent,var(--bg));
}
.hero-inner{max-width:1080px;position:relative;z-index:2}
.badge{
  display:inline-block;
  padding:10px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.28);
  backdrop-filter:blur(12px);
  font-weight:900;
  margin-bottom:18px;
}
h1{
  font-size:clamp(46px,8vw,98px);
  line-height:.92;
  margin:0 0 18px;
  letter-spacing:-2px;
}
h2{
  color:white;
  font-size:clamp(34px,5vw,64px);
  line-height:1;
  margin:0 0 22px;
}
h3{color:var(--gold);margin-top:0}
p,li{color:var(--text);line-height:1.58}
.section{
  padding:76px 8%;
  background:
    radial-gradient(circle at 90% 10%,rgba(255,209,102,.08),transparent 28%),
    radial-gradient(circle at 10% 80%,rgba(45,212,191,.08),transparent 26%);
}
.section.dark{background:#071923}
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(270px,1fr));
  gap:24px;
}
.card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:30px;
  padding:26px;
  backdrop-filter:blur(18px);
  box-shadow:0 24px 90px rgba(0,0,0,.25);
  transition:.22s;
}
.card:hover{
  transform:translateY(-5px);
  border-color:rgba(255,209,102,.52);
}
.feature-card{
  min-height:260px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  overflow:hidden;
  padding:0;
}
.feature-img{
  min-height:170px;
  display:flex;
  align-items:flex-end;
  padding:18px;
  font-size:25px;
  font-weight:900;
  background:
    linear-gradient(rgba(0,0,0,.08),rgba(0,0,0,.75)),
    var(--img);
  background-size:cover;
  background-position:center;
}
.feature-body{padding:22px}
.btn{
  display:inline-block;
  padding:13px 18px;
  border-radius:15px;
  margin-top:12px;
  font-weight:900;
  color:var(--dark);
  background:linear-gradient(135deg,var(--gold),var(--orange));
  border:0;
  cursor:pointer;
}
.btn.secondary{
  background:rgba(255,255,255,.13);
  color:white;
  border:1px solid var(--line);
}
.toolbar{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin:22px 0 28px;
  padding:14px;
  background:rgba(255,255,255,.08);
  border:1px solid var(--line);
  border-radius:24px;
  backdrop-filter:blur(14px);
}
.toolbar button,.toolbar input,.toolbar select{
  padding:12px 15px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
}
.toolbar input,.toolbar select{min-width:230px}
.toolbar button{
  background:rgba(255,255,255,.12);
  color:white;
  font-weight:900;
  cursor:pointer;
}
.toolbar button.active,.toolbar button:hover{
  background:linear-gradient(135deg,var(--gold),var(--orange));
  color:var(--dark);
}
input,select{
  width:100%;
  padding:14px;
  border-radius:14px;
  border:0;
  font-size:16px;
}
label{display:block;color:var(--text);font-weight:900;margin:13px 0 7px}
.tags{display:flex;gap:7px;flex-wrap:wrap;margin:14px 0}
.tags span{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.14);
  color:var(--text);
  padding:7px 10px;
  border-radius:999px;
  font-size:13px;
  font-weight:850;
}
.warning{
  background:linear-gradient(135deg,rgba(213,0,0,.50),rgba(255,209,102,.16));
  border:4px solid rgba(255,209,102,.78);
}
.map{
  min-height:420px;
  border-radius:32px;
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(rgba(0,0,0,.05),rgba(0,0,0,.56)),
    url("https://images.unsplash.com/photo-1519451241324-20b4ea2c4220?auto=format&fit=crop&w=1600&q=85");
  background-size:cover;
  background-position:center;
  border:1px solid var(--line);
  box-shadow:0 24px 90px rgba(0,0,0,.25);
}
.pin{
  position:absolute;
  background:linear-gradient(135deg,var(--gold),var(--orange));
  color:var(--dark);
  padding:9px 12px;
  border-radius:999px;
  font-weight:900;
  box-shadow:0 14px 36px rgba(0,0,0,.36);
}
.result{
  background:rgba(0,0,0,.28);
  border:1px solid var(--line);
  border-radius:22px;
  padding:20px;
}
.split{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:24px;
  align-items:start;
}
footer{
  padding:34px 8%;
  background:#041016;
  color:var(--muted);
}
@media(max-width:900px){
  .split{grid-template-columns:1fr}
}
@media(max-width:720px){
  .nav{justify-content:flex-start;overflow:auto;flex-wrap:nowrap;padding:10px 4%}
  .nav a{white-space:nowrap;font-size:13px;padding:9px 10px}
  .hero{min-height:520px;padding:70px 5%}
  .section{padding:52px 5%}
  .toolbar input,.toolbar select{min-width:100%;width:100%}
}


/* Koordinatenbasierte Bangkok-Food-Map */
.bkk-food-map.real-map{background:linear-gradient(135deg,#082431,#123544);}
.real-map .map-title{position:absolute;left:18px;top:18px;z-index:5;background:rgba(6,19,26,.82);border:1px solid rgba(255,209,102,.55);border-radius:18px;padding:12px 14px;font-weight:900;box-shadow:0 10px 28px rgba(0,0,0,.25)}
.real-map .map-sub{display:block;color:#cfe0e6;font-size:12px;font-weight:700;margin-top:4px}
.real-map .river{position:absolute;inset:0;z-index:0;opacity:.58;pointer-events:none}
.real-map .road-grid{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:72px 72px;opacity:.45;pointer-events:none}
.real-map .district-label{position:absolute;z-index:1;color:rgba(255,255,255,.22);font-weight:900;font-size:18px;text-transform:uppercase;letter-spacing:.08em;pointer-events:none}
.food-pin.real{left:calc(var(--x)*1%);top:calc(var(--y)*1%);font-size:11px;padding:7px 9px;max-width:132px;z-index:4;cursor:pointer}
.food-pin.real.restaurant{border-color:rgba(45,212,191,.72)}
.food-pin.real.restaurant:before{background:linear-gradient(135deg,#2dd4bf,#7dd3fc);box-shadow:0 0 0 5px rgba(45,212,191,.18)}
.food-pin.real.zone{border-color:rgba(255,209,102,.78)}
.food-pin.real.night{border-color:rgba(255,159,28,.9)}
.food-pin.real:hover{z-index:20;transform:translate(-50%,-50%) scale(1.08)}
.food-pin small{display:block;font-size:9px;color:#cfe0e6;font-weight:800;line-height:1.05}
@media(max-width:720px){.food-pin.real{font-size:9px;padding:6px 7px;max-width:92px}.real-map .district-label{font-size:13px}.real-map .map-title{font-size:13px;max-width:220px}}


/* Pin-zu-Eintrag-Verlinkung */
.food-pin.real{color:white;text-decoration:none}
.food-card{scroll-margin-top:96px}
.food-card:target{animation:foodTargetGlow 2.4s ease;border-color:rgba(255,209,102,.95)!important;box-shadow:0 0 0 4px rgba(255,209,102,.20),0 24px 90px rgba(0,0,0,.35)}
@keyframes foodTargetGlow{0%{transform:scale(1.015);box-shadow:0 0 0 8px rgba(255,209,102,.38),0 24px 90px rgba(0,0,0,.35)}65%{transform:scale(1);box-shadow:0 0 0 4px rgba(255,209,102,.18),0 24px 90px rgba(0,0,0,.35)}100%{box-shadow:0 24px 90px rgba(0,0,0,.25)}}
.back-map-link{display:inline-block;margin-top:12px;color:#ffd166;font-weight:900}
.back-map-link:hover{text-decoration:underline}


/* v8: Bangkok Food Map im Google-Maps-Stil – scoped, betrifft nur diesen Map-Bereich */
.bkk-food-map.google-map-style{
  min-height:700px;
  background:#e9efe5!important;
  color:#263238;
  --map-zoom:.85;
  --water:#9fd3f1;
  --park:#bddfbd;
  --land:#eef2e8;
  --road-main:#fff7d6;
  --road:#ffffff;
  --road-edge:#d5d0bd;
  --label:#607d6b;
}
.google-map-style .map-viewport{
  transform-origin:50% 54%;
  transform:scale(var(--map-zoom));
  transition:transform .22s ease;
}
.google-map-style .map-title,
.google-map-style .map-controls,
.google-map-style .map-note{
  background:rgba(255,255,255,.92);
  color:#263238;
  border:1px solid rgba(0,0,0,.12);
  box-shadow:0 10px 28px rgba(0,0,0,.16);
}
.google-map-style .map-sub,.google-map-style .zoom-label,.google-map-style .map-note,.google-map-style .map-scale{color:#455a64}
.google-map-style .map-controls button{background:#fff;color:#263238;border:1px solid rgba(0,0,0,.16)}
.google-map-style .map-controls button:hover{background:#e8f0fe;color:#174ea6}
.google-map-style .map-controls input[type=range]{accent-color:#4285f4;height:150px}
.google-map-style .road-grid{opacity:.30;background-size:30px 30px;z-index:0;background-image:linear-gradient(90deg,rgba(80,80,80,.08) 1px,transparent 1px),linear-gradient(rgba(80,80,80,.08) 1px,transparent 1px)}
.google-map-style .map-blocks{opacity:1;z-index:1}
.google-map-style .map-streets{opacity:1;z-index:3}
.google-map-style .transit-lines{opacity:1;z-index:5}
.google-map-style .river{opacity:1;z-index:2}
.google-map-style .district-label{z-index:7;color:rgba(60,64,67,.62);font-size:14px;text-shadow:0 1px 0 rgba(255,255,255,.65);letter-spacing:.04em}
.google-map-style .map-city-label{position:absolute;z-index:7;color:rgba(32,33,36,.72);font-size:11px;font-weight:800;background:rgba(255,255,255,.58);padding:3px 6px;border-radius:999px;pointer-events:none}
.google-map-style .map-park-label{position:absolute;z-index:6;color:#2e7d32;font-size:11px;font-weight:900;pointer-events:none}
.google-map-style .food-pin.real{background:#fff;color:#202124;border:1px solid rgba(0,0,0,.18);box-shadow:0 3px 10px rgba(0,0,0,.23);font-size:10px;padding:6px 8px;max-width:126px}
.google-map-style .food-pin.real small{color:#5f6368}
.google-map-style .food-pin.real:before{width:9px;height:9px;box-shadow:0 0 0 4px rgba(66,133,244,.13)}
.google-map-style .food-pin.real.zone:before{background:#fbbc04}.google-map-style .food-pin.real.restaurant:before{background:#4285f4}.google-map-style .food-pin.real.night:before{background:#ea4335}
.google-map-style .food-pin.real:hover{transform:translate(-50%,-50%) scale(1.13);border-color:#1a73e8;z-index:80}
.google-map-style .map-scale{background:rgba(255,255,255,.72);border-top:4px solid #5f6368;padding:7px 8px;border-radius:0 0 10px 10px;width:auto;min-width:210px}
.google-map-style .map-layer-label{position:absolute;z-index:8;font-size:10px;font-weight:900;color:#5f6368;background:rgba(255,255,255,.76);border:1px solid rgba(0,0,0,.08);border-radius:999px;padding:3px 7px;pointer-events:none}
@media(max-width:720px){.bkk-food-map.google-map-style{min-height:720px}.google-map-style .food-pin.real{font-size:9px;max-width:96px}.google-map-style .map-controls input[type=range]{height:110px}}




/* Bangkok Food Massive Erweiterung - bleibt kompatibel mit css/style.css */
.food-hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.food-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin-top:24px}
.food-kpi{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:24px;padding:18px;backdrop-filter:blur(16px)}
.food-kpi strong{display:block;font-size:30px;color:#ffd166;line-height:1}
.food-map-wrap{display:grid;grid-template-columns:1.4fr .8fr;gap:24px;align-items:stretch}
.bkk-food-map{min-height:520px;border-radius:34px;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.22);box-shadow:0 28px 90px rgba(0,0,0,.32);background:
 radial-gradient(circle at 45% 55%,rgba(45,212,191,.20),transparent 24%),
 radial-gradient(circle at 25% 30%,rgba(255,209,102,.16),transparent 20%),
 linear-gradient(135deg,rgba(4,16,22,.92),rgba(8,35,47,.94)),
 url('https://images.unsplash.com/photo-1563492065599-3520f775eeed?auto=format&fit=crop&w=1800&q=85');background-size:cover;background-position:center}
.bkk-food-map:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px);background-size:56px 56px;opacity:.35}
.food-pin{position:absolute;transform:translate(-50%,-50%);z-index:2;display:flex;align-items:center;gap:7px;padding:8px 10px;border-radius:999px;background:rgba(6,19,26,.82);border:1px solid rgba(255,209,102,.65);box-shadow:0 10px 30px rgba(0,0,0,.35);font-weight:900;font-size:12px;white-space:nowrap;color:white}
.food-pin:before{content:"";width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,#ffd166,#ff9f1c);box-shadow:0 0 0 5px rgba(255,209,102,.18)}
.map-legend{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.map-legend span{padding:8px 10px;border-radius:999px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);font-weight:850;font-size:13px}
.food-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.food-entry-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}
.food-card-plus{overflow:hidden;padding:0!important}.food-img{height:165px;background-size:cover;background-position:center;position:relative;display:flex;align-items:flex-end;padding:16px;font-weight:900;font-size:20px;color:white;text-shadow:0 4px 18px rgba(0,0,0,.9)}
.food-img:after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(0,0,0,.05),rgba(0,0,0,.75))}.food-img span{position:relative;z-index:1}.food-body{padding:22px}.food-meta{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}.food-meta span{padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.16);font-size:12px;font-weight:850}.food-rating{color:#ffd166;font-weight:900;letter-spacing:1px}.food-tip{margin-top:12px;padding:12px;border-radius:16px;background:rgba(45,212,191,.10);border:1px solid rgba(45,212,191,.25);font-size:14px}.mini-list{display:grid;gap:10px;margin-top:14px}.mini-list a{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.14);font-weight:850}.mini-list a:hover{border-color:rgba(255,209,102,.55)}
@media(max-width:900px){.food-map-wrap{grid-template-columns:1fr}.bkk-food-map{min-height:440px}.food-pin{font-size:10px;padding:7px 8px}.food-img{height:145px}}



/* V3 Preview-Fixes */
.toolbar input[type="search"]{min-width:320px;flex:1;background:rgba(255,255,255,.94);color:#06131a;font-weight:800}
.food-card[style*="display: none"]{display:none!important}
.bkk-food-map{isolation:isolate}
.bkk-food-map:after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 50% 50%,transparent 30%,rgba(0,0,0,.12) 100%)}
@media(max-width:720px){.toolbar input[type="search"]{min-width:100%}.food-map-wrap{grid-template-columns:1fr}.bkk-food-map{min-height:520px}.food-pin{white-space:normal;max-width:130px}}



/* V7: mehr echte Map-Optik + Zoom-Leiste, nur lokal in dieser HTML-Datei */
.bkk-food-map.real-map{
  min-height:620px;
  background:
    radial-gradient(circle at 52% 48%,rgba(255,255,255,.06),transparent 18%),
    linear-gradient(135deg,#0b2a35 0%,#113c48 42%,#08212d 100%)!important;
}
.real-map .map-viewport{
  position:absolute;
  inset:0;
  transform-origin:50% 52%;
  transition:transform .28s ease;
}
.real-map[data-zoom="1"] .map-viewport{transform:scale(1)}
.real-map[data-zoom="2"] .map-viewport{transform:scale(1.35)}
.real-map[data-zoom="3"] .map-viewport{transform:scale(1.75)}
.real-map .map-title{z-index:30}
.real-map .map-controls{
  position:absolute;right:16px;top:16px;z-index:35;
  display:grid;gap:8px;justify-items:center;
  padding:12px 10px;border-radius:20px;
  background:rgba(6,19,26,.86);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 14px 36px rgba(0,0,0,.32);
  backdrop-filter:blur(14px);
}
.real-map .map-controls button{
  width:34px;height:34px;border-radius:12px;border:1px solid rgba(255,255,255,.20);
  background:rgba(255,255,255,.12);color:white;font-weight:900;font-size:18px;cursor:pointer;
}
.real-map .map-controls button:hover{background:linear-gradient(135deg,#ffd166,#ff9f1c);color:#06131a}
.real-map .map-controls input[type=range]{
  writing-mode:vertical-lr;direction:rtl;width:34px;height:120px;accent-color:#ffd166;cursor:pointer;
}
.real-map .zoom-label{font-size:11px;color:#cfe0e6;font-weight:900}
.real-map .map-streets,.real-map .transit-lines,.real-map .map-blocks{position:absolute;inset:0;z-index:1;pointer-events:none}
.real-map .map-blocks{opacity:.36}
.real-map .map-streets{opacity:.72}
.real-map .transit-lines{opacity:.92}
.real-map .river{opacity:.76;z-index:2}
.real-map .road-grid{opacity:.18;background-size:38px 38px;z-index:0}
.real-map .district-label{z-index:3;color:rgba(255,255,255,.28);text-shadow:0 2px 12px rgba(0,0,0,.45)}
.food-pin.real{z-index:10}
.food-pin.real:hover{z-index:50}
.real-map .map-scale{
  position:absolute;left:18px;bottom:16px;z-index:34;
  width:150px;padding-top:7px;border-top:4px solid rgba(255,255,255,.75);
  color:#cfe0e6;font-size:11px;font-weight:900;text-align:center;
}
.real-map .map-note{
  position:absolute;right:16px;bottom:16px;z-index:34;max-width:270px;
  padding:10px 12px;border-radius:16px;background:rgba(6,19,26,.78);border:1px solid rgba(255,255,255,.18);
  color:#cfe0e6;font-size:12px;font-weight:800;
}
@media(max-width:720px){
  .bkk-food-map.real-map{min-height:640px}
  .real-map .map-controls{right:10px;top:92px}
  .real-map .map-controls input[type=range]{height:95px}
  .real-map .map-note{display:none}
}


/* Bangkok Food Map Final: saubere Google-Maps-Optik ohne internes Infofeld */
.bkk-food-map.google-map-style{
  min-height: 860px;
  border-radius: 24px;
  overflow: hidden;
  background:#102437;
}
.google-map-style .map-title,
.google-map-style .map-note,
.google-map-style .map-scale{display:none!important;}
.google-map-style .map-tabs{
  position:absolute; left:18px; top:18px; z-index:120; display:flex;
  border-radius:4px; overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,.28);
}
.google-map-style .map-tabs button{
  border:0; padding:13px 18px; font-weight:900; cursor:pointer;
  background:#263238; color:#fff; font-size:14px;
}
.google-map-style .map-tabs button.active{background:#fff;color:#202124;}
.google-map-style .map-fullscreen{
  position:absolute; right:18px; top:18px; z-index:120; width:46px; height:46px;
  border:0; background:#fff; color:#202124; border-radius:4px; font-size:24px; font-weight:900;
  box-shadow:0 2px 8px rgba(0,0,0,.28); cursor:pointer;
}
.google-map-style.is-full-map{
  position:fixed!important; inset:18px!important; width:auto!important; height:auto!important;
  min-height:auto!important; z-index:9999!important; border-radius:18px!important;
}
.google-map-style.is-full-map .map-viewport{min-height:100%;}
@media(max-width:720px){.bkk-food-map.google-map-style{min-height:720px}}

/* Bangkok Food Map: kleine Legenden-Buttons als Filter */
.map-legend button.map-legend-filter{
  padding:8px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  color:white;
  font-weight:850;
  font-size:13px;
  cursor:pointer;
  transition:.18s;
}
.map-legend button.map-legend-filter:hover,
.map-legend button.map-legend-filter.active{
  background:linear-gradient(135deg,var(--gold),var(--orange));
  color:var(--dark);
  border-color:rgba(255,209,102,.75);
  transform:translateY(-1px);
}
