/* ==========================================================================
   Conciertos En Sevilla — main.css
   Estilos del tema. Variables CSS están en style.css.
   ========================================================================== */

/* ==========================================================================
   ACCESIBILIDAD
   ========================================================================== */
.ces-skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    background: var(--ces-accent);
    color: #fff;
    padding: 12px 18px;
    z-index: 100;
    text-decoration: none;
    font-weight: 500;
}
.ces-skip-link:focus { left: 8px; top: 8px; }

/* ==========================================================================
   LAYOUT BASE
   ========================================================================== */
.ces-container {
    max-width: var(--ces-max-width);
    margin: 0 auto;
    padding-left: var(--ces-side-padding);
    padding-right: var(--ces-side-padding);
}

.ces-main {
    min-height: 60vh;
}

/* ==========================================================================
   TIPOGRAFÍA UTILITARIA
   ========================================================================== */
.ces-display-xl {
    font-family: var(--ces-font-display);
    font-size: clamp(56px, 9vw, 96px);
    line-height: 0.9;
    letter-spacing: 0.5px;
    font-weight: 500;
    text-transform: uppercase;
    margin: 0;
}

.ces-display-lg {
    font-family: var(--ces-font-display);
    font-size: clamp(32px, 5vw, 56px);
    line-height: 0.95;
    letter-spacing: 1px;
    font-weight: 500;
    text-transform: uppercase;
    margin: 0;
}

.ces-display-md {
    font-family: var(--ces-font-display);
    font-size: 22px;
    line-height: 1;
    letter-spacing: 0.5px;
    font-weight: 500;
    text-transform: uppercase;
    margin: 0;
}

.ces-eyebrow {
    font-size: 11px;
    color: var(--ces-text-dim);
    letter-spacing: 3px;
    text-transform: uppercase;
    font-weight: 500;
    margin: 0 0 14px;
}

.ces-accent { color: var(--ces-accent); }

/* ==========================================================================
   HEADER + NAV
   ========================================================================== */
.ces-header {
    border-bottom: 0.5px solid var(--ces-border);
    background: var(--ces-bg);
    position: sticky;
    top: 0;
    z-index: 50;
}

.ces-header__inner {
    max-width: var(--ces-max-width);
    margin: 0 auto;
    padding: 18px var(--ces-side-padding);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
}

.ces-wordmark {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--ces-text);
}
.ces-wordmark:hover { color: var(--ces-text); }

.ces-wordmark__dot {
    width: 9px;
    height: 9px;
    background: var(--ces-accent);
    border-radius: 50%;
    flex-shrink: 0;
}

.ces-wordmark__text {
    font-family: var(--ces-font-display);
    font-size: 24px;
    letter-spacing: 2px;
    line-height: 1;
    text-transform: uppercase;
    font-weight: 500;
}

.ces-nav {
    display: flex;
    align-items: center;
    gap: 22px;
}

.ces-nav__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    gap: 22px;
}

.ces-nav__list a {
    font-size: 12px;
    color: var(--ces-text-muted);
    font-weight: 500;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    padding-bottom: 3px;
    border-bottom: 1.5px solid transparent;
    display: inline-block;
}
.ces-nav__list a:hover,
.ces-nav__list a.is-active {
    color: var(--ces-text);
    border-bottom-color: var(--ces-accent);
}

.ces-search-toggle {
    background: transparent;
    border: none;
    color: var(--ces-text-muted);
    padding: 6px;
    line-height: 0;
}
.ces-search-toggle:hover { color: var(--ces-text); }

/* ==========================================================================
   HOME — HERO
   ========================================================================== */
.ces-home-hero {
    padding: 50px 0 24px;
}

/* ==========================================================================
   HOME — FILTROS / CHIPS
   ========================================================================== */
.ces-home-filters {
    padding-bottom: 24px;
}

.ces-chips {
    display: flex;
    gap: 7px;
    flex-wrap: wrap;
}

