/* ============================================================
   PACKAGE CALCULATOR — Interactive pricing tool
   Phase 4 of theme-test.html meld
   ============================================================ */
.mfl-packages-section { padding: 100px 48px; position: relative; }
.mfl-packages-section .mfl-pkg-bg { position: absolute; inset: 0; background: radial-gradient(ellipse at 40% 30%, rgba(92,138,110,0.06) 0%, transparent 60%), radial-gradient(ellipse at 70% 80%, rgba(200,185,138,0.04) 0%, transparent 50%), linear-gradient(160deg, var(--hybrid2) 0%, var(--hybrid) 50%, var(--hybrid2) 100%); }
.mfl-packages-section .mfl-pkg-texture { position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(200,185,138,0.025) 0px, rgba(200,185,138,0.025) 1px, transparent 1px, transparent 48px), repeating-linear-gradient(-45deg, rgba(200,185,138,0.015) 0px, rgba(200,185,138,0.015) 1px, transparent 1px, transparent 48px); pointer-events: none; }
.mfl-pkg-inner { position: relative; z-index: 1; max-width: 1300px; margin: 0 auto; }

/* Eyebrow prompt above tabs */
.mfl-pkg-prompt {
  text-align: center;
  /* Position prompt so its center sits above the boundary between tab 1 (Dual) and tab 2 (Flagship).
     With 3 equal tabs, that boundary is at ~33% of the tab bar — so we pad the right side by ~33%
     which shifts the centered text leftward to land over the tab 1 / tab 2 midpoint. */
  padding-left: 0;
  padding-right: 33%;
  font-family: 'Source Sans 3', sans-serif;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
  opacity: 0.9;
  white-space: nowrap;
  animation: mfl-prompt-pulse 3.2s ease-in-out infinite;
}
.mfl-pkg-prompt-arrow {
  display: inline-block;
  color: rgba(200,185,138,0.55);
  margin: 0 10px;
  animation: mfl-arrow-bounce 2.2s ease-in-out infinite;
}
.mfl-pkg-prompt-arrow:last-child { animation-delay: 1.1s; }
@keyframes mfl-prompt-pulse {
  0%, 100% { opacity: 0.55; }
  50%      { opacity: 1; }
}
@keyframes mfl-arrow-bounce {
  0%, 100% { transform: translateX(0); opacity: 0.35; }
  50%      { transform: translateX(-4px); opacity: 0.9; }
}
.mfl-pkg-prompt-arrow:last-child {
  animation-name: mfl-arrow-bounce-r;
}
@keyframes mfl-arrow-bounce-r {
  0%, 100% { transform: translateX(0); opacity: 0.35; }
  50%      { transform: translateX(4px); opacity: 0.9; }
}

