/* ============================================================
   Light theme — applied to pages with body.page-light
   Layered on top of style.css; overrides where needed.
   ============================================================ */

:root {
    --light-bg:       #FAF7EF;   /* warm cream */
    --light-surface:  #FFFFFF;
    --light-text:     #14110F;
    --light-text-muted: #6B6660;
    --light-border:   #ECE5D5;
    --light-border-strong: #D9CFB8;
    --accent-gold:    #E0A800;
    --accent-gold-soft: #FFD166;
    --shadow-card:    0 1px 2px rgba(20, 17, 15, 0.04), 0 4px 14px rgba(20, 17, 15, 0.06);
    --shadow-card-hover: 0 2px 6px rgba(20, 17, 15, 0.08), 0 12px 32px rgba(20, 17, 15, 0.10);
}

body.page-light {
    background: var(--light-bg);
    color: var(--light-text);
}
body.page-light .page-bg {
    background: linear-gradient(180deg, #FFFCF4 0%, var(--light-bg) 60%);
    /* Override whatever dark gradient style.css applied */
    opacity: 1;
}

/* --- Header (light) --------------------------------------- */
body.page-light .site-header,
body.page-light .header-shell {
    background: rgba(255, 252, 244, 0.92);
    border-bottom: 0;
}
body.page-light .site-header {
    backdrop-filter: saturate(140%) blur(8px);
    border-bottom: 1px solid var(--light-border);
}
body.page-light .site-nav a,
body.page-light .header-link {
    color: var(--light-text);
    opacity: 0.8;
}
body.page-light .site-nav a:hover,
body.page-light .header-link:hover {
    opacity: 1;
}
body.page-light .menu-toggle span {
    background: var(--light-text);
}
body.page-light .menu-toggle {
    background: var(--light-surface);
    border: 1px solid var(--light-border);
}

body.page-light .header-actions .button--header-secondary {
    color: var(--light-text);
    border-color: rgba(20, 17, 15, 0.12);
    background: rgba(255, 255, 255, 0.72);
    box-shadow: none;
}

body.page-light .header-actions .button--header-secondary:hover,
body.page-light .header-actions .button--header-secondary:focus-visible {
    background: rgba(255, 255, 255, 0.96);
    border-color: rgba(20, 17, 15, 0.22);
}

body.page-light .header-actions .button--sun {
    box-shadow: 0 8px 22px rgba(224, 168, 0, 0.16);
}

@media (max-width: 860px) {
    body.page-light .header-menu {
        background: rgba(255, 252, 244, 0.98);
        border-top: 1px solid var(--light-border);
        border-bottom: 1px solid var(--light-border);
        box-shadow: 0 18px 34px rgba(20, 17, 15, 0.10);
    }

    body.page-light .header-menu .site-nav a,
    body.page-light .header-menu .header-link {
        color: var(--light-text);
        opacity: 1;
    }

    body.page-light .header-menu .site-nav a {
        padding: 0.35rem 0;
    }

    body.page-light .header-actions {
        padding-top: 0.35rem;
        border-top: 1px solid var(--light-border);
    }
}

/* --- Hero (light, type-driven, no diamonds) --------------- */
body.page-light .calendar-hero {
    padding: clamp(3.5rem, 8vw, 6rem) 0 clamp(2rem, 4vw, 3rem);
    text-align: left;
    color: var(--light-text);
}
body.page-light .calendar-hero .eyebrow {
    color: var(--light-text-muted);
    letter-spacing: 0.18em;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 1rem;
    display: inline-block;
}
body.page-light .calendar-hero .eyebrow::before {
    content: "◆ ";
    color: var(--accent-gold);
    margin-right: 0.4rem;
}
body.page-light .calendar-hero h1 {
    font-family: "BagossCondensedFont", sans-serif;
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    line-height: 1.05;
    margin: 0 0 1rem;
    color: var(--light-text);
    font-weight: 700;
    letter-spacing: -0.02em;
}
body.page-light .calendar-hero h1 .accent {
    font-family: "Pacifico", cursive;
    font-weight: 400;
    color: var(--accent-gold);
    display: inline-block;
    transform: rotate(-3deg);
}
body.page-light .calendar-hero p {
    max-width: 38rem;
    font-size: 1.1rem;
    line-height: 1.55;
    color: var(--light-text-muted);
}

/* --- Filter bar ------------------------------------------- */
body.page-light .calendar-filters {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    padding: 1.25rem;
    background: var(--light-surface);
    border: 1px solid var(--light-border);
    border-radius: 1rem;
    box-shadow: var(--shadow-card);
    margin: 2rem 0 0;
}
@media (max-width: 800px) {
    body.page-light .calendar-filters { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
    body.page-light .calendar-filters { grid-template-columns: 1fr; }
}
body.page-light .calendar-filters label {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--light-text-muted);
}
body.page-light .calendar-filters select {
    appearance: none;
    border: 1px solid var(--light-border-strong);
    background: var(--light-surface);
    color: var(--light-text);
    border-radius: 0.55rem;
    padding: 0.65rem 2rem 0.65rem 0.75rem;
    font-family: inherit;
    font-size: 0.95rem;
    background-image: linear-gradient(45deg, transparent 50%, var(--light-text) 50%),
                      linear-gradient(135deg, var(--light-text) 50%, transparent 50%);
    background-position: calc(100% - 1.1rem) 50%, calc(100% - 0.7rem) 50%;
    background-size: 0.4rem 0.4rem, 0.4rem 0.4rem;
    background-repeat: no-repeat;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
body.page-light .calendar-filters select:hover {
    border-color: var(--accent-gold);
}
body.page-light .calendar-filters select:focus {
    outline: none;
    border-color: var(--accent-gold);
    box-shadow: 0 0 0 3px rgba(224, 168, 0, 0.18);
}
body.page-light .calendar-filters-actions {
    grid-column: 1 / -1;
    display: flex;
    justify-content: flex-end;
    gap: 1rem;
    align-items: center;
    padding-top: 0.25rem;
    border-top: 1px solid var(--light-border);
    margin-top: 0.25rem;
    padding-top: 0.85rem;
}
body.page-light .calendar-filters-actions .results-count {
    margin-right: auto;
    font-size: 0.85rem;
    color: var(--light-text-muted);
    font-weight: 500;
}
body.page-light .calendar-filters-actions a.reset {
    font-size: 0.85rem;
    color: var(--light-text-muted);
    text-decoration: underline;
}
body.page-light .calendar-filters-actions a.reset:hover {
    color: var(--light-text);
}

/* --- Month navigation strip ------------------------------- */
body.page-light .calendar-monthnav {
    background: rgba(255, 252, 244, 0.95);
    backdrop-filter: saturate(140%) blur(8px);
    border-bottom: 1px solid var(--light-border);
    position: sticky;
    top: var(--header-height, 64px);
    z-index: 20;
    margin-top: 1.5rem;
}
body.page-light .calendar-monthnav__track {
    display: flex;
    gap: 0.5rem;
    overflow-x: auto;
    padding: 0.85rem 0;
    scroll-behavior: smooth;
    scrollbar-width: thin;
    scrollbar-color: var(--light-border-strong) transparent;
}
body.page-light .calendar-monthnav__track::-webkit-scrollbar { height: 6px; }
body.page-light .calendar-monthnav__track::-webkit-scrollbar-thumb {
    background: var(--light-border-strong);
    border-radius: 3px;
}
body.page-light .calendar-monthnav__pill {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex-shrink: 0;
    padding: 0.45rem 0.85rem;
    background: var(--light-surface);
    border: 1px solid var(--light-border);
    border-radius: 999px;
    color: var(--light-text);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 600;
    transition: border-color 0.12s ease, background 0.12s ease, transform 0.12s ease;
}
body.page-light .calendar-monthnav__pill:hover {
    border-color: var(--accent-gold);
    transform: translateY(-1px);
}
body.page-light .calendar-monthnav__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.4rem;
    height: 1.4rem;
    padding: 0 0.4rem;
    border-radius: 999px;
    background: #F4EFE2;
    color: #6B5B2E;
    font-size: 0.7rem;
    font-weight: 700;
}

html { scroll-behavior: smooth; scroll-padding-top: calc(var(--header-height, 64px) + 4rem); }

/* --- Month sections --------------------------------------- */
body.page-light .calendar-month {
    padding-top: 2.5rem;
    scroll-margin-top: 5rem;
}
body.page-light .calendar-month:first-of-type {
    padding-top: 1.5rem;
}
body.page-light .calendar-month__head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--light-border);
}
body.page-light .calendar-month__title {
    font-family: "BagossCondensedFont", sans-serif;
    font-size: clamp(1.4rem, 3vw, 1.8rem);
    margin: 0;
    color: var(--light-text);
    font-weight: 700;
    letter-spacing: -0.01em;
}
body.page-light .calendar-month__count {
    font-size: 0.85rem;
    color: var(--light-text-muted);
    font-weight: 600;
}

