/* 
 * ╔══════════════════════════════════════════════════════════════╗
 * ║  FLEUR DE SEL - STYLE SHEET                                  ║
 * ║  "Because jazz musicians deserve nice websites too"          ║
 * ║  Last updated: When the bass player finally arrived          ║
 * ╚══════════════════════════════════════════════════════════════╝
 */

/* 
 * Color palette inspired by:
 * - The North Sea on a Tuesday
 * - That one jazz club with the weird lighting
 * - Iris's favorite sweater
 */
:root {
            --color-bg: #4E83B5;
            --color-text: #E5ECF4;
            --color-dark: #2a4a6a;
            --color-accent: #f0e6d2;
            --color-overlay: rgba(46, 82, 118, 0.7);
        }

        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        html {
            scroll-behavior: smooth;
        }

        body {
            font-family: 'Jost', sans-serif;
            background-color: var(--color-bg);
            color: var(--color-text);
            line-height: 1.7;
            overflow-x: hidden;
        }

        
/* ═══════════════════════════════════════════════════════════════
   HERO SECTION
   "The first impression is like a jazz solo - make it count"
   ═══════════════════════════════════════════════════════════════ */
.hero {
            position: relative;
            min-height: 100vh;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            overflow: hidden;
            padding: 40px 20px;
        }

        
/*
 * Wave Animation
 * "Making the website float like a contrabass in zero gravity"
 */
.wave-container {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            z-index: 0;
            overflow: hidden;
        }

        .wave {
            position: absolute;
            bottom: 0;
            left: 0;
            width: 200%;
            height: 100%;
            background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320'%3E%3Cpath fill='%23ffffff' fill-opacity='0.03' d='M0,192L48,197.3C96,203,192,213,288,229.3C384,245,480,267,576,250.7C672,235,768,181,864,181.3C960,181,1056,235,1152,234.7C1248,235,1344,181,1392,154.7L1440,128L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z'%3E%3C/path%3E%3C/svg%3E") repeat-x;
            background-size: 50% 100%;
            animation: waveMove 15s linear infinite;
            opacity: 0.6;
        }

        .wave:nth-child(2) {
            bottom: -20px;
            animation-duration: 20s;
            animation-direction: reverse;
            opacity: 0.4;
        }

        .wave:nth-child(3) {
            bottom: -40px;
            animation-duration: 25s;
            opacity: 0.2;
        }

        
/*
 * Keyframe: waveMove
 * "The only thing that moves faster than our tempo changes"
 */
@keyframes waveMove {
            0% { transform: translateX(0); }
            100% { transform: translateX(-50%); }
        }

        
/*
 * Floating Particles
 * "Meeresluft" - because every website needs a bit of sea breeze
 */
.particles {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            z-index: 1;
            pointer-events: none;
        }

        .particle {
            position: absolute;
            width: 4px;
            height: 4px;
            background: rgba(255, 255, 255, 0.3);
            border-radius: 50%;
            animation: floatUp linear infinite;
        }

        
/*
 * Keyframe: floatUp
 * "Like our spirits after a good gig"
 */
@keyframes floatUp {
            0% {
                transform: translateY(100vh) scale(0);
                opacity: 0;
            }
            10% {
                opacity: 1;
            }
            90% {
                opacity: 0.5;
            }
            100% {
                transform: translateY(-10vh) scale(1);
                opacity: 0;
            }
        }

        .hero-content {
            position: relative;
            z-index: 2;
            text-align: center;
            max-width: 900px;
            animation: fadeInUp 1.5s ease-out;
        }

        
/*
 * Keyframe: fadeInUp
 * "Smooth entrance - unlike our first rehearsal"
 */
