/* Banner do evento */
.event-cover {
    position: relative;
    color: #fff;
    overflow: hidden;
    isolation: isolate;
}
.event-cover__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    z-index: -2;
}
.event-cover__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg,
        rgba(0,0,0,0.35) 0%,
        rgba(0,0,0,0.65) 60%,
        rgba(0,0,0,0.85) 100%);
    z-index: -1;
}
.event-cover__inner {
    padding: var(--space-9) var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    align-items: flex-start;
}
.event-cover__category {
    background: var(--accent);
    color: var(--on-accent);
    text-transform: uppercase;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    padding: 4px var(--space-3);
    border-radius: var(--radius-full);
}
.event-cover h1 {
    color: #fff;
    max-width: 760px;
}
.event-cover__meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3) var(--space-5);
    color: rgba(255,255,255,0.85);
    font-size: 0.95rem;
    margin-top: var(--space-3);
}
.event-cover__meta span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.event-cover__meta svg { color: var(--accent); flex-shrink: 0; }
.event-cover__meta strong { color: #fff; font-weight: 600; }

@media (max-width: 720px) {
    .event-cover__inner { padding: var(--space-7) var(--space-5); }
    .event-cover__meta { gap: var(--space-2) var(--space-4); font-size: 0.88rem; }
}

/* Página */
.event-page {
    padding: var(--space-7) var(--space-5) var(--space-10);
}
.event-page__notice {
    display: flex;
    gap: var(--space-3);
    align-items: flex-start;
    background: var(--accent-soft);
    border: 1px solid var(--accent);
    border-radius: var(--radius-md);
    padding: var(--space-4) var(--space-5);
    color: var(--text-1);
    margin-bottom: var(--space-6);
}
.event-page__notice svg { color: var(--accent); flex-shrink: 0; margin-top: 2px; }
.event-page__notice strong { color: var(--text-0); }

.event-page__head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: var(--space-3);
    margin-bottom: var(--space-5);
    flex-wrap: wrap;
}
.event-page__hint {
    color: var(--text-3);
    font-size: 0.85rem;
}

/* Grid de fotos */
.photo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--space-4);
}

/* Tile */
.photo-tile {
    display: flex;
    flex-direction: column;
    background: var(--bg-0);
    border: 2px solid var(--border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: border-color .15s var(--ease), transform .15s var(--ease);
}
.photo-tile.is-in-cart {
    border-color: var(--accent);
    box-shadow: 0 0 0 4px var(--accent-glow);
}
.photo-tile__img {
    position: relative;
    border: 0;
    padding: 0;
    background: var(--bg-2);
    cursor: zoom-in;
    aspect-ratio: 10 / 7;
    overflow: hidden;
}
.photo-tile__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s var(--ease);
}
.photo-tile__img:hover img { transform: scale(1.03); }

.photo-tile__meta {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: var(--space-3) var(--space-4) var(--space-2);
    gap: var(--space-2);
}
.photo-tile__name {
    color: var(--text-2);
    font-size: 0.82rem;
    font-family: ui-monospace, 'SF Mono', monospace;
}
.photo-tile__price {
    color: var(--accent);
    font-weight: 700;
    font-size: 0.95rem;
}
.photo-tile__form { margin: 0; }
.photo-tile__btn {
    width: 100%;
    border: 0;
    border-top: 1px solid var(--border);
    background: var(--bg-1);
    color: var(--text-1);
    padding: var(--space-3) var(--space-4);
    cursor: pointer;
    font: inherit;
    font-weight: 600;
    font-size: 0.9rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    transition: background .15s var(--ease), color .15s var(--ease);
}
.photo-tile__btn:hover {
    background: var(--accent-soft);
    color: var(--accent);
}
.photo-tile.is-in-cart .photo-tile__btn {
    background: var(--accent);
    color: var(--on-accent);
    border-top-color: var(--accent);
}
.photo-tile.is-in-cart .photo-tile__btn:hover {
    background: var(--accent-dim);
}

/* Estado "já comprada" */
.photo-tile.is-purchased {
    border-color: var(--text-0);
    background: var(--bg-1);
}
.photo-tile.is-purchased .photo-tile__img { cursor: zoom-in; }
.photo-tile__owned-badge {
    position: absolute;
    top: var(--space-3);
    left: var(--space-3);
    background: var(--text-0);
    color: #fff;
    font-size: 0.74rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 4px var(--space-3);
    border-radius: var(--radius-full);
    display: inline-flex;
    align-items: center;
    gap: 4px;
    box-shadow: var(--shadow-md);
}
.photo-tile__owned-badge svg { color: var(--accent); }
.photo-tile__price--owned {
    color: var(--text-3);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.78rem;
    letter-spacing: 0.06em;
}
.photo-tile__btn--owned {
    background: var(--text-0);
    color: #fff;
    text-decoration: none;
}
.photo-tile__btn--owned:hover {
    background: var(--accent);
    color: var(--on-accent);
}

/* Cart FAB (floating action button) */
.cart-fab {
    position: fixed;
    bottom: var(--space-5);
    left: 50%;
    transform: translateX(-50%);
    z-index: 40;
    transition: transform .2s var(--ease);
}
.cart-fab:hover {
    transform: translateX(-50%) translateY(-2px);
}
.cart-fab__link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    background: var(--text-0);
    color: #fff;
    padding: var(--space-3) var(--space-4) var(--space-3) var(--space-3);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-lg);
    transition: background .2s var(--ease), color .2s var(--ease);
}
.cart-fab__link:hover {
    background: var(--accent);
    color: #fff;
}
.cart-fab__count {
    background: var(--accent);
    color: var(--on-accent);
    font-weight: 700;
    min-width: 28px;
    height: 28px;
    padding: 0 8px;
    border-radius: var(--radius-full);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
}
.cart-fab__label { font-size: 0.88rem; opacity: 0.85; }
.cart-fab__cta { display: inline-flex; align-items: center; gap: 4px; font-weight: 600; font-size: 0.92rem; }
.cart-fab__link:hover .cart-fab__count {
    background: #fff;
    color: var(--accent);
}

@media (max-width: 480px) {
    .cart-fab__label { display: none; }
}

/* Lightbox */
.lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.92);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
    padding: var(--space-5);
}
.lightbox[hidden] { display: none; }
.lightbox__img {
    max-width: min(95vw, 1400px);
    max-height: 92vh;
    object-fit: contain;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
}
.lightbox__close {
    position: absolute;
    top: var(--space-4);
    right: var(--space-4);
    background: rgba(255,255,255,0.1);
    border: 0;
    color: #fff;
    width: 48px;
    height: 48px;
    border-radius: var(--radius-full);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .15s var(--ease);
}
.lightbox__close:hover { background: var(--accent); }
