/* Happyland — palette + base chrome.
 *
 * Tokens extracted from the Figma "Ticketing Flow - Desktop" file.
 * Palette: white cards on a light-grey page, blue primary action,
 * Happyland purple as brand accent. Will evolve as more screens land.
 */

:root {
    /* Tokens lifted from the Figma design system (G1/G2/G3/G4/Secondary
     * variables on node 1115:8104). Names use the design intent so
     * future Figma probes are easy to map back. */
    --color-bg:           #f2f2f2;
    --color-surface:      #ffffff;     /* G6 */
    --color-hero-fill:    #d4d4d4;
    --color-border:       #d8d8d8;     /* G4 */
    --color-divider:      #ececec;

    --color-text:         #1a1a1a;     /* G1 */
    --color-text-muted:   #474747;     /* G2 */
    --color-text-faint:   #bababa;     /* G3 — past dates, disabled labels */

    --color-primary:      #0073e6;     /* Secondary — CTA button + links */
    --color-primary-hov:  #005bb8;
    --color-primary-fg:   #ffffff;

    --color-brand:        #6b1a8a;     /* Happyland purple (logo wordmark) */
    --color-accesso:      #5fa728;     /* accesso platform green */

    --space-1:  4px;
    --space-2:  8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 24px;
    --space-6: 32px;
    --space-7: 48px;
    --space-8: 64px;

    --radius-sm: 4px;
    --radius-md: 6px;
    --radius-lg: 16px;        /* matches the Figma calendar card */

    --shadow-card: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);

    --container-max: 1280px;

    /* Roboto from Google Fonts; system stack falls through if it
     * fails to load (offline / blocked). */
    --font-sans: 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    /* Type scale lifted from the Figma "Headline" / "Body" tokens. */
    --type-headline-5: 700 16px/24px var(--font-sans);  /* letter-spacing 0.8 */
    --type-body-2:     400 14px/20px var(--font-sans);
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    min-height: 100%;
}

body {
    font-family: var(--font-sans);
    color: var(--color-text);
    background: var(--color-bg);
    line-height: 1.5;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

a { color: var(--color-primary); }
a:hover { color: var(--color-primary-hov); }

.container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--space-5);
    width: 100%;
}

/* ---- Header ----------------------------------------------------------- */

.site-header {
    background: #fff;
    border-bottom: 1px solid var(--color-border);
    padding: var(--space-4) 0;
    flex-shrink: 0;
}

.site-header .container {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: var(--space-4);
}

.site-header .nav-left,
.site-header .nav-right {
    display: flex;
    align-items: center;
    gap: var(--space-4);
}

.site-header .nav-right { justify-content: flex-end; }

.brand {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}
.brand img {
    height: 63px;
    width: auto;
    display: block;
}

.platform-mark {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
}
.platform-mark img {
    width: 36px;
    height: 36px;
    display: block;
}

/* Header account / cart icons — blue-outline SVGs that fill solid blue on
 * hover (and, for the account icon, when signed in). Background-image swap
 * rather than an <img> so the hover state is pure CSS. */
.header-icon {
    display: inline-block;
    width: 36px;
    height: 36px;
    text-decoration: none;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 26px;
}
.header-icon--account { background-image: url('/assets/icon-account.svg'); }
.header-icon--account:hover,
.header-icon--account.is-authed { background-image: url('/assets/icon-account-hover.svg'); }
.header-icon--cart { background-image: url('/assets/icon-cart.svg'); }
.header-icon--cart:hover { background-image: url('/assets/icon-cart-hover.svg'); }

/* ---- Hero ------------------------------------------------------------- */

.hero {
    height: 230px;
    background: var(--color-hero-fill) url('/assets/hero_img_happyland.jpg') center / cover no-repeat;
    flex-shrink: 0;
}

/* Hero only shows on the venue grid and ticket listing screens —
 * inner flow steps (datetime, guests, cart, etc.) drop it per Figma. */