@keyframes fadeInUp {
            from {
                opacity: 0;
                transform: translateY(40px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        .hero-logo {
            max-width: 320px;
            width: 90%;
            margin-bottom: 40px;
            filter: drop-shadow(0 4px 20px rgba(0,0,0,0.2));
            animation: gentlePulse 4s ease-in-out infinite;
        }

        
/*
 * Keyframe: gentlePulse
 * "The heartbeat of the band (mostly coffee-induced)"
 */
@keyframes gentlePulse {
            0%, 100% { transform: scale(1); }
            50% { transform: scale(1.02); }
        }

        .hero-subtitle {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.6rem;
            font-weight: 300;
            font-style: italic;
            color: var(--color-accent);
            margin-bottom: 20px;
            letter-spacing: 2px;
            opacity: 0;
            animation: fadeInUp 1.5s ease-out 0.5s forwards;
        }

        .hero-description {
            font-size: 1.1rem;
            font-weight: 300;
            max-width: 600px;
            margin: 0 auto 40px;
            line-height: 1.8;
            opacity: 0;
            animation: fadeInUp 1.5s ease-out 0.8s forwards;
        }
        
/*
 * Keyframe: scrollBounce
 * "Bouncing like Iris when the setlist is approved"
 */
@keyframes scrollBounce {
            0%, 100% { transform: translateX(-50%) translateY(0); opacity: 1; }
            50% { transform: translateX(-50%) translateY(8px); opacity: 0.3; }
        }

        
/* ═══════════════════════════════════════════════════════════════
   BAND SECTION
   "Three musicians, one dream, zero roadies"
   ═══════════════════════════════════════════════════════════════ */
.band-section {
            position: relative;
            padding: 80px 20px;
            background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-bg) 100%);
        }

        .band-photo-container {
            max-width: 700px;
            margin: 0 auto;
            position: relative;
        }

        .band-photo {
            width: 100%;
            border-radius: 4px;
            box-shadow: 0 20px 60px rgba(0,0,0,0.4);
            transition: transform 0.6s ease, box-shadow 0.6s ease;
        }

        .band-photo-container:hover .band-photo {
            transform: scale(1.02);
            box-shadow: 0 30px 80px rgba(0,0,0,0.5);
        }

        .band-photo-frame {
            position: absolute;
            top: -15px;
            left: -15px;
            right: 15px;
            bottom: 15px;
            border: 0;
            border-radius: 4px;
            pointer-events: none;
            transition: all 0.6s ease;
        }

        .band-photo-container:hover .band-photo-frame {
            top: -20px;
            left: -20px;
            right: 20px;
            bottom: 20px;
            border-color: rgba(255,255,255,0.3);
        }

        .band-bio {
            max-width: 650px;
            margin: 50px auto 0;
            text-align: center;
        }

        .band-bio h2 {
            font-family: 'Cormorant Garamond', serif;
            font-size: 2rem;
            font-weight: 300;
            font-style: italic;
            margin-bottom: 25px;
            color: var(--color-accent);
        }

        .band-bio p {
            font-size: 1.05rem;
            font-weight: 300;
            line-height: 1.9;
            opacity: 0.9;
        }

        .members {
            margin-top: 30px;
            display: flex;
            justify-content: center;
            gap: 40px;
            flex-wrap: wrap;
        }

        .member {
            text-align: center;
        }

        .member-name {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.3rem;
            font-weight: 600;
            color: var(--color-accent);
        }

        .member-role {
            font-size: 0.9rem;
            font-weight: 300;
            opacity: 0.7;
            margin-top: 4px;
        }


/* ═══════════════════════════════════════════════════════════════
   CONCERTS SECTION
   "Where and when to find us (please bring your own chair)"
   ═══════════════════════════════════════════════════════════════ */
.concerts-section {
            background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-dark) 100%);
            position: relative;
            overflow: hidden;
            padding: 100px 40px;
        }
        .concerts-content {
            position: relative;
            z-index: 2;
            max-width: 800px;
            margin: 0 auto;
        }

        .section-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: 2.5rem;
            font-weight: 300;
            text-align: center;
            margin-bottom: 60px;
            color: var(--color-accent);
            position: relative;
        }

        .section-title::after {
            content: '';
            display: block;
            width: 60px;
            height: 1px;
            background: rgba(255,255,255,0.3);
            margin: 20px auto 0;
        }

        .concert-list {
            list-style: none;
        }

        .concert-item {
            display: flex;
            align-items: center;
            padding: 25px 0;
            border-bottom: 1px solid rgba(255,255,255,0.1);
            transition: all 0.4s ease;
            opacity: 0;
            transform: translateX(-20px);
        }

        .concert-item.visible {
            opacity: 1;
            transform: translateX(0);
        }

        .concert-item:hover {
            padding-left: 15px;
            border-bottom-color: rgba(255,255,255,0.3);
        }

        .concert-date {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.4rem;
            font-weight: 600;
            min-width: 140px;
            color: var(--color-accent);
						padding-right: 10px;
        }

        .concert-venue {
            flex: 1;
            font-size: 1.1rem;
            font-weight: 300;
        }

        .concert-btn {
            padding: 8px 20px;
            border: 1px solid rgba(255,255,255,0.3);
            background: transparent;
            color: var(--color-text);
            font-family: 'Jost', sans-serif;
            font-size: 0.85rem;
            font-weight: 400;
            cursor: pointer;
            border-radius: 2px;
            transition: all 0.3s ease;
            text-decoration: none;
            display: inline-block;
        }

        .concert-btn:hover {
            background: var(--color-text);
            color: var(--color-dark);
            border-color: var(--color-text);
        }

        
