/* PALMER'S CONCRETE COATINGS - Industrial Polish design system
   Boring, OR  ·  (503) 766-9199 */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..900;1,9..144,300..900&family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  --pe-navy:#0A0A0A; --pe-navy-2:#000000; --pe-navy-h:#1F1F1F;
  --pe-cream:#FFFFFF; --pe-cream-2:#F2F2F2; --pe-off:#FAFAFA;
  --pe-blue:#2E7BD8; --pe-blue-deep:#1A5BAA; --pe-blue-soft:#9EC5EE;
  --pe-blue-bright:#C2DCF1; --pe-ink:#07090C; --pe-steel:#5C6670; --pe-rust:#404040;
  --font-display:'Fraunces','Playfair Display','Georgia',serif;
  --font-body:'Inter','Helvetica Neue',system-ui,sans-serif;
  --font-mono:'JetBrains Mono','Menlo',monospace;
  --shadow-card:0 2px 0 var(--pe-ink),0 14px 34px rgba(7,9,12,.22);
  --shadow-heavy:0 4px 0 var(--pe-ink),0 24px 60px rgba(7,9,12,.34);
  --shadow-cop:10px 10px 0 var(--pe-blue);
  --shadow-cha:10px 10px 0 var(--pe-navy);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-weight:400;font-size:17px;line-height:1.6;color:var(--pe-ink);background:var(--pe-cream);overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1280px;margin:0 auto;padding:0 28px}
.wrap-wide{max-width:1480px;margin:0 auto;padding:0 28px}
.italic{font-style:italic;font-weight:400}

.topbar{background:var(--pe-navy);color:var(--pe-cream);font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08);position:relative;z-index:10}
.topbar .row{display:flex;align-items:center;justify-content:space-between;max-width:1480px;margin:0 auto;padding:0 28px;gap:20px}
.topbar .tb-left{display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.topbar .tb-left span{display:inline-flex;align-items:center;gap:8px;opacity:.9}
.topbar .tb-dot{width:6px;height:6px;background:var(--pe-blue);border-radius:50%;box-shadow:0 0 10px var(--pe-blue);animation:pulse 2.4s ease-in-out infinite}
.topbar .tb-phone{color:var(--pe-blue);font-weight:600}
.topbar .tb-phone:hover{color:var(--pe-blue-soft)}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.85)}}

.anno{background:var(--pe-ink);color:var(--pe-cream);font-family:var(--font-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;padding:10px 0;overflow:hidden;white-space:nowrap;position:relative;z-index:9}
.anno-track{display:inline-flex;gap:60px;padding-right:60px;animation:marquee 42s linear infinite}
.anno-track span{display:inline-flex;align-items:center;gap:14px}
.anno-track b{color:var(--pe-blue);font-weight:600}
.anno-dot{width:6px;height:6px;background:var(--pe-blue);border-radius:50%}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

header.site{background:var(--pe-cream);color:var(--pe-navy);position:sticky;top:0;z-index:50;border-bottom:3px solid var(--pe-navy);transition:box-shadow .25s,background .25s}
header.site.scrolled{box-shadow:0 6px 30px rgba(7,9,12,.18)}
.nav-row{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;max-width:1480px;margin:0 auto;gap:20px}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:56px;height:56px;border-radius:12px;display:grid;place-items:center;background:var(--pe-navy);padding:6px;box-shadow:0 2px 0 var(--pe-blue);overflow:hidden}
.brand-mark img{width:100%;height:100%;object-fit:contain;display:block;filter:brightness(1.4) contrast(1.1)}
.brand-type{line-height:1}
.brand-type .big{font-family:var(--font-display);font-weight:800;font-size:24px;letter-spacing:-.015em;color:var(--pe-navy);display:block}
.brand-type .small{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--pe-blue);margin-top:5px;display:block;font-weight:600}
.nav-links{display:flex;align-items:center;flex-wrap:wrap;gap:2px}
.nav-links a{font-family:var(--font-body);font-size:14px;font-weight:500;padding:10px 14px;position:relative;color:var(--pe-navy);transition:color .2s}
.nav-links a:hover{color:var(--pe-blue)}
.nav-links a.active{color:var(--pe-blue)}
.nav-links a.active::after{content:"";position:absolute;bottom:2px;left:14px;right:14px;height:2px;background:var(--pe-blue)}
.nav-cta{margin-left:10px;display:inline-flex;align-items:center;gap:10px;background:var(--pe-blue);color:var(--pe-cream)!important;padding:12px 22px!important;font-weight:600!important;border-radius:999px;box-shadow:0 2px 0 var(--pe-ink);transition:transform .15s,box-shadow .15s,background .15s}
.nav-cta:hover{background:var(--pe-blue-deep)!important;transform:translateY(-2px);box-shadow:0 4px 0 var(--pe-ink)}
.nav-cta .arrow{transition:transform .2s}
.nav-cta:hover .arrow{transform:translateX(3px)}
.nav-cta::after{display:none!important}
.nav-toggle{display:none;background:transparent;border:2px solid var(--pe-navy);color:var(--pe-navy);padding:8px 14px;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;border-radius:4px}
@media (max-width:1080px){.nav-toggle{display:inline-block}.nav-links{display:none;width:100%;padding:18px 0 26px;background:var(--pe-cream-2);flex-direction:column;align-items:stretch;gap:0}.nav-links.open{display:flex}.nav-links a{padding:14px 28px;font-size:16px}.nav-links a.active::after{left:28px;right:auto;width:40px}.nav-cta{margin:14px 28px 0!important;justify-content:center}}

.hero{position:relative;overflow:hidden;isolation:isolate;color:var(--pe-cream);background:var(--pe-navy-2);min-height:92vh}
.hero-bg{position:absolute;inset:0;z-index:0;background-image:url('/images/hero-garage.jpg');background-size:cover;background-position:center;filter:saturate(1.05) contrast(1.1);transform:scale(1.08);animation:heroZoom 22s ease-in-out infinite alternate}
@keyframes heroZoom{from{transform:scale(1.05) translateY(0)}to{transform:scale(1.14) translateY(-12px)}}
.hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(135deg,rgba(0,0,0,.94) 0%,rgba(10,10,10,.78) 45%,rgba(7,9,12,.94) 100%),radial-gradient(ellipse at 20% 50%,rgba(46,123,216,.16) 0%,transparent 60%)}
.hero-grid{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.07;background-image:linear-gradient(rgba(255,255,255,1) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,1) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse at center,#000 30%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 70%)}
.hero-stroke{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.35;mix-blend-mode:screen}
.hero-inner{position:relative;z-index:3;max-width:1480px;margin:0 auto;padding:130px 28px 110px;display:grid;grid-template-columns:1.55fr 1fr;gap:60px;align-items:end}
.hero-eyebrow{display:inline-flex;align-items:center;gap:14px;font-family:var(--font-mono);font-size:12px;letter-spacing:.24em;color:var(--pe-blue);margin-bottom:28px;text-transform:uppercase;font-weight:500}
.hero-eyebrow .line{width:44px;height:1px;background:var(--pe-blue)}
.hero-eyebrow .dot{width:6px;height:6px;background:var(--pe-blue);border-radius:50%}
.hero h1{font-family:var(--font-display);font-weight:800;font-variation-settings:"opsz" 144,"SOFT" 50;font-size:clamp(58px,9.8vw,156px);line-height:.92;letter-spacing:-.028em;color:#FDF9EF;text-shadow:0 2px 28px rgba(7,9,12,.6),0 1px 2px rgba(0,0,0,.45)}
.hero h1 .italic{font-style:italic;font-weight:500;color:var(--pe-blue-soft);font-variation-settings:"opsz" 144,"SOFT" 100;text-shadow:0 2px 24px rgba(0,0,0,.6),0 1px 2px rgba(0,0,0,.4)}
.hero h1 .stroke{position:relative;display:inline-block}
.hero h1 .stroke::after{content:"";position:absolute;left:-4%;right:-4%;bottom:4%;height:18%;background:var(--pe-blue);opacity:.82;z-index:-1;transform:skewY(-1.5deg);border-radius:2px}
.hero-sub{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:clamp(18px,1.7vw,22px);line-height:1.5;margin-top:26px;max-width:560px;color:#F5ECD7;text-shadow:0 1px 12px rgba(7,9,12,.7)}
.hero-cta-row{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-body);font-size:14px;font-weight:600;letter-spacing:.04em;padding:16px 26px;cursor:pointer;border:none;border-radius:999px;transition:transform .15s,box-shadow .15s,background .15s,color .15s}
.btn-cop{background:var(--pe-blue);color:var(--pe-cream);box-shadow:0 3px 0 var(--pe-ink),0 12px 28px rgba(46,123,216,.35)}
.btn-cop:hover{background:var(--pe-blue-deep);transform:translateY(-2px);box-shadow:0 5px 0 var(--pe-ink),0 16px 32px rgba(46,123,216,.45)}
.btn-ghost{background:transparent;color:var(--pe-cream);border:2px solid var(--pe-cream)}
.btn-ghost:hover{background:var(--pe-cream);color:var(--pe-navy)}
.btn-cha{background:var(--pe-navy);color:var(--pe-cream);box-shadow:0 3px 0 var(--pe-ink)}
.btn-cha:hover{background:var(--pe-navy-2);transform:translateY(-2px);box-shadow:0 5px 0 var(--pe-ink)}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(4px)}
.btn-big{padding:18px 30px;font-size:15px}
.hero-card{background:var(--pe-cream);color:var(--pe-ink);padding:32px 30px;align-self:end;position:relative;box-shadow:var(--shadow-heavy);border:1px solid var(--pe-ink);transform:rotate(1deg);max-width:420px}
.hero-card::before{content:"";position:absolute;inset:6px;border:1px solid var(--pe-ink);pointer-events:none}
.hero-card .hc-eyebrow{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--pe-blue);font-weight:600;margin-bottom:6px}
.hero-card h3{font-family:var(--font-display);font-weight:800;font-size:36px;line-height:1;color:var(--pe-navy);margin-bottom:18px;letter-spacing:-.015em}
.hero-card .hc-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px 18px;font-family:var(--font-mono);font-size:13px;border-top:1px dashed var(--pe-ink);padding-top:16px;margin-top:14px}
.hero-card .hc-stats dt{color:var(--pe-navy);font-weight:600;font-size:10px;letter-spacing:.14em;text-transform:uppercase}
.hero-card .hc-stats dd{text-align:right;font-weight:700;color:var(--pe-navy);font-family:var(--font-display)}
.hero-card .seal{position:absolute;top:-28px;right:-28px;width:124px;height:124px;border-radius:50%;background:var(--pe-blue);color:var(--pe-cream);font-family:var(--font-display);font-size:18px;font-weight:800;display:grid;place-items:center;text-align:center;line-height:1;transform:rotate(-10deg);box-shadow:0 6px 14px rgba(0,0,0,.35);border:3px solid var(--pe-cream);padding:10px}
.hero-card .seal small{display:block;font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;margin-top:6px;font-weight:600;line-height:1.2}
@media (max-width:980px){.hero-inner{grid-template-columns:1fr;padding:90px 28px 80px;gap:40px}.hero-card{max-width:100%;transform:rotate(.4deg)}}

