/*
Theme Name: CBA Theme
Description: Custom theme for Cabramatta Business Alliance Incorporated — "Stronger Together". Navy + rainbow brand, ported from the approved demo design.
Author: CBA
Version: 1.0
*/

:root{
  --navy:#1F3A93; --navy-d:#162a6b; --orange:#E8491D; --ink:#1c2230;
  --muted:#697586; --line:#e6e9f0; --bg:#f7f8fb; --white:#fff;
  --rainbow:linear-gradient(90deg,#e8491d,#f2a31b,#f4d11a,#3aaa57,#1f7fd1,#5b3fb0);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:Arial,Helvetica,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.wrap{max-width:1160px;margin:0 auto;padding:0 22px}
.rainbow-bar{height:5px;background:var(--rainbow)}
.photo-frame{display:block;overflow:hidden;background:#e9edf5;line-height:0;border-radius:14px;min-width:0;max-width:100%}
.photo-frame img{width:100%;height:100%;display:block;object-fit:cover}
.hero-photo{aspect-ratio:16/10;min-height:300px}
.member-photo{border-radius:0;min-height:230px;height:100%}
.event-photo{border-radius:0;aspect-ratio:16/9}
.contact-map{aspect-ratio:1100/520;min-height:260px}
section{padding:64px 0}
h2.title{font-size:30px;color:var(--navy);margin-bottom:10px}
p.lead{color:var(--muted);max-width:680px;margin-bottom:30px}
.btn{display:inline-block;padding:12px 22px;border-radius:8px;font-weight:bold;font-size:15px;cursor:pointer;border:0}
.btn-primary{background:var(--orange);color:#fff}
.btn-navy{background:var(--navy);color:#fff}
.btn-ghost{background:transparent;border:2px solid #fff;color:#fff}
.btn-outline{background:#fff;border:2px solid var(--navy);color:var(--navy)}
/* HEADER */
header.nav{position:sticky;top:0;z-index:50;background:#fff;box-shadow:0 2px 10px rgba(20,30,70,.06)}
.navrow{display:flex;align-items:center;justify-content:space-between;padding:12px 22px}
.brand{display:flex;align-items:center;gap:12px}
.logo{width:52px;height:52px;flex:none;object-fit:contain}
.brand b{color:var(--navy);font-size:18px;line-height:1.1;display:block}
.brand span{color:var(--orange);font-size:11px;font-weight:bold;letter-spacing:.05em}
nav.menu{display:flex;align-items:center;gap:22px}
nav.menu a{font-size:14px;font-weight:bold;color:#3a4252}
nav.menu a:hover{color:var(--navy)}
.menu-btn{display:none;background:none;border:0;font-size:26px;color:var(--navy);cursor:pointer}
/* HERO */
.hero{background:linear-gradient(120deg,var(--navy),var(--navy-d));color:#fff;position:relative;overflow:hidden}
.hero .grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding:70px 22px}
.hero .grid>*{min-width:0}
.hero h1{font-size:46px;line-height:1.08;margin-bottom:16px}
.hero h1 .accent{background:var(--rainbow);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{font-size:18px;opacity:.92;margin-bottom:26px;max-width:520px}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap}
.hero .ph{min-height:300px}
.stats{display:flex;gap:30px;margin-top:34px}
.stats div b{font-size:26px;display:block}
.stats div span{font-size:13px;opacity:.8}
/* SPONSOR SLIDER */
.band-light{background:#fff}
.slider-head{text-align:center;margin-bottom:26px}
.slider-head h2{color:var(--navy);font-size:24px}
.slider-head p{color:var(--muted);font-size:14px}
.marquee{overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee .track{display:flex;gap:26px;width:max-content;animation:scroll 22s linear infinite}
.marquee:hover .track{animation-play-state:paused}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.splogo{width:180px;height:90px;flex:none;background:#f1f4fa;border:1px solid var(--line);border-radius:12px;
  display:flex;align-items:center;justify-content:center;color:#8a93a4;font-weight:bold;font-size:14px;text-align:center;padding:8px}
/* NEW MEMBERS SLIDER */
.band-soft{background:#eef2fb}
.nm-slider{position:relative;max-width:920px;margin:0 auto}
.nm-slide{display:none;background:#fff;border-radius:16px;box-shadow:0 10px 30px rgba(20,30,70,.08);
  overflow:hidden;grid-template-columns:1fr 1.2fr}
.nm-slide.active{display:grid}
.nm-body{padding:28px}
.nm-cat{display:inline-block;background:#eaf0fb;color:var(--navy);font-size:12px;font-weight:bold;
  padding:4px 10px;border-radius:20px;margin-bottom:10px}
.nm-body h3{font-size:24px;color:var(--navy);margin-bottom:8px}
.nm-body p{color:var(--muted);margin-bottom:14px}
.nm-dots{display:flex;gap:8px;justify-content:center;margin-top:18px}
.nm-dots button{width:10px;height:10px;border-radius:50%;border:0;background:#c4cde0;cursor:pointer}
.nm-dots button.on{background:var(--navy);width:26px;border-radius:6px}
/* BENEFITS */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px}
.card .ic{width:46px;height:46px;border-radius:12px;background:var(--rainbow);display:flex;align-items:center;
  justify-content:center;font-size:22px;margin-bottom:14px}
.card h4{color:var(--navy);margin-bottom:6px;font-size:17px}
.card p{font-size:14px;color:var(--muted)}
/* EVENTS */
.ev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ev{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.ev .body{padding:18px}
.ev .date{color:var(--orange);font-weight:bold;font-size:13px}
.ev h4{color:var(--navy);margin:6px 0;font-size:18px}
.ev p{font-size:14px;color:var(--muted)}
/* DIRECTORY */
.band-white{background:#fff}
.search{display:flex;gap:10px;max-width:560px;margin-bottom:26px}
.search input{flex:1;padding:13px 16px;border:1px solid var(--line);border-radius:8px;font-size:15px}
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cat{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:22px;text-align:center}
.cat .e{font-size:30px}
.cat b{display:block;color:var(--navy);margin-top:8px}
.cat span{font-size:13px;color:var(--muted)}
/* MEMBERSHIP */
.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.tier{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;text-align:center}
.tier.feat{border:2px solid var(--orange);box-shadow:0 10px 30px rgba(232,73,29,.12)}
.tier h4{color:var(--navy);font-size:18px}
.tier .price{font-size:26px;font-weight:bold;color:var(--ink);margin:10px 0}
.tier .price small{font-size:13px;color:var(--muted);font-weight:normal}
.tier ul{list-style:none;text-align:left;margin:14px 0;font-size:14px;color:var(--muted)}
.tier li{padding:5px 0 5px 22px;position:relative}
.tier li::before{content:"\2713";position:absolute;left:0;color:#3aaa57;font-weight:bold}
/* JOIN FORM */
.band-navy{background:linear-gradient(120deg,var(--navy),var(--navy-d));color:#fff}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:720px}
.form-grid input,.form-grid select,.form-grid textarea{padding:12px 14px;border-radius:8px;border:0;font-size:15px;font-family:inherit;width:100%}
.form-grid .full{grid-column:1/3}
/* CF7 join form -> reuse .form-grid (autop disabled in functions.php) */
#join .form-grid{max-width:720px}
#join .form-grid .wpcf7-form-control-wrap{display:block;width:100%}
#join .wpcf7-form input,#join .wpcf7-form select,#join .wpcf7-form textarea{width:100%;padding:12px 14px;border-radius:8px;border:0;font-size:15px;font-family:inherit}
#join .wpcf7-form input.wpcf7-submit{background:var(--orange);color:#fff;font-weight:bold;width:auto;cursor:pointer;padding:12px 22px}
#join .wpcf7-response-output{grid-column:1/3;margin:14px 0 0;color:#fff;border-radius:8px}
/* CTA BAND */
.ctaband{background:var(--rainbow);color:#fff;text-align:center;padding:56px 0}
.ctaband h2{font-size:30px;margin-bottom:8px;text-shadow:0 2px 8px rgba(0,0,0,.18)}
.ctaband p{margin-bottom:22px;font-weight:bold}
/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}
.contact-grid .ph{min-height:260px}
.cinfo div{margin-bottom:14px}
.cinfo b{color:var(--navy)}
/* FOOTER */
footer{background:#0f1830;color:#aeb8cc;padding:46px 0 0}
.fcols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:30px;padding-bottom:30px}
footer h5{color:#fff;margin-bottom:12px;font-size:15px}
footer a{display:block;font-size:14px;padding:4px 0;color:#aeb8cc}
footer a:hover{color:#fff}
.gov{border-top:1px solid #24304f;padding:18px 0;font-size:12.5px;color:#7f8aa3;text-align:center}
.social{display:flex;gap:10px;margin-top:10px}
.social span{width:36px;height:36px;border-radius:50%;background:#1c294a;display:flex;align-items:center;justify-content:center}
/* INNER PAGE HERO */
.page-hero{background:linear-gradient(120deg,var(--navy),var(--navy-d));color:#fff;padding:66px 0 54px}
.page-hero h1{font-size:40px;margin-bottom:10px}
.page-hero p{opacity:.9;max-width:660px;font-size:17px}
/* DIRECTORY */
.dir-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}
.dir-filter .chip{border:1px solid var(--line);background:#fff;color:#3a4252;font-weight:bold;font-size:14px;padding:8px 16px;border-radius:30px;cursor:pointer}
.dir-filter .chip.on,.dir-filter .chip:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.dir-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.dir-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
.dir-card.feat{border:2px solid var(--orange)}
.dir-photo{aspect-ratio:16/10;min-height:160px;background:#e9edf5}
.dir-body{padding:18px;position:relative}
.dir-feat{position:absolute;top:-12px;right:14px;background:var(--orange);color:#fff;font-size:11px;font-weight:bold;padding:3px 10px;border-radius:20px}
.dir-body h4{color:var(--navy);margin:8px 0 6px;font-size:18px}
.dir-body p{font-size:14px;color:var(--muted);margin-bottom:8px}
.dir-meta{font-size:13px;color:var(--muted)}
.dir-meta div{margin:2px 0}
/* SPONSOR WALL */
.sponsor-wall{display:flex;flex-wrap:wrap;gap:18px}
.sponsor-wall .splogo{width:190px;height:96px}
/* PHOTO FALLBACK */
.photo-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy),var(--navy-d))}
.photo-ph span{font-size:46px;line-height:1}
/* ABOUT PAGE */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.mv{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px;border-top:4px solid var(--orange)}
.mv h3{color:var(--navy);font-size:20px;margin-bottom:8px}
.mv p{color:var(--muted)}
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.value{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px;text-align:center;font-weight:bold;color:var(--navy)}
.value::before{content:"";display:block;height:4px;width:34px;margin:0 auto 10px;border-radius:3px;background:var(--rainbow)}
.team{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px 14px;text-align:center}
.tavatar{width:74px;height:74px;border-radius:50%;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:bold;font-size:24px;background:linear-gradient(135deg,var(--navy),var(--navy-d))}
.tcard h4{color:var(--navy);font-size:16px;margin-bottom:2px}
.tcard .role{color:var(--orange);font-size:12px;font-weight:bold;text-transform:uppercase;letter-spacing:.04em;display:block;margin-bottom:8px}
.tcard p{font-size:13px;color:var(--muted)}
.gov-box{background:#eef2fb;border:1px solid var(--line);border-radius:14px;padding:22px;color:var(--ink);margin-bottom:18px}
.gov-box b{color:var(--navy)}
.faq .qa{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 20px;margin-bottom:12px}
.faq .qa h4{color:var(--navy);margin-bottom:6px;font-size:16px}
.faq .qa p{color:var(--muted);font-size:14px}
@media(max-width:900px){
  /* layout stacking */
  .hero .grid,.contact-grid,.nm-slide.active{grid-template-columns:1fr}
  .cards,.cats,.tiers,.dir-grid,.values,.mv-grid,.team{grid-template-columns:1fr 1fr}
  .ev-grid,.fcols,.form-grid{grid-template-columns:1fr}
  .form-grid .full{grid-column:auto}
  /* spacing + type */
  section{padding:46px 0}
  .hero .grid{padding:46px 22px}
  .hero h1{font-size:32px}
  h2.title{font-size:24px}
  .page-hero{padding:48px 0 40px}
  .page-hero h1{font-size:28px}
  .stats{flex-wrap:wrap;gap:16px 26px}
  .ctaband .btn{display:block;max-width:280px;margin:10px auto 0 !important}
  /* mobile dropdown menu */
  .menu-btn{display:block}
  nav.menu{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:#fff;border-top:1px solid var(--line);
    box-shadow:0 12px 24px rgba(20,30,70,.12);padding:6px 0
  }
  nav.menu.open{display:flex}
  nav.menu a{padding:13px 22px}
  nav.menu a.btn{margin:8px 22px;text-align:center;padding:11px 16px !important}
}
@media(max-width:560px){
  .cards,.cats,.tiers,.dir-grid,.values,.mv-grid,.team{grid-template-columns:1fr}
  .search{flex-wrap:wrap}
  .search input{flex:1 1 100%}
  .hero h1{font-size:28px}
  .splogo{width:150px;height:80px}
}
