:root{
  --bg:#0b1014;
  --card:#0f1820;
  --card2:#101d27;
  --text:#eaf2f7;
  --muted:#b9c6d1;
  --faint:#7f93a3;
  --line:rgba(255,255,255,.12);
  --accent:#7ee5c5;
  --accent2:#87b7ff;
  --shadow:0 20px 60px rgba(0,0,0,.45);
  --radius:18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background: radial-gradient(1200px 700px at 20% 10%, rgba(126,229,197,.12), transparent 55%),
              radial-gradient(1000px 600px at 85% 35%, rgba(135,183,255,.10), transparent 55%),
              var(--bg);
  line-height:1.55;
}

a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}

.wrap{max-width:1100px;margin:0 auto;padding:0 20px}

.hero{
  position:relative;
  min-height:auto;
  overflow:hidden;
  border-bottom:1px solid var(--line);
  padding-bottom:48px;
}
.hero__media{position:absolute;inset:0}
.hero__media img{width:100%;height:100%;object-fit:cover;filter:saturate(1.05) contrast(1.05)}
.hero__scrim{position:absolute;inset:0;background:linear-gradient(180deg, rgba(11,16,20,.45), rgba(11,16,20,.75) 65%, rgba(11,16,20,1))}

.nav{
  position:relative;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 20px;
  max-width:1100px;
  margin:0 auto;
}
.nav__links{display:flex;gap:18px;opacity:.92}
.nav__links a{padding:8px 10px;border-radius:999px}
.nav__links a:hover{background:rgba(255,255,255,.06);text-decoration:none}

.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  font-weight:600;
  letter-spacing:.06em;
  font-size:12px;
}
.badge--bold{
  font-weight:700;
  font-size:13px;
  letter-spacing:.08em;
  padding:9px 16px;
  background:rgba(126,229,197,.1);
  border-color:rgba(126,229,197,.25);
  color:var(--accent);
}

.hero__content{
  position:relative;
  max-width:1100px;
  margin:0 auto;
  padding:48px 20px 0;
}

h1{
  font-family: Fraunces, Georgia, serif;
  font-size: clamp(42px, 6vw, 76px);
  line-height:1.02;
  margin:0 0 20px;
  letter-spacing:-.02em;
  color:#fff;
}
.muted{color:var(--muted)}

.hero__lede{max-width:680px;color:rgba(255,255,255,.88);font-size:19px;margin:0 0 36px;line-height:1.6}

.hero__stats{
  display:flex;align-items:center;gap:0;flex-wrap:wrap;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:16px;
  backdrop-filter:blur(12px);
  padding:0;
  max-width:920px;
}
.hero__stat{
  flex:1;min-width:140px;
  padding:20px 24px;text-align:center;
}
.hero__stat-value{
  font-family:Fraunces, Georgia, serif;
  font-size:28px;font-weight:700;
  color:var(--accent);
  line-height:1.1;margin-bottom:4px;
}
.hero__stat-label{font-size:13px;color:rgba(255,255,255,.7);line-height:1.3}
.hero__stat-divider{width:1px;height:44px;background:rgba(255,255,255,.15);flex-shrink:0}
@media (max-width:700px){
  .hero__stats{flex-direction:column;gap:0}
  .hero__stat{padding:14px 20px}
  .hero__stat-divider{width:60%;height:1px;margin:0 auto}
}

.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin:0 0 26px}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 20px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:var(--text);
  cursor:pointer;
  font-weight:600;
  font-size:16px;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn--primary{
  background:linear-gradient(135deg, rgba(126,229,197,.95), rgba(135,183,255,.90));
  color:#071014;
  border:0;
  box-shadow:0 12px 30px rgba(126,229,197,.18);
}
.btn--ghost{background:rgba(255,255,255,.06)}