.stripe{background:var(--pe-blue);color:var(--pe-cream);padding:14px 0;overflow:hidden;white-space:nowrap;border-top:3px solid var(--pe-ink);border-bottom:3px solid var(--pe-ink);position:relative;z-index:4}
.stripe-track{display:inline-flex;gap:48px;padding-right:48px;animation:marquee 30s linear infinite;font-family:var(--font-display);font-weight:800;font-size:32px;font-style:italic;letter-spacing:-.01em}
.stripe-track span{display:inline-flex;align-items:center;gap:28px}
.stripe-track i{font-style:normal;color:var(--pe-cream);opacity:.55;font-family:var(--font-mono);font-size:22px}

section{position:relative;z-index:2}
.section{padding:110px 0;position:relative}
.section.tight{padding:70px 0}
.section-dark{background:var(--pe-navy);color:var(--pe-cream)}
.section-dark::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.05;background-image:radial-gradient(#fff 1px,transparent 1.3px);background-size:10px 10px}
.section-cream{background:var(--pe-cream-2)}
.section-copper{background:var(--pe-blue-deep);color:var(--pe-cream)}
.section-head{display:grid;grid-template-columns:1fr auto;gap:30px;align-items:end;margin-bottom:60px}
.section-head .eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--pe-blue);font-weight:500;margin-bottom:16px;display:inline-block}
.section-head h2{font-family:var(--font-display);font-weight:800;font-size:clamp(42px,6.5vw,92px);line-height:.92;letter-spacing:-.028em;color:var(--pe-navy)}
.section-dark .section-head h2{color:var(--pe-cream)}
.section-head h2 .italic{font-style:italic;font-weight:400;color:var(--pe-blue)}
.section-head .meta{font-family:var(--font-mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;text-align:right;max-width:300px;border-left:1px solid currentColor;padding-left:22px;opacity:.7}
@media (max-width:780px){.section-head{grid-template-columns:1fr;margin-bottom:40px;gap:16px}.section-head .meta{text-align:left;border-left:0;padding-left:0;border-top:1px solid currentColor;padding-top:14px}}

.svc-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.svc{position:relative;grid-column:span 4;min-height:380px;overflow:hidden;background:var(--pe-navy);color:var(--pe-cream);border:2px solid var(--pe-ink);transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .3s;cursor:pointer;perspective:1000px}
.svc:hover{transform:translateY(-6px) rotateX(2deg);box-shadow:var(--shadow-heavy)}
.svc-img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .8s ease,filter .8s ease;filter:saturate(.92)}
.svc:hover .svc-img{transform:scale(1.08);filter:saturate(1.1)}
.svc::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.18) 0%,rgba(7,9,12,.92) 85%)}
.svc-body{position:absolute;inset:0;z-index:2;padding:26px;display:flex;flex-direction:column;justify-content:space-between}
.svc-num{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;color:var(--pe-blue);font-weight:600}
.svc-title{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,3vw,40px);text-transform:none;line-height:.96;letter-spacing:-.015em}
.svc-sub{font-family:var(--font-body);font-size:14px;opacity:.85;margin-top:6px;max-width:320px}
.svc-arrow{align-self:flex-end;width:44px;height:44px;border-radius:50%;background:var(--pe-blue);color:var(--pe-cream);display:grid;place-items:center;transition:transform .25s;font-family:var(--font-mono)}
.svc:hover .svc-arrow{transform:rotate(-45deg)}
.svc.wide{grid-column:span 6;min-height:440px}
@media (max-width:1100px){.svc{grid-column:span 6}.svc.wide{grid-column:span 12}}
@media (max-width:640px){.svc{grid-column:span 12;min-height:320px}.svc.wide{min-height:360px}}

.estimator{background:var(--pe-cream);color:var(--pe-ink);border:2px solid var(--pe-ink);box-shadow:var(--shadow-cop);padding:50px 50px 40px;position:relative;max-width:920px;margin:0 auto}
.estimator::before{content:"";position:absolute;inset:8px;border:1px dashed var(--pe-ink);pointer-events:none}
.est-header{text-align:center;margin-bottom:36px;position:relative}
.est-header .eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--pe-blue);font-weight:600;margin-bottom:12px}
.est-header h3{font-family:var(--font-display);font-weight:800;font-size:clamp(32px,4vw,54px);color:var(--pe-navy);line-height:1;letter-spacing:-.02em}
.est-header h3 .italic{font-style:italic;font-weight:400;color:var(--pe-blue)}
.est-progress{display:flex;gap:6px;margin-top:22px;justify-content:center}
.est-progress .dot{width:28px;height:4px;background:rgba(10,10,10,.15);border-radius:4px;transition:background .25s,width .25s}
.est-progress .dot.active{background:var(--pe-blue);width:38px}
.est-progress .dot.done{background:var(--pe-navy)}
.est-step{display:none;animation:fadeUp .35s ease}
.est-step.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.est-question{font-family:var(--font-display);font-weight:700;font-size:clamp(22px,2.4vw,30px);color:var(--pe-navy);text-align:center;margin-bottom:28px;letter-spacing:-.01em}
.est-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:26px}
.est-opt{background:var(--pe-off);border:2px solid var(--pe-ink);padding:22px 18px;cursor:pointer;font-family:var(--font-body);font-weight:500;transition:transform .15s,background .15s,color .15s,box-shadow .15s;text-align:center;position:relative;display:flex;flex-direction:column;align-items:center;gap:8px}
.est-opt:hover{background:var(--pe-cream);transform:translateY(-2px);box-shadow:4px 4px 0 var(--pe-ink)}
.est-opt.selected{background:var(--pe-blue);color:var(--pe-cream);border-color:var(--pe-blue);box-shadow:4px 4px 0 var(--pe-ink)}
.est-opt .em{font-size:30px;line-height:1;margin-bottom:4px}
.est-opt .ttl{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-.01em}
.est-opt .desc{font-family:var(--font-mono);font-size:11px;opacity:.8;letter-spacing:.04em}
.est-field{display:block;margin-bottom:18px}
.est-field label{display:block;font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--pe-navy);font-weight:600;margin-bottom:8px}
.est-field input,.est-field select,.est-field textarea{width:100%;padding:14px 16px;font-family:var(--font-body);font-size:16px;border:2px solid var(--pe-ink);background:var(--pe-off);border-radius:2px}
.est-field input:focus,.est-field select:focus,.est-field textarea:focus{outline:2px solid var(--pe-blue);outline-offset:0}
.est-nav{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:14px}
.est-back{background:transparent;border:0;color:var(--pe-navy);font-family:var(--font-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;cursor:pointer;padding:10px 4px;opacity:.7;transition:opacity .2s}
.est-back:hover{opacity:1}
.est-next{background:var(--pe-navy);color:var(--pe-cream);border:0;padding:14px 28px;font-family:var(--font-body);font-weight:600;font-size:14px;border-radius:999px;cursor:pointer;box-shadow:0 3px 0 var(--pe-ink);transition:transform .15s,box-shadow .15s}
.est-next:hover{transform:translateY(-2px);box-shadow:0 5px 0 var(--pe-ink)}
.est-next:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.est-lock-note{background:rgba(46,123,216,.10);border:1px dashed var(--pe-blue);padding:14px 16px;border-radius:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--pe-navy);text-align:center;margin:0 0 18px}
.est-lock-note b{color:var(--pe-blue);font-weight:700}
.est-result{text-align:center;padding:14px 0 6px}
.est-result .rang-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--pe-blue);font-weight:600;margin-bottom:10px}
.est-result .range{font-family:var(--font-display);font-weight:800;font-size:clamp(44px,6vw,76px);color:var(--pe-navy);line-height:1;letter-spacing:-.02em;margin-bottom:8px}
.est-result .range .dash{color:var(--pe-blue);margin:0 10px}
.est-result .note{font-family:var(--font-body);font-size:14px;color:var(--pe-ink);opacity:.7;max-width:500px;margin:0 auto 26px;line-height:1.5;font-style:italic}
@media (max-width:640px){.estimator{padding:30px 18px 24px}.estimator::before{inset:6px}.est-header{margin-bottom:24px}.est-header h3{font-size:28px}.est-header .eyebrow{font-size:10px;letter-spacing:.22em}.est-progress{margin-top:14px}.est-progress .dot{width:22px;height:3px}.est-progress .dot.active{width:30px}.est-question{font-size:20px;margin-bottom:20px}.est-options{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}.est-opt{padding:14px 10px;gap:4px}.est-opt .em{font-size:22px}.est-opt .ttl{font-size:14px}.est-opt .desc{font-size:10px}.est-field{margin-bottom:14px}.est-field label{font-size:10px;letter-spacing:.18em}.est-field input,.est-field select,.est-field textarea{padding:12px 14px;font-size:15px}.est-nav{flex-direction:row-reverse;gap:10px}.est-next{flex:1;padding:14px 16px;font-size:13px}.est-result .range{font-size:44px}.est-result .range .dash{margin:0 6px}.est-result .note{font-size:13px}}

.irl-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:48px}
.irl-strip .slot{aspect-ratio:3/4;background-size:cover;background-position:center;border:2px solid var(--pe-ink);position:relative;transition:transform .4s ease}
.irl-strip .slot:nth-child(2n){transform:translateY(22px)}
.irl-strip .slot:hover{transform:translateY(-8px) scale(1.02)}
.irl-strip .slot:nth-child(2n):hover{transform:translateY(14px) scale(1.02)}
.irl-strip .slot::after{content:attr(data-label);position:absolute;left:12px;bottom:12px;background:var(--pe-cream);color:var(--pe-ink);font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:5px 9px;font-weight:600}
@media (max-width:900px){.irl-strip{grid-template-columns:repeat(2,1fr);gap:10px}.irl-strip .slot:nth-child(2n){transform:translateY(10px)}}