/* ═══════════════════════════════════════════════════════════════
   FOOTER
   "The end of the page, but not the end of the music"
   ═══════════════════════════════════════════════════════════════ */
.footer {
            padding: 80px 20px 40px;
            background: var(--color-dark);
            text-align: center;
            border-top: 1px solid rgba(255,255,255,0.08);
        }

        .footer-logo {
            max-width: 180px;
            margin-bottom: 30px;
            opacity: 0.7;
        }

        .footer-links {
            display: flex;
            justify-content: center;
            gap: 30px;
            margin-bottom: 40px;
            flex-wrap: wrap;
        }

        .footer-link {
            color: var(--color-text);
            text-decoration: none;
            font-size: 0.95rem;
            font-weight: 300;
            position: relative;
            padding-bottom: 4px;
            transition: color 0.3s ease;
        }

        .footer-link::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            width: 0;
            height: 1px;
            background: var(--color-accent);
            transition: width 0.3s ease;
        }

        .footer-link:hover {
            color: var(--color-accent);
        }

        .footer-link:hover::after {
            width: 100%;
        }

        .social-links {
            display: flex;
            justify-content: center;
            gap: 20px;
            margin-bottom: 40px;
        }

        .social-icon {
            width: 44px;
            height: 44px;
            border: 1px solid rgba(255,255,255,0.2);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--color-text);
            text-decoration: none;
            transition: all 0.3s ease;
        }

        .social-icon:hover {
            background: var(--color-text);
            color: var(--color-dark);
            border-color: var(--color-text);
            transform: translateY(-3px);
        }

        .copyright {
            font-size: 0.85rem;
            opacity: 0.5;
            font-weight: 300;
        }

        
/*
 * Mobile Styles
 * "Because even jazz musicians check their phones"
 */
@media (max-width: 600px) {
            .hero-logo {
                max-width: 240px;
            }

            .hero-subtitle {
                font-size: 1.2rem;
            }

            .hero-description {
                font-size: 1rem;
            }

            .section-title {
                font-size: 2rem;
            }
            /* Mobile needs breathing room - no more edge-hugging concerts */
            .concerts-section {
                padding: 60px 20px;
            }

            .concert-item {
                flex-direction: column;
                align-items: flex-start;
                gap: 10px;
            }

            .concert-date {
                min-width: auto;
            }

            .members {
                gap: 25px;
            }

        }