body:not(.page-venue):not(.page-tickets) .hero { display: none; }

/* ---- Main / step container -------------------------------------------- */

main {
    flex: 1;
    padding: var(--space-7) 0;
}

.section-title {
    margin: 0 0 var(--space-5);
    font-size: 22px;
    font-weight: 600;
}

/* ---- Card grid -------------------------------------------------------- */

.card-grid {
    display: grid;
    gap: var(--space-5);
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.card {
    background: var(--color-surface);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-card);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.card-image {
    background: var(--color-hero-fill);
    aspect-ratio: 16 / 10;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: center;
}

.card-image .venue-name {
    color: var(--color-brand);
    font: 700 24px/1.1 var(--font-sans);
    text-align: center;
}

.card-body {
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    flex: 1;
}

.card-title {
    font-size: 16px;
    font-weight: 700;
    margin: 0;
}

.card-desc {
    font-size: 13px;
    color: var(--color-text-muted);
    margin: 0;
    flex: 1;
}

.card-actions {
    padding: 0 var(--space-4) var(--space-4);
    display: flex;
    justify-content: flex-end;
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-2) var(--space-5);
    font-size: 14px;
    font-weight: 600;
    border-radius: var(--radius-md);
    cursor: pointer;
    border: none;
    text-decoration: none;
    transition: background 0.12s ease, transform 0.12s ease;
}

.btn:active { transform: translateY(1px); }

.btn-primary {
    background: var(--color-primary);
    color: var(--color-primary-fg);
}
.btn-primary:hover { background: var(--color-primary-hov); }

/* ---- Footer ----------------------------------------------------------- */

.site-footer {
    background: var(--color-surface);
    border-top: 1px solid var(--color-border);
    padding: var(--space-5) 0;
    text-align: center;
    font-size: 14px;
    flex-shrink: 0;
}

.site-footer a {
    color: var(--color-primary);
    text-decoration: none;
    margin: 0 var(--space-3);
}

.site-footer a:hover { text-decoration: underline; }

/* ---- Back arrow + title row ------------------------------------------ */

.back-title {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-5);
}

.back-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px; height: 28px;
    color: var(--color-primary);
    text-decoration: none;
    font-size: 18px;
    border-radius: 50%;
}
.back-arrow:hover { background: rgba(0, 115, 230, 0.1); }

/* ---- Product card extras --------------------------------------------- */

.product-card .card-image {
    position: relative;
}

