/*
Theme Name: VinylForDecks.ca
Theme URI: https://vinylfordecks.ca/
Author: VinylForDecks.ca
Description: Premium one-page WordPress lead generation theme for DeckRite vinyl membrane decking, waterproof deck surfaces, colours, accessories, specifications, FAQ, and knowledge base content.
Version: 3.6
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: vinyl-for-decks
*/

:root{
  --vfd-blue:#0B5DA8;
  --vfd-blue-2:#1A78C2;
  --vfd-navy:#0C1722;
  --vfd-slate:#172333;
  --vfd-grey:#68717D;
  --vfd-light:#F4F7FA;
  --vfd-line:#D9E2EC;
  --vfd-red:#C51F2B;
  --vfd-white:#FFFFFF;
  --vfd-ice:#EAF3FB;
  --vfd-green:#60856D;
  --vfd-radius:28px;
  --vfd-shadow:0 24px 60px rgba(12,23,34,.14);
  --vfd-shadow-soft:0 14px 36px rgba(12,23,34,.09);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--vfd-white);color:var(--vfd-slate);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.6;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none} a:hover{text-decoration:none}
img{max-width:100%;height:auto;display:block}.screen-reader-text{position:absolute!important;left:-9999px}.vfd-wrap{width:min(1180px,calc(100% - 40px));margin-inline:auto}.vfd-narrow{width:min(900px,calc(100% - 40px));margin-inline:auto}.vfd-section{padding:94px 0;position:relative;overflow:hidden}.vfd-section.alt{background:linear-gradient(180deg,#f8fbfe 0%,#eef5fb 100%)}.vfd-section.dark{background:linear-gradient(135deg,#0C1722 0%,#13293C 100%);color:#fff}.vfd-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 13px;border:1px solid rgba(11,93,168,.18);border-radius:999px;background:#fff;color:var(--vfd-blue);font-weight:900;font-size:13px;letter-spacing:.08em;text-transform:uppercase}.dark .vfd-eyebrow{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.16);color:#fff}.vfd-section h1,.vfd-section h2,.vfd-section h3{line-height:1.08;margin:0;color:inherit;letter-spacing:-.035em}.vfd-section h1{font-size:clamp(46px,7vw,86px);max-width:900px}.vfd-section h2{font-size:clamp(34px,5vw,58px);margin-top:18px}.vfd-section h3{font-size:clamp(22px,3vw,32px)}.vfd-lead{font-size:clamp(18px,2.3vw,23px);color:#526071;max-width:810px;margin:20px 0 0}.dark .vfd-lead{color:#d7e2ed}.vfd-muted{color:#607084}.dark .vfd-muted{color:#c2cfdd}.vfd-buttons{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}.vfd-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:54px;padding:15px 23px;border-radius:16px;font-weight:900;border:2px solid transparent;box-shadow:0 12px 26px rgba(12,23,34,.14);transition:.2s ease}.vfd-btn.primary{background:var(--vfd-red);color:#fff}.vfd-btn.secondary{background:var(--vfd-blue);color:#fff}.vfd-btn.ghost{background:#fff;color:var(--vfd-slate);border-color:var(--vfd-line)}.vfd-btn:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(12,23,34,.19)}

.vfd-canada-flag{display:inline-block;position:relative;width:34px;height:22px;flex:0 0 34px;border-radius:4px;background:#fff;border:1px solid rgba(0,0,0,.1);vertical-align:-5px;box-shadow:0 2px 5px rgba(0,0,0,.08);overflow:hidden}.vfd-canada-flag:before,.vfd-canada-flag:after{content:"";position:absolute;top:0;width:8px;height:100%;background:var(--vfd-red)}.vfd-canada-flag:before{left:0}.vfd-canada-flag:after{right:0}.vfd-canada-flag i{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:13px;height:13px;background:var(--vfd-red);clip-path:polygon(50% 0,61% 34%,95% 17%,74% 47%,100% 56%,66% 60%,72% 100%,50% 75%,28% 100%,34% 60%,0 56%,26% 47%,5% 17%,39% 34%)}.vfd-canada-badge{display:inline-flex;align-items:center;gap:9px;padding:8px 13px;border-radius:999px;background:#fff;border:1px solid var(--vfd-line);box-shadow:0 8px 18px rgba(12,23,34,.06);font-weight:900;color:var(--vfd-slate)}.dark .vfd-canada-badge{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.18);color:#fff}.vfd-topbar{background:var(--vfd-navy);color:#eaf3fb;font-weight:800;font-size:14px}.vfd-topbar .vfd-wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:44px}.vfd-topbar a{color:#fff}.vfd-header{position:sticky;top:0;z-index:99;background:#fff;border-bottom:1px solid rgba(217,226,236,.9);box-shadow:0 10px 28px rgba(12,23,34,.05)}.admin-bar .vfd-header{top:32px}.vfd-header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:96px}.vfd-brand{display:flex;align-items:center;gap:13px;font-weight:1000;letter-spacing:-.04em;font-size:24px;white-space:nowrap}.vfd-main-logo,.vfd-brand .custom-logo{width:min(310px,46vw);max-height:76px;object-fit:contain;filter:none;background:transparent;mix-blend-mode:normal}.vfd-brand .custom-logo-link{display:flex;align-items:center}.vfd-brand-mark{display:grid;place-items:center;width:48px;height:48px;border-radius:15px;background:linear-gradient(135deg,var(--vfd-blue),var(--vfd-blue-2));color:#fff;font-weight:1000;box-shadow:0 10px 20px rgba(11,93,168,.24);position:relative}.vfd-brand-mark:after{content:"";position:absolute;right:-6px;bottom:-6px;width:22px;height:22px;background:var(--vfd-red);border-radius:8px;border:3px solid #fff}.vfd-brand small{display:block;font-size:12px;letter-spacing:.13em;color:var(--vfd-red);font-weight:900;text-transform:uppercase;margin-top:-2px}.vfd-nav{display:flex;align-items:center;gap:8px}.vfd-nav a{font-size:14px;font-weight:900;color:#263443;padding:10px 11px;border-radius:999px}.vfd-nav a:hover{background:var(--vfd-ice);color:var(--vfd-blue)}.vfd-mobile-toggle{display:none;background:#fff;border:1px solid var(--vfd-line);border-radius:14px;padding:10px 12px;font-weight:900;color:var(--vfd-slate)}

.vfd-hero{background:radial-gradient(circle at 82% 8%, rgba(26,120,194,.25), transparent 34%),linear-gradient(135deg,#0B1622 0%,#132A3D 70%,#153854 100%);color:#fff;min-height:760px;padding:92px 0 74px}.vfd-hero-grid{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(360px,.78fr);gap:50px;align-items:center}.vfd-hero .vfd-lead{color:#d6e3ef}.vfd-hero-meta{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}.vfd-pill{display:inline-flex;align-items:center;gap:9px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);padding:10px 13px;border-radius:999px;font-weight:900;color:#fff}.vfd-hero-card{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.18);border-radius:34px;padding:14px;box-shadow:0 28px 80px rgba(0,0,0,.32);position:relative}.vfd-hero-card img{border-radius:24px;aspect-ratio:4/3;object-fit:cover;width:100%;cursor:zoom-in;image-rendering:auto;backface-visibility:hidden;transform:translateZ(0)}.vfd-hero-floating{position:absolute;left:-24px;bottom:28px;background:#fff;color:var(--vfd-slate);padding:16px 18px;border-radius:18px;box-shadow:var(--vfd-shadow);font-weight:1000}.vfd-quick-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:56px}.vfd-quick-card{background:#fff;color:var(--vfd-slate);border-radius:24px;padding:24px;box-shadow:var(--vfd-shadow-soft);border:1px solid rgba(217,226,236,.8);min-height:165px}.vfd-quick-card span{display:block;width:100%;height:50px;border-radius:13px;background:linear-gradient(90deg,var(--vfd-blue),var(--vfd-blue-2));margin-bottom:20px}.vfd-quick-card:nth-child(2) span{background:linear-gradient(90deg,#5E6874,#A7B0B9)}.vfd-quick-card:nth-child(3) span{background:linear-gradient(90deg,var(--vfd-red),#e54855)}.vfd-quick-card:nth-child(4) span{background:linear-gradient(90deg,#5D7E6B,var(--vfd-blue))}.vfd-quick-card strong{display:block;font-size:20px;line-height:1.18;margin-bottom:10px}.vfd-sticky-tabs{position:sticky;top:86px;z-index:40;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--vfd-line);box-shadow:0 10px 26px rgba(12,23,34,.06)}.admin-bar .vfd-sticky-tabs{top:118px}.vfd-sticky-tabs .vfd-wrap{display:flex;align-items:center;gap:8px;overflow:auto;padding:12px 0}.vfd-sticky-tabs a{flex:0 0 auto;border:1px solid var(--vfd-line);background:#fff;border-radius:999px;padding:10px 14px;font-weight:900;font-size:14px;color:#2c3a49}.vfd-sticky-tabs a:hover,.vfd-sticky-tabs a.is-active{background:var(--vfd-blue);border-color:var(--vfd-blue);color:#fff}

.vfd-two{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:50px;align-items:start}.vfd-card{background:#fff;border:1px solid var(--vfd-line);border-radius:var(--vfd-radius);padding:28px;box-shadow:var(--vfd-shadow-soft);color:var(--vfd-slate)}.vfd-card.dark-card{background:#111f2d;border-color:rgba(255,255,255,.14);color:#fff}.vfd-card h3{font-size:26px;margin-bottom:10px}.vfd-check-list{display:grid;gap:14px;margin:26px 0 0;padding:0;list-style:none}.vfd-check-list li{display:flex;gap:11px;align-items:flex-start;font-weight:750;color:#354456}.vfd-check-list li:before{content:"";width:22px;height:22px;flex:0 0 22px;border-radius:7px;background:var(--vfd-blue);margin-top:2px;box-shadow:inset 0 0 0 6px #fff;border:2px solid var(--vfd-blue)}.dark .vfd-check-list li{color:#e3edf6}.vfd-swatch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.vfd-swatch{position:relative;border-radius:20px;overflow:hidden;min-height:146px;background:#ddd;box-shadow:var(--vfd-shadow-soft);border:1px solid rgba(217,226,236,.9)}.vfd-swatch img{width:100%;height:100%;min-height:146px;object-fit:cover;cursor:zoom-in;image-rendering:auto;backface-visibility:hidden;transform:translateZ(0)}.vfd-swatch b{position:absolute;left:12px;bottom:12px;background:rgba(12,23,34,.82);color:#fff;border-radius:999px;padding:7px 10px;font-size:13px}.vfd-series{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:28px}.vfd-series .vfd-card{padding:24px}.vfd-series strong{display:block;color:var(--vfd-blue);font-size:20px;margin-bottom:8px}.vfd-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:36px}.vfd-gallery figure{margin:0;position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--vfd-shadow-soft);background:#d7e2ed}.vfd-gallery img{width:100%;height:235px;object-fit:cover;object-position:center;transition:.3s ease;cursor:zoom-in;image-rendering:auto;backface-visibility:hidden;transform:translateZ(0)}.vfd-gallery figure:hover img{transform:scale(1.025) translateZ(0)}.vfd-gallery figcaption{position:absolute;left:12px;right:12px;bottom:12px;padding:10px 12px;border-radius:14px;background:rgba(12,23,34,.78);color:#fff;font-weight:900;font-size:13px;pointer-events:none}.vfd-testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:28px}.vfd-quote-card{background:#fff;border:1px solid var(--vfd-line);border-radius:24px;padding:24px;box-shadow:var(--vfd-shadow-soft)}.vfd-stars{letter-spacing:3px;color:var(--vfd-red);font-size:18px}.vfd-spec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:30px}.vfd-spec{background:#fff;border-radius:22px;padding:22px;border:1px solid var(--vfd-line);box-shadow:var(--vfd-shadow-soft)}.vfd-spec b{font-size:30px;color:var(--vfd-blue);display:block;line-height:1}.vfd-process{counter-reset:step;display:grid;gap:16px;margin-top:28px}.vfd-process li{list-style:none;counter-increment:step;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:24px;padding:20px 22px 20px 72px;position:relative}.vfd-process li:before{content:counter(step);position:absolute;left:20px;top:20px;width:36px;height:36px;border-radius:12px;background:var(--vfd-red);display:grid;place-items:center;font-weight:1000}.vfd-accessory-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:28px}.vfd-accessory{background:#fff;border:1px solid var(--vfd-line);border-radius:24px;padding:24px;box-shadow:var(--vfd-shadow-soft)}.vfd-accessory .icon{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--vfd-blue),var(--vfd-blue-2));margin-bottom:18px;position:relative}.vfd-accessory .icon:after{content:"";position:absolute;width:22px;height:7px;background:var(--vfd-red);border-radius:20px;right:-6px;bottom:8px}.vfd-faq{display:grid;gap:14px;margin-top:32px}.vfd-faq details{background:#fff;border:1px solid var(--vfd-line);border-radius:20px;padding:18px 20px;box-shadow:0 8px 20px rgba(12,23,34,.06)}.vfd-faq summary{font-size:18px;font-weight:1000;cursor:pointer}.vfd-faq p{margin:12px 0 0;color:#526071}.vfd-kb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}.vfd-post-card{background:#fff;border:1px solid var(--vfd-line);border-radius:24px;padding:24px;box-shadow:var(--vfd-shadow-soft)}.vfd-post-card .date{color:var(--vfd-red);font-weight:900;font-size:13px;text-transform:uppercase;letter-spacing:.08em}.vfd-post-card h3{font-size:24px;margin:10px 0}.vfd-quote-band{background:linear-gradient(135deg,var(--vfd-blue),#13334c);color:#fff;border-radius:36px;padding:36px;margin-top:46px;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;box-shadow:var(--vfd-shadow)}.vfd-quote-band h3{font-size:32px}.vfd-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.vfd-form-grid .full{grid-column:1/-1}.vfd-form input,.vfd-form textarea,.vfd-form select{width:100%;min-height:52px;border:1px solid var(--vfd-line);border-radius:14px;padding:12px 14px;font:inherit;background:#fff;color:var(--vfd-slate)}.vfd-form textarea{min-height:120px;resize:vertical}.vfd-footer{background:var(--vfd-navy);color:#dce7f2;padding:58px 0 30px}.vfd-footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:30px}.vfd-footer h3{color:#fff;margin:0 0 14px;font-size:22px}.vfd-footer a{color:#fff;font-weight:800}.vfd-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}.vfd-footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:32px;padding-top:22px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;color:#aebdcb}.vfd-page-header{background:linear-gradient(135deg,#0C1722,#153854);color:#fff;padding:84px 0}.vfd-content{padding:64px 0}.vfd-content .entry-content{font-size:18px}.vfd-content .entry-content a{text-decoration:underline;color:var(--vfd-blue)}.vfd-content .entry-content img{border-radius:20px}.vfd-empty{background:#fff;border:1px dashed var(--vfd-line);border-radius:20px;padding:28px;color:#526071}

@media (max-width:1120px){.vfd-contact-layout{grid-template-columns:1fr}.vfd-nav{display:none;position:absolute;left:20px;right:20px;top:92px;background:#fff;border:1px solid var(--vfd-line);border-radius:22px;padding:12px;box-shadow:var(--vfd-shadow);flex-direction:column;align-items:stretch}.vfd-nav.is-open{display:flex}.vfd-mobile-toggle{display:inline-flex}.vfd-hero-grid,.vfd-two{grid-template-columns:1fr}.vfd-hero-card{max-width:660px}.vfd-quick-cards,.vfd-gallery,.vfd-spec-grid,.vfd-accessory-grid{grid-template-columns:repeat(2,1fr)}.vfd-sticky-tabs{top:86px}}
@media (max-width:760px){.vfd-modal{padding:14px}.vfd-modal-content{display:block}.vfd-modal-content p{display:none}.vfd-modal-nav{width:44px;height:60px;font-size:42px}.vfd-wrap,.vfd-narrow{width:min(100% - 28px,1180px)}.vfd-topbar .vfd-wrap{justify-content:center;text-align:center;flex-direction:column;padding:8px 0}.vfd-header-inner{min-height:78px}.vfd-brand{font-size:20px}.vfd-main-logo,.vfd-brand .custom-logo{width:min(235px,60vw);max-height:60px}.vfd-brand-mark{width:44px;height:44px}.vfd-hero{padding:60px 0 52px;min-height:auto}.vfd-section{padding:64px 0}.vfd-quick-cards,.vfd-series,.vfd-swatch-grid,.vfd-gallery,.vfd-testimonials,.vfd-spec-grid,.vfd-accessory-grid,.vfd-kb-grid,.vfd-footer-grid{grid-template-columns:1fr}.vfd-quote-band{grid-template-columns:1fr;border-radius:26px}.vfd-form-grid{grid-template-columns:1fr}.vfd-hero-floating{position:static;margin-top:14px}.vfd-gallery img{height:260px}.vfd-sticky-tabs{display:none}}


.vfd-mini-note{display:inline-flex;align-items:center;margin-top:10px;padding:8px 12px;border-radius:999px;background:var(--vfd-ice);color:var(--vfd-blue);font-size:13px;font-weight:900}
.vfd-section-copy{font-size:18px;color:#526071;max-width:760px;margin:16px 0 24px}.dark .vfd-section-copy{color:#d7e2ed}.vfd-contact-layout{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(340px,.95fr);gap:24px;align-items:start;margin-top:24px}.vfd-form-card h2{margin-top:16px}.vfd-field{display:grid;gap:8px}.vfd-field label,.vfd-form label{font-weight:1000;color:var(--vfd-slate);font-size:14px;letter-spacing:.01em}.vfd-hp-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;overflow:hidden!important}.vfd-form input,.vfd-form textarea,.vfd-form select{width:100%;min-height:54px;border:1px solid #cfd9e3;border-radius:14px;padding:13px 14px;font:inherit;background:#fff;color:var(--vfd-slate);outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}.vfd-form input::placeholder,.vfd-form textarea::placeholder{color:#8795a4}.vfd-form input:focus,.vfd-form textarea:focus,.vfd-form select:focus{border-color:var(--vfd-blue);box-shadow:0 0 0 4px rgba(11,93,168,.13)}.vfd-form textarea{min-height:130px;resize:vertical}.vfd-status{min-height:24px;margin:16px 0 0;font-weight:900}.vfd-status.success{color:#1f7a46}.vfd-status.error{color:var(--vfd-red)}.vfd-status.info{color:var(--vfd-blue)}.vfd-contact-card{display:grid;gap:18px}.vfd-contact-card h3{margin:0 0 4px}.vfd-contact-method{padding:16px 0;border:0;border-bottom:1px solid rgba(12,23,34,.12);border-radius:0;background:transparent;display:grid;gap:5px}.vfd-contact-method strong{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--vfd-grey)}.vfd-contact-method span,.vfd-contact-method a{font-size:17px;font-weight:900;color:var(--vfd-slate)}.vfd-contact-note{padding:18px;border-radius:18px;background:linear-gradient(135deg,var(--vfd-blue),#163a56);color:#fff;font-weight:800;margin-top:6px}.vfd-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;padding:28px;background:rgba(5,12,20,.82);backdrop-filter:blur(10px)}.vfd-modal.open{display:flex}.vfd-modal-box{width:min(1120px,94vw);max-height:88vh;background:#fff;border-radius:28px;box-shadow:0 30px 90px rgba(0,0,0,.45);overflow:hidden;display:grid;grid-template-rows:minmax(0,1fr) auto}.vfd-modal-media{background:#0b1622;display:grid;place-items:center;min-height:300px;max-height:72vh}.vfd-modal-media img{max-width:100%;max-height:72vh;width:auto;height:auto;object-fit:contain}.vfd-modal-content{display:flex;align-items:center;gap:16px;justify-content:space-between;padding:18px 22px;color:var(--vfd-slate)}.vfd-modal-content h3{font-size:22px;margin:0}.vfd-modal-content p{margin:0;color:#607084}.vfd-modal-counter{font-weight:1000;color:var(--vfd-red)}.vfd-modal-close,.vfd-modal-nav{position:absolute;border:0;color:#fff;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s ease}.vfd-modal-close{top:18px;right:20px;width:48px;height:48px;border-radius:999px;font-size:34px;line-height:1}.vfd-modal-nav{top:50%;transform:translateY(-50%);width:54px;height:74px;border-radius:18px;font-size:54px}.vfd-modal-prev{left:20px}.vfd-modal-next{right:20px}.vfd-modal-close:hover,.vfd-modal-nav:hover{background:rgba(255,255,255,.27)}body.vfd-modal-active{overflow:hidden}


/* v1.5 SEO + BEAST hardening */
.vfd-main-logo,
.vfd-brand .custom-logo {
  height: auto;
  image-rendering: -webkit-optimize-contrast;
  transform: translateZ(0);
}
.vfd-brand {
  min-width: 0;
}
.vfd-post-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.vfd-post-card .vfd-post-thumb {
  display: block;
  margin: -24px -24px 6px;
  border-radius: 24px 24px 0 0;
  overflow: hidden;
  background: var(--vfd-ice);
  border-bottom: 1px solid var(--vfd-line);
}
.vfd-post-card .vfd-post-thumb img {
  width: 100%;
  height: 210px;
  object-fit: cover;
  display: block;
}
.vfd-post-meta,
.vfd-entry-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  color: #607084;
  font-weight: 850;
  font-size: 14px;
}
.vfd-entry-tax {
  margin-top: 34px;
  padding-top: 24px;
  border-top: 1px solid var(--vfd-line);
  display: grid;
  gap: 10px;
  color: #607084;
  font-weight: 800;
}
.vfd-entry-tax a { color: var(--vfd-blue); text-decoration: none; }
.vfd-pagination,
.navigation.pagination {
  margin-top: 34px;
}
.nav-links {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.nav-links .page-numbers {
  border: 1px solid var(--vfd-line);
  border-radius: 999px;
  padding: 9px 13px;
  background: #fff;
  font-weight: 900;
}
.nav-links .page-numbers.current {
  background: var(--vfd-blue);
  color: #fff;
  border-color: var(--vfd-blue);
}
.vfd-form input:invalid:not(:placeholder-shown),
.vfd-form select:invalid:not(:placeholder-shown),
.vfd-form textarea:invalid:not(:placeholder-shown) {
  border-color: rgba(197,31,43,.55);
}
@media (max-width:760px){
  .vfd-post-card .vfd-post-thumb img { height: 240px; }
}

.vfd-footer address {
  margin: 0;
  font-style: normal;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.7;
}
.vfd-footer address a {
  color: #ffffff;
  text-decoration: none;
  font-weight: 800;
}
.vfd-footer address a:hover,
.vfd-footer address a:focus {
  color: #ffffff;
  text-decoration: underline;
}


/* v1.7 visual tightening, Zonda-style header, and sharper image presentation */
html { scroll-padding-top: 92px; }
.vfd-wrap { width: min(1120px, calc(100% - 44px)); }
.vfd-narrow { width: min(820px, calc(100% - 44px)); }
.vfd-section { padding: 72px 0; }
.vfd-section h1 { font-size: clamp(36px, 5vw, 64px); max-width: 760px; letter-spacing: -.045em; }
.vfd-section h2 { font-size: clamp(28px, 3.6vw, 44px); margin-top: 14px; }
.vfd-section h3 { font-size: clamp(20px, 2.4vw, 27px); }
.vfd-lead { font-size: clamp(16px, 1.55vw, 19px); max-width: 700px; margin-top: 16px; }
.vfd-eyebrow { padding: 6px 11px; font-size: 11px; letter-spacing: .1em; }
.vfd-btn { min-height: 44px; padding: 11px 17px; border-radius: 13px; font-size: 14px; box-shadow: 0 8px 18px rgba(12,23,34,.12); }
.vfd-card { padding: 22px; border-radius: 22px; }
.vfd-card h3 { font-size: 22px; }
.vfd-topbar { font-size: 13px; }
.vfd-topbar .vfd-wrap { min-height: 36px; }
.vfd-canada-flag { width: 27px; height: 18px; flex-basis: 27px; vertical-align: -4px; }
.vfd-canada-flag:before,.vfd-canada-flag:after { width: 7px; }
.vfd-canada-flag i { width: 11px; height: 11px; }
.vfd-header-inner { min-height: 70px; gap: 18px; }
.vfd-main-logo, .vfd-brand .custom-logo { width: min(230px, 29vw); max-height: 54px; }
.vfd-nav { gap: 2px; flex: 1 1 auto; justify-content: center; min-width: 0; }
.vfd-nav a { font-size: 13px; line-height: 1; font-weight: 900; padding: 9px 8px; white-space: nowrap; }
.vfd-nav-actions { display:flex; align-items:center; gap:10px; flex: 0 0 auto; }
.vfd-header-quote { min-height: 38px; padding: 8px 13px; border-radius: 999px; font-size: 13px; box-shadow:none; white-space:nowrap; }
.vfd-mobile-toggle { min-height: 40px; padding: 8px 12px; }
.vfd-hero { min-height: 610px; padding: 70px 0 58px; }
.vfd-hero-grid { grid-template-columns: minmax(0,.92fr) minmax(360px,.88fr); gap: 38px; }
.vfd-hero-card { border-radius: 28px; padding: 10px; }
.vfd-hero-card img { aspect-ratio: 16/10; border-radius: 20px; object-position: center center; }
.vfd-hero-floating { left: 18px; bottom: 18px; padding: 11px 13px; border-radius: 14px; font-size: 13px; }
.vfd-hero-meta { gap: 9px; margin-top: 20px; }
.vfd-pill { padding: 8px 11px; font-size: 13px; }
.vfd-buttons { gap: 10px; margin-top: 26px; }
.vfd-quick-cards { gap: 12px; margin-top: 36px; }
.vfd-quick-card { min-height: 128px; padding: 17px; border-radius: 18px; }
.vfd-quick-card span { height: 34px; border-radius: 10px; margin-bottom: 13px; }
.vfd-quick-card strong { font-size: 16px; margin-bottom: 6px; }
.vfd-quick-card em { font-size: 13px; line-height: 1.35; }
.vfd-sticky-tabs { top: 70px; }
.admin-bar .vfd-sticky-tabs { top: 102px; }
.vfd-sticky-tabs .vfd-wrap { justify-content: center; padding: 9px 0; }
.vfd-sticky-tabs a { padding: 8px 12px; font-size: 13px; }
.vfd-two { gap: 38px; align-items: center; }
.vfd-check-list { gap: 11px; margin-top: 20px; }
.vfd-check-list li { font-size: 15px; }
.vfd-check-list li:before { width: 18px; height: 18px; flex-basis: 18px; border-radius: 6px; }
.vfd-swatch { min-height: 128px; border-radius: 16px; }
.vfd-swatch img { min-height: 128px; }
.vfd-series { gap: 14px; margin-top: 22px; }
.vfd-gallery { gap: 12px; margin-top: 22px; }
.vfd-gallery figure { border-radius: 18px; }
.vfd-gallery img { height: 190px; object-position: center; }
.vfd-gallery figcaption { font-size: 12px; padding: 8px 10px; }
.vfd-testimonials { gap: 14px; margin-top: 20px; }
.vfd-quote-card { padding: 18px; border-radius: 18px; }
.vfd-spec-grid { gap: 12px; margin-top: 24px; }
.vfd-spec { padding: 18px; border-radius: 16px; }
.vfd-spec b { font-size: 24px; }
.vfd-process { gap: 10px; margin-top: 20px; }
.vfd-process li { padding: 15px 16px 15px 58px; border-radius: 16px; }
.vfd-process li:before { left: 15px; top: 15px; width: 30px; height: 30px; border-radius: 10px; }
.vfd-accessory-grid { gap: 12px; margin-top: 22px; }
.vfd-accessory { padding: 18px; border-radius: 18px; }
.vfd-accessory .icon { width: 36px; height: 36px; border-radius: 12px; margin-bottom: 13px; }
.vfd-faq { gap: 10px; margin-top: 24px; }
.vfd-faq details { padding: 14px 16px; border-radius: 15px; }
.vfd-faq summary { font-size: 16px; }
.vfd-kb-grid { gap: 14px; margin-top: 24px; }
.vfd-post-card { padding: 18px; border-radius: 18px; }
.vfd-post-card h3 { font-size: 20px; margin: 4px 0; }
.vfd-post-card .vfd-post-thumb { margin: -18px -18px 4px; border-radius: 18px 18px 0 0; }
.vfd-post-card .vfd-post-thumb img { height: 170px; }
.vfd-quote-band { padding: 24px; margin-top: 34px; border-radius: 24px; }
.vfd-quote-band h3 { font-size: 24px; }
.vfd-contact-layout { grid-template-columns: minmax(0,1fr) 360px; gap: 22px; align-items: stretch; }
.vfd-form-card h2 { margin-top: 12px; }
.vfd-section-copy { font-size: 15px; margin: 12px 0 18px; }
.vfd-form-grid { gap: 12px; }
.vfd-form input, .vfd-form textarea, .vfd-form select { min-height: 48px; border-radius: 12px; padding: 11px 12px; font-size: 14px; }
.vfd-form textarea { min-height: 108px; }
.vfd-contact-card { gap: 10px; }
.vfd-contact-method { padding: 12px 0; }
.vfd-contact-note { padding: 14px; border-radius: 14px; font-size: 14px; }
.vfd-footer { padding: 44px 0 24px; }
.vfd-footer-grid { gap: 24px; }
.vfd-footer h3 { font-size: 18px; margin-bottom: 10px; }
.vfd-footer p, .vfd-footer li, .vfd-footer address { font-size: 14px; }
.vfd-footer-bottom { margin-top: 24px; padding-top: 18px; font-size: 13px; }
@media (max-width:1180px){
  .vfd-main-logo, .vfd-brand .custom-logo { width:min(205px,28vw); }
  .vfd-nav a { font-size: 12.5px; padding: 8px 6px; }
  .vfd-header-quote { font-size: 12.5px; padding-inline: 11px; }
}
@media (max-width:1080px){
  .vfd-nav{display:none;position:absolute;left:20px;right:20px;top:78px;background:#fff;border:1px solid var(--vfd-line);border-radius:20px;padding:12px;box-shadow:var(--vfd-shadow);flex-direction:column;align-items:stretch;justify-content:flex-start}
  .vfd-nav.is-open{display:flex}.vfd-mobile-toggle{display:inline-flex}.vfd-header-quote{display:none}.vfd-hero-grid,.vfd-two{grid-template-columns:1fr}.vfd-contact-layout{grid-template-columns:1fr}.vfd-hero-card{max-width:760px}.vfd-quick-cards,.vfd-gallery,.vfd-spec-grid,.vfd-accessory-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .vfd-wrap,.vfd-narrow{width:min(100% - 30px,1120px)}
  .vfd-section{padding:54px 0}.vfd-section h1{font-size:clamp(34px,11vw,48px)}.vfd-section h2{font-size:clamp(26px,8vw,36px)}.vfd-lead{font-size:16px}.vfd-header-inner{min-height:68px}.vfd-main-logo,.vfd-brand .custom-logo{width:min(220px,58vw);max-height:54px}.vfd-hero{padding:50px 0 46px}.vfd-hero-card img{aspect-ratio: 4/3}.vfd-quick-cards,.vfd-series,.vfd-swatch-grid,.vfd-gallery,.vfd-testimonials,.vfd-spec-grid,.vfd-accessory-grid,.vfd-kb-grid,.vfd-footer-grid{grid-template-columns:1fr}.vfd-gallery img{height:235px}.vfd-quote-band{grid-template-columns:1fr}.vfd-form-grid{grid-template-columns:1fr}.vfd-sticky-tabs{display:none}.vfd-topbar .vfd-wrap{justify-content:center;text-align:center;flex-direction:column;padding:7px 0}.vfd-footer-grid{text-align:left}
}

/* v1.9: gallery labels removed */
.vfd-gallery figcaption{display:none!important}


/* v2.1 reviews section */
.vfd-section.reviews{background:#f3f8fc}
.vfd-section.reviews .vfd-lead{max-width:850px}
.vfd-section.reviews .vfd-testimonials{margin-top:28px}
.vfd-section.reviews .vfd-quote-card p{font-size:17px;line-height:1.65}
@media (max-width:1180px){
  .vfd-nav a{font-size:14px;padding:9px 10px}
  .vfd-header-quote{padding:9px 12px;font-size:13px}
}


/* v2.2 blue theme scrollbar */
html{
  scrollbar-width:thin;
  scrollbar-color:var(--vfd-blue) #eaf3f8;
}
::-webkit-scrollbar{
  width:14px;
  height:14px;
}
::-webkit-scrollbar-track{
  background:#eaf3f8;
}
::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,var(--vfd-blue),var(--vfd-blue-2));
  border:3px solid #eaf3f8;
  border-radius:999px;
}
::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,var(--vfd-blue-2),var(--vfd-red));
}


/* v2.2 cleaner product note chips */
.vfd-mini-note{
  max-width:100%;
  white-space:normal;
  line-height:1.35;
}


/* v2.3 full DeckRite source-content pass and technical-card fixes */
.vfd-spec-grid.spec-readable{grid-template-columns:repeat(4,1fr)}
.vfd-spec-grid.spec-readable .vfd-spec{min-height:136px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;color:var(--vfd-slate);padding:22px 18px}
.vfd-spec-grid.spec-readable .vfd-spec b{font-size:clamp(26px,2.6vw,38px);line-height:1;color:var(--vfd-blue)}
.vfd-spec-grid.spec-readable .vfd-spec span{display:block;color:#405166;font-size:14px;line-height:1.42;max-width:220px}
.colours-layout{grid-template-columns:minmax(0,.72fr) minmax(0,1.28fr)}
.vfd-swatch-grid.all-colours{grid-template-columns:repeat(4,1fr);align-items:stretch}
.vfd-swatch-grid.all-colours .vfd-swatch{min-height:132px}
.vfd-swatch-grid.all-colours .vfd-swatch img{min-height:132px}
.vfd-gallery.expanded-gallery{grid-template-columns:repeat(5,1fr)}
.vfd-gallery.expanded-gallery img{height:190px}
.vfd-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px}
.vfd-info-grid .vfd-card h3{color:var(--vfd-blue)}
.vfd-drawing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:30px}
.vfd-drawing-card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:16px;padding:14px 14px;color:#eef6ff;font-weight:850;line-height:1.35;font-size:14px}
.vfd-accessory-grid.detailed-accessories{grid-template-columns:repeat(4,1fr)}
.vfd-accessory h3{font-size:18px;color:var(--vfd-slate);margin:0 0 8px}.vfd-accessory p{font-size:14px;line-height:1.45;color:#526071}
.vfd-section.reviews .vfd-quote-card p{font-size:16px;line-height:1.58}.vfd-section.reviews .vfd-quote-card strong{display:block;margin-top:16px;color:var(--vfd-slate)}
.vfd-open-image{image-rendering:auto}
@media(max-width:1180px){.vfd-gallery.expanded-gallery{grid-template-columns:repeat(4,1fr)}.vfd-swatch-grid.all-colours,.vfd-drawing-grid,.vfd-accessory-grid.detailed-accessories{grid-template-columns:repeat(3,1fr)}}
@media(max-width:900px){.vfd-info-grid,.vfd-spec-grid.spec-readable{grid-template-columns:repeat(2,1fr)}.vfd-gallery.expanded-gallery{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.vfd-swatch-grid.all-colours,.vfd-gallery.expanded-gallery,.vfd-info-grid,.vfd-drawing-grid,.vfd-accessory-grid.detailed-accessories,.vfd-spec-grid.spec-readable{grid-template-columns:1fr}.vfd-gallery.expanded-gallery img{height:250px}.vfd-spec-grid.spec-readable .vfd-spec{min-height:112px}.colours-layout{grid-template-columns:1fr}}


/* v2.5 homepage cleanup and typography tightening */
:root{
  --vfd-section-y:74px;
}
.vfd-section{padding:var(--vfd-section-y) 0}
.vfd-hero{min-height:auto;padding:74px 0 58px}
.vfd-hero h1{font-size:clamp(42px,5.2vw,78px);line-height:.96;letter-spacing:-.055em}
.vfd-section h2{font-size:clamp(30px,3.5vw,56px);line-height:1.04;letter-spacing:-.04em}
.vfd-page-hero h1{font-size:clamp(40px,4.6vw,68px);line-height:1}
.vfd-lead{font-size:clamp(17px,1.25vw,21px);line-height:1.62}
.vfd-card{padding:26px}
.vfd-quick-cards{margin-top:38px}
.vfd-quick-card{min-height:132px;padding:20px}
.vfd-quick-card span{height:34px;margin-bottom:15px}
.vfd-gallery.featured-gallery{grid-template-columns:repeat(4,minmax(0,1fr))}
.vfd-gallery.featured-gallery figure:nth-child(n+13){display:none}
.gallery-actions{margin-top:26px}
.full-gallery-page{margin-top:26px}
.vfd-form-card .vfd-section-copy{font-size:16px}
@media (max-width:980px){
  :root{--vfd-section-y:58px}
  .vfd-hero{padding:54px 0 44px}
  .vfd-gallery.featured-gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:620px){
  .vfd-gallery.featured-gallery{grid-template-columns:1fr}
  .vfd-section h2{font-size:34px}
}


/* v2.6 visual repair: balanced homepage, fixed featured gallery cards */
.vfd-wrap{
  max-width:1180px;
}
.vfd-header .vfd-wrap,
.vfd-topbar .vfd-wrap{
  max-width:1280px;
}
.vfd-hero{
  min-height:620px;
  padding:86px 0 66px;
}
.vfd-hero h1{
  font-size:clamp(46px,5.8vw,86px);
  line-height:.94;
  letter-spacing:-.055em;
}
.vfd-section{
  padding:86px 0;
}
.vfd-section h2{
  font-size:clamp(34px,4vw,62px);
  line-height:1.02;
}
.vfd-lead{
  font-size:clamp(18px,1.35vw,22px);
  line-height:1.62;
}
.vfd-card{
  padding:30px;
}
.vfd-quick-cards{
  margin-top:48px;
}
.vfd-quick-card{
  min-height:150px;
  padding:22px;
}
.vfd-quick-card span{
  height:42px;
  margin-bottom:18px;
}
.vfd-gallery.featured-gallery,
.vfd-gallery.expanded-gallery{
  align-items:stretch;
}
.vfd-gallery.featured-gallery{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}
.vfd-gallery.featured-gallery figure{
  min-height:0;
  height:auto;
  aspect-ratio:4/3;
  background:#dfeaf2;
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--vfd-shadow-soft);
  border:1px solid rgba(217,226,236,.85);
}
.vfd-gallery.featured-gallery figure img{
  display:block;
  width:100%;
  height:100%;
  min-height:0;
  aspect-ratio:auto;
  object-fit:cover;
  object-position:center;
  border-radius:0;
}
.vfd-gallery.featured-gallery figure:nth-child(n+13){
  display:none;
}
.gallery-actions{
  margin-top:28px;
}
.full-gallery-page figure{
  aspect-ratio:1/1;
  min-height:0;
  overflow:hidden;
}
.full-gallery-page figure img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.vfd-spec-grid.spec-readable{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.vfd-spec-grid.spec-readable .vfd-spec{
  min-height:132px;
  padding:24px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.vfd-spec-grid.spec-readable .vfd-spec b{
  display:block;
  margin-bottom:8px;
}
.vfd-spec-grid.spec-readable .vfd-spec span{
  display:block;
  color:#27384a;
  font-size:14px;
  line-height:1.35;
}
@media (max-width:980px){
  .vfd-hero{
    min-height:auto;
    padding:60px 0 48px;
  }
  .vfd-section{
    padding:64px 0;
  }
  .vfd-gallery.featured-gallery{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .vfd-spec-grid.spec-readable{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width:620px){
  .vfd-gallery.featured-gallery{
    grid-template-columns:1fr;
  }
  .vfd-gallery.featured-gallery figure{
    aspect-ratio:4/3;
  }
  .vfd-section h2{
    font-size:36px;
  }
  .vfd-spec-grid.spec-readable{
    grid-template-columns:1fr;
  }
}


/* v2.7 cleanup: remove unwanted image labels, align hero image, gallery page rename */
.vfd-hero-card{
  align-self:center;
}
.vfd-hero-card img{
  display:block;
}
.vfd-hero-floating{
  display:none!important;
}
.vfd-gallery + .vfd-buttons.gallery-actions{
  margin-top:26px;
}
.vfd-gallery.featured-gallery{
  margin-top:26px;
}
.vfd-gallery.featured-gallery figure img,
.full-gallery-page figure img{
  cursor:zoom-in;
}
.vfd-modal.is-open{
  display:flex;
}
.vfd-modal-media img{
  max-width:min(92vw,1180px);
  max-height:78vh;
  width:auto;
  height:auto;
  object-fit:contain;
  border-radius:18px;
}
.vfd-modal-nav[hidden]{
  display:none!important;
}
.vfd-page-hero{
  background:linear-gradient(180deg,#f5f9fc,#fff);
}


/* v2.8 larger Zonda-style section labels */
.vfd-eyebrow{
  font-size:15px;
  letter-spacing:.14em;
  font-weight:1000;
  padding:11px 18px;
  border-radius:999px;
}
.vfd-section.dark .vfd-eyebrow{
  font-size:16px;
  letter-spacing:.13em;
  padding:12px 22px;
  border-color:rgba(255,255,255,.22);
  background:rgba(255,255,255,.10);
  color:#fff;
  box-shadow:0 10px 28px rgba(0,0,0,.18);
}
.vfd-page-hero .vfd-eyebrow,
.vfd-hero .vfd-eyebrow{
  font-size:15px;
  letter-spacing:.14em;
  padding:11px 18px;
}
@media (max-width:620px){
  .vfd-eyebrow,
  .vfd-section.dark .vfd-eyebrow,
  .vfd-page-hero .vfd-eyebrow,
  .vfd-hero .vfd-eyebrow{
    font-size:13px;
    letter-spacing:.11em;
    padding:9px 14px;
  }
}


/* v3.1 alignment and clean image-only gallery popup */
.colours-layout{
  align-items:flex-start!important;
}
#colours-patterns{
  padding-top:72px;
}
#colours-patterns .vfd-eyebrow{
  margin-top:0;
}
.vfd-hero-meta,
.vfd-pill{
  display:none!important;
}

/* Legacy lightbox rules retained for compatibility; v3.4 final block below makes the popup image-only. */
.vfd-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:34px;
  background:rgba(5,12,20,.86);
  backdrop-filter:blur(8px);
}
.vfd-modal.is-open{
  display:flex!important;
}
html.vfd-modal-open,
html.vfd-modal-open body{
  overflow:hidden;
}
.vfd-modal-box{
  width:auto;
  max-width:94vw;
  max-height:90vh;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:0!important;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  overflow:visible!important;
}
.vfd-modal-media{
  background:transparent!important;
  padding:0!important;
  margin:0!important;
  display:flex;
  align-items:center;
  justify-content:center;
  width:auto!important;
  min-height:0!important;
}
.vfd-modal-media img{
  display:block;
  width:auto!important;
  height:auto!important;
  max-width:88vw!important;
  max-height:82vh!important;
  object-fit:contain!important;
  border-radius:18px;
  box-shadow:0 30px 90px rgba(0,0,0,.55);
}
.vfd-modal-content{
  position:absolute;
  left:50%;
  bottom:22px;
  transform:translateX(-50%);
  background:rgba(11,22,34,.78)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  padding:9px 16px!important;
  min-width:auto!important;
  width:auto!important;
  height:auto!important;
  box-shadow:0 12px 32px rgba(0,0,0,.25);
}
.vfd-modal-content h3,
.vfd-modal-content p{
  display:none!important;
}
.vfd-modal-counter{
  display:block!important;
  font-weight:1000;
  color:#fff!important;
  font-size:16px;
  line-height:1;
}
.vfd-modal-close{
  position:fixed;
  right:28px;
  top:24px;
  width:58px;
  height:58px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.14);
  color:#fff;
  font-size:42px;
  line-height:1;
  cursor:pointer;
  z-index:10002;
}
.vfd-modal-nav{
  position:fixed;
  top:50%;
  transform:translateY(-50%);
  width:58px;
  height:92px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.14);
  color:#fff;
  font-size:54px;
  line-height:1;
  cursor:pointer;
  z-index:10002;
}
.vfd-modal-prev{left:24px}
.vfd-modal-next{right:24px}
.vfd-modal-nav[hidden]{
  display:none!important;
}
@media (max-width:700px){
  .vfd-modal{padding:18px}
  .vfd-modal-media img{
    max-width:94vw!important;
    max-height:78vh!important;
  }
  .vfd-modal-close{
    right:14px;
    top:14px;
    width:48px;
    height:48px;
    font-size:34px;
  }
  .vfd-modal-nav{
    width:46px;
    height:72px;
    font-size:42px;
  }
  .vfd-modal-prev{left:10px}
  .vfd-modal-next{right:10px}
}


/* v3.2 full contact section rebuild */
#quote{
  background:linear-gradient(135deg,#081522 0%,#10283d 100%);
}
#quote .vfd-contact-layout{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(330px,.65fr);
  gap:34px;
  align-items:start;
}
#quote .vfd-form-card,
#quote .vfd-contact-card{
  border-radius:30px;
  border:1px solid rgba(205,219,232,.22);
  box-shadow:0 28px 80px rgba(0,0,0,.22);
}
#quote .vfd-form-card{
  background:#fff;
  padding:42px;
}
#quote .vfd-form-card h2{
  font-size:clamp(36px,4vw,60px);
  line-height:1.03;
  letter-spacing:-.045em;
  margin:0 0 14px;
  color:#152235;
}
#quote .vfd-section-copy{
  color:#53687e!important;
  font-size:18px;
  line-height:1.55;
  max-width:880px;
  margin:0 0 26px;
}
#quote .vfd-form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px 20px;
}
#quote .vfd-field label{
  color:#0d1b2d;
  font-size:15px;
  line-height:1.2;
  margin:0 0 8px;
  font-weight:900;
}
#quote .vfd-field input,
#quote .vfd-field select,
#quote .vfd-field textarea{
  width:100%;
  min-height:54px;
  border-radius:16px;
  border:1px solid #cbd9e6;
  color:#0d1b2d;
  background:#fff;
  font-size:16px;
  padding:13px 15px;
  box-shadow:none;
}
#quote .vfd-field input::placeholder,
#quote .vfd-field textarea::placeholder{
  color:#7b8da1;
}
#quote .vfd-field select{
  color:#0d1b2d;
}
#quote .vfd-field textarea{
  min-height:122px;
  resize:vertical;
}
#quote .vfd-field.full{
  grid-column:1/-1;
}
#quote .vfd-btn.primary[type="submit"]{
  margin-top:20px;
  padding:14px 22px;
  border-radius:999px;
}