.section{padding:72px 0;border-bottom:1px solid var(--line)}
@media (max-width:768px){.section{padding:48px 0}}
.section--alt{background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0) 40%)}
.section__head{margin:0 0 22px}
.section__head h2{font-family:Fraunces, Georgia, serif;font-size:36px;margin:0 0 8px}
.section__head p{margin:0;color:rgba(234,242,247,.82);max-width:850px}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);
  padding:20px;
  box-shadow: var(--shadow);
}
.card--soft{box-shadow:none;background:rgba(255,255,255,.04)}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:900px){.grid2{grid-template-columns:1fr}}

.h3{margin:0 0 8px;font-size:18px}
.big{font-size:16px;margin:0 0 2px}
.small{font-size:13px;color:rgba(234,242,247,.74)}

.tag{
  display:inline-flex;
  align-items:center;
  padding:3px 8px;
  border-radius:999px;
  background:rgba(126,229,197,.16);
  border:1px solid rgba(126,229,197,.35);
  color:rgba(234,242,247,.92);
  font-size:12px;
  font-weight:600;
  margin-left:8px;
}
.tag--fixed{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);color:rgba(234,242,247,.7)}
.tag--choice{background:rgba(135,183,255,.14);border-color:rgba(135,183,255,.35);color:rgba(135,183,255,.95)}
.tag--travel{background:rgba(255,183,77,.14);border-color:rgba(255,183,77,.35);color:rgba(255,200,120,.95)}
.tag--extension{background:rgba(186,126,233,.14);border-color:rgba(186,126,233,.35);color:rgba(210,170,245,.95)}

.date-range{font-size:.95rem;font-weight:600;color:var(--accent);margin-top:6px;letter-spacing:.02em}

.divider{height:1px;background:rgba(255,255,255,.12);margin:16px 0}

.notice{display:flex;gap:12px;align-items:flex-start;background:rgba(135,183,255,.10);border:1px solid rgba(135,183,255,.20);border-radius:14px;padding:12px}
.notice__icon{font-size:18px;line-height:1}
.notice__body{font-size:13px;color:rgba(234,242,247,.88)}

.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace}
code{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;font-size:.95em;color:rgba(234,242,247,.92)}

.vote-callout{
  text-align:center;
  margin:0 0 14px;
  padding:18px 20px 0;
}
.vote-callout__arrow{
  font-size:24px;
  color:var(--accent);
  animation:bounce 1.5s ease infinite;
  line-height:1;
}
@keyframes bounce{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(6px)}
}
.vote-callout__text{
  font-size:15px;
  font-weight:600;
  color:var(--accent);
  letter-spacing:.02em;
  margin-top:4px;
}

.card--vote{
  background:linear-gradient(135deg, rgba(126,229,197,.06), rgba(135,183,255,.06));
  border:2px solid rgba(126,229,197,.25);
  box-shadow:0 0 40px rgba(126,229,197,.08), var(--shadow);
}

.vote-heading{
  font-family:Fraunces, Georgia, serif;
  font-size:22px;
  margin:0 0 18px;
  color:var(--text);
  text-align:center;
}

.voting{display:grid;gap:18px}
.vote-options{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:600px){.vote-options{grid-template-columns:1fr}}
.vote-option{cursor:pointer;display:block}
.vote-option input[type="radio"]{position:absolute;opacity:0;pointer-events:none}
.vote-option__inner{
  padding:28px 24px;border-radius:18px;
  border:2px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  transition:border-color .3s ease,background .3s ease,box-shadow .3s ease,transform .2s ease;
  text-align:center;
}
.vote-option input[type="radio"]:checked + .vote-option__inner{
  border-color:var(--accent);
  background:rgba(126,229,197,.1);
  box-shadow:0 0 30px rgba(126,229,197,.2), 0 4px 20px rgba(126,229,197,.1);
  transform:scale(1.02);
}
.vote-option__inner:hover{border-color:rgba(255,255,255,.35);transform:translateY(-2px)}
.vote-option__emoji{font-size:36px;margin-bottom:10px;line-height:1}
.vote-option__label{font-family:Fraunces, Georgia, serif;font-weight:700;font-size:24px;margin-bottom:4px}
.vote-option__date{font-size:20px;font-weight:700;color:var(--accent);margin-bottom:8px}
.vote-option__route{font-size:14px;color:var(--muted);margin-bottom:6px}
.vote-option__range{font-size:12px;color:var(--accent);font-weight:600;margin:0;letter-spacing:.02em}

