/* ===== Cattleman Cleaning — modern light theme ===== */
:root{
  --ink:#34262D;            /* deep plum charcoal text */
  --ink-soft:#8A727A;       /* muted mauve */
  --amber:#C56B7E;          /* dusty rose — primary accent */
  --amber-lt:#E0A6B4;       /* soft rose */
  --rose-dk:#AB5469;        /* deeper rose for hovers */
  --bronze:#B68A4E;         /* champagne gold — secondary accent */
  --cream:#FDF8F6;          /* ivory page bg */
  --bone:#FFFFFF;           /* cards */
  --sand:#F6EAE6;           /* warm blush taupe (alt sections) */
  --blush:#FBEFEE;          /* soft blush */
  --plate:#2C2026;          /* deep plum (footer / dark accents) */
  --line:rgba(52,38,45,.10);
  --line-2:rgba(52,38,45,.055);
  --line-d:rgba(255,255,255,.14);
  --muted:#8A727A;
  --shadow:0 22px 55px -30px rgba(120,70,90,.32);
  --shadow-sm:0 8px 26px -16px rgba(120,70,90,.24);
  --r:24px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Mulish',system-ui,sans-serif;color:var(--ink);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;line-height:1.12;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1240px;margin:0 auto;padding:0 22px}
.eyebrow{font-weight:800;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--bronze);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--amber)}
.eyebrow.center{justify-content:center}