.ces-chip {
    font-size: 11px;
    letter-spacing: 1px;
    color: var(--ces-text-muted);
    text-transform: uppercase;
    font-weight: 500;
    padding: 7px 14px;
    border: 0.5px solid var(--ces-border-strong);
    background: transparent;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
    text-decoration: none;
    display: inline-block;
}
.ces-chip:hover {
    background: var(--ces-bg-card);
    color: var(--ces-text);
}
.ces-chip.is-active {
    background: var(--ces-accent);
    color: #fff;
    border-color: var(--ces-accent);
}

/* ==========================================================================
   GRID DE CARDS
   ========================================================================== */
.ces-home-grid {
    padding-bottom: 24px;
}

.ces-grid {
    display: grid;
    gap: 12px;
}

.ces-grid--4-col {
    grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 900px) {
    .ces-grid--4-col { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
    .ces-grid--4-col { grid-template-columns: 1fr; }
}

/* ==========================================================================
   CARDS DE EVENTO
   ========================================================================== */
.ces-card {
    display: block;
    text-decoration: none;
    color: var(--ces-text);
    position: relative;
    background: var(--ces-bg-card);
    overflow: hidden;
    transition: transform 0.2s ease;
}
.ces-card:hover {
    color: var(--ces-text);
    transform: translateY(-2px);
}

.ces-card__media {
    aspect-ratio: 3 / 4;
    position: relative;
    overflow: hidden;
    background-color: var(--ces-bg-card);
    background-size: cover;
    background-position: center;
}

.ces-card__gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgba(26, 6, 18, 0.95) 0%, rgba(26, 6, 18, 0) 55%);
    pointer-events: none;
}

.ces-card__body {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 14px;
    color: var(--ces-text);
}

.ces-card__eyebrow {
    font-size: 9px;
    color: rgba(244, 232, 224, 0.85);
    letter-spacing: 1.5px;
    margin: 0 0 4px;
    font-weight: 500;
    text-transform: uppercase;
}

.ces-card__title {
    margin: 0;
}

.ces-card__subtitle {
    margin: 6px 0 0;
    font-size: 12px;
    color: rgba(244, 232, 224, 0.75);
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    line-height: 1.4;
}

/* Featured: ocupa 2 columnas × 2 filas */
.ces-card--featured {
    grid-column: span 2;
    grid-row: span 2;
}

.ces-card--featured .ces-card__media {
    aspect-ratio: 1 / 1;
}

.ces-card--featured .ces-card__gradient {
    background: linear-gradient(0deg, rgba(26, 6, 18, 0.92) 0%, rgba(26, 6, 18, 0.2) 45%, rgba(26, 6, 18, 0) 70%);
}

.ces-card--featured .ces-card__body {
    padding: 22px;
}

.ces-card--featured .ces-card__eyebrow {
    font-size: 11px;
    letter-spacing: 2px;
    margin-bottom: 8px;
}

@media (max-width: 540px) {
    .ces-card--featured {
        grid-column: span 1;
        grid-row: span 1;
    }
    .ces-card--featured .ces-card__media { aspect-ratio: 3 / 4; }
}

/* ==========================================================================
   BADGE
   ========================================================================== */
.ces-badge {
    position: absolute;
    top: 14px;
    left: 14px;
    background: var(--ces-accent);
    color: #fff;
    padding: 5px 12px;
    font-size: 10px;
    letter-spacing: 2px;
    font-weight: 500;
    font-family: var(--ces-font-display);
    text-transform: uppercase;
    z-index: 2;
}

/* ==========================================================================
   BOTONES
   ========================================================================== */
.ces-home-more {
    text-align: center;
    padding: 28px 0 8px;
}