.vote-who{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:stretch;
  margin-top:6px;
}
@media (max-width:600px){.vote-who{grid-template-columns:1fr}}
.btn--vote{
  padding:18px 28px;
  font-size:18px;
  white-space:nowrap;
  display:flex;align-items:center;justify-content:center;
  border-radius:14px;
}

.vote-message{font-size:14px;min-height:22px}
.vote-message--success{color:var(--accent)}
.vote-message--error{color:#ff6b6b}
.vote-results{margin-top:22px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12)}
.vote-results .h3{margin-bottom:12px}
.vote-bar-wrap{margin-bottom:16px}
.vote-bar-label{display:flex;justify-content:space-between;font-size:14px;margin-bottom:6px}
.vote-bar-label span:last-child{font-weight:700}
.vote-bar{height:28px;border-radius:8px;background:rgba(255,255,255,.08);overflow:hidden;position:relative}
.vote-bar__fill{height:100%;border-radius:8px;transition:width .6s ease;min-width:0}
.vote-bar__fill--a{background:linear-gradient(90deg,var(--accent),rgba(126,229,197,.6))}
.vote-bar__fill--b{background:linear-gradient(90deg,var(--accent2),rgba(135,183,255,.6))}
.vote-names{margin-top:6px;font-size:13px;color:rgba(234,242,247,.65);font-style:italic}

.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}

.map{position:relative;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.2)}
.map iframe{width:100%;height:360px;border:0}
.map__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.35))}
.map__overlayInner{padding:14px 16px;border-radius:14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);text-align:center}

.route-desc{margin-top:8px}
.route-desc__cities{
  font-size:15px;font-weight:600;line-height:1.8;
  color:rgba(234,242,247,.82);
}
.route-desc__legend{
  display:flex;gap:18px;flex-wrap:wrap;margin-top:10px;
}
.route-desc__key{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;color:rgba(234,242,247,.7);
}
.route-desc__swatch{
  display:inline-block;width:20px;height:3px;border-radius:2px;
}
.route-desc__swatch--dashed{
  background:none !important;
  border-top:3px dashed;
  height:0;
}

.routeList{margin:0;padding-left:18px}
.routeList li{margin:14px 0;color:rgba(234,242,247,.86);font-size:15px;line-height:1.5}

.gallery{display:grid;grid-template-columns:repeat(3, 1fr);gap:14px;margin-top:18px}
@media (max-width:900px){.gallery{grid-template-columns:1fr}}
.gallery__item{margin:0;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04)}
.gallery__item img{width:100%;height:240px;object-fit:cover;display:block}
.gallery__item figcaption{padding:10px 12px;font-size:13px;color:rgba(234,242,247,.78)}

.toggle-context{
  font-size:13px;color:rgba(234,242,247,.65);
  margin:0 0 8px;font-style:italic;
}
.toggle-context strong{color:var(--accent);font-style:normal}
.toggle{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 18px}
.toggle__btn{
  padding:10px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);color:rgba(234,242,247,.9);cursor:pointer;font-weight:600
}
.toggle__btn.is-active{background:rgba(126,229,197,.18);border-color:rgba(126,229,197,.45)}

.direction-summary{
  padding:12px 16px;
  margin:0 0 18px;
  border-radius:12px;
  background:rgba(126,229,197,.08);
  border:1px solid rgba(126,229,197,.2);
  font-size:15px;
  color:rgba(234,242,247,.9);
  transition:opacity .3s ease;
}