/* Tabs */
.mfl-pkg-tabs {
  display: flex;
  gap: 0;
  margin-bottom: 56px;
  flex-wrap: wrap;
  background: rgba(0,0,0,0.25);
  border-radius: 8px;
  padding: 6px;
  border: 1px solid rgba(200,185,138,0.08);
  position: relative;
  --mfl-ind-left: 0px;
  --mfl-ind-width: 0px;
  --mfl-ind-top: 0px;
}
.mfl-pkg-tabs::after {
  content: '';
  position: absolute;
  top: var(--mfl-ind-top);
  left: var(--mfl-ind-left);
  width: var(--mfl-ind-width);
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, var(--gold) 20%, var(--gold) 80%, transparent 100%);
  border-radius: 2px;
  pointer-events: none;
  transition: left 0.55s cubic-bezier(0.65, 0, 0.35, 1), width 0.55s cubic-bezier(0.65, 0, 0.35, 1), top 0.55s cubic-bezier(0.65, 0, 0.35, 1);
  box-shadow: 0 0 12px rgba(200,185,138,0.55), 0 0 3px rgba(200,185,138,0.9);
  z-index: 2;
}
.mfl-pkg-tab { padding: 14px 28px; font-size: 13px; letter-spacing: 0.13em; text-transform: uppercase; font-weight: 600; cursor: pointer; color: var(--cream-faint); border: none; border-radius: 6px; transition: color 0.25s, background 0.25s; background: transparent; font-family: 'Source Sans 3', sans-serif; position: relative; z-index: 1; }
.mfl-pkg-tab:hover { color: var(--cream); background: rgba(232,224,208,0.05); }
.mfl-pkg-tab.active { color: var(--cream); background: rgba(200,185,138,0.12); box-shadow: 0 1px 3px rgba(0,0,0,0.3); }
/* Breathing glow on the active tab — persists across tab switches */
.mfl-pkg-tab.active {
  animation: mfl-tab-breathe 2.8s ease-in-out infinite;
}
@keyframes mfl-tab-breathe {
  0%, 100% {
    background: rgba(200,185,138,0.10);
    box-shadow: 0 1px 3px rgba(0,0,0,0.3), 0 0 0 0 rgba(200,185,138,0);
  }
  50% {
    background: rgba(200,185,138,0.20);
    box-shadow: 0 1px 3px rgba(0,0,0,0.3), 0 0 22px 2px rgba(200,185,138,0.35);
  }
}
@media (prefers-reduced-motion: reduce) {
  .mfl-pkg-tab.active,
  .mfl-pkg-prompt,
  .mfl-pkg-prompt-arrow { animation: none; }
}
.mfl-pkg-panel { display: none; }
.mfl-pkg-panel.active { display: block; }

/* Dual/Extended headers */
.mfl-dual-header { display: grid; grid-template-columns: 1fr auto; align-items: start; gap: 48px; margin-bottom: 64px; }
.mfl-package-badge { display: inline-flex; align-items: center; gap: 8px; padding: 5px 14px; $1 12px$2; font-weight: 600; color: var(--gold); border: 1px solid rgba(200,185,138,0.25); background: rgba(200,185,138,0.06); margin-bottom: 20px; }
.mfl-package-title { font-family: 'Playfair Display', serif; font-size: clamp(36px, 4.5vw, 56px); line-height: 1.05; color: var(--cream); margin-bottom: 16px; }
.mfl-package-title em { color: var(--gold); font-style: italic; }
.mfl-package-lead { font-size: 16px; line-height: 1.75; color: var(--cream-dim); font-weight: 400; max-width: 540px; }
.mfl-dual-price-block { text-align: right; padding-top: 20px; }
.mfl-dual-price-from { $1 12px$2; color: var(--cream-faint); font-weight: 600; }
.mfl-dual-price-val { font-family: 'Playfair Display', serif; font-size: 52px; color: var(--cream); line-height: 1; }
.mfl-dual-price-per { font-size: 12px; color: var(--cream-faint); margin-top: 6px; margin-bottom: 4px; }

/* Timeline */
.mfl-timeline-wrap { position: relative; padding: 24px 0 0; }
.mfl-timeline-label {
  display: block;
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--cream-dim, rgba(232,224,208,0.6));
  padding-bottom: 32px;
}
/* Rule sits at the bubble centerline so the dots ride the line. The
   value tracks: wrap padding-top (24) + label height (~22) + label
   padding-bottom (32) + .mfl-timeline margin-top (24) - bubble
   offset (30) + bubble radius (6) ≈ 78. */