.process{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:16px}
.proc-item{background:var(--pe-off);border:2px solid var(--pe-ink);padding:30px 26px;position:relative;box-shadow:4px 4px 0 var(--pe-ink);transition:transform .2s,box-shadow .2s}
.proc-item:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--pe-ink)}
.proc-num{font-family:var(--font-display);font-weight:800;font-size:52px;line-height:1;color:var(--pe-blue);display:block;margin-bottom:8px;font-style:italic}
.proc-item h4{font-family:var(--font-display);font-weight:800;font-size:22px;color:var(--pe-navy);margin-bottom:8px;letter-spacing:-.01em}
.proc-item p{font-family:var(--font-body);font-size:14px;color:var(--pe-ink);line-height:1.55}
@media (max-width:900px){.process{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.process{grid-template-columns:1fr}}

.ba-wrap{max-width:1080px;margin:0 auto}
.ba-slider{position:relative;width:100%;aspect-ratio:16/10;overflow:hidden;border:3px solid var(--pe-ink);box-shadow:var(--shadow-cha);user-select:none;touch-action:none;cursor:ew-resize;background:#000}
.ba-img{position:absolute;inset:0;background-size:cover;background-position:center}
.ba-after{z-index:1}
.ba-before{z-index:2;clip-path:inset(0 50% 0 0);transition:clip-path .05s linear}
.ba-handle{position:absolute;top:0;bottom:0;width:4px;background:var(--pe-cream);z-index:3;left:50%;transform:translateX(-50%);box-shadow:0 0 14px rgba(0,0,0,.5)}
.ba-handle::before{content:"";position:absolute;left:50%;top:50%;width:50px;height:50px;transform:translate(-50%,-50%);background:var(--pe-blue);border-radius:50%;box-shadow:0 4px 14px rgba(0,0,0,.4);border:3px solid var(--pe-cream)}
.ba-handle::after{content:"\2194";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:var(--pe-cream);font-size:22px;font-weight:800;z-index:4;font-family:var(--font-body)}
.ba-label{position:absolute;top:16px;background:var(--pe-navy);color:var(--pe-cream);font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;padding:8px 14px;border-radius:4px;z-index:5;font-weight:600;text-transform:uppercase}
.ba-label.l{left:16px}
.ba-label.r{right:16px;background:var(--pe-blue)}

.t-carousel{position:relative;max-width:980px;margin:0 auto}
.t-track-wrap{overflow:hidden}
.t-track{display:flex;transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.t-slide{flex:0 0 100%;padding:14px}
.q-card{position:relative;background:var(--pe-cream);padding:50px 44px 38px;border:2px solid var(--pe-ink);box-shadow:8px 8px 0 var(--pe-blue)}
.q-card::before{content:"\201C";position:absolute;top:-10px;left:24px;font-family:var(--font-display);font-weight:800;font-size:120px;color:var(--pe-blue);line-height:1}
.q-card blockquote{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:clamp(20px,1.9vw,26px);line-height:1.4;color:var(--pe-ink)}
.q-card cite{display:block;margin-top:22px;font-style:normal;font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--pe-navy);font-weight:600}
.q-card .stars{color:var(--pe-blue);margin-bottom:10px;font-size:16px;letter-spacing:2px}
.t-controls{display:flex;gap:14px;justify-content:center;margin-top:26px;align-items:center}
.t-arrow{width:46px;height:46px;border-radius:50%;background:var(--pe-navy);color:var(--pe-cream);display:grid;place-items:center;cursor:pointer;border:0;transition:transform .15s,background .15s;font-size:18px}
.t-arrow:hover{background:var(--pe-blue);transform:scale(1.07)}
.t-dots{display:flex;gap:8px}
.t-dots .td{width:10px;height:10px;border-radius:50%;background:rgba(10,10,10,.2);cursor:pointer;transition:background .2s,transform .2s}
.t-dots .td.active{background:var(--pe-blue);transform:scale(1.3)}

.g-carousel{position:relative;max-width:100%}
.g-track-wrap{overflow:hidden;padding:20px 0}
.g-track{display:flex;gap:20px;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.g-slide{flex:0 0 calc(33.33% - 14px);aspect-ratio:4/3;background-size:cover;background-position:center;border:2px solid var(--pe-ink);position:relative;transition:transform .3s;cursor:pointer}
.g-slide:hover{transform:scale(1.02);z-index:2;box-shadow:var(--shadow-heavy)}
.g-slide::after{content:attr(data-cap);position:absolute;left:14px;bottom:14px;background:rgba(7,9,12,.85);color:var(--pe-cream);font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:6px 12px;font-weight:600}
@media (max-width:900px){.g-slide{flex:0 0 calc(50% - 10px)}}
@media (max-width:540px){.g-slide{flex:0 0 100%}}

.area-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.area-chip{background:var(--pe-cream);color:var(--pe-navy);border:2px solid var(--pe-navy);padding:12px 20px;font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;border-radius:999px;transition:background .2s,color .2s,transform .15s;display:inline-flex;align-items:center;gap:8px}
.area-chip::before{content:"";width:6px;height:6px;background:var(--pe-blue);border-radius:50%}
.area-chip:hover{background:var(--pe-blue);color:var(--pe-cream);border-color:var(--pe-blue);transform:translateY(-2px)}
.section-dark .area-chip{background:transparent;color:var(--pe-cream);border-color:var(--pe-cream)}
.section-dark .area-chip:hover{background:var(--pe-blue);border-color:var(--pe-blue)}

.visit{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:stretch}
.visit-meta{display:grid;grid-template-columns:auto 1fr;gap:14px 26px;font-family:var(--font-mono);font-size:14px;padding:24px 0;border-top:1px solid currentColor;border-bottom:1px solid currentColor;margin:30px 0}
.visit-meta dt{letter-spacing:.2em;text-transform:uppercase;opacity:.7;font-size:11px;font-weight:600}
.visit-meta dd{font-weight:600}
.visit-meta dd a{border-bottom:1px dashed currentColor}
.visit-photo{aspect-ratio:4/5;background-size:cover;background-position:center;border:3px solid var(--pe-ink);box-shadow:var(--shadow-cop);position:relative}
.visit-photo .stamp{position:absolute;top:-30px;right:-30px;width:128px;height:128px;border-radius:50%;background:var(--pe-navy);color:var(--pe-cream);display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:22px;text-align:center;line-height:1;border:4px solid var(--pe-cream);transform:rotate(-12deg);box-shadow:0 8px 18px rgba(0,0,0,.35);padding:12px}
.visit-photo .stamp small{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;margin-top:5px;font-weight:600}
@media (max-width:900px){.visit{grid-template-columns:1fr;gap:40px}.visit-photo{aspect-ratio:4/3}}

.mobile-cta{display:none;position:fixed;bottom:14px;left:14px;right:14px;z-index:100;background:var(--pe-navy);color:var(--pe-cream);padding:12px 16px;border-radius:999px;box-shadow:0 8px 24px rgba(0,0,0,.35),0 2px 0 var(--pe-blue);align-items:center;justify-content:space-between;gap:10px;font-family:var(--font-body);font-size:13px;font-weight:600}
.mobile-cta .m-phone{background:var(--pe-blue);color:var(--pe-cream);padding:10px 16px;border-radius:999px;font-weight:700;display:inline-flex;align-items:center;gap:6px}
@media (max-width:720px){.mobile-cta{display:flex}body{padding-bottom:70px}}

footer{background:var(--pe-ink);color:var(--pe-cream);padding:80px 0 30px;border-top:6px solid var(--pe-blue);position:relative}
footer::before{content:"";position:absolute;top:0;left:0;right:0;height:36px;background-image:radial-gradient(var(--pe-blue) 2px,transparent 2.5px);background-size:18px 18px;opacity:.15;pointer-events:none}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-grid h5{font-family:var(--font-mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--pe-blue);margin-bottom:22px;font-weight:600}
.foot-grid ul{list-style:none}
.foot-grid ul li{margin-bottom:10px;font-family:var(--font-body);font-size:14px}
.foot-grid ul li a{opacity:.8;transition:opacity .15s,color .15s}
.foot-grid ul li a:hover{opacity:1;color:var(--pe-blue)}
.foot-brand{font-family:var(--font-display);font-weight:800;font-size:50px;line-height:.95;margin-bottom:18px;letter-spacing:-.02em}
.foot-brand .italic{font-style:italic;font-weight:400;color:var(--pe-blue)}
.foot-blurb{font-family:var(--font-display);font-style:italic;font-weight:300;max-width:420px;opacity:.8;font-size:16px;line-height:1.5}
.foot-legal{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.6;flex-wrap:wrap;gap:10px}
.foot-credit{text-align:center;padding:24px 0 4px;font-family:var(--font-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;opacity:1;color:var(--pe-cream);font-weight:600}
.foot-credit a{color:var(--pe-blue);font-weight:700;border-bottom:1px solid var(--pe-blue);padding-bottom:1px;transition:color .2s,border-color .2s}
.foot-credit a:hover{color:var(--pe-blue-soft);border-bottom-color:var(--pe-blue-soft)}
@media (max-width:900px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:600px){.foot-grid{grid-template-columns:1fr;gap:30px}}

.page-head{position:relative;padding:110px 0 90px;background:var(--pe-navy);color:var(--pe-cream);overflow:hidden;border-bottom:6px solid var(--pe-blue)}
.page-head::before{content:"";position:absolute;inset:0;opacity:.08;background-image:radial-gradient(#fff 1px,transparent 1.5px);background-size:10px 10px}
.page-head-img{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.35;mix-blend-mode:screen}
.page-head .wrap{position:relative;z-index:1}
.page-head h1{font-family:var(--font-display);font-weight:800;font-size:clamp(56px,8.5vw,128px);line-height:.92;letter-spacing:-.025em;margin:16px 0 22px;color:var(--pe-cream)}
.page-head h1 .italic{font-style:italic;font-weight:400;color:var(--pe-blue)}
.page-head p.lead{font-family:var(--font-display);font-style:italic;font-weight:300;font-size:clamp(18px,1.7vw,22px);max-width:680px;opacity:.95;line-height:1.45}
.crumb{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;opacity:.75;margin-bottom:10px;color:var(--pe-blue)}
.crumb a{border-bottom:1px dashed currentColor}

.prose{max-width:820px;margin:0 auto;font-family:var(--font-body);font-size:17px;line-height:1.7;color:var(--pe-ink)}
.prose h2{font-family:var(--font-display);font-weight:800;font-size:clamp(32px,4.5vw,54px);line-height:.98;margin:54px 0 20px;color:var(--pe-navy);letter-spacing:-.02em}
.prose h2 .italic{font-style:italic;font-weight:400;color:var(--pe-blue)}
.prose h3{font-family:var(--font-display);font-weight:700;font-size:22px;margin:36px 0 12px;color:var(--pe-navy);letter-spacing:-.01em}
.prose p{margin-bottom:20px}
.prose ul{margin:0 0 24px 22px}
.prose ul li{margin-bottom:10px}
.prose ul li::marker{color:var(--pe-blue)}
.prose a{color:var(--pe-blue);border-bottom:1px solid currentColor;font-weight:600}
.prose strong{color:var(--pe-navy)}
.callout{background:var(--pe-navy);color:var(--pe-cream);padding:28px 32px;margin:34px 0;border-left:6px solid var(--pe-blue);position:relative}
.callout::before{content:attr(data-label);position:absolute;top:-10px;left:18px;background:var(--pe-blue);color:var(--pe-cream);font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;padding:3px 10px}
.callout p{font-family:var(--font-display);font-style:italic;font-weight:300;font-size:18px;margin:0;line-height:1.4}

.faq{max-width:820px;margin:0 auto}
.faq details{border-top:1px solid rgba(7,9,12,.15);padding:22px 0;transition:border-color .2s}
.faq details:last-of-type{border-bottom:1px solid rgba(7,9,12,.15)}
.faq summary{cursor:pointer;list-style:none;font-family:var(--font-display);font-weight:700;font-size:clamp(18px,2.2vw,22px);color:var(--pe-navy);letter-spacing:-.01em;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";width:36px;height:36px;background:var(--pe-navy);color:var(--pe-cream);border-radius:50%;display:grid;place-items:center;font-family:var(--font-body);font-weight:600;font-size:20px;transition:transform .25s,background .25s;flex-shrink:0}
.faq details[open] summary::after{content:"\2212";background:var(--pe-blue);transform:rotate(180deg)}
.faq details[open]{border-top-color:var(--pe-blue)}
.faq details p{margin-top:14px;font-family:var(--font-body);font-size:16px;color:var(--pe-ink);opacity:.9;line-height:1.6;max-width:700px}

.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:40px 0}
.feat-grid .feat{background:var(--pe-cream-2);padding:26px 24px;border:1px solid var(--pe-ink);position:relative;transition:transform .2s}
.feat-grid .feat:hover{transform:translateY(-4px)}
.feat .num{font-family:var(--font-display);font-weight:800;font-style:italic;font-size:42px;line-height:1;color:var(--pe-blue);display:block;margin-bottom:4px}
.feat h4{font-family:var(--font-display);font-weight:800;font-size:18px;color:var(--pe-navy);margin-bottom:6px;letter-spacing:-.01em}
.feat p{font-size:14px;line-height:1.5}
@media (max-width:820px){.feat-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.feat-grid{grid-template-columns:1fr}}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-form{display:grid;gap:18px}
.contact-form label{display:block;font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--pe-navy);font-weight:600;margin-bottom:6px}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:14px 16px;font-family:var(--font-body);font-size:16px;border:2px solid var(--pe-ink);background:var(--pe-off);border-radius:2px}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:2px solid var(--pe-blue);outline-offset:0}
.contact-form textarea{resize:vertical;min-height:140px}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr;gap:40px}}

[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
[data-reveal].visible{opacity:1;transform:translateY(0)}
[data-reveal-fade]{opacity:0;transition:opacity 1.2s ease}
[data-reveal-fade].visible{opacity:1}

.tilt{transform-style:preserve-3d;will-change:transform;transition:transform .4s ease}
.scroll-bar{position:fixed;top:0;left:0;right:0;height:3px;z-index:200;background:rgba(7,9,12,.06);pointer-events:none}
.scroll-bar > div{height:100%;width:0%;background:linear-gradient(90deg,var(--pe-blue),var(--pe-blue));box-shadow:0 0 8px var(--pe-blue);transition:width .08s linear}
.orb{position:absolute;pointer-events:none;opacity:.25;border-radius:50%;filter:blur(40px);animation:float 14s ease-in-out infinite}
.orb.cop{background:var(--pe-blue)}
.orb.amb{background:var(--pe-blue)}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,-30px) scale(1.15)}}