.timeline{display:grid;gap:16px}
.day{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  overflow:hidden;
}
.day__body{
  display:grid;
  grid-template-columns:1fr 220px;
  min-height:180px;
}
.day__body:not(:has(.day__image)){
  grid-template-columns:1fr;
}
.day__info{
  padding:20px 24px;
  display:flex;
  flex-direction:column;
}
.day__date{
  font-size:12px;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:rgba(234,242,247,.6);
  display:flex;align-items:center;gap:8px;
}
.day__datetext{
  font-size:13px;color:rgba(234,242,247,.5);margin-top:2px;
}
.day__title{
  margin:8px 0 4px;font-size:17px;font-weight:700;color:var(--text);line-height:1.3;
}
.day__place{
  font-size:13px;color:rgba(234,242,247,.6);margin-bottom:8px;
}
.day__detail{
  margin:0 0 10px;font-size:14px;line-height:1.55;color:rgba(234,242,247,.82);
  flex:1;
}
.day__bottom{
  display:flex;align-items:center;gap:16px;margin-top:auto;padding-top:8px;
}
.day__weather{
  font-size:12px;color:rgba(234,242,247,.5);
}
.day__activity{display:inline-flex}
.day__image{
  position:relative;overflow:hidden;
}
.day__image img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.day__link{
  display:inline-block;margin:4px 0 4px;padding:4px 10px;border-radius:8px;
  font-size:12px;font-weight:600;color:var(--accent);
  background:rgba(126,229,197,.08);border:1px solid rgba(126,229,197,.2);
  transition:background .2s ease,border-color .2s ease;
}
.day__link:hover{background:rgba(126,229,197,.16);border-color:rgba(126,229,197,.4);text-decoration:none}
.dest-links{display:flex;gap:6px;flex-wrap:wrap;margin:4px 0}
.dest-link{
  display:inline-block;padding:3px 8px;border-radius:6px;
  font-size:11px;font-weight:600;color:var(--accent);
  background:rgba(126,229,197,.06);border:1px solid rgba(126,229,197,.15);
  transition:background .2s ease,border-color .2s ease;
}
.dest-link:hover{background:rgba(126,229,197,.14);border-color:rgba(126,229,197,.35);text-decoration:none}

.day__hotel-pick{
  padding:16px 24px 20px;
  border-top:2px dashed rgba(135,183,255,.3);
  background:rgba(135,183,255,.04);
}
.day__hotel-pick-header{
  display:flex;align-items:center;gap:8px;margin-bottom:4px;
}
.day__hotel-pick-icon{
  font-size:18px;color:var(--accent2);
}
.day__hotel-pick-label{
  font-size:13px;font-weight:700;color:var(--accent2);
  text-transform:uppercase;letter-spacing:.03em;
}
.day__hotel-pick-hint{
  font-size:12px;color:rgba(135,183,255,.7);
  margin-bottom:4px;font-style:italic;
}
.day__hotel-pick-hint--action{
  font-size:13px;color:var(--accent);font-style:normal;font-weight:600;
  padding:8px 12px;border-radius:8px;
  background:rgba(126,229,197,.08);border:1px solid rgba(126,229,197,.18);
  margin-bottom:10px;
  animation:pulse-hint 2s ease-in-out infinite;
}
@keyframes pulse-hint{
  0%,100%{box-shadow:0 0 0 0 rgba(126,229,197,.25);border-color:rgba(126,229,197,.18)}
  50%{box-shadow:0 0 12px 4px rgba(126,229,197,.3);border-color:rgba(126,229,197,.5)}
}

@media (max-width:900px){
  .day__body{grid-template-columns:1fr;min-height:auto}
  .day__image{height:160px}
  .day__info{padding:16px}
  .day__hotel-pick{padding:14px 16px 16px}
}