/* --- Festival cards --------------------------------------- */
body.page-light .calendar-results {
    padding: 0 0 4rem;
}
body.page-light .calendar-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 1.25rem;
}
body.page-light .festival-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--light-surface);
    border: 1px solid var(--light-border);
    border-radius: 0.85rem;
    overflow: hidden;
    color: var(--light-text);
    text-decoration: none;
    box-shadow: var(--shadow-card);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
body.page-light .festival-card .fc-image {
    aspect-ratio: 16 / 9;
    background-color: #F0EBDC;
    overflow: hidden;
    border-bottom: 1px solid var(--light-border);
}
body.page-light .festival-card .fc-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
/* Image failed to load — collapse the slot */
body.page-light .festival-card .fc-image--broken {
    aspect-ratio: auto;
    height: 0;
    border: 0;
}
body.page-light .festival-card .fc-body {
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    padding: 1.4rem 1.25rem 1.25rem;
    flex: 1;
}
body.page-light .festival-card:not(.has-image) .fc-body {
    /* Add a subtle top accent bar when there is no image, to keep visual rhythm */
    border-top: 3px solid var(--accent-gold-soft);
}
body.page-light .festival-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-card-hover);
    border-color: var(--light-border-strong);
}
body.page-light .festival-card.is-featured {
    border-color: var(--accent-gold);
    box-shadow: 0 0 0 1px var(--accent-gold) inset, var(--shadow-card);
}
body.page-light .festival-card.is-featured::before {
    content: "★ Featured";
    position: absolute;
    top: 0.7rem;
    right: 0.85rem;
    font-size: 0.68rem;
    font-weight: 800;
    color: var(--accent-gold);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

body.page-light .fc-date {
    font-family: "BagossCondensedFont", sans-serif;
    font-size: 0.92rem;
    font-weight: 700;
    color: var(--accent-gold);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}
body.page-light .fc-name {
    font-family: "BagossCondensedFont", sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1.25;
    margin: 0;
    color: var(--light-text);
    letter-spacing: -0.01em;
}
body.page-light .fc-where {
    font-size: 0.92rem;
    color: var(--light-text-muted);
    display: flex;
    align-items: baseline;
    gap: 0.4rem;
}
body.page-light .fc-flag {
    font-size: 1.1rem;
}
body.page-light .fc-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-top: auto;
    padding-top: 0.85rem;
    border-top: 1px solid var(--light-border);
}
body.page-light .fc-tag {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.28rem 0.55rem;
    border-radius: 0.4rem;
    background: #F4EFE2;
    color: #6B5B2E;
}
body.page-light .fc-tag--type   { background: #FFF1C5; color: #7A5A00; }
body.page-light .fc-tag--style  { background: #DDF1FA; color: #1B4F66; }
body.page-light .fc-tag--badge  { background: #ECE0FF; color: #4A2E8F; }

body.page-light .fc-balance {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    font-weight: 700;
    margin-top: 0.1rem;
}
body.page-light .fc-balance::before {
    content: "";
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: currentColor;
}
body.page-light .fc-balance--balanced  { color: #2E8B57; }
body.page-light .fc-balance--leaders   { color: #C8761B; }
body.page-light .fc-balance--followers { color: #C8761B; }

body.page-light .fc-powered {
    font-size: 0.68rem;
    color: var(--light-text-muted);
    margin-top: 0.4rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-weight: 600;
}

/* --- Empty state ----------------------------------------- */
body.page-light .calendar-empty {
    text-align: center;
    padding: 4rem 1rem;
    background: var(--light-surface);
    border: 1px dashed var(--light-border-strong);
    border-radius: 1rem;
    margin: 2rem 0;
    color: var(--light-text-muted);
}
body.page-light .calendar-empty h2 {
    font-family: "BagossCondensedFont", sans-serif;
    margin: 0 0 0.5rem;
    color: var(--light-text);
}

/* --- Pagination ------------------------------------------- */
body.page-light .calendar-pagination {
    display: flex;
    justify-content: center;
    margin: 2rem 0 4rem;
}
body.page-light .calendar-pagination svg {
    width: 1.1rem;
    height: 1.1rem;
}
body.page-light .calendar-pagination a,
body.page-light .calendar-pagination span {
    color: var(--light-text);
}

/* --- Footer (kept dark for visual anchor on light pages) - */
/* No overrides needed — the existing dark footer provides a clear page end. */

/* ============================================================
   Marketing page (/for-organizers) — body has .page-home + .page-light
   ============================================================ */

body.page-light.page-home .hero-section {
    background: transparent;
    color: var(--light-text);
}
/* Soften the colorful diamond shapes against light bg */
body.page-light.page-home .hero-shape {
    opacity: 0.55;
    mix-blend-mode: multiply;
    filter: blur(1px);
}
body.page-light.page-home .hero-noise {
    opacity: 0.15;
    mix-blend-mode: multiply;
}

body.page-light.page-home .eyebrow {
    color: var(--light-text-muted);
    letter-spacing: 0.18em;
    font-weight: 700;
}
body.page-light.page-home .eyebrow::before {
    content: "◆ ";
    color: var(--accent-gold);
    margin-right: 0.4rem;
}
body.page-light.page-home .eyebrow--ink {
    color: var(--light-text-muted);
}
body.page-light.page-home .eyebrow--ink::before {
    content: "";
    margin: 0;
}

body.page-light.page-home h1,
body.page-light.page-home h2,
body.page-light.page-home h3 {
    color: var(--light-text);
}
body.page-light.page-home .hero-lede,
body.page-light.page-home .section-text {
    color: var(--light-text-muted);
}
body.page-light.page-home .hero-word {
    color: var(--accent-gold);
}

/* Hero facts row */
body.page-light.page-home .hero-facts .fact-card {
    background: var(--light-surface);
    border: 1px solid var(--light-border);
    box-shadow: var(--shadow-card);
}
body.page-light.page-home .hero-facts .fact-card h2 {
    color: var(--light-text);
}
body.page-light.page-home .hero-facts .fact-card p {
    color: var(--light-text-muted);
}

/* Mockup workspace */
body.page-light.page-home .product-mockup {
    background: linear-gradient(180deg, #FFFFFF, #F4EFE2);
    border: 1px solid var(--light-border);
    box-shadow: var(--shadow-card-hover);
}

/* Sections — neutralize the dark/cream/paper alternation in light mode.
   Kept .section--ink and .demo-section dark on purpose, as visual punctuation
   and to make conversion CTAs stand out. */
body.page-light.page-home .section--paper,
body.page-light.page-home .section--cream {
    background: transparent;
    color: var(--light-text);
}
body.page-light.page-home .section--ink {
    background: #14110F;
    color: #F8F4E9;
    border-radius: 1.5rem;
    margin: 3rem 1rem;
}
body.page-light.page-home .section--ink h2,
body.page-light.page-home .section--ink h3 {
    color: #F8F4E9;
}
body.page-light.page-home .section--ink .section-text {
    color: rgba(248, 244, 233, 0.78);
}
body.page-light.page-home .section--ink .eyebrow {
    color: var(--accent-gold-soft);
}
body.page-light.page-home .section--ink .eyebrow::before {
    content: "";
    margin: 0;
}

body.page-light.page-home .feature-card {
    color: #F8F4E9;
}

/* Cards adapt to light surface */
body.page-light.page-home .quote-card,
body.page-light.page-home .comparison-card,
body.page-light.page-home .workflow-card,
body.page-light.page-home .workflow-highlight {
    background: var(--light-surface);
    border: 1px solid var(--light-border);
    color: var(--light-text);
    box-shadow: var(--shadow-card);
}
body.page-light.page-home .comparison-card h3,
body.page-light.page-home .workflow-card h3,
body.page-light.page-home .workflow-highlight h3 {
    color: var(--light-text);
}
body.page-light.page-home .comparison-list li,
body.page-light.page-home .workflow-card p {
    color: var(--light-text-muted);
}
body.page-light.page-home .comparison-kicker,
body.page-light.page-home .workflow-step {
    color: var(--accent-gold);
}
body.page-light.page-home .tag-board span {
    background: #F4EFE2;
    color: #6B5B2E;
    border: 1px solid var(--light-border);
}

/* FAQ */
body.page-light.page-home .faq-item {
    background: var(--light-surface);
    border: 1px solid var(--light-border);
    box-shadow: var(--shadow-card);
}
body.page-light.page-home .faq-item summary {
    color: var(--light-text);
}
body.page-light.page-home .faq-answer p {
    color: var(--light-text-muted);
}

/* Demo / booking — kept dark on purpose, as conversion CTA */
body.page-light.page-home .demo-section {
    background: #14110F;
    color: #F8F4E9;
    border-radius: 1.5rem;
    margin: 3rem 1rem;
}
body.page-light.page-home .demo-section h2 {
    color: #F8F4E9;
}
body.page-light.page-home .demo-section .section-text,
body.page-light.page-home .demo-section .section-text--light {
    color: rgba(248, 244, 233, 0.8);
}
body.page-light.page-home .demo-section .eyebrow {
    color: var(--accent-gold-soft);
}
body.page-light.page-home .demo-section .eyebrow::before {
    content: "";
    margin: 0;
}

/* ============================================================
   Inner pages (privacy, thanks)
   ============================================================ */

body.page-light.page-inner .inner-hero h1,
body.page-light.page-inner h1,
body.page-light.page-inner h2 {
    color: var(--light-text);
}
body.page-light.page-inner .inner-hero {
    padding: 0;
    background: linear-gradient(180deg, #FFFCF4 0%, var(--light-bg) 100%);
    color: var(--light-text);
}
body.page-light.page-inner .inner-hero__shell,
body.page-light.page-inner .thank-you-shell {
    padding-inline: var(--page-gutter);
    padding-block: clamp(3rem, 6.5vw, 5rem) clamp(3rem, 5.5vw, 4.5rem);
}
body.page-light.page-inner .inner-hero h1 {
    max-width: 58rem;
    color: var(--light-text);
    font-size: clamp(2.9rem, 6.4vw, 5.35rem);
    line-height: 1.02;
}
body.page-light.page-inner .inner-hero .eyebrow,
body.page-light.page-inner .inner-hero .hero-lede {
    color: var(--light-text-muted);
}
body.page-light.page-inner .inner-hero .eyebrow::before {
    content: "";
    background: var(--accent-gold);
}
body.page-light.page-inner .inner-hero .hero-lede {
    max-width: 46rem;
}

body.page-light.page-inner .claim-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.72fr);
    gap: clamp(1.25rem, 3vw, 2rem);
    align-items: stretch;
}

body.page-light.page-inner .claim-hero-card {
    border: 1px solid var(--light-border);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(250, 244, 227, 0.96) 100%);
    box-shadow: var(--shadow-card);
}

body.page-light.page-inner .claim-hero-card img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    display: block;
}

body.page-light.page-inner .claim-hero-card__body,
body.page-light.page-inner .claim-hero-card__header {
    padding: 1.15rem 1.15rem 1.25rem;
}

body.page-light.page-inner .claim-hero-card__body p,
body.page-light.page-inner .claim-hero-card__header p {
    margin: 0;
    color: var(--accent-gold);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

body.page-light.page-inner .claim-hero-card__body h2,
body.page-light.page-inner .claim-hero-card__header h2 {
    margin: 0.5rem 0 0;
    font-size: 1.45rem;
    line-height: 1.12;
}

body.page-light.page-inner .claim-hero-card__body ul {
    display: grid;
    gap: 0.55rem;
    margin: 0.9rem 0 0;
    padding: 0;
    list-style: none;
    color: var(--light-text-muted);
}

body.page-light.page-inner .claim-hero-card__header span {
    display: block;
    margin-top: 0.75rem;
    color: var(--light-text-muted);
    line-height: 1.5;
}

body.page-light.page-inner .claim-gallery {
    display: grid;
    gap: 0.8rem;
    padding: 0 1rem 1rem;
}

body.page-light.page-inner .claim-gallery__item {
    display: grid;
    grid-template-columns: 104px minmax(0, 1fr);
    gap: 0.85rem;
    align-items: center;
    color: var(--light-text);
}

body.page-light.page-inner .claim-gallery__item img {
    aspect-ratio: 1;
    border-radius: 0.75rem;
}

body.page-light.page-inner .claim-gallery__item span {
    min-width: 0;
}

body.page-light.page-inner .claim-gallery__item strong,
body.page-light.page-inner .claim-gallery__item small {
    display: block;
}

body.page-light.page-inner .claim-gallery__item strong {
    font-family: "BagossCondensedFont", sans-serif;
    font-size: 1rem;
    line-height: 1.15;
}

body.page-light.page-inner .claim-gallery__item small {
    margin-top: 0.28rem;
    color: var(--light-text-muted);
    line-height: 1.45;
}

@media (max-width: 640px) {
    body.page-light.page-inner .inner-hero__shell,
    body.page-light.page-inner .thank-you-shell {
        padding-inline: 1rem;
        padding-block: 2.35rem 2.8rem;
    }

    body.page-light.page-inner .inner-hero h1 {
        font-size: clamp(2.05rem, 10vw, 2.75rem);
    }
}

@media (max-width: 920px) {
    body.page-light.page-inner .claim-hero-grid {
        grid-template-columns: 1fr;
        align-items: start;
    }
}

body.page-light.page-inner .section--paper {
    background: transparent;
}
body.page-light.page-inner .legal-card,
body.page-light.page-inner .legal-footer-card,
body.page-light.page-inner .thank-you-card {
    background: var(--light-surface);
    border: 1px solid var(--light-border);
    box-shadow: var(--shadow-card);
    color: var(--light-text);
}
body.page-light.page-inner .legal-card p,
body.page-light.page-inner .thank-you-card p {
    color: var(--light-text-muted);
}

/* ============================================================
   Festival detail pages
   ============================================================ */

body.page-festival-detail .festival-detail {
    background: var(--light-bg);
    color: var(--light-text);
}

body.page-festival-detail .festival-hero {
    padding: clamp(2.5rem, 5.5vw, 4.5rem) 0 clamp(2rem, 4.5vw, 3.5rem);
    background:
        radial-gradient(circle at 82% 12%, rgba(255, 209, 102, 0.28), transparent 28rem),
        linear-gradient(180deg, #FFFCF4 0%, var(--light-bg) 100%);
}

body.page-festival-detail .festival-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.72fr);
    align-items: center;
    gap: clamp(2rem, 5vw, 5rem);
}

body.page-festival-detail .festival-back {
    display: inline-flex;
    width: max-content;
    margin-bottom: 1.2rem;
    color: var(--light-text-muted);
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

body.page-festival-detail .festival-back:hover {
    color: var(--light-text);
}

body.page-festival-detail .festival-hero .eyebrow {
    margin-bottom: 1rem;
    color: var(--light-text-muted);
}

body.page-festival-detail .festival-hero .eyebrow::before {
    content: "◆ ";
    color: var(--accent-gold);
    margin-right: 0.4rem;
}

body.page-festival-detail .festival-hero h1 {
    max-width: 64rem;
    margin: 0;
    color: var(--light-text);
    font-family: "BagossCondensedFont", sans-serif;
    font-size: clamp(3rem, 6.6vw, 6.5rem);
    line-height: 0.94;
    letter-spacing: 0;
}

body.page-festival-detail .festival-tagline {
    max-width: 44rem;
    margin: 1rem 0 0;
    color: var(--light-text-muted);
    font-size: clamp(1.05rem, 1.5vw, 1.25rem);
    line-height: 1.55;
}

body.page-festival-detail .festival-quick-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1.35rem;
}

body.page-festival-detail .festival-quick-meta span,
body.page-festival-detail .festival-tags span,
body.page-festival-detail .festival-chip-list span {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    min-height: 2.2rem;
    padding: 0.48rem 0.75rem;
    border: 1px solid var(--light-border);
    border-radius: 999px;
    background: var(--light-surface);
    color: var(--light-text);
    font-size: 0.82rem;
    font-weight: 800;
}

body.page-festival-detail .festival-quick-meta span svg {
    width: 0.95rem;
    height: 0.95rem;
    flex: 0 0 auto;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.8;
}

body.page-festival-detail .festival-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 1rem;
}

body.page-festival-detail .festival-tags span {
    background: #FFF1C5;
    border-color: #F0D98B;
    color: #6D5305;
}

body.page-festival-detail .festival-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    margin-top: 1.7rem;
}

body.page-festival-detail .festival-actions .button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
}

body.page-festival-detail .festival-actions .button svg {
    width: 1rem;
    height: 1rem;
    flex: 0 0 auto;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.8;
}

body.page-festival-detail .festival-media {
    position: relative;
    min-width: 0;
    margin: 0;
    overflow: hidden;
    border: 1px solid var(--light-border);
    border-radius: 1rem;
    background: var(--light-surface);
    box-shadow: var(--shadow-card-hover);
}

body.page-festival-detail .festival-media.has-image {
    aspect-ratio: 4 / 3;
}

body.page-festival-detail .festival-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

body.page-festival-detail .festival-media.is-empty {
    min-height: 24rem;
    display: grid;
    place-items: center;
    background:
        linear-gradient(135deg, rgba(255, 209, 102, 0.34), rgba(140, 102, 199, 0.14)),
        var(--light-surface);
}

body.page-festival-detail .festival-media__placeholder {
    display: grid;
    gap: 0.1rem;
    text-align: center;
    color: var(--light-text);
}

body.page-festival-detail .festival-media__placeholder span {
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.18em;
}

body.page-festival-detail .festival-media__placeholder strong {
    font-family: "BagossCondensedFont", sans-serif;
    font-size: clamp(5rem, 13vw, 8rem);
    line-height: 0.9;
}

body.page-festival-detail .festival-media figcaption {
    position: absolute;
    left: 0.9rem;
    right: 0.9rem;
    bottom: 0.9rem;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 0.85rem;
    border: 1px solid rgba(255, 255, 255, 0.55);
    border-radius: 0.75rem;
    background: rgba(20, 17, 15, 0.72);
    color: #fff;
    font-size: 0.86rem;
    font-weight: 800;
    backdrop-filter: blur(10px);
}

body.page-festival-detail .festival-body {
    padding: clamp(2rem, 5vw, 4rem) 0;
}

body.page-festival-detail .festival-body__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    align-items: start;
    gap: clamp(1.3rem, 3vw, 2rem);
}

