/* ===================================================================
   ComeBack Restoration, LLC — Global Design System
   Distinct identity: near-black ink navy base + terracotta urgency
   accent + slate-teal + a restrained brass/gold premium accent.
   Water motif via wave dividers & hero overlay.
   =================================================================== */

/* ---------- Design Tokens ---------- */
:root{
  /* Color palette */
  --navy-900:#070f1a;
  --navy-800:#0b1a2c;
  --navy-700:#12283f;
  --slate-600:#3a4c5e;
  --slate-400:#71889c;
  --mist-100:#eef2f1;
  --mist-050:#f8f7f4;
  --white:#ffffff;

  --orange-500:#c1440e;   /* urgent accent / CTA — deep terracotta, not stock orange */
  --orange-600:#a5380a;
  --teal-500:#2f6f6d;     /* restoration slate-teal, muted not neon */
  --teal-600:#25595a;
  --teal-050:#eaf2f1;
  --gold-500:#c9972f;     /* premium brass accent for dividers/badges */
  --gold-050:#faf3e3;

  --ink:#0d1620;
  --body:#3a4a58;
  --line:#dde3e0;
  --danger:#c0392b;
  --ok:#1f9d55;

  /* Type scale (fluid) */
  --f-xs:clamp(.75rem,.72rem + .1vw,.82rem);
  --f-sm:clamp(.86rem,.82rem + .2vw,.95rem);
  --f-base:clamp(1rem,.96rem + .2vw,1.08rem);
  --f-md:clamp(1.12rem,1.05rem + .4vw,1.28rem);
  --f-lg:clamp(1.35rem,1.2rem + .8vw,1.7rem);
  --f-xl:clamp(1.7rem,1.4rem + 1.6vw,2.4rem);
  --f-2xl:clamp(2.1rem,1.6rem + 2.6vw,3.3rem);

  /* Spacing scale */
  --s-1:.25rem; --s-2:.5rem; --s-3:.75rem; --s-4:1rem; --s-5:1.5rem;
  --s-6:2rem; --s-7:3rem; --s-8:4rem; --s-9:6rem;

  /* Radius & shadow */
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-pill:999px;
  --sh-1:0 2px 8px rgba(10,26,47,.08);
  --sh-2:0 10px 30px rgba(10,26,47,.12);
  --sh-3:0 20px 50px rgba(10,26,47,.18);

  --maxw:1180px;
  --header-h:76px;

  --font:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);font-size:var(--f-base);line-height:1.65;
  color:var(--body);background:var(--white);overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--teal-600);text-decoration:none}