.ces-btn-ghost {
    font-family: var(--ces-font-display);
    font-size: 16px;
    letter-spacing: 2px;
    color: var(--ces-text);
    text-decoration: none;
    border: 0.5px solid var(--ces-border-strong);
    padding: 14px 32px;
    display: inline-block;
    text-transform: uppercase;
    transition: background 0.15s ease, border-color 0.15s ease;
}
.ces-btn-ghost:hover {
    background: var(--ces-bg-card);
    border-color: var(--ces-text);
    color: var(--ces-text);
}

.ces-btn-cta {
    display: inline-block;
    background: var(--ces-accent);
    color: #fff;
    padding: 18px 28px;
    text-decoration: none;
    font-family: var(--ces-font-display);
    font-size: 20px;
    letter-spacing: 2.5px;
    text-align: center;
    line-height: 1;
    transition: background 0.15s ease;
    text-transform: uppercase;
}
.ces-btn-cta:hover {
    background: var(--ces-accent-hover);
    color: #fff;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.ces-footer {
    background: var(--ces-bg-elevated);
    border-top: 0.5px solid var(--ces-border);
    margin-top: 80px;
}

.ces-footer__inner {
    max-width: var(--ces-max-width);
    margin: 0 auto;
    padding: 60px var(--ces-side-padding) 30px;
}

.ces-footer__top {
    display: grid;
    grid-template-columns: 1.2fr 2fr;
    gap: 60px;
    padding-bottom: 40px;
    border-bottom: 0.5px solid var(--ces-border);
}

@media (max-width: 720px) {
    .ces-footer__top {
        grid-template-columns: 1fr;
        gap: 30px;
    }
}

.ces-footer__wordmark {
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: var(--ces-font-display);
    font-size: 20px;
    letter-spacing: 2px;
    margin-bottom: 14px;
    text-transform: uppercase;
}

.ces-footer__tagline {
    font-size: 13px;
    color: var(--ces-text-muted);
    line-height: 1.7;
    margin: 0;
}

.ces-footer__cols {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

@media (max-width: 540px) {
    .ces-footer__cols {
        grid-template-columns: repeat(2, 1fr);
    }
}

.ces-footer__col-title {
    font-family: var(--ces-font-display);
    font-size: 14px;
    letter-spacing: 1.5px;
    color: var(--ces-accent);
    margin-bottom: 14px;
    text-transform: uppercase;
}

.ces-footer__col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ces-footer__col li {
    margin-bottom: 8px;
}

.ces-footer__col a {
    font-size: 13px;
    color: var(--ces-text-muted);
}
.ces-footer__col a:hover {
    color: var(--ces-text);
}

.ces-footer__bottom {
    padding-top: 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 14px;
}

.ces-footer__copy,
.ces-footer__legal {
    font-size: 10px;
    color: var(--ces-text-faint);
    letter-spacing: 2px;
    text-transform: uppercase;
    margin: 0;
}

/* ==========================================================================
   CONTENIDO DE EVENTO (single)
   ========================================================================== */
.ces-cta-comprar {
    display: inline-block;
    background: var(--ces-accent);
    color: #fff !important;
    padding: 12px 20px;
    text-decoration: none;
    font-family: var(--ces-font-display);
    font-size: 16px;
    letter-spacing: 1.5px;
    margin: 10px 0;
    text-transform: uppercase;
}
.ces-cta-comprar:hover {
    background: var(--ces-accent-hover);
}

/* ==========================================================================
   SINGLE CONCIERTO — BREADCRUMB
   ========================================================================== */
.ces-breadcrumb {
    padding: 14px 0;
    font-size: 11px;
    color: var(--ces-text-dim);
    letter-spacing: 1.5px;
    text-transform: uppercase;
}
.ces-breadcrumb a {
    color: var(--ces-text-dim);
}
.ces-breadcrumb a:hover {
    color: var(--ces-text);
}
.ces-breadcrumb__sep {
    margin: 0 8px;
    color: rgba(244, 232, 224, 0.25);
}
.ces-breadcrumb__current {
    color: var(--ces-text);
}

/* ==========================================================================
   SINGLE CONCIERTO — HERO
   ========================================================================== */
.ces-event-hero {
    position: relative;
    min-height: 380px;
    background-color: var(--ces-bg-card);
    background-size: cover;
    background-position: center top;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
}
.ces-event-hero__gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(26, 6, 18, 0.4) 0%, rgba(26, 6, 18, 0.5) 50%, var(--ces-bg) 100%);
    pointer-events: none;
}
.ces-event-hero__content {
    position: relative;
    padding: 24px 0;
    width: 100%;
}
.ces-event-hero__eyebrow {
    font-size: 11px;
    color: rgba(244, 232, 224, 0.85);
    letter-spacing: 2.5px;
    text-transform: uppercase;
    margin: 0 0 14px;
    font-weight: 500;
}
.ces-event-hero__title {
    margin: 0 0 6px;
}
.ces-event-hero__subtitle {
    font-size: 18px;
    color: rgba(244, 232, 224, 0.85);
    max-width: 600px;
    margin: 0;
    line-height: 1.4;
}
@media (max-width: 720px) {
    .ces-event-hero { min-height: 280px; }
    .ces-event-hero__subtitle { font-size: 14px; }
}

