/* HeatBots — shared site stylesheet.
   Deep-navy "winter night" + amber "heat coil" + ice-blue accent. */
:root{
  --ink:#0b1a2e; --ink2:#122236; --ink3:#050b16;
  --amber:#f59e0b; --amber2:#fbbf24; --ice:#7dd3fc; --gold:#fbbf24; --rose:#fb7185;
  --paper:#f7f9fc; --line:#e4e9f2; --slate:#475569; --slate2:#64748b; --charcoal:#0f172a;
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ margin:0; background:var(--paper); color:var(--charcoal);
      font-family:'Inter',-apple-system,Segoe UI,sans-serif; line-height:1.6; }
img{ max-width:100%; }
a{ color:var(--amber); text-decoration:none; }
a:hover{ text-decoration:underline; }
.wrap{ max-width:1080px; margin:0 auto; padding:0 22px; }
.wrap-narrow{ max-width:780px; margin:0 auto; padding:0 22px; }
h1,h2,h3,h4,.brand{ font-family:'Sora',sans-serif; letter-spacing:-.01em; }
.sr-only{ position:absolute; left:-9999px; }

/* ─── HEADER / NAV ─── */
header{ position:sticky; top:0; z-index:50; background:rgba(11,26,46,.92);
        backdrop-filter:blur(8px); border-bottom:1px solid rgba(255,255,255,.08); }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:16px;
      padding:12px 22px; max-width:1080px; margin:0 auto; }
