/* =========================================
   DJ PROFILE — PREMIUM DARK & NEON THEME
   ========================================= */

:root {
    --bg-dark:       #080808;
    --bg-darker:     #040404;
    --neon:          #d0d0d0;
    --neon-glow:     rgba(200, 200, 200, 0.18);
    --neon-alt:      #a0a0a0;
    --accent:        #e8e8e8;
    --accent2:       #999;
    --text:          #f0f0f0;
    --muted:         #666;
    --glass-bg:      rgba(16, 16, 16, 0.70);
    --glass-border:  rgba(255,255,255,0.07);
    --glass-shadow:  0 8px 32px rgba(0,0,0,.7);
    --radius:        16px;
    --ease:          all 0.3s cubic-bezier(.25,.8,.25,1);
    --font-h:        'Outfit', sans-serif;
    --font-b:        'Open Sans', sans-serif;
}

/* ── RESET ──────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--font-b);
    background: var(--bg-dark);
    color: var(--text);
    line-height: 1.65;
    overflow-x: hidden;
}
h1,h2,h3,h4,h5,h6 { font-family: var(--font-h); color:#fff; font-weight:600; }
a { text-decoration:none; color:var(--text); transition:var(--ease); }
img { max-width:100%; display:block; }
button { font-family:var(--font-h); }

/* ── LAYOUT ─────────────────────────────── */
.container   { max-width:1200px; margin:0 auto; padding:0 20px; }
.section-spacing { padding:100px 0; }
.bg-darker   { background:var(--bg-darker); }
.text-center { text-align:center; }
.mt-4 { margin-top:2rem; }
.mt-5 { margin-top:3rem; }
.mb-4 { margin-bottom:2rem; }
.w-100 { width:100%; }

/* ── GLASS ──────────────────────────────── */
.glass-panel {
    background: var(--glass-bg);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid var(--glass-border);
    box-shadow: var(--glass-shadow);
    border-radius: var(--radius);
}

/* ── UTILITIES ──────────────────────────── */
.text-neon   { color:var(--accent); }
.shadow-neon { box-shadow:0 0 30px var(--neon-glow); }
.border-top-dark { border-top:1px solid var(--glass-border); }

.tag-neon {
    display:inline-block; padding:5px 14px;
    background:rgba(255,255,255,.06); color:var(--accent);
    border:1px solid rgba(255,255,255,.2); border-radius:20px;
    font-size:.85rem; font-weight:600; letter-spacing:1px;
    text-transform:uppercase; margin-bottom:1rem;
}
.tag-muted {
    display:block; color:var(--accent2);
    font-family:var(--font-h); font-weight:600;
    letter-spacing:3px; font-size:.8rem; margin-bottom:.5rem;
}
.tag-solid {
    display:inline-block; padding:8px 18px;
    background:#222; color:#666; border-radius:8px;
    font-size:.9rem; font-weight:600;
}

/* ── SECTION HEADERS ────────────────────── */
.section-header h2 {
    font-size:2.5rem; margin-bottom:1rem;
    text-transform:uppercase; letter-spacing:1px;
}
.section-header p {
    color:var(--muted); font-size:1.1rem;
    max-width:600px; margin:0 auto 3rem;
}

/* ── ANIMATIONS ─────────────────────────── */
.reveal-up { opacity:0; transform:translateY(30px); transition:all 0.8s ease-out; }
.reveal-up.active { opacity:1; transform:none; }
.delay-1 { transition-delay:.2s; }
.delay-2 { transition-delay:.4s; }
.delay-3 { transition-delay:.6s; }

/* ── BUTTONS ────────────────────────────── */
.btn-primary, .btn-outline {
    display:inline-block; padding:12px 28px; border-radius:30px;
    font-family:var(--font-h); font-weight:600; cursor:pointer;
    text-align:center; border:none; letter-spacing:.5px; transition:var(--ease);
}
.btn-primary { background:linear-gradient(135deg, var(--accent), var(--accent2)); color:#111; }
.btn-primary:hover { transform:translateY(-2px); filter:brightness(1.12); box-shadow:0 8px 28px var(--neon-glow); }
.btn-glow { box-shadow:0 0 16px var(--neon-glow); }
.btn-outline { background:transparent; border:1.5px solid rgba(255,255,255,.3); color:var(--text); }
.btn-outline:hover { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.6); transform:translateY(-2px); }
.btn-large { padding:15px 36px; font-size:1.1rem; }
.btn-small { padding:8px 20px; font-size:.9rem; }
.link-arrow { display:inline-block; font-weight:600; text-transform:uppercase; font-family:var(--font-h); }
.link-arrow:hover { transform:translateX(5px); color:var(--accent2); }

