:root{
  --card: #0f1a2d;
  --muted: rgba(255,255,255,.72);
  --muted2: rgba(255,255,255,.55);
  --line: rgba(255,255,255,.10);
}

.itinerary__wrapper {
  background-color: var(--theme-palette-color-4);
  width: 100% !important;
  max-width: 100%;
  padding: 40px 0;
}

.itinerary{
  max-width: 1100px;
  margin: 0 auto;
}

.itinerary__header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-bottom: 14px;
}

.itinerary__title{
  margin:0;
  margin-block-end: 0 !important;
  font-size: 22px;
  letter-spacing:.2px;
  color: var(--theme-palette-color-6);
}

.itinerary__nav{
  display:flex;
  gap:10px;
}

.nav-btn{
  appearance:none;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  color:#fff;
  padding:10px 12px;
  border-radius: 12px;
  cursor:pointer;
}

.nav-btn:hover{
  border-color: var(--theme-palette-color-1);
}

.itinerary-swiper{
  border-top-right-radius: 18px;
  border-top-left-radius: 18px;
  overflow: hidden;
}

/* Card */
.day-card{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
}

.day-card__top{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 0;
  min-height: 320px;
}

.day-card__meta{
  padding: 22px 22px 16px 22px;
}

.day-card__label{
  margin:0 0 6px 0;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted2);
}

.day-card__title{
  margin:0 0 14px 0;
  font-size: 22px;
  line-height: 1.15;
  color: var(--theme-palette-color-6);
}

/* Title row for mobile accordion toggle */
.day-card__title-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.day-card__stats{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:10px;
}

.stat{
  border: 1px solid var(--line);
  background: rgba(0,0,0,.18);
  border-radius: 14px;
  padding: 10px 12px;
}
.stat__label{
  display:block;
  font-size: 12px;
  color: var(--muted2);
  margin-bottom: 4px;
}
.stat__value{
  font-size: 14px;
  color: #fff;
}

.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  font-size: 13px;
  line-height: 1.4;
  width: fit-content;
  color: var(--theme-palette-color-6);
}
.pill--easy{
  border-color: rgba(72,188,162,.55);
  background: rgba(72,188,162,.12);
}
.pill--moderate{
  border-color: rgba(255,204,102,.45);
  background: rgba(255,204,102,.12);
}
.pill--challenging{
  border-color: rgba(220, 38, 38, .45);
  background: rgba(220, 38, 38, .12);
}

.day-card__image{
  margin:0;
  border-left: 1px solid var(--line);
  background: rgba(0,0,0,.15);
}
.day-card__image img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.day-card__body{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 0;
  border-top: 1px solid var(--line);
}

.day-card__content{
  padding: 18px 22px 20px 22px;
}
.day-card__content p{
  margin: 0 0 10px 0;
  line-height: 1.55;
  max-width: 60ch;
}

.day-card__side{
  border-left: 1px solid var(--line);
  padding: 18px;
  display:flex;
  flex-direction:column;
  gap: 12px;
}

.panel{
  border: 1px solid var(--line);
  background: var(--theme-palette-color-4);
  padding: 12px;
}

.section-title{
  margin: 0 0 10px 0;
  font-size: 13px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--muted2);
}

.section-content {
  color: var(--theme-palette-color-6);
}

.elevation-list{
  margin:0;
  padding-left: 16px;
  color: var(--muted);
  line-height: 1.55;
}

.elev-map{
  border: 1px dashed rgba(255,255,255,.18);
  border-radius: 12px;
  padding: 14px;
  min-height: 90px;
  display:flex;
  align-items:center;
}

.muted{
  margin:0;
  color: var(--muted2);
  font-size: 14px;
}

.itinerary__footer{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding: 14px 0 0 0;
}

.itinerary__footer .nav-btn{
  flex:1;
  text-align:center;
}

/* Optional: slightly larger buttons in footer */
.itinerary__footer .nav-btn{
  padding:12px 14px;
}

.swiper-pagination-bullet{
  background: rgba(255,255,255,.35);
  opacity: 1;
}
.swiper-pagination-bullet-active{
  background: var(--theme-palette-color-1);
}

/* -----------------------------
   Accordion mode (mobile)
   ----------------------------- */

/* Stack slides vertically while keeping the same HTML and Swiper classes */
.itinerary[data-mode="accordion"] .itinerary-swiper{
  overflow: visible;
  border-radius: 0; /* optional: looks nicer as stacked cards */
}

.itinerary[data-mode="accordion"] .swiper-wrapper{
  display: block;
  transform: none !important;
}

.itinerary[data-mode="accordion"] .swiper-slide{
  width: auto !important;
  margin-bottom: 14px;
}

/* Hide slider UI */
.itinerary[data-mode="accordion"] .itinerary__nav,
.itinerary[data-mode="accordion"] .itinerary__footer{
  display: none;
}

/* Accordion toggle button (only shown in accordion mode) */
.acc-toggle{
  display:none;
  appearance:none;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  color:#fff;
  padding:8px 10px;
  border-radius: 12px;
  cursor:pointer;
  white-space:nowrap;
}
.acc-toggle:hover{
  border-color: rgba(72,188,162,.45);
}
.itinerary[data-mode="accordion"] .acc-toggle{
  display:inline-flex;
}

.itinerary[data-mode="accordion"] .day-card__head{
  cursor: pointer;
}

/* Collapse behavior */
.itinerary[data-mode="accordion"] .acc-panel{
  overflow: hidden;
  transition: max-height 280ms ease;
}

.itinerary[data-mode="accordion"] .day-card.is-collapsed .acc-panel{
  max-height: 0;
}

/* Make cards feel like separate accordion items */
.itinerary[data-mode="accordion"] .day-card{
  border-radius: 16px;
}

.itinerary[data-mode="accordion"] .day-card__image{
  border-left: 0;
  border-top: 1px solid var(--line);
  height: 220px;
}

.itinerary[data-mode="accordion"] .day-card__side{
  border-left: 0;
  border-top: 1px solid var(--line);
}

.itinerary__counter{
    display: flex;
  align-self: center;
  color: rgba(255,255,255,.72);
  font-size: 13px;
  letter-spacing: .02em;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 12px;
  background: rgba(255,255,255,.04);
}

.nav-btn:disabled{
  opacity: .45;
  cursor: not-allowed;
}

.nav-btn:disabled:hover{
  border: 1px solid var(--line);
}

/* -----------------------------
   Responsive layout
   ----------------------------- */
@media (max-width: 900px){
  body{ padding: 18px; }

  /* In general on mobile, stack sections */
  .day-card__top,
  .day-card__body{
    grid-template-columns: 1fr;
  }

  .day-card__image{
    border-left: 0;
    border-top: 1px solid var(--line);
    height: 220px;
  }

  .day-card__side{
    border-left: 0;
    border-top: 1px solid var(--line);
  }
}