/*
Theme Name: Pacific Soul Jazz Festival
Theme URI: https://pacificsouljazzfestival.com
Author: PSJF
Description: Custom WordPress theme for Pacific Soul Jazz Festival.
Version: 1.2
*/
:root{
  --navy:#06162a;--deep:#020b16;--gold:#f4ae17;--gold2:#d99100;--cream:#fffaf1;--white:#fff;--ink:#07162a;--muted:#526070;--line:#e9dfcf;
  --shadow:0 18px 45px rgba(6,22,42,.12);
}
*{box-sizing:border-box;margin:0;padding:0} html{scroll-behavior:smooth} body{font-family:'Inter',Arial,sans-serif;background:var(--cream);color:var(--ink);line-height:1.55} a{text-decoration:none;color:inherit} img{width:100%;display:block;object-fit:cover}.psjf-container{width:min(1210px,92vw);margin:0 auto}.psjf-section{padding:54px 0}.psjf-eyebrow{font-family:'Inter',sans-serif;color:var(--gold2);font-weight:900;text-transform:uppercase;letter-spacing:.04em;font-size:15px;margin-bottom:10px}.psjf-title{font-family:'Barlow Condensed',Impact,sans-serif;font-size:clamp(36px,4.2vw,55px);line-height:.88;text-transform:uppercase;color:var(--navy);font-weight:900;letter-spacing:-.018em;margin-bottom:15px}.psjf-line{width:47px;height:3px;background:var(--gold);margin:0 0 22px}.psjf-btn{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:12px 25px;border-radius:2px;font-weight:900;font-size:13px;text-transform:uppercase;letter-spacing:.01em;border:1.5px solid transparent;transition:.2s ease}.psjf-btn-gold{background:var(--gold);border-color:var(--gold);color:#051326}.psjf-btn-gold:hover{background:var(--gold2);border-color:var(--gold2)}.psjf-btn-outline{border-color:#06162a;color:#06162a;background:#ffffffc4}.psjf-btn-light{border-color:#ffffffb5;color:#fff;background:transparent}.psjf-btn-outline-gold{border-color:var(--gold);color:var(--navy);background:transparent}
.psjf-header{position:sticky;top:0;z-index:999;background:rgba(255,255,255,.97);box-shadow:0 1px 0 rgba(6,22,42,.06)}.psjf-nav{height:86px;display:flex;align-items:center;justify-content:space-between;gap:24px}.psjf-logo-img{width:150px;flex:0 0 150px}.psjf-logo-img img{height:auto}.psjf-menu{display:flex;gap:27px;align-items:center;font-size:13px;font-weight:900;text-transform:uppercase;color:#061326;white-space:nowrap}.psjf-menu a{padding:34px 0;border-bottom:3px solid transparent}.psjf-menu a:hover{color:var(--gold2);border-color:var(--gold)}.psjf-top-btn{min-width:138px}.psjf-menu-toggle{display:none;font-size:27px;color:var(--navy);font-weight:900}
.psjf-hero{min-height:475px;display:flex;align-items:center;background:linear-gradient(90deg,rgba(255,255,255,1) 0%,rgba(255,255,255,.96) 27%,rgba(255,255,255,.78) 45%,rgba(255,255,255,.08) 70%),url('assets/images/hero-daytime-amphitheater.jpg') right center/auto 100% no-repeat}.psjf-hero-inner{width:min(1210px,92vw);margin:0 auto}.psjf-hero-content{max-width:545px;padding:35px 0 25px}.psjf-hero h1{font-family:'Barlow Condensed',Impact,sans-serif;font-size:clamp(52px,6.6vw,76px);line-height:.86;font-weight:900;text-transform:uppercase;color:var(--navy);letter-spacing:-.025em;margin-bottom:18px}.psjf-hero p{font-size:17px;line-height:1.55;max-width:520px;margin-bottom:21px}.psjf-hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:28px}.psjf-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:740px}.psjf-meta-item{display:grid;grid-template-columns:32px 1fr;gap:10px;font-size:12px;text-transform:uppercase;font-weight:900;color:var(--navy);line-height:1.15}.psjf-meta-icon{font-size:26px;color:var(--gold2);line-height:1}.psjf-meta-item span{display:block;font-weight:700;text-transform:none;color:#26364b;margin-top:2px}
.psjf-subnav{background:var(--navy);color:#fff}.psjf-subnav-inner{width:min(1210px,92vw);height:50px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:58px;overflow-x:auto;text-transform:uppercase;font-size:13px;font-weight:900}.psjf-subnav a{height:50px;display:flex;align-items:center;border-bottom:3px solid transparent}.psjf-subnav a:first-child{color:var(--gold);border-color:var(--gold)}
.psjf-overview{display:grid;grid-template-columns:270px 1fr;gap:54px;align-items:start}.psjf-overview p{font-size:14.7px;margin-bottom:16px}.psjf-card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.psjf-card{background:transparent;border-radius:4px;overflow:hidden}.psjf-card img{height:165px;border-radius:4px}.psjf-card-body{padding:18px 6px 0}.psjf-card-icon{width:48px;height:48px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:21px;margin-top:-35px;margin-left:13px;margin-bottom:13px;position:relative;border:0}.psjf-card h3{font-family:'Inter',sans-serif;font-size:16px;color:var(--navy);text-transform:uppercase;font-weight:900;margin-bottom:8px;line-height:1.1}.psjf-card p{font-size:13px;color:#102036}
.psjf-highlights{padding:42px 0 48px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fffaf1}.psjf-three{display:grid;grid-template-columns:.95fr 1fr 1.1fr;gap:50px}.psjf-highlight{display:grid;grid-template-columns:42px 1fr;gap:16px;margin-bottom:22px}.psjf-highlight-icon{font-size:32px;color:var(--gold2);line-height:1}.psjf-highlight h4{text-transform:uppercase;margin-bottom:4px;font-size:14px;font-weight:900}.psjf-highlight p{font-size:12.8px;color:#1d2b3c}.psjf-tabs{display:flex;gap:9px;margin-bottom:17px}.psjf-tab{background:#fff;color:var(--navy);padding:10px 17px;border-radius:3px;font-size:11px;font-weight:900;text-transform:uppercase;border:1px solid var(--line)}.psjf-tab.active{background:var(--gold);border-color:var(--gold)}.psjf-schedule-row{display:grid;grid-template-columns:88px 1fr;border-bottom:1px solid #ddd4c6;padding:10px 0;font-size:12.5px}.psjf-schedule-row strong{color:var(--gold2);font-weight:900}.psjf-venue img{height:165px;border-radius:4px;margin-bottom:16px}.psjf-venue h3{font-size:16px;color:var(--gold2);text-transform:uppercase;margin-bottom:8px;font-weight:900}.psjf-venue p{font-size:13px;color:#1d2b3c}
.psjf-faq-wrap{display:grid;grid-template-columns:1.25fr .75fr;gap:50px;align-items:center}.psjf-faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px 21px}.psjf-faq details{background:#fff;border:1px solid #e8dfd1;border-radius:1px;padding:14px 17px}.psjf-faq summary{font-size:12.5px;font-weight:900;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:8px}.psjf-faq summary:after{content:'+';color:var(--gold2);font-size:18px;line-height:1}.psjf-faq details[open] summary:after{content:'–'}.psjf-faq p{margin-top:8px;color:var(--muted);font-size:13px}.psjf-faq-img img{height:210px;border-radius:4px;box-shadow:var(--shadow)}
.psjf-cta{background:linear-gradient(90deg,rgba(6,22,42,.96),rgba(6,22,42,.72)),url('assets/images/la-jolla-coast.jpg') center/cover no-repeat;color:#fff;padding:39px 0}.psjf-cta-inner{width:min(1210px,92vw);margin:0 auto;display:grid;grid-template-columns:1.15fr 1fr;gap:30px;align-items:center}.psjf-cta h2{font-family:'Barlow Condensed',Impact,sans-serif;font-size:clamp(32px,4vw,48px);line-height:.9;text-transform:uppercase;letter-spacing:-.015em;margin-bottom:10px}.psjf-cta p{font-size:14px;color:#fff}.psjf-cta-actions{display:flex;justify-content:flex-end;gap:14px;flex-wrap:wrap}.psjf-footer{background:var(--deep);color:white;padding:34px 0 22px}.psjf-footer-grid{display:grid;grid-template-columns:1.55fr repeat(4,1fr) 1.2fr;gap:24px;margin-bottom:24px}.psjf-footer-logo{width:145px;margin-bottom:12px}.psjf-footer h4{color:var(--gold);text-transform:uppercase;font-size:13px;margin-bottom:10px;font-weight:900}.psjf-footer a,.psjf-footer p{display:block;color:rgba(255,255,255,.78);font-size:12px;margin-bottom:5px}.psjf-produced{border:1px solid rgba(246,178,26,.65);padding:17px;text-align:center;border-radius:3px}.psjf-socials{display:flex;gap:10px;color:white;margin-top:12px}.psjf-copy{text-align:center;color:rgba(255,255,255,.55);font-size:11px;text-transform:uppercase;letter-spacing:.08em}
@media(max-width:1080px){.psjf-menu{display:none}.psjf-menu-toggle{display:block}.psjf-overview,.psjf-three,.psjf-faq-wrap,.psjf-cta-inner{grid-template-columns:1fr}.psjf-card-grid{grid-template-columns:repeat(2,1fr)}.psjf-cta-actions{justify-content:flex-start}.psjf-footer-grid{grid-template-columns:1fr 1fr}.psjf-hero{background:linear-gradient(90deg,rgba(255,255,255,.98),rgba(255,255,255,.85)),url('assets/images/hero-daytime-amphitheater.jpg') center/cover no-repeat}}
@media(max-width:680px){.psjf-nav{height:72px}.psjf-logo-img{width:115px;flex-basis:115px}.psjf-top-btn{display:none}.psjf-hero{min-height:auto;padding:35px 0}.psjf-meta,.psjf-card-grid,.psjf-faq-grid,.psjf-footer-grid{grid-template-columns:1fr}.psjf-subnav-inner{justify-content:flex-start;gap:28px}.psjf-btn{width:100%;text-align:center}.psjf-hero h1{font-size:50px}.psjf-section{padding:45px 0}.psjf-card img{height:210px}}