/* Right contact card */
#quote .vfd-contact-card{
  background:#fff;
  padding:36px;
  position:sticky;
  top:108px;
}
#quote .vfd-contact-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:auto;
  padding:8px 13px;
  border-radius:999px;
  background:#eef6fc;
  color:#0b63ad;
  font-weight:1000;
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:16px;
}
#quote .vfd-contact-card h3{
  margin:0 0 24px;
  font-size:clamp(26px,2.4vw,36px);
  line-height:1.1;
  letter-spacing:-.03em;
  color:#152235;
}
#quote .vfd-contact-block{
  padding:20px 0;
  border-top:1px solid #e0e8f0;
}
#quote .vfd-contact-block:first-of-type{
  border-top:0;
  padding-top:0;
}
#quote .vfd-contact-block strong{
  display:block;
  margin-bottom:9px;
  color:#68788c;
  font-size:13px;
  letter-spacing:.13em;
  text-transform:uppercase;
  font-weight:1000;
}
#quote .vfd-contact-block address,
#quote .vfd-contact-block a{
  color:#0d1b2d;
  font-size:18px;
  line-height:1.45;
  font-style:normal;
  font-weight:850;
  word-break:break-word;
}
#quote .vfd-contact-block a:hover{
  color:#0b63ad;
}
#quote .vfd-contact-tip{
  margin-top:24px;
  padding:18px;
  border-radius:18px;
  background:linear-gradient(135deg,#0b63ad,#0b4f8f);
  color:#fff;
  font-size:15px;
  line-height:1.45;
  font-weight:750;
}
#quote .vfd-status{
  color:#0b63ad;
  font-weight:800;
  margin-top:14px;
}
@media (max-width:980px){
  #quote .vfd-contact-layout{
    grid-template-columns:1fr;
  }
  #quote .vfd-contact-card{
    position:static;
  }
}
@media (max-width:680px){
  #quote .vfd-form-card,
  #quote .vfd-contact-card{
    padding:26px;
    border-radius:24px;
  }
  #quote .vfd-form-grid{
    grid-template-columns:1fr;
  }
  #quote .vfd-form-card h2{
    font-size:36px;
  }
}