.mfl-timeline-rule { position: absolute; left: 0; right: 0; top: 78px; height: 1px; opacity: 0.4; }
.mfl-timeline { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1px; margin-top: 24px; }
.mfl-t-step { padding: 28px 16px; position: relative; text-align: center; border-right: 1px solid var(--line); cursor: pointer; transition: background 0.25s; }
.mfl-t-step:last-child { border-right: none; }
.mfl-t-step.ctx-sfl { background: var(--marine2); }
.mfl-t-step.ctx-sfl:hover { background: var(--marine3); }
.mfl-t-step.ctx-mfl { background: var(--forest); }
.mfl-t-step.ctx-mfl:hover { background: var(--forest2); }
/* BFL DISABLED
.mfl-t-step.ctx-bfl { background: var(--burgundy2); }
.mfl-t-step.ctx-bfl:hover { background: var(--burgundy3); }
*/
.mfl-t-step.ctx-transfer { background: var(--hybrid2); }
.mfl-t-step.ctx-transfer:hover { background: var(--hybrid3); }
.mfl-t-node { position: absolute; left: 50%; top: -30px; transform: translateX(-50%); width: 12px; height: 12px; border-radius: 50%; border: 2px solid var(--gold-dk); background: var(--hybrid); }
.mfl-t-step.ctx-sfl .mfl-t-node { border-color: var(--sage); }
/* .mfl-t-step.ctx-bfl .mfl-t-node { border-color: var(--copper); }  BFL DISABLED */
.mfl-t-step.ctx-mfl .mfl-t-node { border-color: var(--gold); }
.mfl-t-step.ctx-transfer .mfl-t-node { border-color: var(--gold-dk); background: linear-gradient(135deg, var(--sage-dk), var(--gold-dk)); width: 14px; height: 14px; }
.mfl-t-lodge { $1 12px$2; font-weight: 600; margin-bottom: 10px; }
.mfl-t-lodge.sfl { color: var(--sage); }
/* .mfl-t-lodge.bfl { color: var(--copper); }  BFL DISABLED */
.mfl-t-lodge.mfl { color: var(--gold); }
.mfl-t-lodge.transfer { color: var(--gold-dk); }
.mfl-t-day { font-family: 'Playfair Display', serif; font-size: 20px; color: var(--cream); margin-bottom: 10px; }
.mfl-t-detail { font-size: 13px; line-height: 1.65; color: var(--cream-faint); font-weight: 400; }

/* Route cards */
.mfl-route-card { opacity: 0.6; cursor: pointer; transition: all 0.25s; flex: 1; min-width: 200px; padding: 16px 20px; border-radius: 6px; }
.mfl-route-card:hover { opacity: 0.85; }
.mfl-route-card.active { opacity: 1; }
.mfl-route-card.sfl-route { background: var(--marine3); border-left: 3px solid var(--sage); }
.mfl-route-card.sfl-route:not(.active) { background: var(--marine2); }

/* Calculator layout */
.mfl-calc-layout { display: grid; grid-template-columns: 1fr 380px; gap: 64px; align-items: start; }
.mfl-calc-badge { display: inline-flex; align-items: center; gap: 8px; padding: 5px 14px; $1 12px$2; font-weight: 600; margin-bottom: 20px; }
.mfl-calc-badge.mfl { color: var(--gold); border: 1px solid rgba(200,185,138,0.25); background: rgba(200,185,138,0.06); }
.mfl-calc-badge.sfl { color: var(--sage); border: 1px solid rgba(92,138,110,0.25); background: rgba(92,138,110,0.06); }
/* .mfl-calc-badge.bfl { color: var(--copper); border: 1px solid rgba(200,122,106,0.25); background: rgba(200,122,106,0.06); }  BFL DISABLED */
.mfl-calc-title { font-family: 'Playfair Display', serif; font-size: clamp(30px, 3.5vw, 44px); line-height: 1.1; color: var(--cream); margin-bottom: 14px; }
.mfl-calc-title em { color: var(--gold); font-style: italic; }
.mfl-calc-title.sfl em { color: var(--sage); }
/* .mfl-calc-title.bfl em { color: var(--copper); }  BFL DISABLED */
.mfl-calc-lead { font-size: 15px; line-height: 1.75; color: var(--cream-dim); font-weight: 400; margin-bottom: 36px; }

/* Controls */
.mfl-ctrl-group { margin-bottom: 28px; }
.mfl-ctrl-label { $1 12px$2; font-weight: 600; color: var(--cream-faint); margin-bottom: 12px; display: block; }
.mfl-ctrl-options { display: flex; gap: 8px; flex-wrap: wrap; }
.mfl-ctrl-btn { padding: 10px 18px; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600; cursor: pointer; border: 1px solid rgba(255,255,255,0.12); color: var(--cream-faint); background: transparent; font-family: 'Source Sans 3', sans-serif; transition: all 0.2s; }
.mfl-ctrl-btn:hover { border-color: var(--cream-faint); color: var(--cream-dim); }
.mfl-ctrl-btn.active { border-color: var(--gold); color: var(--gold); background: rgba(200,185,138,0.08); }

