/* ===== Cinematic full-bleed hero (v5 look) merged into v2 system ===== */
.hero.hero-cine{
  position:relative; min-height:100vh; width:100%; overflow:hidden;
  display:block; padding:0; color:#F7F4EE; isolation:isolate;
}
.hero-cine .hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-cine .hero-bg img{
  position:absolute;inset:-3%;width:106%;height:106%;object-fit:cover;
  transform-origin:60% 45%; animation:heroKen 32s ease-in-out infinite alternate; will-change:transform;
}
@keyframes heroKen{from{transform:scale(1.02)}to{transform:scale(1.12)}}
.hero-cine .hero-scrim{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(10,9,8,.5) 0%,rgba(10,9,8,0) 24%,rgba(10,9,8,0) 46%,rgba(10,9,8,.9) 100%),
    linear-gradient(80deg,rgba(10,9,8,.86) 0%,rgba(10,9,8,.34) 44%,rgba(10,9,8,0) 72%),
    radial-gradient(120% 95% at 50% 34%,transparent 46%,rgba(8,7,6,.55) 100%);
}
.hero-cine .hero-ph{
  position:absolute;z-index:6;top:96px;left:clamp(20px,4.5vw,64px);
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(247,244,238,.7);
  background:rgba(0,0,0,.4);border:1px solid rgba(247,244,238,.25);padding:5px 10px;border-radius:6px;
}
.hero-cine .hero-cine-inner{
  position:relative;z-index:5;display:flex;align-items:flex-end;justify-content:space-between;gap:40px;
  min-height:100vh;padding-top:150px;padding-bottom:clamp(40px,7vh,84px);
}
.hero-cine .hero-copy{max-width:780px;flex:1}
.hero-cine .hero-eyebrow{display:inline-flex;align-items:center;gap:10px;color:rgba(247,244,238,.92)}
.hero-cine .hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:#F7F4EE;display:inline-block}
.hero-cine .hero-head{
  color:#F7F4EE;font-weight:500;letter-spacing:-.03em;line-height:.94;
  font-size:clamp(52px,7.4vw,112px);margin:18px 0 0;text-shadow:0 2px 22px rgba(0,0,0,.5),0 1px 3px rgba(0,0,0,.45);
}
.hero-cine .hero-sub{
  margin-top:22px;font-size:clamp(16px,1.3vw,20px);font-weight:400;line-height:1.55;
  color:rgba(247,244,238,.92);max-width:46ch;text-shadow:0 1px 8px rgba(0,0,0,.5);
}
.hero-cine .hero-cta{margin-top:34px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.hero-cine .scroll-cue{margin-top:36px;color:rgba(247,244,238,.72)}
/* floating "see our work" card, bottom-right */
.hero-cine .hero-fcard{
  flex-shrink:0;width:330px;border-radius:20px;overflow:hidden;position:relative;text-decoration:none;color:#F7F4EE;
  border:1px solid rgba(247,244,238,.22);box-shadow:0 40px 80px -30px rgba(0,0,0,.7);
  transition:transform .6s cubic-bezier(.22,1,.36,1);align-self:flex-end;
}
.hero-cine .hero-fcard:hover{transform:translateY(-6px)}
.hero-cine .hero-fcard img{display:block;width:100%;height:210px;object-fit:cover}
.hero-cine .hero-fcard-ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(10,9,8,.85));display:flex;flex-direction:column;justify-content:flex-end;padding:18px}
.hero-cine .hero-fcard-ov .t{font-weight:600;font-size:16px}
.hero-cine .hero-fcard-ov .s{font-size:12.5px;color:rgba(247,244,238,.78);margin-top:3px}
.hero-cine .hero-fcard-ar{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:999px;background:rgba(247,244,238,.92);color:#1a1a1a;display:grid;place-items:center;font-size:15px}

/* nav: light text while over the dark hero (before .scrolled) */
.nav:not(.scrolled) .brand{color:#F7F4EE}
.nav:not(.scrolled) .nav-links a{color:rgba(247,244,238,.86)}
.nav:not(.scrolled) .nav-links a:hover{color:#fff}
.nav:not(.scrolled) .nav-toggle span{background:#F7F4EE}

@media(max-width:860px){
  .hero-cine .hero-cine-inner{flex-direction:column;align-items:flex-start;padding-top:120px}
  .hero-cine .hero-fcard{display:none}
  .hero-cine .hero-head{font-size:clamp(40px,11vw,72px)}
}

/* Real L Square logo (white over dark hero, black on scrolled/light) */
.brand-img{display:inline-flex;align-items:center}
.brand-img img{height:46px;width:auto;display:block}
.brand-img .logo-b{display:none}
.nav.scrolled .brand-img .logo-w{display:none}
.nav.scrolled .brand-img .logo-b{display:block}

/* supplier marquee real logos */
.supbar-track{align-items:center}
.supbar .supbar-wrap{height:auto}
.supbar-track .sup-cell{display:inline-flex;align-items:center;justify-content:center;width:auto;padding:0 22px;height:100px;flex:0 0 auto}
.supbar-track .sup-logo{max-height:58px;max-width:190px;width:auto;object-fit:contain;opacity:.95}

/* gallery real images */
#studio .bleed{aspect-ratio:21/9;overflow:hidden;border-radius:16px}
#studio .gal2 .g{aspect-ratio:4/3;overflow:hidden;border-radius:16px}
#studio .gal-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s cubic-bezier(.22,1,.36,1)}
#studio .bleed:hover .gal-img,#studio .gal2 .g:hover .gal-img{transform:scale(1.04)}

/* ===== Liquid-glass button — tuned glossier / clearer ===== */
.btn{
  background:
    radial-gradient(80px circle at var(--mx,50%) var(--my,150%), rgba(255,255,255,.5), transparent 60%),
    radial-gradient(150% 88% at 50% -24%, rgba(255,255,255,.92), rgba(255,255,255,.12) 52%, transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,.4) 0%, rgba(255,255,255,.18) 52%, rgba(255,255,255,.34) 100%);
  -webkit-backdrop-filter:blur(16px) saturate(185%);backdrop-filter:blur(16px) saturate(185%);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:
    0 22px 44px -16px rgba(0,0,0,.3),
    0 6px 16px -6px rgba(0,0,0,.16),
    inset 0 2px 1px rgba(255,255,255,.98),
    inset 0 -12px 22px -8px rgba(0,0,0,.10),
    inset 0 0 0 1px rgba(255,255,255,.28);
}
.btn:hover{transform:translateY(-2px);
  box-shadow:0 32px 58px -16px rgba(0,0,0,.34),0 8px 18px -6px rgba(0,0,0,.18),
  inset 0 2px 1px rgba(255,255,255,.98),inset 0 -12px 22px -8px rgba(0,0,0,.10),inset 0 0 0 1px rgba(255,255,255,.28)}
.btn::after{filter:blur(2px);color:rgba(18,18,18,.13)}
/* on dark (hero) — translucent liquid glass */
.btn.on-black{color:#fff;
  background:
    radial-gradient(80px circle at var(--mx,50%) var(--my,150%), rgba(255,255,255,.26), transparent 60%),
    radial-gradient(150% 88% at 50% -24%, rgba(255,255,255,.42), rgba(255,255,255,.05) 55%, transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,.18) 0%, rgba(255,255,255,.05) 55%, rgba(255,255,255,.13) 100%);
  border:1px solid rgba(255,255,255,.42);
  box-shadow:0 22px 44px -16px rgba(0,0,0,.55),inset 0 2px 1px rgba(255,255,255,.5),inset 0 -12px 22px -8px rgba(0,0,0,.22),inset 0 0 0 1px rgba(255,255,255,.16)}
.btn.on-black::after{color:rgba(255,255,255,.16)}

/* no mouse-reactive flashing: remove sheen sweep + cursor-follow glow */
.btn::before{display:none !important}
.btn{
  background:
    radial-gradient(150% 88% at 50% -24%, rgba(255,255,255,.92), rgba(255,255,255,.12) 52%, transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,.4) 0%, rgba(255,255,255,.18) 52%, rgba(255,255,255,.34) 100%);
}
.btn.on-black{
  background:
    radial-gradient(150% 88% at 50% -24%, rgba(255,255,255,.42), rgba(255,255,255,.05) 55%, transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,.18) 0%, rgba(255,255,255,.05) 55%, rgba(255,255,255,.13) 100%);
}

