/* =============================================================================
   NIA COATINGS GROUP — styles.css
   Dark luxury-industrial  |  Bebas Neue + DM Sans + DM Mono
   ============================================================================= */

/* ── TOKENS ──────────────────────────────────────────────────────────────── */
:root {
  --bg:     #080a0d;
  --bg2:    #0f1116;
  --bg3:    #171a22;
  --bg4:    #1e2230;
  --border: rgba(255,255,255,.07);
  --border2:rgba(255,255,255,.13);
  --orange: #ff6b00;
  --orange2:#ff8c3a;
  --orange-tint:rgba(255,107,0,.10);
  --blue:   #1a7fff;
  --red:    #ef4444;
  --green:  #22c55e;
  --text:   #e8e8ec;
  --text2:  #9090a0;
  --text3:  #50505e;
  --display:'Bebas Neue',sans-serif;
  --body:   'DM Sans',sans-serif;
  --mono:   'DM Mono',monospace;
  --max:    1140px;
  --r:      10px;
  --pad:    100px;
}

/* ── RESET ───────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--bg);color:var(--text);
     -webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--orange);border-radius:2px}
a{color:inherit;text-decoration:none}
button,select,input,textarea{font-family:inherit}
ul,ol{list-style:none}
img{display:block;max-width:100%}
address{font-style:normal}
fieldset{border:none;padding:0}
legend{display:block;margin-bottom:4px}   /* was float:left — caused layout breaks */

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;
         overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── LAYOUT ──────────────────────────────────────────────────────────────── */
.wrap{max-width:var(--max);margin:0 auto;padding:0 32px}
section{padding:var(--pad) 0;position:relative}
.section-alt{background:var(--bg2)}

/* ── REVEAL ──────────────────────────────────────────────────────────────── */
.js-ready .reveal{opacity:0;transform:translateY(20px);
  transition:opacity .6s ease,transform .6s ease}
.js-ready .reveal.visible{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}
.reveal-d4{transition-delay:.4s}

/* ── TYPE ────────────────────────────────────────────────────────────────── */
h1,h2,h3,h4{font-family:var(--display);letter-spacing:.06em;line-height:1;font-weight:400}
h1{font-size:clamp(48px,6.5vw,84px);color:#fff}
h1 em{font-style:normal;color:var(--orange)}
h2{font-size:clamp(30px,4vw,50px);color:#fff}
h3{font-size:22px;color:#fff}

.eyebrow{font-size:10px;letter-spacing:.22em;text-transform:uppercase;
         font-weight:600;color:var(--orange);margin-bottom:14px;display:block}
.section-header{margin-bottom:52px}
.section-header.center{text-align:center}
.section-header.center .section-sub{margin:0 auto}
.section-sub{font-size:15px;color:var(--text2);max-width:560px;
             margin-top:14px;line-height:1.7}

/* ── BUTTONS ─────────────────────────────────────────────────────────────── */
.btn{display:inline-block;border-radius:8px;padding:13px 26px;font-size:14px;
     font-weight:600;cursor:pointer;transition:background .2s,transform .15s,border-color .2s;
     border:1.5px solid transparent;letter-spacing:.03em;line-height:1}
.btn-primary{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-primary:hover{background:var(--orange2);border-color:var(--orange2);transform:translateY(-1px);color:#fff}
.btn-secondary{background:transparent;color:var(--text);border-color:var(--border2)}
.btn-secondary:hover{border-color:rgba(255,107,0,.4);background:var(--orange-tint)}
.btn-ghost{background:transparent;color:var(--orange);border-color:rgba(255,107,0,.35)}
.btn-ghost:hover{border-color:var(--orange);background:var(--orange-tint)}
.btn-full{width:100%;text-align:center}

/* ── NAV ─────────────────────────────────────────────────────────────────── */
#site-header{position:fixed;top:0;left:0;right:0;z-index:500;
             background:rgba(8,10,13,.94);backdrop-filter:blur(20px);
             border-bottom:1px solid var(--border)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 32px;height:64px;
           display:flex;align-items:center}
.nav-logo{display:flex;align-items:baseline;gap:9px;flex-shrink:0;text-decoration:none}
.logo-letters{font-family:var(--display);font-size:26px;letter-spacing:.1em;line-height:1}
.l-n{color:var(--blue)}.l-i{color:var(--red)}.l-a{color:var(--green)}
.logo-wordmark{font-size:9px;letter-spacing:.22em;text-transform:uppercase;
               color:var(--orange);font-weight:600}
.nav-links{display:flex;align-items:center;gap:2px;margin-left:36px}
.nav-link{font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
          color:var(--text3);padding:8px 13px;border-radius:6px;
          transition:color .2s,background .2s;display:block}
.nav-link:hover,.nav-link.active{color:var(--text);background:rgba(255,255,255,.04)}
.nav-link.active{color:var(--orange)}
.nav-cta{margin-left:auto;padding:9px 20px;font-size:12px}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;
            cursor:pointer;padding:8px;margin-left:auto}
.hamburger-bar{display:block;width:22px;height:2px;background:var(--text);
               border-radius:2px;transition:transform .3s,opacity .3s}
.nav-toggle[aria-expanded="true"] .hamburger-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .hamburger-bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .hamburger-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile{display:none;flex-direction:column;padding:8px 20px 20px;
            border-top:1px solid var(--border);background:var(--bg2)}
.nav-mobile.open{display:flex}
.nav-mobile .nav-link{padding:13px 8px;font-size:13px;border-bottom:1px solid var(--border)}
.nav-mobile .nav-link:last-of-type{border-bottom:none}
.nav-mobile .btn{margin-top:12px;text-align:center}

/* ── HERO ────────────────────────────────────────────────────────────────── */
#hero{min-height:100vh;padding-top:64px;display:flex;align-items:center;
      position:relative;overflow:hidden;
      background:
        radial-gradient(ellipse 80% 60% at 60% 40%,rgba(255,107,0,.07) 0%,transparent 70%),
        radial-gradient(ellipse 50% 40% at 15% 70%,rgba(26,127,255,.05) 0%,transparent 60%),
        var(--bg)}
.hero-slogan-bg{position:absolute;inset:0;display:flex;flex-direction:column;
                justify-content:center;pointer-events:none;user-select:none;
                overflow:hidden;padding-top:64px;z-index:0}
.hero-slogan-bg span{display:block;font-family:var(--display);
  font-size:clamp(60px,9vw,140px);letter-spacing:.08em;text-transform:uppercase;
  line-height:.92;white-space:nowrap;color:transparent;
  -webkit-text-stroke:1px rgba(255,255,255,.055);padding-left:2vw}
.hero-slogan-bg span:nth-child(2){padding-left:8vw;
  -webkit-text-stroke:1px rgba(255,107,0,.065)}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
           padding:80px 0;width:100%;position:relative;z-index:1}
.hero-content{order:1}
.hero-content h1{margin-bottom:22px}
.hero-desc{font-size:16px;color:var(--text2);line-height:1.7;margin-bottom:34px;max-width:480px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.hero-stats{display:flex;gap:28px;flex-wrap:wrap;padding-top:28px;border-top:1px solid var(--border)}
.hero-stat{display:flex;flex-direction:column}
.stat-num{font-family:var(--display);font-size:28px;letter-spacing:.06em;color:#fff}
.stat-lbl{font-size:11px;color:var(--text3);letter-spacing:.06em;margin-top:2px}
.hero-visual{order:2;position:relative}
.hero-canvas-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;
                  gap:8px;border-radius:16px;overflow:hidden;
                  box-shadow:0 32px 80px rgba(0,0,0,.6),0 0 0 1px var(--border)}
.hero-canvas-cell{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:1.8/1}
.hero-canvas-cell canvas{display:block;width:100%;height:100%;
                          transition:transform .4s ease;object-fit:cover}
.hero-canvas-cell:hover canvas{transform:scale(1.05)}
.hero-canvas-label{position:absolute;bottom:8px;left:8px;
                   background:rgba(0,0,0,.65);backdrop-filter:blur(6px);
                   border-radius:4px;padding:3px 8px;font-size:9px;
                   letter-spacing:.1em;text-transform:uppercase;
                   color:rgba(255,255,255,.7);border:1px solid var(--border)}
.hero-badge{position:absolute;top:-12px;right:-12px;background:var(--orange);color:#fff;
            border-radius:50%;width:68px;height:68px;display:flex;flex-direction:column;
            align-items:center;justify-content:center;font-family:var(--display);
            font-size:12px;letter-spacing:.08em;line-height:1.2;text-align:center;
            box-shadow:0 8px 24px rgba(255,107,0,.4);
            animation:badge-spin 14s linear infinite}
@keyframes badge-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* ── TICKER ──────────────────────────────────────────────────────────────── */
.ticker{background:var(--bg2);border-top:1px solid var(--border);
        border-bottom:1px solid var(--border);padding:11px 0;overflow:hidden}
.ticker-track{display:flex;gap:48px;white-space:nowrap;
              animation:ticker-scroll 24s linear infinite}
.ticker-track:hover{animation-play-state:paused}
@keyframes ticker-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-item{font-size:11px;letter-spacing:.16em;text-transform:uppercase;
             color:var(--text3);display:flex;align-items:center;gap:10px;flex-shrink:0}
.ticker-item::after{content:'·';color:var(--orange)}

/* ── SLOGAN STRIP ────────────────────────────────────────────────────────── */
.slogan-strip{background:var(--bg);border-top:1px solid rgba(255,107,0,.18);
              border-bottom:1px solid rgba(255,107,0,.18);padding:16px 0;overflow:hidden}
.slogan-strip-track{display:flex;align-items:center;gap:32px;white-space:nowrap;
                    animation:slogan-scroll 30s linear infinite}
@keyframes slogan-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.slogan-strip-track span{font-family:var(--display);font-size:15px;letter-spacing:.2em;
                         text-transform:uppercase;color:var(--text3);flex-shrink:0}
.slogan-dot{color:var(--orange) !important;font-size:10px !important;letter-spacing:0 !important}

/* ── SERVICES ────────────────────────────────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;
               border-radius:12px;overflow:hidden}
.svc-card{background:var(--bg2);position:relative;overflow:hidden;
          transition:background .2s}
.svc-card:hover{background:var(--bg3)}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
                  background:linear-gradient(90deg,transparent,var(--orange),transparent);
                  opacity:0;transition:opacity .2s}
.svc-card:hover::before{opacity:1}
.svc-canvas-wrap{height:160px;overflow:hidden}
.svc-canvas-wrap canvas{width:100%;height:100%;display:block;transition:transform .5s ease}
.svc-card:hover .svc-canvas-wrap canvas{transform:scale(1.06)}
.svc-body{padding:20px 22px 26px}
.svc-tag{font-size:9px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
         color:var(--text3);margin-bottom:10px;display:block}
.svc-name{font-family:var(--display);font-size:22px;letter-spacing:.08em;
          color:#fff;margin-bottom:10px}
.svc-desc{font-size:12px;color:var(--text3);line-height:1.6;margin-bottom:14px}
.svc-price{font-family:var(--mono);font-size:12px;color:var(--orange2);margin-bottom:14px;display:block}
.svc-link{font-size:11px;font-weight:600;color:var(--orange);
          letter-spacing:.04em;transition:opacity .2s;display:inline-block}
.svc-link:hover{opacity:.7}

/* ── PROCESS ─────────────────────────────────────────────────────────────── */
.process-steps{list-style:none;display:flex;flex-direction:column;gap:0;margin-bottom:48px}
.proc-step{display:grid;grid-template-columns:80px 1fr;position:relative}
.proc-step-marker{display:flex;flex-direction:column;align-items:center;
                  padding-top:6px;position:relative;z-index:1}
.proc-step-num{width:52px;height:52px;border-radius:50%;background:var(--bg3);
               border:1.5px solid var(--border2);display:flex;align-items:center;
               justify-content:center;font-family:var(--display);font-size:20px;
               letter-spacing:.06em;color:var(--orange);flex-shrink:0;
               transition:background .3s,border-color .3s,box-shadow .3s;
               position:relative;z-index:1}
.proc-step:hover .proc-step-num{background:var(--orange);color:#fff;
                                border-color:var(--orange);box-shadow:0 0 28px rgba(255,107,0,.4)}
.proc-step-line{flex:1;width:1.5px;background:linear-gradient(to bottom,rgba(255,107,0,.3),rgba(255,107,0,.05));
                margin:6px 0 0;min-height:32px}
.proc-step-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);
                padding:28px 32px;margin-left:20px;margin-bottom:20px;
                transition:border-color .2s}
