/* =====================================================================
   Mohan's Precast — base + components  (header/footer/responsive split out)
   ===================================================================== */
:root{
  --primary:#f4b400; --primary-dark:#d99e00; --primary-hover:#caa000;
  --accent-text:#d99e00;
  --bg:#ffffff; --surface:#f6f7f8; --surface-alt:#f0f1f3;
  --dark:#111111; --dark-alt:#1a1a1a;
  --text-heading:#141414; --text-body:#333333; --text-muted:#555555;
  --on-dark:#f5f5f5; --on-dark-muted:#b3b3b3;
  --border:#e3e4e6; --border-dark:#2a2a2a;
  --success:#2e7d32; --danger:#c62828;
  --font-head:'League Spartan','Arial Narrow',sans-serif;
  --font-body:'Azeret Mono',ui-monospace,'Courier New',monospace;   /* live uses Azeret Mono for body copy */
  --font-mono:'Azeret Mono','Courier New',monospace;
  --container:1200px; --pad:1.5rem; --header-h:76px;
  --r-sm:4px; --r-md:8px; --r-lg:16px; --r-pill:999px;
  --sh-sm:0 1px 3px rgba(0,0,0,.08); --sh-md:0 6px 24px rgba(0,0,0,.08); --sh-lg:0 18px 50px rgba(0,0,0,.14);
  --t:.25s ease;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--text-body);background:var(--bg);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:var(--font-head);color:var(--text-heading);line-height:1.15;letter-spacing:-.01em;margin:0 0 .5em;font-weight:800}
