/*
Theme Name: Euro Windows 1.3
Theme URI: https://euro-windows.com/
Author: MainIT Solutions LTD
Author URI: https://mainit.ca/
Description: A fast, AI- and SEO-optimized theme for European windows & doors. v1.3 ships the cobalt "Euro Windows" homepage design (hero, comparison tabs, tilt-&-turn demo, Global 70/86 cards, spec table, finish customizer, testimonials) plus Schema.org structured data, /llms.txt, and Contact Form 7 integration.
Version: 1.3.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: euro-windows
*/

:root{
  --blue:#0F70B7;        /* primary cobalt from logo */
  --blue-d:#00539F;      /* navy facet */
  --sky:#09A1E4;         /* light cyan from logo */
  --navy:#0A2C4E;        /* deep ink-navy */
  --ink:#0C1C2B;
  --muted:#5A6B7B;
  --line:#E2EAF1;
  --bg:#FFFFFF;
  --bg-soft:#F4F8FC;     /* cool off-white */
  --bg-tint:#E9F3FB;     /* pale blue */
  --bg-navy:#072138;
  --r:14px;
  --maxw:1240px;
  --shadow-sm:0 1px 2px rgba(10,44,78,.06), 0 2px 8px rgba(10,44,78,.05);
  --shadow:0 4px 18px rgba(10,44,78,.10), 0 18px 48px rgba(10,44,78,.10);
  --grad:linear-gradient(120deg,var(--blue-d),var(--blue) 52%,var(--sky));
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:118px;}
body{
  margin:0;font-family:"Hanken Grotesk",system-ui,sans-serif;color:var(--ink);
  background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
h1,h2,h3,h4{font-family:"Archivo",sans-serif;margin:0;line-height:1.06;letter-spacing:-.02em;color:var(--navy);}
p{margin:0;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.mono{font-family:"Space Mono",monospace;}
.eyebrow{font-family:"Space Mono",monospace;font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);font-weight:700;}
.section{padding:104px 0;}
.section-soft{background:var(--bg-soft);}
.btn{
  display:inline-flex;align-items:center;gap:9px;font-family:"Archivo",sans-serif;font-weight:700;
  font-size:15px;letter-spacing:.01em;padding:15px 26px;border-radius:999px;cursor:pointer;border:none;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;white-space:nowrap;
}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 8px 20px rgba(15,112,183,.28);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(15,112,183,.36);}
.btn-ghost{background:#fff;color:var(--navy);border:1.5px solid var(--line);}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px);}
.btn-light{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.35);}
.btn-light:hover{background:rgba(255,255,255,.2);}
.arrow{transition:transform .2s ease;}
.btn:hover .arrow{transform:translateX(3px);}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--bg-navy);color:#cfe1f0;font-size:13.5px;}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:42px;gap:20px;}
.topbar .tb-left{display:flex;gap:26px;align-items:center;}
.topbar .tb-left .ti{display:flex;align-items:center;gap:8px;}
.topbar .tb-left svg{opacity:.7;}
.topbar a:hover{color:#fff;}
.region{display:flex;gap:4px;align-items:center;background:rgba(255,255,255,.07);border-radius:999px;padding:3px;}
.region button{font-family:"Space Mono",monospace;font-size:11.5px;font-weight:700;letter-spacing:.05em;color:#9fb8cd;background:none;border:none;padding:4px 12px;border-radius:999px;cursor:pointer;transition:.18s;}
.region button.on{background:var(--sky);color:#04263f;}
.tb-mob{display:none;}

/* ---------- Header ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:box-shadow .25s,border-color .25s;}
header.scrolled{box-shadow:0 6px 24px rgba(10,44,78,.08);border-color:var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px;gap:24px;}
.logo img{height:46px;width:auto;}
.nav-links{display:flex;gap:30px;align-items:center;}
.nav-links a{font-weight:600;font-size:15.5px;color:var(--navy);position:relative;padding:6px 0;white-space:nowrap;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--blue);transition:width .22s ease;}
.nav-links a:hover{color:var(--blue);}
.nav-links a:hover::after{width:100%;}
.nav-cta{display:flex;align-items:center;gap:14px;}
.nav-phone{font-family:"Archivo";font-weight:800;color:var(--navy);font-size:16px;display:flex;align-items:center;gap:8px;}
.nav-phone svg{color:var(--blue);}
.burger{display:none;background:none;border:none;cursor:pointer;padding:8px;}
.burger span{display:block;width:24px;height:2.4px;background:var(--navy);border-radius:2px;margin:5px 0;transition:.25s;}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:
   radial-gradient(1100px 600px at 78% -8%, var(--bg-tint), transparent 60%),
   linear-gradient(180deg,#fff, #fff 60%, var(--bg-soft));}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding-top:84px;padding-bottom:96px;}
.hero h1{font-size:clamp(40px,5vw,68px);font-weight:800;letter-spacing:-.035em;}
.hero h1 .accent{background:linear-gradient(120deg,var(--blue),var(--sky));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.hero p.lead{font-size:19.5px;color:var(--muted);margin-top:24px;max-width:520px;}
.hero-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap;}
.hero-meta{display:flex;gap:30px;margin-top:38px;flex-wrap:wrap;}
.hero-meta .hm{display:flex;flex-direction:column;gap:2px;}
.hero-meta .hm b{font-family:"Archivo";font-size:27px;font-weight:800;color:var(--navy);letter-spacing:-.02em;}
.hero-meta .hm span{font-size:13px;color:var(--muted);font-weight:600;}
.hero-visual{position:relative;}
.hero-img{position:relative;border-radius:20px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/4.4;}
.ph{background:
   repeating-linear-gradient(135deg,#dde9f3,#dde9f3 11px,#e8f1f9 11px,#e8f1f9 22px);
   display:flex;align-items:flex-end;justify-content:flex-start;color:#5e7e9b;}
.ph .ph-tag{font-family:"Space Mono",monospace;font-size:12.5px;background:rgba(255,255,255,.86);padding:7px 12px;border-radius:8px;margin:14px;letter-spacing:.02em;}
.float-chip{position:absolute;background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:16px 18px;display:flex;align-items:center;gap:13px;}
.float-chip .fc-num{font-family:"Archivo";font-weight:900;font-size:30px;color:var(--blue);letter-spacing:-.03em;line-height:1;}
.float-chip .fc-lab{font-size:12px;color:var(--muted);font-weight:600;line-height:1.25;}
.float-chip.u{bottom:26px;left:-26px;}
.float-chip.ph2{top:26px;right:-22px;}
.float-chip .badge{width:42px;height:42px;border-radius:11px;background:var(--bg-tint);display:flex;align-items:center;justify-content:center;color:var(--blue);}

/* ---------- Trust strip ---------- */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;}
.trust .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:26px 32px;flex-wrap:wrap;}
.trust .ti{display:flex;align-items:center;gap:11px;font-weight:700;color:var(--navy);font-size:14.5px;font-family:"Archivo";}
.trust .ti svg{color:var(--blue);flex:none;}

/* ---------- Section heading ---------- */
.shead{max-width:760px;margin-bottom:54px;}
.shead.center{margin-left:auto;margin-right:auto;text-align:center;}
.shead h2{font-size:clamp(30px,3.6vw,46px);font-weight:800;margin-top:14px;}
.shead p{font-size:18px;color:var(--muted);margin-top:18px;}

/* ---------- Comparison tabs ---------- */
.cmp{display:grid;grid-template-columns:300px 1fr;gap:48px;align-items:start;}
.cmp-tabs{display:flex;flex-direction:column;gap:8px;}
.cmp-tab{text-align:left;background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:20px 22px;cursor:pointer;transition:.2s;font-family:inherit;}
.cmp-tab b{font-family:"Archivo";font-weight:700;font-size:18px;color:var(--navy);display:block;}
.cmp-tab span{font-size:13.5px;color:var(--muted);}
.cmp-tab.on{border-color:var(--blue);background:linear-gradient(120deg,#fff,var(--bg-tint));box-shadow:var(--shadow-sm);}
.cmp-tab.on b{color:var(--blue);}
.cmp-panel{display:none;}
.cmp-panel.on{display:grid;grid-template-columns:1fr 1fr;gap:22px;animation:fade .4s ease;}
@keyframes fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.cmp-card{border-radius:16px;padding:30px;border:1px solid var(--line);}
.cmp-card.eu{background:var(--grad);color:#fff;border:none;}
.cmp-card.na{background:#fff;}
.cmp-card h4{font-size:20px;margin-bottom:6px;}
.cmp-card.eu h4{color:#fff;}
.cmp-card .tag{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.85;font-weight:700;}
.cmp-card.na .tag{color:var(--blue);}
.cmp-card ul{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:12px;}
.cmp-card li{display:flex;gap:11px;font-size:15px;align-items:flex-start;}
.cmp-card.eu li{color:#eaf4fb;}
.cmp-card.na li{color:var(--muted);}
.cmp-card li svg{flex:none;margin-top:2px;}

/* ---------- Tilt & turn demo ---------- */
.demo{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.window-stage{aspect-ratio:1/1;background:linear-gradient(160deg,var(--bg-tint),#fff);border-radius:22px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);perspective:1400px;position:relative;overflow:hidden;}
.window-stage::after{content:"";position:absolute;inset:0;background:radial-gradient(420px 300px at 30% 20%,rgba(9,161,228,.10),transparent 70%);}
.win{width:62%;height:72%;position:relative;transform-style:preserve-3d;transition:transform .9s cubic-bezier(.6,.05,.2,1);}
.win-frame{position:absolute;inset:0;background:var(--frame,#fff);border:9px solid var(--frame,#fff);border-radius:5px;box-shadow:0 0 0 2px rgba(10,44,78,.16), var(--shadow);transform-style:preserve-3d;}
.win-sash{position:absolute;inset:9px;background:var(--frame,#fff);border:7px solid var(--frame,#fff);border-radius:3px;box-shadow:0 0 0 1.5px rgba(10,44,78,.14);transition:transform .9s cubic-bezier(.6,.05,.2,1);transform-origin:left center;transform-style:preserve-3d;}
.win-glass{position:absolute;inset:0;background:linear-gradient(135deg,rgba(173,214,240,.9),rgba(225,240,250,.95) 45%,rgba(155,200,232,.85));overflow:hidden;}
.win-glass::before{content:"";position:absolute;top:-40%;left:-20%;width:60%;height:180%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);transform:rotate(18deg);}
.win-handle{position:absolute;left:-3px;top:50%;width:9px;height:34px;background:#9aa7b2;border-radius:4px;transform:translateY(-50%);transition:transform .6s;z-index:3;box-shadow:0 1px 3px rgba(0,0,0,.3);}
/* states */
.win[data-state="tilt"] .win-sash{transform:rotateX(-22deg);transform-origin:bottom center;}
.win[data-state="tilt"] .win-handle{transform:translateY(-50%) rotate(90deg);}
.win[data-state="turn"]{transform:rotateY(-8deg);}
.win[data-state="turn"] .win-sash{transform:rotateY(-58deg);}
.win[data-state="turn"] .win-handle{transform:translateY(-50%) rotate(180deg);}
.demo-controls{display:flex;gap:10px;margin-top:8px;}
.seg{display:inline-flex;background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:5px;gap:4px;}
.seg button{font-family:"Archivo";font-weight:700;font-size:14px;border:none;background:none;padding:10px 20px;border-radius:999px;cursor:pointer;color:var(--muted);transition:.2s;}
.seg button.on{background:var(--grad);color:#fff;box-shadow:0 5px 14px rgba(15,112,183,.28);}
.demo-desc{margin-top:20px;min-height:80px;}
.demo-desc h4{font-size:22px;margin-bottom:8px;}
.demo-desc p{color:var(--muted);font-size:16px;}
.feat-row{display:flex;gap:14px;margin-top:26px;flex-wrap:wrap;}
.feat-pill{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 16px;font-size:13.5px;font-weight:600;color:var(--navy);}
.feat-pill svg{color:var(--blue);}

/* ---------- Product cards ---------- */
.products{display:grid;grid-template-columns:1fr 1fr;gap:28px;}
.pcard{border-radius:20px;overflow:hidden;border:1px solid var(--line);background:#fff;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s;}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.pcard .pc-top{padding:32px 32px 0;position:relative;}
.pcard.premium{background:linear-gradient(180deg,#072138,#0a3157);color:#fff;border:none;}
.pc-badge{position:absolute;top:26px;right:26px;font-family:"Space Mono",monospace;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:999px;background:var(--bg-tint);color:var(--blue);}
.pcard.premium .pc-badge{background:rgba(9,161,228,.22);color:#7fd3f7;}
.pcard h3{font-size:30px;font-weight:800;letter-spacing:-.03em;}
.pcard.premium h3{color:#fff;}
.pc-sub{font-size:14.5px;color:var(--muted);margin-top:6px;}
.pcard.premium .pc-sub{color:#9fc2dd;}
.pc-uval{display:flex;align-items:baseline;gap:8px;margin-top:22px;}
.pc-uval b{font-family:"Archivo";font-size:52px;font-weight:900;letter-spacing:-.04em;line-height:.9;color:var(--blue);}
.pcard.premium .pc-uval b{color:#39bdf3;}
.pc-uval span{font-size:13px;color:var(--muted);font-weight:600;}
.pcard.premium .pc-uval span{color:#9fc2dd;}
.pc-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);margin:28px 0 0;border-radius:12px;overflow:hidden;}
.pcard.premium .pc-stats{background:rgba(255,255,255,.1);}
.pc-stat{background:#fff;padding:16px 18px;}
.pcard.premium .pc-stat{background:#0a3157;}
.pc-stat b{font-family:"Archivo";font-weight:800;font-size:19px;display:block;color:var(--navy);}
.pcard.premium .pc-stat b{color:#fff;}
.pc-stat span{font-size:12px;color:var(--muted);font-weight:600;}
.pcard.premium .pc-stat span{color:#8fb4d1;}
.pc-foot{padding:26px 32px 32px;margin-top:auto;display:flex;gap:12px;align-items:center;}
.link-arrow{font-family:"Archivo";font-weight:700;color:var(--blue);display:inline-flex;align-items:center;gap:7px;font-size:15px;}
.pcard.premium .link-arrow{color:#7fd3f7;}

/* doors strip */
.doors{margin-top:28px;border-radius:20px;overflow:hidden;background:var(--grad);color:#fff;display:grid;grid-template-columns:1fr 1fr;}
.doors .d-txt{padding:46px;}
.doors h3{color:#fff;font-size:30px;font-weight:800;}
.doors p{color:#eaf4fb;margin-top:14px;font-size:16px;max-width:440px;}
.doors .d-feat{display:flex;gap:22px;margin-top:24px;flex-wrap:wrap;}
.doors .d-feat div{font-size:14px;}
.doors .d-feat b{font-family:"Archivo";display:block;font-size:18px;}
.doors .d-img{min-height:280px;}

/* ---------- Spec table ---------- */
.spec-wrap{border-radius:18px;overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-sm);}
.spec-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;}
table.spec{width:100%;border-collapse:collapse;font-size:15.5px;}
table.spec th,table.spec td{padding:18px 24px;text-align:left;border-bottom:1px solid var(--line);}
table.spec thead th{background:var(--bg-navy);color:#fff;font-family:"Archivo";font-weight:700;font-size:15px;}
table.spec thead th.hl{background:linear-gradient(120deg,var(--blue),var(--sky));}
table.spec tbody th{font-weight:600;color:var(--navy);}
table.spec td{font-family:"Space Mono",monospace;font-size:14.5px;color:var(--ink);}
table.spec td.dim{color:var(--muted);}
table.spec td.win{color:var(--blue);font-weight:700;}
table.spec tbody tr:hover{background:var(--bg-soft);}
table.spec tbody tr:last-child th,table.spec tbody tr:last-child td{border-bottom:none;}
.spec-note{font-size:12.5px;color:var(--muted);margin-top:14px;font-family:"Space Mono",monospace;}

/* ---------- Customize / swatches ---------- */
.custom{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.swatch-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-top:8px;}
.swatch{aspect-ratio:1;border-radius:9px;cursor:pointer;border:2px solid transparent;position:relative;transition:transform .15s;box-shadow:inset 0 0 0 1px rgba(10,44,78,.12);}
.swatch:hover{transform:scale(1.08);}
.swatch.on{border-color:var(--blue);box-shadow:0 0 0 2px #fff,0 0 0 4px var(--blue);}
.swatch-name{font-family:"Space Mono",monospace;font-size:13px;color:var(--muted);margin-top:14px;}
.swatch-name b{color:var(--navy);font-weight:700;}
.glass-opts{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap;}
.glass-opts button{font-family:"Archivo";font-weight:700;font-size:13.5px;border:1.5px solid var(--line);background:#fff;border-radius:10px;padding:11px 16px;cursor:pointer;color:var(--muted);transition:.2s;}
.glass-opts button.on{border-color:var(--blue);color:var(--blue);background:var(--bg-tint);}

/* ---------- Testimonials ---------- */
.tcarousel{position:relative;max-width:840px;margin:0 auto;}
.tslide{display:none;text-align:center;animation:fade .5s ease;}
.tslide.on{display:block;}
.tslide .quote{font-family:"Archivo";font-weight:500;font-size:clamp(20px,2.4vw,28px);line-height:1.4;color:var(--navy);letter-spacing:-.01em;}
.tslide .qmark{font-family:"Archivo";font-size:64px;color:var(--sky);line-height:.4;font-weight:900;}
.tperson{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:30px;}
.tperson .av{width:52px;height:52px;border-radius:50%;background:var(--bg-tint);overflow:hidden;}
.tperson b{font-family:"Archivo";color:var(--navy);font-size:16px;display:block;text-align:left;}
.tperson span{font-size:13px;color:var(--muted);}
.tnav{display:flex;justify-content:center;gap:10px;margin-top:36px;align-items:center;}
.tdot{width:9px;height:9px;border-radius:50%;background:var(--line);border:none;cursor:pointer;transition:.2s;padding:0;}
.tdot.on{background:var(--blue);width:26px;border-radius:999px;}
.tarrow{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--line);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--navy);transition:.2s;}
.tarrow:hover{border-color:var(--blue);color:var(--blue);}

/* ---------- Quote / CTA ---------- */
.quote{background:var(--bg-navy);color:#fff;position:relative;overflow:hidden;}
.quote::before{content:"";position:absolute;top:-120px;right:-120px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(9,161,228,.22),transparent 65%);}
.quote .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;position:relative;align-items:center;}
.quote h2{color:#fff;font-size:clamp(30px,3.6vw,44px);font-weight:800;}
.quote .q-lead{color:#a9c6dd;font-size:18px;margin-top:18px;max-width:430px;}
.q-contacts{margin-top:34px;display:flex;flex-direction:column;gap:18px;}
.q-contacts .qc{display:flex;align-items:center;gap:14px;}
.q-contacts .qc .ic{width:46px;height:46px;border-radius:12px;background:rgba(9,161,228,.16);display:flex;align-items:center;justify-content:center;color:#7fd3f7;flex:none;}
.q-contacts .qc b{font-family:"Archivo";font-size:17px;color:#fff;display:block;}
.q-contacts .qc span{font-size:13.5px;color:#9fc2dd;}
.qform{background:#fff;border-radius:20px;padding:34px;box-shadow:var(--shadow);}
.qform h3{color:var(--navy);font-size:22px;margin-bottom:6px;}
.qform .fsub{color:var(--muted);font-size:14px;margin-bottom:22px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:700;color:var(--navy);margin-bottom:6px;font-family:"Archivo";}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:15px;color:var(--ink);background:#fff;transition:.18s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(15,112,183,.14);}
.field.err input,.field.err select,.field.err textarea{border-color:#e05656;background:#fef6f6;}
.field .msg{font-size:12px;color:#e05656;margin-top:5px;display:none;font-weight:600;}
.field.err .msg{display:block;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.qform .btn{width:100%;justify-content:center;margin-top:8px;}
.form-success{display:none;text-align:center;padding:30px 10px;}
.form-success.on{display:block;animation:fade .4s ease;}
.form-success .chk{width:74px;height:74px;border-radius:50%;background:var(--bg-tint);color:var(--blue);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;}
.form-success h3{font-size:24px;}
.form-success p{color:var(--muted);margin-top:10px;}

/* ---------- Footer ---------- */
footer{background:#04182b;color:#a9c6dd;padding:64px 0 30px;}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;}
.flogo{height:48px;margin-bottom:18px;}
footer p.fdesc{font-size:14.5px;max-width:300px;color:#8fb1cb;}
footer h5{font-family:"Archivo";color:#fff;font-size:14px;letter-spacing:.04em;margin-bottom:18px;}
footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;}
footer ul a{font-size:14.5px;color:#a9c6dd;}
footer ul a:hover{color:#fff;}
.fbar{border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding-top:24px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:13px;color:#7193ad;}
.fbar a{color:#7193ad;}
.fbar a:hover{color:#fff;}

/* ---------- Reveal (enhancement only; content visible if motion reduced) ---------- */
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease;}
}

/* ---------- Mobile ---------- */
.mobnav{display:none;}
@media(max-width:980px){
  html{scroll-padding-top:96px;}
  .nav-links,.nav-phone,.topbar .tb-left{display:none;}
  .tb-mob{display:flex;gap:18px;}
  .burger{display:block;}
  .nav{height:66px;}
  .logo img{height:40px;}
  .hero .wrap,.cmp,.demo,.products,.custom,.quote .wrap,.doors,.fgrid,.cmp-panel.on{grid-template-columns:1fr;}
  .hero .wrap{gap:38px;padding-top:48px;padding-bottom:64px;}
  .hero-visual{order:-1;}
  .shead{margin-bottom:38px;}
  .doors .d-img{min-height:200px;}
  .fgrid{gap:34px;}
  .section{padding:72px 0;}
  .wrap{padding:0 22px;}
  .mobnav.open{display:block;position:fixed;inset:108px 0 0;background:#fff;z-index:55;padding:24px 22px;overflow-y:auto;}
  .mobnav.open a{display:block;font-family:"Archivo";font-weight:700;font-size:20px;padding:16px 0;border-bottom:1px solid var(--line);color:var(--navy);}
  .mobnav.open .btn{width:100%;justify-content:center;margin-top:20px;}
  .burger.x span:nth-child(1){transform:translateY(7.4px) rotate(45deg);}
  .burger.x span:nth-child(2){opacity:0;}
  .burger.x span:nth-child(3){transform:translateY(-7.4px) rotate(-45deg);}
  /* spec table scrolls horizontally instead of squashing */
  .spec-wrap{overflow:visible;}
  table.spec{min-width:680px;}
  table.spec th,table.spec td{padding:14px 16px;}
  .quote::before{display:none;}
}
@media(max-width:680px){
  .hero h1{font-size:clamp(33px,8.6vw,48px);}
  .hero p.lead{font-size:17.5px;}
  .hero-cta{gap:10px;}
  .hero-cta .btn{flex:1 1 auto;justify-content:center;}
  .hero-meta{gap:18px 26px;}
  .hero-meta .hm b{font-size:23px;}
  /* shrink floating chips so they don't overrun the image */
  .float-chip{padding:11px 13px;gap:9px;border-radius:12px;}
  .float-chip .fc-num{font-size:22px;}
  .float-chip .fc-lab{font-size:10.5px;}
  .float-chip .badge{width:34px;height:34px;}
  .float-chip.u{left:6px;bottom:14px;} .float-chip.ph2{right:6px;top:14px;}
  .trust .wrap{justify-content:flex-start;gap:14px 22px;padding:22px;}
  .trust .ti{font-size:13.5px;}
  .swatch-grid{grid-template-columns:repeat(7,1fr);}
  .frow{grid-template-columns:1fr;}
  .pc-uval b{font-size:44px;}
  .doors .d-txt{padding:34px 26px;}
  .qform{padding:26px 22px;}
  .tarrow{display:none;}
  .fbar{flex-direction:column;gap:12px;}
}
@media(max-width:430px){
  .wrap{padding:0 18px;}
  .topbar .wrap{gap:10px;}
  .tb-mob a{font-size:12.5px;}
  .region button{padding:4px 9px;font-size:10.5px;}
  .hero h1{font-size:clamp(29px,8.4vw,40px);}
  .hero-cta{flex-direction:column;align-items:stretch;}
  .hero-meta{gap:16px 22px;}
  .pc-stats{grid-template-columns:1fr;}
  .swatch-grid{grid-template-columns:repeat(5,1fr);}
  .pc-foot{flex-wrap:wrap;}
  .pc-foot .btn{margin-left:0!important;width:100%;justify-content:center;}
}

/* ===== Inner pages (products, FAQ, about, contact) — v1.3 palette ===== */
:root{
  --ew-ink:#0A2C4E;--ew-body:#0C1C2B;--ew-muted:#5A6B7B;--ew-line:#E2EAF1;
  --ew-bg:#fff;--ew-bg-alt:#F4F8FC;--ew-accent:#0F70B7;--ew-accent-dark:#00539F;--ew-accent-ink:#fff;
  --ew-radius:14px;--ew-radius-sm:8px;
  --ew-shadow:0 4px 18px rgba(10,44,78,.10),0 18px 48px rgba(10,44,78,.10);
  --ew-shadow-lg:0 18px 50px rgba(10,44,78,.16);
  --ew-maxw:1180px;--ew-gap:clamp(1.25rem,3vw,2.5rem);
  --ew-font:"Hanken Grotesk",system-ui,sans-serif;
}
.ew-wrap{max-width:var(--ew-maxw);margin:0 auto;padding:0 clamp(1rem,4vw,2rem)}
.ew-section{padding:clamp(3rem,7vw,6rem) 0}
.ew-section--alt{background:var(--ew-bg-alt)}
.ew-center{text-align:center}
.ew-eyebrow{display:inline-block;text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:700;color:var(--ew-accent);margin-bottom:.8rem}
.ew-lead{font-size:1.18rem;color:var(--ew-muted);max-width:62ch}
.ew-center .ew-lead{margin-left:auto;margin-right:auto}
.ew-grid{display:grid;gap:var(--ew-gap)}
.ew-grid--2{grid-template-columns:repeat(2,1fr)}
.ew-grid--3{grid-template-columns:repeat(3,1fr)}
.ew-grid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.ew-grid--3,.ew-grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.ew-grid--2,.ew-grid--3,.ew-grid--4{grid-template-columns:1fr}}

/* ============================================================
   Buttons
   ============================================================ */
.ew-btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--ew-accent);color:var(--ew-accent-ink);
  padding:.85rem 1.6rem;border-radius:999px;font-weight:600;border:2px solid var(--ew-accent);
  transition:.18s ease;cursor:pointer;font-size:1rem}
.ew-btn:hover{background:var(--ew-accent-dark);border-color:var(--ew-accent-dark);color:#fff;transform:translateY(-1px)}
.ew-btn--ghost{background:transparent;color:var(--ew-ink);border-color:var(--ew-line)}
.ew-btn--ghost:hover{background:var(--ew-ink);color:#fff;border-color:var(--ew-ink)}
.ew-btn--light{background:#fff;color:var(--ew-ink);border-color:#fff}

/* ============================================================
   Header
   ============================================================ */
.ew-topbar{background:var(--ew-ink);color:#cfd4da;font-size:.86rem}
.ew-topbar .ew-wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:.5rem;padding-bottom:.5rem}
.ew-topbar a{color:#cfd4da}.ew-topbar a:hover{color:#fff}
.ew-topbar__contact{display:flex;gap:1.4rem;flex-wrap:wrap}
@media(max-width:720px){.ew-topbar__social{display:none}}

.ew-header{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.92);backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--ew-line)}
.ew-header .ew-wrap{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-top:.7rem;padding-bottom:.7rem}
.ew-logo img{max-height:54px;width:auto}
.ew-logo a{font-weight:800;font-size:1.4rem;color:var(--ew-ink);letter-spacing:-.02em}
.ew-nav ul{display:flex;gap:1.4rem;list-style:none;margin:0;padding:0;align-items:center}
.ew-nav a{color:var(--ew-ink);font-weight:600;font-size:.98rem;padding:.4rem 0;position:relative}
.ew-nav a:hover{color:var(--ew-accent)}
.ew-nav .sub-menu{display:none;position:absolute;background:#fff;box-shadow:var(--ew-shadow);border:1px solid var(--ew-line);
  border-radius:var(--ew-radius-sm);padding:.5rem;min-width:230px;flex-direction:column;gap:0}
.ew-nav li{position:relative}
.ew-nav li:hover>.sub-menu{display:flex}
.ew-nav .sub-menu a{padding:.5rem .7rem;border-radius:6px;display:block}
.ew-nav .sub-menu a:hover{background:var(--ew-bg-alt)}
.ew-header__cta{display:flex;align-items:center;gap:1rem}
.ew-burger{display:none;background:none;border:0;cursor:pointer;padding:.4rem;width:44px;height:44px}
.ew-burger span{display:block;height:2px;background:var(--ew-ink);margin:5px 0;transition:.2s}
@media(max-width:980px){
  .ew-nav{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:#fff;transform:translateX(100%);
    transition:.25s ease;box-shadow:var(--ew-shadow-lg);padding:5rem 1.5rem 2rem;overflow-y:auto;z-index:300}
  .ew-nav.is-open{transform:translateX(0)}
  .ew-nav ul{flex-direction:column;align-items:stretch;gap:.2rem}
  .ew-nav .sub-menu{display:flex;position:static;box-shadow:none;border:0;padding-left:1rem}
  .ew-burger{display:block;z-index:301}
  .ew-header__cta .ew-btn{display:none}
}
.ew-nav__backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:250}
.ew-nav__backdrop.is-open{display:block}

/* ============================================================
   Hero
   ============================================================ */
.ew-hero{position:relative;background:var(--ew-ink);color:#fff;overflow:hidden}
.ew-hero__media{position:absolute;inset:0}
.ew-hero__media img{width:100%;height:100%;object-fit:cover;opacity:.55}
.ew-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,12,16,.85),rgba(8,12,16,.35))}
.ew-hero .ew-wrap{position:relative;z-index:2;padding-top:clamp(4rem,10vw,8rem);padding-bottom:clamp(4rem,10vw,8rem);max-width:760px;margin-left:auto;margin-right:auto;text-align:center}
.ew-hero h1{color:#fff}
.ew-hero p{color:#dfe3e8;font-size:1.2rem;margin-bottom:1.8rem}
.ew-hero__actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* ============================================================
   Cards
   ============================================================ */
.ew-card{background:#fff;border:1px solid var(--ew-line);border-radius:var(--ew-radius);overflow:hidden;
  transition:.2s ease;display:flex;flex-direction:column;height:100%}
.ew-card:hover{box-shadow:var(--ew-shadow);transform:translateY(-3px)}
.ew-card__media{aspect-ratio:4/3;background:linear-gradient(135deg,#e9eef1,#d6dee3);position:relative;overflow:hidden}
.ew-card__media img{width:100%;height:100%;object-fit:cover}
.ew-card__ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#8a99a3;font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:.82rem}
.ew-card__body{padding:1.3rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1}
.ew-card__body h3{margin-bottom:.4rem}
.ew-card__body p{color:var(--ew-muted);font-size:.97rem;margin-bottom:1rem}
.ew-card__link{margin-top:auto;font-weight:600}

/* feature/process tiles */
.ew-tile{text-align:center;padding:1.5rem}
.ew-tile__icon{width:64px;height:64px;border-radius:50%;background:var(--ew-bg-alt);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:var(--ew-accent)}
.ew-tile__icon svg{width:30px;height:30px}
.ew-step__num{font-weight:800;color:var(--ew-accent);font-size:1.1rem}

/* split media+text */
.ew-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.ew-split--rev .ew-split__media{order:2}
.ew-split__media{border-radius:var(--ew-radius);overflow:hidden;box-shadow:var(--ew-shadow);aspect-ratio:4/3;background:linear-gradient(135deg,#e9eef1,#d6dee3)}
.ew-split__media img{width:100%;height:100%;object-fit:cover}
@media(max-width:820px){.ew-split{grid-template-columns:1fr}.ew-split--rev .ew-split__media{order:0}}

/* stats */
.ew-stats{display:flex;gap:2.5rem;flex-wrap:wrap;justify-content:center;text-align:center}
.ew-stat__num{font-size:2.6rem;font-weight:800;color:var(--ew-ink);line-height:1}
.ew-stat__label{color:var(--ew-muted);font-size:.95rem;margin-top:.3rem}

/* reviews */
.ew-review{background:#fff;border:1px solid var(--ew-line);border-radius:var(--ew-radius);padding:1.6rem;height:100%}
.ew-review__stars{color:#e0a52b;margin-bottom:.6rem;letter-spacing:2px}
.ew-review__name{font-weight:700;color:var(--ew-ink);margin-top:1rem}

/* ============================================================
   FAQ accordion
   ============================================================ */
.ew-faq{max-width:820px;margin:0 auto}
.ew-faq__item{border:1px solid var(--ew-line);border-radius:var(--ew-radius-sm);margin-bottom:.8rem;background:#fff;overflow:hidden}
.ew-faq__q{width:100%;text-align:left;background:none;border:0;padding:1.1rem 1.3rem;font-size:1.06rem;font-weight:600;
  color:var(--ew-ink);cursor:pointer;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.ew-faq__q::after{content:"+";font-size:1.5rem;color:var(--ew-accent);transition:.2s;line-height:1}
.ew-faq__item.is-open .ew-faq__q::after{transform:rotate(45deg)}
.ew-faq__a{padding:0 1.3rem;max-height:0;overflow:hidden;transition:max-height .25s ease}
.ew-faq__a-inner{padding-bottom:1.2rem;color:var(--ew-body)}
.ew-faq__item.is-open .ew-faq__a{max-height:600px}

/* ============================================================
   Single product
   ============================================================ */
.ew-product__hero{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:center}
@media(max-width:820px){.ew-product__hero{grid-template-columns:1fr}}
.ew-product__img{border-radius:var(--ew-radius);overflow:hidden;aspect-ratio:4/3;background:linear-gradient(135deg,#e9eef1,#d6dee3);box-shadow:var(--ew-shadow)}
.ew-specs{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.97rem}
.ew-specs th,.ew-specs td{text-align:left;padding:.7rem .9rem;border-bottom:1px solid var(--ew-line)}
.ew-specs th{color:var(--ew-muted);font-weight:600;width:45%}
.ew-checklist{list-style:none;padding:0}
.ew-checklist li{padding-left:1.8rem;position:relative;margin-bottom:.6rem}
.ew-checklist li::before{content:"✓";position:absolute;left:0;color:var(--ew-accent);font-weight:800}
.ew-breadcrumbs{font-size:.86rem;color:var(--ew-muted);padding:1rem 0}
.ew-breadcrumbs a{color:var(--ew-muted)}.ew-breadcrumbs a:hover{color:var(--ew-accent)}

/* ============================================================
   Content (pages/posts)
   ============================================================ */
.ew-article{max-width:760px;margin:0 auto}
.ew-article img{border-radius:var(--ew-radius);margin:1.5rem 0}
.ew-page-head{padding:clamp(2.5rem,6vw,4.5rem) 0 1rem;background:var(--ew-bg-alt);border-bottom:1px solid var(--ew-line)}
.ew-meta{color:var(--ew-muted);font-size:.9rem;margin-bottom:1.5rem}

/* ============================================================
   CTA band
   ============================================================ */
.ew-cta{background:var(--ew-accent);color:#fff;text-align:center}
.ew-cta h2{color:#fff}
.ew-cta p{color:rgba(255,255,255,.9);max-width:54ch;margin-left:auto;margin-right:auto}

/* ============================================================
   Footer
   ============================================================ */
.ew-footer{background:var(--ew-ink);color:#aeb6bf;padding-top:clamp(3rem,6vw,4.5rem);font-size:.95rem}
.ew-footer h4{color:#fff;font-size:1rem;margin-bottom:1rem}
.ew-footer a{color:#aeb6bf}.ew-footer a:hover{color:#fff}
.ew-footer ul{list-style:none;padding:0;margin:0}
.ew-footer li{margin-bottom:.5rem}
.ew-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem}
@media(max-width:820px){.ew-footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.ew-footer__grid{grid-template-columns:1fr}}
.ew-footer__logo{max-height:48px;margin-bottom:1rem}
.ew-footer__bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.5rem;padding:1.3rem 0;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.86rem}
.ew-social{display:flex;gap:.7rem;margin-top:1rem}
.ew-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center}
.ew-social a:hover{background:var(--ew-accent)}
.ew-social svg{width:18px;height:18px;fill:#fff}

/* ============================================================
   Quote form
   ============================================================ */
.ew-form{background:#fff;border-radius:var(--ew-radius);padding:clamp(1.5rem,4vw,2.5rem);box-shadow:var(--ew-shadow)}
.ew-form label{display:block;font-weight:600;color:var(--ew-ink);margin-bottom:.3rem;font-size:.92rem}
.ew-form input,.ew-form select,.ew-form textarea{width:100%;padding:.75rem .9rem;border:1px solid var(--ew-line);
  border-radius:var(--ew-radius-sm);font:inherit;margin-bottom:1rem;background:#fff}
.ew-form input:focus,.ew-form textarea:focus,.ew-form select:focus{outline:2px solid var(--ew-accent);border-color:var(--ew-accent)}

/* utilities */
.ew-mt0{margin-top:0}.ew-mb0{margin-bottom:0}
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}


/* ===== Contact Form 7 (quote form) ===== */
.qform .wpcf7-form-control-wrap{display:block;}
.qform .wpcf7 p,.qform form.wpcf7-form p{margin:0;}
.field .wpcf7-form-control-wrap{margin:0;}
.wpcf7-form .field input,.wpcf7-form .field select,.wpcf7-form .field textarea{width:100%;}
.qform input.btn,.qform .wpcf7-submit{width:100%;justify-content:center;margin-top:8px;}
.ew-form input.btn,.ew-form .wpcf7-submit{width:auto;}
.wpcf7-not-valid-tip{color:#e05656;font-size:12px;margin-top:5px;font-weight:600;}
.wpcf7-response-output{border-radius:11px!important;margin:14px 0 0!important;padding:.7rem 1rem!important;font-size:14px;}
.wpcf7-spinner{margin:.4rem;}