.proc-step:hover .proc-step-card{border-color:rgba(255,107,0,.2)}
.proc-step-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.proc-step-icon{font-size:28px;line-height:1;flex-shrink:0}
.proc-step-tag{font-size:9px;letter-spacing:.18em;text-transform:uppercase;
               font-weight:700;color:var(--orange);margin-bottom:5px;display:block}
.proc-step-title{font-family:var(--display);font-size:26px;letter-spacing:.07em;color:#fff}
.proc-step-duration{margin-left:auto;text-align:right;flex-shrink:0}
.duration-label{display:block;font-size:9px;letter-spacing:.12em;text-transform:uppercase;
                color:var(--text3);margin-bottom:3px}
.duration-value{display:block;font-family:var(--mono);font-size:12px;color:var(--text2)}
.proc-step-lead{font-size:14px;color:var(--text2);line-height:1.75;margin-bottom:22px;
                max-width:760px;border-left:2px solid rgba(255,107,0,.3);padding-left:16px}
.proc-step-body{display:flex;flex-direction:column;gap:18px}
.proc-step-details{background:rgba(255,255,255,.02);border-radius:8px;
                   padding:18px 20px;border:1px solid rgba(255,255,255,.04)}
.proc-detail-title{font-size:10px;letter-spacing:.14em;text-transform:uppercase;
                   color:var(--text3);font-weight:700;margin-bottom:14px;display:block}
.proc-detail-list{display:flex;flex-direction:column;gap:12px}
.proc-detail-list li{display:flex;gap:10px;font-size:13px;color:var(--text2);line-height:1.65}
.proc-detail-list li strong{color:var(--text);font-weight:600}
.proc-detail-list li > div{flex:1}
.detail-icon{color:var(--orange);font-size:8px;flex-shrink:0;margin-top:5px}
.proc-step-callout{display:flex;gap:12px;background:rgba(255,107,0,.05);
                   border:1px solid rgba(255,107,0,.15);border-radius:8px;
                   padding:14px 18px;font-size:13px;color:var(--text2);line-height:1.65}
.proc-step-callout strong{color:var(--orange2)}
.proc-step-callout--flush{margin-top:0}
.callout-icon{font-size:18px;flex-shrink:0;margin-top:1px}
.proc-step-outcome{font-size:12px;color:var(--text3);line-height:1.65;padding:12px 14px;
                   border-radius:6px;background:rgba(34,197,94,.04);
                   border:1px solid rgba(34,197,94,.1)}
.proc-step-outcome strong{color:var(--green)}

/* Process CTA */
.process-cta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;
             background:linear-gradient(135deg,rgba(255,107,0,.08),rgba(26,127,255,.04));
             border:1px solid rgba(255,107,0,.2);border-radius:var(--r);padding:24px 28px}
