/* =====================================================
   SPRING HILL DECK BUILDERS — DESIGN SYSTEM (light)
   ===================================================== */
:root{
  --paper:#faf7f1; --paper-2:#f1ebdf; --white:#fff;
  --ink:#221a14; --ink-soft:#5c5247;
  --cedar:#c0662a; --cedar-deep:#9c4f1c; --amber:#e89b3c;
  --line:#e7ddcc; --espresso:#1d1611;
  --display:'Big Shoulders Display',Impact,sans-serif;
  --body:'Figtree',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--paper);color:var(--ink-soft);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
section{padding:88px 0}
h1,h2,h3{font-family:var(--display);text-transform:uppercase;line-height:.95;letter-spacing:.5px;color:var(--ink)}
h1{font-size:clamp(2.8rem,6.5vw,5rem);font-weight:900}
h2{font-size:clamp(2.2rem,4.6vw,3.6rem);font-weight:800}
.kicker{font-size:.8rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--cedar);margin-bottom:16px;display:flex;align-items:center;gap:12px}
.kicker::before{content:"";width:34px;height:2px;background:var(--cedar)}
.accent{color:var(--cedar)}
p.lead{color:var(--ink-soft);max-width:62ch;font-size:1.06rem}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:700;font-size:1rem;padding:17px 32px;border-radius:6px;min-height:48px;transition:transform .18s,box-shadow .18s,background .18s;cursor:pointer;border:none}
.btn-call{background:var(--cedar);color:#fff;box-shadow:0 8px 24px rgba(192,102,42,.3)}
.btn-call:hover{background:var(--cedar-deep);transform:translateY(-2px);color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--ink)}
.btn-ghost:hover{border-color:var(--cedar);color:var(--cedar);transform:translateY(-2px)}
.btn-big{font-size:1.15rem;padding:22px 44px}

/* ---------- nav (white) ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:90;background:rgba(255,255,255,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);box-shadow:0 2px 14px rgba(34,26,20,.05)}
.nav{display:flex;align-items:center;justify-content:space-between;height:80px}
.logo img{height:54px;width:auto}
.nav-links{display:flex;gap:26px;align-items:center;list-style:none}
.nav-links>li{position:relative}
.nav-links a{font-weight:600;font-size:.94rem;color:var(--ink-soft);transition:color .15s}
.nav-links>li>a{display:inline-flex;align-items:center;gap:5px;padding:28px 0}
.nav-links a:hover{color:var(--cedar)}
.caret{font-size:.7rem;opacity:.6}
.nav-phone{background:var(--cedar);color:#fff !important;font-weight:800;padding:11px 20px !important;border-radius:6px;font-size:.95rem}
.nav-phone:hover{background:var(--cedar-deep)}
.burger{display:none;background:none;border:none;color:var(--ink);font-size:1.7rem;cursor:pointer;min-width:48px;min-height:48px}

/* ---------- mega menu ---------- */
.mega{display:none;position:fixed;left:0;right:0;top:80px;background:var(--white);border-bottom:1px solid var(--line);box-shadow:0 26px 50px rgba(34,26,20,.14);z-index:95}
.has-mega:hover .mega,.has-mega:focus-within .mega{display:block}
/* hover bridge — fixes death triangle */
.has-mega::after{content:"";position:absolute;left:-20px;right:-20px;bottom:-12px;height:12px}
.mega-inner{padding:34px 24px 28px}
.mega-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.mega-cities{grid-template-columns:repeat(5,1fr)}
.mega-item{display:block;padding:16px 18px;border-radius:10px;border:1px solid transparent;transition:background .15s,border-color .15s}
.mega-item:hover{background:var(--paper);border-color:var(--line)}
.mega-item strong{display:block;font-family:var(--display);text-transform:uppercase;font-size:1.15rem;letter-spacing:.5px;color:var(--ink);margin-bottom:3px}
.mega-item span{font-size:.85rem;color:var(--ink-soft)}
.mega-item:hover strong{color:var(--cedar)}
.mega-city strong{font-size:1rem;margin:0}
.mega-all{display:inline-block;margin-top:18px;font-weight:700;color:var(--cedar);font-size:.92rem}

