.i7tou-daytrip {
  --i7tou-bg: #fffaf3;
  --i7tou-card: #ffffff;
  --i7tou-line: #eadfce;
  --i7tou-text: #2f2a25;
  --i7tou-muted: #71695f;
  --i7tou-primary: #d46f32;
  --i7tou-primary-dark: #aa4f21;
  --i7tou-soft: #f7ead9;
  --i7tou-map-height: 680px;
  color: var(--i7tou-text);
  font-family: inherit;
  margin: 2rem 0;
}

.i7tou-daytrip * { box-sizing: border-box; }
.i7tou-daytrip--fullpage { margin: 0; }

.i7tou-daytrip__hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  background: linear-gradient(135deg, #fff5e7 0%, #fff 62%);
  border: 1px solid var(--i7tou-line);
  border-radius: 24px;
  padding: .95rem 1.3rem;
  box-shadow: 0 12px 28px rgba(77, 54, 30, .08);
}

.i7tou-daytrip__eyebrow {
  color: var(--i7tou-primary-dark);
  font-size: .64rem;
  font-weight: 900;
  letter-spacing: .12em;
  margin: 0 0 .28rem;
}

.i7tou-daytrip__hero h2 {
  font-size: clamp(1.2rem, 2vw, 1.75rem);
  margin: 0 0 .2rem;
  line-height: 1.15;
}

.i7tou-daytrip__hero p:last-child {
  margin: 0;
  color: var(--i7tou-muted);
  font-size: .92rem;
  line-height: 1.45;
}

.i7tou-daytrip__hero-actions,
.i7tou-tripmap__controlbar,
.i7tou-tripmap__day-tabs,
.i7tou-tripitem__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.i7tou-tripmap__controlbar {
  margin-top: 0;
}

.i7tou-tripmap__day-tabs {
  margin-top: .75rem;
}

.i7tou-tripmap__controlbar {
  display: grid;
  grid-template-columns: minmax(360px, .9fr) minmax(420px, 1.1fr);
  align-items: stretch;
  gap: .75rem;
}

.i7tou-tripmap__filterbox,
.i7tou-tripmap__tripbox {
  display: grid;
  gap: .75rem;
  align-items: stretch;
}

.i7tou-tripmap__filterbox {
  grid-template-columns: 1fr 1fr;
}

.i7tou-tripmap__tripbox {
  grid-template-columns: minmax(260px, 1fr) auto;
}

.i7tou-tripmap__actions {
  display: flex;
  align-items: end;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: .55rem;
}

.i7tou-tripmap__select-label {
  border: 1px solid var(--i7tou-line);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 8px 18px rgba(77, 54, 30, .06);
  display: grid;
  gap: .38rem;
  padding: .72rem .9rem;
  color: var(--i7tou-muted);
  font-size: .82rem;
  font-weight: 900;
  position: relative;
  min-width: 0;
}

.i7tou-tripmap__select-label span {
  color: var(--i7tou-primary-dark);
  font-size: .78rem;
  letter-spacing: .02em;
}

.i7tou-tripmap__select-label::after {
  content: '⌄';
  position: absolute;
  right: 14px;
  bottom: 12px;
  font-size: 1.1rem;
  color: var(--i7tou-primary-dark);
  pointer-events: none;
}

.i7tou-tripmap__select-label select {
  width: 100%;
  border: 1px solid #f0dfcf;
  outline: 0;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: linear-gradient(180deg, #fff, #fff8f0);
  color: var(--i7tou-text);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.45;
  border-radius: 14px;
  padding: .78rem 2.2rem .78rem .9rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
  cursor: pointer;
}

.i7tou-tripmap__select-label select:hover,
.i7tou-tripmap__select-label select:focus {
  border-color: #e7b58e;
  box-shadow: 0 0 0 3px rgba(212,111,50,.12);
}

.i7tou-daytrip__btn,
.i7tou-daytrip button,
.i7tou-tripitem__actions a,
.i7tou-tripmap__day-nav {
  appearance: none;
  border: 1px solid var(--i7tou-primary);
  background: var(--i7tou-primary);
  color: #fff;
  border-radius: 999px;
  padding: .58rem .92rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  text-decoration: none;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
}

.i7tou-daytrip button:hover,
.i7tou-tripitem__actions a:hover,
.i7tou-tripmap__day-nav:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(136, 80, 31, .16);
}

.i7tou-daytrip__btn--ghost,
.i7tou-daytrip .i7tou-chip,
.i7tou-tripitem__actions button,
.i7tou-tripitem__actions a {
  background: #fff;
  color: var(--i7tou-primary-dark);
}

.i7tou-daytrip .i7tou-chip {
  border-color: var(--i7tou-line);
  padding: .54rem .84rem;
  font-size: .88rem;
}