.trust-strip{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:28px 50px;padding:22px 0;border-top:1px solid rgba(7,9,12,.12);border-bottom:1px solid rgba(7,9,12,.12);margin:36px 0 0}
.trust-item{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--pe-navy);opacity:.7;display:flex;align-items:center;gap:10px;font-weight:600}
.trust-item .ico{width:18px;height:18px;color:var(--pe-blue)}

@media (max-width:640px){
  .wrap,.wrap-wide{padding:0 18px}
  .topbar .row{padding:0 18px;gap:12px}
  .topbar .tb-left span:not(:first-child){display:none}
  .topbar{font-size:11px;padding:8px 0}
  .anno{font-size:10px;padding:8px 0}
  .anno-track{gap:40px;padding-right:40px}
  .nav-row{padding:14px 18px}
  .brand-mark{width:44px;height:44px}
  .brand-type .big{font-size:20px}
  .brand-type .small{font-size:9px;letter-spacing:.2em}
  .hero{min-height:auto}
  .hero-inner{padding:70px 18px 60px;gap:34px}
  .hero h1{font-size:clamp(46px,13vw,78px)}
  .hero-sub{font-size:16px;margin-top:22px}
  .hero-cta-row{gap:10px;margin-top:28px}
  .btn{padding:14px 20px;font-size:13px}
  .hero-card{padding:26px 22px;transform:rotate(.5deg)}
  .hero-card h3{font-size:28px}
  .hero-card .seal{width:96px;height:96px;top:-18px;right:-14px;font-size:16px;padding:6px}
  .hero-card .seal small{font-size:9px}
  .stripe{padding:11px 0}
  .stripe-track{font-size:22px;gap:30px;padding-right:30px}
  .stripe-track i{font-size:16px}
  .section{padding:64px 0}
  .section.tight{padding:48px 0}
  .section-head{margin-bottom:36px}
  .svc-grid{gap:12px}
  .svc-body{padding:20px}
  .svc-arrow{width:38px;height:38px}
  .process{gap:14px}
  .proc-item{padding:24px 22px;box-shadow:3px 3px 0 var(--pe-ink)}
  .proc-num{font-size:44px}
  .irl-strip{gap:8px;margin-top:32px}
  .ba-handle::before{width:40px;height:40px}
  .ba-handle::after{font-size:18px}
  .ba-label{font-size:9px;padding:6px 10px;top:10px}
  .ba-label.l{left:10px}
  .ba-label.r{right:10px}
  .q-card{padding:36px 26px 28px}
  .q-card::before{font-size:86px;left:18px;top:-6px}
  .t-arrow{width:40px;height:40px}
  .visit{gap:30px}
  .visit-photo .stamp{width:96px;height:96px;top:-18px;right:-8px;font-size:16px;padding:8px}
  .visit-photo .stamp small{font-size:8px}
}

/* ============================================================
   POLISH PASS v2 - contrast, sticker, logo, feature strip
   ============================================================ */

/* ---- Brand mark (SVG logo - no brightness filter needed) ---- */
.brand-mark{ background: transparent; padding: 0; box-shadow: none; border-radius: 0; width: 62px; height: 62px; }
.brand-mark img{ filter: none; border-radius: 10px; box-shadow: 0 2px 6px rgba(0,0,0,.22); }
.brand-type .big{ font-size: 22px; }
.brand-type .small{ color: var(--pe-blue); }

/* ---- Hero card sticker: smaller + tighter layout + reposition ---- */
.hero-card .seal{
  width: 92px; height: 92px;
  top: -22px; right: -18px;
  font-size: 17px; padding: 8px;
  border: 3px solid var(--pe-cream);
  letter-spacing: 0.02em;
  line-height: 1.05;
}
.hero-card .seal small{
  font-size: 8px; letter-spacing: 0.1em;
  margin-top: 3px; line-height: 1.15;
}

/* ---- Hero card "Trusted Across The Metro" - tighter h3, less opacity on subhead ---- */
.hero-card h3{ font-size: 30px; margin-bottom: 10px; }
.hero-card p{ opacity: 1 !important; color: var(--pe-navy); }