/* ---------- mobile drawer ---------- */
.drawer{position:fixed;inset:0 0 0 auto;width:min(340px,88vw);background:#fff;z-index:120;transform:translateX(100%);transition:transform .3s ease;padding:74px 26px 30px;display:flex;flex-direction:column;border-left:1px solid var(--line);overflow-y:auto}
.drawer.open{transform:translateX(0)}
.drawer>a,.acc-toggle{font-family:var(--display);font-size:1.55rem;text-transform:uppercase;padding:13px 0;border-bottom:1px solid var(--line);color:var(--ink);text-align:left;background:none;border-left:none;border-right:none;border-top:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;width:100%;letter-spacing:.5px}
.drawer>a:hover,.acc-toggle:hover{color:var(--cedar)}
.acc-toggle span{transition:transform .2s;font-size:1rem;color:var(--cedar)}
.acc-toggle.open span{transform:rotate(180deg)}
.acc-panel{display:none;flex-direction:column;background:var(--paper);border-bottom:1px solid var(--line)}
.acc-panel.open{display:flex}
.acc-panel a{padding:11px 18px;font-weight:600;font-size:1rem;color:var(--ink-soft);border-bottom:1px solid var(--line)}
.acc-panel a:last-child{border-bottom:none}
.acc-panel a:hover{color:var(--cedar)}
.acc-all{color:var(--cedar) !important;font-weight:700}
.drawer-cta{color:var(--cedar) !important}
.drawer-x{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--ink);font-size:1.9rem;cursor:pointer;min-width:48px;min-height:48px}
.scrim{position:fixed;inset:0;background:rgba(34,26,20,.45);z-index:110;opacity:0;pointer-events:none;transition:opacity .3s}
.scrim.show{opacity:1;pointer-events:auto}

/* ---------- breadcrumbs ---------- */
.breadcrumbs{padding:96px 0 0;font-size:.85rem;color:var(--ink-soft)}
.breadcrumbs .wrap{display:flex;gap:8px;flex-wrap:wrap}
.breadcrumbs a:hover{color:var(--cedar)}
.breadcrumbs .sep{opacity:.4}
.breadcrumbs .current{color:var(--cedar);font-weight:600}

/* ---------- hero (homepage: copy + form) ---------- */
.hero{position:relative;padding:160px 0 80px}
.hero-photo-bg{background:linear-gradient(rgba(250,247,241,.94),rgba(250,247,241,.97)),var(--hero-img) center/cover no-repeat}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:6px;background:repeating-linear-gradient(90deg,var(--cedar) 0 60px,var(--amber) 60px 120px)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center;position:relative;z-index:2}
.hero .sub-h{font-family:var(--display);font-size:clamp(1.4rem,2.6vw,2rem);color:var(--cedar);text-transform:uppercase;letter-spacing:1px;margin:8px 0 20px;font-weight:700}
.hero p{font-size:1.12rem;max-width:54ch;margin-bottom:30px}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:34px}
.hero-trust{display:flex;gap:30px;flex-wrap:wrap;font-size:.88rem}
.hero-trust b{color:var(--ink);font-family:var(--display);font-size:1.5rem;letter-spacing:.5px;display:block}
.stars{color:var(--amber);letter-spacing:2px}

/* ---------- inner page hero ---------- */
.page-hero{padding:36px 0 56px}
.page-hero p.lead{margin-top:18px}

/* ---------- ticker ---------- */
.ticker{background:var(--ink);color:var(--paper);padding:13px 0;overflow:hidden;white-space:nowrap}
.ticker-track{display:inline-block;animation:tick 30s linear infinite;font-family:var(--display);font-size:1.15rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase}
.ticker-track em{color:var(--amber);font-style:normal}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- shared blocks ---------- */
.alt-bg{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.intro-photos{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.intro-photos img{border-radius:10px;height:230px;object-fit:cover;width:100%;box-shadow:0 10px 30px rgba(34,26,20,.12)}
.intro-photos img:first-child{grid-column:1/-1;height:260px}
.checks{list-style:none;margin-top:26px;display:grid;gap:12px}
.checks li{display:flex;gap:12px;align-items:flex-start}
.checks li::before{content:"✓";color:var(--cedar);font-weight:900;font-size:1.1rem;line-height:1.4}

.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.svc-card{background:var(--white);border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 16px rgba(34,26,20,.06)}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(34,26,20,.14)}
.svc-card img{height:200px;width:100%;object-fit:cover}
.svc-body{padding:24px}
.svc-body h3{font-size:1.45rem;margin-bottom:10px}
.svc-body p{font-size:.95rem}
.svc-body a{display:inline-flex;align-items:center;gap:6px;margin-top:14px;color:var(--cedar);font-weight:700;font-size:.9rem}

.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:46px}
.gal-grid img{border-radius:8px;height:215px;width:100%;object-fit:cover;transition:transform .25s;box-shadow:0 6px 18px rgba(34,26,20,.1)}
.gal-grid img:hover{transform:scale(1.03)}
.gal-grid img:nth-child(1),.gal-grid img:nth-child(6){grid-column:span 2}

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:50px}
.step{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:30px 24px;box-shadow:0 4px 16px rgba(34,26,20,.06)}
.step b{font-family:var(--display);font-size:3.4rem;color:var(--cedar);opacity:.35;line-height:1}
.step h3{font-size:1.3rem;margin:12px 0 8px}
.step p{font-size:.92rem}