.btn{display:inline-flex;align-items:center;gap:9px;cursor:pointer;border:none;font-family:'Mulish';font-weight:800;font-size:.95rem;padding:14px 26px;border-radius:999px;transition:.22s ease;text-align:center}
.btn-primary{background:var(--amber);color:#fff;box-shadow:0 10px 24px -12px rgba(197,107,126,.55)}
.btn-primary:hover{background:var(--rose-dk);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:var(--cream)}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn-ghost-light{background:#fff;color:var(--ink);border:1.5px solid var(--line);box-shadow:var(--shadow-sm)}
.btn-ghost-light:hover{border-color:var(--amber);color:var(--bronze);transform:translateY(-2px)}

/* top bar — light & slim */
.topbar{background:#fff;color:var(--ink);font-size:.82rem;font-weight:700;border-bottom:1px solid var(--line-2)}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:40px;gap:16px}
.topbar .tags{display:flex;gap:18px;flex-wrap:wrap;color:var(--ink-soft)}
.topbar .tags span{display:inline-flex;gap:7px;align-items:center}
.topbar a{font-weight:800;color:var(--ink)}
.topbar a:hover{color:var(--bronze)}
.topbar strong{color:var(--bronze)}
.amber{color:var(--amber)}
@media(max-width:720px){
  .topbar .tags span.hide-sm{display:none}
  .topbar .wrap{justify-content:center}
  .topbar .tags{display:none}
}

/* header — light, sticky, clean */
header{position:sticky;top:0;z-index:90;background:rgba(255,255,255,.86);backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--line-2);transition:.3s}
nav{display:flex;align-items:center;justify-content:space-between;gap:16px;height:72px}
.brand{display:flex;align-items:center;gap:11px}
.brand img{height:42px;width:auto}
.brand .bt{font-family:'Playfair Display';color:var(--ink);font-weight:700;font-size:1.1rem;line-height:1}
.brand .bt small{display:block;font-family:'Mulish';font-size:.58rem;letter-spacing:.28em;color:var(--bronze);font-weight:800;margin-top:3px}
.links{display:flex;align-items:center;gap:26px}
.links a.nl{color:var(--ink);font-weight:700;font-size:.93rem;position:relative;padding:4px 0}
.links a.nl::after{content:"";position:absolute;left:0;bottom:-3px;height:2px;width:0;background:var(--amber);transition:.25s}
.links a.nl:hover{color:var(--bronze)}
.links a.nl:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:12px}
.lang{display:inline-flex;border:1.5px solid var(--line);border-radius:999px;overflow:hidden;background:#fff}
.lang button,.lang .lb{background:transparent;color:var(--ink);border:none;cursor:pointer;font-family:'Mulish';font-weight:800;font-size:.78rem;padding:7px 13px;transition:.2s;line-height:1}
.lang button.active,.lang .lb.active{background:var(--amber);color:#fff}
.menu-btn{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.menu-btn span{width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:.3s}
@media(max-width:940px){
  .links{position:fixed;inset:auto 0 auto 0;top:112px;background:#fff;flex-direction:column;gap:0;padding:8px 0 14px;border-bottom:1px solid var(--line);box-shadow:var(--shadow);transform:translateY(-160%);transition:.35s cubic-bezier(.5,0,0,1);max-height:calc(100vh - 112px);overflow:auto}
  .links.open{transform:translateY(0)}
  .links a.nl{width:100%;padding:14px 24px;border-bottom:1px solid var(--line-2)}
  .links .btn{margin:14px 24px 0;justify-content:center}
  .menu-btn{display:flex}
}
@media(max-width:720px){ .links{top:72px;max-height:calc(100vh - 72px)} }

/* hero — light with a glowing logo plate */
.hero{position:relative;background:linear-gradient(180deg,#fff 0%,var(--blush) 100%);color:var(--ink);text-align:center;padding:60px 0 76px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(680px 380px at 50% 0%,rgba(197,107,126,.12),transparent 65%);pointer-events:none}
.hero>*{position:relative;z-index:1}
.logo-plate{display:grid;width:max-content;max-width:90vw;place-items:center;background:linear-gradient(160deg,#ffffff,var(--blush));border:1px solid var(--line);border-radius:26px;padding:22px 36px;margin:0 auto 22px;box-shadow:0 30px 70px -34px rgba(120,70,90,.45),inset 0 0 0 1px rgba(255,255,255,.6)}

.hero .logo-hero{width:min(228px,52vw);filter:drop-shadow(0 8px 18px rgba(120,70,90,.18))}
.hero h1{font-size:clamp(2.3rem,5.2vw,3.9rem);font-weight:700;max-width:15ch;margin:0 auto 18px}
.hero h1 em{font-style:normal;color:var(--amber)}
.hero p.lead{color:var(--ink-soft);font-size:1.05rem;max-width:600px;margin:0 auto 24px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:28px}
.hero-trust{display:flex;gap:14px 26px;justify-content:center;flex-wrap:wrap;color:var(--ink);font-weight:700;font-size:.92rem}
.hero-trust span{display:inline-flex;gap:8px;align-items:center}

/* strip — light cards */
.strip{background:#fff;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
.strip .wrap{display:flex;justify-content:space-around;gap:20px;flex-wrap:wrap;padding:26px 24px;text-align:center}
.strip .n{font-family:'Playfair Display';font-size:1.9rem;font-weight:700;color:var(--amber);line-height:1}
.strip .l{font-size:.76rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px}

section.pad{padding:54px 0}
.sec-head{max-width:660px;margin-bottom:30px}
.sec-head.center{margin:0 auto 30px;text-align:center}
.sec-head h2{font-size:clamp(1.8rem,3.4vw,2.4rem);font-weight:700;margin:9px 0 8px}
.sec-head p{color:var(--muted);font-size:1rem}

/* services */
.services{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.svc{background:var(--bone);border:1px solid var(--line);border-radius:var(--r);padding:28px 24px 26px;transition:.3s;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(197,107,126,.4)}
.svc .ic{width:52px;height:52px;border-radius:15px;background:linear-gradient(135deg,var(--amber-lt),var(--bronze));display:grid;place-items:center;margin-bottom:16px;font-size:1.45rem;box-shadow:0 8px 18px -10px rgba(197,107,126,.45)}
.svc h3{font-size:1.26rem;margin-bottom:9px}
.svc p{color:var(--muted);font-size:.92rem;margin-bottom:15px}
.svc ul{list-style:none;display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.svc li{font-size:.86rem;font-weight:600;display:flex;gap:9px}
.svc li::before{content:"✓";color:var(--amber);font-weight:900}
.svc .lnk{margin-top:auto;font-weight:800;color:var(--bronze);display:inline-flex;gap:7px;font-size:.92rem}
.svc .lnk:hover{gap:11px}
@media(max-width:1080px){.services{gap:14px}.svc{padding:24px 18px}}
@media(max-width:860px){.services{grid-template-columns:repeat(2,1fr);gap:18px}.svc{padding:28px 22px}}
@media(max-width:560px){.services{grid-template-columns:1fr;max-width:420px;margin:0 auto}}

/* why */
.why{background:var(--sand)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.feat{background:var(--bone);border:1px solid var(--line);border-radius:var(--r);padding:28px 24px;transition:.3s;box-shadow:var(--shadow-sm)}
.feat:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.feat .ic{width:50px;height:50px;border-radius:14px;background:var(--cream);border:1px solid var(--line);display:grid;place-items:center;margin-bottom:16px;font-size:1.4rem}
.feat:nth-child(even) .ic{background:linear-gradient(135deg,var(--amber-lt),var(--bronze))}
.feat h3{font-size:1.15rem;margin-bottom:8px}
.feat p{font-size:.91rem;color:var(--muted)}
@media(max-width:860px){.why-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.why-grid{grid-template-columns:1fr}}

/* calculator — light */
.calc{background:var(--cream)}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}
.calc-card{background:var(--bone);border:1px solid var(--line);border-radius:var(--r);padding:30px;box-shadow:var(--shadow-sm)}
.calc-card .seg{display:flex;gap:8px;margin-bottom:22px;flex-wrap:wrap}
.calc-card .seg button{flex:1;min-width:90px;background:var(--cream);color:var(--ink);border:1.5px solid var(--line);border-radius:12px;padding:11px;font-weight:800;font-family:'Mulish';cursor:pointer;transition:.2s;font-size:.86rem}
.calc-card .seg button.active{background:var(--amber);color:#fff;border-color:var(--amber)}
.fld{margin-bottom:15px}
.fld label{display:block;font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;color:var(--ink-soft)}
.fld select,.fld input{width:100%;padding:12px 13px;border-radius:11px;border:1.5px solid var(--line);background:#fff;color:var(--ink);font-family:'Mulish';font-weight:600;font-size:.94rem}
.fld select:focus,.fld input:focus{outline:none;border-color:var(--amber)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:6px}
.checks label{display:flex;gap:8px;align-items:center;font-size:.86rem;font-weight:600;cursor:pointer;text-transform:none;letter-spacing:0;color:var(--ink)}
.calc-out{background:linear-gradient(160deg,#fff,var(--sand));border:1px solid var(--line);border-radius:var(--r);padding:32px;position:sticky;top:96px;box-shadow:var(--shadow-sm)}
.calc-out .label{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--bronze)}
.calc-out .est{font-family:'Playfair Display';font-size:3rem;font-weight:700;color:var(--ink);line-height:1;margin:10px 0 6px}
.calc-out .per{color:var(--ink-soft);font-size:.92rem;margin-bottom:18px}
.calc-out .breakdown{list-style:none;border-top:1px solid var(--line);padding-top:16px;margin-bottom:20px;display:flex;flex-direction:column;gap:9px}
.calc-out .breakdown li{display:flex;justify-content:space-between;font-size:.9rem;font-weight:600;color:var(--ink-soft)}
.calc-out .breakdown li span:last-child{color:var(--ink);font-weight:800}
.calc-out .note{font-size:.78rem;color:var(--ink-soft);margin-top:14px}
.calc-out .btn{width:100%;justify-content:center}
@media(max-width:860px){.calc-grid{grid-template-columns:1fr}.calc-out{position:static}}

/* about band — light */
.band{background:var(--bone);border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
.band .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:38px;align-items:center;padding:52px 24px}
.band .eyebrow{color:var(--bronze)}
.band h2{color:var(--ink);font-size:clamp(2rem,3.6vw,2.6rem);margin-bottom:16px}
.band p{color:var(--ink-soft);font-size:1.05rem;margin-bottom:14px}
.band .es{font-family:'Playfair Display';font-size:1.35rem;color:var(--bronze);font-weight:600}
.band-card{background:linear-gradient(160deg,var(--cream),var(--sand));border:1px solid var(--line);border-radius:var(--r);padding:30px;box-shadow:var(--shadow-sm)}
.band-card .row{display:flex;gap:13px;align-items:center;padding:13px 0;border-bottom:1px solid var(--line);font-weight:600;font-size:.95rem;color:var(--ink)}
.band-card .row:last-child{border:none;padding-bottom:0}.band-card .row:first-child{padding-top:0}
.band-card .k{color:var(--amber);font-weight:900;font-size:1.2rem}
@media(max-width:860px){.band .wrap{grid-template-columns:1fr;gap:30px}}

/* contact / quote */
.quote{background:var(--sand)}
.quote-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:50px;align-items:start}
.qlist{list-style:none;display:flex;flex-direction:column;gap:14px;margin-top:8px}
.qlist li{display:flex;gap:12px;font-weight:600;color:var(--ink-soft)}
.qlist li b{color:var(--ink)}
.form-card{background:var(--bone);border:1px solid var(--line);border-radius:22px;padding:34px;box-shadow:var(--shadow)}
.form-card h3{font-size:1.4rem;margin-bottom:4px}
.form-card .sub{font-size:.9rem;color:var(--muted);margin-bottom:20px}
.form-card .fld label{color:var(--ink-soft)}
.form-card .fld input,.form-card .fld select,.form-card .fld textarea{background:#fff;color:var(--ink);border-color:var(--line)}
.form-card textarea{width:100%;padding:12px 13px;border-radius:11px;border:1.5px solid var(--line);font-family:'Mulish';font-weight:600;resize:vertical;min-height:90px}
.form-card textarea:focus{outline:none;border-color:var(--amber)}
.form-card .btn{width:100%;justify-content:center;margin-top:6px}
.form-note{font-size:.78rem;color:var(--muted);text-align:center;margin-top:12px}
@media(max-width:860px){.quote-grid{grid-template-columns:1fr;gap:32px}.row2{grid-template-columns:1fr}}

/* final CTA — bright amber */
.final{background:linear-gradient(135deg,var(--amber),var(--bronze));color:#fff;text-align:center}
.final .wrap{padding:46px 24px}
.final h2{color:#fff;font-size:clamp(2rem,4vw,2.8rem);margin-bottom:12px}
.final p{font-size:1.08rem;margin-bottom:26px;opacity:.92}
.final .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.final .btn-dark{background:var(--plate)}
.final .btn-dark:hover{background:#000}
.final .btn-ghost{border-color:rgba(255,255,255,.7);color:#fff}
.final .btn-ghost:hover{background:rgba(255,255,255,.16);color:#fff;border-color:#fff}

/* footer — anchored dark */
footer{background:var(--plate);color:var(--cream)}
.foot{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:38px;padding:58px 24px 28px}
.foot img{height:56px;margin-bottom:14px}
.foot p.desc{opacity:.72;font-size:.9rem;max-width:280px}
.foot h4{font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;color:var(--amber-lt);margin-bottom:16px}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot a,.foot li{font-size:.92rem;opacity:.85;font-weight:600}
.foot a:hover{opacity:1;color:var(--amber-lt)}
.foot .ct{display:flex;gap:10px;margin-bottom:11px;font-size:.92rem;opacity:.85;font-weight:600}
.socials{display:flex;gap:10px;margin-top:14px}
.socials a{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:.2s}
.socials a:hover{background:var(--amber)}
.copy{border-top:1px solid var(--line-d);padding:18px 24px;text-align:center;font-size:.83rem;opacity:.62}
@media(max-width:860px){.foot{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:520px){.foot{grid-template-columns:1fr}}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== chatbot ===== */
#cc-chat-btn{position:fixed;right:20px;bottom:20px;z-index:200;width:60px;height:60px;border-radius:50%;border:none;cursor:pointer;background:var(--amber);box-shadow:0 14px 32px -12px rgba(197,107,126,.6);display:grid;place-items:center;transition:.25s}
#cc-chat-btn:hover{transform:scale(1.06)}
#cc-chat-btn svg{width:30px;height:30px}
#cc-chat{position:fixed;right:20px;bottom:92px;z-index:200;width:min(370px,calc(100vw - 32px));height:min(560px,calc(100vh - 130px));background:var(--bone);border-radius:20px;box-shadow:0 30px 70px -24px rgba(0,0,0,.45);display:none;flex-direction:column;overflow:hidden;border:1px solid var(--line)}
#cc-chat.open{display:flex}
.cc-head{background:var(--plate);color:#fff;padding:15px 18px;display:flex;align-items:center;gap:12px}
.cc-head img{height:32px}
.cc-head .t b{font-family:'Playfair Display';font-size:1rem}
.cc-head .t small{display:block;font-size:.72rem;color:var(--amber-lt);font-weight:700}
.cc-head .x{margin-left:auto;background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer;opacity:.7}
.cc-head .x:hover{opacity:1}
.cc-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:var(--cream)}
.cc-msg{max-width:84%;padding:11px 14px;border-radius:14px;font-size:.9rem;line-height:1.5}
.cc-bot{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px}
.cc-user{background:var(--amber);color:#fff;align-self:flex-end;border-bottom-right-radius:4px;font-weight:600}
.cc-quick{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 10px;background:var(--cream)}
.cc-quick button{background:#fff;border:1.5px solid var(--amber);color:var(--bronze);font-weight:700;font-size:.8rem;padding:7px 12px;border-radius:999px;cursor:pointer;transition:.2s}
.cc-quick button:hover{background:var(--amber);color:#fff}
.cc-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:var(--bone)}
.cc-input input{flex:1;border:1.5px solid var(--line);border-radius:999px;padding:10px 14px;font-family:'Mulish';font-size:.9rem;font-weight:600}
.cc-input input:focus{outline:none;border-color:var(--amber)}
.cc-input button{background:var(--amber);border:none;border-radius:50%;width:40px;height:40px;cursor:pointer;display:grid;place-items:center;flex:none}
.cc-input button svg path{fill:#fff}

/* article / blog — light page head */
.page-head{background:linear-gradient(180deg,#fff,var(--cream));border-bottom:1px solid var(--line-2);color:var(--ink);padding:30px 0 26px;text-align:center}
.page-head .crumb{font-size:.82rem;color:var(--ink-soft);margin-bottom:14px}
.page-head .crumb a{color:var(--bronze);font-weight:700}
.page-head h1{font-size:clamp(2rem,4.4vw,3rem);max-width:20ch;margin:0 auto;font-weight:700}
.page-head p.kick{color:var(--ink-soft);margin-top:14px;max-width:60ch;margin-inline:auto}
.article{max-width:820px;margin:0 auto;padding:34px 24px}
.article h2{font-size:1.7rem;margin:34px 0 12px;color:var(--ink)}
.article h3{font-size:1.22rem;margin:24px 0 8px;color:var(--ink)}
.article p{margin-bottom:16px;color:#3A3024}
.article ul,.article ol{margin:0 0 18px 22px;color:#3A3024}
.article li{margin-bottom:7px}
.article .cta-box{background:linear-gradient(160deg,var(--cream),var(--sand));border:1px solid rgba(197,107,126,.35);border-radius:var(--r);padding:30px;text-align:center;margin:40px 0;box-shadow:var(--shadow-sm)}
.article .cta-box h3{color:var(--ink);margin-bottom:10px}
.article .cta-box p{color:var(--ink-soft)}
.article .cta-box .btn{margin-top:8px}
.related{background:var(--sand);padding:50px 0}
.related h2{text-align:center;margin-bottom:26px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rc{background:var(--bone);border:1px solid var(--line);border-radius:14px;padding:22px;transition:.25s;box-shadow:var(--shadow-sm)}
.rc:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.rc small{color:var(--bronze);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.7rem}
.rc h3{font-size:1.06rem;margin:8px 0}
.rc p{font-size:.86rem;color:var(--muted)}
@media(max-width:760px){.related-grid{grid-template-columns:1fr}}

/* blog index */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.bcard{background:var(--bone);border:1px solid var(--line);border-radius:var(--r);padding:26px;transition:.25s;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}
.bcard:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:rgba(197,107,126,.4)}
.bcard .tag{align-self:flex-start;font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--bronze);background:var(--sand);padding:5px 10px;border-radius:999px;margin-bottom:12px}
.bcard h3{font-size:1.12rem;margin-bottom:8px}
.bcard p{font-size:.88rem;color:var(--muted);margin-bottom:14px}
.bcard .lnk{margin-top:auto;font-weight:800;color:var(--bronze);display:inline-flex;gap:6px}
.blog-section-title{font-family:'Playfair Display';font-size:1.55rem;margin:46px 0 22px;padding-bottom:10px;border-bottom:2px solid var(--amber)}
@media(max-width:860px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.blog-grid{grid-template-columns:1fr}}

/* ===== WhatsApp / live handoff ===== */
.cc-quick button.cc-wa{background:#25D366;border-color:#25D366;color:#fff}
.cc-quick button.cc-wa:hover{background:#1da851;border-color:#1da851;color:#fff}
.cc-dots{display:inline-flex;gap:4px;align-items:center}
.cc-dots i{width:7px;height:7px;border-radius:50%;background:var(--bronze);opacity:.5;animation:ccb 1s infinite}
.cc-dots i:nth-child(2){animation-delay:.2s}.cc-dots i:nth-child(3){animation-delay:.4s}
@keyframes ccb{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
#cc-wa-float{position:fixed;right:20px;bottom:90px;z-index:199;width:56px;height:56px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 12px 28px -10px rgba(37,211,102,.85);transition:.25s}
#cc-wa-float:hover{transform:scale(1.08)}
#cc-wa-float svg{width:30px;height:30px}
.live-btns{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.live-btns a{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:.95rem;padding:13px 22px;border-radius:999px;transition:.25s}
.live-btns .wa{background:#25D366;color:#fff}
.live-btns .wa:hover{background:#1da851;transform:translateY(-2px)}
.live-btns .tx{background:var(--ink);color:var(--cream)}
.live-btns .tx:hover{background:#000;transform:translateY(-2px)}

/* ===== Upscale refinements ===== */
.brand .bt{font-weight:700;font-size:1.04rem;letter-spacing:.01em}
.brand .bt small{font-family:'Mulish';letter-spacing:.32em}
header.shrink{box-shadow:0 6px 24px -18px rgba(27,21,16,.5)}
.eyebrow{letter-spacing:.22em}

/* trust chips bar */
.trustbar{background:var(--plate);color:#fff}
.trustbar .wrap{display:flex;justify-content:center;gap:14px 40px;flex-wrap:wrap;padding:18px 24px;align-items:center}
.trustbar span{display:inline-flex;gap:9px;align-items:center;font-weight:700;font-size:.9rem;color:#EADFCB}
.trustbar b{color:var(--amber-lt)}
.trustbar .sep{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.3)}
@media(max-width:600px){.trustbar .sep{display:none}.trustbar .wrap{gap:10px 22px}}

/* process / how it works */

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;counter-reset:step}
.step{position:relative;background:var(--bone);border:1px solid var(--line);border-radius:var(--r);padding:34px 28px 28px;box-shadow:var(--shadow-sm)}
.step::before{counter-increment:step;content:"0" counter(step);font-family:'Playfair Display';font-size:2.6rem;font-weight:800;color:var(--amber);opacity:.28;position:absolute;top:16px;right:22px;line-height:1}
.step .ic{font-size:1.7rem;margin-bottom:12px}
.step h3{font-size:1.25rem;margin-bottom:8px}
.step p{color:var(--muted);font-size:.94rem}
@media(max-width:820px){.steps{grid-template-columns:1fr;max-width:460px;margin:0 auto}}

/* service areas */
.areas{background:var(--bone);border-top:1px solid var(--line-2)}
.area-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:8px}
.area-grid a{display:flex;align-items:center;justify-content:center;text-align:center;gap:6px;background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:13px 10px;font-weight:700;font-size:.9rem;color:var(--ink);transition:.2s}
.area-grid a:hover{border-color:var(--amber);color:var(--bronze);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.areas .more{text-align:center;margin-top:22px;font-weight:800;color:var(--bronze);display:inline-flex;gap:7px}
@media(max-width:900px){.area-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.area-grid{grid-template-columns:repeat(2,1fr)}}

/* testimonials */
.tmonials{background:var(--sand)}

.tm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tm{background:var(--bone);border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.tm .stars{color:var(--bronze);font-size:1.05rem;letter-spacing:2px;margin-bottom:14px}
.tm p{font-family:'Playfair Display';font-style:italic;font-size:1.08rem;color:var(--ink);line-height:1.5;margin-bottom:18px}
.tm .who{margin-top:auto;font-weight:800;font-size:.92rem;color:var(--ink)}
.tm .who small{display:block;font-family:'Mulish';font-weight:600;color:var(--ink-soft);font-size:.82rem;margin-top:2px}
.tm-note{text-align:center;color:var(--ink-soft);font-size:.84rem;margin-top:22px}
@media(max-width:820px){.tm-grid{grid-template-columns:1fr;max-width:460px;margin:0 auto}}

/* FAQ */
.faqs{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq{background:var(--bone);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
.faq summary{list-style:none;cursor:pointer;padding:20px 24px;font-family:'Playfair Display';font-weight:600;font-size:1.12rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:'Mulish';font-weight:800;color:var(--amber);font-size:1.5rem;transition:.25s;flex:none}
.faq[open] summary::after{transform:rotate(45deg)}
.faq .a{padding:0 24px 20px;color:var(--muted);font-size:.97rem}
.faq[open] summary{color:var(--bronze)}

/* hero refinements */
.hero{padding:44px 0 52px}

.hero .rating{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 15px;margin-bottom:18px;font-weight:700;font-size:.86rem;box-shadow:var(--shadow-sm)}
.hero .rating .s{color:var(--bronze);letter-spacing:1px}
.hero h1{font-weight:700}
.logo-plate{padding:30px 40px}
.hero .logo-hero{width:min(210px,48vw)}

/* section eyebrow color consistency on light */
.calc .eyebrow,.areas .eyebrow,.tmonials .eyebrow,.why .eyebrow{color:var(--bronze)}

/* quote form status messages */
.form-success,.form-error{border-radius:14px;padding:18px 20px;font-weight:700;font-size:.96rem;line-height:1.5;margin-top:4px}
.form-success{background:#EAF6EE;border:1px solid #Bfe3CC;color:#1F7A44}
.form-error{background:var(--blush);border:1px solid var(--amber-lt);color:var(--rose-dk)}
.form-error a{color:var(--rose-dk);text-decoration:underline}

/* brand slogan */
.slogan{font-family:'Playfair Display',serif;font-style:italic;font-weight:600;color:var(--amber);font-size:clamp(1.15rem,2.2vw,1.5rem);margin:0 auto 18px;max-width:30ch}
.foot-slogan{font-family:'Playfair Display',serif;font-style:italic;color:var(--amber-lt);font-size:.98rem;margin-top:10px;opacity:.95}

/* chat launcher action buttons (WhatsApp / Text / Call) */
#cc-chat .cc-quick{padding-bottom:16px}
.cc-quick .cc-act{flex:1 1 100%;display:inline-flex;justify-content:center;align-items:center;gap:8px;padding:13px 14px;border-radius:12px;font-weight:800;font-size:.96rem;transition:.2s}
.cc-act.cc-wa{background:#25D366;color:#fff}
.cc-act.cc-wa:hover{background:#1da851}
.cc-act.cc-text{background:var(--ink);color:#fff}
.cc-act.cc-text:hover{background:#1d1318}
.cc-act.cc-call{background:var(--amber);color:#fff}
.cc-act.cc-call:hover{background:var(--rose-dk)}


/* ===== tighter spacing / max real estate ===== */
@media(max-width:560px){
  .wrap{padding:0 16px}
  section.pad{padding:36px 0}
  .hero{padding:30px 0 38px}
  .sec-head{margin-bottom:20px}
  .sec-head.center{margin:0 auto 20px}
  .band .wrap{padding:34px 16px}
  .final .wrap{padding:34px 16px}
  .article{padding:26px 16px}
  .page-head{padding:24px 0 20px}
  .logo-plate{padding:18px 26px;margin-bottom:18px}
}
