/* ============================================
   EVENTI MODULE - Lu Nibareddu
   ============================================ */

/* === EVENTI CONTENT === */
.eventi-content {
    padding: 0 var(--space-4);
}

/* === EVENTI LIST === */
.eventi-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

/* === EVENT CARD ===
   La card eventi ora riusa le classi standard .card / .card-image /
   .card-content / .card-title / .card-subtitle / .card-badge (vedi
   components/card.css) per garantire allineamento e proporzioni IDENTICI
   alle card aree/discover/itinerari. Qui restano solo gli elementi
   specifici degli eventi: date-block, recurring-badge, meta. */

/* Date Block (overlay sull'immagine, top-right) */
.event-card .event-date-block {
    position: absolute;
    top: var(--space-3);
    right: var(--space-3);

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    min-width: 52px;
    padding: var(--space-2) var(--space-3);

    background: var(--bg-card);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);

    text-align: center;
    z-index: 2;
}

.event-card .event-date-day {
    font-size: var(--text-2xl);
    font-weight: var(--weight-bold);
    line-height: 1;
    color: var(--brand-brown);
}

.event-card .event-date-month {
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-top: var(--space-1);
}

/* Meta info (orari + location) sotto il titolo/sottotitolo */
.event-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2) var(--space-4);
}

.event-meta-item {
    display: flex;
    align-items: center;
    gap: var(--space-1);

    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.event-meta-item .material-symbols-outlined {
    font-size: 16px;
    color: var(--brand-brown);
}

/* External Event Badge */
.event-external-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);

    padding: var(--space-1) var(--space-2);
    margin-top: var(--space-2);

    font-size: var(--text-xs);
    font-weight: var(--weight-medium);
    color: var(--brand-nature);

    background: rgba(46, 133, 110, 0.1);
    border-radius: var(--radius-sm);
}

/* Internal Event Badge (mirror of external, brand-brown tonal) */
.event-internal-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);

    padding: var(--space-1) var(--space-2);
    margin-top: var(--space-2);

    font-size: var(--text-xs);
    font-weight: var(--weight-medium);
    color: var(--brand-brown);

    background: rgba(139, 87, 60, 0.1);
    border-radius: var(--radius-sm);
}

/* === DATE SECTION HEADERS === */
.eventi-date-header {
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: rgba(255, 255, 255, 0.9);
    padding: var(--space-4) 0 var(--space-2);
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    margin-bottom: var(--space-3);
}

.eventi-date-header:first-child {
    padding-top: 0;
}

/* === EMPTY STATE === */
.eventi-empty {
    text-align: center;
    padding: var(--space-12) var(--space-4);
}

.eventi-empty-icon {
    font-size: 64px;
    color: rgba(255, 255, 255, 0.5);
    margin-bottom: var(--space-4);
}

.eventi-empty-title {
    font-size: var(--text-lg);
    font-weight: var(--weight-semibold);
    color: var(--text-inverse);
    margin-bottom: var(--space-2);
}

.eventi-empty-text {
    font-size: var(--text-base);
    color: rgba(255, 255, 255, 0.8);
}

/* F138 — Event recurrence */

/* Badge "Ricorrente" — overlay sull'immagine, bottom-right (date-block è top-right).
   Scope a .event-card per evitare di applicarsi ad altre .card-image. */
.event-card .event-recurring-badge {
    position: absolute;
    bottom: var(--space-3);
    right: var(--space-3);

    display: inline-flex;
    align-items: center;
    gap: var(--space-1);

    padding: var(--space-1) var(--space-2);
    background: var(--bg-card);
    color: var(--brand-brown);

    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.05em;

    border-radius: var(--radius-full);
    box-shadow: var(--shadow-md);
    z-index: 2;
}

.event-card .event-recurring-badge .material-symbols-outlined {
    font-size: var(--text-sm);
}

/* Detail modal: "Anche questi giorni" */
.event-other-dates {
    margin-top: var(--space-4);
    padding-top: var(--space-4);
    border-top: 1px solid var(--border-light);
}

.event-other-dates h4 {
    margin: 0 0 var(--space-2);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.event-occurrence-chips {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.event-occurrence-chip {
    display: inline-block;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);

    font-size: var(--text-xs);
    font-weight: var(--weight-medium);

    background: var(--bg-tertiary);
    color: var(--text-primary);
    border: 1px solid transparent;
}

.event-occurrence-chip.is-current {
    background: var(--brand-brown);
    color: var(--text-inverse);
    border-color: var(--brand-brown-dark);
}

/* === EVENT PREVIEW CARD ===
   Variante compatta orizzontale usata in home (renderTodayEvents per
   #today-events) — date-block a sinistra, info a destra, niente immagine.
   Classi prefissate `event-preview-*` per non collidere con la card
   completa standard di /eventi. */
.event-preview-card {
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: var(--space-3);

    background: var(--bg-card);
    padding: var(--space-3);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-float);

    cursor: pointer;
    transition:
        transform var(--duration-fast) var(--ease-out),
        box-shadow var(--duration-fast) var(--ease-out);
}

.event-preview-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-float-hover);
}

.event-preview-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    min-width: 52px;
    padding: var(--space-2);

    background: var(--bg-tertiary);
    border-radius: var(--radius-md);

    text-align: center;
}

.event-preview-date-day {
    font-size: var(--text-xl);
    font-weight: var(--weight-bold);
    color: var(--brand-brown);
    line-height: 1;
}

.event-preview-date-month {
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    color: var(--text-secondary);
    text-transform: uppercase;
    margin-top: var(--space-1);
}

.event-preview-info {
    flex: 1;
    min-width: 0;
}

.event-preview-category {
    display: block;
    font-size: var(--text-xs);
    font-weight: var(--weight-medium);
    color: var(--brand-brown);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--space-1);
}

.event-preview-title {
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--text-primary);
    line-height: var(--leading-tight);
    margin: 0 0 var(--space-2);
}

.event-preview-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2) var(--space-3);
}

.event-preview-meta-item {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    font-size: var(--text-xs);
    color: var(--text-secondary);
}

.event-preview-meta-item .material-symbols-outlined {
    font-size: var(--text-base);
    color: var(--brand-brown);
}
