:root{
  --ink:#0b1b2b;
  --muted:#5a6a7a;
  --line:#e6ecf2;
  --bg:#f6f9fc;
  --card:#ffffff;
  --orange:#e5531d;
  --orange2:#ff7a3d;
  --slate:#1f2933;
  --blue:#0f4d86;
  --radius:14px;
  --shadow: 0 12px 40px rgba(11,27,43,.10);
  --shadow2: 0 10px 22px rgba(11,27,43,.12);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color:var(--ink);
  background:var(--bg);
  line-height:1.45;
}

a{color:inherit}
.container{max-width:1120px;margin:0 auto;padding:0 20px}

.topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--line);
}

.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 0;
  gap:16px;
}

.brand{
  display:flex; align-items:center; gap:12px; text-decoration:none;
  min-width: 230px;
}
.brand img{
  width:44px; height:44px; border-radius:999px;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
}
.brand .name{display:flex; flex-direction:column; line-height:1.05}
.brand .name strong{font-size:14px; letter-spacing:.2px}
.brand .name span{font-size:12px; color:var(--muted)}

.menu{
  display:flex; align-items:center; gap:18px;
}
.menu a{
  text-decoration:none; font-weight:700; font-size:13px;
  color:#1b2b3a;
  padding:10px 10px;
  border-radius:10px;
}
.menu a:hover{background:#f0f5fb}

.actions{
  display:flex; align-items:center; gap:10px;
}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  border-radius:12px;
  padding:12px 14px;
  font-weight:800;
  font-size:13px;
  text-decoration:none;
  border:1px solid transparent;
  transition:transform .08s ease, box-shadow .12s ease, background .12s ease, border-color .12s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background:linear-gradient(135deg,var(--orange),var(--orange2));
  color:#fff;
  box-shadow:0 12px 26px rgba(229,83,29,.26);
}
.btn-primary:hover{box-shadow:0 16px 34px rgba(229,83,29,.28)}
.btn-ghost{
  background:#fff;
  border-color:var(--line);
  color:var(--ink);
}
.btn-ghost:hover{border-color:#cfe0f6;background:#f7fbff}



.hero{
  position:relative;
  background:
    radial-gradient(1200px 500px at 20% -10%, rgba(15,77,134,.28), transparent 60%),
    radial-gradient(900px 500px at 80% -10%, rgba(229,83,29,.24), transparent 60%),
    linear-gradient(180deg, #0b1b2b 0%, #122a3f 55%, #0b1b2b 100%);
  color:#fff;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(800px 320px at 15% 25%, rgba(255,255,255,.10), transparent 55%),
    radial-gradient(700px 320px at 80% 35%, rgba(255,255,255,.08), transparent 55%);
  pointer-events:none;
}
.hero-inner{
  padding:64px 0 58px 0;
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap:28px;
  align-items:center;
  position:relative;
}
.kicker{
  display:inline-flex;
  gap:10px; align-items:center;
  padding:8px 12px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  background:rgba(0,0,0,.14);
  font-size:12px;
  font-weight:900;
  letter-spacing:.3px;
}
.kicker .dot{
  width:10px; height:10px; border-radius:999px;
  background:var(--orange);
  box-shadow:0 0 0 4px rgba(229,83,29,.18);
}
.hero h1{
  margin:14px 0 10px 0;
  font-size:44px;
  line-height:1.05;
  letter-spacing:-.6px;
}
.hero p{
  margin:0;
  color:rgba(255,255,255,.86);
  font-size:16px;
  max-width:56ch;
}
.hero-cta{display:flex; gap:12px; flex-wrap:wrap; margin-top:18px}
.hero-meta{
  margin-top:18px;
  display:flex; gap:10px; flex-wrap:wrap;
}
.pill{
  display:inline-flex; gap:10px; align-items:center;
  padding:10px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  font-size:12px;
  font-weight:800;
}
.pill svg{width:16px;height:16px;opacity:.9}

.hero-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:0 18px 42px rgba(0,0,0,.25);
}
.hero-card .badge{
  display:flex; align-items:center; gap:14px;
}
.hero-card img{width:86px;height:86px;border-radius:999px;background:#fff;border:1px solid rgba(255,255,255,.18)}
.hero-card h3{margin:0;font-size:16px}
.hero-card p{margin:6px 0 0 0; font-size:13px; color:rgba(255,255,255,.84)}
.hero-card .mini{
  margin-top:12px;
  display:grid; gap:10px;
}
.mini-row{
  display:flex; align-items:flex-start; gap:10px;
  font-size:13px; color:rgba(255,255,255,.86);
}
.mini-row b{color:#fff}
.mini-row svg{width:18px;height:18px; flex:0 0 auto; opacity:.9; margin-top:2px}

.section{
  padding:56px 0;
}
.section h2{
  margin:0 0 10px 0;
  font-size:30px;
  letter-spacing:-.3px;
}
.section p.lead{
  margin:0 0 20px 0;
  color:var(--muted);
  max-width:78ch;
}

.grid{
  display:grid;
  grid-template-columns: repeat(4,1fr);
  gap:16px;
}
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:0 1px 0 rgba(11,27,43,.02);
}
.card:hover{box-shadow:var(--shadow2)}
.card .icon{
  width:44px;height:44px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#fff, #f6fbff);
  border:1px solid #e6f0ff;
  color:var(--blue);
}
.card h3{margin:12px 0 6px 0; font-size:16px}
.card p{margin:0; color:var(--muted); font-size:13px}

.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  align-items:start;
}
.panel{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:20px;
  box-shadow:0 1px 0 rgba(11,27,43,.02);
}
.panel h3{margin:0 0 10px 0}
ul.clean{margin:0;padding-left:18px;color:var(--muted)}
ul.clean li{margin:8px 0}

.callout{
  background:linear-gradient(135deg, rgba(229,83,29,.10), rgba(15,77,134,.10));
  border:1px solid rgba(15,77,134,.14);
  border-radius:var(--radius);
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.callout strong{font-size:14px}
.callout span{color:var(--muted); font-weight:700; font-size:13px}
.callout .btn{flex:0 0 auto}

.contact{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:16px;
}
.form{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
}
.row{display:grid; grid-template-columns: 1fr 1fr; gap:12px}
label{display:block; font-size:12px; font-weight:900; margin:12px 0 6px 0; color:#1b2b3a}
input,select,textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px 12px;
  font-size:14px;
  outline:none;
  background:#fff;
}
textarea{min-height:120px; resize:vertical}
input:focus,select:focus,textarea:focus{border-color:#b9d6ff; box-shadow:0 0 0 4px rgba(15,77,134,.12)}
.form .btn{margin-top:14px}

.aside{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
}
.aside .emergency{
  border-radius:14px;
  border:1px solid rgba(229,83,29,.22);
  background:rgba(229,83,29,.08);
  padding:14px;
}
.aside .emergency b{display:block; font-size:14px}
.aside .emergency p{margin:6px 0 0 0; color:var(--muted); font-size:13px}
.aside .stack{margin-top:14px; display:grid; gap:10px}
.kv{
  border:1px dashed #d7e6f8;
  border-radius:14px;
  padding:12px;
  background:#f9fcff;
}
.kv b{display:block; font-size:12px}
.kv span{color:var(--muted); font-size:13px; font-weight:700}

.footer{
  background:#071522;
  color:rgba(255,255,255,.78);
  padding:28px 0;
  border-top:1px solid rgba(255,255,255,.08);
}
.footer .fgrid{
  display:grid; grid-template-columns: 1.1fr .9fr .9fr; gap:16px;
  align-items:start;
}
.footer a{color:rgba(255,255,255,.78); text-decoration:none}
.footer a:hover{color:#fff}
.footer h4{margin:0 0 10px 0; color:#fff}
.small{font-size:12px; color:rgba(255,255,255,.62)}

.notice{
  margin-top:14px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  font-size:12px;
  color:rgba(255,255,255,.82);
}

@media (max-width: 960px){
  .hero-inner{grid-template-columns: 1fr; padding:54px 0}
  .grid{grid-template-columns: repeat(2,1fr)}
  .split{grid-template-columns: 1fr}
  .contact{grid-template-columns: 1fr}
  .footer .fgrid{grid-template-columns: 1fr}
  .menu{display:none}
  }

@media (max-width: 520px){
  .hero h1{font-size:36px}
  .row{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
}



/* Sticky Emergency Activation CTA */
.sticky-cta{
  position: fixed;
  left: 0; right: 0;
  bottom: 14px;
  z-index: 999;
  pointer-events: none; /* allow click only on inner */
}
.sticky-cta .inner{
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 20px;
}
.sticky-cta .bar{
  pointer-events: auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 12px 12px 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(7,21,34,.92);
  backdrop-filter: saturate(140%) blur(10px);
  box-shadow: 0 18px 40px rgba(0,0,0,.32);
  color: rgba(255,255,255,.90);
}
.sticky-cta .left{
  display:flex;
  align-items:center;
  gap:12px;
  min-width: 0;
}
.sticky-cta .badge-dot{
  width:12px;height:12px;border-radius:999px;
  background: var(--orange);
  box-shadow: 0 0 0 5px rgba(229,83,29,.18);
  flex: 0 0 auto;
}
.sticky-cta .text{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}
.sticky-cta .text b{
  font-size:13px;
  letter-spacing:.2px;
}
.sticky-cta .text span{
  font-size:12px;
  color: rgba(255,255,255,.72);
  font-weight:700;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.sticky-cta .right{
  display:flex;
  align-items:center;
  gap:10px;
  flex: 0 0 auto;
}
.sticky-cta .mini-btn{
  height: 40px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  color:#fff;
  font-weight:900;
  font-size:12px;
  cursor:pointer;
}
.sticky-cta .mini-btn:hover{background: rgba(255,255,255,.10)}
.sticky-cta .mini-btn:active{transform: translateY(1px)}
.sticky-cta.hidden{display:none}

/* Prevent overlap with footer on small screens */
@media (max-width: 520px){
  .sticky-cta{bottom: 10px}
  .sticky-cta .text span{display:none}
}

/* Footer SAM mini badge */
.footer-sam{margin-top:12px;display:flex;justify-content:center}
.sam-mini{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--line);border-radius:999px;text-decoration:none;color:inherit;background:#fff}
.sam-mini .dot{width:10px;height:10px;border-radius:999px;border:1px solid var(--line);background:rgba(245,158,11,.18)}
.pill.ok + .dot{}
/* Dot color follows pill state via JS (set on parent) */
.sam-mini.ok .dot{background:rgba(34,197,94,.25);border-color:rgba(34,197,94,.35)}
.sam-mini.bad .dot{background:rgba(239,68,68,.18);border-color:rgba(239,68,68,.35)}
.sam-mini.warn .dot{background:rgba(245,158,11,.18);border-color:rgba(245,158,11,.35)}

/* Dropdown nav (Option A) */
.dropdown{position:relative;display:inline-block}
.dropbtn{
  background:transparent;border:0;font:inherit;font-weight:900;cursor:pointer;
  padding:10px 8px;border-radius:10px;color:inherit;
}
.dropbtn:focus{outline:2px solid rgba(15,77,134,.25);outline-offset:2px}
.dropbtn .chev{font-weight:900;opacity:.75;margin-left:4px}
.dropmenu{
  display:none;position:absolute;top:42px;left:0;min-width:240px;z-index:80;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:0 12px 30px rgba(0,0,0,.10);padding:8px;
}
.dropmenu a{display:block;padding:10px 10px;border-radius:10px;text-decoration:none;color:inherit;font-weight:800}
.dropmenu a:hover{background:rgba(15,77,134,.08)}
.dropdown:hover .dropmenu{display:block}
.dropdown.open .dropmenu{display:block}

/* Mobile drawer groups */
.mgroup{width:100%;text-align:left;background:transparent;border:1px solid var(--line);
  border-radius:12px;padding:12px 12px;margin-top:10px;font-weight:900;cursor:pointer}
.mgroup-menu{padding:8px 6px}
.mgroup-menu a{display:block;padding:10px 10px;border-radius:10px;text-decoration:none;color:inherit;font-weight:800}
.mgroup-menu a:hover{background:rgba(15,77,134,.08)}

/* Keep dropdown usable when header wraps */
@media (max-width: 860px){
  .dropdown:hover .dropmenu{display:none} /* rely on click-to-open on small screens */
}


/* Contact CTA Button */
.contact-cta{
  background:#c0392b;
  color:#fff;
  padding:10px 18px;
  border-radius:10px;
  font-weight:900;
  text-decoration:none;
  white-space:nowrap;
}
.contact-cta:hover{
  background:#a93226;
}


/* Desktop-only navigation baseline */
.menu{ display:flex !important; flex-wrap:wrap; justify-content:center; }
.actions{ margin-left:auto; display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end; }
.nav{ flex-wrap:wrap; }


/* Emergency banner styling (uses existing .callout base) */
[data-emergency-banner]{
  border-color: rgba(229,83,29,.28) !important;
  background: linear-gradient(135deg, rgba(229,83,29,.12), rgba(15,77,134,.10)) !important;
}


/* Compact Emergency Activation Banner (full-width, above contact grid) */
.emergency-banner{
  margin: 0 0 14px 0;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(229,83,29,.30);
  background: linear-gradient(135deg, rgba(229,83,29,.10), rgba(15,77,134,.08));
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.emergency-banner strong{ font-size:13px; letter-spacing:.2px; }
.emergency-banner span{ font-size:12px; color: var(--muted); font-weight:700; }


/* Emergency Phone CTA (shown only in emergency mode) */
.emergency-phone{
  margin: 0 0 16px 0;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(229,83,29,.35);
  background: rgba(229,83,29,.08);
  display: flex;
  align-items: center;
  gap: 12px;
}
.emergency-phone strong{
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
}
.emergency-phone .phone-link{
  font-size: 16px;
  font-weight: 900;
  color: #c0392b;
  text-decoration: none;
}
.emergency-phone .phone-link:hover{
  text-decoration: underline;
}
.emergency-phone .note{
  font-size: 12px;
  color: var(--muted);
  font-weight: 700;
}

/* Inline SAM.gov verification badge (About page) */
.sam-inline{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--line);
border-radius:999px;text-decoration:none;color:inherit;background:#fff;font-weight:900;font-size:12px}
.sam-inline .dot{width:10px;height:10px;border-radius:999px;border:1px solid var(--line);
background:rgba(245,158,11,.18)}
.sam-inline .label{opacity:.85}
.sam-inline.ok .dot{background:rgba(34,197,94,.25);border-color:rgba(34,197,94,.35)}
.sam-inline.bad .dot{background:rgba(239,68,68,.18);border-color:rgba(239,68,68,.35)}
.sam-inline.warn .dot{background:rgba(245,158,11,.18);border-color:rgba(245,158,11,.35)}
.sam-inline:hover{border-color:#cfe0f6;background:#f7fbff}


/* Footer SAM badge readability */
.footer .sam-mini{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:#fff}
.footer .sam-mini .pill{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16)}


/* Move nav links to the left (Public Sector update) */
.topbar .nav{justify-content:flex-start;}
.topbar .menu{margin-left:24px;}


/* Keep header CTAs on one line */
.topbar .actions{display:flex;align-items:center;gap:10px;white-space:nowrap;}
.topbar .btn{padding:10px 14px;font-size:14px;}
.topbar .emergency-btn{font-weight:600;}
.label-mobile{display:none;}
@media (max-width:720px){.label-desktop{display:none;}.label-mobile{display:inline;}}


/* === CLEAN FIX: Emergency CTA responsive label (authoritative) === */
.topbar .emergency-btn .label-desktop{display:inline !important;}
.topbar .emergency-btn .label-mobile{display:none !important;}
@media (max-width:720px){
  .topbar .emergency-btn .label-desktop{display:none !important;}
  .topbar .emergency-btn .label-mobile{display:inline !important;}
}


/* Header wrap fix: keep CTAs on one line */
.topbar .actions{display:flex;align-items:center;gap:8px;white-space:nowrap;flex-wrap:nowrap;}
.topbar .menu{white-space:nowrap;}
@media (max-width:1100px){.topbar .brand .name span{display:none;}}


/* === Residential landing page cards === */
.card-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.card{
  background:#fff;
  border-radius:12px;
  padding:24px;
  box-shadow:0 8px 24px rgba(0,0,0,.08);
  border:1px solid rgba(0,0,0,.06);
}
@media(max-width:768px){
  .card-grid{grid-template-columns:1fr;}
}


/* === Residential landing page form === */
.form-card{
  background:#fff;
  border-radius:12px;
  padding:22px;
  box-shadow:0 8px 24px rgba(0,0,0,.08);
  border:1px solid rgba(0,0,0,.06);
}
.form-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin-bottom:14px;
}
.form-card label{
  display:block;
  font-weight:600;
  margin:0 0 6px;
}
.form-card input,
.form-card textarea{
  width:100%;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.14);
  padding:12px 12px;
  outline:none;
}
.form-card textarea{resize:vertical; min-height:110px;}
.form-actions{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin-top:12px;
}
#zip-msg{min-height:18px;}
@media(max-width:768px){
  .form-grid{grid-template-columns:1fr;}
}


/* === Mobile sticky CTA bar (Residential) === */
.mobile-cta{display:none;}
@media(max-width:768px){
  .mobile-cta{
    display:flex;
    position:fixed;
    bottom:0;
    left:0;
    right:0;
    background:#0b1b2b;
    z-index:999;
  }
  .mobile-cta a{
    flex:1;
    text-align:center;
    padding:14px;
    color:#fff;
    font-weight:700;
    text-decoration:none;
    border-right:1px solid rgba(255,255,255,.15);
  }
  .mobile-cta a:last-child{border-right:none;}
  body{padding-bottom:56px;} /* prevent CTA overlay */
}


/* === Instant quote widget === */
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:12px;}
.quote-grid .full{grid-column:1/-1;}
.quote-box{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.08);
  border-radius:12px;
  padding:16px;
}
.quote-box h3{margin:0 0 8px;}
.quote-price{
  font-size:28px;
  font-weight:800;
  letter-spacing:-.02em;
  margin:6px 0 6px;
}
.quote-note{opacity:.8}
.form-card select{
  width:100%;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.14);
  padding:12px 12px;
  outline:none;
  background:#fff;
}
@media(max-width:768px){
  .quote-grid{grid-template-columns:1fr;}
}

/* === Scoped fixes for Residential landing page only ===
   Prevents global changes from affecting other pages/cards.
   Requires: <body class="lp-residential"> on residential.html
*/
body.lp-residential .hero .small,
body.lp-residential .hero p.small,
body.lp-residential .hero .quote-note,
body.lp-residential .hero #zip-msg{
  color: rgba(255,255,255,.85) !important;
}

body.lp-residential .form-card .small,
body.lp-residential .form-card p.small,
body.lp-residential .form-card .quote-note,
body.lp-residential .form-card #zip-msg{
  color: rgba(17,24,39,.78) !important;
}

body.lp-residential #zip-msg{ font-weight:700; }
body.lp-residential #zip-msg.ok{ color:#16a34a !important; }
body.lp-residential #zip-msg.bad{ color:#dc2626 !important; }

/* === Residential B booking layout === */
body.lp-residential-b .b-wrap{
  min-height: calc(100vh - 60px);
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:32px 16px 16px;
}
body.lp-residential-b .b-card{
  width:min(820px, 100%);
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  box-shadow:0 18px 60px rgba(0,0,0,.18);
  overflow:hidden;
}
body.lp-residential-b .b-head{
  padding:22px 22px 10px;
  border-bottom:1px solid rgba(0,0,0,.06);
  background:linear-gradient(180deg, rgba(15,77,134,.06), rgba(255,255,255,0));
}
body.lp-residential-b .b-head h1{
  margin:6px 0 6px;
  font-size: clamp(22px, 4vw, 34px);
  letter-spacing:-.02em;
}
body.lp-residential-b .b-head .sub{
  opacity:.78;
  margin:0 0 10px;
}
body.lp-residential-b .b-trust{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:10px;
}
body.lp-residential-b .pill{
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding:8px 10px;
  border:1px solid rgba(0,0,0,.10);
  border-radius:999px;
  font-size:12px;
  opacity:.9;
  background:#fff;
}
body.lp-residential-b .b-body{ padding:18px 22px 22px; }
body.lp-residential-b .b-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
}
body.lp-residential-b .b-grid .full{ grid-column:1 / -1; }
body.lp-residential-b .b-card label{ display:block; font-weight:700; margin:0 0 6px; }
body.lp-residential-b .b-card input,
body.lp-residential-b .b-card select,
body.lp-residential-b .b-card textarea{
  width:100%;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.14);
  padding:12px 12px;
  outline:none;
  background:#fff;
}
body.lp-residential-b .b-card textarea{ min-height:110px; resize:vertical; }
body.lp-residential-b .b-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:14px;
}
body.lp-residential-b .b-foot{
  padding:14px 22px;
  border-top:1px solid rgba(0,0,0,.06);
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  opacity:.85;
}
@media(max-width:760px){
  body.lp-residential-b .b-grid{ grid-template-columns:1fr; }
}