.price-badge {
    position: absolute;
    top: var(--space-3);
    right: var(--space-3);
    background: #ffffff;
    border-radius: var(--radius-md);
    padding: var(--space-2) var(--space-3);
    box-shadow: var(--shadow-card);
    text-align: center;
    line-height: 1.1;
    min-width: 64px;
}
.price-badge .price-from {
    display: block;
    font-size: 11px;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.price-badge .price-amt {
    display: block;
    font-size: 16px;
    font-weight: 700;
    color: var(--color-text);
}

.product-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.btn-info {
    width: 32px; height: 32px;
    border-radius: 50%;
    background: transparent;
    border: 1.5px solid var(--color-primary);
    cursor: pointer;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    /* The Figma icon is the canonical "i" — render via background so
     * we keep the empty <button> markup the page templates already
     * produce (no SVG injection required in the page modules). */
    background-image: url('/assets/icon-info.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: 16px 16px;
    color: transparent;
    font-size: 0;
}
.btn-info:hover { background-color: rgba(0, 115, 230, 0.06); }

/* ---- Breadcrumb ------------------------------------------------------- */

.breadcrumb {
    font-size: 13px;
    color: var(--color-text-muted);
    margin-bottom: var(--space-5);
}
.breadcrumb a {
    color: var(--color-primary);
    text-decoration: none;
}
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb .sep { margin: 0 var(--space-2); }

/* ---- Date/Time layout ------------------------------------------------ */

.dt-grid {
    display: grid;
    grid-template-columns: 320px 440px 1fr;
    gap: var(--space-6);
    align-items: start;
}

.dt-included {
    margin-top: var(--space-4);
    font-size: 13px;
    color: var(--color-text-muted);
}
.dt-included strong { color: var(--color-text); display: block; margin-top: var(--space-3); }
.dt-included p { margin: var(--space-1) 0 0; }

.dt-summary { /* right column */ }

/* ---- Calendar -------------------------------------------------------- */

.cal {
    /* Bordered card per Figma node 1115:8104 — white bg, 1px G4 border,
     * 16px radius, 4px outer padding. */
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 4px;
}

.cal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0;
}
.cal-month {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font: var(--type-headline-5);
    letter-spacing: 0.8px;
    color: var(--color-text);
    padding: 10px var(--space-2);
}
.cal-month::after {
    content: "▾";
    font-size: 11px;
    color: var(--color-text-muted);
    margin-top: 2px;
}
.cal-nav {
    background: url('/assets/icon-chevron-left.svg') no-repeat center / 24px 24px;
    border: none;
    width: 24px; height: 24px;
    color: var(--color-text);
    cursor: pointer;
    margin: var(--space-3);
    flex-shrink: 0;
    padding: 0;
    font-size: 0;
}
.cal-nav.next { transform: rotate(180deg); }
.cal-nav:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.cal-row.dow {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    color: var(--color-text-muted);
    font: var(--type-body-2);
    height: 36px;
}
.cal-row.dow .cal-cell {
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px 0;
    margin-top: 0;
}

.cal-cell.day {
    background: transparent;
    border: none;
    font: var(--type-headline-5);
    letter-spacing: 0.8px;
    cursor: pointer;
    padding: var(--space-2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text);
}
.cal-cell.day .day-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px; height: 32px;
    border-radius: 50%;
    line-height: 1;
    text-align: center;
}
.cal-cell.day:hover .day-num { background: rgba(0, 115, 230, 0.08); }
.cal-cell.day.past,
.cal-cell.day.unavailable {
    color: var(--color-text-faint);
    cursor: not-allowed;
}
.cal-cell.day.past:hover .day-num,
.cal-cell.day.unavailable:hover .day-num { background: transparent; }
.cal-cell.day.sel .day-num {
    background: var(--color-primary);
    color: var(--color-primary-fg);
}

/* ---- Time slots (inline below calendar) -----------------------------
 * Pill-style picker per the Figma "Available Times" group: 3-column
 * grid of bordered rounded pills, white bg + dark text by default,
 * filled #0073E6 + white text when selected. */

.dt-slots { margin-top: var(--space-6); padding: 0; }
.dt-slots-head {
    text-align: center;
    font: var(--type-headline-5);
    letter-spacing: 0.4px;
    color: var(--color-text);
    margin: 0 0 var(--space-4);
}
.dt-slot-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-2);
}
.dt-slot {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 18px;            /* fully pill-rounded (height ~36px) */
    padding: var(--space-2) var(--space-4);
    cursor: pointer;
    color: var(--color-text);
    font: 700 14px/20px var(--font-sans);
    text-align: center;
    transition: background 0.12s ease, color 0.12s ease, border-color 0.12s ease;
}
.dt-slot:hover { border-color: var(--color-primary); }
.dt-slot.sel {
    background: var(--color-primary);
    color: var(--color-primary-fg);
    border-color: var(--color-primary);
}

/* ---- Datetime summary (right column) -------------------------------- */

.dt-summary-card {
    /* Plain stack — no surrounding card per the Figma */
}
.dt-summary-row {
    display: flex;
    justify-content: space-between;
    padding: var(--space-3) 0;
    font-size: 14px;
}
.dt-summary-row .key { color: var(--color-text); font-weight: 600; }
.dt-summary-row .val { color: var(--color-primary); font-weight: 500; }
.dt-summary-rule {
    border: none;
    border-top: 1px solid var(--color-divider);
    margin: 0;
}
.dt-summary-cta {
    width: 100%;
    margin-top: var(--space-5);
}
.dt-summary-cta:disabled {
    background: #d8dee5;
    color: #fff;
    cursor: not-allowed;
}