/* configurator floor plans */
#models .cfg-visual{background:#fff}
#models .cfg-visual .slot{display:flex;align-items:center;justify-content:center}
#models .plan-img{width:100%;height:100%;object-fit:contain;display:block;padding:18px}

#models .plan-img{padding:8px}

#models .plan-img{padding:0}
#models .cfg-visual .slot{padding:14px}

/* new logo mark + wordmark */
.brand-img{gap:11px}
.brand-img img{height:27px;width:auto}
.brand-wm{font-weight:600;font-size:19px;letter-spacing:-.015em;line-height:1}

/* features -> editorial split (one sticky image + numbered list) */
.feat-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,80px);margin-top:48px;align-items:start}
.feat-media{position:sticky;top:96px;border-radius:18px;overflow:hidden;box-shadow:0 40px 80px -50px rgba(0,0,0,.4)}
.feat-media img{width:100%;height:auto;display:block;aspect-ratio:4/3;object-fit:cover}
.feat-list{display:flex;flex-direction:column}
.feat-row{display:flex;gap:22px;padding:clamp(22px,2.6vw,38px) 0;border-top:1px solid var(--line);align-items:baseline}
.feat-row:first-child{border-top:0;padding-top:0}
.feat-row .fno{font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--muted);min-width:24px}
.feat-row .ft h4{font-size:clamp(20px,1.9vw,27px);font-weight:600;letter-spacing:-.02em;margin-bottom:9px}
.feat-row .ft p{color:var(--ink-soft);font-size:16px;line-height:1.55;max-width:42ch}
@media(max-width:860px){.feat-split{grid-template-columns:1fr;gap:30px}.feat-media{position:relative;top:0}}