body.page-festival-detail .festival-main {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

body.page-festival-detail .festival-panel,
body.page-festival-detail .festival-side-card,
body.page-festival-detail .festival-powered,
body.page-festival-detail .festival-related-card {
    border: 1px solid var(--light-border);
    border-radius: 0.9rem;
    background: var(--light-surface);
    box-shadow: var(--shadow-card);
}

body.page-festival-detail .festival-panel,
body.page-festival-detail .festival-side-card,
body.page-festival-detail .festival-powered {
    padding: clamp(1.15rem, 2vw, 1.5rem);
}

body.page-festival-detail .festival-panel--wide {
    grid-column: 1 / -1;
}

body.page-festival-detail .festival-panel--balance {
    border-color: rgba(106, 213, 44, 0.42);
    background: linear-gradient(180deg, #FFFFFF 0%, #F3FFE7 100%);
}

body.page-festival-detail .festival-panel__kicker {
    margin: 0 0 0.6rem;
    color: var(--accent-gold);
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.14em;
}

body.page-festival-detail .festival-panel h2,
body.page-festival-detail .festival-side-card h2,
body.page-festival-detail .festival-related__head h2 {
    margin: 0;
    color: var(--light-text);
    font-family: "BagossCondensedFont", sans-serif;
    font-size: clamp(1.45rem, 2.6vw, 2rem);
    line-height: 1.08;
}

body.page-festival-detail .festival-panel p,
body.page-festival-detail .festival-powered p {
    margin: 0.8rem 0 0;
    color: var(--light-text-muted);
    line-height: 1.7;
}

body.page-festival-detail .festival-copy-stack {
    display: grid;
    gap: 0.95rem;
    margin-top: 0.8rem;
    color: var(--light-text-muted);
    line-height: 1.7;
}

body.page-festival-detail .festival-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.95rem;
}

body.page-festival-detail .festival-data-list {
    display: grid;
    gap: 0.85rem;
    margin: 1rem 0 0;
}

body.page-festival-detail .festival-data-list div {
    display: grid;
    gap: 0.15rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid var(--light-border);
}

body.page-festival-detail .festival-data-list div:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

body.page-festival-detail .festival-data-list dt {
    color: var(--light-text-muted);
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

body.page-festival-detail .festival-data-list dd {
    margin: 0;
    color: var(--light-text);
    font-weight: 800;
}

body.page-festival-detail .festival-sidebar {
    position: sticky;
    top: calc(var(--header-height) + 1rem);
    display: grid;
    gap: 1rem;
}

body.page-festival-detail .festival-link-stack {
    display: grid;
    gap: 0.6rem;
    margin-top: 1rem;
}

body.page-festival-detail .festival-link-stack a {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.8rem 0;
    border-bottom: 1px solid var(--light-border);
    color: var(--light-text);
    font-weight: 900;
}

body.page-festival-detail .festival-link-stack a::after {
    content: ">";
    color: var(--accent-gold);
}

body.page-festival-detail .festival-link-stack a:last-child {
    border-bottom: 0;
}

body.page-festival-detail .festival-powered {
    background: var(--light-text);
    color: #fff;
}

body.page-festival-detail .festival-powered strong {
    display: block;
    font-family: "BagossCondensedFont", sans-serif;
    font-size: 1.25rem;
    line-height: 1.05;
}

body.page-festival-detail .festival-powered p {
    color: rgba(255, 255, 255, 0.75);
}

body.page-festival-detail .festival-related {
    padding: 0 0 clamp(3rem, 6vw, 5rem);
}

body.page-festival-detail .festival-related__head {
    margin-bottom: 1rem;
}

body.page-festival-detail .festival-related__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

body.page-festival-detail .festival-related-card {
    display: grid;
    gap: 0.5rem;
    padding: 1.2rem;
    color: var(--light-text);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

body.page-festival-detail .festival-related-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-card-hover);
}

body.page-festival-detail .festival-related-card span,
body.page-festival-detail .festival-related-card small {
    color: var(--light-text-muted);
    font-size: 0.8rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

body.page-festival-detail .festival-related-card strong {
    font-family: "BagossCondensedFont", sans-serif;
    font-size: 1.35rem;
    line-height: 1.08;
}

@media (max-width: 980px) {
    body.page-festival-detail .festival-hero__grid,
    body.page-festival-detail .festival-body__grid {
        grid-template-columns: 1fr;
    }

    body.page-festival-detail .festival-sidebar {
        position: static;
    }

    body.page-festival-detail .festival-related__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    body.page-festival-detail .festival-hero {
        padding: 2rem 0 1.5rem;
    }

    body.page-festival-detail .festival-hero h1 {
        font-size: clamp(2.45rem, 13vw, 3.55rem);
        line-height: 0.98;
    }

    body.page-festival-detail .festival-main {
        grid-template-columns: 1fr;
    }

    body.page-festival-detail .festival-media.has-image {
        aspect-ratio: 16 / 11;
    }

    body.page-festival-detail .festival-actions .button {
        width: 100%;
    }
}

/* ============================================================
   Organizer claim and edit forms
   ============================================================ */

body.page-claim .claim-shell {
    width: 100%;
    margin-inline: 0;
}

body.page-claim .claim-page-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.72fr);
    gap: clamp(1.15rem, 3vw, 2.15rem);
    align-items: start;
}

