/* Munn Diesel — design system. Mirrors the live munndieselrepair.com layout, polished. */
:root{
  --blue:#006DE2;--blue-d:#0a4f9e;--blue-l:#3a96ff;
  --ink:#15202b;--dark:#0d1117;--paper:#ffffff;--off:#eef1f5;--foot:#e8eaed;--line:rgba(20,32,43,.12);
  --text:#3a4654;--muted:#6b7888;--hair:rgba(255,255,255,.14);--ease:cubic-bezier(.16,1,.3,1);--w:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--text);background:var(--paper);-webkit-font-smoothing:antialiased;line-height:1.7;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Montserrat',sans-serif;color:var(--ink);line-height:1.12}
.wrap{max-width:var(--w);margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
/* pill buttons (match live) */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Montserrat';font-weight:700;font-size:.86rem;letter-spacing:.04em;padding:15px 38px;border-radius:40px;border:0;cursor:pointer;transition:transform .4s var(--ease),box-shadow .4s,background .25s,color .25s}
.btn-blue{background:linear-gradient(180deg,var(--blue-l),var(--blue));color:#fff;box-shadow:0 10px 26px rgba(0,109,226,.34)}
.btn-blue:hover{transform:translateY(-3px);box-shadow:0 16px 38px rgba(0,109,226,.46)}
.btn-white{background:#fff;color:var(--blue);box-shadow:0 10px 26px rgba(0,0,0,.18)}
.btn-white:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,.26)}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.6)}.btn-ghost:hover{background:#fff;color:var(--blue);border-color:#fff}
.btn .ar{transition:transform .4s var(--ease)}.btn:hover .ar{transform:translateX(4px)}

/* header — white, like live */
header{position:fixed;inset:0 0 auto 0;z-index:100;background:rgba(255,255,255,.97);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line);transition:box-shadow .4s,padding .4s;padding:14px 0}
header.scrolled{box-shadow:0 6px 24px rgba(13,17,23,.09);padding:8px 0}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{height:64px;width:auto;transition:height .4s var(--ease)}
header .nav .logo{height:64px!important;width:auto!important;max-width:240px!important}
header.scrolled .logo,header.scrolled .nav .logo{height:50px!important}
.menu{display:flex;align-items:center;gap:30px;margin-left:auto;font-family:'Montserrat';font-weight:600;font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink)}
.menu a{position:relative;padding:6px 0;transition:color .25s}
.menu a::after{content:"";position:absolute;left:0;bottom:-1px;height:2px;width:0;background:var(--blue);transition:width .35s var(--ease)}
.menu a:hover,.menu a.active{color:var(--blue)}.menu a:hover::after,.menu a.active::after{width:100%}
.ico{display:inline-flex;align-items:center;justify-content:center;line-height:0;color:inherit}
.ico svg{width:20px;height:20px;display:block}
.ico.sm svg{width:14px;height:14px}
.nav-actions{display:flex;align-items:center;gap:16px}
.nav-cart{position:relative;color:var(--ink);display:inline-flex;transition:color .25s}
.nav-cart:hover{color:var(--blue)}
.nav-cart .ico svg{width:25px;height:25px;stroke-width:1.7}
.nav-cart .dot{position:absolute;top:-3px;right:-4px;width:9px;height:9px;background:var(--blue);border:2px solid #fff;border-radius:50%}
.nav-toggle{display:none;background:none;border:0;color:var(--ink);cursor:pointer;padding:4px}
.nav-toggle .ico svg{width:28px;height:28px}
.sub-trigger{display:inline-flex;align-items:center;gap:5px}
.has-sub{position:relative}
.submenu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 18px 40px rgba(13,17,23,.14);padding:10px;min-width:190px;opacity:0;visibility:hidden;transition:.28s var(--ease);display:flex;flex-direction:column;gap:2px}
.has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(4px)}
.submenu a{padding:9px 14px;border-radius:7px;font-size:.8rem;color:var(--text);text-transform:none;letter-spacing:0}
.submenu a::after{display:none}.submenu a:hover{background:var(--off);color:var(--blue)}