.g-rows { display: flex; flex-direction: column; gap: var(--space-3); }

.cal-icon {
    display: inline-block;
    width: 22px;
    height: 22px;
    margin-right: var(--space-2);
    vertical-align: -4px;
    background: url('/assets/icon-calendar.svg') no-repeat center / contain;
}

/* ---- Guests / quantity layout --------------------------------------- */

.g-grid {
    display: grid;
    grid-template-columns: 320px 1fr 320px;
    gap: var(--space-6);
    align-items: start;
}

/* One outer card for all guest rows per Figma node 1129:12991 —
 * not per-row borders. White surface, G4 border, 16px radius. */
.g-rows {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 0 var(--space-4);
}

.g-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-3) 0;
}
.g-row + .g-row { border-top: 1px solid var(--color-divider); }

.g-row-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.g-row-name {
    font: var(--type-body-2);
    color: var(--color-text);
}
.g-row-price {
    /* Caption from the design system tokens — 12/16, G2. */
    font: 400 12px/16px var(--font-sans);
    color: var(--color-text-muted);
}

/* Quantity stepper: minus / number-field / plus.
 * Each control sits in a 40px hit area; the visual circle/box
 * is centered and 24px (steppers) or 40px (number field). */
.qty-stepper {
    display: flex;
    align-items: center;
    gap: 0;
}
.qty-step {
    width: 40px;
    height: 40px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    position: relative;
    /* The 24px circle outline + icon inside the 40px hit box */
    background-position: center;
    background-repeat: no-repeat;
    background-size: 12px 12px;
}
.qty-step::before {
    content: "";
    position: absolute;
    width: 24px;
    height: 24px;
    border: 2px solid var(--color-text-muted);     /* G2 #474747 */
    border-radius: 50%;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
}
.qty-step.plus  { background-image: url('/assets/icon-plus.svg'); }
.qty-step.minus { background-image: url('/assets/icon-minus.svg'); background-size: 10px 2px; }
.qty-step.is-disabled { cursor: not-allowed; }
.qty-step.is-disabled::before { border-color: var(--color-text-faint); }   /* G3 */
.qty-step.is-disabled { filter: opacity(0.45); }

.qty-field {
    width: 40px;
    height: 40px;
    background: var(--color-surface);
    border: 1px solid var(--color-text-faint);      /* G3 #bababa per Figma */
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font: var(--type-body-2);
    color: var(--color-text);
}

.g-summary {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-5);
    font-size: 14px;
}
.g-sum-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: var(--space-2);
}
.g-sum-row.total {
    font-weight: 700;
    font-size: 16px;
}
.g-sum-rule {
    border: none;
    border-top: 1px solid var(--color-divider);
    margin: var(--space-3) 0;
}
.g-add-btn {
    width: 100%;
    margin-top: var(--space-4);
}

.add-icon::before {
    content: "👤";
    margin-right: var(--space-2);
}

/* ---- Cart ------------------------------------------------------------ */

.cart-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-5);
}
.cart-count { font-size: 14px; color: var(--color-text-muted); }
.cart-icon-sm::before { content: "🛒"; margin-right: var(--space-2); }

.cart-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: var(--space-6);
    align-items: start;
}

.cart-item {
    display: grid;
    grid-template-columns: 100px 1fr auto;
    gap: var(--space-4);
    padding: var(--space-4);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-3);
    align-items: center;
}
.cart-item-img {
    width: 100px; height: 80px;
    background-color: var(--color-hero-fill);
    background-size: cover;
    background-position: center;
    border-radius: var(--radius-sm);
}
.cart-item-title { font-size: 15px; font-weight: 700; margin: 0 0 var(--space-1); }
.cart-item-meta { font-size: 12px; color: var(--color-text-muted); margin: 0; }
.cart-item-end {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: var(--space-2);
}
.cart-item-price { font-weight: 700; }
.cart-item-remove {
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--color-text-muted);
    font-size: 16px;
}
.cart-item-remove:hover { color: var(--color-text); }