/* ==========================================================================
   SINGLE CONCIERTO — BODY (2 cols)
   ========================================================================== */
.ces-event-body {
    padding: 32px 0 0;
}

.ces-event-grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: 36px;
}
@media (max-width: 900px) {
    .ces-event-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }
}

.ces-event-meta {
    display: flex;
    gap: 24px;
    padding-bottom: 24px;
    border-bottom: 0.5px solid var(--ces-border);
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.ces-event-meta__item {
    min-width: 140px;
}
.ces-event-meta__label {
    font-size: 10px;
    color: var(--ces-text-dim);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    margin: 0 0 6px;
    font-weight: 500;
}
.ces-event-meta__value {
    margin: 0;
}
.ces-event-meta__sub {
    font-size: 12px;
    color: var(--ces-text-muted);
    margin: 2px 0 0;
}

.ces-event-section-title {
    font-family: var(--ces-font-display);
    font-size: 22px;
    letter-spacing: 1px;
    color: var(--ces-accent);
    margin: 0 0 14px;
    text-transform: uppercase;
}

.ces-event-prose {
    font-size: 14px;
    color: rgba(244, 232, 224, 0.85);
    line-height: 1.7;
    margin-bottom: 28px;
}
.ces-event-prose h2,
.ces-event-prose h3 {
    font-family: var(--ces-font-display);
    font-size: 18px;
    letter-spacing: 0.5px;
    color: var(--ces-accent);
    margin: 24px 0 10px;
    text-transform: uppercase;
}
.ces-event-prose ul {
    padding-left: 18px;
    margin: 0 0 14px;
}
.ces-event-prose li {
    margin-bottom: 6px;
}
.ces-event-prose strong {
    color: var(--ces-text);
    font-weight: 500;
}

/* ==========================================================================
   SINGLE CONCIERTO — CTA STICKY
   ========================================================================== */
.ces-event-cta-wrap {
    position: relative;
}
@media (min-width: 901px) {
    .ces-event-cta-wrap {
        position: sticky;
        top: 80px;
        align-self: start;
    }
}

.ces-event-cta {
    background: var(--ces-bg-card);
    padding: 24px;
    border: 0.5px solid var(--ces-border);
}
.ces-event-cta__label {
    font-size: 11px;
    color: var(--ces-text-muted);
    letter-spacing: 2px;
    text-transform: uppercase;
    margin: 0 0 14px;
    font-weight: 500;
}
.ces-event-cta__btn {
    width: 100%;
    margin: 0 0 10px;
}
.ces-event-cta__hint {
    font-size: 11px;
    color: rgba(244, 232, 224, 0.55);
    text-align: center;
    line-height: 1.5;
    margin: 0 0 18px;
}
.ces-event-cta__trust {
    list-style: none;
    padding: 18px 0 0;
    margin: 0;
    border-top: 0.5px solid var(--ces-border);
}
.ces-event-cta__trust li {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    font-size: 12px;
    color: var(--ces-text-muted);
    margin-bottom: 10px;
    line-height: 1.5;
}
.ces-event-cta__trust li:last-child { margin-bottom: 0; }
.ces-event-cta__trust strong { color: var(--ces-text); font-weight: 500; }
.ces-event-cta__check {
    color: var(--ces-accent);
    font-size: 14px;
    margin-top: 1px;
}

.ces-event-share {
    margin-top: 12px;
    display: flex;
    gap: 8px;
}
.ces-event-share__btn {
    flex: 1;
    background: transparent;
    border: 0.5px solid var(--ces-border-strong);
    color: var(--ces-text);
    padding: 11px;
    font-family: var(--ces-font-body);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.5px;
    transition: background 0.15s ease;
}
.ces-event-share__btn:hover {
    background: var(--ces-bg-card);
}

/* ==========================================================================
   SINGLE CONCIERTO — VENUE / MAPA
   ========================================================================== */
.ces-event-venue {
    padding: 36px 0 8px;
}
.ces-event-venue__grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    gap: 24px;
}
@media (max-width: 720px) {
    .ces-event-venue__grid {
        grid-template-columns: 1fr;
        gap: 18px;
    }
}