.process-cta-text{flex:1;min-width:200px}
.process-cta-title{font-family:var(--display);font-size:22px;letter-spacing:.07em;
                   color:#fff;margin-bottom:4px}
.process-cta-sub{font-size:13px;color:var(--text2);line-height:1.5}

/* ── MOISTURE TESTING ────────────────────────────────────────────────────── */
.proc-moisture-block{background:rgba(26,127,255,.04);border:1px solid rgba(26,127,255,.14);
                     border-radius:var(--r);padding:24px 26px;display:flex;
                     flex-direction:column;gap:20px}
.moisture-header{display:flex;gap:14px;align-items:flex-start}
.moisture-icon{font-size:26px;flex-shrink:0;margin-top:2px}
.moisture-title{font-family:var(--display);font-size:18px;letter-spacing:.07em;
                color:#fff;margin-bottom:8px}
.moisture-intro{font-size:13px;color:var(--text2);line-height:1.75}
.moisture-section{display:flex;flex-direction:column;gap:10px}
.moisture-section-title{font-size:10px;letter-spacing:.14em;text-transform:uppercase;
                        color:rgba(26,127,255,.8);font-weight:700;margin-bottom:4px;display:block}
.moisture-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.moisture-table{width:100%;border-collapse:collapse;font-size:12px;min-width:540px}
.moisture-table thead tr{border-bottom:1px solid rgba(26,127,255,.2)}
.moisture-table th{font-size:10px;letter-spacing:.1em;text-transform:uppercase;
                   color:var(--text3);font-weight:700;padding:10px 12px;text-align:left}
.moisture-table td{padding:11px 12px;color:var(--text2);line-height:1.55;
                   border-bottom:1px solid rgba(255,255,255,.03);vertical-align:top}
.moisture-table td:first-child{font-family:var(--mono);font-size:11px;white-space:nowrap;color:var(--text)}
.moisture-table td:nth-child(2){font-family:var(--mono);font-size:11px;white-space:nowrap}
.mrow-ok td{background:rgba(34,197,94,.04)}
.mrow-caution td{background:rgba(234,179,8,.05)}
.mrow-high td{background:rgba(249,115,22,.05)}
.mrow-critical td{background:rgba(239,68,68,.06)}
.risk-badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:10px;
            font-weight:700;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}
.risk-low{color:var(--green);background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.25)}
.risk-medium{color:#eab308;background:rgba(234,179,8,.12);border:1px solid rgba(234,179,8,.25)}
.risk-high{color:#f97316;background:rgba(249,115,22,.12);border:1px solid rgba(249,115,22,.25)}
.risk-critical{color:var(--red);background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.25)}

/* ── SPACES ──────────────────────────────────────────────────────────────── */
.spaces-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.space-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);
            padding:30px;transition:border-color .2s,transform .2s}
.space-card:hover{border-color:rgba(255,107,0,.3);transform:translateY(-2px)}
.space-icon{font-size:28px;margin-bottom:16px;display:block}
.space-name{font-size:20px;margin-bottom:10px}
.space-desc{font-size:12px;color:var(--text3);line-height:1.6;margin-bottom:18px}
.space-tags{display:flex;gap:6px;flex-wrap:wrap}
.space-tags li{font-size:10px;letter-spacing:.08em;padding:3px 10px;
               border-radius:999px;border:1px solid var(--border);color:var(--text3)}

/* ── CITIES ──────────────────────────────────────────────────────────────── */
.cities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.city-card{background:var(--bg3);border:1px solid var(--border);border-radius:8px;
           padding:20px 18px;transition:border-color .2s,background .2s;
           display:flex;flex-direction:column;gap:4px}
