/* Jammies Band — Good Vibes, Live. */
/* Fonts */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700&family=Fredoka:wght@600;700&display=swap');

/* ── Tokens ── */
:root {
  --bg: #FFF8F0;
  --bg-alt: #F5EDE3;
  --bg-card: #FFFFFF;
  --bg-dark: #4A2B72;
  --text: #1E1812;
  --text-muted: #8C7E72;
  --text-faint: #B0A090;
  --primary: #E8652B;
  --primary-rgb: 232, 101, 43;
  --primary-light: #F4945E;
  --primary-dark: #C44D1A;
  --accent: #6B3FA0;
  --accent-light: #9B72CC;
  --gold: #F2C94C;
  --border: #E8DDD0;
  --border-light: #F5EDE3;
  --nav-height: 4rem;
  --radius: 0.75rem;
  --radius-lg: 1.25rem;
  --radius-pill: 50rem;
  --shadow: 0 2px 12px rgba(0,0,0,.06);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.1);
  --transition: .25s cubic-bezier(.4,0,.2,1);
}
html.dark {
  --bg: #1E1812;
  --bg-alt: #2A2018;
  --bg-card: #352A22;
  --bg-dark: #2A1845;
  --text: #F5EDE3;
  --text-muted: #B0A090;
  --text-faint: #706050;
  --primary: #F4945E;
  --primary-rgb: 244, 148, 94;
  --primary-light: #FFA878;
  --primary-dark: #E8652B;
  --accent: #9B72CC;
  --accent-light: #B898E0;
  --gold: #F2C94C;
  --border: #3A3028;
  --border-light: #2A2018;
  --shadow: 0 2px 12px rgba(0,0,0,.2);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.3);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',system-ui,sans-serif;font-size:1.125rem;line-height:1.7;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;padding-bottom:2.25rem}
img,video,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit;color:inherit;border:none;background:none}
ul,ol{list-style:none}
h1,h2,h3,h4{font-family:'Fredoka',sans-serif;line-height:1.15;color:var(--text)}

/* ── Typography ── */
.hero-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;font-family:'Fredoka',sans-serif;line-height:1.15}
h2,.section-title{font-size:clamp(1.75rem,3vw,2.5rem);font-weight:600;font-family:'Fredoka',sans-serif;line-height:1.2}
h3{font-size:1.35rem;font-weight:600;font-family:'Fredoka',sans-serif}
.text-muted{color:var(--text-muted)}
.text-faint{color:var(--text-faint)}

/* ── Container ── */
.container{width:100%;max-width:72rem;margin:0 auto;padding:0 1.5rem}
@media(min-width:768px){.container{padding:0 2rem}}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.75rem;font-size:.9375rem;font-weight:700;font-family:'DM Sans',sans-serif;border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition);white-space:nowrap;text-decoration:none}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(var(--primary-rgb),.35)}
.btn-outline{border:2px solid var(--border);color:var(--text);background:transparent}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-white{background:#fff;color:var(--bg-dark)}
.btn-white:hover{background:var(--bg-alt);transform:translateY(-1px)}
.btn-ghost{color:rgba(255,255,255,.85);border:2px solid rgba(255,255,255,.3)}
.btn-ghost:hover{border-color:#fff;color:#fff}

/* ── Nav ── */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-height);display:flex;align-items:center;transition:background var(--transition),box-shadow var(--transition)}
.site-nav.scrolled{background:var(--bg);box-shadow:var(--shadow)}
.site-nav .container{display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:'Fredoka',sans-serif;font-weight:700;font-size:1.35rem;color:var(--text)}
.nav-logo span{color:var(--primary)}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.9375rem;font-weight:500;color:var(--text);transition:color var(--transition)}
.nav-links a:hover{color:var(--primary)}
.nav-cta{padding:.5rem 1.25rem;font-size:.875rem}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem;background:none;border:none}
.hamburger span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:all var(--transition)}