.cart-summary {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-5);
}

.totals-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: var(--space-3);
}
.totals-row.total {
    font-weight: 700;
    font-size: 16px;
    padding-bottom: var(--space-3);
    border-bottom: 1px solid var(--color-divider);
}

.voucher {
    display: flex;
    gap: var(--space-2);
    margin: var(--space-4) 0;
}
.voucher input {
    flex: 1;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font: inherit;
}
.voucher-msg {
    font-size: 13px;
    margin-top: var(--space-2);
    min-height: 1em;
}
.voucher-msg.ok  { color: #2e7d32; }
.voucher-msg.err { color: #d32f2f; }

.cart-cta { width: 100%; margin-top: var(--space-3); }

.btn-secondary {
    background: transparent;
    color: var(--color-primary);
    border: 1px solid var(--color-primary);
}
.btn-secondary:hover { background: rgba(0, 115, 230, 0.06); }

/* ---- Upsell ---------------------------------------------------------- */

.upsell-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: var(--space-6);
    align-items: start;
}
.upsell-cards { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.upsell-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 var(--space-4) var(--space-4);
}

.upsell-summary {
    position: sticky;
    top: var(--space-4);
}

/* ---- Checkout (personal + payment) ----------------------------------- */

.checkout-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: var(--space-6);
    align-items: start;
}

.checkout-form {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-7);
}

.step-indicator {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
    margin-bottom: var(--space-7);
    font-size: 14px;
}
.step-active   { font-weight: 700; color: var(--color-text); }
.step-future   { color: var(--color-text-muted); }
.step-done a   { color: var(--color-primary); text-decoration: none; }
.step-done a:hover { text-decoration: underline; }
.step-line {
    width: 60px;
    height: 1px;
    background: var(--color-text-muted);
    display: inline-block;
}

.form-heading {
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 var(--space-2);
}
.form-sub { color: var(--color-text-muted); margin: 0 0 var(--space-5); font-size: 13px; }

.hl-form { display: flex; flex-direction: column; gap: var(--space-4); }
.field {
    display: block;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    transition: border 0.12s ease;
}
.field:focus-within { border-color: var(--color-primary); }
.field-label {
    display: block;
    font-size: 12px;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--space-1);
}
.field input {
    width: 100%;
    border: none;
    outline: none;
    font: inherit;
    color: var(--color-text);
    background: transparent;
}

.form-cta { width: 100%; margin-top: var(--space-3); padding: var(--space-3) var(--space-5); font-size: 16px; }

/* ---- Payment specifics ---------------------------------------------- */

.gift-add {
    width: 100%;
    background: transparent;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    cursor: not-allowed;
    text-align: left;
    color: var(--color-text-muted);
    font: inherit;
    display: flex;
    align-items: center;
    gap: var(--space-3);
}
.gift-icon {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
}

.pay-methods {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.pay-method {
    display: flex;
    align-items: center;
    padding: var(--space-4);
    border-bottom: 1px solid var(--color-divider);
    cursor: pointer;
    gap: var(--space-3);
}
.pay-method:last-child { border-bottom: none; }
.pay-method.selected { background: rgba(0, 115, 230, 0.04); }
.pay-method.disabled { color: var(--color-text-muted); cursor: not-allowed; }
.pay-method input { accent-color: var(--color-primary); }
.lock-icon {
    display: inline-block;
    width: 16px;
    height: 16px;
    margin-right: var(--space-1);
    vertical-align: -3px;
}

/* ---- Cart-timer + summary aside ------------------------------------- */

.checkout-summary { position: sticky; top: var(--space-4); }

.cart-timer {
    background: #fdf1f1;
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    margin-bottom: var(--space-3);
    color: #b71c1c;
    font-size: 13px;
}
.cart-timer-label { display: block; font-size: 12px; }
.cart-timer-val {
    font-size: 18px;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
}
.cart-timer-icon {
    width: 18px;
    height: 18px;
    /* SVG inherits via fill="var(--fill-0, currentColor)"; the timer
     * lives on a red-tinted background, so let it pick up the
     * surrounding text color. */
    filter: brightness(0) saturate(100%) invert(15%) sepia(86%) saturate(2657%) hue-rotate(347deg) brightness(91%) contrast(96%);
}

/* ---- Confirmation --------------------------------------------------- */

.conf-grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: var(--space-6);
    align-items: start;
}

