/* plan-your-trip.css */
.planner-layout { display: grid; grid-template-columns: 1fr 340px; gap: 3rem; align-items: start; }
.planner-steps { display: flex; flex-direction: column; gap: 2rem; }
.step-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 2rem; position: relative; }
.step-num { position: absolute; top: -1rem; left: 2rem; background: var(--coral); color: var(--white); font-family: var(--font-display); font-size: var(--fs-lg); font-weight: 900; width: 2.5rem; height: 2.5rem; border-radius: 50%; display: flex; align-items: center; justify-content: center; line-height: 1; }
.step-card h3 { font-family: var(--font-display); font-size: var(--fs-xl); font-weight: 700; margin-bottom: 0.75rem; padding-top: 0.5rem; }
.step-card p  { font-size: var(--fs-sm); color: var(--mid); margin-bottom: 1rem; }
.step-options { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; }
.step-option  { background: var(--surface); border: 2px solid var(--border); border-radius: var(--radius); padding: 1rem; text-align: center; cursor: pointer; transition: all var(--transition); }
.step-option:hover { border-color: var(--ocean); background: var(--ocean-light); }
.step-option.selected { border-color: var(--coral); background: var(--coral-light); }
.step-option-icon  { font-size: 1.75rem; display: block; margin-bottom: 0.4rem; }
.step-option-label { font-size: var(--fs-sm); font-weight: 600; color: var(--charcoal); }
.budget-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.budget-card { background: var(--surface); border: 2px solid var(--border); border-radius: var(--radius); padding: 1.25rem; text-align: center; }
.budget-card h4 { font-family: var(--font-display); font-size: var(--fs-md); font-weight: 700; margin-bottom: 0.25rem; }
.budget-range { font-size: var(--fs-sm); color: var(--ocean); font-weight: 600; }
.budget-desc  { font-size: var(--fs-xs); color: var(--mid); margin-top: 0.4rem; }
.planner-sidebar { position: sticky; top: 6rem; display: flex; flex-direction: column; gap: 1.25rem; }
.sidebar-widget { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.5rem; }
.sidebar-widget h3 { font-family: var(--font-display); font-size: var(--fs-md); font-weight: 700; margin-bottom: 1rem; display: flex; align-items: center; gap: 0.5rem; }
.sidebar-widget ul { list-style: none; }
.sidebar-widget li { font-size: var(--fs-sm); color: var(--mid); padding: 0.4rem 0; border-bottom: 1px solid var(--border); }
.sidebar-widget li:last-child { border-bottom: none; }
.sidebar-widget li strong { color: var(--ink); }
.highlight-widget { background: var(--ocean); color: var(--white); border-color: var(--ocean); }
.highlight-widget h3 { color: var(--white); }
.highlight-widget p  { font-size: var(--fs-sm); color: rgba(255,255,255,0.8); margin-bottom: 1rem; }
.timeline { display: flex; flex-direction: column; gap: 0; }
.tl-item { display: flex; gap: 1rem; align-items: flex-start; padding: 0.75rem 0; border-bottom: 1px solid var(--border); }
.tl-item:last-child { border-bottom: none; }
.tl-day  { background: var(--coral); color: var(--white); font-size: var(--fs-xs); font-weight: 700; padding: 0.2rem 0.5rem; border-radius: var(--radius-sm); white-space: nowrap; flex-shrink: 0; align-self: flex-start; margin-top: 0.15rem; }
.tl-content h4 { font-size: var(--fs-sm); font-weight: 700; margin-bottom: 0.2rem; }
.tl-content p  { font-size: var(--fs-xs); color: var(--mid); }
@media(max-width:900px){.planner-layout{grid-template-columns:1fr}.planner-sidebar{position:static}.step-options{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.step-options,.budget-grid{grid-template-columns:1fr}}