body.page-claim .claim-form {
    padding: clamp(1.2rem, 2.5vw, 2rem);
    border: 1px solid var(--light-border);
    border-radius: 1rem;
    background: var(--light-surface);
    box-shadow: var(--shadow-card);
}

body.page-claim .form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

body.page-claim .form-span {
    grid-column: 1 / -1;
}

body.page-claim .claim-form label,
body.page-claim .option-fieldset {
    display: grid;
    gap: 0.45rem;
    min-width: 0;
    margin: 0;
    color: var(--light-text);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

body.page-claim .claim-form input,
body.page-claim .claim-form select,
body.page-claim .claim-form textarea {
    width: 100%;
    min-width: 0;
    padding: 0.82rem 0.95rem;
    border: 1px solid var(--light-border-strong);
    border-radius: 0.65rem;
    background: #FFFCF4;
    color: var(--light-text);
    font-size: 1rem;
    font-weight: 650;
    letter-spacing: 0;
    line-height: 1.45;
}

body.page-claim .claim-form input[type="file"] {
    cursor: pointer;
}

body.page-claim .claim-form input[type="file"]::file-selector-button {
    margin-right: 0.85rem;
    padding: 0.62rem 0.9rem;
    border: 0;
    border-radius: 999px;
    background: var(--light-text);
    color: #FFFCF4;
    font: inherit;
    font-size: 0.86rem;
    font-weight: 900;
    cursor: pointer;
}

body.page-claim .claim-form textarea {
    resize: vertical;
}

body.page-claim .phone-grid {
    display: grid;
    grid-template-columns: minmax(92px, 0.34fr) minmax(0, 1fr);
    gap: 0.75rem;
}

body.page-claim .phone-grid--wide {
    grid-template-columns: minmax(240px, 0.9fr) minmax(0, 1fr);
}

body.page-claim .claim-form input:focus,
body.page-claim .claim-form select:focus,
body.page-claim .claim-form textarea:focus {
    border-color: var(--accent-gold);
    box-shadow: 0 0 0 3px rgba(224, 168, 0, 0.16);
    outline: none;
}

body.page-claim .claim-form .form-grid label > span,
body.page-claim .option-fieldset > span {
    color: #B42318;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: none;
}

body.page-claim .option-fieldset {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    padding: 1rem;
    border: 1px solid var(--light-border);
    border-radius: 0.85rem;
    background: rgba(255, 252, 244, 0.68);
}

body.page-claim .option-fieldset legend {
    width: 100%;
    margin-bottom: 0.35rem;
    color: var(--light-text-muted);
}

body.page-claim .option-fieldset label {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 2.2rem;
    padding: 0.45rem 0.65rem;
    border: 1px solid var(--light-border);
    border-radius: 999px;
    background: var(--light-surface);
    font-size: 0.8rem;
    text-transform: none;
    letter-spacing: 0;
}

body.page-claim .option-fieldset input {
    width: 1rem;
    height: 1rem;
}

body.page-claim .form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    margin-top: 1.4rem;
    padding-top: 1.2rem;
    border-top: 1px solid var(--light-border);
}