/* ---- Contrast fixes: boost faint text across the site ---- */
.svc-sub{ opacity: 1; color: #EDE6D6; }
.est-opt .desc{ opacity: 1; color: var(--pe-navy-h); }
.section-head .meta{ opacity: 0.88; }
.section-dark .section-head .meta{ color: var(--pe-cream); opacity: 0.85; }
.foot-grid ul li a{ opacity: 1; color: #D8D1BD; }
.foot-grid ul li a:hover{ color: var(--pe-blue); }
.foot-blurb{ opacity: 1; color: #D8D1BD; }
.foot-legal{ opacity: 0.85; }
.topbar .tb-left span{ opacity: 1; }
.anno-track{ color: var(--pe-cream); }

/* Hero subtext a bit brighter */
.hero-sub{ color: #F9F2E0; opacity: 1; }

/* Process item paragraphs */
.proc-item p{ color: var(--pe-navy-h); opacity: 1; }

/* Quote card body clearer */
.q-card blockquote{ color: var(--pe-navy); }

/* Testimonial stars slightly bigger + better color */
.q-card .stars{ color: var(--pe-blue); font-size: 18px; }

/* Prose text darker for readability */
.prose p{ color: var(--pe-navy); }
.prose ul li{ color: var(--pe-navy); }

/* ---- Nav CTA "Free Estimate" - keep but slightly tweaked ---- */
.nav-cta{ font-size: 13px; }

/* ============================================================
   NEW: "Why Palmer's" feature strip (replaces before/after)
   ============================================================ */
.why-grid{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
  margin-top: 20px;
}
.why-card{
  background: var(--pe-cream); border: 2px solid var(--pe-ink);
  padding: 32px 26px 28px;
  position: relative; box-shadow: 4px 4px 0 var(--pe-blue);
  transition: transform .2s, box-shadow .2s;
}
.why-card:hover{ transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--pe-blue); }
.why-card .icon{
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--pe-navy); color: var(--pe-blue);
  display: grid; place-items: center; font-size: 24px;
  margin-bottom: 18px; font-weight: 800;
  font-family: var(--font-display); font-style: italic;
}
.why-card h4{
  font-family: var(--font-display); font-weight: 800;
  font-size: 22px; line-height: 1.1; color: var(--pe-navy);
  margin-bottom: 10px; letter-spacing: -0.01em;
}
.why-card p{
  font-size: 14px; line-height: 1.55; color: var(--pe-navy);
}
@media (max-width: 1000px){ .why-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .why-grid{ grid-template-columns: 1fr; } }

/* ============================================================
   NEW: Inline Lead Form (contact form on home page)
   ============================================================ */
.lead-form-wrap{
  max-width: 720px; margin: 0 auto;
  background: var(--pe-cream); border: 2px solid var(--pe-ink);
  box-shadow: var(--shadow-cha); padding: 42px 40px 34px;
  position: relative;
}
.lead-form-wrap::before{
  content:""; position: absolute; inset: 8px;
  border: 1px dashed var(--pe-ink); pointer-events: none;
}
.lead-form-wrap > *{ position: relative; }
.lead-form-head{ text-align: center; margin-bottom: 22px; }
.lead-form-head .eyebrow{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .3em;
  text-transform: uppercase; color: var(--pe-blue); font-weight: 600;
  margin-bottom: 8px;
}
.lead-form-head h3{
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(28px,3.5vw,42px); color: var(--pe-navy);
  line-height: 1; letter-spacing: -0.02em;
}
.lead-form-head h3 .italic{ font-style: italic; font-weight: 400; color: var(--pe-blue); }
.lead-form{ display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.lead-form .full{ grid-column: span 2; }
.lead-form label{
  display: block; font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--pe-navy);
  font-weight: 600; margin-bottom: 6px;
}
.lead-form input, .lead-form textarea{
  width: 100%; padding: 13px 14px; font-family: var(--font-body);
  font-size: 15px; border: 2px solid var(--pe-ink); background: var(--pe-off);
  border-radius: 2px;
}
.lead-form input:focus, .lead-form textarea:focus{
  outline: 2px solid var(--pe-blue); outline-offset: 0;
}
.lead-form textarea{ min-height: 110px; resize: vertical; }
.lead-form .submit-row{
  grid-column: span 2; display: flex; justify-content: space-between;
  align-items: center; gap: 14px; margin-top: 8px;
}
.lead-form .submit-row small{
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em;
  color: var(--pe-navy-h); opacity: .8;
}
@media (max-width: 640px){
  .lead-form-wrap{ padding: 28px 20px 24px; }
  .lead-form{ grid-template-columns: 1fr; gap: 12px; }
  .lead-form .full, .lead-form .submit-row{ grid-column: span 1; }
  .lead-form .submit-row{ flex-direction: column; align-items: stretch; }
  .lead-form .submit-row button{ width: 100%; }
}

/* Estimator: small "bonus" label */
.bonus-badge{
  display: inline-block; background: var(--pe-blue); color: var(--pe-cream);
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; font-weight: 700; padding: 5px 12px;
  border-radius: 999px; margin-bottom: 14px;
}

/* Secondary CTA text link style */
.cta-link{
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--pe-blue); font-weight: 600;
  border-bottom: 1px solid currentColor; padding-bottom: 2px;
}
.cta-link:hover{ color: var(--pe-blue-soft); }

/* ============================================================
   Portfolio cards - replaces simple IRL strip
   ============================================================ */
.portfolio-grid{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px;
  margin-top: 16px;
}
.port-card{
  background: var(--pe-cream); border: 2px solid var(--pe-ink);
  overflow: hidden; transition: transform .25s, box-shadow .25s;
  display: flex; flex-direction: column;
  box-shadow: 4px 4px 0 var(--pe-ink);
}
.port-card:hover{ transform: translate(-3px,-3px); box-shadow: 7px 7px 0 var(--pe-blue); }
.port-img{
  position: relative;
  aspect-ratio: 4/3; background-size: cover; background-position: center;
  border-bottom: 2px solid var(--pe-ink);
}
.port-tag{
  position: absolute; top: 12px; left: 12px;
  background: var(--pe-blue); color: var(--pe-cream);
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .18em;
  text-transform: uppercase; font-weight: 700;
  padding: 5px 10px; border-radius: 2px;
}
.port-body{ padding: 18px 20px 20px; flex: 1; display: flex; flex-direction: column; gap: 4px; }
.port-city{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--pe-blue); font-weight: 700;
}
.port-service{
  font-family: var(--font-display); font-weight: 800;
  font-size: 22px; line-height: 1.05; color: var(--pe-navy);
  letter-spacing: -0.01em; margin-top: 2px;
}
.port-meta{
  font-family: var(--font-body); font-size: 13px; line-height: 1.4;
  color: var(--pe-navy-h); margin-top: 6px;
}
@media (max-width: 1100px){ .portfolio-grid{ grid-template-columns: repeat(2, 1fr); gap: 16px; } }
@media (max-width: 560px){ .portfolio-grid{ grid-template-columns: 1fr; gap: 14px; } }

/* Polish: keep bonus badge as a small pill, not stretched in grid */
.section-head .bonus-badge{ justify-self: start; align-self: start; }
.section-head{ position: relative; }

/* =============================================================
   NAV DROPDOWN — Service Areas mega menu
   ============================================================= */
.nav-dd{ position: relative; display: inline-block; }
.nav-dd-btn{
  font-family: var(--font-body); font-size: 14px; font-weight: 500;
  padding: 10px 14px; background: transparent; border: 0;
  color: var(--pe-navy); cursor: pointer;
  display: inline-flex; align-items: center; gap: 7px;
  position: relative; transition: color .2s;
}
.nav-dd-btn:hover, .nav-dd-btn[aria-expanded="true"]{ color: var(--pe-blue); }
.nav-dd-btn.active{ color: var(--pe-blue); }
.nav-dd-btn.active::after{
  content: ""; position: absolute; bottom: 2px; left: 14px; right: 28px;
  height: 2px; background: var(--pe-blue);
}
.nav-dd-caret{ transition: transform .25s ease; opacity: .7; }
.nav-dd-btn[aria-expanded="true"] .nav-dd-caret{ transform: rotate(180deg); }

.nav-dd-panel{
  position: absolute; top: calc(100% + 14px); left: 50%;
  transform: translateX(-50%) translateY(-8px);
  min-width: 540px; max-width: 640px;
  background: var(--pe-cream);
  border: 2px solid var(--pe-navy);
  border-radius: 4px;
  box-shadow: 0 2px 0 var(--pe-blue), 0 18px 50px rgba(7,9,12,.28);
  padding: 20px 22px;
  opacity: 0; visibility: hidden;
  transition: opacity .22s ease, transform .22s ease, visibility 0s linear .22s;
  z-index: 100;
}
.nav-dd.is-open .nav-dd-panel{
  opacity: 1; visibility: visible;
  transform: translateX(-50%) translateY(0);
  transition: opacity .22s ease, transform .22s ease, visibility 0s linear 0s;
}
.nav-dd-panel::before{
  content: ""; position: absolute; top: -9px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 14px; height: 14px; background: var(--pe-cream);
  border-left: 2px solid var(--pe-navy); border-top: 2px solid var(--pe-navy);
}
.nav-dd-head{
  display: flex; justify-content: space-between; align-items: baseline;
  padding-bottom: 12px; margin-bottom: 14px;
  border-bottom: 1px dashed rgba(10,10,10,.22);
}
.nav-dd-eyebrow{
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--pe-blue); font-weight: 700;
}
.nav-dd-all{
  font-family: var(--font-body); font-size: 13px; font-weight: 600;
  color: var(--pe-navy); padding: 4px 0; border-bottom: 1px solid var(--pe-blue);
  transition: color .2s;
}
.nav-dd-all:hover{ color: var(--pe-blue); }
.nav-dd-grid{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px 18px;
}
.nav-dd-grid a{
  font-family: var(--font-body); font-size: 14px; font-weight: 500;
  padding: 9px 12px; color: var(--pe-navy);
  border-radius: 3px;
  transition: background .18s ease, color .18s ease, transform .18s ease;
  position: relative; display: block;
}
.nav-dd-grid a::before{
  content: "·"; position: absolute; left: 2px; top: 50%; transform: translateY(-50%);
  color: var(--pe-blue); font-weight: 900; font-size: 18px; line-height: 1;
  opacity: 0; transition: opacity .18s, transform .18s;
}
.nav-dd-grid a:hover{
  background: rgba(46,123,216,.09); color: var(--pe-blue);
  transform: translateX(6px);
}
.nav-dd-grid a:hover::before{ opacity: 1; transform: translateY(-50%) translateX(-4px); }

@media (max-width: 1080px){
  .nav-dd{ display: block; width: 100%; }
  .nav-dd-btn{ width: 100%; justify-content: space-between; padding: 14px 28px; font-size: 16px; }
  .nav-dd-btn.active::after{ left: 28px; right: auto; width: 40px; }
  .nav-dd-panel{
    position: static; transform: none; min-width: 0; max-width: none;
    border: 0; border-top: 1px solid rgba(10,10,10,.15); border-radius: 0;
    box-shadow: none; padding: 8px 18px 12px;
    opacity: 1; visibility: visible;
    display: none;
    background: var(--pe-off);
  }
  .nav-dd.is-open .nav-dd-panel{ display: block; }
  .nav-dd-panel::before{ display: none; }
  .nav-dd-grid{ grid-template-columns: repeat(2, 1fr); gap: 2px 8px; }
  .nav-dd-head{ flex-direction: column; align-items: flex-start; gap: 6px; }
}


/* =============================================================
   AREA PAGE + INDEX STYLES (mono-tag, page-head-meta, area-card, areas-masonry, callout-cta)
   ============================================================= */
.page-head-meta{
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 22px;
}
.mono-tag{
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--pe-blue); font-weight: 600;
  padding: 7px 14px;
  background: rgba(224,165,96,.08);
  border: 1px solid rgba(224,165,96,.32);
  border-radius: 2px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.callout-cta{
  display: inline-flex; align-items: center; gap: 12px;
  margin-top: 18px;
  background: var(--pe-navy); color: var(--pe-cream);
  font-family: var(--font-body); font-size: 14px; font-weight: 600;
  padding: 14px 24px; border-radius: 999px;
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
  box-shadow: 0 2px 0 var(--pe-blue);
}
.callout-cta:hover{
  background: var(--pe-blue); transform: translateY(-2px);
  box-shadow: 0 6px 0 var(--pe-ink);
}
.callout-cta .arrow{ transition: transform .2s ease; }
.callout-cta:hover .arrow{ transform: translateX(4px); }