.ces-event-venue__map {
    background: var(--ces-bg-card);
    border: 0.5px solid var(--ces-border);
    overflow: hidden;
    position: relative;
    min-height: 280px;
}
.ces-event-venue__map svg {
    width: 100%;
    height: 280px;
    display: block;
}
.ces-event-venue__map-tag {
    position: absolute;
    bottom: 14px;
    right: 14px;
    background: rgba(26, 6, 18, 0.85);
    padding: 8px 12px;
    font-size: 10px;
    color: var(--ces-text-muted);
    letter-spacing: 0.5px;
}

.ces-event-venue__info {
    padding-top: 4px;
}
.ces-event-venue__address {
    font-size: 14px;
    color: var(--ces-text);
    margin: 0 0 4px;
    line-height: 1.5;
}
.ces-event-venue__address-sub {
    font-size: 13px;
    color: var(--ces-text-muted);
    margin: 0 0 20px;
}
.ces-event-venue__gmaps {
    display: inline-block;
    background: transparent;
    color: var(--ces-accent);
    border: 0.5px solid var(--ces-accent);
    padding: 9px 16px;
    text-decoration: none;
    font-size: 11px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    font-weight: 500;
}
.ces-event-venue__gmaps:hover {
    background: var(--ces-accent);
    color: #fff;
}

/* ==========================================================================
   SINGLE CONCIERTO — RELACIONADOS
   ========================================================================== */
.ces-event-related {
    padding: 36px 0 24px;
}
.ces-event-related .ces-event-section-title {
    color: var(--ces-text);
    margin-bottom: 18px;
    font-size: 26px;
}

/* ==========================================================================
   RESPONSIVE GENERAL
   ========================================================================== */
@media (max-width: 720px) {
    :root {
        --ces-side-padding: 20px;
    }

    .ces-wordmark__text { font-size: 18px; letter-spacing: 1.5px; }
    .ces-nav__list { gap: 14px; }
    .ces-nav__list a { font-size: 11px; }
    .ces-home-hero { padding: 32px 0 18px; }
}

/* ==========================================================================
   ARCHIVE — HERO Y BÚSQUEDA
   ========================================================================== */
.ces-archive-hero {
    padding: 50px 0 28px;
}

.ces-archive-hero .ces-display-xl {
    margin-bottom: 14px;
}

.ces-archive-intro {
    font-size: 15px;
    color: var(--ces-text-muted);
    max-width: 620px;
    line-height: 1.6;
    margin: 14px 0 0;
}