.conf-title { margin: 0 0 var(--space-3); font-size: 28px; }
.conf-meta { margin: 0; font-size: 13px; }
.conf-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-4) var(--space-5);
    margin-top: var(--space-4);
}
.conf-card-row { display: grid; grid-template-columns: 80px 1fr; gap: var(--space-4); align-items: start; }
.conf-card-key { font-size: 11px; color: var(--color-text-muted); letter-spacing: 0.04em; }
.conf-card-row strong { display: block; }
.conf-card-meta { display: block; font-size: 12px; color: var(--color-text-muted); margin-top: var(--space-1); }

.conf-cta { display: inline-flex; margin-right: var(--space-3); margin-top: var(--space-4); }

.conf-summary {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-5);
}
.conf-summary-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-4);
}
.conf-line {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-3) 0;
    border-bottom: 1px solid var(--color-divider);
}
.conf-line:last-child { border-bottom: none; }
.conf-line-body { display: flex; flex-direction: column; gap: var(--space-1); }
.conf-line-meta { font-size: 12px; color: var(--color-text-muted); }
.conf-line-date { color: var(--color-primary); }
.conf-line-end { text-align: right; display: flex; flex-direction: column; gap: var(--space-1); }

/* ---- Placeholder utility --------------------------------------------- */

.placeholder {
    padding: var(--space-7) var(--space-5);
    background: var(--color-surface);
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-md);
    text-align: center;
    color: var(--color-text-muted);
}

/* ---- Auth (sign-in / register / forgot / account) -------------------- */

.auth-card {
    max-width: 440px;
    margin: var(--space-6) auto;
    padding: var(--space-6);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}

.auth-title {
    margin: 0 0 var(--space-2);
    font-size: 24px;
    font-weight: 700;
    color: var(--color-text);
}

.auth-sub {
    margin: 0 0 var(--space-5);
    color: var(--color-text-muted);
    font-size: 14px;
}

.auth-msg {
    margin-bottom: var(--space-4);
    font-size: 13px;
    color: #d32f2f;
    min-height: 1em;
}
.auth-msg-success { color: #2e7d32; }

.auth-links {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin-top: var(--space-5);
    font-size: 14px;
}
.auth-links a {
    color: var(--color-primary);
    text-decoration: none;
}
.auth-links a:hover { text-decoration: underline; }

/* ---- Checkout identity chooser --------------------------------------- */

.checkout-chooser {
    display: flex;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    margin-bottom: var(--space-5);
}
.chooser-tab {
    flex: 1;
    padding: var(--space-3) var(--space-4);
    background: var(--color-surface);
    border: 0;
    border-right: 1px solid var(--color-border);
    font: inherit;
    font-size: 14px;
    color: var(--color-text);
    cursor: pointer;
    text-align: center;
}
.chooser-tab:last-child { border-right: 0; }
.chooser-tab.active {
    background: var(--color-primary);
    color: #fff;
}

.chooser-form {
    margin-bottom: var(--space-6);
    padding: var(--space-5);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}

/* ---- Account page ---------------------------------------------------- */

.account-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-5);
    margin: var(--space-5) 0;
}
@media (max-width: 720px) {
    .account-grid { grid-template-columns: 1fr; }
}