.hotel-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px}
.hotel-cards--single{grid-template-columns:1fr;max-width:280px}
@media (max-width:768px){.hotel-cards{grid-template-columns:1fr}}
.hotel-card{cursor:pointer;display:block}
.hotel-card--static{cursor:default}
.hotel-card input[type="radio"]{position:absolute;opacity:0;pointer-events:none}
.hotel-card__inner{
  padding:14px;border-radius:12px;
  border:2px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  transition:border-color .25s ease,background .25s ease,box-shadow .25s ease;
  height:100%;display:flex;flex-direction:column;gap:6px;
}
.hotel-card--selected .hotel-card__inner{
  border-color:var(--accent2);
  background:rgba(135,183,255,.08);
  box-shadow:0 0 20px rgba(135,183,255,.12);
}
.hotel-card:not(.hotel-card--static) .hotel-card__inner:hover{border-color:rgba(255,255,255,.3)}
.hotel-card__name{font-weight:700;font-size:14px;color:var(--text)}
.hotel-card__cost{font-size:13px;color:var(--accent2);font-weight:600}
.hotel-card__link{
  display:inline-block;margin-top:auto;padding:3px 8px;border-radius:6px;
  font-size:11px;font-weight:600;color:var(--accent2);
  background:rgba(135,183,255,.08);border:1px solid rgba(135,183,255,.18);
  transition:background .2s ease;align-self:flex-start;
}
.hotel-card__link:hover{background:rgba(135,183,255,.16);text-decoration:none}

.connection-hubs{display:grid;gap:10px;margin:12px 0}
.hub{padding:12px 14px;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);line-height:1.5}
.hub strong{color:var(--accent);font-size:14px}
.stopover-note{
  margin:12px 0 4px;padding:12px 14px;border-radius:12px;
  background:rgba(135,183,255,.08);border:1px solid rgba(135,183,255,.18);
  font-size:14px;color:rgba(234,242,247,.88);line-height:1.55;
}
.stopover-note strong{color:var(--accent2)}

.kbd{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:rgba(234,242,247,.72)}
.dot{width:10px;height:10px;border-radius:50%}
.dot--low{background:rgba(126,229,197,.9)}
.dot--med{background:rgba(135,183,255,.95)}

.bullets{margin:8px 0 0;padding-left:18px;color:rgba(234,242,247,.84)}
.bullets li{margin:8px 0}

.form{display:grid;gap:12px;margin-top:10px}
.field{display:grid;gap:8px}
.field__label{font-size:17px;color:rgba(234,242,247,.82);font-weight:600}
select{
  -webkit-appearance:none;
  appearance:none;
  background:rgba(0,0,0,.22) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23eaf2f7' stroke-width='2' fill='none'/%3E%3C/svg%3E") no-repeat right 16px center;
  border:1px solid rgba(255,255,255,.14);
  color:rgba(234,242,247,.92);
  padding:18px 40px 18px 20px;
  border-radius:14px;
  font-size:18px;
  font-family:inherit;
  width:100%;
  cursor:pointer;
  position:relative;
  z-index:1;
}

