/*
Theme Name: Shansen Business Theme
Theme URI: https://www.shansenenterprises.com
Author: BRUsoft (brusoft.in)
Author URI: https://brusoft.in
Description: Custom catalog-mode theme for Shansen Enterprises — industrial fuses, cables, transformers & meters. WooCommerce catalog mode with WhatsApp + email quote CTAs, theme-native JSON-LD schema (@graph), 4-slide hero, brand logo strip and a selectable Location page template with areaServed. Built on the BRUsoft Business Theme master pattern. Deep-blue "VOLTEDGE" palette.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: Proprietary — BRUsoft client theme
Text Domain: shansen
Tags: woocommerce, catalog, business, custom-colors, custom-menu, featured-images
*/

/* ============================================================
   1. DESIGN TOKENS  (override the blue/copper via Customizer-injected vars if needed)
   ============================================================ */
:root{
  --navy-950:#061325; --navy-900:#0a2240; --navy-850:#0c2b50; --navy-800:#103660;
  --navy-700:#16487f; --blue:#2e8bff; --blue-bright:#56a5ff; --copper:#d08a4f;
  --copper-soft:#e7b486; --paper:#f5f8fc; --paper-2:#eef3f9; --white:#ffffff;
  --ink:#0a1c30; --ink-soft:#4d6378; --ink-faint:#7d91a3; --line:#dde6f0;
  --line-dark:rgba(120,170,235,.16); --radius:18px; --maxw:1240px; --ease:cubic-bezier(.2,.7,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'IBM Plex Sans',sans-serif;color:var(--ink);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Archivo',sans-serif;line-height:1.06;letter-spacing:-.02em}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
.mono{font-family:'IBM Plex Mono',monospace}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);font-weight:500;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--copper);display:inline-block}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* placeholder helper */
.ph{position:relative;background:repeating-linear-gradient(45deg,rgba(120,170,235,.10) 0 10px,rgba(120,170,235,.04) 10px 20px);display:grid;place-items:center;color:var(--ink-faint);font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.05em;text-align:center;border:1px dashed rgba(120,170,235,.4)}
.ph.on-dark{background:repeating-linear-gradient(45deg,rgba(120,170,235,.16) 0 10px,rgba(120,170,235,.05) 10px 20px);color:#7e9bba;border-color:rgba(120,170,235,.3)}

/* ============================================================
   2. BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:'Archivo',sans-serif;font-weight:700;font-size:15px;padding:15px 26px;border-radius:12px;cursor:pointer;border:1.5px solid transparent;transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s;letter-spacing:.01em;line-height:1}
.btn svg{width:19px;height:19px;flex:0 0 auto}
.btn-wa{background:#22c55e;color:#06250f;box-shadow:0 10px 26px -10px rgba(34,197,94,.7)}
.btn-wa:hover{transform:translateY(-3px);box-shadow:0 16px 34px -10px rgba(34,197,94,.85);color:#06250f}
.btn-ghost{border-color:rgba(255,255,255,.28);color:#fff;background:rgba(255,255,255,.04)}
.btn-ghost:hover{background:rgba(255,255,255,.1);transform:translateY(-3px);color:#fff}
.btn-dark{background:var(--navy-900);color:#fff}.btn-dark:hover{transform:translateY(-3px);color:#fff}
.btn-mail{background:var(--navy-900);color:#fff}.btn-mail:hover{transform:translateY(-3px);color:#fff}

/* ============================================================
   3. UTILITY BAR + HEADER
   ============================================================ */
.util{background:var(--navy-950);color:#b9cbe0;font-size:13px;border-bottom:1px solid rgba(255,255,255,.06)}
.util .wrap{display:flex;justify-content:space-between;align-items:center;height:42px;flex-wrap:wrap;gap:8px}
.util a{color:#cfe0f2;transition:color .25s}.util a:hover{color:#fff}
.util .left{display:flex;gap:22px;align-items:center}
.util .left span{display:flex;align-items:center;gap:7px}
.util .left svg{width:14px;height:14px;color:var(--blue-bright)}
.util .badge{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.12em;color:var(--copper-soft);text-transform:uppercase}
@media(max-width:820px){.util .left span:nth-child(2){display:none}.util .badge{display:none}}

.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
.site-header.shrink{box-shadow:0 8px 30px -18px rgba(10,28,48,.3)}
.site-header .wrap{display:flex;align-items:center;gap:22px;height:76px}
.brand{display:flex;align-items:center;gap:11px;font-family:'Archivo',sans-serif;font-weight:900;font-size:21px;letter-spacing:-.03em;color:var(--ink);flex:0 0 auto}
.brand .spark{width:34px;height:34px;border-radius:9px;background:linear-gradient(140deg,var(--navy-900),var(--navy-700));display:grid;place-items:center;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.brand .spark svg{width:20px;height:20px;color:var(--blue-bright)}
.brand b{color:var(--blue);font-weight:900}
.brand small{display:block;font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.18em;color:var(--ink-faint);font-weight:500;margin-top:1px}
.brand img{max-height:46px;width:auto}
.main-nav{display:flex;align-items:center;gap:26px;margin-left:6px}
.main-nav a{font-size:14.5px;font-weight:500;color:var(--ink-soft);position:relative;transition:color .25s;white-space:nowrap}
.main-nav a:hover,.main-nav .current-menu-item>a{color:var(--ink)}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--copper);transition:width .3s var(--ease)}
.main-nav a:hover::after{width:100%}
.main-nav ul{list-style:none;display:flex;align-items:center;gap:26px;margin:0;padding:0}

.search{display:flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:0 12px;height:42px;flex:1 1 200px;max-width:300px;margin-left:auto;transition:border-color .25s,box-shadow .25s}
.search:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(46,139,255,.12)}
.search svg{width:17px;height:17px;color:var(--ink-faint);flex:0 0 auto}
.search input{border:0;background:none;outline:0;width:100%;font-family:'IBM Plex Sans',sans-serif;font-size:14px;color:var(--ink)}
.search input::placeholder{color:var(--ink-faint)}
.search button{background:none;border:0;padding:0;cursor:pointer;display:grid;place-items:center}

.head-cta{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.head-cta .btn{padding:12px 18px;font-size:14px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s}
@media(max-width:1060px){.main-nav,.main-nav ul{gap:18px}.search{max-width:200px}}
@media(max-width:940px){
  .search:not(.m-search){display:none}
  .main-nav{position:fixed;inset:0 0 0 auto;width:min(84vw,360px);background:var(--navy-900);flex-direction:column;justify-content:flex-start;gap:8px;transform:translateX(100%);transition:transform .4s var(--ease);padding:90px 30px 30px;align-items:stretch;margin:0}
  .main-nav.open{transform:translateX(0)}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .main-nav a{color:#cfe0f2;font-size:18px;font-family:'Archivo',sans-serif;font-weight:700;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08);display:block}
  .main-nav .m-search{display:flex;margin:0 0 14px;max-width:none}
  .head-cta .btn:not(.burger){display:none}
  .burger{display:flex;z-index:60}
  .burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);background:#fff}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:#fff}
}
@media(min-width:941px){.m-search{display:none}}

/* ============================================================
   4. HERO + SLIDER
   ============================================================ */
.hero{position:relative;background:var(--navy-900);color:#eaf2fb;overflow:hidden;padding:74px 0 84px}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(120,170,235,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,235,.07) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(120% 100% at 80% 0,#000,transparent 75%)}
.hero .glow{position:absolute;width:680px;height:680px;border-radius:50%;background:radial-gradient(circle,rgba(46,139,255,.30),transparent 62%);top:-220px;right:-160px;pointer-events:none}
.hero .glow2{position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(208,138,79,.16),transparent 65%);bottom:-160px;left:-120px;pointer-events:none}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.02fr .98fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(2.3rem,5vw,4rem);font-weight:800;margin:20px 0 20px;color:#fff}
.hero h1 .hi{color:var(--blue-bright);position:relative;white-space:nowrap}
.hero h1 .hi::after{content:"";position:absolute;left:0;right:0;bottom:6px;height:10px;background:rgba(208,138,79,.32);z-index:-1;border-radius:2px}
.hero p.lede{font-size:clamp(1rem,1.6vw,1.14rem);color:#b8cbe0;max-width:540px;margin-bottom:30px}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}
.trust-row{display:flex;gap:28px;flex-wrap:wrap;border-top:1px solid var(--line-dark);padding-top:24px}
.trust-row .t{display:flex;flex-direction:column}
.trust-row .t b{font-family:'Archivo',sans-serif;font-size:1.6rem;font-weight:800;color:#fff;line-height:1}
.trust-row .t span{font-size:12px;color:#8ba6c2;margin-top:6px}

.slider{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 40px 90px -30px rgba(0,0,0,.65);border:1px solid rgba(120,170,235,.2);background:var(--navy-850)}
.slides{display:flex;transition:transform .7s var(--ease)}
.slide{min-width:100%;aspect-ratio:4/3.1;position:relative;display:flex;flex-direction:column;justify-content:flex-end}
.slide .slide-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.slide .ph{position:absolute;inset:0;border:0;font-size:12px}
.slide .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,20,38,.15) 0%,rgba(8,20,38,.35) 45%,rgba(8,20,38,.92) 100%)}
.slide .scontent{position:relative;z-index:2;padding:26px 28px 30px}
.slide .sbrand{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-bright);background:rgba(46,139,255,.16);padding:5px 11px;border-radius:7px;display:inline-block;margin-bottom:14px}
.slide h3{color:#fff;font-size:clamp(1.4rem,3vw,1.9rem);font-weight:800;margin-bottom:8px;line-height:1.05}
.slide p{color:#c4d6ea;font-size:.95rem;max-width:380px;margin-bottom:16px}
.slide .sbtn{display:inline-flex;align-items:center;gap:8px;font-family:'Archivo',sans-serif;font-weight:700;font-size:13.5px;color:#06250f;background:#22c55e;padding:11px 18px;border-radius:10px;transition:transform .25s}
.slide .sbtn:hover{transform:translateY(-2px)}
.slide .sbtn svg{width:16px;height:16px}
.s-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:42px;height:42px;border-radius:50%;background:rgba(8,22,42,.6);border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;cursor:pointer;transition:background .25s;backdrop-filter:blur(4px)}
.s-nav:hover{background:rgba(46,139,255,.7)}
.s-nav svg{width:18px;height:18px;color:#fff}
.s-prev{left:14px}.s-next{right:14px}
.s-dots{position:absolute;bottom:16px;right:24px;z-index:5;display:flex;gap:8px}
.s-dots button{width:9px;height:9px;border-radius:50%;border:0;background:rgba(255,255,255,.4);cursor:pointer;transition:width .3s,background .3s;padding:0}
.s-dots button.active{width:26px;border-radius:5px;background:var(--blue-bright)}
@media(max-width:940px){.hero .wrap{grid-template-columns:1fr;gap:20px}.hero-copy{order:1}.hero-art{order:2}.slide{aspect-ratio:16/11}}
@media(max-width:560px){.hero{padding:48px 0 60px}.trust-row{gap:18px}.s-dots{right:16px}}

/* ============================================================
   5. BRAND MARQUEE (300x150 logos)
   ============================================================ */
.brands{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:30px 0;overflow:hidden}
.brands .wrap{display:flex;align-items:center;gap:26px}
.brands .lbl{font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);max-width:140px;flex:0 0 auto}
.marquee{flex:1;overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee .track{display:flex;gap:26px;width:max-content;animation:slideLogos 22s linear infinite}
.brands:hover .track{animation-play-state:paused}
@keyframes slideLogos{to{transform:translateX(-50%)}}
.logo-box{width:160px;height:80px;border-radius:10px;background:#fff;border:1px solid var(--line);flex:0 0 auto;position:relative;overflow:hidden;display:grid;place-items:center}
.logo-box img{max-width:80%;max-height:64%;object-fit:contain}
.logo-box .ph{position:absolute;inset:0;border-radius:10px;font-size:9.5px;line-height:1.3;padding:6px}
.logo-box .ph b{display:block;font-family:'Archivo',sans-serif;color:var(--navy-800);font-size:12px}

/* ============================================================
   6. SECTIONS
   ============================================================ */
section.block{padding:92px 0}
.sec-head{max-width:680px;margin-bottom:50px}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.85rem);font-weight:800;margin:18px 0 16px}
.sec-head p{color:var(--ink-soft);font-size:1.05rem}
.center{text-align:center;margin-left:auto;margin-right:auto}
.center .eyebrow{justify-content:center}

/* category grid w/ images */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cat{position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;display:flex;flex-direction:column}
.cat:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(10,28,48,.4);border-color:transparent}
.cat .cat-img{aspect-ratio:16/10;position:relative;overflow:hidden}
.cat .cat-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.cat:hover .cat-img img{transform:scale(1.05)}
.cat .cat-img .ph{position:absolute;inset:0;border:0;border-radius:0}
.cat .cat-img .bbadge{position:absolute;top:12px;left:12px;z-index:2;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(10,34,64,.82);padding:5px 10px;border-radius:6px;backdrop-filter:blur(2px)}
.cat .cat-body{padding:24px 26px 26px;display:flex;flex-direction:column;flex:1}
.cat h3{font-size:1.28rem;font-weight:700;margin-bottom:8px}
.cat p{font-size:.95rem;color:var(--ink-soft);margin-bottom:16px;flex:1}
.cat .tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.cat .tags span{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--ink-faint);border:1px solid var(--line);padding:3px 9px;border-radius:20px}
.cat .qlink{font-family:'Archivo',sans-serif;font-weight:700;font-size:14px;color:var(--navy-800);display:inline-flex;align-items:center;gap:7px;transition:gap .3s,color .3s}
.cat .qlink svg{width:15px;height:15px}
.cat:hover .qlink{color:var(--blue);gap:11px}
@media(max-width:900px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cat-grid{grid-template-columns:1fr}}

/* why (dark) */
.why{background:var(--navy-900);color:#eaf2fb;position:relative;overflow:hidden}
.why::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(120,170,235,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,235,.06) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(120% 90% at 0 100%,#000,transparent 70%)}
.why .wrap{position:relative;z-index:2}
.why .sec-head h2{color:#fff}.why .sec-head p{color:#b8cbe0}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.vp{padding:28px 24px;border-radius:var(--radius);background:rgba(255,255,255,.035);border:1px solid rgba(120,170,235,.16);transition:background .35s,transform .35s var(--ease)}
.vp:hover{background:rgba(46,139,255,.1);transform:translateY(-5px)}
.vp .n{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--copper-soft);letter-spacing:.1em;margin-bottom:18px}
.vp .vi{width:46px;height:46px;border-radius:11px;background:rgba(46,139,255,.14);display:grid;place-items:center;margin-bottom:18px}
.vp .vi svg{width:23px;height:23px;color:var(--blue-bright)}
.vp h3{color:#fff;font-size:1.16rem;margin-bottom:9px;font-weight:700}
.vp p{font-size:.92rem;color:#a8bfd6}
@media(max-width:900px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.why-grid{grid-template-columns:1fr}}

/* steps */
.steps{background:var(--paper)}
.step-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:34px 28px;position:relative}
.step .num{font-family:'Archivo',sans-serif;font-weight:900;font-size:3.4rem;color:var(--paper-2);line-height:.8;position:absolute;top:18px;right:22px}
.step .si{width:50px;height:50px;border-radius:12px;background:var(--navy-900);display:grid;place-items:center;margin-bottom:22px}
.step .si svg{width:24px;height:24px;color:var(--blue-bright)}
.step h3{font-size:1.22rem;font-weight:700;margin-bottom:10px}
.step p{color:var(--ink-soft);font-size:.96rem}
@media(max-width:820px){.step-grid{grid-template-columns:1fr;gap:16px}}

/* stats */
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{text-align:center;padding:10px}
.stat b{font-family:'Archivo',sans-serif;font-weight:900;font-size:clamp(2.3rem,4.5vw,3.3rem);color:var(--navy-900);display:block;line-height:1;letter-spacing:-.03em}
.stat b em{color:var(--copper);font-style:normal}
.stat span{font-size:.9rem;color:var(--ink-soft);margin-top:10px;display:block}
@media(max-width:700px){.stats .wrap{grid-template-columns:repeat(2,1fr);gap:34px 16px}}

/* CTA band */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--navy-900),var(--navy-700));color:#fff;border-radius:26px;padding:60px 54px;display:grid;grid-template-columns:1.3fr .7fr;gap:40px;align-items:center}
.cta-band::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(120% 120% at 100% 0,#000,transparent 70%)}
.cta-band .glowc{position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(46,139,255,.4),transparent 60%);top:-160px;right:-100px}
.cta-band>*{position:relative;z-index:2}
.cta-band h2{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:800;margin-bottom:16px}
.cta-band p{color:#bcd2ea;max-width:480px}
.cta-band .cbox{display:flex;flex-direction:column;gap:14px}
.cta-band .btn{justify-content:center;font-size:16px;padding:17px 28px}
.cta-band .hint{font-family:'IBM Plex Mono',monospace;font-size:12px;color:#9fb9d6;text-align:center}
@media(max-width:820px){.cta-band{grid-template-columns:1fr;padding:44px 30px}}

/* ============================================================
   7. WOOCOMMERCE — CATALOG MODE GRID + SINGLE
   ============================================================ */
.wc-wrap{padding:64px 0 92px}
.wc-head{margin-bottom:40px}
.wc-head h1{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:800;margin:14px 0 12px}
.wc-head p{color:var(--ink-soft);max-width:680px}
.woocommerce ul.products,
ul.products{display:grid!important;grid-template-columns:repeat(4,1fr);gap:22px;list-style:none;margin:0;padding:0}
/* fix: ghost empty first product (CSS grid vs WC float) */
.woocommerce ul.products::before,
.woocommerce ul.products::after{display:none!important;content:none!important}
.woocommerce ul.products li.product,
ul.products li.product{width:auto!important;margin:0!important;float:none!important;background:var(--white);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;display:flex;flex-direction:column}
.woocommerce ul.products li.product:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(10,28,48,.4);border-color:transparent}
.woocommerce ul.products li.product a img{margin:0;border-radius:0;aspect-ratio:1/1;object-fit:cover}
.woocommerce ul.products li.product .product-thumb-ph{aspect-ratio:1/1}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:'Archivo',sans-serif!important;font-weight:700;font-size:1.02rem!important;color:var(--ink);padding:16px 18px 4px!important}
.woocommerce ul.products li.product .pbrand{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--copper);padding:0 18px}
.woocommerce ul.products li.product .price{color:var(--ink-soft)!important;font-size:.9rem!important;padding:4px 18px 0;font-family:'IBM Plex Sans',sans-serif!important;font-weight:500}
.product-cta-row{margin-top:auto;padding:16px 18px 18px;display:flex;gap:8px}
.product-cta-row .btn{flex:1;justify-content:center;padding:10px 12px;font-size:12.5px}
@media(max-width:1000px){.woocommerce ul.products,ul.products{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.woocommerce ul.products,ul.products{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.woocommerce ul.products,ul.products{grid-template-columns:1fr}}

/* single product */
.single-product div.product{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:56px 0}
.single-product div.product .woocommerce-product-gallery{margin:0!important;width:auto!important;float:none!important}
.single-product div.product .product_title{font-size:clamp(1.6rem,3vw,2.3rem)!important;font-weight:800;margin-bottom:10px}
.single-product .pbrand-badge{display:inline-block;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--navy-800);padding:5px 11px;border-radius:7px;margin-bottom:16px}
.single-product .woocommerce-product-details__short-description{color:var(--ink-soft);margin-bottom:24px}
.single-quote-box{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:24px;margin:8px 0 24px}
.single-quote-box h4{font-size:1.1rem;margin-bottom:6px}
.single-quote-box p{color:var(--ink-soft);font-size:.95rem;margin-bottom:16px}
.single-quote-box .qbtns{display:flex;gap:12px;flex-wrap:wrap}
.single-product .product_meta{font-size:.9rem;color:var(--ink-faint);border-top:1px solid var(--line);padding-top:18px}
@media(max-width:820px){.single-product div.product{grid-template-columns:1fr;gap:28px;padding:36px 0}}

/* breadcrumb */
.crumb{background:var(--paper);border-bottom:1px solid var(--line);font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-faint)}
.crumb .wrap{padding-top:14px;padding-bottom:14px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.crumb a{color:var(--ink-soft)}.crumb a:hover{color:var(--blue)}
.crumb .sep{opacity:.5}
.crumb .cur{color:var(--copper)}

/* ============================================================
   8. LOCATION TEMPLATE
   ============================================================ */
.lhero{position:relative;background:var(--navy-900);color:#eaf2fb;overflow:hidden;padding:64px 0 70px}
.lhero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(120,170,235,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,235,.07) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(120% 100% at 80% 0,#000,transparent 75%)}
.lhero .glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(46,139,255,.28),transparent 62%);top:-200px;right:-140px}
.lhero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center}
.lhero .pin{display:inline-flex;align-items:center;gap:8px;font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--copper-soft);background:rgba(208,138,79,.13);padding:6px 13px;border-radius:8px;margin-bottom:18px}
.lhero .pin svg{width:14px;height:14px}
.lhero h1{font-size:clamp(2rem,4.4vw,3.4rem);font-weight:800;color:#fff;margin-bottom:18px}
.lhero h1 .hi{color:var(--blue-bright)}
.lhero p{font-size:1.06rem;color:#b8cbe0;max-width:560px;margin-bottom:28px}
.lhero .actions{display:flex;gap:14px;flex-wrap:wrap}
.lhero .mapwrap{position:relative}
.lhero .map{aspect-ratio:4/3.2;border-radius:18px;overflow:hidden;border:1px solid rgba(120,170,235,.22);box-shadow:0 40px 80px -30px rgba(0,0,0,.6)}
.lhero .map iframe{width:100%;height:100%;border:0;display:block}
.lhero .map .ph{position:absolute;inset:0;border:0}
@media(max-width:900px){.lhero .wrap{grid-template-columns:1fr;gap:24px}}

.facts{background:var(--paper);border-bottom:1px solid var(--line);padding:30px 0}
.facts .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.fact{display:flex;gap:13px;align-items:flex-start}
.fact .fi{width:42px;height:42px;border-radius:11px;background:var(--white);border:1px solid var(--line);display:grid;place-items:center;flex:0 0 auto}
.fact .fi svg{width:20px;height:20px;color:var(--navy-800)}
.fact b{font-family:'Archivo',sans-serif;font-size:.98rem;display:block;color:var(--ink)}
.fact span{font-size:.85rem;color:var(--ink-soft)}
@media(max-width:760px){.facts .wrap{grid-template-columns:1fr 1fr;gap:22px}}

.lcontent{display:grid;grid-template-columns:1.4fr .9fr;gap:50px;align-items:start}
.lcontent .prose{color:var(--ink-soft);font-size:1.02rem}
.lcontent .prose h2{font-size:clamp(1.6rem,3vw,2.2rem);color:var(--ink);margin:6px 0 16px}
.lcontent .prose h3{font-size:1.3rem;color:var(--ink);margin:28px 0 12px}
.lcontent .prose p{margin-bottom:16px}
.lcontent .prose ul{margin:8px 0 18px 20px}
.lcontent .prose ul li{margin-bottom:8px}
.aside{position:sticky;top:96px;background:var(--navy-900);color:#eaf2fb;border-radius:var(--radius);padding:28px;box-shadow:0 30px 60px -34px rgba(10,28,48,.5)}
.aside h3{color:#fff;font-size:1.25rem;margin-bottom:8px}
.aside p{color:#b8cbe0;font-size:.94rem;margin-bottom:18px}
.aside .btn{width:100%;justify-content:center;margin-bottom:10px}
@media(max-width:900px){.lcontent{grid-template-columns:1fr;gap:30px}.aside{position:static}}

.pmini{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.pmini a{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:20px;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s}
.pmini a:hover{transform:translateY(-5px);box-shadow:0 24px 50px -30px rgba(10,28,48,.4);border-color:transparent}
.pmini .pi{width:44px;height:44px;border-radius:11px;background:var(--paper);display:grid;place-items:center;margin-bottom:14px}
.pmini .pi svg{width:22px;height:22px;color:var(--navy-800)}
.pmini h4{font-size:1.04rem;margin-bottom:5px}
.pmini span{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--copper)}
@media(max-width:820px){.pmini{grid-template-columns:1fr 1fr}}

.clusters{background:var(--paper)}
.cluster-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cluster-grid a{display:flex;align-items:center;gap:10px;background:var(--white);border:1px solid var(--line);border-radius:12px;padding:15px 16px;font-weight:500;font-size:.96rem;color:var(--ink);transition:border-color .25s,transform .25s,color .25s}
.cluster-grid a:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}
.cluster-grid a svg{width:16px;height:16px;color:var(--copper);flex:0 0 auto}
.cluster-grid a.current{background:var(--navy-900);color:#fff;border-color:transparent}
.cluster-grid a.current svg{color:var(--blue-bright)}
.state-h{font-family:'Archivo',sans-serif;font-weight:800;font-size:1.05rem;margin:26px 0 14px;display:flex;align-items:center;gap:10px}
.state-h::after{content:"";height:1px;flex:1;background:var(--line)}
@media(max-width:820px){.cluster-grid{grid-template-columns:1fr 1fr}}

/* ============================================================
   9. GENERIC PAGE / POST CONTENT
   ============================================================ */
.page-hero{background:var(--navy-900);color:#fff;padding:60px 0 56px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(120,170,235,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,235,.07) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(120% 100% at 80% 0,#000,transparent 75%)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-size:clamp(2rem,4vw,3rem);font-weight:800}
.page-body{padding:64px 0 90px}
.page-body .wrap{max-width:820px}
.page-body h2{font-size:1.7rem;margin:30px 0 14px}
.page-body h3{font-size:1.3rem;margin:24px 0 10px}
.page-body p{color:var(--ink-soft);margin-bottom:16px}
.page-body ul,.page-body ol{margin:0 0 18px 22px;color:var(--ink-soft)}
.page-body img{border-radius:14px;margin:18px 0}
.page-body a{color:var(--blue);text-decoration:underline}

/* ============================================================
   10. FOOTER + FLOAT
   ============================================================ */
.site-footer{background:var(--navy-950);color:#a7bdd4;padding:68px 0 30px;font-size:.92rem}
.f-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.08)}
.site-footer .brand{color:#fff;margin-bottom:16px}
.site-footer .fabout{max-width:300px;color:#8ba6c2;line-height:1.7}
.site-footer h4{color:#fff;font-family:'Archivo',sans-serif;font-size:14px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:18px}
.site-footer ul{list-style:none;display:grid;gap:11px;margin:0;padding:0}
.site-footer ul a{color:#a7bdd4;transition:color .25s,padding .25s}
.site-footer ul a:hover{color:#fff;padding-left:4px}
.fcontact div{display:flex;gap:10px;margin-bottom:13px;align-items:flex-start}
.fcontact svg{width:16px;height:16px;color:var(--blue-bright);flex:0 0 auto;margin-top:3px}
.fcontact a{color:#a7bdd4}.fcontact a:hover{color:#fff}
.f-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;flex-wrap:wrap;gap:12px;font-size:12.5px;color:#7d93aa}
.f-bottom .mono{color:var(--copper-soft)}
@media(max-width:820px){.f-grid{grid-template-columns:1fr 1fr;gap:34px}}
@media(max-width:480px){.f-grid{grid-template-columns:1fr}}

.wa-float{position:fixed;bottom:22px;right:22px;z-index:80;width:58px;height:58px;border-radius:50%;background:#22c55e;display:grid;place-items:center;box-shadow:0 14px 30px -8px rgba(34,197,94,.7);transition:transform .3s var(--ease)}
.wa-float:hover{transform:scale(1.08)}.wa-float svg{width:30px;height:30px;color:#06250f}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #22c55e;animation:ping 2.2s ease-out infinite}
@keyframes ping{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.7);opacity:0}}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
