/* ============================================================
   Solano Grand EC — site stylesheet
   Palette: Senja Woods green + CDL gold + sand neutrals
   Type: Oswald (stencil-ish display, echoes wordmark) + Inter (body)
   ============================================================ */
:root{
  --forest:#1f3d2f;        /* deep Senja green - primary */
  --forest-deep:#16302440; /* (unused alpha sample) */
  --teal:#23503d;          /* nav active / links */
  --teal-deep:#16242a;     /* dark CTA section bg */
  --gold:#b08d57;          /* CDL gold - brass accent */
  --gold-deep:#8f6f3e;
  --brass:#b08d57;
  --brass-deep:#8f6f3e;
  --ink:#1c2b24;           /* body text */
  --ink-soft:#46564d;
  --sand:#f2ede3;          /* even row / soft panels */
  --aqua-soft:#e7efe9;     /* nav hover */
  --line:#dfe4dc;
  --white:#ffffff;
  --footer-bg:#0e1a1f;     /* deeper than teal-deep so footer separates */
  --serif:'Oswald','Arial Narrow',sans-serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);font-size:1.02rem;line-height:1.7;background:var(--white);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.15;color:var(--forest);margin:0 0 .5em;letter-spacing:.01em}
h1{font-size:2.3rem}
h2{font-size:1.72rem;text-transform:uppercase;letter-spacing:.03em}
h3{font-size:1.24rem}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-family:var(--sans);font-weight:700;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);margin:0 0 .5rem}
section{padding:30px 0}
.section-tint{background:var(--sand)}
.btn{display:inline-block;background:var(--gold);color:#fff;padding:13px 26px;border-radius:30px;font-weight:600;font-family:var(--sans);font-size:.95rem;border:0;cursor:pointer;transition:.18s}
.btn:hover{background:var(--gold-deep);text-decoration:none;color:#fff}
.btn-outline{background:transparent;border:1.5px solid var(--gold);color:var(--gold-deep)}
.btn-outline:hover{background:var(--gold);color:#fff}
.lead{font-size:1.12rem;line-height:1.75}

/* ---------- top utility bar ---------- */
.topbar{background:var(--forest);color:#dfe7e0;font-size:.8rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;min-height:38px;gap:14px}
.topbar a{color:#fff}
.topbar .tb-left{opacity:.92}
.topbar .tb-right{display:flex;gap:16px;flex-wrap:wrap}
.topbar .tb-right a{white-space:nowrap}
@media(max-width:760px){.topbar .tb-left{display:none}}

/* ---------- header / nav ---------- */
.site-head{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.97);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.header-in{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:68px}
.brand{font-family:var(--serif);font-weight:600;font-size:1.5rem;color:var(--forest);white-space:nowrap;letter-spacing:.04em;text-transform:uppercase;display:flex;align-items:center}
.brand img{height:30px;width:auto}
.brand small{display:block;font-family:var(--sans);font-weight:600;font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);margin-top:3px}
.mainnav{display:flex;align-items:center;gap:18px}
.navlinks{list-style:none;display:flex;gap:2px;margin:0;padding:0;align-items:flex-start}
.navlinks>li{position:relative;display:flex}
.navlinks a{display:flex;padding:12px 10px 10px;font-size:.86rem;font-weight:500;color:var(--ink);border-radius:6px;line-height:1.2;white-space:nowrap}
.navlinks a:hover,.navlinks a.active{color:var(--teal);background:var(--aqua-soft);text-decoration:none}
.navlinks a.active{font-weight:600}
.cta-pill{background:var(--gold)!important;color:#fff!important;padding:11px 18px!important;border-radius:30px;font-weight:600;font-size:.86rem;white-space:nowrap}
.cta-pill:hover{background:var(--gold-deep)!important;color:#fff!important}
.caret{display:inline-block;width:0;height:0;margin-left:5px;vertical-align:middle;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor}
.has-dd .submenu{list-style:none;margin:0;padding:8px;position:absolute;top:calc(100% + 6px);left:0;min-width:220px;background:var(--white);border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 34px rgba(22,36,42,.13);opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s;z-index:70}
.has-dd:hover .submenu,.has-dd:focus-within .submenu{opacity:1;visibility:visible;transform:none}
.submenu a{padding:9px 12px;font-size:.85rem;border-radius:6px;color:var(--ink)}
.submenu a:hover{background:var(--aqua-soft);color:var(--teal)}
.dd-acc{display:none}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.hamburger span{width:24px;height:2px;background:var(--forest);border-radius:2px;transition:.2s}

@media(max-width:1024px){
  .hamburger{display:flex}
  .mainnav{position:fixed;inset:68px 0 auto 0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:8px 16px 20px;border-bottom:1px solid var(--line);box-shadow:0 14px 40px rgba(22,36,42,.16);max-height:calc(100vh - 68px);overflow-y:auto;transform:translateY(-150%);transition:transform .25s;z-index:55}
  .mainnav.open{transform:none}
  .navlinks{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .navlinks>li{border-bottom:1px solid var(--line)}
  .navlinks a{padding:13px 6px;font-size:.95rem;justify-content:flex-start;text-align:left}
  .cta-pill{margin-top:14px;text-align:center;justify-content:center}
  .has-dd .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-radius:0;padding:0 0 6px 14px;display:none;min-width:0}
  .has-dd.open-acc .submenu{display:block}
  .dd-acc{display:block;position:absolute;right:0;top:6px;width:40px;height:40px;background:none;border:0;cursor:pointer}
  .dd-acc::after{content:"+";font-size:1.4rem;color:var(--teal);position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
  .has-dd.open-acc .dd-acc::after{content:"\2013"}
}

/* ---------- hero slider ---------- */
.hero{position:relative;overflow:hidden;background:#0d1a13}
.hero-slides{position:relative;width:100%;aspect-ratio:1536/720;max-height:78vh}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;z-index:1}
.hero-slide.active{opacity:1;z-index:2}
.hero-slide img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;z-index:3;background:linear-gradient(105deg,rgba(16,40,28,.55) 0%,rgba(16,40,28,.28) 45%,rgba(16,40,28,.12) 100%);display:flex;align-items:center}
.hero-content{max-width:var(--maxw);margin:0 auto;padding:0 26px;width:100%;color:#fff}
.hero-content .eyebrow{color:#f3e6cf}
.hero h1{color:#fff;font-size:2.9rem;text-shadow:0 2px 18px rgba(0,0,0,.4);max-width:760px;text-transform:uppercase}
.hero .lead{color:#f3f6f1;text-shadow:0 1px 10px rgba(0,0,0,.45);max-width:560px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.hero-arrows{position:absolute;z-index:5;bottom:18px;right:24px;display:flex;gap:8px}
.hero-arrows button{width:42px;height:42px;border-radius:50%;border:1.5px solid rgba(255,255,255,.7);background:rgba(16,40,28,.32);color:#fff;font-size:1.1rem;cursor:pointer;transition:.18s}
.hero-arrows button:hover{background:var(--gold);border-color:var(--gold)}
.hero-dots{position:absolute;z-index:5;bottom:22px;left:0;right:0;display:flex;justify-content:center;gap:9px}
.hero-dots button{width:10px;height:10px;border-radius:50%;border:0;background:rgba(255,255,255,.45);cursor:pointer;padding:0}
.hero-dots button.active{background:var(--gold);width:26px;border-radius:5px}
@media(max-width:760px){
  .hero-slides{aspect-ratio:auto;height:74vh;max-height:none}
  .hero h1{font-size:2rem}
  .hero .lead{display:none}
}

/* ---------- generic blocks ---------- */
.fullprose{font-size:1.12rem;line-height:1.78}
.fullprose p{max-width:none}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}
.split img{border-radius:12px;box-shadow:0 14px 34px rgba(22,40,30,.14)}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:20px}}

/* stat strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 16px;text-align:center}
.stat b{display:block;font-family:var(--serif);font-size:1.7rem;color:var(--forest);line-height:1}
.stat span{font-size:.82rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;margin-top:6px;display:block}
@media(max-width:680px){.stats{grid-template-columns:repeat(2,1fr)}}

/* facts box: single-column label/value rows */
.facts{background:#fff;border:1px solid var(--line);border-radius:14px;padding:8px 22px;margin:0}
.facts .row{display:flex;justify-content:space-between;gap:18px;padding:13px 0;border-bottom:1px solid var(--line)}
.facts .row:last-child{border-bottom:0}
.facts .row .k{color:var(--ink-soft);font-weight:500}
.facts .row .v{font-weight:600;text-align:right;color:var(--forest)}

/* trio */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.trio .card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
.trio .card img,.trio .card .img-placeholder{width:100%;aspect-ratio:16/10;object-fit:cover}
.trio .card .body{padding:18px 20px 22px;display:flex;flex-direction:column;flex:1}
.trio .card h3{margin-bottom:.4em}
.trio .card h3 a{color:var(--forest)}
.trio .card .read{margin-top:auto;font-weight:600;color:var(--gold-deep)}
@media(max-width:880px){.trio{grid-template-columns:1fr}}

.img-placeholder{display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(135deg,#eef2ec,#eef2ec 12px,#e7ede6 12px,#e7ede6 24px);color:var(--ink-soft);font-size:.85rem;letter-spacing:.05em;text-transform:uppercase}

/* update band */
.update-band{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.update-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 24px}
.update-card.dark{background:var(--forest);color:#eaf0ea;border:0}
.update-card.dark h3,.update-card.dark .eyebrow{color:#fff}
.update-card.dark a{color:#f1e2c6}
.update-list{list-style:none;margin:0;padding:0}
.update-list li{padding:10px 0;border-bottom:1px solid var(--line);font-size:.95rem}
.update-list li:last-child{border-bottom:0}
.update-list .date{font-weight:700;color:var(--gold-deep);margin-right:6px}
.checklist{list-style:none;margin:12px 0 0;padding:0}
.checklist li{padding:6px 0 6px 26px;position:relative;font-size:.95rem}
.checklist li::before{content:"\2713";position:absolute;left:0;color:var(--gold);font-weight:700}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
@media(max-width:820px){.update-band{grid-template-columns:1fr}}

/* dark CTA section */
.cta-band{background:var(--teal-deep);color:#eaf0ea;text-align:center}
.cta-band h2{color:#fff}
.cta-band p{max-width:620px;margin:0 auto 18px;color:#cdd8d0}

/* FAQ */
.faq details{background:#fff;border:1px solid var(--line);border-radius:10px;margin-bottom:10px;padding:0 18px}
.faq summary{cursor:pointer;padding:15px 0;font-family:var(--serif);font-size:1.06rem;color:var(--forest);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.3rem;color:var(--gold);flex-shrink:0}
.faq details[open] summary::after{content:"\2013"}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq .ans{padding:14px 0 18px}
.faq .ans p:last-child{margin-bottom:0}

/* forms */
.form-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1/-1}
@media(max-width:620px){.form-grid{grid-template-columns:1fr}}
.field label{display:block;font-size:.82rem;font-weight:600;color:var(--ink-soft);margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:.95rem;background:#fdfdfb}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.consent{display:flex;gap:10px;align-items:flex-start;margin:14px 0}
.consent input{flex:0 0 18px;width:18px;height:18px;margin-top:3px}
.consent span{font-size:.86rem;color:var(--ink-soft);line-height:1.5}
.consent a{text-decoration:underline}
.hp{display:none}
.form-msg{margin-top:12px;font-size:.92rem}

/* breadcrumb */
.crumb{background:var(--sand);font-size:.84rem;color:var(--ink-soft)}
.crumb .container{padding-top:11px;padding-bottom:11px}
.crumb a{color:var(--teal)}

/* subpage banner */
.subbanner{position:relative;background:var(--forest)}
.subbanner img{width:100%;height:230px;object-fit:cover;opacity:.9}
.subbanner .ov{position:absolute;inset:0;background:linear-gradient(100deg,rgba(16,40,28,.6),rgba(16,40,28,.3));display:flex;align-items:center}
.subbanner h1{color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.4);margin:0;text-transform:uppercase}

/* financing tables */
.tbl-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--line);margin:18px 0}
table.data{width:100%;border-collapse:collapse;font-size:.94rem;min-width:440px}
table.data thead th{background:var(--teal-deep);color:#fff;text-align:left;padding:12px 14px;font-family:var(--sans);font-weight:600;letter-spacing:.02em}
table.data thead th.num{text-align:right}
table.data td{padding:11px 14px;border-bottom:1px solid var(--line)}
table.data td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
table.data tbody tr:nth-child(odd){background:#fff}
table.data tbody tr:nth-child(even){background:var(--sand)}
.tbl-note{font-size:.8rem;color:var(--ink-soft);margin:6px 2px 0;font-style:italic}
table.kv td:first-child{width:42%;font-weight:600;color:var(--forest)}

/* lightbox */
.lb-overlay{position:fixed;inset:0;background:rgba(10,18,14,.9);z-index:200;display:none;align-items:center;justify-content:center;padding:20px;cursor:zoom-out}
.lb-overlay.open{display:flex}
.lb-overlay img{max-width:95%;max-height:92%;border-radius:8px}

/* footer */
.site-foot{background:var(--footer-bg);color:#c4d0c7;border-top:1px solid rgba(176,141,87,.28);padding:42px 0 22px;font-size:.92rem}
.foot-grid{display:grid;grid-template-columns:1.1fr 1.5fr 1.1fr;gap:34px}
.foot-brand img{height:50px;width:auto;margin-bottom:12px}
.foot-brand p{color:#9fb0a3;font-size:.9rem}
.site-foot h4{color:#fff;font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}
.foot-links{width:100%;border-collapse:collapse;table-layout:fixed}
.foot-links td{width:50%;padding:5px 8px 5px 0;vertical-align:top}
.foot-links a{color:#c4d0c7;white-space:nowrap}
.foot-links a:hover{color:#fff}
.foot-contact{list-style:none;margin:0;padding:0}
.foot-contact li{margin-bottom:10px;line-height:1.45}
.foot-contact .lbl{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#8a9c8f}
.foot-contact a{color:#e7ede8}
.foot-disclaimer{border-top:1px solid rgba(255,255,255,.1);margin-top:28px;padding-top:18px;font-size:.78rem;color:#8a9c8f;line-height:1.6}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:18px;padding-top:16px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.82rem;color:#9fb0a3}
.foot-bottom a{color:#c4d0c7}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr;gap:26px}}

/* utility */
.mt0{margin-top:0}.center{text-align:center}
.prose-links a{font-weight:500}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery-grid img{border-radius:10px;cursor:zoom-in;aspect-ratio:4/3;object-fit:cover;width:100%}
@media(max-width:760px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
.coming-soon{text-align:center;padding:40px 20px;background:#fff;border:1px dashed var(--line);border-radius:14px}
.coming-soon svg{width:84px;height:84px;margin-bottom:14px}
.coming-soon h3{margin-bottom:.3em}
