/* Bridgewater Concerts — local web app */

:root {
    --bg: #fafaf7;
    --fg: #1b1b1b;
    --card: #ffffff;
    --muted: #5a5a5a;
    --line: #e4e4dc;
    --line-soft: #efefe9;
    --others-bg: #f1efe8;
    --accent: #6f4c8a;
    --accent-soft: #f3eef9;
    --picked: #fff5d6;
    --picked-line: #d6c270;
    --shadow: 0 1px 2px rgba(0, 0, 0, 0.05), 0 4px 12px rgba(0, 0, 0, 0.04);
    color-scheme: light;
}

[data-theme="dark"] {
    --bg: #15151a;
    --fg: #e7e5e0;
    --card: #1f1f25;
    --muted: #9c9c9c;
    --line: #2c2c33;
    --line-soft: #25252d;
    --others-bg: #18181d;
    --accent: #b495d6;
    --accent-soft: #2c2438;
    --picked: #36331f;
    --picked-line: #685a30;
    --shadow: 0 1px 2px rgba(0, 0, 0, 0.4), 0 4px 12px rgba(0, 0, 0, 0.3);
    color-scheme: dark;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
    color: var(--fg);
    background: var(--bg);
    line-height: 1.5;
    padding-bottom: 6rem; /* leave room for the floating submit button */
}

a {
    color: var(--accent);
}

/* ── Top bar ─────────────────────────────────────────────── */

.topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.85rem 1.5rem;
    border-bottom: 1px solid var(--line);
    background: var(--card);
    position: sticky;
    top: 0;
    z-index: 10;
    gap: 1rem;
    flex-wrap: wrap;
}

.topbar h1 {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: var(--accent);
}

.topbar-right {
    display: flex;
    align-items: center;
    gap: 1rem;
}

/* Presence pill — "Helen is also picking now". */
.presence-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: var(--accent-soft);
    color: var(--accent);
    border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
    border-radius: 999px;
    padding: 0.2rem 0.7rem;
    font-size: 0.8rem;
    font-weight: 500;
}
.presence-pill::before {
    content: "";
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: #3aa75a;
    flex: none;
}

/* "Which of you is this?" — person buttons. */
.picker-people {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    justify-content: center;
}
.person-btn {
    font: inherit;
    font-size: 1.05rem;
    font-weight: 600;
    color: #fff;
    background: var(--person-color, var(--accent));
    border: none;
    border-radius: 0.5rem;
    padding: 0.7rem 1.5rem;
    cursor: pointer;
    transition: filter 0.15s, transform 0.08s;
}
.person-btn:hover { filter: brightness(1.08); }
.person-btn:active { transform: scale(0.97); }
.picker-alt {
    margin-top: 1.3rem;
    font-size: 0.9rem;
}

.who {
    font-size: 0.92rem;
    color: var(--muted);
}

.person-name {
    color: var(--person-color, var(--fg));
    white-space: nowrap;
}

.person-count {
    font-variant-numeric: tabular-nums;
}

/* ── Theme toggle ───────────────────────────────────────── */

.theme-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    padding: 0;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--card);
    color: var(--fg);
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s, transform 0.05s;
}

.theme-toggle:hover {
    border-color: var(--accent);
    background: var(--accent-soft);
}

.theme-toggle:active {
    transform: scale(0.94);
}

.theme-toggle .icon {
    width: 1.1rem;
    height: 1.1rem;
}

/* Show the icon for the *next* theme — i.e. moon when in light mode,
   sun when in dark mode. */
:root .theme-toggle .icon-sun  { display: none; }
:root .theme-toggle .icon-moon { display: block; }
[data-theme="dark"] .theme-toggle .icon-sun  { display: block; }
[data-theme="dark"] .theme-toggle .icon-moon { display: none; }

/* ── Family picker page ─────────────────────────────────── */

.picker {
    max-width: 460px;
    margin: 4rem auto;
    padding: 0 1.5rem;
    text-align: center;
}

.picker h2 {
    margin-top: 0;
    font-size: 1.8rem;
    font-weight: 600;
}

.picker p {
    color: var(--muted);
    margin-bottom: 2rem;
}

.picker-form {
    display: grid;
    gap: 1rem;
}

/* ── Fancy dropdown ─────────────────────────────────────── */