/* ── NAVBAR ─────────────────────────────── */
.navbar {
    position:fixed; top:0; left:0; width:100%;
    z-index:900; padding:20px 0; transition:var(--ease);
    background:linear-gradient(to bottom,rgba(0,0,0,.85),transparent);
}
.navbar.scrolled {
    background:rgba(5,5,5,.92); backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px); padding:14px 0;
    border-bottom:1px solid var(--glass-border);
}
.nav-container {
    display:flex; justify-content:space-between; align-items:center;
    max-width:1200px; margin:0 auto; padding:0 20px;
}
.back-link { font-size:.9rem; color:var(--muted); display:flex; align-items:center; gap:5px; }
.back-link:hover { color:var(--accent); }
.logo { font-family:var(--font-h); font-size:1.8rem; font-weight:800; letter-spacing:1px; color:#fff; }
.logo span { color:var(--accent2); }
.nav-links { display:flex; align-items:center; gap:30px; }
.nav-links a:not(.btn-primary) {
    font-family:var(--font-h); font-size:.95rem;
    text-transform:uppercase; letter-spacing:1px; position:relative;
    color:var(--muted);
}
.nav-links a:not(.btn-primary):hover { color:#fff; }
.nav-links a:not(.btn-primary)::after {
    content:''; position:absolute; bottom:-5px; left:0;
    width:0; height:2px; background:linear-gradient(90deg, var(--accent), var(--accent2));
    transition:var(--ease);
}
.nav-links a:not(.btn-primary):hover::after { width:100%; }

/* ── HAMBURGER ──────────────────────────── */
.mobile-menu-btn {
    display:none; flex-direction:column; gap:6px;
    cursor:pointer; z-index:1001; background:none; border:none; padding:4px;
}
.mobile-menu-btn span {
    display:block; width:28px; height:2px;
    background:var(--text); border-radius:2px; transition:var(--ease);
}
/* X state */
.mobile-menu-btn.open span:nth-child(1) { transform:rotate(45deg) translate(5px,6px); }
.mobile-menu-btn.open span:nth-child(2) { opacity:0; }
.mobile-menu-btn.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-6px); }

/* ── MOBILE MENU (slides from LEFT) ─────── */
.menu-overlay {
    display:none; position:fixed; inset:0;
    background:rgba(0,0,0,.6); z-index:1000;
    backdrop-filter:blur(4px);
}
.menu-overlay.active { display:block; }

.mobile-menu {
    position:fixed; top:0; left:-100%; width:280px; height:100vh;
    background:rgba(10,10,10,.97); border-right:1px solid var(--glass-border);
    padding:0; z-index:1010; display:flex; flex-direction:column;
    transition:left 0.38s cubic-bezier(.4,0,.2,1);
    box-shadow:4px 0 30px rgba(0,0,0,.8);
}
.mobile-menu.active { left:0; }

.mobile-menu-header {
    display:flex; justify-content:space-between; align-items:center;
    padding:24px 24px 20px; border-bottom:1px solid var(--glass-border);
}
.mobile-menu-close {
    background:none; border:none; color:var(--text); font-size:1.8rem;
    cursor:pointer; line-height:1; padding:0 4px; transition:var(--ease);
}
.mobile-menu-close:hover { color:var(--accent); }