/* v3.3 strict image-only lightbox: remove bottom title/footer completely */
.vfd-modal-content,
#vfdModalTitle,
#vfdModalCounter,
.vfd-modal-content h3,
.vfd-modal-content p{
  display:none!important;
  visibility:hidden!important;
  height:0!important;
  min-height:0!important;
  max-height:0!important;
  overflow:hidden!important;
  padding:0!important;
  margin:0!important;
  border:0!important;
}
.vfd-modal.is-open{
  display:flex!important;
}
.vfd-modal-box{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:0!important;
  padding:0!important;
  overflow:visible!important;
  width:auto!important;
  height:auto!important;
  max-width:94vw!important;
  max-height:90vh!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.vfd-modal-media{
  background:transparent!important;
  padding:0!important;
  margin:0!important;
  width:auto!important;
  height:auto!important;
  min-height:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.vfd-modal-media img{
  display:block!important;
  width:auto!important;
  height:auto!important;
  max-width:90vw!important;
  max-height:86vh!important;
  object-fit:contain!important;
  border-radius:18px!important;
  box-shadow:0 28px 90px rgba(0,0,0,.58)!important;
}

/* v3.4 authoritative image-only lightbox and cache-reset hardening */
.vfd-modal{
  position:fixed!important;
  inset:0!important;
  z-index:99999!important;
  display:none!important;
  align-items:center!important;
  justify-content:center!important;
  padding:34px!important;
  background:rgba(5,12,20,.88)!important;
  backdrop-filter:blur(8px)!important;
}
.vfd-modal.is-open,
.vfd-modal.open{
  display:flex!important;
}
html.vfd-modal-open,
html.vfd-modal-open body,
body.vfd-modal-active{
  overflow:hidden!important;
}
.vfd-modal-box{
  width:auto!important;
  max-width:94vw!important;
  max-height:90vh!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:0!important;
  overflow:visible!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.vfd-modal-media{
  background:transparent!important;
  padding:0!important;
  margin:0!important;
  width:auto!important;
  min-width:0!important;
  min-height:0!important;
  max-height:none!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.vfd-modal-media img{
  display:block!important;
  width:auto!important;
  height:auto!important;
  max-width:88vw!important;
  max-height:82vh!important;
  object-fit:contain!important;
  border-radius:18px!important;
  box-shadow:0 30px 90px rgba(0,0,0,.55)!important;
  background:transparent!important;
}
.vfd-modal-content,
#vfdModalTitle,
#vfdModalCounter,
.vfd-modal-title,
.vfd-modal-help,
.vfd-modal-counter{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
  height:0!important;
  min-height:0!important;
  max-height:0!important;
  width:0!important;
  min-width:0!important;
  max-width:0!important;
  overflow:hidden!important;
  padding:0!important;
  margin:0!important;
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
}
.vfd-modal-close,
.vfd-modal-nav{
  position:fixed!important;
  z-index:100002!important;
  border:1px solid rgba(255,255,255,.24)!important;
  background:rgba(255,255,255,.15)!important;
  color:#fff!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  cursor:pointer!important;
  transition:.2s ease!important;
}
.vfd-modal-close{
  top:24px!important;
  right:28px!important;
  width:58px!important;
  height:58px!important;
  border-radius:999px!important;
  font-size:42px!important;
  line-height:1!important;
}
.vfd-modal-nav{
  top:50%!important;
  transform:translateY(-50%)!important;
  width:58px!important;
  height:92px!important;
  border-radius:999px!important;
  font-size:54px!important;
  line-height:1!important;
}
.vfd-modal-prev{left:24px!important;}
.vfd-modal-next{right:24px!important;}
.vfd-modal-nav[hidden]{display:none!important;}
.vfd-modal-close:hover,
.vfd-modal-nav:hover{background:rgba(255,255,255,.27)!important;}
@media (max-width:700px){
  .vfd-modal{padding:18px!important;}
  .vfd-modal-media img{max-width:94vw!important;max-height:78vh!important;border-radius:14px!important;}
  .vfd-modal-close{right:14px!important;top:14px!important;width:48px!important;height:48px!important;font-size:34px!important;}
  .vfd-modal-nav{width:46px!important;height:72px!important;font-size:42px!important;}
  .vfd-modal-prev{left:10px!important;}
  .vfd-modal-next{right:10px!important;}
}



/* v3.5 colour sample lightbox labels only
   Keeps project gallery image-only, but shows the selected DeckRite colour name when browsing colour samples. */
.vfd-modal-colour-title{
  position:fixed!important;
  left:50%!important;
  bottom:28px!important;
  transform:translateX(-50%)!important;
  z-index:10010!important;
  display:none;
  max-width:min(86vw,520px);
  padding:10px 18px!important;
  border-radius:999px!important;
  background:rgba(12,23,34,.88)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.18)!important;
  box-shadow:0 18px 42px rgba(0,0,0,.32)!important;
  font-size:16px!important;
  line-height:1.15!important;
  font-weight:1000!important;
  letter-spacing:.01em!important;
  text-align:center!important;
  pointer-events:none!important;
  white-space:normal!important;
}
.vfd-modal-colour-title.is-visible{display:block!important;visibility:visible!important;opacity:1!important;}
@media (max-width:760px){
  .vfd-modal-colour-title{bottom:18px!important;font-size:14px!important;padding:9px 14px!important;}
}


/* v3.6 nav label fit */
.vfd-nav{gap:clamp(10px,1.15vw,18px)}
.vfd-nav a{font-size:clamp(12px,.92vw,14px);white-space:nowrap}
@media (max-width:1180px){.vfd-nav a{font-size:12px}.vfd-header-quote{padding-inline:10px}}