.city-card:hover{border-color:rgba(255,107,0,.3);background:var(--bg4)}
.city-card strong{font-family:var(--display);font-size:18px;letter-spacing:.08em;color:#fff}
.city-card span{font-size:11px;color:var(--text3)}

/* ── ESTIMATOR ───────────────────────────────────────────────────────────── */
.estimator-frame{background:var(--bg2);border:1px solid var(--border);
                 border-radius:16px;overflow:hidden;
                 box-shadow:0 24px 80px rgba(0,0,0,.5),0 0 0 1px rgba(255,107,0,.05)}
.est-tabs{display:flex;border-bottom:1px solid var(--border);
          background:rgba(0,0,0,.2);padding:0 28px}
.est-tab{background:none;border:none;color:var(--text3);font-size:11px;
         letter-spacing:.12em;text-transform:uppercase;font-weight:600;
         padding:14px 18px;cursor:pointer;border-bottom:2px solid transparent;
         margin-bottom:-1px;transition:color .2s,border-color .2s}
.est-tab:hover{color:var(--text2)}
.est-tab.active{color:var(--orange);border-bottom-color:var(--orange)}
.est-panel{padding:32px 28px 28px}
.est-panel[hidden]{display:none}
.est-section{margin-bottom:32px}
.est-section-title{font-family:var(--display);font-size:16px;letter-spacing:.12em;
                   color:#fff;margin-bottom:4px;display:block}
.est-section-sub{font-size:12px;color:var(--text3);margin-bottom:14px;display:block}
.resin-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.resin-card{display:block;background:var(--bg3);border:1.5px solid var(--border);
            border-radius:var(--r);padding:18px 20px;cursor:pointer;
            transition:border-color .2s,background .2s}
.resin-card:hover{border-color:rgba(255,107,0,.3)}
.resin-card.active{border-color:var(--orange);background:rgba(255,107,0,.07)}
.resin-name{display:block;font-weight:600;font-size:15px;color:#fff;margin-bottom:5px}
.resin-desc{display:block;font-size:11px;color:var(--text3);line-height:1.5}
.sys-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.sys-card{background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--r);
          overflow:hidden;cursor:pointer;transition:border-color .2s,background .2s}
.sys-card:hover{border-color:rgba(255,107,0,.3)}
.sys-card.active{border-color:var(--orange);background:rgba(255,107,0,.07)}
.sys-canvas-wrap{height:96px;overflow:hidden}
.sys-canvas-wrap canvas{width:100%;height:100%;display:block;transition:transform .4s ease}
.sys-card:hover .sys-canvas-wrap canvas{transform:scale(1.05)}
.sys-card-body{padding:10px 12px}
.sys-card-tag{font-size:9px;letter-spacing:.12em;text-transform:uppercase;
              font-weight:700;color:var(--text3);margin-bottom:4px;display:block}
.sys-card.active .sys-card-tag{color:var(--orange)}
.sys-card-name{font-weight:600;font-size:12px;color:#fff;margin-bottom:3px;display:block}
.sys-card-desc{font-size:10px;color:var(--text3);line-height:1.4;display:block}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field-group{display:flex;flex-direction:column;gap:6px}
.field-label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;
             font-weight:600;color:var(--text3);display:block}
.field-input{background:rgba(255,255,255,.05);border:1.5px solid var(--border);
             border-radius:8px;color:var(--text);padding:11px 14px;font-size:13px;
             outline:none;transition:border-color .2s;appearance:none;
             -webkit-appearance:none;width:100%}
.field-input:focus{border-color:var(--orange)}
.field-input::placeholder{color:var(--text3)}
select.field-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2350505e' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
                   background-repeat:no-repeat;background-position:right 12px center;
                   padding-right:34px;cursor:pointer}
select.field-input option{background:#1a1b22}
.field-hint{font-size:11px;color:var(--text3);line-height:1.5;display:block}
.pill-group{display:flex;gap:8px;flex-wrap:wrap}
.pill{background:rgba(255,255,255,.04);border:1.5px solid var(--border);border-radius:999px;
      padding:7px 15px;font-size:12px;font-weight:500;color:var(--text2);cursor:pointer;
      transition:border-color .2s,background .2s,color .2s}
.pill:hover{border-color:rgba(255,107,0,.4);color:var(--orange2)}
.pill.active{border-color:var(--orange);background:rgba(255,107,0,.12);color:var(--orange2)}
.est-cta-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
             background:linear-gradient(135deg,rgba(255,107,0,.08),rgba(26,127,255,.04));
             border:1px solid rgba(255,107,0,.18);border-radius:var(--r);padding:18px 22px}
.est-cta-hint{flex:1;font-size:12px;color:var(--text3);min-width:160px;display:block}

/* Visualize panel */
.est-vis-title{font-family:var(--display);font-size:22px;letter-spacing:.08em;
               margin-bottom:3px;display:block}
.est-vis-sub{font-size:12px;color:var(--text3);margin-bottom:18px;display:block}
.vis-hero-wrap{position:relative;border-radius:10px;overflow:hidden;
               margin-bottom:10px;border:1px solid var(--border);
               box-shadow:0 0 40px rgba(255,107,0,.1)}
.vis-hero-wrap canvas{display:block;width:100%;height:auto}
.vis-hero-overlay{position:absolute;inset:0;
                  background:linear-gradient(to top,rgba(0,0,0,.55) 0%,rgba(0,0,0,.08) 50%,transparent 100%);
                  pointer-events:none}
.vis-hero-caption{position:absolute;bottom:12px;left:14px;color:#fff}
.vis-hero-caption strong{display:block;font-family:var(--display);font-size:22px;
                         letter-spacing:.08em;line-height:1}
.vis-hero-caption span{display:block;font-size:10px;color:rgba(255,255,255,.6);margin-top:2px}
.vis-hero-badge{position:absolute;top:12px;right:12px;background:rgba(0,0,0,.65);
                backdrop-filter:blur(8px);border-radius:5px;padding:4px 10px;
                font-size:9px;letter-spacing:.1em;text-transform:uppercase;
                color:var(--text3);border:1px solid var(--border)}
.vis-nav{position:absolute;top:50%;transform:translateY(-50%);width:100%;
         padding:0 10px;display:flex;justify-content:space-between;pointer-events:none}
.vis-nav-btn{pointer-events:all;background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.15);
             color:#fff;border-radius:5px;width:32px;height:32px;cursor:pointer;font-size:14px;
             display:flex;align-items:center;justify-content:center;
             backdrop-filter:blur(5px);transition:background .2s}
.vis-nav-btn:hover{background:rgba(255,107,0,.6)}
.vis-dots{position:absolute;bottom:44px;left:50%;transform:translateX(-50%);
          display:flex;gap:5px}
.vis-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.3);
         cursor:pointer;transition:background .2s,transform .2s}
.vis-dot.active{background:var(--orange);transform:scale(1.3)}
.vis-thumbs{display:flex;gap:7px;overflow-x:auto;padding-bottom:4px;margin-bottom:20px;
            scrollbar-width:thin;scrollbar-color:var(--orange) transparent}
.vis-thumb{flex-shrink:0;border-radius:5px;overflow:hidden;
           border:2px solid transparent;cursor:pointer;transition:border-color .2s;
           width:64px;height:42px}
.vis-thumb canvas{width:100%;height:100%;display:block}
.vis-thumb.active{border-color:var(--orange)}
.vis-grid-label{font-family:var(--display);font-size:12px;letter-spacing:.12em;
                color:var(--text3);margin-bottom:10px;display:block}
.vis-sys-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:20px}
.vis-sys-card{border-radius:8px;overflow:hidden;border:1.5px solid var(--border);
              cursor:pointer;transition:border-color .2s}
.vis-sys-card:hover{border-color:rgba(255,107,0,.4)}
.vis-sys-card.active{border-color:var(--orange)}
.vis-sys-card canvas{display:block;width:100%}
.vis-sys-info{padding:7px 9px;background:rgba(0,0,0,.4)}
.vis-sys-name{font-size:11px;font-weight:600;color:var(--text2);display:block}
.vis-sys-card.active .vis-sys-name{color:var(--orange2)}
.vis-sys-sub{font-size:9px;color:var(--text3);display:block}
.vis-fin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.vis-fin-card{border-radius:8px;overflow:hidden;border:1.5px solid var(--border);
              transition:border-color .2s}
.vis-fin-card.active{border-color:var(--orange)}
.vis-fin-card canvas{display:block;width:100%}
.vis-fin-info{padding:6px 9px;background:rgba(0,0,0,.4);font-size:10px;
              font-weight:600;color:var(--text2);text-transform:capitalize;display:block}
.vis-fin-card.active .vis-fin-info{color:var(--orange2)}