.mobile-link {
    display:block; padding:16px 24px; font-family:var(--font-h);
    font-size:1.1rem; text-transform:uppercase; letter-spacing:1px;
    color:var(--muted); border-bottom:1px solid var(--glass-border);
    transition:var(--ease);
}
.mobile-link:hover { color:#fff; padding-left:32px; }
.mobile-link.btn-primary {
    margin:24px; border-radius:30px; border:none;
    color:#111; text-align:center;
}
.mobile-link.btn-primary:hover { padding-left:24px; }

/* ── HERO ───────────────────────────────── */
.hero {
    position:relative; height:100vh;
    display:flex; align-items:center; justify-content:center;
    overflow:hidden;
}
#hero-canvas {
    position:absolute; inset:0;
    width:100%; height:100%;
}
.hero-overlay {
    position:absolute; inset:0;
    background:linear-gradient(160deg, rgba(0,0,0,.3) 0%, rgba(2,2,2,.82) 100%);
}
.hero-content {
    position:relative; z-index:10;
    text-align:center; max-width:820px; padding-top:80px;
}
.hero h1 {
    font-size:5.5rem; line-height:1.05; margin-bottom:20px;
    text-transform:uppercase; letter-spacing:3px;
    background:linear-gradient(to right,#fff,#9a9a9a);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    background-clip:text;
}
.hero p { font-size:1.2rem; color:#ccc; margin-bottom:40px; max-width:580px; margin-inline:auto; }
.hero-buttons { display:flex; gap:20px; justify-content:center; flex-wrap:wrap; }

/* ── ABOUT ──────────────────────────────── */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.about-image-wrapper { position:relative; }
.dj-portrait { border-radius:20px; overflow:hidden; }
.dj-portrait img { width:100%; height:500px; object-fit:cover; object-position:center top; }
.floating-stat {
    position:absolute; bottom:-20px; right:-20px;
    padding:20px; text-align:center; min-width:150px;
}
.floating-stat .strong {
    display:block; font-family:var(--font-h);
    font-size:2.5rem; font-weight:800; line-height:1;
}
.about-text h2 { font-size:2.8rem; margin-bottom:24px; line-height:1.2; }
.about-text p  { color:var(--muted); margin-bottom:20px; font-size:1.05rem; }
.stats-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.stat-box h3  { font-size:2rem; color:#fff; margin-bottom:4px; }
.stat-box p   { color:var(--muted); font-size:.9rem; margin:0; }

/* ── MUSIC ──────────────────────────────── */
.tracks-container {
    max-width:820px; margin:0 auto;
    display:flex; flex-direction:column; gap:14px;
}
.track-row {
    display:flex; align-items:center;
    padding:14px 24px; gap:18px; transition:var(--ease);
}
.track-row:hover {
    transform:translateX(8px);
    border-color:rgba(255,255,255,.15);
    box-shadow:0 4px 18px rgba(0,0,0,.5);
}
.play-btn {
    width:46px; height:46px; border-radius:50%;
    background:linear-gradient(135deg, var(--accent), var(--accent2)); border:none; color:#111;
    font-size:1rem; display:flex; align-items:center; justify-content:center;
    cursor:pointer; transition:var(--ease);
    flex-shrink:0;
}
.play-btn:hover { transform:scale(1.1); filter:brightness(1.15); }
.track-info { flex:1; min-width:0; }
.track-info h3 { font-size:1.05rem; margin-bottom:3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.track-info p  { font-size:.82rem; color:var(--muted); }
.track-waveform {
    flex:2; height:4px; background:rgba(255,255,255,.1);
    border-radius:2px; position:relative; overflow:hidden;
    cursor:pointer; display:none;
}
@media (min-width:600px) { .track-waveform { display:block; } }
.waveform-bar {
    height:100%; background:linear-gradient(90deg, var(--accent), var(--accent2));
    position:absolute; left:0; top:0;
}
.track-time { font-family:var(--font-h); color:var(--muted); font-size:.88rem; width:58px; text-align:right; flex-shrink:0; }

/* ── EVENTS ─────────────────────────────── */
.events-list {
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
    gap:24px;
    margin-top:12px;
}

/* Card wrapper */
.event-card {
    display:flex; flex-direction:column;
    overflow:hidden; transition:var(--ease);
    border-radius:var(--radius);
}
.event-card:hover {
    transform:translateY(-4px);
    border-color:rgba(255,255,255,.18);
    box-shadow:0 16px 40px rgba(0,0,0,.6);
}

/* Card image */
.event-card-img {
    position:relative; width:100%; height:200px;
    overflow:hidden; flex-shrink:0;
}
.event-card-img img {
    width:100%; height:100%; object-fit:cover;
    transition:transform .55s ease;
}
.event-card:hover .event-card-img img { transform:scale(1.07); }

/* Genre tag — top left */
.event-genre-tag {
    position:absolute; top:12px; left:12px; z-index:2;
    padding:4px 11px;
    background:rgba(14,14,14,.78); color:var(--accent);
    border-radius:20px; font-size:.7rem; font-weight:700;
    letter-spacing:1px; text-transform:uppercase;
    backdrop-filter:blur(6px);
    border:1px solid rgba(255,255,255,.1);
}

/* Date badge — top right */
.event-date-badge {
    position:absolute; top:12px; right:12px; z-index:2;
    display:flex; flex-direction:column; align-items:center;
    background:rgba(10,10,10,.88); backdrop-filter:blur(8px);
    border:1px solid rgba(255,255,255,.1);
    border-radius:10px; padding:8px 12px; min-width:52px;
}
.eday {
    font-family:var(--font-h); font-size:1.6rem;
    font-weight:900; line-height:1; color:#fff;
}
.emonth {
    font-size:.65rem; font-weight:700; letter-spacing:2px;
    color:var(--muted); text-transform:uppercase;
}
.eyear {
    font-size:.6rem; font-weight:600; letter-spacing:1px;
    color:rgba(255,255,255,.3); margin-top:3px; padding-top:3px;
    border-top:1px solid rgba(255,255,255,.08);
    width:100%; text-align:center;
}

/* Card body */
.event-card-body {
    flex:1; display:flex; flex-direction:column;
    padding:20px 22px;
}
.event-card-body h3 {
    font-size:1.05rem; margin-bottom:10px; line-height:1.3;
}
.event-meta {
    color:var(--muted); font-size:.82rem;
    margin-bottom:5px; line-height:1.4;
}

/* Card footer */
.event-card-footer {
    display:flex; align-items:center;
    justify-content:space-between;
    margin-top:auto; padding-top:16px;
    border-top:1px solid var(--glass-border);
}
.event-price {
    font-family:var(--font-h); font-size:1.1rem;
    font-weight:800; color:#fff;
}
.event-sold-out {
    font-family:var(--font-h); font-size:.85rem;
    color:var(--muted); letter-spacing:1px;
}

/* ── GALLERY ────────────────────────────── */
.gallery-grid {
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:16px;
}
.gallery-item {
    position:relative; overflow:hidden;
    border-radius:12px; cursor:pointer;
    border:1px solid var(--glass-border);
    aspect-ratio:3/4;
}
.gallery-item img {
    width:100%; height:100%; object-fit:cover;
    transition:transform .5s ease;
}
.gallery-item:hover img { transform:scale(1.08); }
.gallery-overlay {
    position:absolute; inset:0;
    background:rgba(0,0,0,.45);
    display:flex; align-items:center; justify-content:center;
    opacity:0; transition:var(--ease);
    font-size:2rem;
}
.gallery-item:hover .gallery-overlay { opacity:1; }

/* ── LIGHTBOX ───────────────────────────── */
.lightbox {
    display:none; position:fixed; inset:0; z-index:2000;
    background:rgba(0,0,0,.95); backdrop-filter:blur(12px);
    align-items:center; justify-content:center;
}
.lightbox.open { display:flex; }
.lightbox-img-wrap {
    position:relative; max-width:90vw; max-height:85vh;
    display:flex; align-items:center; justify-content:center;
}
.lightbox-img-wrap img {
    max-width:90vw; max-height:82vh;
    border-radius:10px; box-shadow:0 0 40px rgba(0,0,0,.9);
    object-fit:contain; animation:lb-zoom .3s ease;
}
@keyframes lb-zoom { from{transform:scale(.9);opacity:0;} to{transform:scale(1);opacity:1;} }

.lightbox-close {
    position:absolute; top:16px; right:22px;
    background:none; border:none; color:#fff;
    font-size:2.6rem; cursor:pointer; z-index:2001;
    line-height:1; transition:var(--ease);
}
.lightbox-close:hover { color:var(--accent); }

.lightbox-nav {
    position:absolute; top:50%; transform:translateY(-50%);
    background:rgba(0,0,0,.55); border:1px solid var(--glass-border);
    color:#fff; font-size:1.8rem; padding:14px 18px;
    cursor:pointer; border-radius:10px; z-index:2001;
    transition:var(--ease);
}
.lightbox-nav:hover { background:rgba(255,255,255,.15); color:#fff; border-color:rgba(255,255,255,.3); }
.lightbox-prev { left:16px; }
.lightbox-next { right:16px; }

.lightbox-counter {
    position:absolute; bottom:18px; left:50%; transform:translateX(-50%);
    background:rgba(0,0,0,.6); color:#ccc; font-family:var(--font-h);
    font-size:.9rem; padding:5px 16px; border-radius:20px;
    letter-spacing:1px;
}

/* ── MODAL (Newsletter) ─────────────────── */
.modal-overlay {
    display:none; position:fixed; inset:0; z-index:2100;
    background:rgba(0,0,0,.85); backdrop-filter:blur(10px);
    align-items:center; justify-content:center; padding:20px;
}
.modal-overlay.open { display:flex; }
.modal-content {
    position:relative; width:100%; max-width:450px;
    padding:40px; animation: modal-show .4s cubic-bezier(.16,1,.3,1);
}
@keyframes modal-show { from{opacity:0;transform:scale(.9) translateY(20px);} to{opacity:1;transform:scale(1) translateY(0);} }

.modal-close {
    position:absolute; top:15px; right:20px;
    background:none; border:none; color:var(--muted);
    font-size:1.8rem; cursor:pointer; transition:var(--ease);
}
.modal-close:hover { color:#fff; }

.modal-header { text-align:center; margin-bottom:30px; }
.modal-header i { font-size:2.4rem; margin-bottom:15px; display:block; }
.modal-header h2 { font-size:2rem; margin-bottom:10px; }
.modal-header p { color:var(--muted); font-size:.92rem; }







/* ── ARTISTS ────────────────────────────── */
.artists-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 30px 20px;
    justify-content: center; /* Centra los artistas en la fila */
}

.artist-card {
    background: none;
    border: none;
    box-shadow: none;
    text-align: center;
    padding: 0;
    transition: var(--ease);
    width: 140px; /* Ancho fijo para controlar el tamaño */
}

    .artist-card:hover {
        transform: translateY(-5px);
    }

.artist-img-wrap {
    width: 110px; /* Círculo más pequeño */
    height: 110px;
    margin: 0 auto 12px;
    border-radius: 50%;
    border: 1px solid var(--glass-border);
    padding: 4px;
    transition: var(--ease);
    position: relative;
    overflow: hidden;
}

.artist-card:hover .artist-img-wrap {
    border-color: var(--accent);
    box-shadow: 0 0 15px var(--accent-glow);
}

.artist-img-wrap img {
    border-radius: 50%;
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(100%);
    transition: var(--ease);
}

.artist-card:hover img {
    filter: grayscale(0%);
    transform: scale(1.08);
}

.artist-info {
    padding: 0;
}

    .artist-info h3 {
        font-size: 0.9rem;
        letter-spacing: 0.5px;
        margin-bottom: 4px;
        text-transform: uppercase;
    }

    .artist-info p {
        font-size: 0.72rem;
        color: var(--muted);
        margin-bottom: 0;
    }

/* Cleanup extra elements */
.artist-genre-tag,
.artist-featured-badge,
.artist-socials {
    display: none;
}






/* ── LINEUP ─────────────────────────────── */
.lineup-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 30px;
    margin-top: 20px;
}
.lineup-card {
    padding: 30px 20px;
    text-align: center;
    transition: var(--ease);
    border: 1px solid var(--glass-border);
}
.lineup-card:hover {
    transform: translateY(-8px);
    border-color: rgba(255,255,255,.2);
    box-shadow: 0 12px 40px rgba(0,0,0,0.8);
}
.lineup-img {
    width: 140px;
    height: 140px;
    margin: 0 auto 20px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid rgba(255,255,255,0.1);
    transition: var(--ease);
}
.lineup-card:hover .lineup-img {
    border-color: var(--accent);
    transform: scale(1.05);
}
.lineup-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(1);
    transition: var(--ease);
}
.lineup-card:hover .lineup-img img {
    filter: grayscale(0.5);
}
.lineup-info h3 {
    font-size: 1.2rem;
    letter-spacing: 1px;
    margin-bottom: 5px;
    text-transform: uppercase;
}
.lineup-info p {
    font-size: 0.85rem;
    color: var(--muted);
    font-weight: 600;
    letter-spacing: 0.5px;
}

/* ── SOCIAL SECTION ─────────────────────── */
.social-grid-large {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    gap: 16px;
    justify-items: center;
    margin-top: 40px;
}
.social-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    transition: var(--ease);
}
.social-icon-box {
    width: 64px;
    height: 64px;
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--glass-border);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    color: #fff;
    transition: all 0.4s cubic-bezier(.4, 0, .2, 1);
}
.social-item span {
    font-family: var(--font-h);
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: var(--ease);
}
/* Redundant rules removed as they are now handled by :not(.disabled) blocks below */

/* Disabled State */
.social-item.disabled {
    pointer-events: none;
    cursor: default;
    user-select: none;
}

.social-item.disabled .social-icon-box {
    opacity: 0.25;
    filter: grayscale(1) brightness(0.9);
    background: rgba(255, 255, 255, 0.02);
    border: 1px dashed rgba(255, 255, 255, 0.08);
    box-shadow: none !important;
}

.social-item.disabled span {
    color: var(--muted);
    opacity: 0.4;
}

.social-item.disabled:hover .social-icon-box {
    transform: none;
}

/* Brand Colors (Enabled only) */
.social-item.instagram:not(.disabled) .social-icon-box { background: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%); border: none; }
.social-item.facebook:not(.disabled) .social-icon-box  { background: #1877F2; border-color: #1877F2; }
.social-item.youtube:not(.disabled) .social-icon-box   { background: #FF0000; border-color: #FF0000; }
.social-item.tiktok:not(.disabled) .social-icon-box    { background: #000; border-color: #fff; box-shadow: 2px 2px #ff0050, -2px -2px #00f2ea; }
.social-item.soundcloud:not(.disabled) .social-icon-box { background: #FF5500; border-color: #FF5500; }
.social-item.spotify:not(.disabled) .social-icon-box    { background: #1DB954; border-color: #1DB954; }
.social-item.twitch:not(.disabled) .social-icon-box     { background: #9146FF; border-color: #9146FF; }
.social-item.x-twitter:not(.disabled) .social-icon-box  { background: #000; border-color: #fff; }
.social-item.drive:not(.disabled) .social-icon-box      { background: #4285F4; border-color: #4285F4; }

/* ── TOAST NOTIFICATIONS ────────────────── */
.toast-container {
    position: fixed;
    top: 30px;
    right: 30px;
    z-index: 3000;
    display: flex;
    flex-direction: column;
    gap: 12px;
    pointer-events: none;
}
.toast {
    pointer-events: auto;
    min-width: 280px;
    max-width: 400px;
    padding: 16px 24px;
    background: rgba(15, 15, 15, 0.95);
    backdrop-filter: blur(12px);
    border-radius: 12px;
    border-left: 5px solid #fff;
    box-shadow: 0 10px 40px rgba(0,0,0,0.6);
    color: #fff;
    font-family: var(--font-h);
    font-size: 0.95rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 12px;
    transform: translateX(120%);
    transition: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
.toast.active { transform: translateX(0); }
.toast.leaving { transform: translateX(120%); opacity: 0; }

.toast.success { border-color: #00ff88; box-shadow: 0 5px 20px rgba(0,255,136,0.15); }
.toast.warning { border-color: #ffaa00; box-shadow: 0 5px 20px rgba(255,170,0,0.15); }
.toast.danger  { border-color: #ff3366; box-shadow: 0 5px 20px rgba(255,51,102,0.15); }

.toast i { font-size: 1.2rem; }
.toast.success i { color: #00ff88; }
.toast.warning i { color: #ffaa00; }
.toast.danger i  { color: #ff3366; }

/* Scale and Brightness on Hover for Enabled Items */
.social-item:not(.disabled):hover .social-icon-box {
    transform: translateY(-8px) scale(1.1);
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
    filter: brightness(1.1);
}

.social-item:not(.disabled) span {
    color: var(--muted);
}

.social-item:not(.disabled):hover span {
    color: #fff;
    opacity: 1;
}

@media (max-width: 480px) {
    .social-grid-large { grid-template-columns: repeat(3, 1fr); gap: 12px; }
    .social-icon-box { width: 52px; height: 52px; font-size: 1.3rem; }
}

/* ── CONTACT & BOOKING ──────────────────── */
.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 40px;
    align-items: start;
}
.contact-card {
    padding: 50px;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.contact-header {
    margin-bottom: 35px;
}
.contact-header i {
    font-size: 2.5rem;
    margin-bottom: 20px;
    display: block;
}
.contact-header h2 {
    font-size: 2.2rem;
    margin-bottom: 10px;
}
.contact-header p {
    color: var(--muted);
    font-size: 1rem;
    line-height: 1.5;
}

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

@media (max-width: 992px) {
    .contact-grid { grid-template-columns: 1fr; }
    .contact-card { padding: 40px 30px; }
}

@media (max-width:768px) {
    .artists-grid {
        display: flex;
        flex-wrap: wrap;
        gap: 15px 2%;
        justify-content: center;
    }

    .artist-card {
        width: 22%;
    }

    .artist-img-wrap {
        width: 80px;
        height: 80px;
    }
}

/* ── SHARED FORM STYLES ─────────────────── */
.modern-form .form-group { margin-bottom:18px; }
.modern-form label {
    display:block; margin-bottom:7px;
    font-family:var(--font-h); font-size:.88rem;
    color:var(--muted); letter-spacing:.5px;
}
.modern-form input,
.modern-form textarea,
.modern-form select {
    width:100%; padding:14px; background:rgba(0,0,0,.3);
    border:1px solid var(--glass-border); border-radius:8px;
    color:#fff; font-family:var(--font-b); font-size:1rem; transition:var(--ease);
}
.modern-form input:focus,
.modern-form textarea:focus { outline:none; border-color:rgba(255,255,255,.35); box-shadow:0 0 10px rgba(255,255,255,.05); }
.form-row { display:flex; gap:18px; }
.form-row .form-group { flex:1; }
.form-message { margin-top:14px; text-align:center; font-size:.9rem; }
.form-message.success { color:#00ff88; }
.form-message.error   { color:#ff3366; }

/* ── FOOTER ─────────────────────────────── */
.footer { padding:60px 0 20px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:40px; margin-bottom:40px; }
.footer-brand p { color:var(--muted); margin-top:14px; max-width:300px; }
.footer-links h4, .footer-social h4 { margin-bottom:18px; font-size:1.1rem; }
.footer-links a { display:block; color:var(--muted); margin-bottom:10px; }
.footer-links a:hover { color:var(--accent); padding-left:5px; }
.social-icons { display:flex; gap:12px; }
.social-icons a {
    width:40px; height:40px; border-radius:50%;
    background:var(--glass-bg); border:1px solid var(--glass-border);
    display:flex; align-items:center; justify-content:center;
    font-family:var(--font-h); font-weight:600; font-size:.85rem;
}
.social-icons a:hover { background:rgba(255,255,255,.12); color:#fff; }
.social-icons a.disabled {
    pointer-events: none;
    opacity: 0.25;
    filter: grayscale(1);
    border: 1px dashed rgba(255,255,255,0.1);
    background: transparent;
}
.footer-bottom { text-align:center; padding-top:20px; color:var(--muted); font-size:.88rem; }

/* ── RESPONSIVE ─────────────────────────── */
@media (max-width:1024px) {
    .gallery-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px) {
    .about-grid  { grid-template-columns:1fr; }
    .booking-box { flex-direction:column; }
    .hero h1     { font-size:3.8rem; }
    .footer-grid { grid-template-columns:1fr; text-align:center; }
    .footer-brand p { margin:14px auto; }
    .social-icons  { justify-content:center; }
}
@media (max-width:768px) {
    .nav-links     { display:none; }
    .back-link     { display:none; }
    .mobile-menu-btn { display:flex; }

    .events-list   { grid-template-columns:1fr; }

    .form-row      { flex-direction:column; gap:0; }
    .booking-info, .booking-form-wrapper { padding:30px 20px; }

    .lightbox-prev { left:6px; }
    .lightbox-next { right:6px; }
    .lightbox-nav  { padding:10px 14px; font-size:1.4rem; }
}
@media (max-width:540px) {
    .gallery-grid  { grid-template-columns:1fr 1fr; }
    .hero h1       { font-size:2.8rem; }
    .hero-buttons  { flex-direction:column; align-items:center; }
    .floating-stat { bottom:10px; right:10px; padding:12px; min-width:120px; }
    .floating-stat .strong { font-size:2rem; }
}