.dropdown {
    position: relative;
    display: inline-block;
    width: 100%;
}

.dropdown::after {
    content: "";
    position: absolute;
    right: 1.25rem;
    top: 50%;
    width: 0.55rem;
    height: 0.55rem;
    border-right: 2px solid var(--accent);
    border-bottom: 2px solid var(--accent);
    transform: translateY(-70%) rotate(45deg);
    pointer-events: none;
}

.dropdown-select {
    appearance: none;
    -webkit-appearance: none;
    width: 100%;
    padding: 1rem 3rem 1rem 1.25rem;
    font-size: 1rem;
    font-family: inherit;
    color: var(--fg);
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 0.65rem;
    box-shadow: var(--shadow);
    cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.dropdown-select:hover {
    border-color: var(--accent);
}

.dropdown-select:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-soft);
}

/* ── Primary button ─────────────────────────────────────── */

.primary-btn {
    padding: 0.85rem 1.5rem;
    font-size: 1rem;
    font-weight: 600;
    color: white;
    background: var(--accent);
    border: 0;
    border-radius: 0.65rem;
    cursor: pointer;
    transition: background 0.15s, transform 0.05s;
}

.primary-btn:hover {
    background: #5b3d72;
}

.primary-btn:active {
    transform: scale(0.98);
}

.primary-btn.small {
    padding: 0.45rem 0.95rem;
    font-size: 0.9rem;
}

/* ── Access-code gate ──────────────────────────────────── */

.gate {
    max-width: 420px;
    margin: 5rem auto;
    padding: 0 1.5rem;
    text-align: center;
}

.gate-title {
    margin: 0 0 0.3rem;
    font-size: 1.6rem;
    font-weight: 600;
}

.gate-intro {
    color: var(--muted);
    margin: 0 0 2rem;
}

.gate-form {
    display: grid;
    gap: 1rem;
}

.code-input {
    width: 100%;
    padding: 1rem;
    font-size: 1.8rem;
    font-weight: 700;
    text-align: center;
    letter-spacing: 0.4rem;
    text-transform: uppercase;
    font-family: inherit;
    color: var(--fg);
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 0.65rem;
    box-shadow: var(--shadow);
}

.code-input::placeholder {
    letter-spacing: normal;
    font-weight: 400;
    color: var(--muted);
}

.code-input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-soft);
}

.gate-error {
    margin: 0;
    font-size: 0.9rem;
    color: #cf4436;
}

/* ── Concerts page ──────────────────────────────────────── */

.concerts {
    max-width: 980px;
    margin: 0 auto;
    padding: 1.25rem 1.5rem 4rem;
}

.controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
}

.count {
    font-size: 1.15rem;
    font-weight: 600;
}