.areas-masonry{
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 1080px){ .areas-masonry{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 780px){  .areas-masonry{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px){  .areas-masonry{ grid-template-columns: 1fr; } }

.area-card{
  position: relative;
  display: flex; flex-direction: column; gap: 4px;
  padding: 22px 22px 24px;
  background: var(--pe-off);
  border: 2px solid var(--pe-navy);
  border-radius: 4px;
  box-shadow: 0 2px 0 var(--pe-blue);
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease;
  overflow: hidden;
  isolation: isolate;
}
.area-card::before{
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(280px circle at var(--mx,50%) var(--my,50%), rgba(46,123,216,.13), transparent 55%);
  opacity: 0; transition: opacity .22s ease;
  z-index: -1; pointer-events: none;
}
.area-card:hover{
  transform: translate(-3px, -3px);
  box-shadow: 6px 6px 0 var(--pe-blue), 0 18px 40px rgba(7,9,12,.18);
}
.area-card:hover::before{ opacity: 1; }
.area-card-name{
  font-family: var(--font-display); font-weight: 800;
  font-size: 26px; line-height: 1; letter-spacing: -0.015em;
  color: var(--pe-navy);
}
.area-card-county{
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--pe-blue); font-weight: 700;
  margin-top: 4px;
}
.area-card-arrow{
  position: absolute; top: 22px; right: 22px;
  font-family: var(--font-display); font-size: 22px; color: var(--pe-navy);
  transition: transform .22s ease, color .22s ease;
}
.area-card:hover .area-card-arrow{
  transform: translateX(4px) translateY(-2px);
  color: var(--pe-blue);
}


/* =============================================================
   21ST.DEV-STYLE ELEMENTS (keeping Palmer's copper/charcoal)
   ============================================================= */

/* ---------- Bento service grid ---------- */
.bento{
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 200px;
  gap: 14px;
  margin-top: 40px;
}
.bento-item{
  position: relative;
  background: var(--pe-off);
  border: 2px solid var(--pe-navy);
  border-radius: 4px;
  padding: 24px;
  overflow: hidden;
  display: flex; flex-direction: column; justify-content: flex-end;
  text-decoration: none;
  transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease;
  box-shadow: 0 2px 0 var(--pe-blue);
  isolation: isolate;
}
.bento-item::before{
  content: ""; position: absolute; inset: 0; z-index: -2;
  background-size: cover; background-position: center;
  background-image: var(--bento-img, none);
  opacity: .22;
  transition: opacity .35s ease, transform .8s ease;
  transform: scale(1.05);
}
.bento-item::after{
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(135deg, rgba(0,0,0,.82), rgba(0,0,0,.55) 55%, rgba(46,123,216,.35));
}
.bento-item:hover{ transform: translate(-2px, -4px); box-shadow: 4px 6px 0 var(--pe-blue), 0 20px 50px rgba(7,9,12,.3); }
.bento-item:hover::before{ opacity: .38; transform: scale(1); }
.bento-item.dark{ color: var(--pe-cream); }
.bento-item.dark .bento-kicker{ color: var(--pe-blue); }
.bento-item.dark h3{ color: #FDF9EF; }
.bento-kicker{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--pe-blue); font-weight: 700;
  margin-bottom: 8px;
}
.bento-item h3{
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(22px, 3vw, 32px); line-height: 1; letter-spacing: -0.015em;
  color: var(--pe-navy);
}
.bento-item p{ font-size: 14px; line-height: 1.5; color: inherit; opacity: .88; margin-top: 8px; max-width: 36ch; }
.bento-item .bento-arrow{
  position: absolute; top: 20px; right: 20px;
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(46,123,216,.18);
  color: var(--pe-blue);
  display: grid; place-items: center;
  font-size: 18px; font-family: var(--font-display);
  transition: transform .3s ease, background .3s ease;
}
.bento-item:hover .bento-arrow{ transform: translate(3px,-3px) rotate(-8deg); background: var(--pe-blue); color: var(--pe-cream); }

/* Bento size variants */
.bento-item.span-3 { grid-column: span 3; }
.bento-item.span-2 { grid-column: span 2; }
.bento-item.span-4 { grid-column: span 4; }
.bento-item.row-2  { grid-row: span 2; }

@media (max-width: 900px){
  .bento{ grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px; }
  .bento-item.span-3, .bento-item.span-2, .bento-item.span-4 { grid-column: span 2; }
  .bento-item.row-2 { grid-row: span 1; }
}

/* ---------- Animated counters ---------- */
.stats-grid{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
  padding: 56px 0; border-top: 1px solid rgba(10,10,10,.15); border-bottom: 1px solid rgba(10,10,10,.15);
}
@media (max-width: 780px){ .stats-grid{ grid-template-columns: repeat(2, 1fr); } }
.stat{ text-align: center; }
.stat-num{
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(50px, 8vw, 92px); line-height: 1;
  letter-spacing: -0.03em; color: var(--pe-navy);
  display: inline-block;
}
.stat-num .plus{ color: var(--pe-blue); font-style: italic; font-weight: 500; }
.stat-label{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase; font-weight: 600; color: var(--pe-blue);
  margin-top: 12px; display: block;
}
.stat-sub{
  font-family: var(--font-body); font-size: 14px; color: var(--pe-navy-h);
  margin-top: 6px;
}

/* ---------- Testimonial marquee ---------- */
.tm-marquee{
  overflow: hidden;
  padding: 56px 0;
  background: var(--pe-navy-2);
  color: var(--pe-cream);
  position: relative;
  isolation: isolate;
}
.tm-marquee::before{
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: radial-gradient(ellipse 60% 40% at 20% 30%, rgba(46,123,216,.18), transparent 70%),
              radial-gradient(ellipse 50% 40% at 80% 70%, rgba(224,165,96,.12), transparent 70%);
  animation: tmAurora 18s ease-in-out infinite alternate;
}
@keyframes tmAurora{
  0%   { background-position: 0% 0%, 100% 100%; }
  100% { background-position: 40% 20%, 60% 80%; }
}
.tm-marquee-lead{
  text-align: center; margin-bottom: 40px;
  padding: 0 28px;
}
.tm-marquee-lead .eyebrow{
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--pe-blue); font-weight: 600;
}
.tm-marquee-lead h2{
  font-family: var(--font-display); font-weight: 800; color: var(--pe-cream);
  font-size: clamp(36px, 5vw, 58px); line-height: 1.02; letter-spacing: -0.02em;
  margin-top: 14px;
}
.tm-marquee-lead h2 .italic{ color: var(--pe-blue-soft); font-weight: 500; }

.tm-track{
  display: inline-flex; gap: 24px; padding-left: 24px;
  animation: tmScroll 50s linear infinite;
  will-change: transform;
}
.tm-card{
  flex: 0 0 380px;
  background: rgba(250,247,238,.04);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(242,239,232,.1);
  border-radius: 6px;
  padding: 26px 28px;
  display: flex; flex-direction: column; gap: 16px;
  transition: transform .3s ease, border-color .3s ease;
}
.tm-card:hover{ transform: translateY(-4px); border-color: var(--pe-blue); }
.tm-stars{ display: inline-flex; gap: 3px; color: var(--pe-blue); }
.tm-stars::before{ content: "★★★★★"; letter-spacing: 2px; font-size: 16px; }
.tm-quote{
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: 17px; line-height: 1.45; color: var(--pe-cream);
}
.tm-meta{
  display: flex; align-items: center; gap: 14px; margin-top: auto;
  padding-top: 14px; border-top: 1px solid rgba(242,239,232,.12);
}
.tm-avatar{
  width: 42px; height: 42px; border-radius: 50%;
  background: var(--pe-blue); color: var(--pe-cream);
  font-family: var(--font-display); font-weight: 800; font-size: 18px;
  display: grid; place-items: center;
}
.tm-name{ font-family: var(--font-body); font-weight: 600; font-size: 14px; color: var(--pe-off); }
.tm-city{ font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--pe-blue-soft); margin-top: 3px; }
@keyframes tmScroll{
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.tm-marquee:hover .tm-track{ animation-play-state: paused; }

/* ---------- FAQ accordion ---------- */
.faq-list{ display: flex; flex-direction: column; gap: 10px; max-width: 880px; margin: 40px auto 0; }
.faq-item{
  border: 2px solid var(--pe-navy);
  border-radius: 4px;
  background: var(--pe-off);
  overflow: hidden;
  transition: box-shadow .25s ease, border-color .25s ease;
}
.faq-item[open]{ box-shadow: 0 2px 0 var(--pe-blue); border-color: var(--pe-navy); }
.faq-item summary{
  list-style: none;
  cursor: pointer;
  padding: 20px 26px;
  display: flex; justify-content: space-between; align-items: center; gap: 20px;
  font-family: var(--font-display); font-weight: 700; font-size: 20px;
  letter-spacing: -0.01em; color: var(--pe-navy);
  transition: color .2s ease;
}
.faq-item summary::-webkit-details-marker{ display: none; }
.faq-item summary:hover{ color: var(--pe-blue); }
.faq-item summary .faq-icon{
  flex: 0 0 34px; width: 34px; height: 34px;
  border-radius: 50%; border: 2px solid var(--pe-navy);
  display: grid; place-items: center;
  font-family: var(--font-mono); font-size: 22px; font-weight: 300;
  line-height: 0; color: var(--pe-navy);
  transition: transform .3s ease, background .3s ease, color .3s ease, border-color .3s ease;
}
.faq-item[open] summary .faq-icon{
  transform: rotate(135deg);
  background: var(--pe-blue); color: var(--pe-cream); border-color: var(--pe-blue);
}
.faq-answer{
  padding: 0 26px 24px;
  font-family: var(--font-body); color: var(--pe-navy-h); line-height: 1.6;
  max-width: 72ch;
}
.faq-answer p + p{ margin-top: 12px; }

/* ---------- Estimator (Evergreen-style, but in Palmer's brand) ---------- */
.estimator-wrap{
  max-width: 840px; margin: 0 auto;
  background: var(--pe-cream);
  border: 3px solid var(--pe-navy);
  border-radius: 6px;
  padding: clamp(24px, 4vw, 48px);
  position: relative;
  isolation: isolate;
  box-shadow: 0 4px 0 var(--pe-blue), 0 30px 60px rgba(7,9,12,.18);
}
.estimator-wrap::before{
  content: ""; position: absolute; inset: -3px; z-index: -1;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--pe-blue), var(--pe-blue), var(--pe-blue-deep));
  opacity: .18; filter: blur(10px);
}
.est-progress{ display: flex; gap: 6px; margin-bottom: 28px; }
.est-progress div{
  flex: 1; height: 4px; border-radius: 999px; background: rgba(10,10,10,.14);
  overflow: hidden; position: relative;
}
.est-progress div.active::before{
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, var(--pe-blue), var(--pe-blue));
  transform-origin: left;
  animation: estFill .5s cubic-bezier(.2,.8,.2,1) forwards;
}
.est-progress div.done{ background: linear-gradient(90deg, var(--pe-blue), var(--pe-blue)); }
@keyframes estFill{ from{ transform: scaleX(0); } to{ transform: scaleX(1); } }