/* fix feat-split grid (min-width:0) + portrait sticky image for real pin motion */
.feat-split{grid-template-columns:0.92fr 1.08fr;align-items:start}
.feat-media,.feat-list{min-width:0}
.feat-media{aspect-ratio:3/4;height:auto}
.feat-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:auto}
.feat-list{padding-top:8px}

/* scroll-stepped active highlight (the motion) */
.feat-row{opacity:.30;transition:opacity .6s cubic-bezier(.22,1,.36,1)}
.feat-row.active{opacity:1}
.feat-list{padding-top:0}

/* feature image -> 4/5 to fit landscape interior */
.feat-media{aspect-ratio:4/5}

/* #how -> cinematic parallax image band (replaces 3 cards) */
.how-band{position:relative;width:100%;margin-top:clamp(40px,5vw,64px);border-radius:20px;overflow:hidden;aspect-ratio:21/9;
  clip-path:inset(7% 9% round 20px);box-shadow:0 50px 90px -55px rgba(0,0,0,.5);
  transition:clip-path 1.25s cubic-bezier(.22,1,.36,1),opacity .9s ease,transform 1s cubic-bezier(.22,1,.36,1)}
.how-band.in{clip-path:inset(0 0 round 20px)}
.how-band img{position:absolute;left:0;top:-18%;width:100%;height:136%;object-fit:cover;display:block;will-change:transform}
@media(max-width:860px){.how-band{aspect-ratio:16/10}}

/* ===== #process -> cinematic dark section (token override recolors all) ===== */
#process{
  --paper:#14110D; --paper-2:#1C1813; --paper-3:#241F18;
  --ink:#F7F4EE; --ink-soft:rgba(247,244,238,.74); --muted:rgba(247,244,238,.52);
  --line:rgba(247,244,238,.15); --line-2:rgba(247,244,238,.07);
  background:#14110D; color:#F7F4EE;
}
#process .proc-line i{background:linear-gradient(180deg,#C98A5E,#E6BB8C)}
#process .pstep.on .node{box-shadow:0 0 0 5px rgba(201,138,94,.14),0 0 22px rgba(201,138,94,.32)}
#process .pstep.on .when{color:#D8A878}

/* ===== Areas We Serve (SEO cities) ===== */
#areas .areas-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:38px}
#areas .area-chip{display:inline-flex;padding:10px 18px;border:1px solid var(--line);border-radius:999px;font-size:15px;color:var(--ink-soft);background:var(--paper);transition:border-color .35s var(--ease),color .35s var(--ease),transform .35s var(--ease)}
#areas .area-chip:hover{border-color:var(--ink);color:var(--ink);transform:translateY(-2px)}
#areas .areas-links{margin-top:30px;font-size:15px;color:var(--muted)}
#areas .areas-links a{color:var(--ink-soft);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--line);transition:color .3s}
#areas .areas-links a:hover{color:var(--ink)}

/* ===== FAQ accordion (FAQPage) ===== */
#faqs .faq-list{margin-top:42px;border-top:1px solid var(--line)}
#faqs .faq-item{border-bottom:1px solid var(--line)}
#faqs .faq-item summary{list-style:none;cursor:pointer;padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:28px;font-size:clamp(17px,1.5vw,21px);font-weight:500;letter-spacing:-.01em;color:var(--ink)}
#faqs .faq-item summary::-webkit-details-marker{display:none}
#faqs .faq-item summary::after{content:"+";font-size:26px;line-height:1;color:var(--muted);font-weight:300;transition:transform .4s var(--ease);flex:none}
#faqs .faq-item[open] summary::after{transform:rotate(45deg)}
#faqs .faq-item summary:hover{color:var(--ink-soft)}
#faqs .faq-a{padding:2px 0 26px;color:var(--ink-soft);font-size:16px;line-height:1.62;max-width:72ch}