.stats{background:var(--cedar);color:#fff;padding:54px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stats b{font-family:var(--display);font-size:3.4rem;font-weight:900;display:block;line-height:1}
.stats span{font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.12em}

.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.testi{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:30px;box-shadow:0 4px 16px rgba(34,26,20,.06)}
.testi p{font-style:italic;font-size:.98rem}
.testi footer{margin-top:18px;font-weight:700;color:var(--ink)}
.testi footer small{display:block;color:var(--cedar);font-weight:700;letter-spacing:.14em;font-size:.72rem;margin-top:4px;text-transform:uppercase}

.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.chip{border:1px solid var(--line);background:var(--white);border-radius:999px;padding:9px 18px;font-size:.88rem;font-weight:600;transition:border-color .15s,color .15s;display:inline-block}
.chip:hover{border-color:var(--cedar);color:var(--cedar)}

/* ---------- forms ---------- */
form{display:grid;gap:14px}
.form-card{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:32px;box-shadow:0 14px 40px rgba(34,26,20,.12)}
.form-title{font-size:1.7rem;margin-bottom:4px}
.form-sub{font-size:.92rem;margin-bottom:18px}
.form-sub b{color:var(--cedar)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
label{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
input,select,textarea{width:100%;background:var(--paper);border:1px solid var(--line);border-radius:8px;color:var(--ink);padding:14px 16px;font-family:var(--body);font-size:1rem;margin-top:6px}
input:focus,select:focus,textarea:focus{outline:2px solid var(--cedar);border-color:transparent}
.form-success{display:none;text-align:center;padding:40px 20px}
.form-success h3{color:var(--cedar);font-size:1.8rem;margin-bottom:10px}
.hp{position:absolute;left:-9999px;opacity:0}

/* ---------- FAQ ---------- */
.faq-list{margin-top:50px;display:grid;gap:14px;max-width:900px}
.faq{border:1px solid var(--line);border-radius:10px;background:var(--white);overflow:hidden;box-shadow:0 3px 12px rgba(34,26,20,.05)}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:22px 26px;font-weight:700;font-size:1.04rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--display);font-size:1.7rem;color:var(--cedar);transition:transform .2s}
.faq[open] summary::after{transform:rotate(45deg)}
.faq .ans{padding:0 26px 24px;font-size:.97rem;max-width:75ch}

/* ---------- long-form prose (service/city/blog pages) ---------- */
.prose{max-width:760px}
.prose h2{font-size:clamp(1.8rem,3.4vw,2.5rem);margin:44px 0 16px}
.prose h3{font-size:1.35rem;margin:32px 0 12px}
.prose p{margin-bottom:16px}
.prose ul{margin:0 0 16px 22px}
.prose ul li{margin-bottom:8px}
.prose a{color:var(--cedar);border-bottom:1px dashed var(--cedar);font-weight:600}
.prose img{border-radius:12px;margin:26px 0;box-shadow:0 12px 32px rgba(34,26,20,.14)}
.content-grid{display:grid;grid-template-columns:1fr 340px;gap:56px;align-items:start}
.sidebar{position:sticky;top:104px;display:grid;gap:22px}
.side-card{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:26px;box-shadow:0 6px 20px rgba(34,26,20,.07)}
.side-card h3{font-size:1.3rem;margin-bottom:12px}
.side-card ul{list-style:none;display:grid;gap:8px}
.side-card a:hover{color:var(--cedar)}
.side-phone{font-family:var(--display);font-size:2rem;color:var(--cedar);display:block;margin:8px 0;letter-spacing:.5px}

/* ---------- related grid ---------- */
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px}
.rel-tile{background:var(--white);border:1px solid var(--line);border-radius:10px;padding:22px;font-family:var(--display);text-transform:uppercase;font-size:1.1rem;color:var(--ink);letter-spacing:.5px;transition:border-color .15s,transform .15s}
.rel-tile:hover{border-color:var(--cedar);color:var(--cedar);transform:translateY(-3px)}
.rel-tile.all{background:var(--cedar);color:#fff;border-color:var(--cedar)}

/* ---------- blog cards ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.blog-card{background:var(--white);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 4px 16px rgba(34,26,20,.06);transition:transform .2s,box-shadow .2s}
.blog-card:hover{transform:translateY(-5px);box-shadow:0 16px 38px rgba(34,26,20,.13)}
.blog-card img{height:190px;width:100%;object-fit:cover}
.blog-body{padding:24px}
.blog-body time{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--cedar)}
.blog-body h3{font-size:1.3rem;margin:10px 0;line-height:1.1}
.blog-body p{font-size:.93rem}

/* ---------- final CTA ---------- */
.final{position:relative;text-align:center;color:#f5efe4;background:var(--espresso)}
.final-bg{position:absolute;inset:0;background:var(--final-img) center/cover;opacity:.16}
.final .wrap{position:relative;z-index:2}
.final h2{font-size:clamp(2.6rem,6.5vw,5rem);color:#fff}
.final .kicker{justify-content:center;color:var(--amber)}
.final .kicker::before{background:var(--amber)}
.phone-huge{font-family:var(--display);font-size:clamp(2.4rem,6vw,4.4rem);color:var(--amber);display:inline-block;margin:24px 0 30px;letter-spacing:1px}
.final .btn-ghost{color:#fff;border-color:rgba(255,255,255,.5)}
.final .btn-ghost:hover{border-color:var(--amber);color:var(--amber)}

/* ---------- footer ---------- */
footer.site{background:var(--espresso);color:#b8ab99;padding:60px 0 110px;font-size:.92rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.foot-grid h4{font-family:var(--display);text-transform:uppercase;font-size:1.15rem;color:#fff;margin-bottom:14px;letter-spacing:1px}
.foot-grid ul{list-style:none;display:grid;gap:8px}
.foot-grid a:hover{color:var(--amber)}
.foot-phone{color:var(--amber);font-weight:700}
.copy{margin-top:46px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem}

/* ---------- sticky mobile dual-action bar ---------- */
.callbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;grid-template-columns:1fr 1fr;box-shadow:0 -8px 30px rgba(34,26,20,.3)}
.callbar a{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--display);font-size:1.25rem;font-weight:800;letter-spacing:1px;padding:17px 8px;text-transform:uppercase;min-height:56px}
.cb-call{background:var(--cedar);color:#fff}
.cb-quote{background:var(--white);color:var(--cedar);border-top:2px solid var(--cedar)}

/* ---------- animations ---------- */
.fade{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.fade.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.fade{opacity:1;transform:none;transition:none}.ticker-track{animation:none}}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .nav-links{display:none}
  .burger{display:block}
  .callbar{display:grid}
  .hero-grid,.two-col,.content-grid{grid-template-columns:1fr;gap:44px}
  .sidebar{position:static}
  .svc-grid,.testi-grid,.blog-grid,.rel-grid{grid-template-columns:1fr 1fr}
  .steps,.stats-grid{grid-template-columns:1fr 1fr}
  .gal-grid{grid-template-columns:1fr 1fr}
  .gal-grid img:nth-child(1),.gal-grid img:nth-child(6){grid-column:span 1}
  .foot-grid{grid-template-columns:1fr 1fr}
  section{padding:64px 0}
  .hero{padding:130px 0 64px}
}
@media(max-width:600px){
  .svc-grid,.testi-grid,.blog-grid,.rel-grid,.steps,.gal-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr;gap:34px}
  .frow{grid-template-columns:1fr}
  .gal-grid img{height:240px}
  .form-card{padding:24px}
  .logo img{height:44px}
}