.est-step{ display: none; animation: estFadeUp .45s cubic-bezier(.2,.8,.2,1) both; }
.est-step.active{ display: block; }
@keyframes estFadeUp{ from{ opacity: 0; transform: translateY(14px); } to{ opacity: 1; transform: none; } }

.est-step .est-eyebrow{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase; font-weight: 700; color: var(--pe-blue);
}
.est-step h3{
  font-family: var(--font-display); font-weight: 800; font-size: clamp(28px, 4vw, 40px);
  line-height: 1.05; letter-spacing: -0.02em; color: var(--pe-navy);
  margin-top: 8px;
}
.est-step .est-hint{ color: var(--pe-navy-h); margin-top: 8px; font-size: 15px; }

.est-opts{
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px; margin-top: 24px;
}
.est-opt{
  padding: 18px 16px; text-align: center;
  background: var(--pe-off);
  border: 2px solid var(--pe-navy);
  border-radius: 4px;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
  font-family: var(--font-body);
  position: relative;
}
.est-opt:hover{ transform: translateY(-2px); box-shadow: 0 2px 0 var(--pe-blue); }
.est-opt.selected{
  border-color: var(--pe-blue);
  background: rgba(46,123,216,.08);
  box-shadow: 2px 2px 0 var(--pe-blue);
}
.est-opt.selected::before{
  content: "✓"; position: absolute; top: 8px; right: 10px;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--pe-blue); color: var(--pe-cream);
  display: grid; place-items: center;
  font-size: 12px; font-weight: 800;
}
.est-opt-label{ font-weight: 700; color: var(--pe-navy); font-size: 15px; display: block; }
.est-opt-sub{ font-family: var(--font-mono); font-size: 10px; letter-spacing: .16em;
  text-transform: uppercase; color: var(--pe-blue); margin-top: 4px; display: block; }

.est-input{
  width: 100%; padding: 16px 18px;
  background: var(--pe-off); color: var(--pe-ink);
  border: 2px solid var(--pe-navy); border-radius: 4px;
  font-family: var(--font-body); font-size: 17px; margin-top: 20px;
  transition: border-color .18s ease, box-shadow .18s ease;
}
.est-input:focus{ outline: none; border-color: var(--pe-blue); box-shadow: 0 0 0 4px rgba(46,123,216,.18); }
.est-input + .est-input{ margin-top: 10px; }

.est-nav{
  display: flex; justify-content: space-between; gap: 10px;
  margin-top: 28px;
}
.est-btn{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 26px; border-radius: 999px;
  font-family: var(--font-body); font-size: 15px; font-weight: 600;
  cursor: pointer; border: 0;
  transition: transform .18s ease, background .2s ease, box-shadow .18s ease;
}
.est-btn-primary{ background: var(--pe-blue); color: var(--pe-cream); box-shadow: 0 2px 0 var(--pe-ink); }
.est-btn-primary:hover{ background: var(--pe-blue-deep); transform: translateY(-2px); box-shadow: 0 4px 0 var(--pe-ink); }
.est-btn-ghost{ background: transparent; color: var(--pe-navy); border: 2px solid var(--pe-navy); }
.est-btn-ghost:hover{ background: var(--pe-navy); color: var(--pe-cream); }

.est-result{ display: none; text-align: center; padding: 16px 0; }
.est-result.active{ display: block; animation: estFadeUp .6s cubic-bezier(.2,.8,.2,1) both; }
.est-price{
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(54px, 9vw, 98px); line-height: 1; letter-spacing: -0.03em;
  color: var(--pe-navy);
  background: linear-gradient(135deg, var(--pe-navy), var(--pe-blue));
  -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
  margin: 14px 0 10px;
}
.est-price-sub{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase; font-weight: 600; color: var(--pe-blue);
}
.est-result p{ margin: 18px auto; max-width: 520px; color: var(--pe-navy-h); }

/* ---------- Magnetic button (cursor-attracted) ---------- */
.magnet{ display: inline-block; transition: transform .35s cubic-bezier(.2,.8,.2,1); }

/* ---------- Section eyebrow + title helpers ---------- */
.section-pre-title{
  text-align: center; margin-bottom: 36px;
}
.section-pre-title .eyebrow{
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .24em;
  text-transform: uppercase; color: var(--pe-blue); font-weight: 700;
  display: inline-flex; align-items: center; gap: 12px;
}
.section-pre-title .eyebrow::before,
.section-pre-title .eyebrow::after{
  content: ""; width: 34px; height: 1px; background: var(--pe-blue);
}
.section-pre-title h2{
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(38px, 6vw, 72px); line-height: 1.02; letter-spacing: -0.02em;
  color: var(--pe-navy); margin-top: 16px;
}
.section-pre-title h2 .italic{ color: var(--pe-blue); font-weight: 500; }
.section-pre-title p{
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: clamp(18px, 1.8vw, 22px); line-height: 1.5; color: var(--pe-navy-h);
  max-width: 640px; margin: 20px auto 0;
}

/* ---------- Reveal cards / scale reveal ---------- */
[data-reveal-scale]{ opacity: 0; transform: scale(.96); transition: opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1); }
[data-reveal-scale].in{ opacity: 1; transform: scale(1); }
[data-reveal-stagger] > *{ opacity: 0; transform: translateY(20px); transition: opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1); }
[data-reveal-stagger].in > *{ opacity: 1; transform: none; }
[data-reveal-stagger].in > *:nth-child(1){ transition-delay: 0ms; }
[data-reveal-stagger].in > *:nth-child(2){ transition-delay: 70ms; }
[data-reveal-stagger].in > *:nth-child(3){ transition-delay: 140ms; }
[data-reveal-stagger].in > *:nth-child(4){ transition-delay: 210ms; }
[data-reveal-stagger].in > *:nth-child(5){ transition-delay: 280ms; }
[data-reveal-stagger].in > *:nth-child(6){ transition-delay: 350ms; }
[data-reveal-stagger].in > *:nth-child(7){ transition-delay: 420ms; }
[data-reveal-stagger].in > *:nth-child(8){ transition-delay: 490ms; }

/* ---------- Spotlight trail (cursor-following) ---------- */
.pc-spot{
  position: fixed; pointer-events: none; z-index: 1;
  width: 460px; height: 460px; border-radius: 50%;
  background: radial-gradient(circle, rgba(46,123,216,.10) 0%, transparent 60%);
  transform: translate(-50%, -50%);
  mix-blend-mode: multiply; opacity: 0;
  transition: opacity .3s ease;
}
@media (max-width: 780px){ .pc-spot{ display: none; } }

/* ---------- FAQ + estimator reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  [data-reveal-scale], [data-reveal-stagger] > *{ opacity: 1; transform: none; }
}

/* ============================================================
   MOBILE OPTIMIZATION PASS
   - bigger touch targets (44px min)
   - tighter padding
   - readable type at small sizes
   - swipe-friendly carousels
   ============================================================ */
