/* ============================================================
   AGENDA — Timeline dia a dia · Estilo editorial
   ============================================================ */

/* ----------------------------------------------------------
   HEADER DA AGENDA
   ---------------------------------------------------------- */
.agenda-header {
  padding: var(--s5) var(--s5) var(--s3);
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}

.agenda-mono-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--c-primary);
  margin-bottom: var(--s2);
}

.agenda-title {
  font-family: var(--font-serif);
  font-size: 1.8rem;
  font-weight: 300;
  font-style: italic;
  color: var(--text);
  line-height: 1;
}

.agenda-subtitle {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text3);
  margin-top: 4px;
}

/* ----------------------------------------------------------
   DAY TABS — estilo editorial
   ---------------------------------------------------------- */
.agenda-tabs {
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 20;
}

.agenda-tabs-scroll {
  display: flex;
  gap: var(--s2);
  padding: var(--s3) var(--s5);
  overflow-x: auto;
  scrollbar-width: none;
}
.agenda-tabs-scroll::-webkit-scrollbar { display: none; }

.agenda-tab {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 5px 10px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  min-width: 52px;
  cursor: pointer;
  transition: all var(--t-fast);
  flex-shrink: 0;
  background: var(--bg);
  -webkit-tap-highlight-color: transparent;
  gap: 1px;
}

.agenda-tab:hover {
  border-color: var(--c-primary);
  color: var(--c-primary);
}

.agenda-tab[aria-selected="true"] {
  background: var(--text);
  border-color: var(--text);
  color: var(--bg);
}

.tab-day {
  font-family: var(--font-serif);
  font-size: 1.2rem;
  font-weight: 300;
  line-height: 1;
  color: inherit;
}

.agenda-tab[aria-selected="true"] .tab-day {
  color: var(--c-gold-light, #d4ab4f);
}

.tab-mon {
  font-family: var(--font-mono);
  font-size: 7.5px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  opacity: 0.7;
  line-height: 1;
}

/* ----------------------------------------------------------
   DAY CARD
   ---------------------------------------------------------- */
.day-card {
  margin-bottom: 0;
}

/* Card header com hero image */
.day-card-header {
  position: relative;
  height: 160px;
  overflow: hidden;
  background: var(--bg2);
  background-size: cover;
  background-position: center;
}

.day-card-header-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(26,20,16,0.1) 0%,
    rgba(26,20,16,0.7) 100%
  );
}

.day-card-header-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--s4) var(--s5);
  color: #fdfaf3;
}

.day-city-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 8px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  background: rgba(139,30,30,0.85);
  color: #fdfaf3;
  padding: 2px 8px;
  border-radius: var(--r-xl);
  margin-bottom: var(--s2);
}

.day-title {
  font-family: var(--font-serif);
  font-size: 1.35rem;
  font-weight: 300;
  line-height: 1.15;
  text-shadow: 0 1px 4px rgba(0,0,0,0.3);
}

.day-subtitle {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.85rem;
  opacity: 0.8;
}

.day-date-label {
  font-family: var(--font-mono);
  font-size: 8px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  opacity: 0.7;
  margin-top: 2px;
}

/* ----------------------------------------------------------
   DAY SUMMARY
   ---------------------------------------------------------- */
.day-summary {
  padding: var(--s4) var(--s5);
  border-bottom: 1px solid var(--border);
}

.day-summary-text {
  font-size: 0.85rem;
  color: var(--text2);
  line-height: 1.65;
  margin-bottom: var(--s3);
}

.day-tag {
  display: inline-flex;
  margin-right: var(--s1);
  margin-bottom: var(--s1);
  font-family: var(--font-mono);
  font-size: 8px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: var(--r-xl);
  border: 1px solid var(--border);
  color: var(--text3);
}

/* ----------------------------------------------------------
   EVENTOS — timeline com linha vertical
   ---------------------------------------------------------- */
.day-events {
  padding: var(--s3) 0 var(--s5);
}

.event-section-label {
  font-family: var(--font-mono);
  font-size: 8.5px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--text3);
  padding: var(--s3) var(--s5) var(--s2);
  display: flex;
  align-items: center;
  gap: var(--s3);
}
.event-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}

.event-item {
  display: grid;
  grid-template-columns: 48px 1px 1fr auto;
  gap: 0 var(--s3);
  padding: var(--s2) var(--s5) var(--s2) var(--s5);
  position: relative;
  cursor: default;
}