/* Quote panel */
.quote-header{display:flex;gap:18px;align-items:flex-start;margin-bottom:22px;flex-wrap:wrap}
.quote-title{font-family:var(--display);font-size:30px;letter-spacing:.08em;
             color:#fff;display:block}
.quote-company{font-size:10px;letter-spacing:.16em;color:var(--text3);
               text-transform:uppercase;margin-top:4px;display:block}
.quote-swatch{display:flex;gap:12px;align-items:center}
.quote-swatch-canvas{width:56px;height:56px;border-radius:7px;overflow:hidden;
                     border:1px solid var(--border);flex-shrink:0}
.quote-swatch-canvas canvas{width:100%;height:100%;display:block}
.quote-swatch-name{font-weight:600;font-size:14px;display:block}
.quote-swatch-detail{font-size:11px;color:var(--text3);margin-top:2px;display:block}
.breakdown-card{background:var(--bg3);border:1px solid var(--border);
                border-radius:var(--r);padding:20px 24px;margin-bottom:12px}
.breakdown-label{font-family:var(--display);font-size:11px;letter-spacing:.16em;
                 color:var(--text3);margin-bottom:12px;display:block}
.breakdown-row{display:flex;justify-content:space-between;align-items:center;
               padding:9px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.breakdown-row:last-of-type{border-bottom:none}
.breakdown-row-name{font-size:12px;color:var(--text2)}
.breakdown-row-val{font-family:var(--mono);font-size:13px;color:var(--text)}
.breakdown-total{display:flex;justify-content:space-between;align-items:center;
                 padding-top:14px;margin-top:8px;border-top:1px solid rgba(255,255,255,.09)}
.breakdown-total-label{font-family:var(--display);font-size:18px;letter-spacing:.1em}
.breakdown-total-val{font-family:var(--mono);font-size:22px;color:var(--orange)}
.quote-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.metric-card{background:var(--bg3);border:1px solid var(--border);
             border-radius:var(--r);padding:12px 14px}
.metric-label{font-size:9px;letter-spacing:.1em;text-transform:uppercase;
              color:var(--text3);margin-bottom:3px;display:block}
.metric-value{font-family:var(--mono);font-size:13px;color:var(--text);display:block}
.quote-disclaimer{background:rgba(255,107,0,.05);border:1px solid rgba(255,107,0,.18);
                  border-radius:var(--r);padding:12px 16px;font-size:11px;
                  color:var(--text3);line-height:1.7;margin-bottom:12px}
.quote-disclaimer strong{color:var(--orange2)}
.quote-empty{text-align:center;padding:60px 20px;color:var(--text3)}
.quote-empty-icon{font-size:44px;margin-bottom:14px;display:block}
.quote-empty-title{font-family:var(--display);font-size:20px;letter-spacing:.1em;
                   color:var(--text2);margin-bottom:8px;display:block}
.quote-cta{background:linear-gradient(135deg,rgba(255,107,0,.08),rgba(26,127,255,.04));
           border:1px solid rgba(255,107,0,.18);border-radius:var(--r);
           padding:18px 22px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.quote-cta-txt{flex:1}
.quote-cta-title{font-weight:600;font-size:13px;margin-bottom:2px;display:block}
.quote-cta-sub{font-size:11px;color:var(--text3);display:block}

/* Price bar */
.price-bar{background:rgba(9,10,13,.97);border-top:1px solid rgba(255,107,0,.22);
           padding:10px 28px;display:flex;align-items:center}
.price-bar[hidden]{display:none}
.pb-stats{flex:1;display:flex;gap:24px;flex-wrap:wrap}
.pb-label{display:block;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--text3)}
.pb-value{display:block;font-family:var(--mono);font-size:14px;color:var(--text2);margin-top:1px}
.pb-value.accent{color:var(--orange2)}
.pb-total-label{display:block;font-size:9px;letter-spacing:.12em;
                text-transform:uppercase;color:var(--text3)}
.pb-total-value{display:block;font-family:var(--display);font-size:26px;
                letter-spacing:.06em;color:var(--orange);line-height:1}

/* ── TESTIMONIALS ────────────────────────────────────────────────────────── */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.testi-card{background:var(--bg3);border:1px solid var(--border);
            border-radius:var(--r);padding:28px}
.testi-stars{color:var(--orange);font-size:14px;letter-spacing:2px;margin-bottom:16px;display:block}
.testi-card blockquote p{font-size:13px;color:var(--text2);line-height:1.7;
                         font-style:italic;margin-bottom:20px}
.testi-card footer strong{display:block;font-size:12px;font-weight:600;color:var(--text)}
.testi-card footer span{font-size:11px;color:var(--text3);margin-top:2px;display:block}

/* ── FAQ ─────────────────────────────────────────────────────────────────── */
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{display:flex;justify-content:space-between;align-items:center;width:100%;
       padding:20px 0;background:none;border:none;cursor:pointer;font-size:15px;
       font-weight:500;color:var(--text);text-align:left;gap:16px;transition:color .2s}
.faq-q:hover{color:var(--orange)}
.faq-icon{flex-shrink:0;width:24px;height:24px;border-radius:50%;
          border:1px solid var(--border2);display:flex;align-items:center;
          justify-content:center;font-size:14px;color:var(--text3);
          transition:background .2s,border-color .2s,color .2s,transform .25s}
.faq-item.open .faq-icon{background:var(--orange);border-color:var(--orange);
                         color:#fff;transform:rotate(45deg)}
.faq-a{padding-bottom:20px;font-size:13px;color:var(--text2);line-height:1.7}
.faq-a[hidden]{display:none}

/* ── CONTACT ─────────────────────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-info h2{margin-bottom:16px}
.contact-desc{font-size:14px;color:var(--text2);line-height:1.7;margin-bottom:36px}
.contact-details{display:flex;flex-direction:column;gap:16px}
.contact-item{display:flex;align-items:flex-start;gap:14px}
.contact-icon{width:40px;height:40px;border-radius:8px;background:var(--orange-tint);
              border:1px solid rgba(255,107,0,.2);display:flex;align-items:center;
              justify-content:center;font-size:16px;flex-shrink:0}
.contact-value{display:block;font-weight:500;font-size:14px;color:var(--text);transition:color .2s}
.contact-value:hover{color:var(--orange)}
.contact-sub{display:block;font-size:11px;color:var(--text3);margin-top:2px}
.contact-form .form-group{margin-bottom:14px}
.form-label{display:block;font-size:10px;letter-spacing:.12em;text-transform:uppercase;
            font-weight:600;color:var(--text3);margin-bottom:7px}
.optional{font-weight:400;letter-spacing:0;text-transform:none}
.form-input{width:100%;background:rgba(255,255,255,.05);border:1.5px solid var(--border);
            border-radius:8px;color:var(--text);padding:12px 16px;font-size:14px;
            outline:none;transition:border-color .2s;appearance:none;-webkit-appearance:none}
.form-input:focus{border-color:var(--orange)}
.form-input::placeholder{color:var(--text3)}
.form-textarea{resize:vertical;min-height:110px}
select.form-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2350505e' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
                  background-repeat:no-repeat;background-position:right 14px center;
                  padding-right:36px;cursor:pointer}
select.form-input option{background:#1e2230}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-note{font-size:11px;color:var(--text3);text-align:center;margin-top:10px;display:block}

/* ── FOOTER ──────────────────────────────────────────────────────────────── */
#site-footer{background:var(--bg);border-top:1px solid var(--border);padding:60px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand .footer-logo{display:flex;align-items:baseline;gap:8px;margin-bottom:14px}
.footer-tagline{font-size:13px;color:var(--text3);line-height:1.6;max-width:260px}
.footer-col-title{font-size:10px;letter-spacing:.16em;text-transform:uppercase;
                  font-weight:600;color:var(--text3);margin-bottom:16px;display:block}
#site-footer nav ul,
#site-footer div > ul{display:flex;flex-direction:column;gap:10px}
#site-footer a{font-size:13px;color:var(--text3);transition:color .2s}
#site-footer a:hover{color:var(--orange)}
.footer-bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;
               justify-content:space-between;align-items:center;flex-wrap:wrap;
               gap:12px;font-size:11px;color:var(--text3)}
.footer-certs{display:flex;gap:8px;flex-wrap:wrap}
.cert{background:var(--bg3);border:1px solid var(--border);border-radius:4px;
      padding:4px 10px;font-size:10px;letter-spacing:.08em;display:inline-block}

/* ── RESPONSIVE ──────────────────────────────────────────────────────────── */
@media (max-width: 1080px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}

@media (max-width: 960px) {
  :root { --pad: 72px; }
  .hero-grid          { grid-template-columns: 1fr; gap: 40px; padding: 60px 0; }
  .hero-visual        { order: -1; }
  .services-grid      { grid-template-columns: 1fr 1fr; }
  .proc-step          { grid-template-columns: 60px 1fr; }
  .proc-step-duration { display: none; }
  .spaces-grid        { grid-template-columns: 1fr 1fr; }
  .cities-grid        { grid-template-columns: repeat(4,1fr); }
  .testi-grid         { grid-template-columns: 1fr; }
  .contact-grid       { grid-template-columns: 1fr; }
  .sys-grid           { grid-template-columns: 1fr 1fr; }
  .vis-sys-grid       { grid-template-columns: 1fr 1fr; }
  .quote-metrics      { grid-template-columns: 1fr 1fr; }

.cmp-specs-grid    { grid-template-columns: 1fr 1fr; }
  .cmp-pc-grid       { grid-template-columns: 1fr 1fr; }
  .cmp-verdict-grid  { grid-template-columns: 1fr 1fr; }
}


@media (max-width: 720px) {
  .cities-grid        { grid-template-columns: 1fr 1fr; }
  .footer-grid        { grid-template-columns: 1fr 1fr; }

.cmp-hero                { grid-template-columns: 1fr; grid-template-rows: 1fr auto 1fr; }
  .cmp-vs                  { width: 100%; height: 40px; border: none;
                             border-top: 1px solid var(--border);
                             border-bottom: 1px solid var(--border); }
  .cmp-specs-grid          { grid-template-columns: 1fr; }
  .cmp-pc-grid             { grid-template-columns: 1fr; }
  .cmp-verdict-grid        { grid-template-columns: 1fr; }
  .cmp-cta                 { flex-direction: column; align-items: flex-start; }
}


@media (max-width: 640px) {
  :root { --pad: 56px; }
  .wrap               { padding: 0 16px; }
  .nav-links, .nav-cta { display: none; }
  .nav-toggle         { display: flex; }
  .hero-grid          { padding: 48px 0; }
  .hero-actions       { flex-direction: column; }
  .hero-actions .btn  { text-align: center; }
  .hero-stats         { gap: 16px; }
  .services-grid      { grid-template-columns: 1fr; }
  .spaces-grid        { grid-template-columns: 1fr; }
  .proc-step          { grid-template-columns: 48px 1fr; }
  .proc-step-card     { margin-left: 12px; padding: 18px 16px; }
  .proc-step-num      { width: 36px; height: 36px; font-size: 14px; }
  .proc-step-title    { font-size: 20px; }
  .proc-step-lead     { font-size: 13px; }
  .proc-moisture-block { padding: 16px; }
  .moisture-header    { flex-direction: column; gap: 6px; }
  .process-cta        { flex-direction: column; align-items: flex-start; }
  .est-tabs           { padding: 0 12px; }
  .est-tab            { padding: 11px 12px; font-size: 10px; }
  .est-panel          { padding: 20px 16px; }
  .resin-grid         { grid-template-columns: 1fr; }
  .sys-grid           { grid-template-columns: 1fr 1fr; }
  .field-row          { grid-template-columns: 1fr; }
  .vis-sys-grid       { grid-template-columns: 1fr 1fr; }
  .vis-fin-grid       { grid-template-columns: 1fr 1fr; }
  .quote-metrics      { grid-template-columns: 1fr 1fr; }
  .quote-header       { flex-direction: column; }
  .price-bar          { padding: 8px 14px; }
  .pb-stats           { gap: 12px; }
  .form-row           { grid-template-columns: 1fr; }
  .footer-grid        { grid-template-columns: 1fr; }
  .footer-bottom      { flex-direction: column; align-items: flex-start; }
  .testi-grid         { grid-template-columns: 1fr; }
  .cities-grid        { grid-template-columns: 1fr 1fr; }
  .est-cta-row        { flex-direction: column; align-items: flex-start; }

.cmp-pc-grid             { grid-template-columns: 1fr; }
}


@media (max-width: 420px) {
  .sys-grid  { grid-template-columns: 1fr; }
  .hero-canvas-grid { gap: 4px; }
}

@media print {
  #site-header, .no-print { display: none !important; }
}


/* ── EPOXY vs POLYASPARTIC COMPARISON ────────────────────────────────────── */

/* Hero visual split */
.cmp-hero {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 0;
  align-items: stretch;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 40px;
  box-shadow: 0 24px 64px rgba(0,0,0,.5), 0 0 0 1px var(--border);
  min-height: 320px;
}

.cmp-hero-card {
  position: relative;
  overflow: hidden;
  min-height: 320px;
}

.cmp-canvas-wrap {
  position: relative;
  width: 100%;
  height: 320px;
}
.cmp-canvas-wrap canvas {
  display: block;
  width: 100%;
  height: 320px;
}

.cmp-canvas-tint {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.65) 0%, rgba(0,0,0,.1) 60%, transparent 100%);
  pointer-events: none;
  z-index: 1;
}
.cmp-canvas-tint--poly {
  background: linear-gradient(to top, rgba(255,107,0,.25) 0%, rgba(0,0,0,.1) 60%, transparent 100%);
}