.i7tou-daytrip .i7tou-chip.is-active {
  border-color: var(--i7tou-primary);
  background: var(--i7tou-primary);
  color: #fff;
}

.i7tou-daytrip .i7tou-chip--day {
  border-color: var(--day-accent, var(--i7tou-line));
  color: var(--day-accent, var(--i7tou-primary-dark));
  background: color-mix(in srgb, var(--day-accent, #d46f32) 9%, white);
}

.i7tou-daytrip .i7tou-chip--day.is-active {
  border-color: var(--day-accent, var(--i7tou-primary));
  background: var(--day-accent, var(--i7tou-primary));
  color: #fff;
}

.i7tou-daytrip__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(380px, .88fr);
  gap: 1rem;
  margin-top: .55rem;
  align-items: start;
}

.i7tou-daytrip__map-wrap,
.i7tou-daytrip__panel {
  border: 1px solid var(--i7tou-line);
  border-radius: 24px;
  background: var(--i7tou-card);
  overflow: hidden;
  box-shadow: 0 12px 28px rgba(77, 54, 30, .08);
}

.i7tou-daytrip__map-wrap {
  position: sticky;
  top: 1rem;
  z-index: 1;
}

.admin-bar .i7tou-daytrip__map-wrap { top: 3rem; }

.i7tou-daytrip__map-note {
  display: none;
}

.i7tou-daytrip__map {
  min-height: 420px;
  height: var(--i7tou-map-height);
  background: #eef2ec;
}

.i7tou-daytrip__panel {
  position: relative;
  z-index: 2;
  max-height: calc(var(--i7tou-map-height) + 3rem);
  overflow: auto;
}

.i7tou-daytrip__summary {
  position: sticky;
  top: 0;
  z-index: 3;
  background: rgba(255, 255, 255, .96);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--i7tou-line);
  padding: .85rem 1rem;
  color: var(--i7tou-muted);
  font-size: .92rem;
}

.i7tou-daytrip__summary strong {
  display: block;
  color: var(--i7tou-text);
  font-size: clamp(1.18rem, 2vw, 1.36rem);
  line-height: 1.35;
  margin-bottom: .48rem;
}

.i7tou-daytrip__summary p {
  margin: 0 0 .45rem;
  line-height: 1.55;
}

.i7tou-tripmap__summary-meta {
  color: var(--i7tou-primary-dark);
  font-weight: 800;
}

.i7tou-tripmap__timeline {
  display: grid;
  gap: 1rem;
  padding: 1rem;
}

.i7tou-tripday {
  border: 1px solid var(--i7tou-line);
  border-radius: 20px;
  background: #fff;
  overflow: hidden;
}