.price{font-family:Fraunces, Georgia, serif;font-size:54px;letter-spacing:-.02em;margin:10px 0 0}
.priceSub{color:rgba(234,242,247,.78)}
.breakdown{display:grid;gap:8px;font-size:13px;color:rgba(234,242,247,.82)}
.breakdown__row{display:flex;justify-content:space-between;gap:12px}
.breakdown__row span:last-child{font-weight:700}
.breakdown__note{margin-top:8px;padding:10px 12px;font-size:12px;color:rgba(210,170,245,.85);background:rgba(186,126,233,.08);border:1px solid rgba(186,126,233,.2);border-radius:10px;line-height:1.5}
.breakdown__early-bird{margin-top:10px;padding:10px 12px;font-size:12px;color:rgba(126,229,197,.92);background:rgba(126,229,197,.08);border:1px solid rgba(126,229,197,.2);border-radius:10px;line-height:1.6}
.breakdown__early-bird a{color:var(--accent);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.breakdown__early-bird a:hover{text-decoration:none}

.early-bird{
  margin-top:10px;padding:10px 12px;border-radius:10px;
  font-size:12px;line-height:1.6;
  color:rgba(126,229,197,.92);
  background:rgba(126,229,197,.08);
  border:1px solid rgba(126,229,197,.2);
}
.early-bird__badge{
  display:inline-block;padding:2px 7px;border-radius:6px;
  font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  color:#071014;background:var(--accent);margin-right:6px;
  vertical-align:1px;
}
.early-bird__link{
  color:var(--accent);font-weight:600;
  text-decoration:underline;text-underline-offset:2px;
  margin-left:4px;
}
.early-bird__link:hover{text-decoration:none}

.copybox{display:grid;gap:10px}
pre{
  margin:0;
  padding:14px;
  border-radius:14px;
  background:rgba(0,0,0,.20);
  border:1px solid rgba(255,255,255,.12);
  overflow:auto;
  white-space:pre-wrap;
}

.reveal{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.visible{opacity:1;transform:none}

.nav__hamburger{
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:8px;
  z-index:11;
}
.nav__hamburger span{
  display:block;
  width:24px;
  height:2px;
  background:var(--text);
  border-radius:2px;
  transition:transform .3s ease, opacity .3s ease;
}

@media (max-width:768px){
  .nav__links{
    display:none;
    flex-direction:column;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:rgba(11,16,20,.96);
    backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);
    padding:12px 0;
    z-index:10;
  }
  .nav__links.is-open{
    display:flex;
  }
  .nav__links a{
    padding:14px 20px;
    width:100%;
    border-radius:0;
    font-size:16px;
  }
  .nav__links a:hover{
    background:rgba(255,255,255,.08);
  }
  .nav__hamburger{
    display:flex;
  }
}

.leaflet-stop-number{background:none!important;border:none!important}
.leaflet-stop-number span{display:flex;align-items:center;justify-content:center;width:28px;height:28px;font-size:12px;font-weight:700;color:#0b1014;pointer-events:none}

#leafletMap{z-index:0}

.group-pref__block{margin-bottom:24px}
.group-pref__block:last-child{margin-bottom:0}
.group-pref__title{font-weight:700;font-size:15px;color:var(--text);margin-bottom:10px}
.group-pref__nights{font-weight:400;font-size:13px;color:rgba(234,242,247,.5)}
.group-pref__bars{display:flex;flex-direction:column;gap:8px}
.group-pref__bar-row{display:grid;grid-template-columns:160px 1fr 32px;align-items:center;gap:10px}
.group-pref__bar-label{font-size:13px;color:rgba(234,242,247,.75);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.group-pref__bar{height:20px;background:rgba(234,242,247,.06);border-radius:6px;overflow:hidden}
.group-pref__bar-fill{height:100%;border-radius:6px;transition:width .5s ease}
.group-pref__bar-fill--a{background:var(--accent)}
.group-pref__bar-fill--b{background:#87b7ff}
.group-pref__bar-fill--hotel{background:var(--accent)}
.group-pref__bar-count{font-size:14px;font-weight:700;color:var(--text);text-align:right}
.group-pref__names{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.group-pref__chip{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;background:rgba(126,229,197,.12);color:var(--accent)}
.group-pref__chip--b{background:rgba(135,183,255,.12);color:#87b7ff}
.group-pref__voters{font-size:12px;color:rgba(234,242,247,.45);margin-top:2px;margin-bottom:6px;padding-left:170px}
.group-pref__divider{height:1px;background:var(--line);margin:24px 0}
.group-pref__empty{font-size:14px;color:rgba(234,242,247,.4);font-style:italic}

@media(max-width:768px){
  .group-pref__bar-row{grid-template-columns:120px 1fr 28px;gap:6px}
  .group-pref__voters{padding-left:0}
}

.footer{padding:28px 0}
.footer__inner{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:18px}