.cmp-canvas-caption {
  position: absolute;
  bottom: 16px;
  left: 18px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  z-index: 2;
}

.cmp-badge {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  align-self: flex-start;
}
.cmp-badge--epoxy { background: rgba(26,127,255,.25); color: #7ab8ff; border: 1px solid rgba(26,127,255,.4); }
.cmp-badge--poly  { background: rgba(255,107,0,.25);  color: #ffb070; border: 1px solid rgba(255,107,0,.4); }

.cmp-canvas-tag {
  font-size: 22px;
  font-family: var(--display);
  letter-spacing: .08em;
  color: #fff;
  display: block;
}

/* VS divider */
.cmp-vs {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  background: var(--bg);
  font-family: var(--display);
  font-size: 18px;
  letter-spacing: .12em;
  color: var(--text3);
  border-left: 1px solid var(--border);
  border-right: 1px solid var(--border);
  flex-shrink: 0;
}

/* Specs grid */
.cmp-specs-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 28px;
}

.cmp-spec-col {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 22px 24px;
}

.cmp-spec-col--epoxy { border-top: 3px solid var(--blue); }
.cmp-spec-col--poly  { border-top: 3px solid var(--orange); }

.cmp-spec-heading {
  font-family: var(--display);
  font-size: 22px;
  letter-spacing: .08em;
  color: #fff;
  margin-bottom: 16px;
}
.cmp-spec-col--epoxy .cmp-spec-heading { color: #7ab8ff; }
.cmp-spec-col--poly  .cmp-spec-heading { color: var(--orange2); }

.cmp-spec-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.cmp-spec-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
  font-size: 13px;
}
.cmp-spec-row:last-child { border-bottom: none; }

.cmp-spec-row dt {
  color: var(--text3);
  font-size: 11px;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-weight: 600;
  flex-shrink: 0;
}

.cmp-spec-row dd {
  color: var(--text2);
  text-align: right;
  line-height: 1.4;
}

.cmp-spec-price dd {
  font-family: var(--mono);
  color: var(--orange2);
  font-size: 12px;
}

/* Pros & Cons grid — 2×2 */
.cmp-pc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 12px;
  margin-bottom: 28px;
}

.cmp-pc-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 20px 22px;
}

/* Epoxy pair — left column */
.cmp-pc--epoxy { border-left: 3px solid var(--blue); }
/* Poly pair — right column */
.cmp-pc--poly  { border-left: 3px solid var(--orange); }

.cmp-pc-pros .cmp-pc-header { margin-bottom: 12px; }
.cmp-pc-cons .cmp-pc-header { margin-bottom: 12px; }

.cmp-pc-header {
  display: flex;
  align-items: center;
  gap: 8px;
}

.cmp-pc-icon {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}

.cmp-pc-pros .cmp-pc-icon { background: rgba(34,197,94,.15); color: var(--green); }
.cmp-pc-cons .cmp-pc-icon { background: rgba(239,68,68,.12); color: var(--red); }