.ces-search-form {
    display: flex;
    gap: 8px;
    max-width: 520px;
    margin-top: 24px;
}

.ces-search-input {
    flex: 1;
    background: var(--ces-bg-card);
    border: 0.5px solid var(--ces-border-strong);
    color: var(--ces-text);
    padding: 14px 16px;
    font-family: var(--ces-font-body);
    font-size: 14px;
    outline: none;
    transition: border-color 0.15s ease;
}
.ces-search-input:focus {
    border-color: var(--ces-accent);
}
.ces-search-input::placeholder {
    color: var(--ces-text-faint);
}

.ces-search-submit {
    background: var(--ces-accent);
    color: #fff;
    border: none;
    padding: 14px 22px;
    font-family: var(--ces-font-display);
    font-size: 14px;
    letter-spacing: 2px;
    cursor: pointer;
    transition: background 0.15s ease;
    text-transform: uppercase;
}
.ces-search-submit:hover {
    background: var(--ces-accent-hover);
}

/* ==========================================================================
   ARCHIVE — GRID Y PAGINACIÓN
   ========================================================================== */
.ces-archive-grid {
    padding: 0 0 32px;
}

.ces-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 18px;
    padding: 36px 0 0;
    flex-wrap: wrap;
}

.ces-pagination__info {
    font-size: 12px;
    color: var(--ces-text-muted);
    letter-spacing: 1px;
    text-transform: uppercase;
}

.ces-empty {
    padding: 60px 0;
    text-align: center;
}

.ces-empty__title {
    font-family: var(--ces-font-display);
    font-size: 28px;
    letter-spacing: 1px;
    color: var(--ces-text);
    margin: 0 0 12px;
}

.ces-empty__subtitle {
    color: var(--ces-text-muted);
    font-size: 14px;
    margin: 0;
}
.ces-empty__subtitle a {
    color: var(--ces-accent);
    text-decoration: underline;
}

/* ==========================================================================
   NAVEGADOR DE MESES
   ========================================================================== */
.ces-month-nav {
    padding: 24px 0 32px;
}

.ces-month-nav__grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 8px;
}

