/* Travel planner UI. Loaded only on the travel-planning page. */

/* ============================================================
   Travel planner page
   ============================================================ */
.planner-hero {
    position: relative;
    min-height: 520px;
    display: grid;
    align-items: end;
    color: var(--off-white);
    isolation: isolate;
    overflow: hidden;
}
.planner-hero__media {
    position: absolute;
    inset: 0;
    z-index: -2;
    background:
        linear-gradient(180deg, rgba(36,33,29,.03) 0%, rgba(36,33,29,.34) 78%),
        linear-gradient(90deg, rgba(36,33,29,.24) 0%, rgba(36,33,29,.05) 58%),
        url("../img/content/kalgoorlie-prospector-train.webp") center/cover no-repeat;
}
.planner-hero__inner {
    min-width: 0;
    padding-top: 110px;
    padding-bottom: 44px;
}
.planner-hero .eyebrow,
.planner-section .eyebrow { color: var(--rust); }
.planner-hero .eyebrow { color: #FFE08B; }
.planner-hero h1 {
    max-width: min(760px, 100%);
    color: var(--off-white);
    font-size: clamp(2.2rem, 5vw, 4.4rem);
    margin-bottom: 16px;
}
.planner-hero p {
    max-width: min(680px, 100%);
    color: rgba(255,250,239,.94);
    font-size: clamp(1.02rem, 2vw, 1.24rem);
}
.planner-jumps {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 24px;
}
.planner-jumps a,
.planner-links a {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 7px 12px;
    border-radius: var(--r-sm);
    border: 1px solid rgba(255,255,255,.50);
    color: var(--paper);
    background: rgba(36,33,29,.24);
    font-size: .92rem;
    font-weight: 700;
}
.planner-jumps a:hover,
.planner-links a:hover {
    text-decoration: none;
    background: var(--gold);
    color: var(--ink);
}
.planner-section { padding: 52px 0; }
.planner-section + .planner-section { border-top: 1px solid var(--line); }
.planner-quick { background: var(--sky-pale); }
.planner-quick-grid,
.planner-itinerary-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.planner-quick-grid article,
.planner-card,
.planner-panel {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--r-sm);
    padding: 20px;
    box-shadow: var(--shadow-1);
}
.planner-quick-grid article p { margin-bottom: 12px; }
.planner-quick-grid article a { font-weight: 800; }
.planner-itinerary-grid { grid-template-columns: repeat(4, 1fr); }
.planner-card strong,
.planner-stay-list strong {
    display: block;
    color: var(--rust);
    font-size: 1.05rem;
    margin-bottom: 8px;
}
.planner-card p { margin-bottom: 10px; }
.planner-card small {
    display: block;
    color: var(--muted);
    line-height: 1.45;
}
.planner-two-col > .wrap,
.wrap.planner-two-col {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 24px;
}
.planner-panel-head {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: start;
    margin-bottom: 14px;
}
.planner-panel-head h2 { margin-bottom: 0; }
.planner-panel-head small {
    color: var(--muted);
    text-align: right;
}
.planner-checklist {
    display: grid;
    gap: 10px;
}
.planner-checklist label {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 10px;
    border: 1px solid var(--line);
    border-radius: var(--r-sm);
    background: var(--off-white);
}
.planner-checklist input {
    width: 18px;
    height: 18px;
    accent-color: var(--rust);
}
.planner-checklist input:checked + span {
    color: var(--muted);
    text-decoration: line-through;
}
.planner-form-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.planner-form-grid label {
    display: grid;
    gap: 6px;
    color: var(--muted);
    font-size: .84rem;
    font-weight: 800;
    text-transform: uppercase;
}
.planner-form-grid input,
.planner-form-grid select {
    width: 100%;
    min-width: 0;
    border: 1px solid var(--line);
    border-radius: var(--r-sm);
    background: var(--off-white);
    color: var(--ink);
    padding: 10px;
    font: inherit;
    text-transform: none;
}
.planner-budget-result {
    display: block;
    margin-top: 18px;
    padding: 18px;
    border-radius: var(--r-sm);
    background: linear-gradient(135deg, var(--gold) 0%, #F2C75C 100%);
    color: var(--ink);
}
.planner-budget-result small {
    display: block;
    color: rgba(36,33,29,.70);
    font-weight: 700;
    text-transform: uppercase;
}
.planner-budget-result strong {
    display: block;
    font-size: clamp(2rem, 5vw, 3.3rem);
    line-height: 1.05;
}
.planner-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border: 1px solid var(--line);
    border-radius: var(--r-sm);
    background: var(--paper);
}
.planner-drive-table {
    width: 100%;
    border-collapse: collapse;
}
.planner-drive-table th,
.planner-drive-table td {
    padding: 13px 14px;
    border-bottom: 1px solid var(--line);
    text-align: left;
    vertical-align: top;
}
.planner-drive-table th {
    background: var(--off-white);
    color: var(--rust);
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.planner-drive-table td:first-child { font-weight: 800; }
.planner-drive-table tr:last-child td { border-bottom: 0; }
.planner-stay-list {
    display: grid;
    gap: 12px;
    margin-bottom: 18px;
}
.planner-stay-list article {
    padding-bottom: 12px;
    border-bottom: 1px dashed var(--line);
}
.planner-stay-list article:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}
.planner-stay-list span {
    display: block;
    font-weight: 800;
    margin-bottom: 2px;
}
.planner-stay-list p { margin-bottom: 0; color: var(--muted); }
.planner-pack-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    padding-left: 0;
    margin: 0;
    list-style: none;
}
.planner-pack-list li {
    padding: 9px 10px;
    border: 1px solid var(--line);
    border-radius: var(--r-sm);
    background: var(--off-white);
}
.planner-offline-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
}
.planner-offline-grid h3 { margin-bottom: 12px; }
.planner-offline-grid ol {
    margin: 0;
    padding-left: 1.3em;
}
.planner-offline-grid li { margin-bottom: 8px; }
.planner-note {
    margin: 16px 0 0;
    padding-top: 14px;
    border-top: 1px dashed var(--line);
    color: var(--muted);
    font-size: .94rem;
}
.planner-widgets { align-items: stretch; }
.planner-links { background: linear-gradient(135deg, var(--sky-pale) 0%, var(--sand-pale) 100%); color: var(--ink); }
.planner-links h2 { color: var(--ink); }
.planner-links a {
    border-color: rgba(181,91,50,.24);
    color: var(--rust);
    background: rgba(255,253,247,.72);
}
.planner-links .wrap > div {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

@media (max-width: 900px) {
    .planner-quick-grid,
    .planner-itinerary-grid,
    .planner-two-col > .wrap,
    .wrap.planner-two-col {
        grid-template-columns: 1fr 1fr;
    }
}
@media (max-width: 620px) {
    .planner-hero { min-height: 500px; }
    .planner-hero__inner { padding-bottom: 34px; }
    .planner-section { padding: 38px 0; }
    .planner-quick-grid,
    .planner-itinerary-grid,
    .planner-two-col > .wrap,
    .wrap.planner-two-col,
    .planner-form-grid,
    .planner-pack-list,
    .planner-offline-grid {
        grid-template-columns: 1fr;
    }
    .planner-panel-head { display: block; }
    .planner-panel-head small {
        display: block;
        text-align: left;
        margin-top: 4px;
    }
}