.i7tou-tripday__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: .8rem;
  padding: .9rem 1rem;
  background: color-mix(in srgb, var(--day-accent, #d46f32) 8%, #fffaf3);
  border-bottom: 1px solid color-mix(in srgb, var(--day-accent, #d46f32) 25%, #eadfce);
}

.i7tou-tripday__head div {
  display: grid;
  gap: .2rem;
}

.i7tou-tripday__head span {
  color: var(--day-accent, var(--i7tou-primary-dark));
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .08em;
}

.i7tou-tripday__head strong {
  font-size: 1.08rem;
}

.i7tou-tripmap__day-nav {
  white-space: nowrap;
  font-size: .82rem;
  padding: .52rem .75rem;
}

.i7tou-tripday__intro {
  margin: 0;
  padding: .85rem 1rem;
  color: var(--i7tou-muted);
  line-height: 1.55;
  border-bottom: 1px solid var(--i7tou-line);
}

.i7tou-tripday__route-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .42rem;
  background: linear-gradient(135deg, #fff8ee 0%, #eefaf6 100%);
  border-bottom: 1px solid #eadfce;
  box-shadow: inset 4px 0 0 var(--day-accent, var(--i7tou-primary));
}

.i7tou-tripday__route-chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  border-radius: 999px;
  padding: .34rem .72rem;
  background: #ffffff;
  color: #2f2a25;
  border: 1px solid rgba(212, 111, 50, .18);
  box-shadow: 0 4px 10px rgba(77, 54, 30, .06);
  font-weight: 800;
  font-size: .9rem;
}

.i7tou-tripday__route-arrow {
  color: var(--day-accent, var(--i7tou-primary));
  font-weight: 900;
  font-size: 1rem;
}

.i7tou-tripday__items {
  display: grid;
}

.i7tou-tripitem {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: .8rem;
  padding: .9rem 1rem;
  border-bottom: 1px solid var(--i7tou-line);
}

.i7tou-tripitem:last-child { border-bottom: 0; }

.i7tou-tripitem.is-departure {
  grid-template-columns: 1fr;
}


.i7tou-tripitem.is-departure {
  grid-template-columns: 1fr;
}


.i7tou-tripitem.is-active {
  background: color-mix(in srgb, var(--day-accent, #d46f32) 8%, #fff);
  box-shadow: inset 4px 0 0 var(--day-accent, var(--i7tou-primary));
}

.i7tou-tripitem__time {
  color: var(--day-accent, var(--i7tou-primary-dark));
  font-weight: 900;
  font-size: .86rem;
  line-height: 1.35;
}

.i7tou-tripitem__title-row {
  display: grid;
  gap: .25rem;
}

.i7tou-tripitem__title-row span {
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: color-mix(in srgb, var(--day-accent, #d46f32) 14%, white);
  color: var(--day-accent, var(--i7tou-primary-dark));
  padding: .24rem .55rem;
  font-size: .75rem;
  font-weight: 900;
}

.i7tou-tripitem__title-row strong {
  color: var(--i7tou-text);
  font-size: 1.02rem;
  line-height: 1.35;
}

.i7tou-tripitem__meta {
  color: var(--i7tou-muted);
  font-size: .84rem;
  margin-top: .45rem;
}

.i7tou-tripitem p {
  color: var(--i7tou-muted);
  line-height: 1.55;
  margin: .45rem 0 0;
}

.i7tou-tripitem__actions {
  margin-top: .7rem;
}

.i7tou-tripitem__actions button,
.i7tou-tripitem__actions a {
  border-color: var(--i7tou-line);
  padding: .48rem .7rem;
  font-size: .82rem;
}

.i7tou-tripitem__actions button:first-child {
  border-color: var(--day-accent, var(--i7tou-primary));
  background: var(--day-accent, var(--i7tou-primary));
  color: #fff;
}

.i7tou-tripday--self {
  background: #fffdf8;
}

.i7tou-tripday__self-message {
  margin: 0;
  padding: 1rem;
  color: var(--i7tou-text);
  line-height: 1.7;
  background: #fffaf3;
}

.i7tou-daytrip__empty,
.i7tou-daytrip__error {
  padding: 1rem;
  border: 1px dashed var(--i7tou-line);
  border-radius: 16px;
  background: #fffaf3;
  color: var(--i7tou-muted);
}

.i7tou-marker {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  border: 2px solid #fff;
  background: var(--marker-color, var(--i7tou-primary));
  color: #fff;
  font-weight: 900;
  box-shadow: 0 6px 12px rgba(0, 0, 0, .22);
}

.i7tou-marker span {
  transform: rotate(45deg);
  font-size: .76rem;
  white-space: nowrap;
}

.i7tou-place-popup {
  width: 230px;
}

.i7tou-place-popup img {
  width: 100%;
  height: 118px;
  object-fit: cover;
  border-radius: 12px;
  margin-bottom: .5rem;
}

.i7tou-place-popup strong {
  display: block;
  font-size: 1rem;
  line-height: 1.35;
  margin-bottom: .25rem;
}

.i7tou-place-popup p {
  margin: .35rem 0;
  color: #5f5850;
  line-height: 1.45;
}

.i7tou-place-popup__badge {
  display: inline-flex;
  align-items: center;
  width: max-content;
  border-radius: 999px;
  background: color-mix(in srgb, var(--day-accent, #d46f32) 12%, white);
  color: var(--day-accent, var(--i7tou-primary-dark));
  padding: .28rem .55rem;
  font-size: .76rem;
  font-weight: 800;
}

.i7tou-place-popup__links {
  display: flex;
  gap: .4rem;
  margin-top: .5rem;
}

.i7tou-place-popup__links a {
  flex: 1;
  text-align: center;
  border-radius: 999px;
  padding: .45rem .5rem;
  text-decoration: none;
  background: var(--i7tou-primary);
  color: #fff !important;
  font-weight: 800;
}

@media (max-width: 980px) {
  .i7tou-tripmap__controlbar,
  .i7tou-tripmap__filterbox,
  .i7tou-tripmap__tripbox { grid-template-columns: 1fr; }

  .i7tou-daytrip__hero,
  .i7tou-daytrip__layout {
    grid-template-columns: 1fr;
    display: grid;
  }

  .i7tou-daytrip__hero-actions {
    justify-content: flex-start;
  }

  .i7tou-daytrip__map-wrap {
    position: relative;
    top: 0;
    z-index: 1;
  }

  .i7tou-daytrip__map {
    height: min(62vh, 460px);
  }

  .i7tou-daytrip__panel {
    z-index: 3;
    max-height: none;
    margin-top: .75rem;
  }
}

@media (max-width: 560px) {
  .i7tou-daytrip {
    margin: 1rem 0;
  }

  .i7tou-daytrip__hero,
  .i7tou-daytrip__map-wrap,
  .i7tou-daytrip__panel {
    border-radius: 18px;
  }

  .i7tou-daytrip__hero {
    padding: .9rem 1rem;
  }

  .i7tou-tripmap__day-tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: .35rem;
  }

  .i7tou-daytrip .i7tou-chip {
    white-space: nowrap;
  }

  .i7tou-tripmap__day-tabs {
    margin-top: .55rem;
    margin-bottom: .15rem;
  }

  .i7tou-daytrip__layout {
    margin-top: .35rem;
    gap: .75rem;
  }

  .i7tou-daytrip__map {
    height: min(58vh, 420px);
    min-height: 340px;
  }

  .i7tou-daytrip__panel {
    margin-top: .85rem;
  }

  .i7tou-tripitem {
    grid-template-columns: 1fr;
    gap: .4rem;
  }
}

.i7tou-tripitem__food-btn {
  border-color: #e08a22 !important;
  background: #e08a22 !important;
  color: #fff !important;
}

.i7tou-tripitem__food-btn:disabled {
  opacity: .65;
  cursor: wait;
  transform: none !important;
  box-shadow: none !important;
}

.i7tou-food-clear-control-wrap {
  margin: 10px 10px 0 0;
}

.i7tou-food-clear-control {
  appearance: none;
  border: 1px solid #e08a22;
  background: #fff;
  color: #a35411;
  border-radius: 999px;
  padding: .5rem .8rem;
  font-weight: 900;
  font-size: .86rem;
  cursor: pointer;
  box-shadow: 0 6px 16px rgba(0, 0, 0, .16);
}

.i7tou-food-clear-control:hover {
  background: #fff6e9;
}

.i7tou-food-marker {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  border: 2px solid #fff;
  background: #e08a22;
  color: #fff;
  font-weight: 900;
  box-shadow: 0 6px 12px rgba(0, 0, 0, .22);
}

.i7tou-food-marker span {
  transform: rotate(45deg);
  font-size: .72rem;
  white-space: nowrap;
}

.i7tou-food-popup__badge {
  background: #fff3df;
  color: #a35411;
}

.i7tou-food-popup__distance {
  color: #a35411 !important;
  font-weight: 800;
}

.i7tou-food-popup__badges {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  margin-bottom: .35rem;
}

.i7tou-food-popup__rank {
  display: inline-flex;
  align-items: center;
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: #fff8e8;
  color: #b46a00;
  border: 1px solid #f1d49a;
  padding: .28rem .55rem;
  font-size: .76rem;
  font-weight: 900;
}


/* v121 mobile layout fix: keep the trip title below the map, not floating over it,
   and reduce the blank gap between day tabs and the map. */
@media (max-width: 760px) {
  .i7tou-tripmap__day-tabs {
    margin-top: .42rem !important;
    margin-bottom: 0 !important;
    padding-bottom: .08rem !important;
    gap: .45rem !important;
  }

  .i7tou-daytrip__layout {
    display: flex !important;
    flex-direction: column !important;
    margin-top: .12rem !important;
    gap: .48rem !important;
  }

  .i7tou-daytrip__map-wrap {
    position: static !important;
    top: auto !important;
    z-index: auto !important;
    margin: 0 !important;
    transform: none !important;
    overflow: hidden !important;
  }

  .i7tou-daytrip__map {
    height: min(52vh, 390px) !important;
    min-height: 320px !important;
  }

  .i7tou-daytrip__panel {
    position: static !important;
    z-index: auto !important;
    margin: .55rem 0 0 !important;
    max-height: none !important;
    overflow: visible !important;
    transform: none !important;
    clear: both !important;
  }

  .i7tou-daytrip__summary {
    position: static !important;
    top: auto !important;
    z-index: auto !important;
    border-radius: 18px 18px 0 0;
  }

  .i7tou-daytrip__summary strong {
    font-size: 1.32rem;
    line-height: 1.34;
  }
}

@media (max-width: 420px) {
  .i7tou-daytrip__map {
    height: min(50vh, 360px) !important;
    min-height: 300px !important;
  }

  .i7tou-daytrip__summary strong {
    font-size: 1.24rem;
  }
}

/* v122 mobile map render fix: keep Leaflet with an explicit visible size on phones. */
@media (max-width: 760px) {
  .i7tou-daytrip__map-wrap {
    width: 100% !important;
    min-width: 0 !important;
    display: block !important;
  }

  .i7tou-daytrip__map,
  .i7tou-daytrip__map.leaflet-container {
    display: block !important;
    width: 100% !important;
    height: 360px !important;
    min-height: 360px !important;
    visibility: visible !important;
  }
}

@media (max-width: 420px) {
  .i7tou-daytrip__map,
  .i7tou-daytrip__map.leaflet-container {
    height: 340px !important;
    min-height: 340px !important;
  }
}