/* === Booking wizard (Residential B) === */
body.lp-residential-b .stepper{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px;}
body.lp-residential-b .step{
  display:flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:999px;
  border:1px solid rgba(0,0,0,.10);
  font-size:12px;opacity:.65;background:#fff;
}
body.lp-residential-b .step .n{
  width:20px;height:20px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(0,0,0,.18);font-weight:800;font-size:12px;
}
body.lp-residential-b .step.active{opacity:1;border-color:rgba(15,77,134,.35);}
body.lp-residential-b .step.active .n{border-color:rgba(15,77,134,.55);}
body.lp-residential-b .wizard{margin-top:12px;}
body.lp-residential-b .wizard fieldset{border:0;padding:0;margin:0;display:none;}
body.lp-residential-b .wizard fieldset.active{display:block;}
body.lp-residential-b .summary{
  border:1px solid rgba(0,0,0,.10);
  border-radius:14px;
  padding:14px;
  background:rgba(15,77,134,.04);
}
body.lp-residential-b .summary .row{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;margin:6px 0;}
body.lp-residential-b .summary .k{opacity:.7;}
body.lp-residential-b .summary .v{font-weight:800;}
body.lp-residential-b .hint{font-size:12px;opacity:.75;margin-top:8px;}
body.lp-residential-b #wiz-msg.err{color:#dc2626;font-weight:800;font-size:12px;margin-top:10px;}