@media (max-width: 720px) {
    .ces-month-nav__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (max-width: 420px) {
    .ces-month-nav__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.ces-month-nav__item {
    background: var(--ces-bg-card);
    border: 0.5px solid var(--ces-border);
    padding: 14px 8px;
    text-decoration: none;
    color: var(--ces-text);
    text-align: center;
    transition: background 0.15s ease, border-color 0.15s ease;
}
.ces-month-nav__item:hover {
    background: var(--ces-bg-elevated);
    border-color: var(--ces-accent);
    color: var(--ces-text);
}
.ces-month-nav__count {
    font-size: 10px;
    color: var(--ces-text-muted);
    letter-spacing: 1px;
    margin-top: 4px;
    text-transform: uppercase;
}

/* ==========================================================================
   PÁGINA DE SALAS
   ========================================================================== */
.ces-venues-grid {
    padding: 0 0 60px;
}

.ces-venues__list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background: var(--ces-border);
}

.ces-venue-card {
    background: var(--ces-bg);
    padding: 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-decoration: none;
    color: var(--ces-text);
    transition: background 0.15s ease;
}
.ces-venue-card:hover {
    background: var(--ces-bg-card);
    color: var(--ces-text);
}

.ces-venue-card__info {
    flex: 1;
}

.ces-venue-card__name {
    margin: 0 0 4px;
}

.ces-venue-card__count {
    font-size: 12px;
    color: var(--ces-text-muted);
    letter-spacing: 1px;
    text-transform: uppercase;
    margin: 0;
}

.ces-venue-card__arrow {
    font-family: var(--ces-font-display);
    font-size: 32px;
    color: var(--ces-accent);
    margin-left: 20px;
    transition: transform 0.15s ease;
}
.ces-venue-card:hover .ces-venue-card__arrow {
    transform: translateX(6px);
}

/* ==========================================================================
   PÁGINA DE FESTIVALES
   ========================================================================== */
.ces-festivals-list {
    padding: 0 0 32px;
}

.ces-festival-block {
    padding: 36px 0;
    border-top: 0.5px solid var(--ces-border);
}
.ces-festival-block:first-child {
    border-top: none;
    padding-top: 0;
}

.ces-festival-block__header {
    margin-bottom: 24px;
}

.ces-festival-block__desc {
    font-size: 14px;
    color: var(--ces-text-muted);
    margin: 14px 0 10px;
    max-width: 680px;
    line-height: 1.6;
}

.ces-festival-block__meta {
    font-size: 11px;
    color: var(--ces-text-dim);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    font-weight: 500;
    margin: 0 0 14px;
}

/* ==========================================================================
   PÁGINA PROMOTORES
   ========================================================================== */
.ces-promoter-hero {
    padding: 50px 0 28px;
    border-bottom: 0.5px solid var(--ces-border);
}

.ces-promoter-lead {
    font-size: 17px;
    color: var(--ces-text);
    max-width: 700px;
    line-height: 1.6;
    margin: 14px 0 28px;
}
.ces-promoter-lead strong {
    color: var(--ces-accent);
}

.ces-promoter-hero__cta {
    display: inline-block;
}

.ces-promoter-benefits {
    padding: 50px 0 28px;
}

.ces-promoter-steps {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 28px;
}
@media (max-width: 720px) {
    .ces-promoter-steps {
        grid-template-columns: 1fr;
    }
}

.ces-promoter-step {
    padding: 24px;
    background: var(--ces-bg-card);
    border: 0.5px solid var(--ces-border);
}

.ces-promoter-step__num {
    font-family: var(--ces-font-display);
    font-size: 14px;
    letter-spacing: 2px;
    color: var(--ces-accent);
    margin-bottom: 8px;
}

.ces-promoter-step h3 {
    margin: 0 0 10px;
    font-size: 22px;
}

.ces-promoter-step p {
    font-size: 14px;
    color: var(--ces-text-muted);
    line-height: 1.6;
    margin: 0;
}

.ces-promoter-why {
    padding: 24px 0 28px;
}

.ces-promoter-features {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
}
@media (max-width: 720px) {
    .ces-promoter-features {
        grid-template-columns: 1fr;
    }
}

.ces-promoter-feature {
    padding: 20px 22px;
    border-left: 2px solid var(--ces-accent);
    background: rgba(224, 0, 108, 0.04);
}

.ces-promoter-feature h3 {
    font-family: var(--ces-font-display);
    font-size: 18px;
    letter-spacing: 0.5px;
    margin: 0 0 6px;
    color: var(--ces-text);
}

.ces-promoter-feature p {
    font-size: 14px;
    color: var(--ces-text-muted);
    line-height: 1.5;
    margin: 0;
}

.ces-promoter-cta-bottom {
    padding: 50px 0;
    background: var(--ces-bg-elevated);
    border-top: 0.5px solid var(--ces-border);
    border-bottom: 0.5px solid var(--ces-border);
    text-align: center;
}

.ces-promoter-cta-bottom .ces-display-xl {
    margin-bottom: 14px;
}

.ces-promoter-cta-bottom p {
    color: var(--ces-text-muted);
    font-size: 15px;
    margin: 0 0 22px;
}

.ces-promoter-cta-bottom__btn {
    margin-bottom: 18px;
}

.ces-promoter-cta-bottom__legal {
    font-size: 11px;
    color: var(--ces-text-faint);
    max-width: 480px;
    margin: 14px auto 0;
    line-height: 1.5;
}

.ces-promoter-faq {
    padding: 50px 0;
}

.ces-faq-item {
    border-bottom: 0.5px solid var(--ces-border);
    padding: 14px 0;
}

.ces-faq-item summary {
    font-family: var(--ces-font-body);
    font-size: 15px;
    font-weight: 500;
    color: var(--ces-text);
    cursor: pointer;
    padding: 8px 0;
    list-style: none;
    position: relative;
    padding-right: 30px;
}

.ces-faq-item summary::-webkit-details-marker { display: none; }

.ces-faq-item summary::after {
    content: '+';
    position: absolute;
    right: 0;
    top: 8px;
    font-family: var(--ces-font-display);
    font-size: 22px;
    color: var(--ces-accent);
    line-height: 1;
}
.ces-faq-item[open] summary::after {
    content: '−';
}

.ces-faq-item p {
    font-size: 14px;
    color: var(--ces-text-muted);
    line-height: 1.6;
    padding: 8px 0 12px;
    margin: 0;
}

/* ==========================================================================
   FORMULARIOS (sugerir evento)
   ========================================================================== */
.ces-suggest-hero {
    padding: 50px 0 28px;
}

.ces-suggest-form-section {
    padding: 0 0 50px;
}

.ces-form {
    max-width: 640px;
}

.ces-form__row {
    margin-bottom: 18px;
}

.ces-form__row--cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}
@media (max-width: 540px) {
    .ces-form__row--cols {
        grid-template-columns: 1fr;
    }
}

