/* Lightning Lane prices hub. Builds on the park-page / almanac-table / plan-* chrome
   in site.css; only the price-specific pieces live here. llp- namespace. */

.llp-page .llp-h2 {
    font-family: var(--display);
    font-size: 22px;
    font-weight: 700;
    color: var(--ink);
    margin: var(--space-2xl) 0 var(--space-sm);
}
.llp-page .llp-sub {
    color: var(--muted);
    font-family: var(--label);
    margin: 0 0 var(--space-md);
}

/* ---- live "prices right now" panel ---- */
.llp-live {
    margin-top: var(--space-lg);
    padding: var(--space-md) var(--space-lg) var(--space-lg);
    background: var(--paper-2);
    border: 1px solid var(--hair);
    border-radius: 14px;
}
.llp-live .llp-h2 { margin-top: 0; }
.llp-live-status { color: var(--muted); font-family: var(--label); margin: var(--space-xs) 0 0; }

/* ---- park filter chips ---- */
.llp-filters {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
    margin: 0 0 var(--space-md);
}
.llp-chip {
    font-family: var(--label);
    font-size: 13px;
    font-weight: 600;
    color: var(--ink-soft);
    background: var(--paper);
    border: 1px solid var(--hair);
    border-radius: 999px;
    padding: 6px 14px;
    cursor: pointer;
    transition: border-color 0.15s ease, color 0.15s ease;
}
.llp-chip:hover { color: var(--ink); border-color: var(--rule); }
.llp-chip.is-active {
    color: var(--paper);
    background: var(--gold);
    border-color: var(--gold);
}

/* ---- price bar chart (the live single-ride data viz) ---- */
.llp-bars {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}
.llp-bar-row {
    display: grid;
    grid-template-columns: minmax(9rem, 18rem) 1fr auto;
    align-items: center;
    gap: var(--space-sm);
}
/* The grid display above overrides the UA [hidden] rule, so the park filter's
   row.hidden would not hide anything without this. */
.llp-bar-row[hidden] { display: none; }
.llp-bar-label {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
}
.llp-bar-label a { color: var(--blue); text-decoration: none; font-weight: 600; }
.llp-bar-label a:hover { text-decoration: underline; }
.llp-bar-label > span:first-child { font-weight: 600; color: var(--ink); }
.llp-bar-park { font-family: var(--label); font-size: 12px; color: var(--muted); }
.llp-bar {
    position: relative;
    height: 14px;
    background: var(--paper);
    border: 1px solid var(--hair);
    border-radius: 999px;
    overflow: hidden;
}
.llp-bar-fill {
    position: absolute;
    inset: 0 auto 0 0;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--gold-deep), var(--gold));
    transition: width 0.4s ease;
}
.llp-bar-val {
    font-family: var(--label);
    font-weight: 700;
    color: var(--ink);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

/* ---- Multi Pass by park ---- */
.llp-multi-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
    gap: var(--space-sm);
}
.llp-multi-card {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: var(--space-md);
    background: var(--paper-2);
    border: 1px solid var(--hair);
    border-radius: 12px;
}
.llp-multi-park { font-family: var(--label); font-size: 13px; font-weight: 700; color: var(--muted); }
.llp-multi-band {
    font-family: var(--display);
    font-size: 20px;
    font-weight: 700;
    color: var(--gold);
    font-variant-numeric: tabular-nums;
}
.llp-multi-foot { font-family: var(--label); font-size: 12px; color: var(--muted); }

/* ---- history table ---- */
.llp-table th:nth-child(2), .llp-table td:nth-child(2) { text-align: left; }
.llp-table .llp-ride a { color: var(--blue); text-decoration: none; }
.llp-table .llp-ride a:hover { text-decoration: underline; }
.llp-typical { font-weight: 700; color: var(--ink); font-variant-numeric: tabular-nums; white-space: nowrap; }
.llp-low { color: var(--gold); font-variant-numeric: tabular-nums; white-space: nowrap; }
.llp-high { color: var(--muted); font-variant-numeric: tabular-nums; white-space: nowrap; }
.llp-when { color: var(--muted); white-space: nowrap; }

.llp-note {
    margin: var(--space-xl) 0 0;
    padding: var(--space-md) var(--space-lg);
    background: var(--paper-2);
    border: 1px dashed var(--hair);
    border-radius: 12px;
    color: var(--ink-soft);
    font-family: var(--label);
}

/* ---- share + faq ---- */
.llp-share {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin: var(--space-2xl) 0 0;
}
.llp-share-label { font-family: var(--label); font-weight: 700; color: var(--muted); }
.llp-share-btn {
    font-family: var(--label);
    font-size: 13px;
    font-weight: 600;
    color: var(--ink);
    background: var(--paper-2);
    border: 1px solid var(--rule);
    border-radius: 999px;
    padding: 6px 16px;
    text-decoration: none;
}
.llp-share-btn:hover { border-color: var(--gold); color: var(--gold); }

.llp-faq dl { margin: 0; }
.llp-faq dt { font-weight: 700; color: var(--ink); margin-top: var(--space-md); }
.llp-faq dd { margin: var(--space-2xs) 0 0; color: var(--ink-soft); }

@media (max-width: 32rem) {
    .llp-bar-row { grid-template-columns: 1fr auto; }
    .llp-bar { display: none; }
}