@media (max-width: 720px){
  /* Touch target minimums */
  .nav-cta, .btn, .est-opt, .area-chip, .t-arrow, .est-back, .est-next,
  .nav-links a, .topbar .tb-phone, .mobile-cta a, .lead-form button,
  .contact-form button, .svc-arrow, .t-dots .td{
    min-height: 44px;
  }
  .nav-links a{ padding: 14px 28px; }
  /* Increase tap area on small dots */
  .t-dots .td{ width: 14px; height: 14px; padding: 0; }

  /* Hero - tighter padding, ensure h1 doesn't overflow */
  .hero{ min-height: auto; }
  .hero-inner{ padding: 60px 18px 50px; gap: 28px; }
  .hero h1{ font-size: clamp(40px, 11vw, 64px); line-height: 0.96; word-break: break-word; }
  .hero-sub{ font-size: 15px; line-height: 1.55; margin-top: 20px; }
  .hero-eyebrow{ font-size: 10px; letter-spacing: 0.2em; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; }
  .hero-eyebrow .line{ width: 24px; }
  .hero-cta-row{ gap: 10px; margin-top: 24px; flex-direction: column; align-items: stretch; }
  .hero-cta-row .btn{ justify-content: center; width: 100%; }
  .btn{ padding: 14px 22px; font-size: 14px; min-height: 48px; }
  .btn-big{ padding: 16px 24px; font-size: 14px; min-height: 50px; }

  /* Hero card */
  .hero-card{ padding: 24px 22px; transform: rotate(0); margin: 0; }
  .hero-card h3{ font-size: 26px; }
  .hero-card .seal{
    width: 78px; height: 78px;
    top: -16px; right: -10px;
    font-size: 14px; padding: 6px;
  }
  .hero-card .seal small{ font-size: 8px; }
  .hero-card .hc-stats{ font-size: 12px; gap: 8px 12px; }

  /* Sections - tighter vertical padding */
  .section{ padding: 56px 0; }
  .section.tight{ padding: 40px 0; }
  .section-head{ margin-bottom: 30px; gap: 12px; }
  .section-head h2{ font-size: clamp(34px, 8.4vw, 52px); }
  .section-head .meta{ font-size: 11px; }

  /* Service grid */
  .svc-grid{ gap: 12px; }
  .svc{ min-height: 280px; }
  .svc.wide{ min-height: 320px; }
  .svc-body{ padding: 18px; }
  .svc-title{ font-size: 24px; }
  .svc-sub{ font-size: 13px; }
  .svc-arrow{ width: 36px; height: 36px; min-height: 36px; }

  /* Estimator */
  .estimator{ padding: 24px 16px 22px; max-width: 100%; }
  .estimator::before{ inset: 5px; }
  .est-header h3{ font-size: 26px; }
  .est-question{ font-size: 18px; margin-bottom: 16px; line-height: 1.3; }
  .est-options{ grid-template-columns: 1fr 1fr; gap: 8px; }
  .est-opt{ padding: 14px 8px; min-height: 78px; }
  .est-opt .em{ font-size: 22px; }
  .est-opt .ttl{ font-size: 13px; }
  .est-opt .desc{ font-size: 9px; }
  .est-field input, .est-field select, .est-field textarea{
    padding: 14px 12px; font-size: 16px; /* prevents iOS zoom */
  }
  .est-nav{ gap: 8px; flex-direction: row; }
  .est-back{ flex: 0 0 auto; padding: 10px 12px; font-size: 11px; }
  .est-next{ flex: 1 1 auto; padding: 14px 16px; font-size: 13px; }
  .est-result .range{ font-size: clamp(36px, 10vw, 48px); }

  /* Process cards */
  .process{ grid-template-columns: 1fr; gap: 12px; }
  .proc-item{ padding: 22px 18px; box-shadow: 3px 3px 0 var(--pe-ink); }
  .proc-num{ font-size: 38px; }
  .proc-item h4{ font-size: 20px; }
  .proc-item p{ font-size: 14px; }

  /* Why grid - keep 1 col on phones for readability */
  .why-grid{ grid-template-columns: 1fr; gap: 12px; }
  .why-card{ padding: 24px 22px; box-shadow: 3px 3px 0 var(--pe-blue); }
  .why-card .icon{ width: 48px; height: 48px; font-size: 20px; margin-bottom: 14px; }

  /* Real Floors / portfolio cards */
  .portfolio-grid{ grid-template-columns: 1fr; gap: 14px; }
  .port-card{ box-shadow: 3px 3px 0 var(--pe-ink); }
  .port-img{ aspect-ratio: 16/10; }
  .port-body{ padding: 16px 18px 18px; }
  .port-service{ font-size: 20px; }
  .port-meta{ font-size: 13px; }

  /* Lead form */
  .lead-form-wrap{ padding: 24px 18px 22px; }
  .lead-form-wrap::before{ inset: 5px; }
  .lead-form{ grid-template-columns: 1fr; gap: 12px; }
  .lead-form .full, .lead-form .submit-row{ grid-column: span 1; }
  .lead-form .submit-row{ flex-direction: column-reverse; align-items: stretch; gap: 12px; text-align: center; }
  .lead-form .submit-row button{ width: 100%; }
  .lead-form input, .lead-form textarea{ font-size: 16px; padding: 13px 12px; min-height: 48px; }
  .lead-form-head h3{ font-size: 26px; }

  /* Testimonial carousel */
  .t-carousel{ padding: 0 4px; }
  .q-card{ padding: 32px 20px 24px; box-shadow: 5px 5px 0 var(--pe-blue); }
  .q-card::before{ font-size: 70px; left: 14px; top: -4px; }
  .q-card blockquote{ font-size: 16px; line-height: 1.45; }
  .q-card cite{ font-size: 10px; }
  .t-arrow{ width: 44px; height: 44px; min-height: 44px; font-size: 16px; }
  .t-controls{ gap: 10px; margin-top: 18px; }

  /* Gallery carousel */
  .g-slide{ flex: 0 0 100%; aspect-ratio: 4/3; }
  .g-slide::after{ font-size: 9px; padding: 5px 10px; left: 10px; bottom: 10px; }

  /* Service area chips */
  .area-grid{ gap: 8px; }
  .area-chip{ padding: 10px 16px; font-size: 11px; min-height: 42px; }

  /* Contact form */
  .contact-form input, .contact-form textarea, .contact-form select{
    font-size: 16px; padding: 14px 12px; min-height: 48px;
  }

  /* Visit / contact block */
  .visit{ grid-template-columns: 1fr; gap: 30px; }
  .visit-photo{ aspect-ratio: 16/10; }
  .visit-photo .stamp{ width: 84px; height: 84px; top: -16px; right: -8px; font-size: 14px; padding: 8px; }
  .visit-photo .stamp small{ font-size: 8px; }
  .visit-meta{ font-size: 13px; gap: 10px 18px; }
  .visit-meta dt{ font-size: 10px; }

  /* Page heads on sub-pages */
  .page-head{ padding: 70px 0 56px; }
  .page-head h1{ font-size: clamp(40px, 10vw, 64px); }
  .page-head p.lead{ font-size: 15px; line-height: 1.5; }
  .crumb{ font-size: 10px; }

  /* Prose body on sub-pages */
  .prose{ font-size: 16px; line-height: 1.65; }
  .prose h2{ font-size: clamp(28px, 7vw, 36px); margin-top: 36px; margin-bottom: 14px; }
  .prose h3{ font-size: 18px; }
  .prose ul{ margin-left: 18px; }
  .callout{ padding: 22px 22px; }
  .callout p{ font-size: 16px; }

  /* Footer */
  .foot-grid{ grid-template-columns: 1fr; gap: 26px; padding-bottom: 32px; }
  .foot-brand{ font-size: 38px; }
  .foot-grid h5{ margin-bottom: 14px; }
  .foot-grid ul li{ font-size: 14px; margin-bottom: 8px; }
  .foot-legal{ flex-direction: column; align-items: flex-start; gap: 8px; padding-top: 20px; font-size: 10px; }
  .foot-credit{ font-size: 11px; padding: 18px 0 4px; line-height: 1.5; letter-spacing: .14em; }

  /* Topbar - hide some pieces, simplify */
  .topbar{ font-size: 10px; padding: 8px 0; }
  .topbar .row{ padding: 0 16px; gap: 10px; }
  .topbar .tb-left span:nth-child(n+2){ display: none; }
  .topbar .tb-phone{ font-size: 11px; padding: 6px 10px; }

  /* Anno marquee smaller text */
  .anno{ font-size: 10px; padding: 8px 0; letter-spacing: .12em; }
  .anno-track{ gap: 32px; padding-right: 32px; }

  /* Header / nav */
  header.site{ position: sticky; top: 0; }
  .nav-row{ padding: 12px 16px; }
  .brand-mark{ width: 44px; height: 44px; }
  .brand-type .big{ font-size: 18px; }
  .brand-type .small{ font-size: 8px; letter-spacing: 0.18em; margin-top: 3px; }
  .nav-toggle{ font-size: 11px; padding: 8px 12px; }

  /* Stripe marquee */
  .stripe{ padding: 10px 0; }
  .stripe-track{ font-size: 18px; gap: 24px; padding-right: 24px; }
  .stripe-track i{ font-size: 14px; }

  /* Bonus badge size */
  .bonus-badge{ font-size: 9px; padding: 4px 10px; letter-spacing: .18em; }

  /* Sticky mobile CTA - prevent overlap with content */
  .mobile-cta{ font-size: 12px; padding: 10px 14px; }
  .mobile-cta .m-phone{ padding: 9px 14px; min-height: 38px; }
  body{ padding-bottom: 76px; }

  /* Wrap padding */
  .wrap, .wrap-wide{ padding: 0 16px; }
}

/* Even smaller phones (iPhone SE, narrow Androids) */
@media (max-width: 380px){
  .est-options{ grid-template-columns: 1fr; }
  .hero h1{ font-size: clamp(34px, 11vw, 48px); }
  .section-head h2{ font-size: clamp(30px, 9vw, 42px); }
  .brand-type .big{ font-size: 16px; }
  .brand-type .small{ font-size: 7px; }
}

/* Tablet portrait optimizations */
@media (min-width: 721px) and (max-width: 980px){
  .hero-inner{ grid-template-columns: 1fr; gap: 36px; padding: 80px 28px 70px; }
  .hero-card{ max-width: 460px; }
  .portfolio-grid{ grid-template-columns: 1fr 1fr; }
  .why-grid{ grid-template-columns: 1fr 1fr; }
  .process{ grid-template-columns: 1fr 1fr; }
  .visit{ grid-template-columns: 1fr; }
}

/* Reduce motion if user prefers */
@media (prefers-reduced-motion: reduce){
  .hero-bg, .anno-track, .stripe-track, .orb, .hero-card .seal{
    animation: none !important;
  }
  [data-reveal], [data-reveal-fade]{ opacity: 1 !important; transform: none !important; }
  .svc:hover, .why-card:hover, .port-card:hover{ transform: none !important; }
}

/* Touch device tweaks - remove hover effects that don't translate */
@media (hover: none){
  .svc:hover{ transform: none; box-shadow: none; }
  .svc:hover .svc-img{ transform: none; }
  .port-card:hover{ transform: none; box-shadow: 4px 4px 0 var(--pe-ink); }
  .why-card:hover{ transform: none; }
  .area-chip:hover{ transform: none; }
}

/* ============================================================
   Clean Free Estimate CTA card - replaces ugly callout-with-text-link
   ============================================================ */
.estimate-cta{
  background: var(--pe-cream-2);
  border: 2px solid var(--pe-ink);
  box-shadow: 6px 6px 0 var(--pe-blue);
  padding: 40px 36px;
  margin: 50px 0 16px;
  text-align: center;
  position: relative;
}
.estimate-cta::before{
  content:""; position: absolute; inset: 8px;
  border: 1px dashed var(--pe-ink); pointer-events: none;
}
.estimate-cta > *{ position: relative; }
.estimate-cta .eyebrow{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.3em;
  text-transform: uppercase; color: var(--pe-blue); font-weight: 700;
  margin-bottom: 10px; display: inline-block;
}
.estimate-cta h3{
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(28px, 3.6vw, 42px);
  line-height: 1.05; color: var(--pe-navy); letter-spacing: -0.02em;
  margin-bottom: 12px;
}
.estimate-cta h3 .italic{ font-style: italic; font-weight: 400; color: var(--pe-blue); }
.estimate-cta p{
  font-family: var(--font-body); font-size: 15px; line-height: 1.55;
  color: var(--pe-navy); opacity: .9;
  max-width: 520px; margin: 0 auto 22px;
}
.estimate-cta .btn{
  font-size: 15px; padding: 16px 30px;
}
.estimate-cta .cta-secondary{
  display: block; margin-top: 14px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--pe-navy); opacity: .65;
}
.estimate-cta .cta-secondary a{
  color: var(--pe-blue); font-weight: 700;
  border-bottom: 1px dashed currentColor;
}
@media (max-width: 640px){
  .estimate-cta{ padding: 28px 22px; box-shadow: 4px 4px 0 var(--pe-blue); }
  .estimate-cta h3{ font-size: 24px; }
  .estimate-cta p{ font-size: 14px; }
  .estimate-cta .btn{ font-size: 14px; padding: 14px 24px; width: 100%; justify-content: center; }
}