/* Guest grid */
.mfl-guest-grid { display: flex; flex-direction: column; gap: 4px; margin-top: 12px; }
.mfl-guest-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: rgba(255,255,255,0.03); border: 1px solid var(--line2); border-radius: 4px; }
.mfl-guest-info { flex: 1; }
.mfl-guest-label { font-size: 13px; font-weight: 600; color: var(--cream); letter-spacing: 0.04em; }
.mfl-guest-sub { font-size: 11px; color: var(--cream-faint); margin-top: 2px; }
.mfl-guest-counter { display: flex; align-items: center; gap: 14px; }
.mfl-gctr-btn { width: 28px; height: 28px; border-radius: 50%; border: 1px solid var(--gold-dk); background: transparent; color: var(--gold); font-size: 18px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.2s; font-family: 'Source Sans 3', sans-serif; padding: 0; }
.mfl-gctr-btn:hover { background: var(--gold); color: var(--hybrid); border-color: var(--gold); }
.mfl-gctr-val { font-family: 'Playfair Display', serif; font-size: 20px; font-weight: 700; color: var(--gold); min-width: 24px; text-align: center; }
.mfl-guest-validation { font-size: 11px; color: #e07070; margin-top: 8px; min-height: 16px; letter-spacing: 0.04em; padding: 0 2px; }

/* Price card */
.mfl-price-card { background: var(--hybrid3); border: 1px solid var(--line2); padding: 36px 32px; position: sticky; top: 88px; }
.mfl-price-card-header { $1 12px$2; color: var(--cream-faint); font-weight: 600; margin-bottom: 24px; padding-bottom: 16px; border-bottom: 1px solid var(--line); }
.mfl-price-line { display: flex; justify-content: space-between; align-items: baseline; padding: 10px 0; border-bottom: 1px solid var(--line); }
.mfl-price-line-label { font-size: 13px; color: var(--cream-dim); font-weight: 400; }
.mfl-price-line-val { font-size: 14px; color: var(--cream-dim); font-family: 'Playfair Display', serif; }
.mfl-price-total-row { display: flex; justify-content: space-between; align-items: baseline; padding: 20px 0 0; }
.mfl-price-total-label { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cream-faint); font-weight: 600; }
.mfl-price-total-val { font-family: 'Playfair Display', serif; font-size: 36px; color: var(--cream); line-height: 1; }
.mfl-price-total-unit { font-family: 'Source Sans 3', sans-serif; $1 12px$2; color: rgba(200,185,138,0.55); margin-top: 6px; text-align: right; }
.mfl-price-party-line { display: flex; justify-content: space-between; align-items: baseline; padding: 14px 0 0; margin-top: 12px; border-top: 1px solid rgba(200,185,138,0.12); }
.mfl-price-party-label { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cream-faint); font-weight: 600; }
.mfl-price-party-val { font-family: 'Source Sans 3', sans-serif; font-size: 15px; color: var(--cream-dim); font-weight: 400; }
.mfl-price-party-val em { font-style: normal; font-size: 11px; color: var(--cream-faint); font-weight: 400; margin-left: 4px; }
.mfl-price-total-per { font-size: 11px; color: var(--cream-faint); margin-top: 6px; text-align: right; }
.mfl-estimate-caveat { text-align: right; margin-top: 10px; }
.mfl-pick-dates-chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; font-family: 'Source Sans 3', sans-serif; $1 12px$2; color: var(--gold); background: rgba(200,185,138,0.08); border: 1px solid rgba(200,185,138,0.35); border-radius: 100px; cursor: pointer; transition: all 0.2s ease; }
.mfl-pick-dates-chip:hover { background: rgba(200,185,138,0.18); border-color: rgba(200,185,138,0.6); color: var(--gold-lt); transform: translateY(-1px); }
.mfl-pick-dates-chip .mfl-chip-icon { font-size: 8px; color: var(--gold); animation: mfl-chip-pulse 2.2s ease-in-out infinite; }
@keyframes mfl-chip-pulse { 0%, 100% { opacity: 0.5; } 50% { opacity: 1; } }
.mfl-price-card-cta { margin-top: 24px; width: 100%; padding: 14px; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 700; cursor: pointer; border: none; font-family: 'Source Sans 3', sans-serif; transition: background 0.2s; background: var(--gold); color: var(--hybrid); }
.mfl-price-card-cta:hover { background: var(--gold-lt); }
.mfl-price-note { font-size: 11px; color: var(--cream-faint); text-align: center; margin-top: 14px; line-height: 1.5; font-weight: 400; }