h1{font-size:clamp(2.25rem,4.5vw,3.5rem)}
h2{font-size:clamp(1.75rem,3.5vw,2.6rem)}
h3{font-size:1.5rem}
p{margin:0 0 1rem}
a{color:inherit;text-decoration:none;transition:color var(--t)}
img{max-width:100%;display:block}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad)}
.section{padding:6rem 0}
.section--sm{padding:3.5rem 0}
.section--surface{background:var(--surface)}
.section--dark{background:var(--dark);color:var(--on-dark)}
.section--dark h1,.section--dark h2,.section--dark h3{color:#fff}
.text-center{text-align:center}
.mb-0{margin-bottom:0}.mt-2{margin-top:2rem}
.empty-note{text-align:center;color:var(--text-muted);padding:3rem 0}

.eyebrow{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.2em;font-size:.875rem;font-weight:700;color:var(--accent-text);display:inline-block;margin-bottom:.85rem}
.eyebrow--light{color:var(--primary)}
.section-head{max-width:720px;margin:0 auto 3rem}
.lead{font-size:1.125rem;color:var(--text-muted)}

.btn{display:inline-flex;align-items:center;gap:.5rem;justify-content:center;font-family:var(--font-head);font-weight:400;letter-spacing:.05em;text-transform:uppercase;font-size:1.0625rem;padding:.95rem 1.9rem;border-radius:var(--r-sm);border:2px solid transparent;cursor:pointer;transition:all var(--t);line-height:1}
.btn--sm{padding:.65rem 1.25rem;font-size:.8rem}
.btn--primary{background:var(--primary);color:#111;border-color:var(--primary)}
.btn--primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);transform:translateY(-2px)}
.btn--outline{background:transparent;color:var(--text-heading);border-color:var(--text-heading)}
.btn--outline:hover{background:var(--text-heading);color:#fff}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}

/* Hero */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__bg::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,rgba(10,10,10,.85) 0%,rgba(10,10,10,.55) 55%,rgba(10,10,10,.25) 100%)}
.hero__inner{position:relative;z-index:2;padding:6rem 0;width:100%}
.hero h1{color:#fff;font-size:clamp(2.5rem,10vw,8rem);font-weight:900;line-height:1;margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:.07em}
.hero h1 .ln{display:block}
.hero h1 .hl{color:var(--primary)}
.hero h1 .hl-outline{color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.3);text-stroke:1px rgba(255,255,255,.3)}
.hero__sub{font-family:var(--font-mono);font-size:1.25rem;font-weight:700;line-height:1.3;color:#d1d5db;letter-spacing:.01em;max-width:600px;margin-bottom:2rem}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero__stats{display:flex;gap:2.5rem;margin-top:3rem;flex-wrap:wrap}
.hero__stat strong{font-family:var(--font-head);font-size:2.25rem;color:var(--primary);display:block;line-height:1}
.hero__stat span{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:#cfcfcf}

.trustbar{background:var(--dark);padding:1.25rem 0}
.trustbar__inner{display:flex;align-items:center;justify-content:center;gap:2.5rem;flex-wrap:wrap}
.trustbar span{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:#d8d8d8}
.trustbar b{color:var(--primary)}
/* Gold "trusted supplier" strip (matches live site) */
.trustbar--gold{background:var(--primary);padding:.9rem 0}
.trustbar--gold .trustbar__inner{gap:.85rem}
.trustbar--gold .trustbar__shield{font-size:1.1rem;filter:saturate(0) brightness(.2)}
.trustbar--gold .trustbar__text{font-family:var(--font-mono);font-weight:600;color:#111;letter-spacing:.1em;text-transform:uppercase;font-size:.82rem;text-align:center}

.split{display:grid;grid-template-columns:1.05fr 1fr;gap:4rem;align-items:center}
.split__media img{border-radius:var(--r-lg);box-shadow:var(--sh-md);width:100%;height:100%;max-height:565px;object-fit:cover}
/* Forging-the-Future section — exact live layout (outlined heading line, gold-bar lead, gray icon stat cards, USA badge) */
.display-outline{color:transparent;-webkit-text-stroke:1.5px rgba(17,17,17,.25);text-stroke:1.5px rgba(17,17,17,.25)}
.display-head__gold{color:var(--primary)}
.forging-lead{font-family:var(--font-mono);font-size:1.25rem;font-weight:700;line-height:1.45;color:#333;border-left:4px solid var(--primary);padding-left:1.3rem;margin:1.75rem 0 2.5rem;max-width:560px}
.forging-stats{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.forging-stat{background:#f2f2f2;padding:2rem 1.85rem}
.forging-stat__ic{display:inline-flex;color:var(--primary);margin-bottom:1.4rem}
.forging-stat h3{font-family:var(--font-head);font-size:1.5rem;font-weight:700;text-transform:none;letter-spacing:.01em;color:var(--text-heading);margin:0 0 .5rem;line-height:1.1}
.forging-stat p{font-family:var(--font-mono);font-size:.875rem;font-weight:400;color:rgba(51,51,51,.8);margin:0;line-height:1.5}
.split__media{position:relative}
.forging-badge{position:absolute;left:1.5rem;bottom:-1.25rem;background:var(--primary);color:#111;font-family:var(--font-head);font-weight:800;text-transform:uppercase;font-size:1.05rem;line-height:1.18;letter-spacing:.02em;padding:1.05rem 1.35rem}
.checklist{list-style:none;padding:0;margin:1.5rem 0 0}
.checklist li{position:relative;padding:.4rem 0 .4rem 2rem;font-weight:500;color:var(--text-body)}
.checklist li::before{content:'✓';position:absolute;left:0;top:.4rem;color:#111;background:var(--primary);width:1.35rem;height:1.35rem;border-radius:50%;display:grid;place-items:center;font-size:.8rem;font-weight:700}

.grid{display:grid;gap:1.75rem}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}

.card{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:transform var(--t),box-shadow var(--t);display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.card__media{aspect-ratio:4/3;overflow:hidden;background:var(--surface-alt)}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card__media img{transform:scale(1.06)}
.card__body{padding:1.25rem 1.35rem 1.5rem;flex:1;display:flex;flex-direction:column}
.card__tag{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-text);margin-bottom:.5rem}
.card__title{font-size:1.15rem;margin-bottom:.4rem}
.card__desc{font-size:.9rem;color:var(--text-muted);margin-bottom:1rem;flex:1}
.card__link{font-family:var(--font-head);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-heading)}
.card__link:hover{color:var(--accent-text)}
.card__link::after{content:' →'}

.service-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);padding:2rem;transition:var(--t);text-align:center}
.service-card:hover{border-color:var(--primary);box-shadow:var(--sh-md);transform:translateY(-4px)}
.service-card .num{font-family:var(--font-head);font-size:2.5rem;font-weight:900;color:var(--surface-alt);-webkit-text-stroke:1px var(--primary);line-height:1;margin-bottom:.75rem}
.service-card h3{font-size:1.2rem}
.service-card p{font-size:.9rem;color:var(--text-muted);margin:0}

.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.stat-box strong{font-family:var(--font-head);font-size:2.75rem;color:var(--primary);display:block;font-weight:900}
.stat-box span{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}

.page-hero{background:linear-gradient(135deg,#0c0c0d 0%,#1c1d20 60%,#262019 100%);color:#fff;padding:5rem 0 4.5rem;position:relative;text-align:left}
.page-hero h1{color:#9aa0a6;text-transform:uppercase;letter-spacing:.06em;font-size:clamp(2.4rem,5.6vw,4.5rem);line-height:1;font-weight:900;margin:.5rem 0 1.25rem}
.page-hero .eyebrow{color:var(--primary);border-left:3px solid var(--primary);background:rgba(244,180,0,.08);padding:.55rem 1.1rem;border-radius:0 4px 4px 0;display:inline-block}
.page-hero p{color:#cfcfcf;max-width:680px;margin:0}
.page-hero .breadcrumb{margin-top:1.1rem}
.breadcrumb{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.08em;color:var(--on-dark-muted);margin-top:1rem}
.breadcrumb a:hover{color:var(--primary)}

.filters{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:flex-start;margin-bottom:2.5rem}
.filters button{font-family:var(--font-head);font-weight:500;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;padding:.6rem 1.2rem;border:1px solid var(--border);background:#fff;border-radius:4px;cursor:pointer;transition:var(--t)}
.filters button:hover,.filters button.active{background:var(--primary);border-color:var(--primary);color:#111}

.testimonial{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);padding:2rem;height:100%}
.testimonial .stars{color:var(--primary);margin-bottom:.75rem;letter-spacing:2px}
.testimonial p{font-style:italic;color:var(--text-body)}
.testimonial .who{font-family:var(--font-head);font-weight:700;color:var(--text-heading);margin-top:1rem}
.testimonial .who small{display:block;font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);font-weight:400;letter-spacing:.05em}

.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.product-detail__media img{border-radius:var(--r-lg);box-shadow:var(--sh-md);width:100%}
.spec-list{list-style:none;padding:0;margin:1.5rem 0}
.spec-list li{padding:.65rem 0;border-bottom:1px solid var(--border);display:flex;gap:.5rem;font-size:.92rem}
.spec-list li::before{content:'▪';color:var(--primary)}

.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);padding:2.5rem;box-shadow:var(--sh-sm)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.field{margin-bottom:1.25rem}
.field label{display:block;font-family:var(--font-head);font-weight:600;font-size:.85rem;margin-bottom:.4rem;color:var(--text-heading)}
.field input,.field select,.field textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--border);border-radius:var(--r-sm);font-family:var(--font-body);font-size:.95rem;background:#fff;transition:var(--t)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(244,180,0,.18)}
.field textarea{min-height:140px;resize:vertical}
.alert{padding:1rem 1.25rem;border-radius:var(--r-sm);margin-bottom:1.5rem;font-size:.92rem}
.alert--success{background:#e8f5e9;color:#1b5e20;border:1px solid #a5d6a7}
.alert--error{background:#fdecea;color:#922;border:1px solid #f5c6cb}

.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:3rem;align-items:start}
.info-card{display:flex;gap:1rem;padding:1.25rem 0;border-bottom:1px solid var(--border)}
.info-card .ic{flex:0 0 44px;height:44px;background:var(--surface);border-radius:50%;display:grid;place-items:center;color:var(--accent-text);font-size:1.1rem}
.info-card h4{margin:0 0 .2rem;font-size:1rem}
.info-card p,.info-card a{margin:0;color:var(--text-muted);font-size:.92rem}

.cert-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem;text-align:center}
.cert-badge{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);padding:1.75rem 1rem;transition:var(--t)}
.cert-badge:hover{box-shadow:var(--sh-md);border-color:var(--primary)}
.cert-badge .seal{width:60px;height:60px;margin:0 auto .75rem;border-radius:50%;background:var(--dark);color:var(--primary);display:grid;place-items:center;font-family:var(--font-head);font-weight:800;font-size:.8rem}
.cert-badge strong{display:block;font-size:.95rem}
.cert-badge small{color:var(--text-muted);font-size:.8rem}

.resource-item{display:flex;align-items:center;gap:1.25rem;background:#fff;border:1px solid var(--border);border-radius:var(--r-md);padding:1.25rem 1.5rem;margin-bottom:1rem;transition:var(--t)}
.resource-item:hover{box-shadow:var(--sh-sm);border-color:var(--primary)}
.resource-item .doc-ic{flex:0 0 48px;height:48px;background:var(--surface);border-radius:var(--r-sm);display:grid;place-items:center;color:var(--accent-text);font-size:1.3rem}
.resource-item h4{margin:0 0 .15rem;font-size:1.05rem}
.resource-item p{margin:0;font-size:.85rem;color:var(--text-muted)}
.resource-item .btn{margin-left:auto}

.post-content h3{margin-top:1.5rem}

/* ===== Live-match homepage sections ===== */
.display-head{text-transform:uppercase;letter-spacing:.06em;line-height:1;font-size:clamp(2.1rem,5.6vw,4.5rem);font-weight:900}

/* ===== Scroll-reveal animations (match live site motion) ===== */
html.js-reveal .reveal{opacity:0;transform:translateY(34px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1);will-change:opacity,transform}
html.js-reveal .reveal.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){html.js-reveal .reveal{opacity:1!important;transform:none!important;transition:none}}

/* Hero entrance */
.hero .eyebrow{animation:heroUp .8s .1s both}
.hero h1 .ln{animation:heroUp .9s both}
.hero h1 .ln:nth-child(1){animation-delay:.15s}
.hero h1 .ln:nth-child(2){animation-delay:.32s}
.hero h1 .ln:nth-child(3){animation-delay:.49s}
.hero__sub{animation:heroUp .8s .6s both}
.hero__actions{animation:heroUp .8s .75s both}
.hero__scroll{animation:heroUp .8s .95s both}
@keyframes heroUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.hero .eyebrow,.hero h1 .ln,.hero__sub,.hero__actions,.hero__scroll{animation:none}}

/* Hero scroll hint */
.hero__scroll{margin-top:2.5rem;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.25em;color:#cfcfcf;text-transform:uppercase;display:flex;align-items:center;gap:.6rem}
.hero__scroll span{display:inline-block;animation:bob 1.6s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* Gold trust bar — pins to the top of the homepage on scroll (navbar hides) */
.goldbar{background:var(--primary);border-top:2px solid #111;border-bottom:2px solid #111;position:sticky;top:0;z-index:90}
body.gb-stuck .goldbar{box-shadow:0 6px 16px rgba(0,0,0,.18)}
.goldbar__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;min-height:60px;padding:.6rem 1.5rem}
.goldbar__item{font-family:var(--font-head);text-transform:uppercase;font-weight:400;letter-spacing:.02em;color:#111;display:flex;align-items:center;gap:.5rem;font-size:1rem}
.goldbar__item .ic{display:inline-flex;align-items:center;color:#111}
.goldbar__cta{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;font-weight:700;letter-spacing:.02em;color:#111;text-decoration:underline;text-underline-offset:3px}
.goldbar__cta:hover{color:#000}

/* Intro stat pair + USA badge */
.stat-pair{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:2rem;border-top:1px solid var(--border);padding-top:1.75rem}
.stat-pair__item strong{font-family:var(--font-head);font-size:1.5rem;color:var(--text-heading);display:block;margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.02em}
.stat-pair__item span{font-size:.88rem;color:var(--text-muted)}
.intro-media{position:relative}
.usa-badge{position:absolute;bottom:-26px;left:-26px;width:130px;height:130px;border-radius:50%;background:var(--primary);color:#111;
  display:grid;place-content:center;text-align:center;font-family:var(--font-head);font-weight:900;font-size:2rem;line-height:1;
  box-shadow:var(--sh-lg);border:4px solid #fff}
.usa-badge small{display:block;font-size:.6rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-top:.25rem;line-height:1.2}

/* Core Services (dark) */
.services-dark .eyebrow{color:var(--primary)}
.svc-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.svc-head h2{color:#fff;margin:0}
.svc-divider{height:1px;background:var(--border-dark);margin:2.5rem 0}
.svc-card{display:flex;flex-direction:column;background:#16181d;border:1px solid var(--border-dark);border-radius:var(--r-md);overflow:hidden;transition:var(--t)}
.svc-card:hover{transform:translateY(-5px);border-color:var(--primary)}
.svc-card__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.svc-card__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05);transition:filter .4s,transform .5s}
.svc-card:hover .svc-card__media img{filter:grayscale(0);transform:scale(1.05)}
.svc-card__num{position:absolute;top:1rem;left:1rem;font-family:var(--font-head);font-weight:900;font-size:1.6rem;color:var(--primary)}
.svc-card__body{padding:1.5rem}
.svc-card__body h3{font-family:var(--font-head);font-size:1.875rem;font-weight:800;text-transform:uppercase;color:#fff;margin-bottom:.65rem;letter-spacing:.02em;line-height:1.1}
.svc-card__body p{font-family:var(--font-mono);font-size:.84rem;color:#9ca3af;margin-bottom:1rem;line-height:1.6}
.svc-card__link{font-family:var(--font-head);font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.05em;color:var(--primary)}

/* Portfolio cards */
.proj-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:var(--r-md);overflow:hidden;transition:var(--t)}
.proj-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.proj-card__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--surface-alt)}
.proj-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.proj-card:hover .proj-card__media img{transform:scale(1.05)}
.proj-card__tag{position:absolute;top:1rem;left:1rem;background:var(--primary);color:#111;font-family:var(--font-mono);font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .65rem;border-radius:3px;z-index:2}
.proj-card__count{position:absolute;bottom:1rem;right:1rem;background:rgba(17,17,17,.78);color:#fff;font-family:var(--font-mono);font-size:.7rem;font-weight:600;padding:.25rem .55rem;border-radius:20px;display:inline-flex;align-items:center;gap:.3rem;z-index:2}
/* Building New York header — two columns (heading left, description right) like live */
.bny-head{display:grid;grid-template-columns:1.5fr 1fr;align-items:end;gap:2.5rem;margin-bottom:3rem}
.bny-head .display-head{margin:0}
.bny-head__sub{font-family:var(--font-mono);font-size:1rem;color:var(--text-muted);margin:0 0 .55rem;line-height:1.6}
@media(max-width:768px){.bny-head{grid-template-columns:1fr;gap:1rem}}
.proj-card__body{padding:1.35rem 1.5rem 1.6rem;border-left:3px solid var(--primary)}
.proj-card__body h3{font-size:1.2rem;text-transform:uppercase;letter-spacing:.01em;margin-bottom:.6rem}
.proj-card__loc{font-size:.88rem;color:var(--text-muted);margin-bottom:.35rem}
.proj-card__loc span{font-weight:600;color:var(--text-heading)}
.proj-card__desc{font-size:.85rem;color:var(--text-muted);margin-bottom:1rem}
.proj-card__link{font-family:var(--font-head);font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.05em;color:var(--accent-text)}
.proj-card__link:hover{color:var(--primary)}

/* Why choose + agencies */
/* Why Choose Mohan's (dark) — exact live layout: centered heading + gold rule, 4 icon cards in a bordered grid */
.why-choose .display-head{color:#fff}
.why-choose__head{margin-bottom:3.5rem}
.why-choose__rule{display:block;width:120px;height:4px;background:var(--primary);margin:1.5rem auto 0;border-radius:2px}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(255,255,255,.12)}
.why-card{text-align:left;padding:2.5rem 2rem;border-right:1px solid rgba(255,255,255,.12)}
.why-card:last-child{border-right:0}
.why-card__ic{display:inline-flex;color:var(--primary);margin-bottom:1.75rem}
.why-card h3{font-family:var(--font-head);font-size:1.25rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:#fff;margin:0 0 .85rem;line-height:1.15}
.why-card p{font-family:var(--font-mono);font-size:.875rem;color:#9ca3af;margin:0;line-height:1.6}
.why-choose .agencies-title{text-align:center;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;color:#9ca3af;margin:3.5rem 0 0}
/* Agencies — right-to-left infinite scrolling marquee, logos fit inside their boxes */
.agencies-marquee{overflow:hidden;margin-top:1.75rem;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.agencies-track{display:flex;gap:1.25rem;width:max-content;animation:agencies-scroll 40s linear infinite}
.agencies-marquee:hover .agencies-track{animation-play-state:paused}
.agencies__logo{flex:0 0 auto;width:175px;height:110px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:1.4rem;overflow:hidden}
.agencies__logo img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}
@keyframes agencies-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.agencies-track{animation:none}}

/* Gold CTA (Ready to build) */
.cta-gold{position:relative;background:var(--primary);padding:5rem 0;text-align:center;overflow:hidden}
.cta-gold__inner{position:relative;z-index:2;max-width:760px}
.cta-gold h2{color:#111;margin:0 0 1.25rem}
.cta-gold p{color:#3a2f00;max-width:560px;margin:0 auto 2rem;font-size:1.05rem}
.cta-gold__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.usa-badge--cta{position:absolute;top:2rem;left:2rem;bottom:auto;width:104px;height:104px;background:#fff;color:#111;border-color:var(--primary)}
.btn--dark{background:#111;color:#fff;border-color:#111}
.btn--dark:hover{background:#000;border-color:#000;transform:translateY(-2px)}
.btn--outline-dark{background:transparent;color:#111;border-color:#111}
.btn--outline-dark:hover{background:#111;color:#fff}

/* Products page hero + cards */
.page-hero--products{background:linear-gradient(135deg,#0c0c0d 0%,#1c1d20 60%,#262019 100%);padding:5rem 0 4.5rem;text-align:left}
.page-hero--products .container{max-width:var(--container)}
.eyebrow--boxed{border-left:3px solid var(--primary);background:rgba(244,180,0,.08);padding:.55rem 1.1rem;border-radius:0 4px 4px 0}
.page-hero__display{font-size:clamp(2.4rem,5.6vw,4.5rem);text-transform:uppercase;letter-spacing:.06em;line-height:1;color:#9aa0a6;font-weight:900;margin:.5rem 0 1.25rem}
/* Centered page-hero variant (Coping Stone) — Title Case, centered, no eyebrow */
.page-hero--center{text-align:center}
.page-hero--center .page-hero__display{text-transform:none;letter-spacing:0}
.page-hero--center p{margin-left:auto;margin-right:auto;max-width:680px}
.cs-what__head{font-size:clamp(1.9rem,3.6vw,3rem)}
.cs-keyfeatures h3{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.02em;margin-bottom:1.1rem;font-size:1.5rem;color:var(--text-heading)}
.page-hero--products p{margin:0;max-width:680px}
.filter-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:var(--text-muted);margin-bottom:.85rem}
.prod-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:var(--t)}
.prod-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);border-color:var(--primary)}
.prod-card__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--surface-alt)}
.prod-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.prod-card:hover .prod-card__media img{transform:scale(1.06)}
.prod-card__tag{position:absolute;top:.85rem;left:.85rem;background:rgba(17,17,17,.82);color:#fff;font-family:var(--font-mono);font-size:.6rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.28rem .6rem;border-radius:3px}
.prod-card__body{padding:1.15rem 1.25rem 1.4rem;flex:1;display:flex;flex-direction:column}
.prod-card__body h3{font-size:1.5rem;font-weight:700;text-transform:uppercase;letter-spacing:.01em;margin-bottom:.6rem}
.prod-card__meta{font-size:.8rem;color:var(--text-muted);margin:0 0 .25rem}
.prod-card__meta span{font-weight:600;color:var(--text-heading)}
.prod-card__link{margin-top:.85rem;font-family:var(--font-head);font-weight:700;text-transform:uppercase;font-size:.78rem;letter-spacing:.05em;color:var(--accent-text)}
.custom-cta p{color:#cfcfcf;max-width:560px;margin:.5rem auto 1.75rem}

/* Product detail page */
.pd-back{display:inline-block;font-family:var(--font-head);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;color:var(--text-heading);margin-bottom:2rem}
.pd-back:hover{color:var(--accent-text)}
.pd-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start}
.pd-media{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-md);background:var(--surface-alt);max-width:80%}
.pd-media img{width:100%;display:block}
.pd-tag{position:absolute;top:1.25rem;left:1.25rem;background:var(--primary);color:#111;font-family:var(--font-mono);font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.35rem .75rem;border-radius:3px}
.pd-info{padding-left:1.5rem;border-left:4px solid var(--primary)}
.pd-name{font-size:clamp(2.1rem,4vw,3.4rem);text-transform:uppercase;letter-spacing:.02em;line-height:1.02;color:#9aa0a6;font-weight:900;margin:0 0 .4rem}
.pd-cat{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.82rem;margin-bottom:1.6rem}
.pd-specs{border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-bottom:1.6rem}
.pd-spec{display:flex;gap:1rem;align-items:flex-start;padding:.95rem 1.25rem;background:var(--surface)}
.pd-spec:not(:last-child){border-bottom:1px solid var(--border)}
.pd-spec__ic{color:var(--accent-text);font-size:1.1rem;line-height:1.4}
.pd-spec strong{display:block;font-family:var(--font-head);text-transform:uppercase;font-size:.8rem;letter-spacing:.04em;color:var(--text-heading);margin-bottom:.15rem}
.pd-spec p{margin:0;color:var(--text-muted);font-size:.92rem}
.pd-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.9rem}
.pd-why h3{font-size:1.15rem;text-transform:uppercase;letter-spacing:.02em;margin-bottom:.9rem}
@media(max-width:768px){.pd-grid{grid-template-columns:1fr;gap:2rem}.pd-info{padding-left:1rem;border-left-width:3px}.pd-media{max-width:100%}}
.pd-media{overflow:hidden}
.pd-media img{transition:transform .6s cubic-bezier(.22,.61,.36,1)}
.pd-media:hover img{transform:scale(1.05)}

/* ===== Polished hover effects (zoom / fade / lift) ===== */
.card__media,.prod-card__media,.proj-card__media,.svc-card__media{position:relative;overflow:hidden}
.card__media::after,.prod-card__media::after,.proj-card__media::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(244,180,0,.28),rgba(17,17,17,.05) 55%,transparent);opacity:0;transition:opacity .45s ease;pointer-events:none;z-index:1}
.card:hover .card__media::after,.prod-card:hover .prod-card__media::after,.proj-card:hover .proj-card__media::after{opacity:1}
.card__media img,.prod-card__media img,.proj-card__media img{transition:transform .6s cubic-bezier(.22,.61,.36,1)}
.card:hover .card__media img,.prod-card:hover .prod-card__media img,.proj-card:hover .proj-card__media img,.svc-card:hover .svc-card__media img{transform:scale(1.09)}
.card,.prod-card,.proj-card,.svc-card,.service-card,.why-card,.cert-badge,.resource-item{transition:transform .3s cubic-bezier(.22,.61,.36,1),box-shadow .3s ease,border-color .3s ease}
.card__link,.prod-card__link,.proj-card__link,.svc-card__link{display:inline-block;transition:color .25s ease,transform .25s ease,letter-spacing .25s ease}
.card:hover .card__link,.prod-card:hover .prod-card__link,.proj-card:hover .proj-card__link,.svc-card:hover .svc-card__link{transform:translateX(4px)}
.prod-card__tag,.proj-card__tag{transition:transform .3s ease}
.prod-card:hover .prod-card__tag,.proj-card:hover .proj-card__tag{transform:translateY(-3px)}
/* agency logos pop on hover */
.agencies__logo{transition:transform .3s ease,filter .3s ease,opacity .3s ease,box-shadow .3s ease}
.agencies__logo:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
/* buttons: subtle lift already; add press */
.btn{transition:all .25s cubic-bezier(.22,.61,.36,1)}
.btn:active{transform:translateY(0) scale(.98)}

/* ===== Project detail page + carousel ===== */
.pj-head{border-left:4px solid var(--primary);padding-left:1.5rem;margin:1.5rem 0 2.25rem}
.pj-head .eyebrow{color:var(--accent-text);margin-bottom:.35rem}
.pj-name{font-size:clamp(2.1rem,5vw,4.4rem);text-transform:uppercase;letter-spacing:.02em;line-height:1;color:#9aa0a6;font-weight:900;margin:0}
.pj-info{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:2.75rem}
.pj-info__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:1.2rem;display:flex;gap:.85rem;align-items:flex-start;transition:transform .3s ease,box-shadow .3s ease}
.pj-info__card:hover{transform:translateY(-3px);box-shadow:var(--sh-sm)}
.pj-info__card .fic{flex:0 0 36px;height:36px;border-radius:50%;border:1px solid var(--border);display:grid;place-items:center;color:var(--accent-text);background:#fff}
.pj-info__card strong{display:block;font-family:var(--font-head);text-transform:uppercase;font-size:.78rem;letter-spacing:.04em;margin-bottom:.2rem;color:var(--text-heading)}
.pj-info__card p{margin:0;color:var(--text-muted);font-size:.9rem;line-height:1.45}
.pj-block{margin-bottom:2.75rem}
.pj-block h2{margin-bottom:1.1rem}
.pj-overview{color:var(--text-muted);max-width:840px;font-size:1.05rem;margin:0}
.carousel{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-md);background:#111;width:100%;max-width:80%;margin-left:auto;margin-right:auto}
.carousel__viewport{overflow:hidden}
.carousel__track{display:flex;transition:transform .55s cubic-bezier(.22,.61,.36,1)}
.carousel__slide{min-width:100%;aspect-ratio:16/9;background:#0d0d0d}
.carousel__slide img{width:100%;height:100%;object-fit:cover;object-position:center}
.carousel__nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;border:0;background:rgba(255,255,255,.92);color:#111;font-size:1.6rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .2s,transform .2s;z-index:2;box-shadow:var(--sh-sm)}
.carousel__nav:hover{background:var(--primary)}
.carousel__nav--prev{left:1rem}.carousel__nav--next{right:1rem}
.carousel__nav:active{transform:translateY(-50%) scale(.92)}
.carousel__count{position:absolute;bottom:1rem;right:1rem;background:rgba(17,17,17,.72);color:#fff;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;padding:.28rem .6rem;border-radius:3px;z-index:2}
.carousel__dots{position:absolute;bottom:1.1rem;left:50%;transform:translateX(-50%);display:flex;gap:.45rem;z-index:2}
.carousel__dots button{width:8px;height:8px;border-radius:50%;border:0;background:rgba(255,255,255,.55);cursor:pointer;padding:0;transition:all .25s}
.carousel__dots button.active{background:var(--primary);width:22px;border-radius:4px}
.carousel__slide{cursor:zoom-in}
.carousel__zoom{position:absolute;top:1rem;right:1rem;width:42px;height:42px;border-radius:50%;border:0;background:rgba(17,17,17,.6);color:#fff;cursor:pointer;display:grid;place-items:center;transition:background .2s,transform .2s,opacity .2s;z-index:3;opacity:.85}
.carousel__zoom:hover{background:var(--primary);color:#111;transform:scale(1.1);opacity:1}
/* Full-screen image viewer */
.cfs{position:fixed;inset:0;background:rgba(8,8,8,.96);display:none;align-items:center;justify-content:center;z-index:9999;opacity:0;transition:opacity .3s ease}
.cfs.open{display:flex;opacity:1}
.cfs__stage{max-width:92vw;max-height:88vh;display:flex;align-items:center;justify-content:center}
.cfs__img{max-width:92vw;max-height:88vh;width:auto;height:auto;object-fit:contain;border-radius:6px;box-shadow:0 24px 70px rgba(0,0,0,.7);opacity:0;transform:scale(.96);transition:opacity .35s ease,transform .35s cubic-bezier(.22,.61,.36,1)}
.cfs__img--in{opacity:1;transform:scale(1)}
.cfs__close{position:absolute;top:1.25rem;right:1.5rem;width:48px;height:48px;border-radius:50%;border:0;background:rgba(255,255,255,.12);color:#fff;font-size:1.9rem;line-height:1;cursor:pointer;transition:.2s;z-index:2}
.cfs__close:hover{background:var(--primary);color:#111;transform:rotate(90deg)}
.cfs__nav{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;border:0;background:rgba(255,255,255,.12);color:#fff;font-size:2rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .2s,transform .2s;z-index:2}
.cfs__nav:hover{background:var(--primary);color:#111}
.cfs__nav:active{transform:translateY(-50%) scale(.9)}
.cfs__nav--prev{left:1.5rem}.cfs__nav--next{right:1.5rem}
.cfs__count{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);color:#fff;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.08em;background:rgba(255,255,255,.1);padding:.32rem .85rem;border-radius:20px}
@media(max-width:560px){.cfs__nav{width:44px;height:44px;font-size:1.55rem}.cfs__nav--prev{left:.5rem}.cfs__nav--next{right:.5rem}.cfs__close{top:.6rem;right:.6rem}}
@media(max-width:992px){.carousel{max-width:92%}}
@media(max-width:768px){.pj-info{grid-template-columns:1fr 1fr}.carousel__slide{aspect-ratio:4/3}.carousel{max-width:100%}}
@media(max-width:480px){.pj-info{grid-template-columns:1fr}}

/* Services page */
.svc-detail-list{display:flex;flex-direction:column;gap:0}
.svc-detail{display:grid;grid-template-columns:120px 1fr;gap:2rem;padding:2.5rem 0;border-bottom:1px solid var(--border);align-items:start}
.svc-detail:first-child{padding-top:0}
.svc-detail__num{font-family:var(--font-head);font-weight:900;font-size:3.5rem;color:var(--surface-alt);-webkit-text-stroke:1px var(--primary);line-height:1}
.svc-detail__content h2{text-transform:uppercase;letter-spacing:.02em;font-size:1.6rem;margin-bottom:.5rem}
.svc-detail__sub{font-family:var(--font-mono);font-size:.85rem;color:var(--accent-text);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.85rem}
.svc-detail__content>p:last-child{color:var(--text-muted);margin:0}
.grid--5{grid-template-columns:repeat(5,1fr)}
.process-grid{counter-reset:step}
.process-step{text-align:center;padding:1rem .5rem}
.process-step__num{width:56px;height:56px;margin:0 auto 1rem;border-radius:50%;border:2px solid var(--primary);color:var(--primary);display:grid;place-items:center;font-family:var(--font-head);font-weight:900;font-size:1.3rem}
.process-step h3{color:#fff;font-size:1.05rem;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem}
.process-step p{color:#b3b3b3;font-size:.84rem;margin:0}
.checklist--2col{display:grid;grid-template-columns:1fr 1fr;gap:0 1.5rem}

/* Service blocks (alternating image + content) */
.svc-row{display:grid;grid-template-columns:1fr 1.05fr;gap:3.5rem;align-items:center;padding:3.5rem 0;border-bottom:1px solid var(--border)}
.svc-row:first-child{padding-top:0}
.svc-row:last-child{border-bottom:0}
.svc-row--flip .svc-row__media{order:2}
.svc-row__media{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-md);background:var(--surface-alt)}
.svc-row__media img{width:100%;display:block;transition:transform .6s cubic-bezier(.22,.61,.36,1)}
.svc-row__media:hover img{transform:scale(1.05)}
.svc-row__content .eyebrow{margin-bottom:.5rem}
.svc-row__content h2{font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:.6rem}
.svc-row__sub{font-family:var(--font-mono);font-size:.85rem;color:var(--accent-text);text-transform:uppercase;letter-spacing:.03em;line-height:1.5;margin-bottom:1.1rem}
.svc-row__desc{color:var(--text-muted);margin-bottom:1.5rem}
.svc-incl{display:grid;gap:1rem}
.svc-incl__card{background:var(--surface);border-left:3px solid var(--primary);border-radius:0 var(--r-md) var(--r-md) 0;padding:1.1rem 1.3rem;transition:box-shadow .3s ease,transform .3s ease}
.svc-incl__card:hover{box-shadow:var(--sh-sm);transform:translateX(3px)}
.svc-incl__card h4{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.04em;font-size:.85rem;margin-bottom:.4rem;color:var(--text-heading)}
.svc-incl__card p{margin:0;font-size:.88rem;color:var(--text-muted);line-height:1.6}

/* Why-choose media + USA badge */
.why-media{position:relative}
.why-media img{border-radius:var(--r-lg);box-shadow:var(--sh-md);width:100%;height:100%;object-fit:cover}
.why-usa{position:absolute;left:1.25rem;bottom:1.25rem;right:1.25rem;background:rgba(17,17,17,.86);backdrop-filter:blur(2px);border-radius:var(--r-md);padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem}
.why-usa img{width:54px;height:auto;flex:0 0 54px;box-shadow:none;border-radius:0}
.why-usa strong{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.04em;color:#fff;font-size:1rem}
.why-usa span{color:#cfcfcf;font-size:.82rem}
@media(max-width:768px){.svc-row{grid-template-columns:1fr;gap:1.75rem;padding:2.5rem 0}.svc-row--flip .svc-row__media{order:0}}

/* ===== Expedited Services page (exact live match) ===== */
.exp-hero{background:linear-gradient(135deg,#0b0b0c 0%,#15110a 55%,#241b09 100%)}
.exp-hero__sub{font-family:var(--font-mono);font-size:1.05rem;font-weight:700;line-height:1.5;color:rgba(255,255,255,.8);letter-spacing:.01em;max-width:680px;margin:0}

/* section headings + subtitles */
.exp-h2{font-family:var(--font-head);font-weight:900;text-transform:uppercase;letter-spacing:.05em;line-height:1.05;font-size:clamp(2rem,4.4vw,3rem);color:#111;margin:0 0 1rem}
.exp-h2--light{color:#fff}
.exp-h2--bar{border-left:5px solid var(--primary);padding-left:1.1rem;margin-bottom:.7rem}
.exp-sub{font-family:var(--font-mono);font-size:1rem;line-height:1.6;color:#666;margin:0 0 2.5rem;max-width:780px}
.exp-sub.text-center{margin-left:auto;margin-right:auto}
.exp-dark .exp-sub{color:rgba(255,255,255,.8)}

/* §2 intro + key benefit */
.exp-sec{background:#fff}
.exp-intro{text-align:left}
.exp-intro p{font-family:var(--font-mono);font-size:1.125rem;line-height:1.625;letter-spacing:.02em;color:#333;margin:0 0 1.5rem;max-width:920px}
.exp-keybenefit{margin-top:.6rem;background:#f5f5f5;border-left:4px solid var(--primary);padding:1.6rem 1.9rem;text-align:left}
.exp-keybenefit__label{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.02em;font-size:1rem;font-weight:400;color:#111;margin-bottom:.5rem}
.exp-keybenefit p{font-family:var(--font-mono);margin:0;color:#333;font-size:1rem;line-height:1.65}

/* §3 shorter-lead-time banner */
.exp-banner{background:rgb(244,180,0);padding:2.2rem 0;overflow:hidden;text-align:center}
.exp-banner h2{margin:0;font-family:var(--font-head);font-weight:900;text-transform:uppercase;letter-spacing:.04em;line-height:1.05;color:#111;font-size:clamp(1.4rem,5.4vw,4.4rem);white-space:nowrap}

/* §4 when you need (dark section, flat white cards, gold line icons) */
.exp-dark{background:#111}
.exp-card-grid{margin-top:.5rem}
.exp-card{background:#fff;padding:2.4rem 2rem;text-align:left;transition:transform .35s cubic-bezier(.22,.61,.36,1),box-shadow .35s ease}
.exp-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(0,0,0,.35)}
.exp-card__ic{display:inline-flex;color:var(--accent-text);margin-bottom:1.2rem;transition:transform .35s ease}
.exp-card:hover .exp-card__ic{transform:scale(1.08)}
.exp-card h3{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.02em;font-weight:400;font-size:1.15rem;margin-bottom:.7rem;color:#111;line-height:1.3}
.exp-card p{font-family:var(--font-mono);margin:0;color:#333;font-size:.95rem;line-height:1.6}

/* §5 additional costs — numbered list + gray panel */
.exp-cost-layout{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.exp-cost-list{display:grid;gap:1.7rem}
.exp-cost-item{display:flex;gap:1.1rem;align-items:flex-start}
.exp-cost-item__num{flex:none;width:40px;height:40px;border-radius:50%;background:var(--primary);color:#111;font-family:var(--font-head);font-weight:800;font-size:1.15rem;display:flex;align-items:center;justify-content:center}
.exp-cost-item h3{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.02em;font-weight:400;font-size:1.1rem;margin-bottom:.35rem;color:#111}
.exp-cost-item p{font-family:var(--font-mono);margin:0;color:#444;font-size:.92rem;line-height:1.6}
.exp-cost-panel{background:#f3f3f3;border-left:5px solid var(--primary);padding:2rem 2.2rem}
.exp-cost-panel__lead{font-family:var(--font-mono);color:#333;font-size:1rem;line-height:1.7;margin:0 0 1.5rem}
.exp-cost-panel__lead strong{color:#111;font-weight:700}
.exp-cost-panel__box{background:#fff;padding:1.6rem 1.8rem;margin-bottom:1.3rem}
.exp-cost-panel__box h4{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.03em;font-size:.95rem;color:#111;margin-bottom:1rem;font-weight:700}
.exp-cost-panel__box ul{list-style:none;padding:0;margin:0;display:grid;gap:.7rem}
.exp-cost-panel__box li{font-family:var(--font-mono);position:relative;padding-left:1.2rem;color:#444;font-size:.92rem}
.exp-cost-panel__box li::before{content:"•";position:absolute;left:0;color:var(--primary);font-weight:700}
.exp-cost-panel__note{font-family:var(--font-mono);margin:0;color:#777;font-size:.9rem;font-style:italic;line-height:1.6}

/* §6 disclaimer (white box on dark) */
.exp-disclaimer{max-width:1000px;margin:0 auto;background:#fff;padding:2.6rem 2.8rem}
.exp-disclaimer__head{display:flex;align-items:center;gap:.9rem;margin-bottom:1.2rem;color:var(--accent-text)}
.exp-disclaimer__head h2{margin:0;font-family:var(--font-head);font-weight:900;text-transform:uppercase;letter-spacing:.03em;font-size:1.7rem;color:#111}
.exp-disclaimer__intro{font-family:var(--font-mono);color:#444;margin-bottom:1.4rem}
.exp-disclaimer__list{list-style:none;padding:0;margin:0;display:grid;gap:1.1rem}
.exp-disclaimer__list li{font-family:var(--font-mono);position:relative;padding-left:2.2rem;color:#444;font-size:.95rem;line-height:1.6}
.exp-disclaimer__list li::before{content:"!";position:absolute;left:0;top:0;width:24px;height:24px;border:2px solid var(--primary);border-radius:50%;color:var(--accent-text);font-weight:800;font-size:.8rem;display:flex;align-items:center;justify-content:center}
.exp-disclaimer__foot{font-family:var(--font-mono);margin:1.6rem 0 0;padding-top:1.4rem;border-top:1px solid var(--border);color:#666;font-style:italic}

/* §7 request — gray contact cards + dark form panel */
.exp-contact-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2.5rem}
.exp-contact-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.35rem;background:#f3f3f3;padding:2.2rem 1.5rem;color:#111;text-decoration:none;transition:transform .3s ease,box-shadow .3s ease}
.exp-contact-card:hover{transform:translateY(-5px);box-shadow:0 14px 32px rgba(0,0,0,.12)}
.exp-contact-card .exp-contact-card__ic{display:inline-flex;color:var(--accent-text);margin-bottom:.6rem}
.exp-contact-card h3{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.03em;font-weight:400;font-size:1.1rem;margin:0;color:#111}
.exp-contact-card strong{font-family:var(--font-mono);color:#111;font-size:1rem;font-weight:700}
.exp-contact-card span{font-family:var(--font-mono);color:#777;font-size:.85rem}
.exp-form-panel{background:#111;padding:2.8rem 2.6rem}
.exp-form-panel>h3{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.03em;font-weight:900;font-size:1.6rem;margin-bottom:1.8rem;color:#fff}
.exp-form-panel .field{margin-bottom:1.3rem}
.exp-form-panel label{display:block;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;color:#fff;margin-bottom:.5rem}
.exp-form-panel input,.exp-form-panel select,.exp-form-panel textarea{width:100%;padding:.85rem 1rem;border:0;border-radius:0;font-family:var(--font-mono);font-size:.95rem;background:#fff;color:#111}
.exp-form-panel input::placeholder,.exp-form-panel textarea::placeholder{color:#999;font-style:italic}
.exp-form-panel input:focus,.exp-form-panel select:focus,.exp-form-panel textarea:focus{outline:2px solid var(--primary)}
.exp-form-panel textarea{min-height:140px;resize:vertical}
.exp-form-panel .btn{margin-top:.5rem}
.exp-form-panel .alert{margin-bottom:1.2rem}

@media(max-width:900px){.exp-cost-layout{grid-template-columns:1fr;gap:2rem}}
@media(max-width:768px){.exp-contact-row{grid-template-columns:1fr}.exp-cost-panel,.exp-disclaimer,.exp-form-panel{padding:1.6rem}.exp-banner h2{white-space:normal;font-size:2.4rem}}

/* ===== Cast Stone page (exact live match) ===== */
.cs-hero{background:linear-gradient(135deg,#111 0%,#111 45%,#0f172a 100%);padding:5.5rem 0;color:#fff}
.cs-hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:3.5rem;align-items:center}
.cs-hero__media img{width:100%;max-width:538px;aspect-ratio:1/1;object-fit:cover;border-radius:8px;box-shadow:0 25px 50px -12px rgba(0,0,0,.55);display:block;margin-left:auto}
.cs-hero__title{font-family:var(--font-head);font-weight:900;text-transform:none;letter-spacing:.06em;line-height:1;color:#fff;font-size:clamp(2.6rem,5.6vw,4.5rem);margin:0 0 1.5rem}
.cs-gold{color:var(--primary)}
.cs-hero__sub{font-family:var(--font-body);font-size:1.5rem;font-weight:700;line-height:1.2;color:#e5e7eb;letter-spacing:.02em;margin:0 0 2rem;max-width:620px}
.cs-hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.cs-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--font-head);font-weight:700;text-transform:none;letter-spacing:.02em;font-size:1.05rem;padding:1.5rem 2rem;border-radius:8px;text-decoration:none;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease;cursor:pointer}
.cs-btn--gold{background:var(--primary);color:#111}
.cs-btn--gold:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(244,180,0,.35)}
.cs-btn--white{background:#fff;color:#111}
.cs-btn--white:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.25)}
.cs-btn--dark{background:#111;color:#fff}
.cs-btn--dark:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.3)}
.cs-hero__badges{display:flex;gap:1.8rem;flex-wrap:wrap;margin-top:2.2rem}
.cs-badge{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-size:1rem;color:#fff}
.cs-badge svg{color:var(--primary)}

/* sections */
.cs-sec{padding:7rem 0}
.cs-sec--white{background:#fff}
.cs-sec--gray{background:#f2f2f2}
.cs-head{text-align:center;max-width:820px;margin:0 auto 4rem}
.cs-head h2{font-family:var(--font-head);font-weight:900;text-transform:none;letter-spacing:.05em;font-size:clamp(2rem,4.4vw,3rem);color:#111;margin:0 0 1.5rem;line-height:1.05}
.cs-head__sub{font-family:var(--font-body);font-size:1.125rem;line-height:1.625;color:#333;margin:0 auto;max-width:768px;letter-spacing:.01em}

/* cards */
.cs-grid{display:grid;gap:2rem}
.cs-grid--3{grid-template-columns:repeat(3,1fr)}
.cs-grid--4{grid-template-columns:repeat(4,1fr)}
.cs-card{border-radius:8px;padding:2rem;text-align:left;transition:transform .35s cubic-bezier(.22,.61,.36,1),box-shadow .35s ease}
.cs-sec--white .cs-card{background:#f2f2f2}
.cs-sec--gray .cs-card{background:#fff}
.cs-card:hover{transform:translateY(-6px);box-shadow:0 16px 36px rgba(0,0,0,.1)}
.cs-card__ic{display:inline-flex;color:var(--accent-text);margin-bottom:1rem;transition:transform .35s ease}
.cs-card:hover .cs-card__ic{transform:scale(1.08)}
.cs-card h3{font-family:var(--font-head);font-weight:700;text-transform:none;letter-spacing:.02em;font-size:1.25rem;color:#111;margin:0 0 .75rem;line-height:1.25}
.cs-card--plain h3{font-size:1.5rem}
.cs-card p{font-family:var(--font-body);margin:0;color:#333;font-size:1rem;line-height:1.5}
.cs-checks{list-style:none;padding:0;margin:1.1rem 0 0;display:grid;gap:.6rem}
.cs-checks li{display:flex;align-items:center;gap:.6rem;font-family:var(--font-body);font-size:1rem;color:#333}
.cs-checks svg{color:var(--accent-text);flex:none}
.cs-center{text-align:center;margin-top:3rem}

/* locations */
.cs-locations{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;max-width:900px;margin:0 auto}
.cs-loc{font-family:var(--font-mono);font-size:1rem;color:#333;background:#f2f2f2;border-radius:8px;padding:1rem}
.cs-sec--white .cs-loc{background:#f2f2f2}

/* stats band (dark) */
.cs-stats{background:linear-gradient(135deg,#111 0%,#0f172a 100%);padding:7rem 0}
.cs-stats__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;text-align:center}
.cs-stat__num{display:block;font-family:var(--font-head);font-weight:900;letter-spacing:.04em;font-size:clamp(3rem,5vw,3.75rem);color:var(--primary);line-height:1}
.cs-stat h3{font-family:var(--font-head);font-weight:700;text-transform:none;letter-spacing:.02em;font-size:1.25rem;color:#fff;margin:.7rem 0 .6rem}
.cs-stat p{font-family:var(--font-body);margin:0 auto;color:#cbd5e1;font-size:.95rem;line-height:1.6;max-width:300px}

/* CTA */
.cs-cta h2{font-family:var(--font-head);font-weight:900;text-transform:none;letter-spacing:.05em;font-size:clamp(2rem,4.4vw,3rem);color:#111;margin:0 0 1.1rem}
.cs-cta__sub{font-family:var(--font-body);font-size:1.125rem;line-height:1.6;color:#333;max-width:720px;margin:0 auto 2rem}
.cs-center.cs-hero__actions{justify-content:center}

.cs-btn svg{flex:none}
@media(max-width:1024px){.cs-grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.cs-hero__grid{grid-template-columns:1fr;gap:2.5rem}.cs-hero__media{order:-1}.cs-hero__media img{margin:0 auto;max-width:420px}}
@media(max-width:820px){.cs-grid--3{grid-template-columns:1fr}.cs-grid--4{grid-template-columns:1fr}.cs-stats__grid{grid-template-columns:1fr;gap:2rem}.cs-hero{padding:4rem 0}}

/* ===== Resources page (exact live match) ===== */
.res-head{margin-bottom:3rem}
.res-head .display-head{font-size:clamp(2.2rem,5vw,3.75rem);text-align:left;margin:0 0 1rem;line-height:1.05}
.res-head__sub{font-family:var(--font-mono);font-size:1.125rem;line-height:1.5;color:#333;margin:0;text-align:left}

/* download cards */
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.res-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:transform .35s cubic-bezier(.22,.61,.36,1),box-shadow .35s ease}
.res-card:hover{transform:translateY(-6px);box-shadow:0 16px 36px rgba(0,0,0,.12)}
.res-card__media img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:#f2f2f2}
.res-card__body{padding:1.6rem;display:flex;flex-direction:column;flex:1}
.res-card__body h3{display:flex;align-items:flex-start;gap:.6rem;font-family:var(--font-head);font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:1.2rem;color:#111;margin:0 0 .7rem;line-height:1.25}
.res-card__ic{color:var(--accent-text);flex:none;margin-top:1px}
.res-card__body p{font-family:var(--font-body);color:#444;font-size:.95rem;line-height:1.6;margin:0 0 1.2rem;flex:1}
.res-card__dl{display:inline-flex;align-items:center;gap:.5rem;color:var(--accent-text);font-family:var(--font-head);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.9rem;text-decoration:none;transition:gap .25s ease}
.res-card__dl:hover{gap:.85rem}

/* FAQ accordion */
.res-faq{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.res-faq__item{border-bottom:1px solid rgba(51,51,51,.1)}
.res-faq__item:last-child{border-bottom:0}
.res-faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.3rem 1.6rem;background:none;border:0;cursor:pointer;text-align:left;font-family:var(--font-head);font-weight:400;text-transform:uppercase;letter-spacing:.02em;font-size:1.125rem;color:#111;transition:color .2s ease}
.res-faq__q:hover{color:var(--accent-text)}
.res-faq__chev{color:var(--accent-text);transition:transform .3s ease;flex:none;display:inline-flex}
.res-faq__item.is-open .res-faq__chev{transform:rotate(180deg)}
.res-faq__a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.res-faq__item.is-open .res-faq__a{max-height:420px}
.res-faq__a p{margin:0;padding:0 1.6rem 1.4rem;font-family:var(--font-body);color:#444;font-size:1rem;line-height:1.65}
.related-read{font-family:var(--font-body);font-size:.95rem;color:#555}
.related-read a{color:var(--accent-text,#d99e00);text-decoration:none;font-weight:600}
.related-read a:hover{text-decoration:underline}
/* FAQ page — grouped accordions */
.faq-page{max-width:920px;margin:0 auto}
.faq-group{margin-bottom:3rem}
.faq-group:last-child{margin-bottom:0}
.faq-group__title{font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:1.1rem;color:var(--text-heading)}
.faq-page .res-faq{border-top:1px solid rgba(51,51,51,.1)}
.faq-page .res-faq__item.is-open .res-faq__a{max-height:600px}

/* gold CTA */
.res-cta{background:var(--primary);padding:5.5rem 0;text-align:center}
.res-cta h2{font-family:var(--font-head);font-weight:900;text-transform:uppercase;letter-spacing:.04em;font-size:clamp(2rem,4.5vw,3.75rem);color:#111;margin:0 0 1.1rem;line-height:1.05}
.res-cta p{font-family:var(--font-body);color:#1a1a1a;font-size:1.15rem;line-height:1.6;max-width:640px;margin:0 auto 2rem}
.res-cta__btn{display:inline-flex;align-items:center;background:#111;color:#fff;font-family:var(--font-head);font-weight:700;text-transform:uppercase;letter-spacing:.03em;font-size:1rem;padding:1.05rem 2.4rem;border-radius:8px;text-decoration:none;transition:transform .25s ease,box-shadow .25s ease}
.res-cta__btn:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.3)}

@media(max-width:1024px){.res-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.res-grid{grid-template-columns:1fr}}

/* ===== Certifications page ===== */
.cert-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.cert-card{background:#f2f2f2;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:transform .35s cubic-bezier(.22,.61,.36,1),box-shadow .35s ease}
.cert-card:hover{transform:translateY(-6px);box-shadow:0 16px 36px rgba(0,0,0,.12)}
.cert-card__media img{width:100%;aspect-ratio:440/192;object-fit:cover;display:block;background:#fff}
.cert-card__body{padding:1.6rem;display:flex;flex-direction:column;flex:1;text-align:left;align-items:flex-start}
.cert-card__body h3{font-family:var(--font-head);font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:1.25rem;color:#111;margin:0 0 .5rem;line-height:1.25}
.cert-card__org{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.03em;font-size:.875rem;color:var(--accent-text);margin-bottom:.9rem}
.cert-card__body p{font-family:var(--font-body);color:#444;font-size:.95rem;line-height:1.6;margin:0 0 1.2rem;flex:1}
.cert-card__link{display:inline-flex;align-items:center;gap:.5rem;color:var(--accent-text);font-family:var(--font-head);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.9rem;text-decoration:none;transition:gap .25s ease}
.cert-card__link:hover{gap:.85rem}
@media(max-width:1024px){.cert-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.cert-grid{grid-template-columns:1fr}}

/* per-page heading scale to match live (home/projects 72px; inner pages smaller) */
.pg-services .display-head{font-size:clamp(1.9rem,3.6vw,3rem)}
.pg-product-detail .display-head,.pg-project-detail .display-head{font-size:clamp(1.6rem,3vw,2.25rem)}

/* ===== Contact page ===== */
.res-head--light .display-head{color:#fff}
.res-head--light .res-head__sub{color:rgba(255,255,255,.8)}
.ct-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:start}
.ct-info{display:grid;gap:1.25rem}
.ct-info__card{display:flex;gap:1.1rem;align-items:flex-start;background:#f2f2f2;border-radius:8px;padding:1.5rem 1.6rem}
.ct-info__ic{display:inline-flex;color:var(--accent-text);flex:none;margin-top:2px}
.ct-info__body h3{font-family:var(--font-head);font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:1.1rem;color:#111;margin:0 0 .45rem}
.ct-info__body p{font-family:var(--font-body);color:#555;font-size:.95rem;line-height:1.5;margin:.12rem 0}
.ct-info__body a{color:#555;text-decoration:none}
.ct-info__body a:hover{color:var(--accent-text)}

.ct-form-card{background:#f2f2f2;border-radius:8px;padding:2.2rem}
.ct-form-card>h3{font-family:var(--font-head);font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:1.4rem;color:#111;margin:0 0 1.4rem}
.ct-quote-sec{background:#111}
.ct-quote-card{background:#fff;border-radius:8px;padding:2.6rem;max-width:880px;margin:0 auto}

.ct-form-card .field,.ct-quote-card .field{margin-bottom:1.1rem}
.ct-form-card label,.ct-quote-card label{display:block;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;color:#111;margin-bottom:.45rem}
.ct-form-card input,.ct-form-card textarea,.ct-quote-card input,.ct-quote-card textarea{width:100%;padding:.78rem 1rem;border:1px solid rgba(51,51,51,.2);border-radius:6px;font-family:var(--font-body);font-size:.95rem;background:#fff;color:#111;transition:border-color .2s ease,box-shadow .2s ease}
.ct-form-card input:focus,.ct-form-card textarea:focus,.ct-quote-card input:focus,.ct-quote-card textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(244,180,0,.15)}
.ct-form-card textarea{min-height:130px;resize:vertical}
.ct-quote-card textarea{min-height:150px;resize:vertical}
.ct-form-card input::placeholder,.ct-quote-card input::placeholder,.ct-quote-card textarea::placeholder{color:#999}
.ct-btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;width:100%;background:var(--primary);color:#111;font-family:var(--font-head);font-weight:700;text-transform:uppercase;letter-spacing:.03em;font-size:1rem;padding:1rem 2rem;border:0;border-radius:8px;cursor:pointer;margin-top:.4rem;transition:transform .25s ease,box-shadow .25s ease}
.ct-btn:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(244,180,0,.35)}
.ct-btn svg{flex:none}

.ct-map{margin-top:2.5rem;border-radius:8px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.1);border:1px solid var(--border)}
.ct-map iframe{filter:grayscale(.15)}
@media(max-width:900px){.ct-grid{grid-template-columns:1fr;gap:2rem}}