.logo{ display:flex; align-items:center; gap:11px; color:#fff; }
.logo:hover{ text-decoration:none; }
.logo img{ height:34px; width:34px; object-fit:contain; background:#fff;
           border-radius:7px; padding:2px; }
.logo .brand{ font-weight:800; font-size:19px; letter-spacing:.3px; }
.logo .brand b{ color:var(--amber); }
.nav-links{ display:flex; align-items:center; gap:22px; }
.nav-links a{ color:#cbd5e1; font-weight:600; font-size:14.5px; }
.nav-links a:hover{ color:#fff; text-decoration:none; }
.nav-cta{ background:var(--amber); color:#1a0f00 !important;
          padding:9px 18px; border-radius:999px; font-weight:800; }
.nav-cta:hover{ background:var(--amber2); }
.nav-login{ color:#fff !important; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18);
            padding:8px 14px; border-radius:999px; font-weight:700 !important; font-size:13.5px !important; }
.nav-login:hover{ background:rgba(255,255,255,.14); text-decoration:none; }
.burger{ display:none; background:none; border:0; cursor:pointer; padding:6px; }
.burger span{ display:block; width:24px; height:2px; background:#fff; margin:5px 0; border-radius:2px; }


/* ─── BRAND BAR (Scott Whiting Companies) ─── */
.brand-bar{ background:var(--ink3); color:rgba(255,255,255,.75); font-size:12px; letter-spacing:.5px;
            padding:6px 22px; display:flex; align-items:center; justify-content:space-between; gap:12px; }
.brand-bar a{ color:rgba(255,255,255,.75); text-decoration:none; transition:color .2s; }
.brand-bar a:hover{ color:var(--amber); }
.brand-bar-links{ display:flex; gap:16px; align-items:center; flex-wrap:wrap; }
.brand-bar-label{ font-size:10px; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.4); }
.brand-bar-sep{ color:rgba(255,255,255,.2); }
.brand-bar-link{ display:inline-flex; align-items:center; gap:5px; }
.brand-bar-link img{ height:20px; width:20px; object-fit:contain; background:#fff; border-radius:4px; padding:2px; }
.brand-bar-link.current{ color:var(--amber); font-weight:700; }
@media(max-width:760px){
  .brand-bar{ flex-direction:column; gap:6px; padding:8px 16px; text-align:center; }
  .brand-bar-links{ justify-content:center; }
}

/* ─── ANNOUNCEMENT BAR ─── */
.annc{ background:var(--ice); color:#062436; text-align:center; padding:7px 16px;
       font-size:13px; font-weight:700; font-family:'Inter',sans-serif; }
.annc a{ color:#062436; text-decoration:underline; }

/* ─── HERO ─── */
.hero{ background:radial-gradient(900px 500px at 80% -10%, rgba(245,158,11,.22), transparent 60%),
       linear-gradient(180deg,var(--ink),var(--ink2)); color:#fff; }
.hero-in{ display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
          padding:64px 0 72px; }
.kick{ font-size:12px; letter-spacing:3px; text-transform:uppercase;
       color:var(--amber); font-weight:800; }
.hero h1{ font-size:clamp(34px,5vw,54px); line-height:1.08; margin:12px 0 14px; font-weight:800; }
.hero h1 em{ font-style:normal; color:var(--amber); text-shadow:0 0 24px rgba(245,158,11,.55); }
.hero p{ color:#c2cee0; font-size:17px; max-width:520px; margin:0 0 26px; }
.hero .btns a{ display:inline-block; font-weight:800; border-radius:999px;
               padding:14px 26px; margin:0 10px 10px 0; }
.b-glow{ background:var(--amber); color:#1a0f00 !important;
         box-shadow:0 10px 30px rgba(245,158,11,.45); }
.b-glow:hover{ background:var(--amber2); text-decoration:none; }
.b-ghost{ border:2px solid rgba(255,255,255,.35); color:#fff !important; }
.b-ghost:hover{ background:rgba(255,255,255,.08); text-decoration:none; }
.b-solid{ background:var(--charcoal); color:#fff !important; padding:14px 26px;
          border-radius:999px; font-weight:800; display:inline-block; }
.b-solid:hover{ background:#1a2540; text-decoration:none; }
.hero-img{ width:100%; border-radius:16px; box-shadow:0 30px 70px rgba(0,0,0,.55);
           border:1px solid rgba(255,255,255,.12); display:block; }
.pills{ display:flex; gap:10px; flex-wrap:wrap; margin-top:8px; }
.pills span{ font-size:12.5px; font-weight:700; color:#9fb4cc;
             border:1px solid rgba(255,255,255,.15); border-radius:999px; padding:5px 13px; }

/* compact hero variant for inner pages */
.hero.compact .hero-in{ grid-template-columns:1fr; padding:54px 0 44px; text-align:center; }
.hero.compact h1{ margin-left:auto; margin-right:auto; max-width:780px; }
.hero.compact p{ margin-left:auto; margin-right:auto; }

/* breadcrumb */
.crumb{ font-size:13px; color:#9fb4cc; padding:14px 0 0; }
.crumb a{ color:#9fb4cc; } .crumb a:hover{ color:#fff; }

/* ─── SECTIONS ─── */
section{ padding:64px 0; }
.eyebrow{ font-size:12px; letter-spacing:3px; text-transform:uppercase;
          color:var(--amber); font-weight:800; text-align:center; }
h2.sec{ font-size:clamp(26px,3.6vw,38px); text-align:center; margin:8px 0 8px; font-weight:800; }
.sub{ text-align:center; color:var(--slate); max-width:640px; margin:0 auto 38px; font-size:16.5px; }
.dark{ background:var(--ink); color:#fff; }
.dark h2.sec, .dark .sub{ color:#fff; }
.dark .sub{ color:#a9bace; }
.dark .feat{ background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.1); }
.dark .feat p{ color:#a9bace; }

.grid2{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.grid3{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.grid4{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }

.feat{ background:#fff; border:1px solid var(--line); border-radius:14px;
       padding:24px; transition:transform .15s ease, box-shadow .15s ease; }
.feat:hover{ transform:translateY(-2px); box-shadow:0 12px 30px rgba(15,23,42,.08); }
.feat .ic{ font-size:26px; line-height:1; }
.feat h3{ font-size:18px; margin:10px 0 6px; }
.feat p{ margin:0; color:var(--slate); font-size:14.5px; }
.feat .more{ display:inline-block; margin-top:12px; font-weight:700; font-size:13.5px; }

.trust{ background:#fff; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:22px 0; }
.trust-row{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center;
            gap:18px 30px; color:var(--slate2); font-size:13.5px; font-weight:600; }
.trust-row b{ color:var(--charcoal); }

.quote{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:24px; }
.quote .q{ font-size:16px; color:var(--charcoal); margin:0 0 12px; line-height:1.55; }
.quote .who{ font-size:13.5px; color:var(--slate); font-weight:600; }
.quote .stars{ color:var(--gold); font-size:14px; letter-spacing:1px; }

.gtee{ background:linear-gradient(135deg,#1a0f00,#3d2400);
       color:#fff; border-radius:18px; padding:32px; display:flex; gap:22px; align-items:center; }
.gtee .seal{ width:96px; height:96px; flex:0 0 96px; border-radius:50%;
             background:var(--amber); color:#1a0f00; display:flex; align-items:center; justify-content:center;
             font-family:'Sora',sans-serif; font-weight:800; font-size:12px; text-align:center; line-height:1.15;
             box-shadow:0 8px 30px rgba(245,158,11,.5); }
.gtee h3{ margin:0 0 6px; font-size:20px; }
.gtee p{ margin:0; color:#e8d5b8; font-size:14.5px; }

.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.gallery .gitem{ position:relative; overflow:hidden; border-radius:12px; border:1px solid var(--line); }
.gallery img{ width:100%; height:200px; object-fit:cover; display:block; transition:transform .25s ease; }
.gallery .gitem:hover img{ transform:scale(1.05); }
.gallery .cap{ position:absolute; bottom:0; left:0; right:0; padding:10px 12px;
               background:linear-gradient(transparent,rgba(0,0,0,.75));
               color:#fff; font-size:13px; font-weight:600; }

.city-tags{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center;
            max-width:760px; margin:0 auto; }
.city-tags a, .city-tags span{ background:#fff; border:1px solid var(--line); border-radius:999px;
                                padding:8px 16px; font-weight:600; font-size:14px; color:var(--charcoal); }
.city-tags a:hover{ background:var(--amber); color:#1a0f00; text-decoration:none; border-color:var(--amber); }
.city-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.city-card{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:22px;
            text-decoration:none; color:var(--charcoal); display:block; transition:all .15s ease; }
.city-card:hover{ border-color:var(--amber); box-shadow:0 8px 24px rgba(245,158,11,.15);
                  transform:translateY(-2px); text-decoration:none; }
.city-card h3{ margin:0 0 6px; font-size:18px; }
.city-card p{ margin:0; color:var(--slate); font-size:14px; }
.city-card .arrow{ float:right; color:var(--amber); font-weight:800; }

/* ─── SAVINGS CALC ─── */
.savings-box{ background:linear-gradient(135deg,#0b1a2e,#1d2c47); color:#fff; border-radius:18px;
              padding:32px; text-align:center; }
.savings-box .big{ font-family:'Sora',sans-serif; font-size:54px; font-weight:800; color:var(--amber);
                   line-height:1; margin:6px 0 4px; }
.savings-box .small{ font-size:14px; color:#a9bace; }

/* ─── CONSULTATION FORM ─── */
.cta{ background:radial-gradient(700px 400px at 20% 0%, rgba(245,158,11,.18), transparent 60%), var(--ink); color:#fff; }
.cta h2.sec, .cta .sub{ color:#fff; } .cta .sub{ color:#a9bace; }
#cf, .cf{ display:grid; grid-template-columns:1fr 1fr; gap:12px; max-width:620px; margin:0 auto; }
#cf input, #cf textarea, .cf input, .cf textarea{
   width:100%; padding:13px 15px; border:0; border-radius:10px; font-size:15px; font-family:inherit; }
#cf .full, .cf .full{ grid-column:1/-1; }
#cf textarea, .cf textarea{ min-height:90px; resize:vertical; }
#cf button, .cf button{ grid-column:1/-1; background:var(--amber); color:#1a0f00;
                         font-weight:800; border:0; border-radius:999px; padding:15px; font-size:15px; cursor:pointer; }
#cf button:hover, .cf button:hover{ background:var(--amber2); }
#cfMsg, .cfMsg{ text-align:center; margin-top:14px; color:#fff; }
.cf-aside{ text-align:center; color:#a9bace; font-size:13.5px; margin-top:14px; }
.cf-aside a{ color:#fff; font-weight:700; }

.faq details{ background:#fff; border:1px solid var(--line); border-radius:12px;
              padding:16px 20px; margin-bottom:10px; }
.faq summary{ cursor:pointer; font-weight:700; font-size:15.5px; list-style:none; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; float:right; font-size:22px; line-height:1; color:var(--amber); }
.faq details[open] summary::after{ content:"–"; }
.faq details p{ margin:10px 0 0; color:var(--slate); }

.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.step{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:22px; position:relative; }
.step .n{ position:absolute; top:-14px; left:22px; width:32px; height:32px;
          background:var(--amber); color:#1a0f00; border-radius:50%;
          display:flex; align-items:center; justify-content:center;
          font-family:'Sora',sans-serif; font-weight:800; font-size:15px; }
.step h3{ margin:8px 0 6px; font-size:16.5px; }
.step p{ margin:0; color:var(--slate); font-size:14px; }

footer{ background:var(--ink3); color:#8aa0ba; padding:40px 0 28px; font-size:14px; }
footer .cols{ display:flex; flex-wrap:wrap; gap:30px; justify-content:space-between; }
footer a{ color:#bcd; }
footer h4{ color:#fff; font-size:14px; margin:0 0 10px; text-transform:uppercase; letter-spacing:1.5px; }
footer ul{ list-style:none; padding:0; margin:0; }
footer ul li{ margin:5px 0; }
footer .brand-row{ display:flex; gap:14px; flex-wrap:wrap; margin-top:10px; }
footer .bottom{ border-top:1px solid rgba(255,255,255,.08); margin-top:24px;
                padding-top:16px; font-size:12.5px; color:#67809a;
                display:flex; flex-wrap:wrap; justify-content:space-between; gap:10px; }

.portal-bar{ background:linear-gradient(135deg,#3d2400,#1a0f00); color:#fff;
             border-radius:14px; padding:18px 22px; margin-top:20px;
             display:flex; flex-wrap:wrap; gap:14px; align-items:center; justify-content:space-between; }
.portal-bar .pb-lead{ font-family:'Sora',sans-serif; font-weight:700; font-size:15px; color:#fff; }
.portal-bar .pb-lead span{ display:block; font-family:'Inter',sans-serif; font-weight:500; font-size:12.5px; color:#e8d5b8; }
.portal-bar .pb-btns{ display:flex; gap:10px; flex-wrap:wrap; }
.portal-bar .pb-btns a{ background:var(--amber); color:#1a0f00 !important; padding:9px 16px; border-radius:999px;
                        font-weight:700; font-size:13.5px; }
.portal-bar .pb-btns a.alt{ background:transparent; color:#fff !important; border:1px solid rgba(255,255,255,.3); }
.portal-bar .pb-btns a:hover{ text-decoration:none; opacity:.92; }

@media(max-width:980px){
  .grid3, .grid4, .steps, .city-cards, .gallery{ grid-template-columns:repeat(2,1fr); }
}
@media(max-width:760px){
  .nav-links{ display:none; }
  .burger{ display:block; }
  body.nav-open .nav-links{ display:flex; position:absolute; top:60px; left:0; right:0;
                            flex-direction:column; background:var(--ink); padding:18px 22px; gap:16px; }
  .hero-in{ grid-template-columns:1fr; padding:48px 0 56px; }
  .grid2,.grid3,.grid4,.steps,.city-cards{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr 1fr; }
  #cf,.cf{ grid-template-columns:1fr; }
  .gtee{ flex-direction:column; text-align:center; padding:26px 20px; }
  section{ padding:48px 0; }
}
