/* ===========================================================
   Bulldog Sewer & Drain — styles.css
   Self-contained. Light industrial theme, locked green accent.
   =========================================================== */

/* ---------- Fonts (self-hosted) ---------- */
@font-face{font-family:"Oswald";src:url("assets/fonts/font-oswald-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Oswald";src:url("assets/fonts/font-oswald-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Oswald";src:url("assets/fonts/font-oswald-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/fonts/font-inter-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/fonts/font-inter-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/fonts/font-inter-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/fonts/font-inter-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --paper:#ffffff;
  --paper-2:#f2f5f6;
  --paper-3:#e9edee;
  --ink:#141a1d;
  --ink-soft:#4b565c;
  --line:#e0e5e7;
  --dark:#121719;
  --dark-2:#1a2226;
  --green:#5bb22b;        /* fills / accents */
  --green-700:#4a9a22;    /* hover */
  --green-ink:#2f7d12;    /* green text on white (AA) */
  --red:#cf2530;          /* emergency only */
  --display:"Oswald", "Arial Narrow", system-ui, sans-serif;
  --body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --wrap:1200px;
  --radius:14px;
  --shadow:0 18px 40px -22px rgba(20,26,29,.45);
  --shadow-sm:0 8px 22px -14px rgba(20,26,29,.40);
}

/* ---------- Reset ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.04;margin:0;letter-spacing:.01em;text-transform:uppercase}
p{margin:0 0 1rem}
ul{margin:0;padding:0;list-style:none}
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 22px}
.green{color:var(--green-ink)}
.i{width:18px;height:18px;flex:0 0 auto;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.skip-link{position:absolute;left:-999px;top:0;background:var(--green);color:#0e1316;padding:10px 16px;z-index:200;border-radius:0 0 8px 0;font-weight:700}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--green);outline-offset:2px;border-radius:6px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.03em;
  font-size:.94rem;line-height:1;padding:.85rem 1.25rem;border-radius:10px;border:2px solid transparent;
  cursor:pointer;transition:transform .12s ease, background .18s ease, color .18s ease, border-color .18s ease, box-shadow .18s ease;white-space:nowrap}
.btn .i{width:17px;height:17px}
.btn:active{transform:translateY(1px) scale(.99)}
.btn--solid{background:var(--green);color:#0e1316;box-shadow:0 10px 22px -12px rgba(91,178,43,.9)}
.btn--solid:hover{background:var(--green-700)}
.btn--ghost{background:var(--paper);color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--ink);}
.btn--outline-light{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.55)}
.btn--outline-light:hover{background:rgba(255,255,255,.16);border-color:#fff}
.btn--lg{padding:1.05rem 1.6rem;font-size:1.02rem}
.btn--block{width:100%}

/* ---------- Utility bar ---------- */
.utilbar{background:var(--dark);color:#cfd6d9;font-size:.82rem}
.utilbar__inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:38px;flex-wrap:wrap}
.utilbar__item{display:inline-flex;align-items:center;gap:.45rem}
.utilbar__item .i{width:15px;height:15px;stroke:var(--green)}
.utilbar__item--accent{color:#fff;font-weight:500}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line);transition:box-shadow .2s ease}
.header.is-stuck{box-shadow:0 10px 30px -18px rgba(20,26,29,.4)}
.header__inner{display:flex;align-items:center;gap:1.2rem;min-height:74px}
.brand{display:flex;align-items:center}
.brand__logo{height:54px;width:auto}
.nav{display:flex;gap:1.4rem;margin-left:1rem}
.nav a{font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.04em;font-size:.95rem;
  color:var(--ink);padding:.4rem 0;position:relative}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--green);transition:right .22s ease}
.nav a:hover::after,.nav a:focus-visible::after{right:0}
.header__cta{display:flex;align-items:center;gap:.6rem;margin-left:auto}
.btn--call .i{stroke:currentColor}

.navtoggle{display:none;margin-left:auto;width:46px;height:42px;border:1px solid var(--line);background:var(--paper);
  border-radius:10px;flex-direction:column;gap:5px;align-items:center;justify-content:center;cursor:pointer}
.navtoggle span{width:22px;height:2px;background:var(--ink);transition:.2s}
.navtoggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.navtoggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.navtoggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobilenav{display:none;flex-direction:column;background:var(--paper);border-bottom:1px solid var(--line);padding:8px 22px 18px}
.mobilenav a{font-family:var(--display);text-transform:uppercase;letter-spacing:.03em;font-weight:500;
  padding:.85rem 0;border-bottom:1px solid var(--line);color:var(--ink)}
.mobilenav.is-open{display:flex}
.mobilenav__calls{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-top:14px}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:clamp(540px,82vh,760px);display:flex;align-items:center;color:#fff;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 60%}
.hero__scrim{position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(12,16,18,.92) 0%,rgba(12,16,18,.78) 38%,rgba(12,16,18,.42) 70%,rgba(12,16,18,.25) 100%)}
.hero__inner{position:relative;z-index:1;padding:96px 22px;max-width:760px}
.hero__title{font-size:clamp(2.7rem,6.2vw,4.6rem);letter-spacing:.005em;text-shadow:0 2px 20px rgba(0,0,0,.35)}
.hero__sub{font-size:clamp(1.05rem,2vw,1.28rem);color:#e7ecee;max-width:46ch;margin:1.1rem 0 1.8rem;line-height:1.5}
.hero__actions{display:flex;gap:.8rem;flex-wrap:wrap}

.eyebrow{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.22em;
  font-size:.8rem;color:var(--ink-soft);margin:0 0 .85rem}
.eyebrow--green{color:var(--green)}

/* ---------- Trust strip ---------- */
.trust{background:var(--dark);color:#fff;border-bottom:4px solid var(--green)}
.trust__inner{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;padding:26px 22px}
.trust__item{display:flex;flex-direction:column;text-align:center;gap:.15rem;position:relative}
.trust__item+.trust__item::before{content:"";position:absolute;left:-.5rem;top:50%;transform:translateY(-50%);height:34px;width:1px;background:rgba(255,255,255,.14)}
.trust__item strong{font-family:var(--display);font-size:1.18rem;letter-spacing:.02em}
.trust__item span{font-size:.82rem;color:#aab4b8}

/* ---------- Sections ---------- */
.section{padding:84px 0}
.section--alt{background:var(--paper-2)}
.section__head{max-width:720px;margin:0 auto 48px;text-align:center}
.section__title{font-size:clamp(1.9rem,3.8vw,2.85rem)}
.section__lead{color:var(--ink-soft);font-size:1.08rem;margin-top:1rem}
.section__note{text-align:center;color:var(--ink-soft);margin-top:34px;font-size:1rem}
.section__note a{color:var(--green-ink);font-weight:600}

/* ---------- Service cards ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .2s ease, box-shadow .2s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card__img{aspect-ratio:4/3;overflow:hidden;background:var(--paper-3)}
.card__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card__img img{transform:scale(1.05)}
.card__body{padding:18px 18px 22px;display:flex;flex-direction:column;gap:.5rem}
.card__body h3{font-size:1.16rem;line-height:1.12}
.card__body p{color:var(--ink-soft);font-size:.95rem;line-height:1.5;margin:0}

/* first card spans two columns as a feature */
.cards .card:first-child{grid-column:span 2;flex-direction:row}
.cards .card:first-child .card__img{aspect-ratio:auto;width:46%;min-height:100%}
.cards .card:first-child .card__body{justify-content:center;padding:26px}
.cards .card:first-child h3{font-size:1.4rem}
.cards .card:first-child p{font-size:1rem}

/* ---------- Split (camera) ---------- */
.split{background:var(--dark);color:#fff;padding:84px 0}
.split__inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split__media{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ba{margin:0;position:relative;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.12)}
.ba img{aspect-ratio:3/4;object-fit:cover;width:100%}
.ba figcaption{position:absolute;left:10px;top:10px;background:rgba(12,16,18,.78);color:#fff;
  font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;padding:.3rem .6rem;border-radius:6px}
.ba:last-child figcaption{background:var(--green);color:#0e1316}
.split__copy h2{font-size:clamp(1.8rem,3.4vw,2.5rem);margin-bottom:1rem}
.split__copy p{color:#cdd5d8;font-size:1.05rem}
.ticklist{margin:1.2rem 0 1.6rem;display:grid;gap:.7rem}
.ticklist li{position:relative;padding-left:1.9rem;color:#e7ecee}
.ticklist li::before{content:"";position:absolute;left:0;top:.15rem;width:1.2rem;height:1.2rem;border-radius:50%;
  background:var(--green);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.5z'/></svg>") center/80% no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.5z'/></svg>") center/80% no-repeat}

/* ---------- Why ---------- */
.why{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.why__item{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;box-shadow:var(--shadow-sm)}
.why__icon{display:inline-flex;width:52px;height:52px;border-radius:12px;align-items:center;justify-content:center;
  background:rgba(91,178,43,.12);margin-bottom:14px}
.why__icon svg{width:26px;height:26px;fill:none;stroke:var(--green-ink);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.why__item h3{font-size:1.16rem;margin-bottom:.5rem}
.why__item p{color:var(--ink-soft);font-size:.96rem;margin:0}

/* ---------- Area ---------- */
.area__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center}
.area__list{display:grid;grid-template-columns:repeat(3,1fr);gap:.55rem .8rem;margin:1.5rem 0}
.area__list li{position:relative;padding-left:1.1rem;color:var(--ink);font-weight:500;font-size:.97rem}
.area__list li::before{content:"";position:absolute;left:0;top:.55rem;width:7px;height:7px;border-radius:50%;background:var(--green)}
.area__calls{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:.5rem}
.area__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover}

/* ---------- Reviews ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{margin:0;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm)}
.quote__stars{color:var(--green);letter-spacing:.12em;font-size:1.05rem;margin-bottom:.7rem}
.quote blockquote{margin:0 0 1rem;font-size:1.08rem;line-height:1.5;color:var(--ink);font-weight:500}
.quote figcaption{color:var(--ink-soft);font-size:.85rem}
.reviews__cta{text-align:center;margin-top:36px}

/* ---------- About ---------- */
.about__inner{display:grid;grid-template-columns:.95fr 1.05fr;gap:52px;align-items:center}
.about__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%}
.about__copy p{color:var(--ink-soft)}
.about__copy .btn{margin-top:.6rem}

/* ---------- Emergency ---------- */
.emergency{background:linear-gradient(100deg,#2a0e0f 0%,#1a1719 60%);color:#fff;border-top:4px solid var(--red);border-bottom:4px solid var(--red)}
.emergency__inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:46px 22px;flex-wrap:wrap}
.emergency__kicker{font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-size:.8rem;color:#ff8a8f;margin:0 0 .4rem}
.emergency__text h2{font-size:clamp(1.7rem,3.2vw,2.4rem)}
.emergency__text p{color:#e8d9da;margin:.5rem 0 0;max-width:46ch}
.emergency__calls{display:flex;gap:.8rem;flex-wrap:wrap}

/* ---------- Contact ---------- */
.contact__inner{display:grid;grid-template-columns:1fr 1.05fr;gap:52px;align-items:start}
.contact__rows{display:grid;gap:.4rem;margin:1.4rem 0 1.2rem}
.contact__row{display:flex;gap:.9rem;align-items:flex-start;padding:.7rem 0;border-bottom:1px solid var(--line)}
.contact__row:last-child{border-bottom:0}
a.contact__row:hover .contact__ico{background:var(--green);}
a.contact__row:hover .contact__ico svg{stroke:#0e1316}
.contact__ico{flex:0 0 auto;width:42px;height:42px;border-radius:10px;background:rgba(91,178,43,.12);
  display:inline-flex;align-items:center;justify-content:center;transition:.18s}
.contact__ico svg{width:20px;height:20px;fill:none;stroke:var(--green-ink);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:.18s}
.contact__row span:last-child{display:flex;flex-direction:column;line-height:1.4}
.contact__row strong{font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;font-size:.84rem;color:var(--ink-soft);font-weight:600}
.contact__social{display:flex;gap:.6rem;margin-top:.4rem}
.contact__social a,.footer__social a{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);
  display:inline-flex;align-items:center;justify-content:center;transition:.18s}
.contact__social a svg{width:20px;height:20px;fill:none;stroke:var(--ink);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.contact__social a:hover{background:var(--green);border-color:var(--green)}
.contact__social a:hover svg{stroke:#0e1316}

/* form */
.contact__formwrap{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:var(--shadow)}
.section--alt .contact__formwrap{background:var(--paper)}
.qform{display:grid;gap:14px}
.field{display:flex;flex-direction:column;gap:.35rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field label{font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;font-weight:600;color:var(--ink)}
.field .opt{color:var(--ink-soft);font-weight:500;text-transform:none;letter-spacing:0}
.field input,.field select,.field textarea{font-family:var(--body);font-size:1rem;color:var(--ink);
  background:var(--paper-2);border:1.5px solid var(--line);border-radius:10px;padding:.78rem .9rem;width:100%;transition:.16s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);background:#fff;box-shadow:0 0 0 3px rgba(91,178,43,.18)}
.field input::placeholder,.field textarea::placeholder{color:#8a949a}
.field.invalid input,.field.invalid select{border-color:var(--red);background:#fff5f5}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.qform__fine{font-size:.86rem;color:var(--ink-soft);margin:.2rem 0 0;text-align:center}
.qform__fine a{color:var(--green-ink);font-weight:600}
.qform__done{background:rgba(91,178,43,.1);border:1.5px solid var(--green);border-radius:12px;padding:20px;text-align:center}
.qform__done strong{font-family:var(--display);text-transform:uppercase;letter-spacing:.03em;font-size:1.1rem;display:block;margin-bottom:.3rem}
.qform__done p{color:var(--ink-soft);font-size:.95rem}
.qform__doneactions{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-top:.6rem}

/* ---------- Footer ---------- */
.footer{background:var(--dark);color:#c7cfd2;padding-top:56px}
.footer__inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px;padding-bottom:40px}
.footer__mascot{height:58px;width:auto;margin-bottom:6px;filter:drop-shadow(0 6px 16px rgba(0,0,0,.4))}
.footer__name{font-family:var(--display);text-transform:uppercase;letter-spacing:.03em;font-size:1.35rem;color:#fff;margin:.2rem 0 .4rem}
.footer__tag{font-size:.92rem;max-width:34ch;color:#aab4b8}
.footer__social{display:flex;gap:.5rem;margin-top:14px}
.footer__social a{border-color:rgba(255,255,255,.16)}
.footer__social a svg{stroke:#cfd6d9}
.footer__social a:hover{background:var(--green);border-color:var(--green)}
.footer__social a:hover svg{stroke:#0e1316}
.footer__col h4{font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;color:#fff;font-size:1rem;margin-bottom:14px}
.footer__col ul li{margin-bottom:.55rem;font-size:.93rem}
.footer__col a:hover{color:var(--green)}
.footer__area{display:grid;grid-template-columns:1fr 1fr;gap:.2rem .8rem}
.footer__bar{border-top:1px solid rgba(255,255,255,.1)}
.footer__barinner{display:flex;justify-content:space-between;gap:1rem;padding:18px 22px;flex-wrap:wrap}
.footer__bar p{margin:0;font-size:.82rem;color:#939da1}
.footer__fine{color:#7d878b}

/* ---------- Mobile sticky call bar ---------- */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:120;display:none;
  grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.1);
  box-shadow:0 -10px 30px -16px rgba(0,0,0,.5)}
.callbar__btn{display:flex;align-items:center;justify-content:center;gap:.45rem;padding:14px;
  font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;font-weight:600;font-size:.98rem}
.callbar__btn .i{stroke:currentColor}
.callbar__btn--call{background:var(--green);color:#0e1316}
.callbar__btn--est{background:var(--dark);color:#fff}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease, transform .6s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ===========================================================
   Responsive
   =========================================================== */
@media (max-width:1040px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .cards .card:first-child{grid-column:span 2}
  .why{grid-template-columns:repeat(2,1fr)}
  .footer__inner{grid-template-columns:1fr 1fr;gap:28px}
}
@media (max-width:900px){
  .nav,.header__cta{display:none}
  .navtoggle{display:flex}
  .trust__inner{grid-template-columns:repeat(2,1fr);gap:18px}
  .trust__item:nth-child(odd)::before{display:none}
  .trust__item{padding:6px 0}
  .split__inner,.area__inner,.about__inner,.contact__inner{grid-template-columns:1fr;gap:34px}
  .about__media{order:2}
  .quotes{grid-template-columns:1fr}
  .emergency__inner{flex-direction:column;align-items:flex-start}
}
@media (max-width:720px){
  body{font-size:16px}
  .section{padding:60px 0}
  .split{padding:60px 0}
  .utilbar__item:first-child{display:none}
  .utilbar__inner{justify-content:center}
  .cards{grid-template-columns:1fr}
  .cards .card:first-child{grid-column:span 1;flex-direction:column}
  .cards .card:first-child .card__img{width:100%;aspect-ratio:4/3}
  .why{grid-template-columns:1fr}
  .area__list{grid-template-columns:repeat(2,1fr)}
  .footer__inner{grid-template-columns:1fr;gap:26px}
  .footer__area{max-width:300px}
  .callbar{display:grid}
  body{padding-bottom:58px}
  .hero__inner{padding:64px 22px 72px}
  .hero{min-height:auto}
  .field-row{grid-template-columns:1fr}
  .header__inner{min-height:64px}
  .brand__logo{height:46px}
}
@media (max-width:420px){
  .area__list{grid-template-columns:1fr}
  .hero__actions{flex-direction:column;align-items:stretch}
  .hero__actions .btn{width:100%}
}
