:root{
  --bg:#FFFFFF; --blue:#10B7E5; --blue-h:#0DA3CC; --red:#EF3E2E; --red-h:#D73528;
  --text:#0F172A; --text2:#475569; --border:#E2E8F0;
  --emerald:#059669; --amber:#D97706; --rose:#E11D48; --slate:#64748B;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:#F8FAFC}
a{color:var(--blue);text-decoration:none}
.wrap{max-width:1040px;margin:0 auto;padding:0 16px}
header.app{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid var(--border)}
header.app .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;cursor:pointer}
.brand img.wordmark{height:40px;width:auto;display:block}
.brand .dpurl{font-weight:700;font-size:12px;color:var(--blue);letter-spacing:.2px}
.hero-logo{display:block;width:min(300px,72%);height:auto;margin:0 auto 10px}
.nav-btns{display:flex;gap:8px}
.btn{border:1px solid var(--border);background:#fff;color:var(--text);padding:9px 16px;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:7px}
.btn:hover{border-color:#cbd5e1;background:#f8fafc}
.btn.primary{background:var(--blue);border-color:var(--blue);color:#fff}
.btn.primary:hover{background:var(--blue-h);border-color:var(--blue-h)}
.btn.red{background:var(--red);border-color:var(--red);color:#fff}
.btn.red:hover{background:var(--red-h)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.sm{padding:6px 12px;font-size:13px}

.hero{text-align:center;padding:46px 0 10px}
.hero h1{font-size:40px;margin:14px 0 6px;letter-spacing:-1px}
.hero .tag{font-size:18px;color:var(--blue);font-weight:700}
.hero .sub{color:var(--text2);max-width:560px;margin:8px auto 0;font-size:15px}
.stats{display:flex;gap:28px;justify-content:center;margin:22px 0 6px}
.stats div{text-align:center}
.stats b{display:block;font-size:24px;color:var(--text)}
.stats span{font-size:12px;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}

.card{background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:0 1px 3px rgba(15,23,42,.04)}
.panel{padding:26px;margin:24px 0 60px}
.panel h2{margin:0 0 4px;font-size:22px}
.panel .lead{color:var(--text2);margin:0 0 20px;font-size:14px}
label.fld{font-weight:700;font-size:14px;margin:18px 0 7px;display:flex;align-items:center;gap:7px}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{flex:1;min-width:120px;border:1px solid var(--border);background:#fff;border-radius:12px;padding:12px;font-size:14px;font-weight:600;cursor:pointer}
.seg button.on{border-color:var(--blue);background:#ecfaff;color:var(--blue-h)}
input[type=text],select{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:12px;font-size:15px;background:#fff;outline:none}
input[type=text]:focus,select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #cdefff}
.suggest{position:absolute;left:0;right:0;top:calc(100% + 4px);background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 28px rgba(15,23,42,.14);z-index:50;overflow:hidden}
.suggest div{padding:10px 14px;cursor:pointer;font-size:14px;border-bottom:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.suggest div:last-child{border-bottom:0}
.suggest div:hover{background:#f1f9ff;color:var(--blue-h)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hint{font-size:12.5px;color:var(--text2);margin-top:6px}
.ok{color:var(--emerald);font-weight:600}
.toggle{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--border);border-radius:14px;padding:14px 16px;margin-top:10px;background:#fbfdff}
.toggle .t-txt b{display:block;font-size:14px}
.toggle .t-txt span{font-size:12.5px;color:var(--text2)}
.switch{width:46px;height:26px;border-radius:999px;background:#cbd5e1;position:relative;cursor:pointer;flex:none;transition:.2s}
.switch.on{background:var(--blue)}
.switch i{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:.2s}
.switch.on i{left:23px}
.wc-modes{display:flex;gap:8px;margin-top:10px}
.wc-modes button{flex:1;border:1px solid var(--border);background:#fff;border-radius:10px;padding:9px;font-size:13px;font-weight:600;cursor:pointer}
.wc-modes button.on{border-color:var(--red);background:#fef2f1;color:var(--red-h)}

#map{height:460px;border-radius:16px;overflow:hidden;border:1px solid var(--border)}
.summary{display:flex;gap:18px;flex-wrap:wrap;align-items:baseline;margin:18px 0}
.summary h2{margin:0;font-size:24px}
.summary .meta{color:var(--text2);font-size:14px}
.flow{background:#ecfaff;border:1px solid #bdeafd;color:#0b6c8a;border-radius:12px;padding:11px 15px;font-size:13.5px;margin:14px 0}
.trim{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:12px;padding:11px 15px;font-size:13.5px;margin:14px 0;display:none}
.drivenote{background:#fff1f0;border:1px solid #fbcfca;color:#9a1b1b;border-radius:12px;padding:11px 15px;font-size:13.5px;margin:14px 0;display:none;font-weight:600}
.countries{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 18px}
.chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);border-radius:999px;padding:6px 12px;font-size:13px;font-weight:600}

.stop{display:flex;gap:16px;padding:16px;align-items:flex-start;border-bottom:1px solid var(--border)}
.stop:last-child{border-bottom:0}
.stopnum{flex:none;width:30px;height:30px;border-radius:50%;background:var(--blue);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:14px;margin-top:2px}
.venuephoto{flex:none;width:96px;height:96px;border-radius:14px;overflow:hidden;position:relative;border:1px solid var(--border);background:#eef2f7}
.venuephoto .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:34px}
.venuephoto .fl{position:absolute;left:6px;bottom:6px;font-size:18px;filter:drop-shadow(0 1px 1px rgba(0,0,0,.3))}
.stopbody{flex:1;min-width:0}
.stoptop{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.stoptop .name{font-weight:700;font-size:17px}
.stoptop .ctry{color:var(--text2);font-size:13.5px;font-weight:600}
.addr{color:var(--text2);font-size:13px;margin:3px 0 8px}
.drinkline{display:flex;align-items:center;gap:10px;margin:8px 0}
.drinkglass{width:42px;height:42px;flex:none;display:inline-flex}
.drinkname{font-weight:700;font-size:15px}
.drinkcat{font-size:12px;color:var(--text2)}
.confchip{font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:999px;border:1px solid}
.c-high{color:var(--emerald);background:#ecfdf5;border-color:#a7f3d0}
.c-med{color:var(--amber);background:#fffbeb;border-color:#fde68a}
.c-low{color:var(--rose);background:#fff1f2;border-color:#fecdd3}
.c-nv{color:var(--slate);background:#fff;border-color:#cbd5e1}
.wcbadge{font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:999px;background:#fef2f1;color:var(--red-h);border:1px solid #fbcfca}
.wcplayer{display:flex;align-items:center;gap:10px;margin-top:10px;background:#fff7f6;border:1px solid #fbcfca;border-radius:12px;padding:8px 12px;font-size:13.5px}
.wcplayer .pimg{width:38px;height:38px;border-radius:50%;overflow:hidden;flex:none;display:flex;align-items:center;justify-content:center;background:#fde3df;font-size:18px}
.wcplayer .pimg img{width:100%;height:100%;object-fit:cover}
.wcplayer .ptxt b{color:var(--text)}
.legs{display:flex;gap:16px;color:var(--text2);font-size:12.5px;margin-top:8px;flex-wrap:wrap}
.stopactions{display:flex;flex-direction:column;gap:8px;flex:none}
.alts{margin-top:12px;border-top:1px dashed var(--border);padding-top:10px}
.alts summary{cursor:pointer;font-size:13px;font-weight:700;color:var(--blue-h)}
.alt{display:flex;align-items:center;gap:10px;padding:8px;border:1px solid var(--border);border-radius:12px;margin-top:8px;cursor:pointer;transition:.12s}
.alt:hover{border-color:var(--blue);background:#f6fdff}
.alt .an{font-weight:600;font-size:14px}
.alt .am{font-size:12px;color:var(--text2)}
.endbar{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;padding:18px}
footer{background:#fff;border-top:1px solid var(--border);text-align:center;padding:22px;color:var(--text2);font-size:13px;margin-top:30px}
footer b{color:var(--text)}
footer a{font-weight:600}
.hidden{display:none!important}
.leaflet-marker-num{background:var(--blue);color:#fff;border:2px solid #fff;border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.leaflet-marker-start{background:var(--red);color:#fff;border:2px solid #fff;border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;box-shadow:0 1px 4px rgba(0,0,0,.3)}
@media(max-width:680px){
  .hero h1{font-size:30px}.row2{grid-template-columns:1fr}#map{height:340px}
  .venuephoto{width:72px;height:72px}.stopactions{flex-direction:row}
}