/* hero — centered, blue-tinted photo (premium, photo reads through) */
.hero{position:relative;min-height:86vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:-6% 0;background-size:cover;background-position:center 35%;will-change:transform}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,22,45,.58) 0%,rgba(0,74,160,.58) 52%,rgba(5,16,34,.8) 100%),radial-gradient(120% 85% at 50% 40%,transparent 42%,rgba(5,14,30,.5) 100%)}
.hero .wrap{position:relative;z-index:2;padding:130px 28px 84px;max-width:1000px}
.hero h1{font-size:clamp(2.5rem,6.2vw,5.4rem);font-weight:900;color:#fff;text-transform:uppercase;letter-spacing:.005em;line-height:1.02;text-shadow:0 4px 34px rgba(0,0,0,.45)}
.hero .sub{font-family:'Montserrat';font-style:italic;font-weight:600;font-size:clamp(1.05rem,2.3vw,1.55rem);color:rgba(255,255,255,.96);margin:22px auto 38px;max-width:30ch;text-shadow:0 2px 20px rgba(0,0,0,.5)}
.hero .btn{font-size:.92rem;padding:16px 44px}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
@media(max-width:560px){.hero-actions{width:100%}.hero-actions .btn{flex:1;min-width:140px;justify-content:center;padding:15px 20px}}

/* logo slider — plain logos, no boxes/names (match live), under the banner */
.logos{background:#fff;padding:46px 0;position:relative;border-bottom:1px solid var(--line)}
.logo-marquee{position:relative;width:100%;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.logo-track{display:flex;width:max-content;align-items:center;animation:marquee 40s linear infinite}
.logo-marquee:hover .logo-track{animation-play-state:paused}
.logo-track img{height:80px;width:auto;max-width:210px;object-fit:contain;flex:none;margin-right:80px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.logo-track{animation:none;flex-wrap:wrap;justify-content:center}.logo-track img{margin:0 20px}}
/* logo strip inside the hero banner */
.hero-logos{position:absolute;left:0;right:0;bottom:0;z-index:4;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);padding:16px 0;box-shadow:0 -6px 24px rgba(5,14,30,.18)}
.hero-logos .logo-track img{height:70px;margin-right:70px}
@media(max-width:560px){.hero-logos{padding:12px 0}.hero-logos .logo-track img{height:50px;margin-right:46px}}

.sec{padding:104px 0}
.sec-head{text-align:center;max-width:760px;margin:0 auto}
.sec-head h2{font-size:clamp(1.9rem,4vw,3rem);font-weight:800;text-transform:uppercase;color:var(--ink)}
.sec-head p{color:var(--muted);font-size:1.05rem;margin-top:16px}
.kicker{font-family:'Montserrat';font-weight:700;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);display:block;margin-bottom:14px}

/* services — 3 cards with real photos */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:56px}
.svc{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:transform .45s var(--ease),box-shadow .45s}
.svc:hover{transform:translateY(-8px);box-shadow:0 28px 60px rgba(13,17,23,.16)}
.svc .ph{aspect-ratio:16/10;overflow:hidden}
.svc .ph div{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .7s var(--ease)}
.svc:hover .ph div{transform:scale(1.07)}
.svc .b{padding:30px 28px 32px;display:flex;flex-direction:column;flex:1}
.svc h3{font-size:1.28rem;font-weight:800;text-transform:uppercase;color:var(--ink);line-height:1.15}
.svc p{margin:13px 0 22px;font-size:.96rem;color:var(--muted);flex:1}
.svc .btn{align-self:flex-start;padding:12px 26px;font-size:.78rem}