/* Inclusions */
.mfl-calc-inclusions { margin-top: 48px; }
.mfl-calc-inc-title { $1 12px$2; color: var(--cream-faint); font-weight: 600; margin-bottom: 20px; }
.mfl-calc-inc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.mfl-calc-inc-item { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; color: var(--cream-faint); font-weight: 400; line-height: 1.5; }
.mfl-calc-inc-item::before { content: ''; width: 4px; height: 4px; border-radius: 50%; background: var(--gold); flex-shrink: 0; margin-top: 7px; opacity: 0.5; }

/* Pricing breakdown grid */
.mfl-dp-note { background: var(--hybrid3); border: 1px solid var(--line2); padding: 28px 32px; margin-bottom: 40px; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 24px; }
.mfl-dp-col-title { $1 12px$2; color: var(--cream-faint); font-weight: 600; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.mfl-dp-row { display: flex; justify-content: space-between; padding: 6px 0; font-size: 13px; color: var(--cream-dim); font-weight: 400; }
.mfl-dp-row strong { color: var(--cream-dim); font-weight: 400; }
.mfl-dp-total { display: flex; justify-content: space-between; padding: 10px 0 0; margin-top: 4px; border-top: 1px solid var(--line2); font-size: 14px; color: var(--cream); }
.mfl-dp-total strong { font-family: 'Playfair Display', serif; font-size: 20px; color: var(--gold); }

/* Responsive */
@media (max-width: 900px) {
  .mfl-packages-section { padding: 60px 24px; }
  .mfl-calc-layout { grid-template-columns: 1fr; }
  .mfl-price-card { position: static; }
  .mfl-dp-note { grid-template-columns: 1fr; }
  .mfl-dual-header { grid-template-columns: 1fr; }
  .mfl-dual-price-block { text-align: left; }
  .mfl-pkg-tab { padding: 10px 16px; font-size: 12px; }
  .mfl-calc-inc-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  /* Stack package tabs vertically on phones — "hamburger" style */
  .mfl-pkg-tabs {
    flex-direction: column;
    gap: 4px;
    padding: 8px;
  }
  .mfl-pkg-tab {
    width: 100%;
    text-align: center;
    padding: 14px 16px;
    font-size: 12px;
    border-radius: 6px;
  }
  /* Hide the animated gold underline on stacked tabs — it doesn't translate to vertical */
  .mfl-pkg-tabs::after { display: none; }
  /* Give active tab a visible fill instead */
  .mfl-pkg-tab.active { background: rgba(200,185,138,0.18); color: var(--cream); }
  /* Center the "Select a Package Below" prompt — no lateral offset when tabs are stacked */
  .mfl-pkg-prompt { padding-right: 0 !important; padding-left: 0 !important; text-align: center !important; }
}
@media (max-width: 768px) {
  .mfl-timeline { display: flex; flex-direction: column; }
  .mfl-timeline-rule { width: 1px; height: auto; left: 16px; top: 0; bottom: 0; right: auto; }
  .mfl-timeline-wrap { padding: 0 0 0 40px; }
  .mfl-t-step { text-align: left; border-right: none; border-bottom: 1px solid var(--line); }
  .mfl-t-node { left: -32px; top: 36px; transform: none; }
}