.cmp-pc-title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text2);
}

.cmp-pc-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cmp-pc-list li {
  font-size: 12px;
  color: var(--text2);
  line-height: 1.55;
  padding-left: 14px;
  position: relative;
}

.cmp-pc-pros .cmp-pc-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--green);
  font-size: 10px;
  top: 1px;
}

.cmp-pc-cons .cmp-pc-list li::before {
  content: '✗';
  position: absolute;
  left: 0;
  color: var(--red);
  font-size: 10px;
  top: 1px;
}

/* Best-for verdict row */
.cmp-verdict-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 28px;
}

.cmp-verdict {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 20px 22px;
}

.cmp-verdict--epoxy { border-top: 2px solid var(--blue); }
.cmp-verdict--poly  { border-top: 2px solid var(--orange); }

.cmp-verdict-icon {
  font-size: 26px;
  flex-shrink: 0;
  margin-top: 2px;
}

.cmp-verdict-title {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 8px;
}
.cmp-verdict--epoxy .cmp-verdict-title { color: #7ab8ff; }
.cmp-verdict--poly  .cmp-verdict-title { color: var(--orange2); }

.cmp-verdict-body {
  font-size: 13px;
  color: var(--text2);
  line-height: 1.65;
}

/* CTA row */
.cmp-cta {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  background: linear-gradient(135deg, rgba(255,107,0,.08), rgba(26,127,255,.05));
  border: 1px solid rgba(255,107,0,.2);
  border-radius: var(--r);
  padding: 22px 28px;
}

.cmp-cta-text {
  flex: 1;
  font-size: 13px;
  color: var(--text2);
  line-height: 1.6;
  min-width: 200px;
}

/* =============================================================================
   NIA COATINGS — SEO ENHANCEMENTS: Additional section styles
   ============================================================================= */

/* ── TRUST BAR ──────────────────────────────────────────────────────────────── */
.trust-bar {
  background: var(--bg2);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 18px 0;
}
.trust-bar-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
  row-gap: 12px;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 28px;
}
.trust-item strong { display: block; font-size: .875rem; font-weight: 600; color: var(--text); }
.trust-item span   { display: block; font-size: .75rem;  color: var(--text2); }
.trust-icon { font-size: 1.25rem; }
.trust-divider { width: 1px; height: 36px; background: var(--border2); flex-shrink: 0; }
@media (max-width: 600px) { .trust-divider { display: none; } .trust-item { padding: 0 16px; } }

/* ── WHY NIA GRID ──────────────────────────────────────────────────────────── */
.why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 56px;
}
@media (max-width: 900px) { .why-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .why-grid { grid-template-columns: 1fr; } }

.why-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 32px 28px;
  transition: border-color .25s, transform .25s;
}
.why-card:hover {
  border-color: var(--orange);
  transform: translateY(-3px);
}
.why-icon { font-size: 2rem; margin-bottom: 16px; }
.why-title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 10px;
}
.why-body { font-size: .875rem; color: var(--text2); line-height: 1.7; }

/* ── COST GUIDE ─────────────────────────────────────────────────────────────── */
.cost-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 56px;
}
@media (max-width: 900px) { .cost-grid { grid-template-columns: 1fr; max-width: 520px; margin-inline: auto; } }

.cost-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.cost-card--popular {
  border-color: var(--orange);
  background: linear-gradient(135deg, rgba(255,107,0,.06) 0%, var(--bg2) 100%);
  position: relative;
}
.cost-card--popular::before {
  content: 'Most Requested';
  position: absolute;
  top: -1px; right: 24px;
  background: var(--orange);
  color: #fff;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 0 0 6px 6px;
}
.cost-card-header { display: flex; align-items: center; gap: 16px; }
.cost-space-icon  { font-size: 2rem; }
.cost-space-tag   { font-size: .7rem; text-transform: uppercase; letter-spacing: .1em; color: var(--orange); font-weight: 600; margin-bottom: 4px; }
.cost-space-name  { font-size: 1.05rem; font-weight: 600; color: var(--text); }
.cost-sizes       { display: flex; flex-direction: column; gap: 10px; }
.cost-size-row    { display: flex; justify-content: space-between; align-items: center; gap: 12px; border-bottom: 1px solid var(--border); padding-bottom: 10px; }
.cost-size-row:last-child { border-bottom: none; padding-bottom: 0; }
.cost-size-label  { font-size: .8rem; color: var(--text2); }
.cost-size-range  { font-size: .875rem; font-weight: 600; color: var(--text); white-space: nowrap; }
.cost-rate        { font-size: .8rem; color: var(--text2); }
.cost-rate strong { color: var(--orange); }
.cost-note {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 20px 24px;
  margin-top: 32px;
  font-size: .85rem;
  color: var(--text2);
  line-height: 1.7;
}
.cost-note-icon { font-size: 1.2rem; flex-shrink: 0; margin-top: 1px; }
.cost-note strong { color: var(--text); }

/* ── SPACES — enhanced with CTA ─────────────────────────────────────────────── */
.spaces-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 56px;
}
@media (max-width: 1000px) { .spaces-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .spaces-grid { grid-template-columns: 1fr; } }

.space-cta {
  display: inline-block;
  margin-top: 16px;
  font-size: .8rem;
  font-weight: 600;
  color: var(--orange);
  letter-spacing: .03em;
  transition: color .2s;
}
.space-cta:hover { color: var(--orange2); }

/* reveal-d3 and d5 classes */
.reveal-d3 { transition-delay: .3s !important; }
.reveal-d4 { transition-delay: .4s !important; }
.reveal-d5 { transition-delay: .5s !important; }

/* ── CITIES — detailed cards ─────────────────────────────────────────────────── */
.cities-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 56px;
}
@media (max-width: 1000px) { .cities-detail-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .cities-detail-grid { grid-template-columns: 1fr; } }

.city-detail-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: border-color .25s, transform .2s;
}
.city-detail-card:hover { border-color: var(--orange); transform: translateY(-2px); }
.city-detail-card--featured {
  border-color: var(--orange);
  background: linear-gradient(135deg, rgba(255,107,0,.07) 0%, var(--bg2) 100%);
  grid-column: span 1;
}
.city-detail-name   { font-size: 1.15rem; font-weight: 700; color: var(--text); }
.city-detail-region { font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; color: var(--orange); font-weight: 600; }
.city-detail-desc   { font-size: .84rem; color: var(--text2); line-height: 1.65; }
.city-detail-services { display: flex; flex-direction: column; gap: 6px; flex: 1; }
.city-detail-services li { font-size: .8rem; color: var(--text2); }
.city-cta-link {
  font-size: .8rem;
  font-weight: 600;
  color: var(--orange);
  letter-spacing: .03em;
  transition: color .2s;
  align-self: flex-start;
}
.city-cta-link:hover { color: var(--orange2); }

/* ── TESTIMONIALS — 6-up grid ────────────────────────────────────────────────── */
.testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
}
@media (max-width: 900px) { .testi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .testi-grid { grid-template-columns: 1fr; } }

/* ── CONTACT — additions ─────────────────────────────────────────────────────── */
.contact-certs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 24px;
}
.contact-certs .cert {
  font-size: .75rem;
  font-weight: 600;
  padding: 5px 12px;
  border-radius: 20px;
  background: rgba(34,197,94,.12);
  color: #22c55e;
  border: 1px solid rgba(34,197,94,.25);
}