/* why choose us — dark, diagonal texture, numbered points, floating badge */
.why{position:relative;overflow:hidden;background:var(--dark);color:#fff}
.why::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.02) 0 1px,transparent 1px 24px);pointer-events:none}
.why .sec-head h2{color:#fff}
.why .grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:62px;align-items:center}
.why-points{display:flex;flex-direction:column}
.why-pt{display:flex;gap:22px;padding:26px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.why-pt:first-child{padding-top:0}.why-pt:last-child{border-bottom:0;padding-bottom:0}
.why-pt .ic{flex:none;width:56px;height:56px;border-radius:14px;display:grid;place-items:center;color:#fff;background:linear-gradient(150deg,var(--blue-l),var(--blue));box-shadow:0 12px 26px rgba(0,109,226,.38)}
.why-pt .ic svg{width:26px;height:26px}
.why-pt h3{font-size:1.2rem;font-weight:800;color:#fff;text-transform:none}
.why-pt p{margin-top:8px;font-size:.96rem;color:rgba(255,255,255,.62)}
.why-media{position:relative;aspect-ratio:4/5;max-height:560px;border-radius:16px;overflow:hidden;box-shadow:0 34px 80px rgba(0,0,0,.55)}
.why-media>div:first-child{width:100%;height:100%;background-size:cover;background-position:center}
.why-media::after{content:"";position:absolute;inset:0;background:linear-gradient(205deg,transparent 48%,rgba(0,90,200,.55))}
.why-badge{position:absolute;left:22px;bottom:22px;z-index:2;display:flex;align-items:center;gap:14px;background:#fff;border-radius:14px;padding:15px 20px;box-shadow:0 18px 40px rgba(0,0,0,.35)}
.why-badge b{font-family:'Montserrat';font-weight:900;font-size:1.9rem;line-height:1;color:var(--blue)}
.why-badge span{font-size:.74rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);line-height:1.3}

/* M18 feature — dark block */
.m18{position:relative;background:#0d1117;color:#fff;overflow:hidden;padding:96px 0}
.m18::before{content:"NEW";position:absolute;left:-10px;top:30px;font-family:'Montserrat';font-weight:900;font-size:13rem;color:rgba(255,255,255,.03);letter-spacing:-.04em;line-height:1;pointer-events:none}
.m18 .wrap{position:relative;z-index:2}
.m18 .title{text-align:center;font-size:clamp(1.8rem,3.6vw,2.7rem);font-weight:800;color:#fff;margin-bottom:50px;text-transform:none}
.m18 .grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.m18 .pimg{display:grid;place-items:center}.m18 .pimg img{max-height:380px;width:auto;filter:drop-shadow(0 26px 50px rgba(0,0,0,.5))}
.m18 ul{list-style:none;display:flex;flex-direction:column;gap:22px}
.m18 li{display:flex;gap:16px;align-items:flex-start}
.m18 li .ck{flex:none;width:26px;height:26px;border-radius:50%;background:var(--blue);display:grid;place-items:center;color:#fff;font-size:.8rem;margin-top:3px}
.m18 li b{font-family:'Montserrat';font-weight:800;font-size:1.16rem;color:#fff;display:block;text-transform:uppercase}
.m18 li span{font-size:.95rem;color:rgba(255,255,255,.6)}
.m18 .btn{margin-top:14px}

/* SEO text */
.seo{background:#fff;text-align:center}
.seo h2{font-size:clamp(1.5rem,3.4vw,2.3rem);font-weight:800;text-transform:uppercase;color:var(--ink);max-width:900px;margin:0 auto}
.seo h3{font-size:1.2rem;font-weight:800;text-transform:uppercase;color:var(--blue);margin:46px 0 16px}
.seo p{max-width:820px;margin:0 auto 16px;color:var(--text);font-size:1.02rem}

/* reviews */
.reviews{background:var(--off)}
.rev-top{text-align:center;margin-bottom:46px}
.rev-badge{display:inline-flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:40px;padding:12px 26px;box-shadow:0 8px 22px rgba(13,17,23,.07)}
.rev-badge .g{font-family:'Montserrat';font-weight:800;font-size:1.1rem}
.rev-badge .g b{color:#4285F4}.rev-badge .stars{color:#FBBC05;letter-spacing:2px}
.rev-badge .num{font-size:.86rem;color:var(--muted)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rev{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;box-shadow:0 8px 22px rgba(13,17,23,.05)}
.rev .hd{display:flex;align-items:center;gap:13px;margin-bottom:12px}
.rev .av{width:44px;height:44px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-family:'Montserrat';font-weight:800}
.rev .nm{font-family:'Montserrat';font-weight:700;color:var(--ink);font-size:.96rem}
.rev .stars{color:#FBBC05;font-size:.85rem;letter-spacing:1px}
.rev p{font-size:.94rem;color:var(--text)}
.rev-note{text-align:center;margin-top:30px;font-size:.84rem;color:var(--muted)}

/* call now CTA — dark parallax */
.callnow{position:relative;color:#fff;text-align:center;overflow:hidden}
.callnow .cbg{position:absolute;inset:0;background-size:cover;background-position:center;will-change:transform}
.callnow .cbg::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(13,17,23,.82),rgba(13,17,23,.86))}
.callnow .wrap{position:relative;z-index:2;padding:96px 28px}
.callnow h2{font-family:'Montserrat';font-weight:800;font-size:clamp(1.5rem,3.4vw,2.4rem);color:#fff;margin-bottom:28px;text-transform:none}

/* footer */
footer{position:relative;background:var(--dark);color:rgba(255,255,255,.66);border-top:3px solid var(--blue);overflow:hidden}
footer::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.015) 0 1px,transparent 1px 26px);pointer-events:none}
.foot{position:relative;z-index:1;display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:40px;padding:72px 0 48px}
.foot .logo{height:80px!important;width:auto!important;margin-bottom:22px;filter:drop-shadow(0 4px 14px rgba(0,0,0,.45))}
.foot p,.foot .ci{font-size:.93rem;line-height:1.9;color:rgba(255,255,255,.6)}
.foot .ci b{color:#fff;font-weight:700}
.foot .soc{display:flex;gap:11px;margin:8px 0 24px}
.foot .soc a{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:#fff;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);transition:transform .3s var(--ease),background .25s,box-shadow .3s}
.foot .soc a:hover{background:var(--blue);border-color:var(--blue);transform:translateY(-3px);box-shadow:0 12px 24px rgba(0,109,226,.42)}
.foot h4{font-family:'Montserrat';font-weight:800;font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:var(--blue-l);margin-bottom:24px;padding-bottom:13px;position:relative}
.foot h4::after{content:"";position:absolute;left:0;bottom:0;width:28px;height:2px;background:var(--blue)}
.foot ul{list-style:none}.foot ul li{margin-bottom:13px}
.foot ul a{font-size:.93rem;color:rgba(255,255,255,.64);transition:color .25s,padding .25s}.foot ul a:hover{color:#fff;padding-left:6px}
.foot .map{border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.14);height:200px}.foot .map iframe{width:100%;height:100%;border:0;filter:grayscale(.25) contrast(1.05) brightness(.96)}
.foot-b{position:relative;z-index:1;background:#070a0e;color:rgba(255,255,255,.5);text-align:center;padding:20px;font-size:.82rem;border-top:1px solid rgba(255,255,255,.06)}.foot-b a{color:var(--blue-l)}

/* interior pages: contact info + form */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.info-list{display:flex;flex-direction:column}
.info-row{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--line)}
.info-row .ic{width:46px;height:46px;border-radius:50%;background:var(--off);border:1px solid var(--line);display:grid;place-items:center;color:var(--blue);font-size:1.1rem;flex:none}
.info-row b{font-family:'Montserrat';font-weight:700;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block}
.info-row p{color:var(--ink);font-weight:600;font-size:1.04rem;margin-top:3px}
.form{background:var(--off);border:1px solid var(--line);border-radius:16px;padding:34px}
.form h3{font-size:1.3rem;font-weight:800;text-transform:uppercase;color:var(--ink)}
.form .fg{margin-top:15px}.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form label{font-family:'Montserrat';font-weight:600;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:7px}
.form input,.form textarea{width:100%;padding:13px 15px;border:1px solid #cfd6df;border-radius:8px;font-family:'Inter';font-size:.97rem;background:#fff;transition:.2s}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,109,226,.15)}
.form button{margin-top:18px;width:100%;justify-content:center}
.map-full{border-radius:16px;overflow:hidden;border:1px solid var(--line);height:360px;margin-top:46px}.map-full iframe{width:100%;height:100%;border:0}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}.form .row{grid-template-columns:1fr}}

/* ===================== WooCommerce store ===================== */
.wc-top{padding-top:130px}
.woocommerce-products-header{display:none}
.wc-page .wrap{max-width:var(--w)}
.woocommerce, .woocommerce-page{color:var(--text)}
.woocommerce .woocommerce-breadcrumb{font-family:'Montserrat';font-size:.8rem;color:var(--muted);margin-bottom:26px}
.woocommerce .woocommerce-breadcrumb a{color:var(--blue)}
/* buttons → brand blue pill (kills the default purple) */
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button, .woocommerce #respond input#submit,
.woocommerce a.button.alt, .woocommerce button.button.alt, .woocommerce input.button.alt,
.woocommerce .single_add_to_cart_button, .woocommerce #place_order, .woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.wc-block-components-button, .wp-block-button__link{
  background:linear-gradient(180deg,var(--blue-l),var(--blue))!important;color:#fff!important;
  font-family:'Montserrat',sans-serif!important;font-weight:700!important;text-transform:uppercase;letter-spacing:.04em;
  border:0!important;border-radius:40px!important;padding:14px 32px!important;font-size:.84rem!important;line-height:1.2!important;
  box-shadow:0 8px 22px rgba(0,109,226,.3);transition:transform .35s var(--ease),box-shadow .35s,background .25s!important;cursor:pointer}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce .single_add_to_cart_button:hover, .woocommerce #place_order:hover, .woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover,
.wc-block-components-button:hover{background:#0962c6!important;transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,109,226,.42)!important}
.woocommerce a.added_to_cart{margin-left:10px;color:var(--blue)!important;font-family:'Montserrat';font-weight:700;font-size:.8rem}
/* prices */
.woocommerce div.product p.price, .woocommerce div.product span.price, .woocommerce ul.products li.product .price,
.woocommerce-Price-amount, .woocommerce .cart .product-subtotal .amount, .woocommerce .order-total .amount{color:var(--blue)!important;font-family:'Montserrat',sans-serif;font-weight:800}
.woocommerce div.product p.price{font-size:1.7rem;margin:8px 0 18px}
.woocommerce del .woocommerce-Price-amount{color:var(--muted-2)!important;font-weight:500}
.woocommerce span.onsale{background:var(--blue)!important;border-radius:40px;font-family:'Montserrat';font-weight:700;min-height:auto;line-height:1;padding:8px 14px;top:14px;left:14px}
/* single product */
.single-product div.product{display:grid!important;grid-template-columns:minmax(0,1fr) 1fr;gap:54px;align-items:start;margin:0!important}
.single-product div.product .woocommerce-product-gallery{width:auto!important;max-width:520px;margin:0!important;float:none!important}
.single-product div.product .woocommerce-product-gallery img{border-radius:14px;border:1px solid var(--line)}
.single-product div.product .summary{width:auto!important;margin:0!important;float:none!important}
.single-product div.product .product_title{font-family:'Montserrat',sans-serif;font-weight:800;font-size:clamp(1.5rem,3vw,2.2rem);text-transform:uppercase;color:var(--ink);line-height:1.12;margin-bottom:6px}
.woocommerce div.product .woocommerce-product-rating{margin-bottom:12px}
.woocommerce div.product form.cart{margin:22px 0;display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.woocommerce .quantity input.qty{border:1px solid #cfd6df;border-radius:8px;padding:13px 10px;width:74px;height:auto;font-family:'Inter'}
.woocommerce div.product .product_meta{font-size:.85rem;color:var(--muted);margin-top:18px;border-top:1px solid var(--line);padding-top:16px}
.woocommerce div.product .product_meta a{color:var(--blue)}
.woocommerce div.product .woocommerce-tabs{grid-column:1/-1;margin-top:40px}
.woocommerce div.product .woocommerce-tabs ul.tabs li{border-radius:8px 8px 0 0}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active{border-bottom-color:#fff;background:#fff}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{color:var(--blue)}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{border-bottom-color:var(--line)}
.woocommerce .related.products, .woocommerce .upsells.products{grid-column:1/-1;margin-top:50px}
.woocommerce .related.products>h2, .woocommerce .upsells.products>h2{font-family:'Montserrat';font-weight:800;text-transform:uppercase;font-size:1.5rem;margin-bottom:26px}
/* product grid (archive + related) */
.woocommerce ul.products li.product, .woocommerce-page ul.products li.product{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;padding:0 0 22px!important;text-align:left;transition:transform .4s var(--ease),box-shadow .4s,border-color .4s}
.woocommerce ul.products li.product:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(13,17,23,.13);border-color:var(--blue)}
.woocommerce ul.products li.product a img{margin:0 0 16px!important;border-radius:0}
.woocommerce ul.products li.product .woocommerce-loop-product__title{padding:4px 18px 0;font-family:'Montserrat';font-weight:700;font-size:1rem;color:var(--ink)}
.woocommerce ul.products li.product .price{padding:0 18px;display:block;margin:8px 0 14px}
.woocommerce ul.products li.product .button, .woocommerce ul.products li.product .added_to_cart{margin:0 18px!important;display:inline-block}
.woocommerce .products .star-rating{margin:0 18px 6px}
/* cart */
.woocommerce table.shop_table{border-radius:12px;border:1px solid var(--line);overflow:hidden}
.woocommerce table.shop_table th{font-family:'Montserrat';text-transform:uppercase;font-size:.74rem;letter-spacing:.06em;color:var(--ink);background:var(--off)}
.woocommerce-cart table.cart img{width:64px;border-radius:8px}
.woocommerce .cart-collaterals .cart_totals>h2, .woocommerce-checkout h3, .woocommerce-checkout #order_review_heading{font-family:'Montserrat';font-weight:800;text-transform:uppercase;font-size:1.25rem}
/* forms (checkout/account) */
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea,
.woocommerce-page form .form-row input.input-text, .select2-container--default .select2-selection--single{
  border:1px solid #cfd6df!important;border-radius:8px!important;padding:13px 14px!important;font-family:'Inter';min-height:48px}
.woocommerce form .form-row label{font-family:'Montserrat';font-weight:600;font-size:.78rem;color:var(--muted)}
/* notices */
.woocommerce-message, .woocommerce-info, .woocommerce-error{border-top-color:var(--blue)!important;border-radius:8px}
.woocommerce-message::before, .woocommerce-info::before{color:var(--blue)!important}
.woocommerce .star-rating span::before, .woocommerce p.stars a::before{color:#FBBC05}
@media(max-width:768px){.single-product div.product{grid-template-columns:1fr;gap:28px}.single-product div.product .woocommerce-product-gallery{max-width:100%}}

/* icon sizing in context */
.foot .soc a .ico svg{width:15px;height:15px}
.info-row .ic .ico svg{width:21px;height:21px}
.m18 li .ck .ico svg{width:13px;height:13px;stroke-width:3.2}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
@media(max-width:960px){
  .nav-toggle{display:inline-flex}
  .menu{position:fixed;top:0;right:0;height:100vh;width:min(84vw,330px);background:#fff;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:2px;padding:96px 26px 40px;box-shadow:-12px 0 44px rgba(13,17,23,.18);transform:translateX(105%);transition:transform .42s var(--ease);z-index:130;overflow-y:auto}
  header.open .menu{transform:translateX(0)}
  header.open::before{content:"";position:fixed;inset:0;background:rgba(13,17,23,.45);z-index:120}
  .menu a{width:100%;padding:14px 0;font-size:1rem;border-bottom:1px solid var(--line)}
  .menu a::after{display:none}
  .has-sub{width:100%}.sub-trigger{padding:14px 0;border-bottom:1px solid var(--line)}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding:6px 0 6px 16px;min-width:0}
  .submenu a{font-size:.9rem;padding:9px 0;border-bottom:0}
  .nav-cart{position:relative;z-index:131}
  .svc-grid,.rev-grid{grid-template-columns:1fr 1fr}
  .why .grid,.m18 .grid{grid-template-columns:1fr;gap:40px}
  .why-media{aspect-ratio:16/10;max-height:340px}
  .foot{grid-template-columns:1fr 1fr}
  .m18::before{font-size:7rem}
}
@media(max-width:560px){
  .svc-grid,.rev-grid,.foot{grid-template-columns:1fr}
  .sec{padding:72px 0}
  .hero{min-height:78vh}
  .hero .wrap{padding:120px 22px 70px}
  .logo-track img{height:56px}
  .m18{padding:70px 0}
}
body.nav-open{overflow:hidden}

/* ===================== Shopping experience: cart badge, slide-out cart, payment badges ===================== */
.nav-cart{position:relative}
.nav-cart .js-cart-count{position:absolute;top:-8px;right:-10px;min-width:18px;height:18px;padding:0 4px;background:var(--blue);color:#fff;border:2px solid #fff;border-radius:10px;font-family:'Montserrat';font-weight:800;font-size:.62rem;line-height:1;display:none;align-items:center;justify-content:center}
.nav-cart .js-cart-count.has{display:inline-flex}
/* slide-out cart drawer */
.cart-drawer{position:fixed;inset:0;z-index:200;visibility:hidden}
.cart-drawer.open{visibility:visible}
.cart-drawer-backdrop{position:absolute;inset:0;background:rgba(13,17,23,.5);opacity:0;transition:opacity .4s var(--ease)}
.cart-drawer.open .cart-drawer-backdrop{opacity:1}
.cart-drawer-panel{position:absolute;top:0;right:0;height:100%;width:min(90vw,360px);background:#fff;box-shadow:-18px 0 52px rgba(13,17,23,.28);display:flex;flex-direction:column;transform:translateX(103%);transition:transform .44s var(--ease)}
.cart-drawer.open .cart-drawer-panel{transform:none}
.cart-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--line);flex:none}
.cart-drawer-head h3{font-family:'Montserrat';font-weight:800;text-transform:uppercase;font-size:1.1rem;color:var(--ink);letter-spacing:.02em}
.cart-drawer-close{background:var(--off);border:1px solid var(--line);border-radius:9px;width:36px;height:36px;display:grid;place-items:center;cursor:pointer;color:var(--ink);transition:.2s}
.cart-drawer-close:hover{background:var(--ink);color:#fff}
.cart-drawer-close .ico svg{width:19px;height:19px}
.js-mini-cart{flex:1;overflow-y:auto;padding:4px 22px}
.cart-drawer-pay{flex:none;padding:16px 22px;border-top:1px solid var(--line);background:var(--off)}
.cart-drawer-pay .pay-badges{gap:6px}.cart-drawer-pay .pay{height:24px;min-width:40px}
/* mini-cart (WooCommerce markup) */
.woocommerce-mini-cart.cart_list,ul.cart_list{list-style:none;margin:0;padding:0}
.woocommerce-mini-cart__empty-message{padding:46px 0;text-align:center;color:var(--muted)}
ul.cart_list li,.woocommerce-mini-cart li{position:relative;display:block;padding:16px 36px 16px 0;border-bottom:1px solid var(--line);font-size:.9rem;line-height:1.35}
ul.cart_list li>a:not(.remove),.woocommerce-mini-cart li>a:not(.remove){display:flex;align-items:center;gap:14px;color:var(--ink)!important;font-weight:600;text-decoration:none}
ul.cart_list li img,.woocommerce-mini-cart li img{width:58px!important;height:58px!important;flex:none;object-fit:cover;border-radius:9px;border:1px solid var(--line);float:none!important;margin:0!important}
ul.cart_list li .quantity,.woocommerce-mini-cart li .quantity{display:block;margin:9px 0 0 72px;font-family:'Montserrat';font-weight:700;font-size:.82rem;color:var(--muted)}
ul.cart_list li .quantity .woocommerce-Price-amount,.woocommerce-mini-cart li .quantity .woocommerce-Price-amount{color:var(--blue);font-size:.98rem}
ul.cart_list li a.remove,.woocommerce-mini-cart li a.remove{position:absolute!important;right:0;top:50%;left:auto!important;margin-top:-12px!important;width:24px;height:24px;line-height:22px!important;text-align:center;color:var(--muted-2)!important;border:1px solid var(--line);border-radius:50%;font-size:.9rem;background:#fff}
ul.cart_list li a.remove:hover,.woocommerce-mini-cart li a.remove:hover{background:#e53935;color:#fff!important;border-color:#e53935}
.woocommerce-mini-cart__total{display:flex;justify-content:space-between;align-items:center;padding:18px 0;margin-top:4px;font-family:'Montserrat';font-weight:700;text-transform:uppercase;font-size:.9rem;border-top:2px solid var(--ink)}
.woocommerce-mini-cart__total .woocommerce-Price-amount{color:var(--blue)!important;font-size:1.2rem}
.woocommerce-mini-cart__buttons{display:flex;flex-direction:column;gap:10px;padding:0 0 12px;margin:0}
.woocommerce-mini-cart__buttons a{width:100%;text-align:center;margin:0!important}
.woocommerce-mini-cart__buttons a.checkout{order:-1}
.woocommerce-mini-cart__buttons a.button:not(.checkout){background:#fff!important;color:var(--blue)!important;border:1.5px solid var(--blue)!important;box-shadow:none!important}
/* payment badges */
.pay-badges{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.pay-badges .pay-lbl{font-family:'Montserrat';font-weight:700;font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);margin-right:3px}
.pay{display:inline-flex;align-items:center;justify-content:center;height:26px;min-width:44px;padding:0 9px;background:#fff;border:1px solid var(--line);border-radius:5px;font-family:'Montserrat';font-weight:800;font-size:.6rem;letter-spacing:.02em;box-shadow:0 1px 2px rgba(13,17,23,.05)}
.pay-visa{color:#1a1f71;font-style:italic;letter-spacing:.05em;font-size:.66rem}
.pay-amex{color:#fff;background:#2e77bc;border-color:#2e77bc}
.pay-disc{color:#e36100;font-size:.55rem}
.pay-affirm{color:#4a4af4;text-transform:lowercase;font-size:.78rem}
.pay-mc{gap:0;min-width:46px}
.pay-mc .mc-c{width:15px;height:15px;border-radius:50%;display:inline-block}
.pay-mc .mc-a{background:#eb001b}.pay-mc .mc-b{background:#f79e1b;margin-left:-7px}
.pay svg{flex:none}
.pay-apple{background:#000;color:#fff;border-color:#000;gap:3px;font-size:.66rem}
.pay-apple svg{width:13px;height:13px}
.pay-gpay{gap:3px;color:#5f6368;font-size:.66rem}
.pay-gpay svg{width:15px;height:15px}
.product-pay{margin-top:18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.product-pay .pay-secure{font-family:'Montserrat';font-weight:600;font-size:.72rem;color:var(--muted);display:inline-flex;align-items:center;gap:6px}
.product-pay .pay-secure::before{content:"";width:8px;height:8px;border-radius:50%;background:#16a34a;box-shadow:0 0 0 3px rgba(22,163,74,.18)}
.foot-pay{position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.08);padding:20px 0;display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:9px}
.foot-pay .pay-lbl{color:rgba(255,255,255,.5)}
.foot-companies{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:7px 13px;padding:18px 0;border-top:1px solid rgba(255,255,255,.08);font-family:'Montserrat';font-size:.82rem}
.foot-companies .fc-lbl{color:rgba(255,255,255,.5);font-weight:600;letter-spacing:.02em}
.foot-companies a{color:var(--blue-l);font-weight:700;transition:color .2s}
.foot-companies a:hover{color:#fff}
.foot-companies .fc-dot{color:rgba(255,255,255,.28)}

/* ===================== Larger on desktop ===================== */
@media(min-width:1200px){
  :root{--w:1280px}
  body{font-size:1.05rem}
  .hero{min-height:90vh}
  .hero h1{font-size:clamp(3rem,6.6vw,6rem)}
  .hero .sub{font-size:clamp(1.2rem,2.3vw,1.7rem)}
  .sec{padding:130px 0}
  .sec-head h2{font-size:clamp(2.3rem,4.2vw,3.4rem)}
  .sec-head p{font-size:1.14rem}
  .svc h3{font-size:1.38rem}.svc p{font-size:1.02rem}
  .why-pt h3{font-size:1.3rem}.why-pt p{font-size:1.02rem}
  .m18 li b{font-size:1.3rem}
  .seo h2{font-size:clamp(1.7rem,3.4vw,2.5rem)}.seo p{font-size:1.08rem}
  .btn{padding:16px 42px;font-size:.92rem}
  .hero-logos .logo-track img{height:78px}
  .logo-track img{height:86px}
  .callnow h2{font-size:clamp(1.7rem,3.4vw,2.7rem)}
}

/* ===================== Mobile polish ===================== */
@media(max-width:560px){
  .hero h1{font-size:clamp(2.1rem,9vw,2.9rem)}
  .hero .sub{font-size:1.02rem}
  .sec-head h2,.seo h2{font-size:clamp(1.45rem,6.4vw,2rem)}
  .single-product div.product .product_title{font-size:1.5rem}
  .m18 .title{font-size:1.55rem}
  .product-pay,.pay-badges{justify-content:flex-start}
  .cart-drawer-panel{width:100vw}
  .roadside .wrap,.callnow .wrap{padding-left:22px;padding-right:22px}
  .foot{gap:30px}
}