.event-item.event-clickable {
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.event-item.event-clickable:hover {
  background: var(--bg2);
}

.event-time {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.08em;
  color: var(--text3);
  text-align: right;
  padding-top: 3px;
  align-self: start;
}

.event-dot {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.event-dot::before {
  content: '';
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--c-primary);
  border: 1.5px solid var(--bg);
  box-shadow: 0 0 0 1.5px var(--c-primary);
  margin-top: 4px;
  flex-shrink: 0;
  z-index: 1;
}

.event-dot::after {
  content: '';
  flex: 1;
  width: 1px;
  background: var(--border);
  margin-top: 4px;
  min-height: 20px;
}

.event-item:last-child .event-dot::after {
  display: none;
}

.event-body {
  padding-bottom: var(--s3);
  min-width: 0;
}

.event-title {
  font-family: var(--font-serif);
  font-size: 0.95rem;
  color: var(--text);
  line-height: 1.3;
  margin-bottom: 2px;
}

.event-detail {
  font-size: 0.78rem;
  color: var(--text3);
  line-height: 1.4;
}

.event-chevron {
  font-size: 0.85rem;
  color: var(--text3);
  align-self: start;
  padding-top: 2px;
  flex-shrink: 0;
}

/* Steps de transporte dentro do evento */
.event-steps {
  margin-top: var(--s2);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.event-step {
  display: flex;
  align-items: center;
  gap: var(--s2);
  font-size: 0.78rem;
  color: var(--text3);
}

.event-step-icon { flex-shrink: 0; }
.event-step-text { flex: 1; }

.event-step-duration,
.event-step-price {
  font-family: var(--font-mono);
  font-size: 8px;
  letter-spacing: 0.1em;
  color: var(--c-gold);
  flex-shrink: 0;
}

/* Opções de restaurante */
.event-restaurant-options {
  margin-top: var(--s2);
  border-top: 1px solid var(--border);
  padding-top: var(--s2);
}

.event-restaurant {
  font-size: 0.78rem;
  color: var(--text2);
  margin-bottom: 2px;
}

/* ----------------------------------------------------------
   MODAL DE EVENTO
   ---------------------------------------------------------- */
.event-modal-header {
  display: flex;
  gap: var(--s4);
  align-items: flex-start;
  margin-bottom: var(--s5);
  padding-bottom: var(--s4);
  border-bottom: 1px solid var(--border);
}

.event-modal-icon {
  font-size: 1.5rem;
  flex-shrink: 0;
}

.event-modal-title {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  font-weight: 300;
  color: var(--text);
  line-height: 1.2;
}

.event-modal-time {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text3);
  margin-top: 4px;
}

.modal-detail {
  font-size: 0.9rem;
  color: var(--text2);
  line-height: 1.65;
  margin-bottom: var(--s4);
}

.modal-section {
  margin-bottom: var(--s5);
}

.modal-section-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: var(--s3);
}

.modal-section p {
  font-size: 0.88rem;
  color: var(--text2);
  line-height: 1.7;
}

.modal-section--romantic {
  text-align: center;
  padding: var(--s4);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}

.modal-romantic-text {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1rem;
  color: var(--c-primary);
  line-height: 1.5;
}

.modal-section--history p {
  font-size: 0.9rem;
}

.modal-restaurant {
  padding: var(--s2) 0;
  border-bottom: 1px solid var(--border);
  line-height: 1.5;
}
.modal-restaurant:last-child { border-bottom: none; }

.modal-restaurant-label {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-terracotta, #C84B31);
  margin-bottom: 2px;
}

.modal-restaurant-name {
  display: block;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text1);
  margin-bottom: 2px;
}

.modal-restaurant-specialty {
  font-size: 0.82rem;
  color: var(--text2);
  font-style: italic;
  margin-bottom: 4px;
}

.modal-restaurant-addr {
  font-size: 0.78rem;
  color: var(--text3);
  margin-bottom: 4px;
}

.modal-restaurant-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.modal-restaurant-price {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text2);
}

.modal-restaurant-tip {
  font-size: 0.78rem;
  color: var(--text3);
  font-style: italic;
}

.modal-restaurant-note {
  font-size: 0.78rem;
  color: var(--text3);
  font-style: italic;
  margin-top: 2px;
}

.hotel-modal-notes {
  font-size: 0.82rem;
  color: var(--text3);
  font-style: italic;
  margin-top: var(--s2);
  padding-top: var(--s2);
  border-top: 1px solid var(--border);
}

.drop-cap > p:first-child::first-letter {
  font-family: var(--font-serif);
  font-size: 2.8rem;
  font-weight: 400;
  float: left;
  line-height: 0.85;
  margin-right: 6px;
  margin-top: 4px;
  color: var(--c-primary);
}

/* ----------------------------------------------------------
   HOJE (highlight)
   ---------------------------------------------------------- */
.agenda-tab.today {
  border-color: var(--c-gold);
}
.agenda-tab.today[aria-selected="true"] {
  background: var(--c-gold);
  border-color: var(--c-gold);
}

.today-indicator {
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--c-gold);
  animation: pulse-dot 1.5s ease-in-out infinite;
  margin-left: 4px;
  vertical-align: middle;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(0.8); }
}

/* ----------------------------------------------------------
   TRANSPORT STEPS (detail)
   ---------------------------------------------------------- */
.transport-steps {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: var(--s4);
}

.transport-step {
  display: flex;
  gap: var(--s3);
  position: relative;
  padding-bottom: var(--s3);
}
.transport-step:last-child { padding-bottom: 0; }

.transport-step-line {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
}

.transport-step-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--c-primary);
  border: 2px solid var(--bg);
  box-shadow: 0 0 0 1.5px var(--c-primary);
  flex-shrink: 0;
  z-index: 1;
}

.transport-step-connector {
  width: 1px;
  flex: 1;
  background: var(--border);
  min-height: 20px;
  margin-top: 3px;
}
.transport-step:last-child .transport-step-connector { display: none; }

.transport-step-body { flex: 1; padding-bottom: var(--s1); }

.transport-step-label {
  font-family: var(--font-mono);
  font-size: 8.5px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text3);
}

.transport-step-main {
  font-family: var(--font-serif);
  font-size: 0.9rem;
  color: var(--text);
}

.transport-step-detail {
  font-size: 0.75rem;
  color: var(--text3);
}