.filter-form {
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.filter-form label {
    color: var(--muted);
    font-size: 0.9rem;
}

.filter-form .dropdown {
    min-width: 16rem;
}

.filter-form .dropdown-select {
    padding: 0.5rem 2.5rem 0.5rem 0.9rem;
    font-size: 0.9rem;
    border-radius: 0.5rem;
}

.filter-form .dropdown::after {
    right: 0.95rem;
    width: 0.4rem;
    height: 0.4rem;
}

.empty-state {
    color: var(--muted);
    font-style: italic;
    padding: 2rem;
    text-align: center;
}

/* ── Month sections ─────────────────────────────────────── */

.month {
    margin-top: 2rem;
}

.month-heading {
    font-size: 1.4rem;
    color: var(--accent);
    border-bottom: 2px solid var(--accent-soft);
    padding-bottom: 0.3rem;
    margin-bottom: 1rem;
}

/* ── Series pills on each concert ───────────────────────── */

.concert-series {
    margin: 0 0 0.5rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
}

/* Venue flag — shown only when a concert is NOT at the Bridgewater Hall. */
.concert-venue {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    margin: 0 0 0.55rem;
    padding: 0.18rem 0.6rem;
    background: #f7e3cf;
    color: #98480f;
    border-radius: 0.35rem;
    font-size: 0.82rem;
    font-weight: 600;
}
.venue-icon {
    width: 0.95rem;
    height: 0.95rem;
    flex: none;
}

/* Expandable long piece / performer lists. */
.concert-pieces.list-collapsed > li:nth-child(n+5),
.concert-performers.list-collapsed > li:nth-child(n+5) {
    display: none;
}
.more-toggle {
    background: none;
    border: none;
    padding: 0;
    margin: -0.15rem 0 0.6rem;
    color: var(--accent);
    font: inherit;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
}
.more-toggle:hover {
    text-decoration: underline;
}

.tag {
    display: inline-block;
    background: var(--accent-soft);
    color: var(--accent);
    border: 1px solid color-mix(in srgb, var(--accent) 25%, transparent);
    border-radius: 999px;
    padding: 0.05rem 0.6rem;
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.02em;
}

/* ── Concert card ──────────────────────────────────────── */

.concert {
    display: grid;
    grid-template-columns: 160px 1fr 150px;
    grid-template-areas:
        "img body picks"
        "others others others";
    column-gap: 1.5rem;
    row-gap: 1.25rem;
    padding: 1rem 1rem 1.5rem;
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 0.65rem;
    box-shadow: var(--shadow);
    margin-bottom: 0.85rem;
    overflow: hidden;
    transition: background 0.2s, border-color 0.2s;
}

.concert.is-picked {
    background: var(--picked);
    border-color: var(--picked-line);
}

.concert > .concert-img,
.concert > .concert-img--placeholder {
    grid-area: img;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: var(--line-soft);
    border-radius: 0.4rem;
    overflow: hidden;
    margin: 0;
}

.concert > .concert-body  { grid-area: body;  min-width: 0; }
.concert > .concert-picks { grid-area: picks; align-self: start; }

/* The 'Also picked by' strip breaks out of the card padding so it can be
   a true full-width band along the bottom of the card. The negative side
   and bottom margins counter the card's own padding so the strip sits
   flush with the card edges. */
.concert > .concert-others {
    grid-area: others;
    margin: 0 -1rem -1.5rem;
}

.concert-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Brochure-scanned concerts — a 'Scanned from brochure' pill, plus fallback
   thumbnails (orchestra logo, or a name panel) for concerts with no photo. */
.tag--brochure {
    background: #e7b54a;
    color: #3c2c00;
    border-color: color-mix(in srgb, #8a6512 45%, transparent);
}
.concert-img--logo {
    display: flex;
    align-items: center;
    justify-content: center;
}
.concert-img--logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}
.concert-img.concert-img--bbc   { background: #ffffff; }
.concert-img.concert-img--halle { background: #d4a95c; }
.concert-img--name {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 0.55rem;
}
.concert-img--name span {
    color: #fff;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    line-height: 1.2;
    font-size: 0.86rem;
}
.concert-img.concert-img--intl { background: #2f3a45; }

/* ── Concert content ────────────────────────────────────── */

.concert-when {
    color: var(--muted);
    font-size: 0.85rem;
    margin: 0;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.concert-title {
    margin: 0.1rem 0 0.25rem;
    font-size: 1.05rem;
    line-height: 1.3;
}

.concert-sub {
    margin: 0 0 0.5rem;
    color: var(--muted);
    font-style: italic;
    font-size: 0.9rem;
}

.concert-performers,
.concert-pieces {
    margin: 0.3rem 0;
    padding-left: 1.1rem;
    font-size: 0.88rem;
}

.concert-performers li,
.concert-pieces li {
    margin-bottom: 0.05rem;
}

.role {
    color: var(--muted);
    font-style: italic;
    margin-left: 0.2rem;
}

.extra {
    color: var(--muted);
    font-style: italic;
    list-style: none;
    margin-left: -1.1rem;
}

.concert-desc {
    margin: 0.6rem 0 0.3rem;
    color: var(--muted);
    font-size: 0.88rem;
}

.concert-desc summary {
    cursor: pointer;
    color: var(--accent);
    font-weight: 500;
}

.concert-desc[open] summary {
    margin-bottom: 0.4rem;
}

.concert-meta {
    margin: 0.4rem 0 0;
    font-size: 0.85rem;
    color: var(--muted);
    display: flex;
    flex-wrap: wrap;
    gap: 0 1rem;
    align-items: baseline;
}

.price {
    color: var(--fg);
    font-weight: 500;
}

.book-link {
    color: var(--accent);
    text-decoration: none;
}

.book-link:hover {
    text-decoration: underline;
}

/* ── Checkboxes column (far right) ──────────────────────── */

.concert-picks {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.pick {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.55rem;
    font-size: 0.92rem;
    padding: 0.35rem 0.5rem;
    border-radius: 0.4rem;
    cursor: pointer;
    user-select: none;
    border: 1px solid transparent;
    color: var(--fg); /* neutral when unchecked — black in light, white in dark */
    transition: background 0.1s, border-color 0.1s, color 0.1s;
}

.pick:hover {
    background: color-mix(in srgb, var(--person-color, var(--accent)) 12%, transparent);
    border-color: color-mix(in srgb, var(--person-color, var(--accent)) 30%, transparent);
}

.pick.is-checked {
    background: var(--person-color, var(--accent));
    color: white;
    border-color: var(--person-color, var(--accent));
}

.pick.is-checked .pick-name {
    font-weight: 600;
}

.pick input[type="checkbox"] {
    width: 1.05rem;
    height: 1.05rem;
    accent-color: var(--person-color, var(--accent));
    margin: 0;
}

/* Sparkle burst when a name is ticked (added by app.js, in the person's
   colour, then removed once the animation finishes). */
.bw-sparkle {
    position: absolute;
    pointer-events: none;
    background: #ffffff;
    clip-path: polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
    transform: scale(0);
    opacity: 0;
    z-index: 20;
    filter: drop-shadow(0 1px 1.5px rgba(0, 0, 0, 0.45));
    animation: bw-sparkle-pop 600ms ease-out forwards;
}
@keyframes bw-sparkle-pop {
    0%   { transform: scale(0) rotate(0deg);     opacity: 0; }
    35%  { transform: scale(1.15) rotate(50deg); opacity: 1; }
    100% { transform: scale(0) rotate(120deg);   opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
    .bw-sparkle { display: none; }
}

/* ── "Also picked by" — full-width strip below the card ──── */

.concert-others {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    padding: 0.55rem 1rem;
    margin: 0;
    background: var(--others-bg);
    border-top: 1px solid var(--line);
    color: var(--muted);
    font-size: 0.88rem;
    text-align: right;
}

.family-icon {
    width: 1.15rem;
    height: 1.15rem;
    color: var(--accent);
    flex-shrink: 0;
    fill: currentColor;
}

.others-label {
    font-style: italic;
}

.others-names {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.15rem;
}

.others-name {
    color: var(--person-color, var(--fg));
    font-weight: 600;
}

.others-sep {
    color: var(--muted);
}

/* ── Fixed submit bar (full-width, dark, bottom of screen) ── */

.submit-bar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 20;
    padding: 0.85rem 1.5rem;
    background: #18181c;
    color: #efeee9;
    border-top: 1px solid #2a2a2f;
    box-shadow: 0 -6px 18px rgba(0, 0, 0, 0.2);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.submit-bar-label {
    font-size: 0.92rem;
    color: #b9b8b3;
}

.submit-bar-label strong {
    color: #f8f7f4;
    font-weight: 600;
}

.submit-bar-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.booking-link {
    color: #d9c9ee;
    font-size: 0.92rem;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
}

.booking-link:hover {
    text-decoration: underline;
}

.booking-link[hidden] {
    display: none;
}

.submit-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.75rem 1.4rem;
    font-size: 1rem;
    font-weight: 600;
    color: white;
    background: var(--accent);
    border: 0;
    border-radius: 0.55rem;
    cursor: pointer;
    transition: background 0.15s, transform 0.05s;
}

.submit-btn:hover {
    background: #5b3d72;
}

.submit-btn:active {
    transform: scale(0.97);
}

.submit-btn .submit-icon {
    display: none;
    width: 1.1rem;
    height: 1.1rem;
}

.submit-btn .submit-icon svg {
    width: 100%;
    height: 100%;
}

.submit-btn.is-submitted {
    background: #2a8c4a;
}

.submit-btn.is-submitted:hover {
    background: #226d3a;
}

.submit-btn.is-submitted .submit-icon {
    display: inline-flex;
}

/* ── Mobile ──────────────────────────────────────────────── */

@media (max-width: 760px) {
    .concert {
        grid-template-columns: 96px 1fr;
        grid-template-areas:
            "img    body"
            "picks  picks"
            "others others";
        column-gap: 0.85rem;
        padding: 1rem 1rem 1.5rem;
    }
    .concert > .concert-img,
    .concert > .concert-img--placeholder {
        max-width: none;
        margin: 0;
        align-self: start;
    }
    .concert > .concert-picks {
        flex-direction: row;
        flex-wrap: wrap;
        margin-bottom: 0.5rem;
    }
    .concert-others {
        justify-content: flex-start;
        text-align: left;
    }

    .sheet-concert {
        grid-template-columns: 1fr auto;
        grid-template-areas:
            "date tickets"
            "detail detail";
    }
    .sheet-col-date    { grid-area: date; }
    .sheet-col-tickets { grid-area: tickets; }
    .sheet-col-detail  { grid-area: detail; }
}

/* ════════════════════════════════════════════════════════════
   Carol's booking review page (booking.php)
   ════════════════════════════════════════════════════════════ */

.booking {
    max-width: 880px;
    margin: 0 auto;
    padding: 1.5rem 1.5rem 4rem;
}

.booking-summary {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.85rem;
    margin-bottom: 1.5rem;
}

.booking-stat {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 0.65rem;
    box-shadow: var(--shadow);
    padding: 1rem;
    text-align: center;
}

.booking-stat-num {
    display: block;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--accent);
}

.booking-stat-num--cost {
    font-size: 1.05rem;
    line-height: 1.7;
}

.booking-stat-label {
    display: block;
    font-size: 0.8rem;
    color: var(--muted);
    margin-top: 0.2rem;
}

.booking-intro {
    color: var(--muted);
    font-size: 0.95rem;
}

.booking-actions {
    margin: 1rem 0 1.5rem;
}

.booking-actions .primary-btn {
    display: inline-block;
    text-decoration: none;
}

/* ── A concert row on the review page ───────────────────── */

.bk-concert {
    display: flex;
    align-items: flex-start;
    gap: 1.1rem;
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 0.65rem;
    box-shadow: var(--shadow);
    padding: 1rem 1.25rem;
    margin-bottom: 0.7rem;
    transition: background 0.15s, border-color 0.15s;
}

.bk-concert.is-confirmed {
    background: color-mix(in srgb, #2a8c4a 12%, var(--card));
    border-color: color-mix(in srgb, #2a8c4a 45%, var(--line));
}

.bk-photo,
.bk-photo--placeholder {
    width: 88px;
    height: 88px;
    flex-shrink: 0;
    border-radius: 0.45rem;
    overflow: hidden;
    background: var(--line-soft);
    margin: 0;
}

.bk-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.bk-main {
    flex: 1;
    min-width: 0;
}

.bk-line {
    margin: 0.15rem 0;
    font-size: 0.86rem;
    color: var(--muted);
}

.bk-pieces {
    font-style: italic;
}

.bk-meta {
    margin: 0.35rem 0 0.5rem;
    font-size: 0.85rem;
    color: var(--muted);
    display: flex;
    flex-wrap: wrap;
    gap: 0 1rem;
    align-items: baseline;
}

.bk-tickets {
    font-weight: 600;
    color: var(--fg);
}

.bk-attendees {
    margin: 0;
    font-size: 0.9rem;
}

.bk-attendees-label {
    color: var(--muted);
    margin-right: 0.3rem;
}

.att-name {
    color: var(--person-color, var(--fg));
    font-weight: 600;
}

/* ── Floating "printable sheet" button (booking review) ─── */

.floating-sheet-btn {
    position: fixed;
    right: 1.25rem;
    bottom: 1.25rem;
    z-index: 30;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.8rem 1.35rem;
    font-size: 0.95rem;
    font-weight: 600;
    color: white;
    background: var(--accent);
    border-radius: 999px;
    text-decoration: none;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2), 0 2px 5px rgba(0, 0, 0, 0.1);
    transition: background 0.15s, transform 0.05s;
}

.floating-sheet-btn:hover {
    background: #5b3d72;
}

.floating-sheet-btn:active {
    transform: scale(0.97);
}

.floating-sheet-btn[hidden] {
    display: none;
}

/* ── Lock / read-only ──────────────────────────────────── */

.lock-banner {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 1.1rem;
    padding: 0.7rem 1rem;
    background: color-mix(in srgb, #e6a817 16%, var(--card));
    border: 1px solid color-mix(in srgb, #e6a817 45%, var(--line));
    border-radius: 0.55rem;
    font-size: 0.92rem;
}

.lock-icon {
    width: 1.2rem;
    height: 1.2rem;
    flex-shrink: 0;
    fill: currentColor;
    color: #b8842a;
}

.pick.is-locked {
    cursor: default;
    opacity: 0.9;
}

.pick.is-locked:hover {
    background: transparent;
    border-color: transparent;
}

.pick.is-locked.is-checked:hover {
    background: var(--person-color, var(--accent));
    border-color: var(--person-color, var(--accent));
}

.lock-control {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin: 0 0 1.5rem;
    padding: 0.9rem 1.1rem;
    border: 1px solid var(--line);
    border-radius: 0.6rem;
    background: var(--card);
}

.lock-control.is-locked {
    background: color-mix(in srgb, #e6a817 14%, var(--card));
    border-color: color-mix(in srgb, #e6a817 45%, var(--line));
}

.lock-control-text {
    font-size: 0.92rem;
    color: var(--muted);
}

.lock-control-text strong {
    color: var(--fg);
}

.lock-btn {
    flex-shrink: 0;
    padding: 0.65rem 1.15rem;
    font-size: 0.95rem;
    font-weight: 600;
    color: white;
    background: var(--accent);
    border: 0;
    border-radius: 0.5rem;
    cursor: pointer;
    transition: background 0.15s;
}

.lock-btn:hover {
    background: #5b3d72;
}

.lock-btn:disabled {
    opacity: 0.6;
    cursor: default;
}

/* ── Calendar download panel ───────────────────────────── */

.cal-panel {
    margin: 0 0 1.25rem;
    padding: 1rem 1.1rem 1.1rem;
    background: var(--accent-soft);
    border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--line));
    border-radius: 0.65rem;
}

.cal-panel-title {
    margin: 0 0 0.25rem;
    font-size: 1.1rem;
    color: var(--accent);
}

.cal-panel-intro {
    margin: 0 0 0.85rem;
    font-size: 0.88rem;
    color: var(--muted);
}

.cal-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.cal-buttons--major {
    margin-bottom: 0.6rem;
}

.cal-btn {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.55rem 0.9rem;
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 0.5rem;
    text-decoration: none;
    color: var(--fg);
    transition: background 0.12s, box-shadow 0.12s, transform 0.05s;
}

.cal-btn:hover {
    background: color-mix(in srgb, var(--accent) 6%, var(--card));
    box-shadow: var(--shadow);
}

.cal-btn:active {
    transform: scale(0.98);
}

.cal-btn--major {
    flex: 1 1 15rem;
    padding: 0.75rem 1.1rem;
}

.gcal-icon {
    width: 1.6rem;
    height: 1.6rem;
    flex-shrink: 0;
}

.cal-btn--major .gcal-icon {
    width: 2rem;
    height: 2rem;
}

.cal-btn-text {
    display: flex;
    flex-direction: column;
    gap: 0.05rem;
    min-width: 0;
}

.cal-btn-name {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--person-color, var(--fg));
}

.cal-btn--major .cal-btn-name {
    font-size: 1.1rem;
}

.cal-btn-count {
    font-size: 0.78rem;
    color: var(--muted);
}

/* ── Date-context badges (holidays / bank hols / school night) ── */

.concert-context {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    margin: 0 0 0.5rem;
}

.ctx-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.14rem 0.62rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 600;
    border: 1px solid transparent;
}

.ctx-icon {
    width: 0.85rem;
    height: 0.85rem;
    flex-shrink: 0;
}

.ctx-badge--holiday {
    background: color-mix(in srgb, #14854a 14%, var(--card));
    border-color: color-mix(in srgb, #14854a 40%, var(--line));
    color: color-mix(in srgb, #14854a 75%, var(--fg));
}

.ctx-badge--bank {
    background: color-mix(in srgb, #2e6db3 14%, var(--card));
    border-color: color-mix(in srgb, #2e6db3 40%, var(--line));
    color: color-mix(in srgb, #2e6db3 78%, var(--fg));
}

.ctx-badge--night {
    background: color-mix(in srgb, #e6a817 18%, var(--card));
    border-color: color-mix(in srgb, #e6a817 48%, var(--line));
    color: color-mix(in srgb, #b8842a 80%, var(--fg));
}

/* ── Hallé youth ensemble marker ───────────────────────── */

.youth-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0 0 0.5rem;
    padding: 0.2rem 0.6rem;
    background: color-mix(in srgb, #14854a 14%, var(--card));
    border: 1px solid color-mix(in srgb, #14854a 40%, var(--line));
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 600;
    color: color-mix(in srgb, #14854a 75%, var(--fg));
}

.youth-icon {
    width: 0.95rem;
    height: 0.95rem;
    fill: currentColor;
    flex-shrink: 0;
}

/* A performing child — shown instead of a checkbox. */
.pick--performing {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.92rem;
    padding: 0.35rem 0.5rem;
    border: 1px dashed color-mix(in srgb, var(--person-color, var(--accent)) 45%, transparent);
    border-radius: 0.4rem;
    color: var(--person-color, var(--fg));
}

.perform-icon {
    width: 0.95rem;
    height: 0.95rem;
    fill: currentColor;
    flex-shrink: 0;
}

.perform-note {
    margin-left: auto;
    font-size: 0.72rem;
    font-style: italic;
    color: var(--muted);
}

/* ── "Will book" confirm toggle ─────────────────────────── */

.bk-confirm {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
    align-self: center;
    font-size: 0.95rem;
    font-weight: 600;
    padding: 0.6rem 0.9rem;
    border: 1px solid var(--line);
    border-radius: 0.5rem;
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
}

.bk-confirm:hover {
    border-color: #2a8c4a;
}

.bk-concert.is-confirmed .bk-confirm {
    background: #2a8c4a;
    border-color: #2a8c4a;
    color: white;
}

.bk-confirm-input {
    width: 1.1rem;
    height: 1.1rem;
    accent-color: #2a8c4a;
    margin: 0;
}

/* ════════════════════════════════════════════════════════════
   Printable booking sheet (booking-sheet.php)
   ════════════════════════════════════════════════════════════ */

.sheet-body {
    background: var(--bg);
}

.sheet-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    max-width: 800px;
    margin: 0 auto;
    padding: 1.25rem 1.5rem 0;
}

.sheet {
    max-width: 800px;
    margin: 0 auto;
    padding: 1.5rem;
}

.sheet-head {
    border-bottom: 2px solid var(--fg);
    padding-bottom: 0.6rem;
    margin-bottom: 1.25rem;
}

.sheet-head h1 {
    margin: 0;
    font-size: 1.4rem;
}

.sheet-sub {
    margin: 0.3rem 0 0;
    color: var(--muted);
    font-size: 0.9rem;
}

.sheet-concert {
    display: grid;
    grid-template-columns: 128px 1fr 160px;
    gap: 1rem;
    padding: 0.7rem 0;
    border-bottom: 1px solid var(--line);
    break-inside: avoid;
}

.sheet-col-detail {
    min-width: 0;
}

.sheet-col-tickets {
    text-align: right;
}

.sheet-date-big {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    color: var(--fg);
    line-height: 1.25;
    white-space: nowrap;
}

.sheet-date-day {
    margin: 0.1rem 0 0;
    font-size: 0.74rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

.sheet-series {
    margin: 0 0 0.05rem;
    font-size: 0.7rem;
    color: var(--accent);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.sheet-title {
    margin: 0 0 0.15rem;
    font-size: 1.05rem;
}

.sheet-perf {
    margin: 0.05rem 0;
    font-size: 0.78rem;
}

.sheet-pieces {
    margin: 0.05rem 0;
    font-size: 0.78rem;
    font-style: italic;
    color: var(--muted);
}

.sheet-tickets-num {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 700;
    white-space: nowrap;
}

.sheet-for {
    margin: 0.15rem 0 0;
    font-size: 0.78rem;
    color: var(--muted);
}

.sheet-price {
    margin: 0.15rem 0 0;
    font-size: 0.78rem;
    color: var(--muted);
    white-space: nowrap;
}

.sheet-total {
    margin-top: 1.25rem;
    padding-top: 0.75rem;
    border-top: 2px solid var(--fg);
    font-size: 1rem;
}

@media print {
    .no-print { display: none !important; }
    body, .sheet-body {
        background: white;
        color: black;
    }
    .sheet {
        max-width: none;
        padding: 0;
    }
    .sheet-head,
    .sheet-total {
        border-color: black;
    }
    .sheet-concert {
        border-bottom-color: #bbb;
    }
}