/* Dark hero nav contrast */
body.has-dark-hero .site-nav:not(.scrolled) .nav-logo{color:#fff}
body.has-dark-hero .site-nav:not(.scrolled) .nav-links a{color:rgba(255,255,255,.85)}
body.has-dark-hero .site-nav:not(.scrolled) .nav-links a:hover{color:#fff}
body.has-dark-hero .site-nav:not(.scrolled) .hamburger span{background:#fff}
body.has-dark-hero .site-nav:not(.scrolled) .theme-toggle svg{stroke:#fff}

/* Mobile nav */
@media(max-width:767px){
  .hamburger{display:flex}
  .nav-links{position:fixed;top:var(--nav-height);left:0;right:0;flex-direction:column;background:var(--bg);padding:1.5rem;gap:1rem;transform:translateY(-120%);opacity:0;transition:all var(--transition);box-shadow:var(--shadow-lg);border-bottom:1px solid var(--border)}
  .nav-links.open{transform:translateY(0);opacity:1}
  body.has-dark-hero .site-nav:not(.scrolled) .nav-links{background:var(--bg)}
  body.has-dark-hero .site-nav:not(.scrolled) .nav-links a{color:var(--text)}
}

/* ── Theme Toggle ── */
.theme-toggle{background:none;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center}
.theme-toggle svg{width:20px;height:20px;stroke:var(--text);fill:none;stroke-width:2;transition:stroke var(--transition)}
.theme-toggle:hover svg{stroke:var(--primary)}
html.dark .theme-toggle .icon-sun{display:block}
html.dark .theme-toggle .icon-moon{display:none}
html:not(.dark) .theme-toggle .icon-sun{display:none}
html:not(.dark) .theme-toggle .icon-moon{display:block}

/* ── Hero ── */
.hero{position:relative;min-height:85vh;display:flex;align-items:center;overflow:hidden;padding:calc(var(--nav-height) + 2rem) 0 3rem}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(74,43,114,.75) 0%,rgba(232,101,43,.6) 100%)}
.hero-content{position:relative;z-index:1;max-width:42rem}
.hero-content .hero-title{color:#fff;margin-bottom:1rem}
.hero-content .hero-sub{color:rgba(255,255,255,.88);font-size:1.125rem;line-height:1.7;margin-bottom:2rem;max-width:36rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}

/* ── Genre Groove Bar ── */
.groove-bar-wrap{position:relative;z-index:1;margin-top:3rem}
.groove-bar{display:flex;border-radius:var(--radius-pill);overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.2)}
.groove-bar .genre-block{flex:1;padding:.75rem 1rem;text-align:center;font-family:'Fredoka',sans-serif;font-weight:600;font-size:.9375rem;color:#fff;transition:transform .4s cubic-bezier(.4,0,.2,1);cursor:default}
.groove-bar .genre-block:nth-child(1){background:#E8652B}
.groove-bar .genre-block:nth-child(2){background:#2D9B4E}
.groove-bar .genre-block:nth-child(3){background:#6B3FA0}
.groove-bar .genre-block:nth-child(4){background:#D4544A}
.groove-bar.animate .genre-block{animation:groovePop .5s cubic-bezier(.34,1.56,.64,1) both}
.groove-bar.animate .genre-block:nth-child(2){animation-delay:.08s}
.groove-bar.animate .genre-block:nth-child(3){animation-delay:.16s}
.groove-bar.animate .genre-block:nth-child(4){animation-delay:.24s}
@keyframes groovePop{0%{transform:scaleX(0)}100%{transform:scaleX(1)}}

/* ── Section shared ── */
section{padding:5rem 0}
.section-label{font-size:.8125rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin-bottom:.5rem}
.section-title{margin-bottom:1rem}
.section-sub{color:var(--text-muted);max-width:36rem;margin-bottom:2.5rem}

/* ── Genre Cards ── */
.genre-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(15rem,1fr));gap:1.5rem}
.genre-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;transition:all var(--transition)}
.genre-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.genre-card .genre-icon{width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;font-size:1.25rem}
.genre-card:nth-child(1) .genre-icon{background:rgba(232,101,43,.12);color:#E8652B}
.genre-card:nth-child(2) .genre-icon{background:rgba(45,155,78,.12);color:#2D9B4E}
.genre-card:nth-child(3) .genre-icon{background:rgba(107,63,160,.12);color:#6B3FA0}
.genre-card:nth-child(4) .genre-icon{background:rgba(212,84,74,.12);color:#D4544A}
.genre-card h3{margin-bottom:.5rem}
.genre-card p{color:var(--text-muted);font-size:1rem;line-height:1.6}

/* ── Video ── */
.video-section{background:var(--bg-alt);text-align:center}
.video-section .section-title{margin-bottom:.5rem}
.video-section .section-sub{margin:0 auto 2.5rem}
.video-facade{position:relative;max-width:48rem;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;aspect-ratio:16/9;box-shadow:var(--shadow-lg)}
.video-facade img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition)}
.video-facade:hover img{transform:scale(1.03)}
.video-facade .play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:4.5rem;height:4.5rem;background:rgba(255,255,255,.95);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px rgba(0,0,0,.2);transition:all var(--transition)}
.video-facade:hover .play-btn{transform:translate(-50%,-50%) scale(1.08);background:#fff}
.play-btn svg{width:1.5rem;height:1.5rem;fill:var(--primary);margin-left:3px}

/* ── Testimonials ── */
.testimonials{background:var(--bg)}
.testimonial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(18rem,1fr));gap:1.5rem}
.testimonial-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem}
.testimonial-card blockquote{font-size:1.05rem;line-height:1.7;margin-bottom:1.25rem;color:var(--text);font-style:italic}
.testimonial-card cite{display:block;font-style:normal;font-size:.875rem;color:var(--text-muted);font-weight:500}
.testimonial-card .stars{color:var(--gold);margin-bottom:.75rem;font-size:1.1rem;letter-spacing:.15em}

/* ── CTA Banner ── */
.cta-banner{position:relative;background:var(--bg-dark);color:#fff;text-align:center;overflow:hidden}
.cta-banner::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(107,63,160,.3),rgba(232,101,43,.15));pointer-events:none}
.cta-banner .container{position:relative;z-index:1}
.cta-banner .section-title{color:#fff}
.cta-banner .section-sub{color:rgba(255,255,255,.8);margin:0 auto 2rem}
.cta-banner .cta-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin-bottom:1rem}
.cta-banner .cta-email{color:rgba(255,255,255,.65);font-size:.9375rem}
.cta-banner .cta-email a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.cta-banner .cta-email a:hover{color:#fff}

/* ── Footer ── */
.site-footer{background:var(--bg-alt);border-top:1px solid var(--border);padding:2.5rem 0}
.footer-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}
.footer-copy{font-size:.875rem;color:var(--text-muted)}
.footer-copy a{color:var(--primary);text-decoration:underline;text-underline-offset:3px}
.footer-copy a:hover{color:var(--primary-dark)}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{font-size:.875rem;color:var(--text-muted);transition:color var(--transition)}
.footer-links a:hover{color:var(--primary)}

/* ── About Page ── */
.page-header{padding:calc(var(--nav-height) + 3rem) 0 3rem;background:var(--bg-alt)}
.page-header h1{margin-bottom:.75rem}
.about-content{padding:4rem 0}
.about-content .about-text{max-width:42rem;font-size:1.125rem;line-height:1.8;color:var(--text)}
.about-content .about-text p{margin-bottom:1.5rem}
.about-content .about-cta{margin-top:2rem}

/* ── Contact Page ── */
.contact-section{padding:4rem 0}
.contact-grid{display:grid;grid-template-columns:1fr;gap:3rem}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-info h2{margin-bottom:1rem}
.contact-info p{color:var(--text-muted);margin-bottom:1.5rem;max-width:28rem}
.contact-info .info-item{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:var(--text-muted);font-size:1rem}
.contact-info .info-item svg{width:20px;height:20px;stroke:var(--primary);fill:none;stroke-width:2;flex-shrink:0}

/* ── Form ── */
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem;color:var(--text)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:1rem;color:var(--text);transition:border-color var(--transition)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.12)}
.form-group textarea{resize:vertical;min-height:7rem}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%238C7E72' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:480px){.form-row{grid-template-columns:1fr}}
.form-submit{margin-top:.5rem}
.form-status{margin-top:1rem;padding:1rem;border-radius:var(--radius);font-size:.9375rem;display:none}
.form-status.success{display:block;background:rgba(45,155,78,.1);color:#2D9B4E;border:1px solid rgba(45,155,78,.2)}
.form-status.error{display:block;background:rgba(212,84,74,.1);color:#D4544A;border:1px solid rgba(212,84,74,.2)}
.cf-turnstile{margin-bottom:1rem}

/* ── 404 ── */
.error-page{min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:calc(var(--nav-height) + 2rem) 1.5rem 4rem}
.error-page h1{font-size:clamp(2.5rem,6vw,4.5rem);margin-bottom:1rem}
.error-page p{color:var(--text-muted);font-size:1.125rem;margin-bottom:2rem;max-width:28rem;margin-left:auto;margin-right:auto}
.error-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}

/* ── Disclaimer Bar ── */
.disclaimer-bar{position:fixed;bottom:0;left:0;right:0;z-index:101;background:var(--bg-alt);border-top:1px solid var(--border);padding:.5rem 1rem;text-align:center;font-size:.75rem;color:var(--text-faint)}
.disclaimer-bar a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}

/* ── Animations ── */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up:nth-child(2){transition-delay:.1s}
.fade-up:nth-child(3){transition-delay:.2s}
.fade-up:nth-child(4){transition-delay:.3s}

/* ── Utilities ── */
.text-center{text-align:center}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