/* ===== ADU guide grid (SEO body content) ===== */
#guide .guide-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(28px,3vw,46px) clamp(40px,5vw,84px);margin-top:46px}
#guide .guide-item h3{font-size:clamp(19px,1.7vw,23px);font-weight:600;letter-spacing:-.015em;margin-bottom:10px}
#guide .guide-item p{color:var(--ink-soft);font-size:15.5px;line-height:1.62;max-width:50ch}
@media(max-width:860px){#guide .guide-grid{grid-template-columns:1fr;gap:30px}}

/* ADU guide -> premium numbered editorial grid (matches site numbered patterns) */
#guide .guide-grid{grid-template-columns:repeat(3,1fr);gap:clamp(34px,3.4vw,50px) clamp(30px,3.6vw,60px);margin-top:clamp(40px,4vw,58px)}
#guide .guide-item{padding-top:24px;border-top:1px solid var(--line)}
#guide .gno{display:block;font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--muted);margin-bottom:13px;font-variant-numeric:tabular-nums}
#guide .guide-item h3{font-size:clamp(18px,1.35vw,21px);font-weight:600;letter-spacing:-.015em;margin-bottom:10px}
#guide .guide-item p{color:var(--ink-soft);font-size:14.5px;line-height:1.6;max-width:40ch}
@media(max-width:980px){#guide .guide-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){#guide .guide-grid{grid-template-columns:1fr}}

/* ============================================================
   ADU GUIDE PAGE (dedicated content page — same design system)
   ============================================================ */
.guide-page{background:var(--paper)}
/* force light nav (no dark hero behind) */
.guide-page .nav{position:fixed;top:0;left:0;right:0;background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line-2)}
.guide-page .nav .brand{color:var(--ink)}
.guide-page .nav .brand-img .logo-w{display:none}
.guide-page .nav .brand-img .logo-b{display:block}
.guide-page .nav .nav-links a{color:var(--ink-soft)}
.guide-page .nav .nav-toggle span{background:var(--ink)}

/* page hero */
.gp-hero{padding-top:clamp(130px,15vh,190px);padding-bottom:clamp(38px,6vh,68px)}
.gp-title{font-size:clamp(44px,7vw,100px);font-weight:500;letter-spacing:-.03em;line-height:.95;margin-top:18px;color:var(--ink)}
.gp-lead{font-size:clamp(18px,1.6vw,22px);line-height:1.5;color:var(--ink-soft);max-width:60ch;margin-top:24px}
.gp-lead b{font-weight:600;color:var(--ink)}

/* body: sticky toc + content */
.gp-body{display:grid;grid-template-columns:268px 1fr;gap:clamp(40px,6vw,96px);align-items:start;padding-bottom:clamp(60px,8vh,110px)}
.gp-toc{position:sticky;top:108px;display:flex;flex-direction:column;min-width:0}
.gp-toc-h{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.gp-toc nav{display:flex;flex-direction:column;margin-bottom:26px}
.gp-toc-link{display:flex;gap:12px;align-items:baseline;padding:10px 0;font-size:15px;color:var(--muted);transition:color .35s var(--ease);border-bottom:1px solid var(--line-2)}
.gp-toc-link .n{font-size:11.5px;font-weight:600;color:var(--faint);font-variant-numeric:tabular-nums;min-width:20px}
.gp-toc-link:hover{color:var(--ink-soft)}
.gp-toc-link.active{color:var(--ink)}
.gp-toc-link.active .n{color:var(--accent)}
.gp-toc .btn{align-self:flex-start}

.gp-content{max-width:760px;min-width:0}
.gp-sec{padding:clamp(34px,4vw,50px) 0;border-top:1px solid var(--line)}
.gp-sec:first-child{border-top:0;padding-top:0}
.gp-no{display:block;font-size:12.5px;font-weight:600;letter-spacing:.1em;color:var(--accent);margin-bottom:14px;font-variant-numeric:tabular-nums}
.gp-sec h2{font-size:clamp(26px,3vw,40px);font-weight:500;letter-spacing:-.025em;line-height:1.06;margin-bottom:20px;color:var(--ink)}
.gp-sec p{font-size:clamp(16px,1.25vw,18px);line-height:1.62;color:var(--ink-soft);margin-bottom:15px;max-width:64ch}
.gp-sec p b{font-weight:600;color:var(--ink)}
.gp-inline{color:var(--ink);font-weight:500;text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--line)}
.gp-inline:hover{text-decoration-color:var(--ink)}
.gp-defs{display:grid;grid-template-columns:1fr 1fr;gap:24px 44px;margin-top:24px}
.gp-defs dt{font-weight:600;font-size:17px;letter-spacing:-.01em;color:var(--ink);margin-bottom:6px}
.gp-defs dd{margin:0;font-size:15px;line-height:1.55;color:var(--ink-soft)}
.gp-list{margin-top:18px;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:12px}
.gp-list li{position:relative;padding-left:22px;font-size:16px;line-height:1.55;color:var(--ink-soft)}
.gp-list li::before{content:"";position:absolute;left:0;top:11px;width:7px;height:7px;border-radius:50%;background:var(--accent)}
.gp-list li b{color:var(--ink);font-weight:600}
.gp-trust{font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:10px}
.gp-cta{text-align:center;border-top:1px solid var(--line);padding-top:clamp(50px,7vh,88px);padding-bottom:clamp(60px,9vh,120px)}
.gp-cta .lead{margin:18px auto 32px;max-width:48ch}
@media(max-width:980px){
  .gp-body{grid-template-columns:1fr;gap:28px}
  .gp-toc{position:static;border-bottom:1px solid var(--line);padding-bottom:22px}
  .gp-toc nav{margin-bottom:18px}
  .gp-defs{grid-template-columns:1fr}
}

/* nav brand wordmark -> full lockup (matches footer / official logo) */
.brand-wm{display:inline-flex;flex-direction:column;justify-content:center;line-height:1}
.brand-wm b{font-weight:600;font-size:15.5px;letter-spacing:.04em;color:inherit}
.brand-wm small{display:block;font-size:8px;letter-spacing:.26em;font-weight:600;margin-top:4px;color:var(--muted);text-transform:uppercase}
.nav:not(.scrolled) .brand-wm small{color:rgba(247,244,238,.62)}

/* footer mark -> real logo PNG (unify with nav) */
.foot .brand .mark{height:36px;width:auto;display:block}

/* guide page images (match site warm style) */
.gp-hero-img{margin:clamp(6px,2vh,18px) 0 0;border-radius:18px;overflow:hidden;aspect-ratio:16/7;box-shadow:0 40px 80px -55px rgba(0,0,0,.4)}
.gp-hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.gp-fig{margin:30px 0 6px}
.gp-fig img{width:100%;height:auto;display:block;aspect-ratio:16/10;object-fit:cover;border-radius:14px}
.gp-fig figcaption{font-size:13px;color:var(--muted);margin-top:12px;letter-spacing:.01em}
@media(max-width:860px){.gp-hero-img{aspect-ratio:16/9}}

/* quote form (dark CTA) */
.quote-form{margin-top:26px;max-width:580px}
.quote-form .qf-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.quote-form .qf-grid2{display:grid;grid-template-columns:1fr auto;gap:12px;margin-top:12px}
.quote-form input,.quote-form select{background:rgba(247,244,238,.06);border:1px solid rgba(247,244,238,.22);border-radius:12px;color:#F7F4EE;font-family:inherit;font-size:15px;padding:14px 16px;width:100%;transition:border-color .3s,background .3s}
.quote-form input::placeholder{color:rgba(247,244,238,.5)}
.quote-form input:focus,.quote-form select:focus{outline:none;border-color:rgba(247,244,238,.6);background:rgba(247,244,238,.10)}
.quote-form select{color:rgba(247,244,238,.7);appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23F7F4EE' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
.quote-form .qf-grid2 .btn{white-space:nowrap}
.quote-form .qf-status{margin-top:14px;font-size:14px;color:rgba(247,244,238,.88)}
.quote-form .qf-status.err{color:#F0B8A0}
@media(max-width:600px){.quote-form .qf-grid,.quote-form .qf-grid2{grid-template-columns:1fr}}

/* honeypot (anti-spam, hidden) */
.qf-hp{position:absolute !important;left:-9999px !important;width:1px;height:1px;opacity:0;pointer-events:none}

/* fix: quote-form must stack (override .cta-form flex) */
.quote-form{display:block}
.quote-form input,.quote-form select{min-width:0}

/* quote-form readability: brighter text + fixed height so the <select> text isn't clipped */
.quote-form input,.quote-form select{height:54px;padding:0 16px;line-height:1.4;font-size:16px;color:#F7F4EE}
.quote-form select{padding-right:42px;color:rgba(247,244,238,.95)}
.quote-form input::placeholder{color:rgba(247,244,238,.74)}
.quote-form .qf-grid2{align-items:stretch}
.quote-form .qf-grid2 .btn{min-height:54px}

/* Shared CRM quote form overrides. Keep the older homepage .quote-form rules
   from leaking into the light article/page form added for the SEO URL cleanup. */
.quote-form.lsq-quote-form{display:flex;flex-direction:column;gap:12px;max-width:none;margin-top:0}
.quote-form.lsq-quote-form .qf-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.quote-form.lsq-quote-form .qf-grid2{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:12px;margin-top:0}
.quote-form.lsq-quote-form input,
.quote-form.lsq-quote-form select,
.quote-form.lsq-quote-form textarea{
  height:auto;min-height:54px;border-radius:16px;padding:15px 18px;line-height:1.35;
  background:rgba(255,255,255,.62);border:1px solid var(--line);color:var(--ink);
}
.quote-form.lsq-quote-form textarea{min-height:82px;border-radius:18px}
.quote-form.lsq-quote-form input::placeholder,
.quote-form.lsq-quote-form textarea::placeholder{color:var(--muted)}
.quote-form.lsq-quote-form select{appearance:auto;-webkit-appearance:auto;background-image:none;padding-right:18px;color:var(--ink)}
.quote-form.lsq-quote-form select:invalid{color:var(--muted)}
.quote-form.lsq-quote-form .qf-status{color:var(--ink);font-size:15px}
.quote-form.lsq-quote-form .qf-status.err{color:#8A2F21}
.lsq-quote-panel--dark .quote-form.lsq-quote-form input,
.lsq-quote-panel--dark .quote-form.lsq-quote-form select,
.lsq-quote-panel--dark .quote-form.lsq-quote-form textarea{
  background:transparent;border-color:rgba(241,238,231,.25);color:var(--on-black);
}
.lsq-quote-panel--dark .quote-form.lsq-quote-form input::placeholder,
.lsq-quote-panel--dark .quote-form.lsq-quote-form textarea::placeholder{color:var(--on-black-mut)}
.lsq-quote-panel--dark .quote-form.lsq-quote-form select:invalid{color:var(--on-black-mut)}
.lsq-quote-panel--dark .quote-form.lsq-quote-form option{color:var(--ink)}
.lsq-quote-panel--dark .quote-form.lsq-quote-form .qf-status{color:var(--on-black)}
.lsq-quote-panel--dark .quote-form.lsq-quote-form .qf-status.err{color:#FFD6CC}
@media(max-width:760px){
  .quote-form.lsq-quote-form .qf-grid,
  .quote-form.lsq-quote-form .qf-grid2{grid-template-columns:1fr}
}

/* ===== Astra parent-theme override fixes =====
   Astra declares element-level colors (button text #fff, h1–h6 slate #1e293b)
   that beat the redesign's token / inheritance based colors, making text vanish
   on light custom cards and on dark sections. Re-assert the intended colors with
   selectors specific enough to win regardless of cascade order. */

/* Configurator option labels are <button> text, which Astra forces to white,
   but the option cards sit on a light panel → names were invisible. */
.cfg-opt{color:var(--ink)}

/* Headings inside dark sections (#process, .cta) are meant to inherit the
   section's light text color, but Astra's h1–h6 rule overrides inheritance.
   Restore inheritance so each heading follows its section's color. */
#process :is(h1,h2,h3,h4,h5,h6),
.cta :is(h1,h2,h3,h4,h5,h6){color:inherit}

/* ===== Mobile polish (A + B) — 2026-06-07 ===== */

/* A3: open mobile menu shows a light (--paper) panel, so the white logo and
   white hamburger/X would disappear on it — force them dark when menu is open. */
.nav.menu-open .brand-img .logo-w{display:none}
.nav.menu-open .brand-img .logo-b{display:block}
.nav.menu-open .brand{color:var(--ink)}
.nav.menu-open .nav-toggle span{background:var(--ink)}

/* A2: configurator option rows — on narrow screens stack the model name above
   its description (dot pinned right) so names like "The Laguna" stop wrapping. */
@media(max-width:600px){
  .cfg-opt{display:grid;grid-template-columns:1fr auto;align-items:center;column-gap:14px;row-gap:3px}
  .cfg-opt .nm{grid-column:1;grid-row:1}
  .cfg-opt .sf{grid-column:1;grid-row:2}
  .cfg-opt .dot{grid-column:2;grid-row:1 / 3;align-self:center}
}

/* B5: primary CTA inside the open mobile menu (anchors auto-close the menu).
   Higher specificity than ".nav-mobile a" so these don't inherit the giant link size. */
.nav-mobile{overflow-y:auto;padding-block:clamp(80px,14vh,120px)}
.nav-mobile .nav-mobile-cta{display:flex;flex-direction:column;gap:14px;width:100%;margin-top:36px}
.nav-mobile .nav-mobile-quote{display:flex;align-items:center;justify-content:center;gap:10px;height:58px;background:var(--ink);color:var(--paper);border-radius:14px;font-size:18px;font-weight:600;letter-spacing:-.01em;padding:0}
.nav-mobile .nav-mobile-call{text-align:center;font-size:17px;font-weight:500;color:var(--ink-soft);padding:0}

/* B4: persistent bottom CTA bar — mobile only, always one thumb-tap away. */
.m-cta{display:none}
@media(max-width:760px){
  .m-cta{position:fixed;left:0;right:0;bottom:0;z-index:54;display:flex;gap:10px;
    padding:10px 14px calc(10px + env(safe-area-inset-bottom,0px));
    background:color-mix(in srgb,var(--paper) 90%,transparent);
    -webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);
    border-top:1px solid var(--line)}
  .m-cta a{display:flex;align-items:center;justify-content:center;gap:8px;height:52px;border-radius:13px;
    font-size:16px;font-weight:600;letter-spacing:-.01em;text-decoration:none}
  .m-cta-quote{flex:2;background:var(--ink);color:var(--paper)}
  .m-cta-call{flex:1;background:transparent;color:var(--ink);border:1px solid rgba(20,20,20,.28)}
  body{padding-bottom:74px}            /* keep content clear of the fixed bar */
  .nav.menu-open ~ .m-cta{display:none} /* hide bar while full-screen menu is open */
  /* Astra's scroll-to-top button collides with the sticky CTA bar's Call
     button (bottom-right). The CTA bar covers that corner, so hide it on mobile.
     !important overrides Astra's inline display toggle. */
  #ast-scroll-top{display:none!important}
}

/* Small phones: tighten the hero so the primary CTA stays above the fold. */
@media(max-width:600px){
  .hero-cine .hero-cine-inner{padding-top:108px}
  .hero-cine .hero-head{font-size:clamp(40px,11.5vw,58px);margin-top:14px}
  .hero-cine .hero-sub{margin-top:16px;font-size:15px;line-height:1.5}
  .hero-cine .hero-cta{margin-top:24px}
  .hero-cine .scroll-cue{display:none}
}

/* "Details that earn their keep" — mobile redesign.
   On phones the desktop sticky-image + scroll-highlight layout looked broken:
   a later non-media rule (.feat-split 0.92fr 1.08fr) forced 2 columns, so the
   image stayed tiny on the left and rows were dimmed to .30. Make it a clean
   full-width banner image + a readable, full-opacity stacked list. Placed last
   so it wins source order over that override. */
@media(max-width:860px){
  .feat-split{grid-template-columns:1fr;gap:0}
  .feat-media{position:relative;top:0;aspect-ratio:4/5;margin-bottom:clamp(22px,6vw,32px)}
  .feat-media img{aspect-ratio:4/5}
  .feat-list{padding-top:0}
  .feat-row{opacity:1;gap:18px;padding:24px 0;align-items:flex-start}
  .feat-row .ft h4{font-size:clamp(20px,5.6vw,24px)}
  .feat-row .ft p{font-size:15.5px;max-width:none}
}

/* ===== ADU hub pages (template-adu-hub.php) — reuses the .gp-* guide system,
   single-column (no TOC), plus hero/CTA button rows and internal-link band. */
/* Content must never depend on JS to be visible (SEO + reliability + LiteSpeed
   JS-defer): show reveals by default on hubs instead of waiting for the .in class. */
.hub-page .reveal{opacity:1;transform:none}
.hub-body{grid-template-columns:1fr}
.hub-body .gp-content{margin-inline:auto}
.hub-cta{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-top:clamp(26px,3vw,34px)}
.hub-intro .gp-lead-2{font-size:clamp(18px,1.5vw,21px);line-height:1.6;color:var(--ink-soft);max-width:64ch;margin:0}
.hub-why .gp-no{color:var(--accent);font-size:15px}
.hub-faq h2{margin-bottom:6px}
.hub-links{display:flex;flex-wrap:wrap;gap:14px 26px;margin-top:clamp(40px,5vw,56px);padding-top:30px;border-top:1px solid var(--line)}
.hub-links a{font-size:15px;font-weight:500;color:var(--ink-soft);transition:color .3s var(--ease)}
.hub-links a:hover{color:var(--ink)}
.hub-proof{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,330px);gap:clamp(22px,4vw,42px);align-items:center}
.hub-proof h2{font-size:clamp(25px,2.5vw,34px);max-width:14ch}
.hub-proof p{font-size:16px;line-height:1.58;max-width:43ch;margin-bottom:18px}
.hub-proof-link{display:inline-flex;align-items:center;gap:7px;font-size:15px;font-weight:600;color:var(--ink);text-decoration:underline;text-underline-offset:4px;text-decoration-color:rgba(157,107,55,.35);transition:text-decoration-color .3s var(--ease),color .3s var(--ease)}
.hub-proof-link:hover{color:var(--accent);text-decoration-color:currentColor}
.hub-proof-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.hub-proof-thumb{display:block;aspect-ratio:4/3;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--paper-2)}
.hub-proof-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s var(--ease)}
.hub-proof-gallery:hover img{transform:scale(1.035)}
@media(max-width:600px){
  .hub-cta{gap:12px}
  .hub-cta .btn{flex:1 1 100%;justify-content:center}
}
@media(max-width:760px){
  .hub-proof{grid-template-columns:1fr;gap:20px}
  .hub-proof h2{max-width:18ch}
  .hub-proof-gallery{max-width:420px}
}
/* /services/ grid of links to each hub */
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,1.6vw,20px);margin-bottom:clamp(40px,5vw,64px)}
.svc-card{display:flex;flex-direction:column;gap:7px;padding:clamp(22px,2.5vw,30px);border:1px solid var(--line);border-radius:16px;background:var(--paper-2);transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease)}
.svc-card:hover{transform:translateY(-3px);border-color:rgba(20,20,20,.2);box-shadow:0 18px 40px -28px rgba(0,0,0,.3)}
.svc-card-t{font-size:clamp(18px,1.6vw,22px);font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.svc-card-d{font-size:14.5px;line-height:1.5;color:var(--ink-soft)}
.svc-card-ar{margin-top:auto;padding-top:14px;color:var(--accent);font-size:18px}
@media(max-width:620px){.svc-grid{grid-template-columns:1fr}}
/* "Building an ADU in your OC city" citation links */
.hub-cities .city-links{display:flex;flex-wrap:wrap;gap:10px 12px;margin-top:22px}
.hub-cities .city-links a{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border:1px solid var(--line);border-radius:999px;font-size:14.5px;font-weight:500;color:var(--ink-soft);transition:border-color .3s var(--ease),color .3s var(--ease),background .3s var(--ease)}
.hub-cities .city-links a:hover{border-color:var(--ink);color:var(--ink)}
.hub-cities .city-links .city-all{background:var(--paper-2);color:var(--ink)}
/* ===== About page ===== */
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,20px);margin-top:clamp(18px,3vw,30px)}
.about-stats > div{display:flex;flex-direction:column;gap:6px;padding:clamp(20px,2.2vw,28px);border:1px solid var(--line);border-radius:16px;background:var(--paper-2)}
.about-stats .v{font-size:clamp(26px,2.6vw,36px);font-weight:600;letter-spacing:-.02em;color:var(--ink);line-height:1}
.about-stats .k{font-size:13.5px;color:var(--ink-soft);line-height:1.4}
@media(max-width:760px){.about-stats{grid-template-columns:1fr 1fr}}
.about-team{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,26px);margin-top:26px}
.team-card{display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--line);border-radius:18px;background:var(--paper-2);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.team-card:hover{transform:translateY(-3px);box-shadow:0 24px 50px -34px rgba(0,0,0,.35)}
.team-photo{aspect-ratio:4/5;overflow:hidden;background:var(--paper-3)}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:center 22%;display:block;transition:transform .8s var(--ease)}
.team-card:hover .team-photo img{transform:scale(1.04)}
.team-body{padding:clamp(22px,2.4vw,30px)}
.team-card h3{font-size:clamp(20px,1.8vw,24px);font-weight:600;letter-spacing:-.01em;color:var(--ink);margin-bottom:4px}
.team-card .team-role{font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.team-card p{font-size:15.5px;line-height:1.55;color:var(--ink-soft)}
@media(max-width:680px){.about-team{grid-template-columns:1fr}}
.about-reviews .btn{margin-top:18px}
/* Per-type ADU illustration band on hub heroes (watercolor on warm paper) */
.hub-illus{margin:clamp(6px,2vh,18px) 0 0;border:1px solid var(--line);border-radius:18px;overflow:hidden;aspect-ratio:3/2;background:linear-gradient(180deg,#fff 0%,#fbfaf7 52%,#f4f0e8 100%);box-shadow:0 30px 70px -55px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center}
.hub-illus img{width:100%;height:100%;object-fit:contain;padding:30px;display:block}
.hub-illus img[src*="/detached-adu.webp"]{object-fit:cover;object-position:center 63%;padding:0}
@media(max-width:860px){
  .hub-illus{aspect-ratio:4/3}
  .hub-illus img{padding:16px}
  .hub-illus img[src*="/detached-adu.webp"]{padding:0;object-position:center 60%}
}

/* ============================================================
   Contact / FAQs / Areas pages — GHL→CRM migration (2026-06-09)
   ============================================================ */
.contact-section{padding:clamp(36px,6vh,72px) 0 clamp(50px,8vh,96px)}
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,4vw,64px);align-items:start}
.contact-info h2{font-size:clamp(22px,2.4vw,30px);font-weight:500;letter-spacing:-.02em;color:var(--ink);margin-bottom:20px}
.contact-list{list-style:none;margin:0 0 24px;padding:0}
.contact-list li{display:flex;flex-direction:column;gap:3px;padding:15px 0;border-top:1px solid var(--line)}
.contact-list li:first-child{border-top:0}
.ci-k{font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.ci-v{font-size:clamp(16px,1.4vw,19px);color:var(--ink);font-weight:500}
a.ci-v{text-decoration:none;transition:color .3s var(--ease)}
a.ci-v:hover{color:var(--accent)}
.contact-trust{font-size:15px;line-height:1.62;color:var(--ink-soft);margin:0 0 22px;max-width:46ch}
/* form fills its column (override the default centered 760px panel) */
.contact-grid .lsq-quote-panel,
.areas-form-section .lsq-quote-panel{width:100%;margin:0}
.areas-form-section{padding:0 0 clamp(50px,8vh,96px)}

/* Areas — cities + official-resource links */
.areas-grid{list-style:none;margin:6px 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:2px 18px}
.areas-page .areas-grid li{font-size:clamp(15px,1.2vw,17px);color:var(--ink-soft);padding:10px 0;border-bottom:1px solid var(--line)}
.areas-links{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:10px 12px}
.areas-links a{display:inline-flex;align-items:center;gap:6px;font-size:14.5px;color:var(--ink);text-decoration:none;border:1px solid var(--line);border-radius:999px;padding:9px 16px;transition:border-color .3s var(--ease),color .3s var(--ease)}
.areas-links a:hover{border-color:var(--ink);color:var(--accent)}

/* FAQ accordion — faqs page + hub authority FAQ (was previously unstyled) */
.lsq-authority-faq{margin-top:6px}
.lsq-authority-faq .faq-item{border-bottom:1px solid var(--line)}
.lsq-authority-faq .faq-item summary{list-style:none;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:24px;font-size:clamp(17px,1.5vw,21px);font-weight:500;letter-spacing:-.01em;color:var(--ink)}
.lsq-authority-faq .faq-item summary::-webkit-details-marker{display:none}
.lsq-authority-faq .faq-item summary::after{content:"+";font-size:26px;line-height:1;color:var(--muted);font-weight:300;transition:transform .4s var(--ease);flex:none}
.lsq-authority-faq .faq-item[open] summary::after{transform:rotate(45deg)}
.lsq-authority-faq .faq-item summary:hover{color:var(--ink-soft)}
.lsq-authority-faq .faq-a{padding:0 0 24px;font-size:clamp(15px,1.2vw,17px);line-height:1.62;color:var(--ink-soft);max-width:70ch}

@media(max-width:860px){
  .contact-grid{grid-template-columns:1fr;gap:30px}
}
