/* ========================================
   The Screenhouse — Global Stylesheet
   ======================================== */

/* --- Tokens --- */
:root{
  --navy:#06243A;--deep-navy:#031827;--black:#050505;
  --cream:#F4E1C7;--soft-white:#F8F5EF;
  --gold:#F5B11A;--orange:#E86F1C;--red-orange:#C8431F;
  --teal:#0C7893;--blue-teal:#0E5268;--muted-blue:#2D6F8B;
  --text-dark:#101820;--text-light:#FFFFFF;
  --radius:12px;--radius-sm:8px;
  --shadow:0 4px 24px rgba(0,0,0,.35);
  --transition:all .25s ease;
  --max-w:1120px;
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:16px;line-height:1.6;color:var(--text-dark);background:var(--soft-white)}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* --- Typography --- */
h1,h2,h3,.display-heading{font-family:"Bebas Neue","Oswald",Impact,sans-serif;letter-spacing:.03em;text-transform:uppercase;line-height:1.1}
h1{font-size:clamp(2.2rem,5vw,3.6rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem)}
h3{font-size:clamp(1.1rem,2vw,1.4rem)}
.kicker{font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;font-weight:600}
.text-muted{color:#6b7280}
.text-cream{color:var(--cream)}
.text-gold{color:var(--gold)}

/* --- Container --- */
.container{width:min(var(--max-w),100%);margin-inline:auto;padding-inline:1.25rem}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border:2px solid transparent;border-radius:999px;padding:.75rem 1.5rem;font-family:"Bebas Neue",sans-serif;font-weight:700;font-size:1rem;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:var(--transition);text-decoration:none;white-space:nowrap}
.btn-gold{background:var(--gold);color:var(--text-dark);border-color:var(--gold)}
.btn-gold:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.btn-outline{background:transparent;border-color:rgba(255,255,255,.4);color:#fff}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-outline-dark{background:transparent;border-color:var(--navy);color:var(--navy)}
.btn-outline-dark:hover{border-color:var(--gold);color:var(--gold)}
.btn-teal{background:var(--teal);color:#fff;border-color:var(--teal)}
.btn-teal:hover{background:var(--blue-teal);border-color:var(--blue-teal)}
.btn-sm{padding:.5rem 1rem;font-size:.85rem}
.btn-lg{padding:.9rem 2rem;font-size:1.1rem}

/* ===== HEADER ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--deep-navy);border-bottom:1px solid rgba(255,255,255,.06);transition:background .3s,box-shadow .3s}
.site-header.scrolled{background:rgba(3,24,39,.97);box-shadow:0 2px 20px rgba(0,0,0,.5)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.header-logo img{height:44px;width:auto}
.header-nav{display:flex;gap:1.1rem;align-items:center}
.header-nav a{color:rgba(255,255,255,.75);font-size:.88rem;font-weight:500;transition:var(--transition);white-space:nowrap}
.header-nav a:hover,.header-nav a.active{color:var(--gold)}
.header-phone{display:flex;align-items:center;gap:.3rem;color:var(--gold);font-size:.85rem;font-weight:700;white-space:nowrap}
.header-phone svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}
.header-cta{margin-left:.6rem}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:28px;padding:0}
.nav-toggle span{display:block;height:2px;background:#fff;border-radius:2px;transition:var(--transition)}

@media(max-width:900px){
  .header-nav{position:fixed;top:64px;left:0;right:0;bottom:0;background:var(--deep-navy);flex-direction:column;padding:2rem 1.5rem;gap:1.5rem;transform:translateX(100%);transition:transform .3s ease;z-index:999}
  .header-nav.open{transform:translateX(0)}
  .header-nav a{font-size:1.15rem;color:#fff}
  .nav-toggle{display:flex}
  .header-cta{display:none}
}

/* ===== HERO ===== */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:6rem 1.25rem 4rem;background:linear-gradient(160deg,var(--black) 0%,var(--deep-navy) 50%,var(--navy) 100%);overflow:hidden;color:#fff}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,rgba(245,177,26,.08),transparent 60%),radial-gradient(circle at 80% 70%,rgba(12,120,147,.06),transparent 50%);pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:780px}
.hero h1{margin-bottom:.8rem;color:#fff}
.hero .sub{font-size:clamp(1rem,2vw,1.2rem);color:rgba(255,255,255,.75);max-width:600px;margin:0 auto 1.5rem;line-height:1.6}
.hero .btn-row{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap}
.hero .rotating-text{color:var(--gold);display:inline}

/* ===== SECTIONS ===== */
.section{padding:4rem 0}
.section-dark{background:var(--deep-navy);color:#fff}
.section-navy{background:var(--navy);color:#fff}
.section-cream{background:var(--cream);color:var(--text-dark)}
.section-header{text-align:center;max-width:640px;margin:0 auto 2rem}
.section-header p{color:#6b7280;margin-top:.4rem}
.section-dark .section-header p,.section-navy .section-header p{color:rgba(255,255,255,.6)}

/* ===== CARDS ===== */
.card-grid{display:grid;gap:1.25rem}
.cols-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.cols-3{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.cols-4{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.card{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius);padding:1.5rem;transition:var(--transition)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card .icon{font-size:2rem;margin-bottom:.6rem}
.card h3{margin-bottom:.35rem;text-transform:none;font-family:"Inter",sans-serif;font-weight:700;font-size:1.05rem;letter-spacing:0}
.card p{color:#6b7280;font-size:.92rem;line-height:1.55}

.card-dark{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);color:#fff}
.card-dark:hover{border-color:var(--gold);background:rgba(255,255,255,.08)}
.card-dark h3{color:var(--gold)}
.card-dark p{color:rgba(255,255,255,.65)}

/* ===== FEATURE COLUMNS ===== */
.feature-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.feature-col{text-align:center;padding:2rem 1.5rem;border-radius:var(--radius);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);transition:var(--transition)}
.feature-col:hover{border-color:var(--gold)}
.feature-col h3{margin:.8rem 0 .4rem;color:var(--gold)}
.feature-col p{color:rgba(255,255,255,.65);font-size:.92rem}

/* ===== STATS ===== */
.stats-row{display:flex;justify-content:center;gap:2.5rem;flex-wrap:wrap;padding:1.5rem 0}
.stat{text-align:center}
.stat .num{font-family:"Bebas Neue",sans-serif;font-size:clamp(2rem,4vw,2.8rem);color:var(--gold);line-height:1}
.stat .label{font-size:.8rem;color:#6b7280;margin-top:.2rem}
.section-dark .stat .label{color:rgba(255,255,255,.5)}

/* ===== PAGE HERO (inner pages) ===== */
.page-hero{background:linear-gradient(160deg,var(--black),var(--deep-navy),var(--navy));color:#fff;padding:7rem 0 3rem;text-align:center}
.page-hero .kicker{color:var(--gold)}
.page-hero h1{margin-bottom:.6rem}
.page-hero p{color:rgba(255,255,255,.7);max-width:600px;margin:0 auto;font-size:1.05rem;line-height:1.6}

/* ===== FAQ ===== */
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border-bottom:1px solid rgba(0,0,0,.08);padding:1rem 0}
.section-dark .faq-item{border-color:rgba(255,255,255,.1)}
.faq-q{display:flex;justify-content:space-between;align-items:center;width:100%;text-align:left;font-weight:600;font-size:1rem;padding:0;color:inherit;background:none;border:none;cursor:pointer}
.faq-q::after{content:'+';font-size:1.3rem;color:var(--gold);flex-shrink:0;margin-left:1rem;transition:var(--transition)}
.faq-item.open .faq-q::after{content:'−'}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;font-size:.92rem;line-height:1.6;color:#6b7280}
.section-dark .faq-a{color:rgba(255,255,255,.6)}
.faq-a-inner{padding:.6rem 0 .5rem}
.faq-item.open .faq-a{max-height:400px}

/* ===== FORMS ===== */
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.3rem}
.form-input{width:100%;padding:.7rem .9rem;border:1px solid rgba(0,0,0,.15);border-radius:var(--radius-sm);font-family:inherit;font-size:.95rem;background:#fff;color:var(--text-dark);transition:var(--transition)}
.form-input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(12,120,147,.15)}
select.form-input{appearance:auto}
textarea.form-input{resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}

/* ===== MAP ===== */
.map-frame{border-radius:var(--radius);overflow:hidden;border:1px solid rgba(0,0,0,.1);min-height:300px}
.map-frame iframe{width:100%;height:100%;min-height:300px;border:0}

/* ===== NEWSLETTER ===== */
.newsletter{background:var(--navy);color:#fff;padding:3rem 0}
.newsletter-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.newsletter h3{font-family:"Bebas Neue",sans-serif;font-size:1.5rem;letter-spacing:.04em;text-transform:uppercase}
.newsletter p{color:rgba(255,255,255,.6);font-size:.9rem}
.newsletter-form{display:flex;gap:.5rem}
.newsletter-form input{min-width:240px;padding:.7rem .9rem;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);background:rgba(255,255,255,.08);color:#fff;font-size:.95rem}
.newsletter-form input::placeholder{color:rgba(255,255,255,.4)}
.newsletter-form input:focus{outline:none;border-color:var(--gold)}
@media(max-width:700px){.newsletter-inner{flex-direction:column;text-align:center}.newsletter-form{width:100%;flex-direction:column}.newsletter-form input{min-width:0;width:100%}}

/* ===== FOOTER ===== */
.site-footer{background:var(--black);color:rgba(255,255,255,.7);padding:3.5rem 0 0}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem}
.footer-brand img{height:50px;margin-bottom:.6rem}
.footer-tagline{font-size:.88rem;color:rgba(255,255,255,.5);max-width:280px;line-height:1.5}
.footer-col h4{font-family:"Bebas Neue",sans-serif;font-size:1rem;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem}
.footer-col a{display:block;font-size:.88rem;color:rgba(255,255,255,.6);padding:.2rem 0;transition:var(--transition)}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{margin-top:2.5rem;padding:1.2rem 0;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:rgba(255,255,255,.35)}
@media(max-width:768px){.footer-inner{grid-template-columns:1fr 1fr;gap:1.5rem}.footer-bottom{flex-direction:column;gap:.4rem;text-align:center}}
@media(max-width:480px){.footer-inner{grid-template-columns:1fr}}

/* ===== COMING SOON ===== */
.coming-soon{min-height:100vh;display:grid;place-items:center;padding:2rem;background:linear-gradient(160deg,var(--black),var(--deep-navy),var(--navy));color:#fff;text-align:center}
.coming-soon-card{max-width:520px;width:100%}
.coming-soon-card img{height:576px;max-width:90vw;object-fit:contain;margin:0 auto 2rem;display:block}
.coming-soon-card h1{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:.6rem}
.coming-soon-card p{color:rgba(255,255,255,.6);margin-bottom:1.5rem;font-size:1rem}
.coming-soon-card .gold{color:var(--gold);font-weight:700}

/* ===== CTA BLOCK ===== */
.cta-block{text-align:center;padding:4rem 0}
.cta-block h2{margin-bottom:.6rem}
.cta-block p{max-width:50ch;margin:0 auto .8rem}
.cta-block .btn-row{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}

/* ===== TWO-COL LAYOUT ===== */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start}
@media(max-width:768px){.two-col{grid-template-columns:1fr}}

/* ===== GREAT-FOR LIST ===== */
.great-for{columns:2;gap:1rem}
.great-for li{padding:.3rem 0;font-size:.92rem;color:#6b7280;break-inside:avoid}
.great-for li::before{content:'✓ ';color:var(--teal);font-weight:700}
@media(max-width:600px){.great-for{columns:1}}

/* ===== PROGRAM CARDS ===== */
.program-card{border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);padding:2rem;transition:var(--transition)}
.program-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.program-card h3{color:var(--gold);margin-bottom:.4rem}
.program-card p{color:rgba(255,255,255,.6);font-size:.92rem;margin-bottom:.8rem}

/* ===== CALENDAR PLACEHOLDER ===== */
.calendar-placeholder{text-align:center;padding:3rem 2rem;background:rgba(0,0,0,.03);border:2px dashed rgba(0,0,0,.1);border-radius:var(--radius);color:#6b7280}
.section-dark .calendar-placeholder{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.1);color:rgba(255,255,255,.5)}

/* ===== UTILITY ===== */
.text-center{text-align:center}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}

/* ===== PRINT ===== */
@media print{.site-header,.site-footer,.newsletter,.btn,.nav-toggle{display:none!important}body{background:#fff;color:#222}}