h1,h2,h3,h4{color:var(--ink);line-height:1.2;font-weight:800;letter-spacing:-.01em}
h1{font-size:var(--f-2xl)}
h2{font-size:var(--f-xl)}
h3{font-size:var(--f-lg)}
ul{list-style:none}
:focus-visible{outline:3px solid var(--teal-500);outline-offset:2px}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--s-5)}
.section{padding-block:var(--s-9)}
.section--tight{padding-block:var(--s-8)}
.center{text-align:center}
.eyebrow{
  display:inline-block;font-size:var(--f-sm);font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--teal-600);margin-bottom:var(--s-3)
}
.lede{font-size:var(--f-md);color:var(--slate-600);max-width:62ch;margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;font-weight:700;
  padding:.85rem 1.5rem;border-radius:var(--r-pill);font-size:var(--f-base);
  border:2px solid transparent;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
  text-align:center;line-height:1.1
}
.btn svg{width:1.1em;height:1.1em;flex:none}
.btn--call{background:var(--orange-500);color:#fff;box-shadow:0 8px 22px rgba(255,106,43,.35)}
.btn--call:hover{background:var(--orange-600);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn--ghost:hover{background:rgba(255,255,255,.12)}
.btn--teal{background:var(--teal-500);color:#fff}
.btn--teal:hover{background:var(--teal-600);transform:translateY(-2px)}
.btn--lg{padding:1.05rem 1.9rem;font-size:var(--f-md)}
.pulse{animation:pulse 2.2s infinite}
@keyframes pulse{
  0%{box-shadow:0 8px 22px rgba(255,106,43,.35),0 0 0 0 rgba(255,106,43,.55)}
  70%{box-shadow:0 8px 22px rgba(255,106,43,.35),0 0 0 16px rgba(255,106,43,0)}
  100%{box-shadow:0 8px 22px rgba(255,106,43,.35),0 0 0 0 rgba(255,106,43,0)}
}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;background:rgba(255,255,255,.96);
  backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--line);
  transition:box-shadow .2s ease
}
.site-header.scrolled{box-shadow:var(--sh-1)}
.topbar{background:var(--navy-800);color:#cfe0ee;font-size:var(--f-xs)}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-block:.4rem}
.topbar a{color:#fff;font-weight:700}
.topbar .badge-247{color:var(--teal-500);font-weight:800;letter-spacing:.05em}
.nav{display:flex;align-items:center;justify-content:space-between;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:900;color:var(--ink);font-size:1.15rem;letter-spacing:-.02em}
.brand .mark{width:40px;height:40px;flex:none;border-radius:11px;box-shadow:0 3px 10px rgba(7,15,26,.25)}
.brand .mark.footer-mark{box-shadow:none}
.brand small{display:block;font-size:.62rem;font-weight:600;color:var(--slate-400);letter-spacing:.12em;text-transform:uppercase}
.menu{display:flex;align-items:center;gap:1.4rem}
.menu>li>a{color:var(--slate-600);font-weight:600;font-size:var(--f-sm);padding-block:.5rem;position:relative}
.menu>li>a:hover{color:var(--navy-700)}
.has-drop{position:relative}
.drop{
  position:absolute;top:100%;left:0;min-width:280px;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-md);box-shadow:var(--sh-2);padding:.5rem;opacity:0;visibility:hidden;
  transform:translateY(8px);transition:.2s ease;z-index:70
}
.drop--tall{max-height:75vh;overflow-y:auto}
.drop-heading{font-size:var(--f-xs);font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  color:var(--slate-400);padding:.6rem .8rem .2rem}
.has-drop:hover .drop,.has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateY(0)}
.drop a{display:block;padding:.55rem .8rem;border-radius:var(--r-sm);color:var(--slate-600);font-size:var(--f-sm);font-weight:600}
.drop a:hover{background:var(--mist-100);color:var(--navy-700)}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.nav-phone{display:inline-flex;align-items:center;gap:.45rem;font-weight:800;color:var(--navy-800)}
.burger{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px}
.burger span{display:block;width:24px;height:2px;background:var(--navy-800);margin:5px auto;transition:.3s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;background:var(--navy-800);overflow:hidden}
.hero__bg{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;opacity:.28}
.hero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(120deg,rgba(10,26,47,.92) 40%,rgba(18,50,85,.78) 100%)}
.hero .container{position:relative;z-index:2;padding-block:var(--s-9)}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:var(--s-7);align-items:center}
.hero h1{color:#fff;max-width:16ch}
.hero .sub{font-size:var(--f-md);color:#d5e3f0;margin-top:var(--s-4);max-width:52ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:var(--s-3);margin-top:var(--s-6)}
.hero__meta{display:flex;flex-wrap:wrap;gap:1.2rem;margin-top:var(--s-6);font-size:var(--f-sm);color:#bcd0e2}
.hero__meta b{color:#fff}
.pill-badge{
  display:inline-flex;align-items:center;gap:.5rem;background:rgba(18,165,165,.18);
  border:1px solid rgba(18,165,165,.5);color:#8ff0f0;padding:.4rem .9rem;border-radius:var(--r-pill);
  font-size:var(--f-sm);font-weight:700;margin-bottom:var(--s-4)
}
.pill-badge .dot{width:9px;height:9px;border-radius:50%;background:#25e0a0;box-shadow:0 0 0 0 rgba(37,224,160,.7);animation:pulse-dot 1.8s infinite}
@keyframes pulse-dot{0%{box-shadow:0 0 0 0 rgba(37,224,160,.7)}70%{box-shadow:0 0 0 10px rgba(37,224,160,0)}100%{box-shadow:0 0 0 0 rgba(37,224,160,0)}}
.hero__card{
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:var(--r-lg);
  padding:var(--s-6);backdrop-filter:blur(4px)
}
.hero__card h2{color:#fff;font-size:var(--f-lg)}
.hero__card ul{margin-top:var(--s-4);display:grid;gap:.7rem}
.hero__card li{display:flex;gap:.6rem;color:#e5eef6;font-size:var(--f-sm)}
.hero__card li::before{content:"";width:20px;height:20px;flex:none;border-radius:50%;background:var(--teal-500);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/70% no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/70% no-repeat}

/* ---------- Wave divider ---------- */
.wave{display:block;width:100%;height:auto;line-height:0}
.wave--flip{transform:rotate(180deg)}

/* ---------- Answer-first block ---------- */
.answer-block{
  background:var(--teal-050);border-left:5px solid var(--teal-500);border-radius:var(--r-md);
  padding:var(--s-5) var(--s-6);box-shadow:var(--sh-1)
}
.answer-block h2{font-size:var(--f-md);margin-bottom:var(--s-2);color:var(--navy-800)}
.answer-block p{color:var(--slate-600)}

/* ---------- Trust strip ---------- */
.trust{background:var(--navy-900);color:#cfe0ee}
.trust .container{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-5);padding-block:var(--s-6);text-align:center}
.trust .num{font-size:var(--f-xl);font-weight:900;color:#fff;display:block}
.trust .lbl{font-size:var(--f-sm);color:#9fb6cc}

/* ---------- Cards ---------- */
.grid{display:grid;gap:var(--s-5)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s-6);
  box-shadow:var(--sh-1);transition:transform .22s ease,box-shadow .22s ease;height:100%
}
.card:hover{transform:translateY(-6px);box-shadow:var(--sh-2)}
.card .ico{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:var(--s-4);
  background:linear-gradient(135deg,var(--teal-050),#fff);color:var(--teal-600);border:1px solid var(--teal-050)
}
.card .ico svg{width:28px;height:28px}
.card h3{font-size:var(--f-md);margin-bottom:var(--s-2)}
.card p{font-size:var(--f-sm);color:var(--slate-600)}
.card__links{margin-top:var(--s-4);display:grid;gap:.4rem}
.card__links a{font-size:var(--f-sm);font-weight:600;color:var(--slate-600);display:flex;align-items:center;gap:.4rem}
.card__links a::before{content:"›";color:var(--orange-500);font-weight:900}
.card__links a:hover{color:var(--teal-600)}

/* Pillar card (larger, colored top) */
.pillar{position:relative;overflow:hidden}
.pillar::before{content:"";position:absolute;top:0;left:0;right:0;height:6px}
.pillar--water::before{background:linear-gradient(90deg,var(--teal-500),#3fc4e8)}
.pillar--fire::before{background:linear-gradient(90deg,var(--orange-500),#ffb347)}
.pillar--mold::before{background:linear-gradient(90deg,#1f9d55,#7ed957)}
.tag{display:inline-block;font-size:var(--f-xs);font-weight:800;text-transform:uppercase;letter-spacing:.1em;
  padding:.25rem .7rem;border-radius:var(--r-pill);margin-bottom:var(--s-3)}
.tag--water{background:var(--teal-050);color:var(--teal-600)}
.tag--fire{background:#fff0e6;color:var(--orange-600)}
.tag--mold{background:#eafaef;color:#1f9d55}

/* ---------- Process steps ---------- */
.steps{counter-reset:step;display:grid;gap:var(--s-5)}
.steps.grid-3{grid-template-columns:repeat(3,1fr)}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s-6) var(--s-5) var(--s-5)}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-18px;left:var(--s-5);
  width:44px;height:44px;border-radius:12px;background:var(--navy-800);color:#fff;font-weight:900;
  display:grid;place-items:center;font-size:1.1rem;box-shadow:var(--sh-1)}
.step h3{font-size:var(--f-base);margin:.4rem 0 .3rem}
.step p{font-size:var(--f-sm);color:var(--slate-600)}

/* ---------- Feature list / signs ---------- */
.check-list{display:grid;gap:.7rem}
.check-list li{display:flex;gap:.6rem;font-size:var(--f-sm);color:var(--body)}
.check-list li::before{content:"";width:22px;height:22px;flex:none;border-radius:6px;background:var(--teal-050);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/72% no-repeat;
  background-color:var(--teal-500)}
.warn-list li::before{background-color:var(--orange-500)}

/* Split section */
.split{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-7);align-items:center}
.split img{border-radius:var(--r-lg);box-shadow:var(--sh-2)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:linear-gradient(120deg,var(--navy-800),var(--teal-600));color:#fff;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:
  radial-gradient(600px 200px at 90% -20%,rgba(255,106,43,.35),transparent)}
.cta-band .container{position:relative;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--s-5);padding-block:var(--s-7)}
.cta-band h2{color:#fff;max-width:20ch}
.cta-band p{color:#d7e6f2;margin-top:.4rem}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:var(--s-3);max-width:850px;margin-inline:auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:0 var(--s-5);box-shadow:var(--sh-1)}
.faq summary{cursor:pointer;list-style:none;padding:var(--s-4) 0;font-weight:700;color:var(--navy-800);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:var(--f-base)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--teal-500);font-weight:400;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding-bottom:var(--s-5);color:var(--slate-600);font-size:var(--f-sm)}

/* ---------- Breadcrumbs ---------- */
.crumbs{background:var(--mist-050);border-bottom:1px solid var(--line)}
.crumbs ol{display:flex;flex-wrap:wrap;gap:.5rem;font-size:var(--f-xs);color:var(--slate-400);padding-block:.8rem}
.crumbs li{display:flex;gap:.5rem;align-items:center}
.crumbs li+li::before{content:"/";color:var(--line)}
.crumbs a{color:var(--slate-600);font-weight:600}
.crumbs [aria-current]{color:var(--navy-800)}

/* ---------- Related / area chips ---------- */
.chips{display:flex;flex-wrap:wrap;gap:.6rem}
.chip{display:inline-flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-pill);padding:.5rem 1rem;font-size:var(--f-sm);font-weight:600;color:var(--slate-600)}
.chip:hover{border-color:var(--teal-500);color:var(--teal-600)}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-900);color:#b8cadd;font-size:var(--f-sm)}
.site-footer .container{padding-block:var(--s-8)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:var(--s-6)}
.foot-grid--full{grid-template-columns:1.3fr repeat(5,1fr)}
.foot-grid--full ul{max-height:340px;overflow-y:auto;padding-right:.4rem}
.foot-grid--full ul::-webkit-scrollbar{width:5px}
.foot-grid--full ul::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:99px}
.foot-col-title{color:#fff;font-size:var(--f-base);margin-bottom:var(--s-4);font-weight:800}
.site-footer h4{color:#fff;font-size:var(--f-base);margin-bottom:var(--s-4)}
.site-footer a{color:#b8cadd}
.site-footer a:hover{color:#fff}
.foot-grid ul{display:grid;gap:.55rem}
.foot-nap{display:grid;gap:.6rem}
.foot-nap a{font-weight:700;color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:var(--s-7);padding-top:var(--s-5);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;color:#7f97ad;font-size:var(--f-xs)}

/* ---------- Mobile call bar ---------- */
.mobile-call{
  position:fixed;left:0;right:0;bottom:0;z-index:80;display:none;
  background:var(--orange-500);color:#fff;font-weight:800;text-align:center;
  padding:.9rem;box-shadow:0 -6px 20px rgba(10,26,47,.25)
}
.mobile-call a{color:#fff;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1.05rem}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .hero__grid,.split{grid-template-columns:1fr}
  .grid-3,.steps.grid-3,.trust .container{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-grid--full{grid-template-columns:1fr 1fr 1fr}
  .menu,.nav-phone{display:none}
  .burger{display:block}
  .mobile-nav{display:block}
}
@media(max-width:600px){
  .grid-2,.grid-3,.steps.grid-3{grid-template-columns:1fr}
  .trust .container{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr}
  .foot-grid--full{grid-template-columns:1fr}
  .foot-grid--full ul{max-height:none;overflow-y:visible}
  .mobile-call{display:block}
  body{padding-bottom:64px}
  .topbar .container{justify-content:center}
  .topbar .hide-sm{display:none}
}

/* ---------- Mobile nav drawer ---------- */
.mobile-nav{
  display:none;position:fixed;inset:var(--header-h) 0 0;z-index:55;background:#fff;
  padding:var(--s-5);overflow-y:auto;transform:translateX(100%);transition:transform .3s ease
}
.mobile-nav.open{transform:none}
.mobile-nav a{display:block;padding:.8rem 0;border-bottom:1px solid var(--line);color:var(--navy-800);font-weight:600}
.mobile-nav .sub{padding-left:1rem;color:var(--slate-600);font-weight:500;font-size:var(--f-sm)}
@media(max-width:960px){.mobile-nav{display:block}}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
