/* ============================================================
   MasterP Plumbers & Projects
   Trade / industrial design system — charcoal + safety yellow,
   squared buttons with hard offset shadows (inspired by Pressure-It).
   ============================================================ */
:root{
  --ink:#15273b;          /* headings — deep brand navy */
  --charcoal:#16293f;     /* dark section bg — deep navy (relates to brand blue) */
  --charcoal-d:#0e1c2c;   /* darkest navy — footer / emergency bar */
  --blue:#1670b8;         /* primary brand — matches logo */
  --blue-d:#0f5184;       /* darker blue (text / hover on white) */
  --blue-l:#5bb3e8;       /* light blue — accents/text on dark backgrounds */
  --yellow:#FFC107;       /* EMERGENCY accent only */
  --yellow-l:#ffca28;
  --body:#3a4654;
  --muted:#6b7682;
  --line:#E0E0E0;
  --bg:#ffffff;
  --bg-alt:#F5F5F5;
  --wa:#25D366;
  --wa-d:#1da955;
  --radius:12px;
  --shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  --shadow-lg:0 12px 24px rgba(28,28,28,.15);
  --hard:4px 4px 0 0 rgba(28,28,28,.92);
  --hard-sm:2px 2px 0 0 rgba(28,28,28,.92);
  --maxw:1160px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{font-family:"Inter",system-ui,sans-serif;color:var(--body);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.brand__text{font-family:"Plus Jakarta Sans","Inter",sans-serif;color:var(--ink);line-height:1.12;font-weight:800;letter-spacing:-.02em}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.container--narrow{max-width:840px}
.ico{width:1.1em;height:1.1em;fill:currentColor;flex:none}
.ic{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;display:block;flex:none}
.hl{color:var(--blue-d)}
.kicker{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);margin-bottom:14px}
.kicker::before{content:"";width:24px;height:3px;background:var(--blue);border-radius:2px}
.link{color:var(--ink);font-weight:700;text-decoration:underline;text-decoration-color:var(--blue);text-underline-offset:3px}
.link:hover{color:var(--blue-d)}

/* ---- Trade buttons: squared, uppercase, hard offset shadow ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:"Plus Jakarta Sans",sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.045em;line-height:1;border-radius:3px;border:none;cursor:pointer;white-space:nowrap;font-size:.8rem;height:2.85rem;padding:0 1.5rem;transition:transform .12s ease,box-shadow .12s ease,background-color .2s,color .2s}
.btn--lg{font-size:.92rem;height:3.4rem;padding:0 2rem}
.btn--block{width:100%}
.btn .ico{width:1.15em;height:1.15em}
/* primary = brand blue with hard charcoal shadow */
.btn--call{background:var(--blue);color:#fff;box-shadow:var(--hard)}
.btn--call:hover{background:var(--blue-d);transform:translate(2px,2px);box-shadow:var(--hard-sm)}
.btn--call:active{transform:translate(4px,4px);box-shadow:0 0 0 0 rgba(28,28,28,.92)}
/* whatsapp = green with hard charcoal shadow */
.btn--wa{background:var(--wa);color:#fff;box-shadow:var(--hard)}
.btn--wa:hover{background:var(--wa-d);transform:translate(2px,2px);box-shadow:var(--hard-sm)}
.btn--wa:active{transform:translate(4px,4px);box-shadow:0 0 0 0 rgba(28,28,28,.92)}
/* ghost = outline (charcoal on light) */
.btn--ghost{background:transparent;color:var(--charcoal);box-shadow:inset 0 0 0 2px var(--charcoal)}
.btn--ghost:hover{background:var(--charcoal);color:#fff}
/* ghost on dark backgrounds → outline light-blue */
.hero .btn--ghost,.bigcta .btn--ghost{color:var(--blue-l);box-shadow:inset 0 0 0 2px var(--blue-l)}
.hero .btn--ghost:hover,.bigcta .btn--ghost:hover{background:var(--blue-l);color:var(--charcoal)}

/* ---- Emergency bar ---- */
.utilbar{background:var(--charcoal-d);color:#cfcfcf;font-size:.84rem;border-bottom:3px solid var(--yellow)}
.utilbar__inner{display:flex;align-items:center;gap:18px;justify-content:space-between;padding:9px 0;flex-wrap:wrap}
.utilbar__item{display:inline-flex;align-items:center;gap:9px;color:#d4d4d4}
.utilbar__item strong{color:#fff;font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.utilbar__call{display:inline-flex;align-items:center;gap:7px;background:var(--yellow);color:var(--charcoal);font-family:"Plus Jakarta Sans",sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.03em;padding:7px 16px;border-radius:3px;font-size:.82rem;white-space:nowrap;box-shadow:var(--hard-sm)}
.utilbar__call .ico{width:1em;height:1em}
.utilbar__call:hover{background:var(--yellow-l);transform:translate(1px,1px);box-shadow:1px 1px 0 0 rgba(0,0,0,.6)}
.utilbar__pulse .dot{width:9px;height:9px;border-radius:50%;background:var(--yellow);box-shadow:0 0 0 0 rgba(255,193,7,.7);animation:pulse 1.8s infinite;flex:none}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,193,7,.6)}70%{box-shadow:0 0 0 9px rgba(255,193,7,0)}100%{box-shadow:0 0 0 0 rgba(255,193,7,0)}}

/* ---- Header ---- */
.header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.header.scrolled{box-shadow:0 2px 8px rgba(28,28,28,.08)}
.header__inner{display:flex;align-items:center;gap:20px;height:72px}
.brand{display:flex;align-items:center;gap:11px}
.brand img{object-fit:contain;display:block}
.brand--light img{background:#fff;border-radius:6px;padding:5px 6px;box-sizing:content-box}
.brand__text{font-size:1.3rem;line-height:1;display:flex;flex-direction:column}
.brand__text small{font-size:.6rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-d);margin-top:3px}
.nav{display:flex;gap:22px;margin-left:auto;font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.03em}
.nav a{color:var(--ink);padding:4px 0;position:relative}
.nav a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--blue);transform:scaleX(0);transition:transform .2s}
.nav a:hover::after{transform:scaleX(1)}
.header__cta{display:flex;gap:10px;align-items:center}
.hamburger{display:none;background:none;border:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;margin-left:auto}
.hamburger span{width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:.25s}

/* ---- Hero (dark) ---- */
.hero{background:linear-gradient(140deg,#1a3046 0%,#0e1c2c 100%);color:#c8d3de;overflow:hidden;position:relative}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;background:var(--blue)}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:64px 22px 72px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.05);border:1px solid rgba(58,155,212,.6);color:#fff;font-weight:700;font-size:.8rem;letter-spacing:.02em;text-transform:uppercase;padding:8px 15px;border-radius:3px}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--blue-l)}
.hero h1{font-size:clamp(2.1rem,5vw,3.5rem);margin:20px 0 16px;color:#fff;text-transform:uppercase;letter-spacing:-.01em}
.hero .hl{color:var(--blue-l)}
.lead{font-size:1.12rem;max-width:33em;color:#cdd7e1}
.hero__btns{display:flex;flex-wrap:wrap;gap:14px;margin:28px 0 26px}
.hero__trust{display:flex;flex-direction:column;gap:12px}
.stars{color:#FFB300;font-weight:800;letter-spacing:1px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.hero .stars span{color:#e2e2e2;font-weight:500;letter-spacing:0;font-size:.92rem}
.ticks{list-style:none;display:flex;flex-wrap:wrap;gap:9px 22px;font-size:.9rem;font-weight:700;color:#eaeaea}
.ticks li{display:inline-flex;align-items:center;gap:8px}
.ic-chk{width:17px;height:17px;stroke-width:3;color:var(--blue-l)}
.hero__media{position:relative}
.hero__media>img{border-radius:var(--radius);box-shadow:0 24px 60px rgba(0,0,0,.5);width:100%;height:auto;object-fit:cover;aspect-ratio:4/4.6;border:3px solid var(--blue-l)}
.hero__badge{position:absolute;background:#fff;border-radius:6px;box-shadow:var(--shadow-lg);padding:12px 16px;display:flex;flex-direction:column;line-height:1.1}
.hero__badge strong{font-family:"Plus Jakarta Sans";font-size:1.4rem;color:var(--charcoal)}
.hero__badge span{font-size:.78rem;color:var(--muted)}
.hero__badge{bottom:22px;left:-14px;border-left:5px solid var(--blue)}
.hero__badge--2{top:22px;right:-14px;bottom:auto;left:auto;border-left:5px solid var(--charcoal)}
.hero__badge--2 strong{color:var(--blue-d)}

/* ---- Trust strip ---- */
.strip{background:var(--charcoal)}
.strip__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;padding:26px 22px}
.strip__item{text-align:center;border-right:1px solid rgba(255,255,255,.12)}
.strip__item:last-child{border:none}
.strip__item strong{display:block;font-family:"Plus Jakarta Sans";font-size:1.25rem;color:var(--blue-l)}
.strip__item span{font-size:.82rem;color:#c6d0da}

/* ---- Sections ---- */
.section{padding:74px 0}
.section--alt{background:var(--bg-alt)}
.section__head{max-width:680px;margin:0 auto 44px;text-align:center}
.section__head .kicker{margin-bottom:14px}
.section__head h2{font-size:clamp(1.7rem,3.6vw,2.5rem);margin-bottom:12px;text-transform:uppercase}
.section__head p{font-size:1.05rem}

/* ---- Service cards ---- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;position:relative;box-shadow:var(--shadow);transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card__ico{width:52px;height:52px;border-radius:8px;display:grid;place-items:center;margin-bottom:16px;background:var(--blue);color:#fff}
.card__ico .ic{width:26px;height:26px}
.card h3{font-size:1.06rem;margin-bottom:8px}
.card p{font-size:.92rem}
.card--hot{border-color:var(--yellow);box-shadow:var(--hard)}
.card--hot:hover{box-shadow:6px 6px 0 0 rgba(28,28,28,.92);transform:translate(-2px,-2px)}
.badge-hot{position:absolute;top:14px;right:14px;background:var(--yellow);color:var(--charcoal);font-size:.66rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:4px 9px;border-radius:3px}
.card--cta{background:var(--charcoal);color:#fff;display:flex;flex-direction:column;gap:8px;justify-content:center}
.card--cta h3{color:#fff;text-transform:uppercase}
.card--cta p{color:#c6d0da}
.card--cta .btn{margin-top:8px}
.card__list{list-style:none;margin-top:14px;padding-top:14px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:7px}
.card__list li{position:relative;padding-left:20px;font-size:.85rem;color:var(--body)}
.card__list li::before{content:"";position:absolute;left:2px;top:8px;width:7px;height:7px;background:var(--blue);border-radius:1px;transform:rotate(45deg)}
.card--cta .card__list{border-top-color:rgba(255,255,255,.15)}

/* ---- How it works (3-step) ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;counter-reset:step}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;text-align:center;box-shadow:var(--shadow);position:relative;transition:transform .3s,box-shadow .3s}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.step__num{width:54px;height:54px;margin:0 auto 16px;display:grid;place-items:center;background:var(--blue);color:#fff;font-family:"Plus Jakarta Sans";font-weight:800;font-size:1.5rem;border-radius:8px;box-shadow:var(--hard-sm)}
.step h3{font-size:1.12rem;margin-bottom:8px;text-transform:uppercase}
.step p{font-size:.93rem}

/* ---- Guarantee banner ---- */
.guarantee{display:flex;align-items:center;gap:22px;background:var(--charcoal);color:#fff;border-radius:var(--radius);padding:26px 30px;border-left:6px solid var(--blue-l);margin-top:8px}
.guarantee__seal{flex:none;width:62px;height:62px;display:grid;place-items:center;background:var(--blue);color:#fff;border-radius:50%}
.guarantee__seal .ic{width:32px;height:32px;stroke-width:2.4}
.guarantee h3{color:#fff;text-transform:uppercase;font-size:1.15rem;margin-bottom:4px}
.guarantee p{color:#cdd7e1;font-size:.95rem}

/* ---- Pricing ---- */
.pricing{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;max-width:840px;margin:0 auto}
.price{display:flex;justify-content:space-between;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:16px 20px;box-shadow:var(--shadow);border-left:4px solid var(--blue)}
.price__job{font-weight:600;color:var(--ink)}
.price__amt{font-family:"Plus Jakarta Sans",sans-serif;font-weight:800;color:var(--ink);white-space:nowrap}
.pricing__note{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;text-align:center;margin-top:22px;font-weight:700;color:var(--ink)}
.pricing__note .ic-chk{color:var(--wa-d)}
.pricing__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:24px}

/* ---- About ---- */
.about__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:center}
.about__media img{border-radius:var(--radius);box-shadow:var(--shadow-lg);aspect-ratio:4/3.4;object-fit:cover;width:100%;height:auto;border-bottom:5px solid var(--blue)}
.about__copy h2{font-size:clamp(1.7rem,3.4vw,2.4rem);margin-bottom:14px;text-transform:uppercase}
.why{list-style:none;margin:18px 0 24px;display:flex;flex-direction:column;gap:13px}
.why li{padding-left:32px;position:relative}
.why li::before{content:"";position:absolute;left:0;top:3px;width:20px;height:20px;background:var(--blue);border-radius:3px}
.why li::after{content:"";position:absolute;left:6px;top:8px;width:8px;height:5px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg)}
.why strong{color:var(--ink)}
.about__btns{display:flex;gap:14px;flex-wrap:wrap}

/* ---- Gallery ---- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gallery__item{margin:0;position:relative;border-radius:8px;overflow:hidden;cursor:pointer;box-shadow:var(--shadow);grid-row:span 1}
.gallery__item--tall{grid-row:span 2}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery__item:hover img{transform:scale(1.06)}
.gallery__item figcaption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(17,17,17,.88));color:#fff;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:24px 14px 12px;opacity:0;transform:translateY(8px);transition:.25s}
.gallery__item::before{content:"";position:absolute;left:0;bottom:0;width:0;height:4px;background:var(--blue);transition:width .3s;z-index:2}
.gallery__item:hover::before{width:100%}
.gallery__item:hover figcaption{opacity:1;transform:none}

/* ---- Reviews ---- */
.google-badge{display:inline-flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px 22px;box-shadow:var(--shadow);margin-top:6px;transition:transform .15s,box-shadow .15s}
.google-badge:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.google-badge__g{flex:none}
.google-badge__txt{display:inline-flex;align-items:center;gap:8px;font-weight:800;color:var(--ink);font-size:1.05rem}
.google-badge__txt .stars{font-size:1rem}
.google-badge__sub{font-size:.84rem;color:var(--blue-d);font-weight:700;text-transform:uppercase;letter-spacing:.02em}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow);border-top:4px solid var(--blue)}
.review p{color:var(--ink);font-size:1rem;flex:1}
.review footer{display:flex;align-items:center;gap:12px}
.avatar{width:42px;height:42px;border-radius:8px;background:var(--blue);color:#fff;display:grid;place-items:center;font-weight:800;font-family:"Plus Jakarta Sans"}
.review footer strong{display:block;color:var(--ink)}
.review footer small{color:#157a3a;font-weight:700}
.reviews__cta{text-align:center;margin-top:26px;color:var(--body)}

/* ---- Areas ---- */
.areas{list-style:none;display:grid;grid-template-columns:repeat(6,1fr);gap:12px;max-width:980px;margin:0 auto}
.areas li{background:#fff;border:1px solid var(--line);border-radius:6px;padding:12px 10px;text-align:center;font-weight:700;font-size:.88rem;color:var(--ink);transition:.18s}
.areas li:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.areas__note{text-align:center;margin-top:24px}

/* ---- FAQ ---- */
.faq{display:flex;flex-direction:column;gap:12px}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);overflow:hidden}
.faq__item[open]{border-color:var(--blue);box-shadow:var(--hard-sm)}
.faq__item summary{display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer;padding:18px 22px;font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;color:var(--ink);list-style:none;font-size:1.02rem}
.faq__item summary::-webkit-details-marker{display:none}
.faq__chev{width:20px;height:20px;color:var(--blue-d);flex:none;transition:transform .2s}
.faq__item[open] .faq__chev{transform:rotate(180deg)}
.faq__a{padding:0 22px 20px;color:var(--body)}
.faq__a a{color:var(--ink);font-weight:700;text-decoration:underline;text-decoration-color:var(--blue)}

/* ---- Big CTA ---- */
.bigcta{background:linear-gradient(135deg,#1a3046,#0e1c2c);color:#fff;position:relative}
.bigcta::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--blue)}
.bigcta__inner{display:flex;align-items:center;justify-content:space-between;gap:28px;padding:50px 22px;flex-wrap:wrap}
.bigcta h2{color:#fff;font-size:clamp(1.6rem,3vw,2.2rem);text-transform:uppercase}
.bigcta p{color:#cdd7e1;margin-top:6px}
.bigcta__btns{display:flex;gap:14px;flex-wrap:wrap}

/* ---- Contact ---- */
.contact__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:start}
.contact__info h2{font-size:clamp(1.7rem,3.4vw,2.4rem);margin-bottom:12px;text-transform:uppercase}
.contact__list{list-style:none;margin-top:24px;display:flex;flex-direction:column;gap:16px}
.contact__list li{display:flex;gap:14px;align-items:flex-start}
.ci{flex:none;width:44px;height:44px;background:var(--blue);border-radius:8px;display:grid;place-items:center;color:#fff}
.ci .ic{width:21px;height:21px}
.contact__list small{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--blue-d);font-weight:800}
.contact__list a{color:var(--ink);font-weight:700}
.contact__list a:hover{color:var(--blue-d)}
.contact__form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}
.form-emergency{display:flex;align-items:center;gap:12px;background:var(--charcoal);border:none;color:#fff;border-left:5px solid var(--yellow);border-radius:6px;padding:14px 16px;margin-bottom:6px;font-size:.92rem}
.form-emergency .ic{width:26px;height:26px;flex:none;stroke:var(--yellow)}
.form-emergency strong{color:#fff;display:block;text-transform:uppercase;letter-spacing:.02em}
.form-emergency:hover{background:#000}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-weight:700;font-size:.84rem;color:var(--ink);text-transform:uppercase;letter-spacing:.03em}
.field input,.field select,.field textarea{font:inherit;padding:11px 13px;border:1.5px solid var(--line);border-radius:6px;background:#fafafa;transition:.15s;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(22,112,184,.22)}
.form__note{font-size:.82rem;text-align:center;color:var(--muted)}
.map{margin-top:34px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);line-height:0}
.map iframe{width:100%;height:340px;border:0;display:block;filter:grayscale(.2)}

/* ---- Footer ---- */
.footer{background:var(--charcoal-d);color:#bcc6d1;padding-top:54px;border-top:4px solid var(--blue)}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:36px;padding-bottom:36px}
.brand--light .brand__text{color:#fff}
.brand--light .brand__text small{color:var(--blue-l)}
.footer__about{margin-top:14px;font-size:.92rem;max-width:34em}
.footer h4{color:#fff;margin-bottom:14px;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:9px;font-size:.92rem}
.footer a:hover{color:var(--blue-l)}
.footer__bar{border-top:1px solid rgba(255,255,255,.1);padding:18px 0}
.footer__bar-inner{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.82rem;color:#93a1b0}

/* ---- Floating WhatsApp widget ---- */
.wa-fab{position:fixed;right:20px;bottom:22px;z-index:60;display:inline-flex;align-items:center;gap:.6rem;background:var(--charcoal);color:#fff;font-weight:700;font-size:.9rem;padding:.7rem 1.1rem .7rem .8rem;border-radius:5px;box-shadow:0 8px 24px rgba(0,0,0,.32);transition:transform .15s,background-color .2s}
.wa-fab:hover{transform:translateY(-2px);background:#000}
.wa-fab .wa-icon{display:inline-flex;align-items:center;justify-content:center;width:2.1rem;height:2.1rem;border-radius:4px;background:var(--wa);color:#fff;flex-shrink:0}
.wa-fab .wa-icon .ico{width:1.3em;height:1.3em}

/* ---- Mobile sticky call bar ---- */
.mobilebar{position:fixed;bottom:0;left:0;right:0;z-index:60;display:none;box-shadow:0 -6px 20px rgba(0,0,0,.2)}
.mobilebar__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:15px;color:var(--charcoal);font-weight:800;font-family:"Plus Jakarta Sans";text-transform:uppercase;letter-spacing:.03em;font-size:.9rem}
.mobilebar__btn--call{background:var(--blue);color:#fff}
.mobilebar__btn--wa{background:var(--wa);color:#fff}

/* ---- Lightbox ---- */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(10,10,10,.94);display:none;align-items:center;justify-content:center;padding:30px}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:86vh;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.6);border:3px solid var(--blue)}
.lightbox__close{position:absolute;top:18px;right:24px;background:none;border:none;color:#fff;font-size:2.6rem;line-height:1;cursor:pointer}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:none;color:#fff;font-size:2rem;width:52px;height:52px;border-radius:6px;cursor:pointer;display:grid;place-items:center}
.lightbox__nav:hover{background:var(--blue);color:#fff}
.lightbox__prev{left:18px}
.lightbox__next{right:18px}

/* ---- Responsive ---- */
@media(max-width:980px){
  .hero__grid,.about__grid,.contact__grid{grid-template-columns:1fr}
  .hero__media{order:-1;max-width:460px;margin:0 auto}
  .cards{grid-template-columns:repeat(2,1fr)}
  .reviews{grid-template-columns:1fr}
  .areas{grid-template-columns:repeat(4,1fr)}
  .strip__grid{grid-template-columns:repeat(3,1fr);gap:20px 10px}
  .strip__item:nth-child(3){border:none}
  .footer__grid{grid-template-columns:1fr 1fr}
  .pricing{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
}
@media(max-width:760px){
  .nav{display:none;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:#fff;border-bottom:1px solid var(--line);padding:14px 22px;gap:4px;box-shadow:var(--shadow)}
  .nav.open{display:flex}
  .nav a{padding:11px 0;border-bottom:1px solid var(--line)}
  .header__cta{display:none}
  .hamburger{display:flex}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .areas{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr}
  .mobilebar{display:flex}
  body{padding-bottom:56px}
  .wa-fab{display:none}
  .utilbar__inner{justify-content:center;gap:10px;text-align:center}
  .utilbar__item{font-size:.76rem}
  .guarantee{flex-direction:column;text-align:center}
  .map iframe{height:280px}
}
@media(max-width:440px){
  .cards{grid-template-columns:1fr}
  .strip__grid{grid-template-columns:repeat(2,1fr)}
  .hero__badge{display:none}
}

/* ---- Accessibility: skip link + visible keyboard focus ---- */
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--blue);color:#fff;font-family:"Plus Jakarta Sans",sans-serif;font-weight:800;padding:12px 18px;border-radius:0 0 8px 0;text-decoration:none}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--blue-l);outline-offset:2px;border-radius:3px}
.btn:focus-visible,.utilbar__call:focus-visible,.mobilebar__btn:focus-visible{outline:3px solid #fff;outline-offset:3px}
.nav a:focus-visible{outline:3px solid var(--blue);outline-offset:4px}
/* Honeypot field — hidden from people, visible to bots */
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
/* Inline form-success message */
.form-success{display:flex;align-items:flex-start;gap:9px;background:#eaf6ee;border:1px solid #bfe3cb;color:#15633a;border-radius:8px;padding:12px 14px;font-size:.9rem;font-weight:600;line-height:1.5}
.form-success .ic-chk{color:#1da955;flex:none;margin-top:2px;width:18px;height:18px;stroke-width:3}
.form-success a{color:#15633a;text-decoration:underline}
/* WhatsApp buttons: subtle shadow improves white-text legibility (A11Y-5) */
.btn--wa{text-shadow:0 1px 1px rgba(0,0,0,.28)}
/* No-JavaScript fallback bar */
.noscript-bar{background:var(--yellow);color:var(--charcoal);text-align:center;padding:11px 16px;font-weight:700;font-size:.9rem}
.noscript-bar a{text-decoration:underline;color:var(--charcoal)}