body.page-claim .claim-form .terms-check {
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
    margin-top: 1.1rem;
    color: var(--light-text-muted);
    font-size: 0.94rem;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.45;
    text-transform: none;
}

body.page-claim .terms-check input {
    flex: 0 0 auto;
    width: 1.1rem;
    height: 1.1rem;
    margin-top: 0.18rem;
}

body.page-claim .terms-check a {
    color: var(--light-text);
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 0.18em;
}

body.page-claim .form-error {
    display: block;
    margin-top: 0.45rem;
    color: #B42318;
    font-size: 0.84rem;
    font-weight: 800;
}

body.page-claim .image-upload-field img {
    width: min(100%, 28rem);
    aspect-ratio: 16 / 9;
    border: 1px solid var(--light-border);
    border-radius: 0.75rem;
    object-fit: cover;
}

body.page-claim .field-help {
    margin: 0;
    color: var(--light-text-muted);
    font-size: 0.86rem;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.45;
    text-transform: none;
}

body.page-claim .claim-side-panel {
    position: sticky;
    top: calc(var(--header-height) + 1rem);
}

body.page-claim .claim-side-panel__card {
    padding: 1.25rem;
    border: 1px solid var(--light-border);
    border-radius: 1rem;
    background: linear-gradient(180deg, #fff 0%, #faf4e3 100%);
    box-shadow: var(--shadow-card);
}

body.page-claim .claim-side-panel__image {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 4.55;
    margin-bottom: 1.05rem;
    border-radius: 0.85rem;
    object-fit: cover;
    box-shadow: 0 10px 24px rgba(20, 17, 15, 0.08);
}

body.page-claim .claim-side-panel__kicker {
    margin: 0;
    color: var(--accent-gold);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

body.page-claim .claim-side-panel__card h2 {
    margin: 0.55rem 0 0;
    font-size: 1.6rem;
    line-height: 1.1;
}

body.page-claim .claim-side-panel__meta {
    display: grid;
    gap: 0.45rem;
    margin-top: 0.9rem;
}

body.page-claim .claim-side-panel__meta span {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    width: fit-content;
    min-height: 2.1rem;
    padding: 0.42rem 0.75rem;
    border: 1px solid rgba(20, 17, 15, 0.08);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.8);
    color: var(--light-text);
    font-size: 0.82rem;
    font-weight: 800;
}

body.page-claim .claim-side-panel__card ul {
    display: grid;
    gap: 0.8rem;
    margin: 1rem 0 0;
    padding: 0;
    list-style: none;
    color: var(--light-text-muted);
    line-height: 1.55;
}

body.page-claim .claim-side-panel__card li {
    padding-top: 0.8rem;
    border-top: 1px solid rgba(20, 17, 15, 0.08);
}

body.page-claim .claim-side-panel__card li:first-child {
    padding-top: 0;
    border-top: 0;
}

@media (max-width: 640px) {
    body.page-claim .form-grid {
        grid-template-columns: 1fr;
    }

    body.page-claim .phone-grid {
        grid-template-columns: 1fr;
    }

    body.page-claim .form-actions .button {
        width: 100%;
    }
}

@media (max-width: 980px) {
    body.page-claim .claim-page-grid {
        grid-template-columns: 1fr;
    }

    body.page-claim .claim-side-panel {
        position: static;
    }
}

body.page-organizer .organizer-note,
body.page-organizer .organizer-flash {
    margin-top: 1rem;
    padding: 1rem 1.1rem;
    border: 1px solid var(--light-border);
    border-radius: 0.85rem;
    background: rgba(255, 252, 244, 0.92);
    color: var(--light-text);
}

body.page-organizer .organizer-note strong,
body.page-organizer .organizer-flash {
    display: block;
    font-weight: 900;
}

body.page-organizer .organizer-note p {
    margin: 0.4rem 0 0;
    color: var(--light-text-muted);
    line-height: 1.6;
}

body.page-organizer .organizer-shell {
    display: grid;
    gap: 1rem;
}

body.page-organizer .organizer-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1rem;
}