.ces-form__label {
    display: block;
    font-size: 11px;
    color: var(--ces-text-dim);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    font-weight: 500;
    margin-bottom: 8px;
}

.ces-form__input {
    width: 100%;
    background: var(--ces-bg-card);
    border: 0.5px solid var(--ces-border-strong);
    color: var(--ces-text);
    padding: 12px 14px;
    font-family: var(--ces-font-body);
    font-size: 14px;
    outline: none;
    transition: border-color 0.15s ease;
}
.ces-form__input:focus {
    border-color: var(--ces-accent);
}
.ces-form__input::placeholder {
    color: var(--ces-text-faint);
}

textarea.ces-form__input {
    resize: vertical;
    min-height: 80px;
}

.ces-form__hint {
    font-size: 11px;
    color: var(--ces-text-faint);
    margin: 6px 0 0;
    line-height: 1.5;
}

.ces-form__actions {
    margin-top: 24px;
}

.ces-form__message {
    margin-top: 18px;
    padding: 12px 16px;
    font-size: 13px;
}
.ces-form__message:empty { display: none; }
.ces-form__message.is-loading { background: var(--ces-bg-card); color: var(--ces-text-muted); }
.ces-form__message.is-success { background: rgba(61, 217, 154, 0.1); color: #6be0b3; border-left: 2px solid #3dd99a; }
.ces-form__message.is-error   { background: rgba(255, 85, 119, 0.1); color: #ff5577; border-left: 2px solid #ff5577; }

.ces-form__hp {
    position: absolute;
    left: -9999px;
    opacity: 0;
    pointer-events: none;
}

/* ==========================================================================
   FAVORITOS — BOTONES Y PÁGINA
   ========================================================================== */
.ces-fav-btn {
    flex: 1;
    background: transparent;
    border: 0.5px solid var(--ces-border-strong);
    color: var(--ces-text);
    padding: 11px;
    font-family: var(--ces-font-body);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.5px;
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.ces-fav-btn:hover {
    background: var(--ces-bg-card);
}
.ces-fav-btn.is-saved {
    border-color: var(--ces-accent);
    color: var(--ces-accent);
}
.ces-fav-btn__icon {
    font-size: 14px;
}

.ces-fav-actions {
    padding: 0 0 24px;
    display: flex;
    gap: 10px;
}
.ces-btn-ghost--danger {
    color: #ff5577 !important;
    border-color: rgba(255, 85, 119, 0.4) !important;
}

.ces-fav-results {
    padding: 0 0 60px;
}