/* ── FOOTER — enhanced ───────────────────────────────────────────────────────── */
.footer-contact-quick {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 16px;
}
.footer-phone, .footer-email {
  font-size: .875rem;
  color: var(--text2);
  transition: color .2s;
}
.footer-phone:hover, .footer-email:hover { color: var(--orange); }

/* ── STICKY CTA BAR (mobile) ────────────────────────────────────────────────── */
.sticky-cta {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 900;
  background: var(--bg2);
  border-top: 1px solid var(--border2);
  padding: 12px 20px;
  gap: 10px;
  box-shadow: 0 -8px 32px rgba(0,0,0,.4);
}
@media (max-width: 768px) { .sticky-cta { display: flex; } }
.sticky-cta a {
  flex: 1;
  text-align: center;
  padding: 13px 12px;
  border-radius: 8px;
  font-size: .875rem;
  font-weight: 600;
  text-decoration: none;
}
.sticky-cta-call {
  background: var(--orange);
  color: #fff;
}
.sticky-cta-form {
  background: var(--bg3);
  color: var(--text);
  border: 1px solid var(--border2);
}

/* ── Quote table (JS-rendered) ────────────────────────────── */
.quote-logo{font-family:var(--display);font-size:22px;letter-spacing:.12em;color:var(--orange);margin-bottom:4px}
.quote-meta{display:flex;flex-wrap:wrap;gap:8px 18px;font-size:11px;color:var(--text3);margin-bottom:18px}
.quote-table{width:100%;border-collapse:collapse;margin-bottom:18px;font-size:13px}
.quote-table th{text-align:left;padding:8px 10px;background:rgba(255,107,0,.08);color:var(--text3);font-weight:600;font-size:10px;letter-spacing:.12em;text-transform:uppercase;border-bottom:1px solid var(--border)}
.quote-table td{padding:9px 10px;border-bottom:1px solid rgba(255,255,255,.05);color:var(--text2)}
.quote-table td:last-child{text-align:right;font-variant-numeric:tabular-nums}
.quote-table th:last-child{text-align:right}
.quote-row-sub td{border-top:1px solid var(--border);color:var(--text1);padding-top:12px}
.quote-row-total td{background:rgba(255,107,0,.08);color:var(--orange2);font-size:15px;padding:12px 10px;border-top:2px solid rgba(255,107,0,.3)}
.quote-note{font-size:12px;color:var(--text3);line-height:1.6;margin-bottom:18px;padding:12px;background:rgba(255,107,0,.04);border-left:3px solid rgba(255,107,0,.3);border-radius:0 4px 4px 0}
.quote-note a{color:var(--orange)}
a.quote-cta{display:inline-block;margin-top:4px;padding:13px 28px;background:linear-gradient(135deg,var(--orange),#e55a00);color:#fff;font-weight:700;font-size:14px;border-radius:6px;text-decoration:none;letter-spacing:.03em}
a.quote-cta:hover{opacity:.9}

/* ── Visualizer thumb canvases ────────────────────────────── */
.vis-thumb-canvas{width:100%;height:90px;display:block;border-radius:5px;overflow:hidden}
#vis-sys-grid canvas{border-radius:5px;cursor:pointer;border:2px solid transparent;transition:border-color .2s}
#vis-sys-grid canvas:hover{border-color:var(--orange)}

/* ── Form success ─────────────────────────────────────────── */
.form-success{text-align:center;padding:48px 24px}
.form-success-icon{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;background:rgba(255,107,0,.15);color:var(--orange);font-size:28px;margin-bottom:18px}
.form-success h3{font-family:var(--display);font-size:26px;letter-spacing:.1em;margin-bottom:10px;color:var(--text1)}
.form-success p{font-size:14px;color:var(--text2);line-height:1.6}

/* ── XPS Certification card — featured highlight ─────────── */
.why-card--featured {
  border-color: rgba(255,107,0,0.45);
  background: linear-gradient(135deg, rgba(255,107,0,0.08), rgba(255,107,0,0.03));
  position: relative;
}
.why-card--featured::before {
  content: 'CERTIFIED';
  position: absolute;
  top: -1px;
  right: 16px;
  background: var(--orange);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .14em;
  padding: 3px 8px;
  border-radius: 0 0 5px 5px;
}
.why-card--featured .why-title { color: var(--orange2); }

/* ══════════════════════════════════════════════════════════
   COMMERCIAL METALLIC DESIGNS SECTION
   ══════════════════════════════════════════════════════════ */

.metallic-designs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
}

.metallic-design-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color .25s, transform .25s;
}
.metallic-design-card:hover {
  border-color: rgba(255,107,0,.4);
  transform: translateY(-4px);
}

/* Canvas preview */
.metallic-design-canvas-wrap {
  position: relative;
  height: 190px;
  overflow: hidden;
}
.metallic-design-canvas {
  display: block;
  width: 100%;
  height: 100%;
}
.metallic-design-canvas-wrap:hover .metallic-design-canvas {
  transform: scale(1.04);
  transition: transform .5s ease;
}

/* Badge */
.metallic-design-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--orange);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 4px;
}
.metallic-design-badge--green  { background: #1a7a3a; }
.metallic-design-badge--purple { background: #6b2fa0; }
.metallic-design-badge--copper { background: #b5541a; }
.metallic-design-badge--white  { background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.3); color: #fff; backdrop-filter: blur(4px); }

/* Body */
.metallic-design-body {
  padding: 22px 20px 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.metallic-design-name {
  font-family: var(--display);
  font-size: 22px;
  letter-spacing: .1em;
  color: var(--text1);
  margin-bottom: 4px;
}
.metallic-design-tagline {
  font-size: 11px;
  color: var(--orange);
  letter-spacing: .06em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 12px;
}
.metallic-design-desc {
  font-size: 13px;
  color: var(--text2);
  line-height: 1.7;
  margin-bottom: 18px;
  flex: 1;
}

/* Spec list */
.metallic-design-specs {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  border-top: 1px solid var(--border);
  padding-top: 14px;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.metallic-design-specs li {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
}
.spec-label { color: var(--text3); }
.spec-val   { color: var(--text2); font-weight: 500; text-align: right; }

/* CTA link */
.metallic-design-cta {
  display: block;
  text-align: center;
  padding: 11px 16px;
  background: rgba(255,107,0,.1);
  border: 1px solid rgba(255,107,0,.3);
  border-radius: 6px;
  color: var(--orange2);
  font-weight: 600;
  font-size: 13px;
  text-decoration: none;
  transition: background .2s, border-color .2s;
  margin-top: auto;
}
.metallic-design-cta:hover {
  background: rgba(255,107,0,.2);
  border-color: var(--orange);
}

/* Bottom CTA strip */
.metallic-cta-strip {
  margin-top: 48px;
  padding: 32px;
  background: linear-gradient(135deg, rgba(255,107,0,.07), rgba(255,107,0,.03));
  border: 1px solid rgba(255,107,0,.2);
  border-radius: 12px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.metallic-cta-strip p {
  flex: 1;
  min-width: 220px;
  font-size: 14px;
  color: var(--text2);
  margin: 0;
}
.metallic-cta-strip .btn { white-space: nowrap; }

/* Responsive */
@media (max-width: 1024px) {
  .metallic-designs-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .metallic-designs-grid { grid-template-columns: 1fr; }
  .metallic-cta-strip    { flex-direction: column; text-align: center; }
  .metallic-design-canvas-wrap { height: 160px; }
}