body.page-organizer .organizer-toolbar form {
    margin: 0;
}

body.page-organizer .organizer-actions-card .claim-hero-card__header {
    height: 100%;
}

body.page-organizer .organizer-festival-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

body.page-organizer .organizer-festival-card {
    padding: 1.2rem;
    border: 1px solid var(--light-border);
    border-radius: 1rem;
    background: var(--light-surface);
    box-shadow: var(--shadow-card);
}

body.page-organizer .organizer-festival-card__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.9rem;
}

body.page-organizer .organizer-festival-card__meta {
    margin: 0;
    color: var(--light-text-muted);
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

body.page-organizer .organizer-festival-card h2 {
    margin: 0.45rem 0 0;
    font-size: 1.9rem;
    line-height: 0.98;
}

body.page-organizer .organizer-festival-card__location {
    margin: 0.9rem 0 0;
    color: var(--light-text-muted);
    line-height: 1.55;
}

body.page-organizer .organizer-status-pill {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.4rem 0.7rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

body.page-organizer .organizer-status-pill--published {
    background: rgba(106, 213, 44, 0.16);
    color: #2e7d1b;
}

body.page-organizer .organizer-status-pill--pending-review {
    background: rgba(255, 191, 20, 0.18);
    color: #8a5b00;
}

body.page-organizer .organizer-status-pill--draft {
    background: rgba(140, 102, 199, 0.14);
    color: #6c4eb2;
}

@media (max-width: 800px) {
    body.page-organizer .organizer-festival-grid {
        grid-template-columns: 1fr;
    }
}