.account-card {
    padding: var(--space-6);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}

.account-meta {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: var(--space-2) var(--space-4);
    margin: var(--space-4) 0 var(--space-5);
    font-size: 14px;
}
.account-meta dt { color: var(--color-text-muted); }
.account-meta dd { margin: 0; color: var(--color-text); }

.account-order {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: var(--space-3) 0;
    border-bottom: 1px solid var(--color-border);
    font-size: 14px;
}
.account-order:last-child { border-bottom: 0; }
.account-order-date {
    margin-left: var(--space-3);
    color: var(--color-text-muted);
    font-size: 13px;
}

.account-actions {
    display: flex;
    gap: var(--space-3);
    flex-wrap: wrap;
    margin-top: var(--space-4);
}

/* ---- Pass holder forms (one fieldset per holder) --------------------- */

.holder-block {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-4) var(--space-5);
    margin-bottom: var(--space-4);
}
.holder-block legend {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-muted);
    padding: 0 var(--space-2);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* ---- My passes ------------------------------------------------------- */

.passes-profile {
    display: flex;
    gap: var(--space-4);
    align-items: center;
    margin-top: var(--space-4);
}
.passes-avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: var(--color-bg-muted, #f3f3f3);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: none;
    font-size: 36px;
}
.passes-avatar img { width: 100%; height: 100%; object-fit: cover; }

.passes-profile-meta { flex: 1; min-width: 0; }
.passes-profile-meta strong { display: block; margin-bottom: var(--space-1); }

.loyalty-panel {
    margin-top: var(--space-5);
    padding: var(--space-4) var(--space-5);
    background: var(--color-primary);
    color: #fff;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
}
.loyalty-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.8;
}
.loyalty-balance {
    font-size: 36px;
    font-weight: 700;
    line-height: 1.1;
    margin-top: var(--space-1);
}
.loyalty-expiry {
    font-size: 13px;
    text-align: right;
    opacity: 0.9;
}

.passes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--space-4);
    margin-top: var(--space-3);
}
.pass-card {
    text-align: center;
    padding: var(--space-4);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}
.pass-qr {
    width: 100%;
    max-width: 180px;
    aspect-ratio: 1 / 1;
    display: block;
    margin: 0 auto var(--space-3);
}
.pass-name {
    font-weight: 600;
    color: var(--color-text);
}
.pass-meta {
    font-size: 12px;
    color: var(--color-text-muted);
    margin-top: var(--space-1);
}
.pass-renew {
    width: 100%;
    margin-top: var(--space-3);
}
.pass-terms {
    margin-top: var(--space-1);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    color: var(--color-primary);
}

/* ---- Renew-pass modal ------------------------------------------------- */
.hl-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
    z-index: 1000;
}
.hl-modal {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.18);
    padding: var(--space-6);
    width: 100%;
    max-width: 420px;
}
.hl-modal .section-title {
    margin: 0 0 var(--space-4);
}
.hl-modal .btn {
    width: 100%;
    margin-top: var(--space-2);
}
.renew-opt {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-2);
}
.renew-opt span { flex: 1; }
.renew-opt strong { color: var(--color-text); }
.renew-opt.single { background: var(--color-divider); }
.renew-receipt {
    margin: var(--space-3) 0 var(--space-4);
}
.renew-receipt div {
    display: flex;
    justify-content: space-between;
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--color-divider);
    font-size: 14px;
}
.renew-receipt span { color: var(--color-text-muted); }

.related-block {
    padding: var(--space-4);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-4);
}
.related-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: var(--space-3);
    gap: var(--space-3);
    flex-wrap: wrap;
}
.related-header h3 { font-size: 16px; font-weight: 600; margin: 0; color: var(--color-text); }
.related-header .pill {
    padding: 2px 10px;
    border-radius: 12px;
    background: var(--color-primary);
    color: #fff;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.placeholder h2 { margin-top: 0; color: var(--color-text); }
