/* ============================================================
   CIMFLEX — design bespoke "blueprint" (técnico / engenharia)
   Tubos, dutos e eletrodutos corrugados · PEAD & PVC · desde 2004
   ============================================================ */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
:root{
  --navy:#06182e; --navy-2:#0a2440; --navy-3:#0e2c50;
  --blue:#0e63c4; --blue-2:#3f8be0; --green:#57b947; --light:#cfe0f5;
  --paper:#eef4fb; --ink:#06182e;
  --line:rgba(207,224,245,.14); --line-2:rgba(207,224,245,.28);
  --muted:#8aa4c6;
  --ff-d:'Chakra Petch',system-ui,sans-serif;
  --ff-m:'Space Mono',ui-monospace,monospace;
  --ff-b:'Inter',system-ui,sans-serif;
  --ff-s:'Chakra Petch',system-ui,sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}
html{ -webkit-font-smoothing:antialiased; }
body{ font-family:var(--ff-b); background:var(--navy); color:#dbe6f5; line-height:1.58; overflow-x:hidden; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
.wrap{ max-width:1300px; margin:0 auto; padding:0 32px; }
.ff-s{ font-family:var(--ff-s); font-style:italic; font-weight:500; color:var(--green); }

/* split words (engine) */
.w{ display:inline-block; overflow:hidden; vertical-align:top; }
.wi{ display:inline-block; will-change:transform; }

/* blueprint grid backgrounds */
.grid-bg{ position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:56px 56px; mask-image:radial-gradient(120% 90% at 70% 20%,#000 40%,transparent 100%); }
.grid-bg.dense{ background-size:34px 34px; opacity:.5; mask-image:none; }
.grid-bg.light{ background-image:
    linear-gradient(rgba(14,99,196,.10) 1px,transparent 1px),
    linear-gradient(90deg,rgba(14,99,196,.10) 1px,transparent 1px);
  background-size:52px 52px; mask-image:none; }

/* ---------- Preloader ---------- */
.preload{ position:fixed; inset:0; z-index:3000; background:var(--navy); display:flex; align-items:flex-end; justify-content:space-between; padding:44px 40px; }
.preload::before{ content:"// CIMFLEX · SISTEMA"; position:absolute; top:44px; left:40px; font-family:var(--ff-m); font-size:.72rem; letter-spacing:.2em; color:var(--blue-2); }
.preload .pl-logo{ height:44px; }
.preload .pl-num{ font-family:var(--ff-d); font-weight:700; font-size:clamp(4rem,14vw,10rem); line-height:.8; color:#0e2c50; }

/* ---------- Header ---------- */
.hdr{ position:fixed; top:0; left:0; right:0; z-index:1000; padding:22px 0; transition:padding .4s var(--ease),background .4s,border-color .4s; border-bottom:1px solid transparent; }
.hdr.scrolled{ padding:11px 0; background:rgba(6,24,46,.82); backdrop-filter:blur(16px); border-bottom:1px solid var(--line); }
.hdr-in{ display:flex; align-items:center; justify-content:space-between; gap:20px; }
.hdr .logo{ height:36px; }
.nav{ display:flex; gap:34px; }
.nav a{ font-family:var(--ff-m); font-size:.82rem; letter-spacing:.02em; color:var(--light); position:relative; padding:5px 0; transition:color .3s; }
.nav a::after{ content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--green); transition:width .35s var(--ease); }
.nav a:hover{ color:#fff; } .nav a:hover::after{ width:100%; }
.hdr-cta a{ font-family:var(--ff-m); font-size:.78rem; letter-spacing:.04em; border:1px solid var(--line-2); padding:11px 20px; transition:.3s; color:#fff; clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px); }
.hdr-cta a:hover{ background:var(--blue); border-color:var(--blue); }
.burger{ display:none; width:44px;height:44px;background:0;border:0;flex-direction:column;gap:6px;cursor:pointer;align-items:center;justify-content:center; }
.burger span{ width:26px;height:2px;background:#fff; }

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:100vh; display:flex; flex-direction:column; justify-content:center; padding:150px 0 90px;
  background:radial-gradient(120% 100% at 80% 0%,var(--navy-2) 0%,var(--navy) 60%); overflow:hidden; }
@supports not (justify-content:safe center){ .hero{ justify-content:flex-start; } }
@supports (justify-content:safe center){ .hero{ justify-content:safe center; } }
.hero-grid{ position:relative; z-index:2; display:grid; grid-template-columns:1.12fr .88fr; gap:56px; align-items:center; width:100%; }
.hero-eyebrow{ font-family:var(--ff-m); letter-spacing:.14em; text-transform:uppercase; font-size:.74rem; color:var(--green); display:flex; align-items:center; gap:12px; margin-bottom:26px; }
.hero-eyebrow::before{ content:""; width:42px; height:1px; background:var(--green); }
.hero h1{ font-family:var(--ff-d); font-weight:700; font-size:clamp(2.6rem,6vw,5.7rem); line-height:1; letter-spacing:-.02em; text-transform:none; }
.hero p{ margin:30px 0 36px; font-size:1.15rem; color:var(--light); max-width:46ch; }
.hero-actions{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; }
.btn{ font-family:var(--ff-m); font-size:.86rem; letter-spacing:.02em; display:inline-flex; align-items:center; gap:10px; padding:16px 28px;
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  transition:transform .3s var(--ease),background .3s,color .3s; }
.btn svg{ width:18px; height:18px; }
.btn-fill{ background:var(--blue); color:#fff; }
.btn-fill:hover{ transform:translateY(-3px); box-shadow:0 16px 40px -14px var(--blue); }
.btn-line{ border:1px solid var(--line-2); color:#fff; }
.btn-line:hover{ background:#fff; color:var(--navy); }
.hero-fig{ position:relative; overflow:hidden; aspect-ratio:3/3.5; border:1px solid var(--line-2);
  clip-path:polygon(24px 0,100% 0,100% calc(100% - 24px),calc(100% - 24px) 100%,0 100%,0 24px); }
.hero-fig img{ width:100%; height:100%; object-fit:cover; }
.hero-fig .cap{ position:absolute; left:16px; bottom:16px; right:16px; font-family:var(--ff-m); font-size:.72rem; letter-spacing:.05em; color:#fff; background:rgba(6,24,46,.6); backdrop-filter:blur(6px); padding:10px 14px; border:1px solid var(--line); }
.hero-fig .cross{ position:absolute; color:var(--green); font-size:1rem; z-index:3; opacity:.85; }
.hero-fig .cross.tl{ top:10px; left:10px; } .hero-fig .cross.tr{ top:10px; right:10px; }
.hero-fig .cross.bl{ bottom:10px; left:10px; } .hero-fig .cross.br{ bottom:10px; right:10px; }
.hero-stats{ display:flex; gap:40px; margin-top:50px; border-top:1px solid var(--line); padding-top:26px; }
.hero-stats .hs{ display:flex; flex-direction:column; gap:4px; }
.hero-stats .hs b{ font-family:var(--ff-d); font-weight:600; font-size:1.35rem; color:#fff; display:block; }
.hero-stats .hs span{ font-family:var(--ff-m); color:var(--muted); font-size:.74rem; display:block; }
.hero-scroll{ position:absolute; bottom:28px; left:50%; transform:translateX(-50%); z-index:2; font-family:var(--ff-m); font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; display:flex; flex-direction:column; align-items:center; gap:9px; opacity:.6; }
.hero-scroll .line{ width:1px; height:44px; background:var(--line-2); overflow:hidden; position:relative; }
.hero-scroll .line::after{ content:""; position:absolute; top:-44px; left:0; width:100%; height:44px; background:var(--green); animation:scrolldot 2s var(--ease) infinite; }
@keyframes scrolldot{ to{ transform:translateY(88px); } }

/* ---------- Marquee ---------- */
.marquee{ padding:20px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); overflow:hidden; background:var(--navy-2); }
.marquee-track{ display:flex; gap:44px; width:max-content; align-items:center; }
.marquee-track span{ font-family:var(--ff-d); font-weight:600; text-transform:uppercase; letter-spacing:.02em; font-size:1.35rem; color:#26456c; white-space:nowrap; }
.marquee-track span.on{ color:var(--green); font-family:var(--ff-m); }

/* ---------- Section heads ---------- */
.sec-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:34px; margin-bottom:64px; flex-wrap:wrap; }
.sec-tag{ font-family:var(--ff-m); letter-spacing:.12em; font-size:.76rem; color:var(--green); }
.sec-h2{ font-family:var(--ff-d); font-weight:700; font-size:clamp(2rem,4.4vw,3.4rem); line-height:1.04; letter-spacing:-.01em; margin-top:14px; color:#fff; }
.sec-lead{ font-family:var(--ff-b); color:var(--light); max-width:42ch; font-size:1.04rem; }

/* ---------- Sobre ---------- */
.about{ padding:130px 0; position:relative; }
.about-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.about-card{ position:relative; padding:34px 30px 40px; border:1px solid var(--line); background:linear-gradient(180deg,var(--navy-2),var(--navy)); min-height:300px; display:flex; flex-direction:column;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%); transition:border-color .35s; }
.about-card:hover{ border-color:var(--blue); }
.about-card .ac-lbl{ font-family:var(--ff-m); font-size:.72rem; letter-spacing:.08em; color:var(--blue-2); }
.about-card h3{ font-family:var(--ff-d); font-weight:600; font-size:1.6rem; color:#fff; margin:auto 0 12px; padding-top:36px; }
.about-card p{ color:var(--muted); font-size:.94rem; }

/* ---------- Marcas ---------- */
.brands{ padding:0 0 130px; }
.brands-head{ display:flex; align-items:center; gap:20px; margin-bottom:30px; flex-wrap:wrap; }
.brands-head h3{ font-family:var(--ff-d); font-weight:500; font-size:1.05rem; color:var(--muted); }
.brands-strip{ display:flex; gap:26px; align-items:stretch; flex-wrap:wrap; }
.brand-logo{ flex:1; min-width:180px; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; padding:34px 26px; background:var(--navy-2); transition:border-color .35s; }
.brand-logo:hover{ border-color:var(--green); }
.brand-logo img{ height:40px; max-height:40px; width:auto; max-width:100%; object-fit:contain; filter:grayscale(1) brightness(1.7); opacity:.62; transition:.35s; }
.brand-logo:hover img{ filter:none; opacity:1; }

/* ---------- Statement ---------- */
.statement-sec{ padding:140px 0; border-top:1px solid var(--line); }
.statement{ font-family:var(--ff-d); font-weight:600; font-size:clamp(1.8rem,4.6vw,3.7rem); line-height:1.16; letter-spacing:-.01em; max-width:20ch; color:#fff; text-transform:none; }

/* ---------- Bands ---------- */
.bands{ padding:70px 0; overflow:hidden; }
.band-wrap{ transform:rotate(-3deg) scale(1.06); display:flex; flex-direction:column; gap:6px; }
.band{ display:flex; width:max-content; white-space:nowrap; will-change:transform; }
.band span{ font-family:var(--ff-d); font-weight:700; font-size:clamp(1.4rem,3vw,2.5rem); text-transform:uppercase; padding:10px 0; }
.band.b1 span,.band.b3 span{ color:transparent; -webkit-text-stroke:1px rgba(207,224,245,.3); }
.band.b3 span{ -webkit-text-stroke-color:rgba(14,99,196,.55); }
.band.b2{ background:var(--green); }
.band.b2 span{ color:var(--navy); padding:14px 0; }

/* ---------- Scroll horizontal (produtos) ---------- */
.h-scroll{ position:relative; height:100vh; overflow:hidden; background:var(--paper); color:var(--navy); }
.h-track{ position:relative; z-index:2; display:flex; height:100vh; align-items:center; gap:30px; padding:0 60px; width:max-content; will-change:transform; }
.h-intro{ flex:0 0 44vw; max-width:520px; }
.h-intro .sec-tag{ color:var(--blue); }
.h-intro h2{ font-family:var(--ff-d); font-weight:700; font-size:clamp(2rem,3.4vw,3rem); line-height:1.04; margin:16px 0 18px; color:var(--navy); text-transform:none; }
.h-intro h2 .ff-s{ color:var(--blue); }
.h-intro p{ color:#41597a; font-size:1.05rem; }
.h-intro .hint{ margin-top:26px; font-family:var(--ff-m); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); display:flex; align-items:center; gap:10px; }
.h-panel{ flex:0 0 30vw; min-width:340px; height:76vh; overflow:hidden; position:relative; background:var(--navy); color:#fff; border:1px solid rgba(6,24,46,.16);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 26px),calc(100% - 26px) 100%,0 100%); }
.hp-img{ position:absolute; inset:0; overflow:hidden; }
.hp-img img{ width:100%; height:100%; object-fit:cover; opacity:.78; }
.h-panel::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top,rgba(6,24,46,.95),rgba(6,24,46,.15) 62%); }
.h-panel::before{ content:"+"; position:absolute; top:16px; right:18px; z-index:3; color:var(--green); font-family:var(--ff-m); font-size:1.1rem; }
.hp-body{ position:absolute; z-index:2; left:26px; right:26px; bottom:26px; }
.hp-body .idx{ font-family:var(--ff-m); color:var(--green); font-size:.76rem; letter-spacing:.06em; }
.hp-body h3{ font-family:var(--ff-d); font-weight:600; font-size:1.55rem; margin:8px 0 8px; }
.hp-body p{ color:#c2d3ea; font-size:.9rem; }
.hp-body .spec{ display:inline-block; margin-top:14px; font-family:var(--ff-m); font-size:.72rem; letter-spacing:.03em; color:#fff; border:1px solid var(--line-2); padding:6px 12px; }

/* ---------- Qualidade ---------- */
.quality{ padding:130px 0; position:relative; }
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; border-top:1px solid var(--line); padding-top:16px; }
.step{ position:relative; padding:28px 0 0; }
.step .big{ font-family:var(--ff-d); font-style:normal; font-weight:700; font-size:2.6rem; color:var(--navy-3); line-height:1; display:block; }
.step .st-lbl{ display:block; margin:14px 0 8px; font-family:var(--ff-m); font-size:.72rem; letter-spacing:.06em; color:var(--green); }
.step h3{ font-family:var(--ff-d); font-weight:600; font-size:1.25rem; color:#fff; margin-bottom:8px; }
.step p{ color:var(--muted); font-size:.92rem; }

/* ---------- Números ---------- */
.numbers{ padding:130px 0; background:var(--navy-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.num-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; border-top:1px solid var(--line); }
.num{ padding:44px 20px 0 0; border-right:1px solid var(--line); }
.num:last-child{ border-right:0; }
.num b{ font-family:var(--ff-d); font-weight:700; font-size:clamp(2.6rem,5vw,4.4rem); letter-spacing:-.03em; line-height:1; display:block; color:#fff; }
.num b .u{ color:var(--green); }
.num span{ font-family:var(--ff-m); color:var(--muted); font-size:.82rem; display:block; margin-top:12px; }

/* ---------- Depoimentos ---------- */
.quotes{ padding:130px 0; }
.q-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.q{ position:relative; border:1px solid var(--line); padding:34px 30px; background:var(--navy-2);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 16px),calc(100% - 16px) 100%,0 100%); }
.q .q-mark{ font-family:var(--ff-d); font-weight:700; font-size:3rem; color:var(--blue); line-height:.6; display:block; margin-bottom:10px; }
.q p{ font-size:1.05rem; color:#dbe6f5; line-height:1.5; }
.q .who{ margin-top:22px; font-family:var(--ff-m); font-size:.76rem; letter-spacing:.04em; color:var(--green); }

/* ---------- FAQ ---------- */
.faq{ padding:0 0 130px; }
.faq-grid{ max-width:940px; border-top:1px solid var(--line); margin-top:10px; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; text-align:left; background:0; border:0; color:#fff; font-family:var(--ff-d); font-weight:600; font-size:clamp(1.05rem,2vw,1.3rem); padding:28px 0; display:flex; justify-content:space-between; align-items:center; gap:20px; cursor:pointer; }
.faq-q .pm{ flex:0 0 auto; width:36px; height:36px; border:1px solid var(--line-2); display:flex; align-items:center; justify-content:center; font-family:var(--ff-d); font-size:1.3rem; transition:.35s var(--ease); }
.faq-item.open .faq-q .pm{ background:var(--green); color:var(--navy); border-color:var(--green); transform:rotate(45deg); }
.faq-a{ overflow:hidden; height:0; }
.faq-a-in{ padding:0 0 28px; color:var(--muted); max-width:74ch; font-size:1rem; }

/* ---------- CTA ---------- */
.cta-sec{ padding:0 0 60px; }
.cta{ position:relative; overflow:hidden; background:linear-gradient(120deg,var(--blue) 0%,#0a4a97 100%); padding:80px; text-align:center;
  clip-path:polygon(30px 0,100% 0,100% calc(100% - 30px),calc(100% - 30px) 100%,0 100%,0 30px); }
.cta .grid-bg.dense{ opacity:.28; }
.cta .cta-lbl{ position:relative; z-index:2; font-family:var(--ff-m); font-size:.78rem; letter-spacing:.1em; color:#bfe3ff; }
.cta h2{ position:relative; z-index:2; font-family:var(--ff-d); font-weight:700; font-size:clamp(2rem,4.4vw,3.4rem); letter-spacing:-.01em; color:#fff; margin:16px auto 0; max-width:20ch; text-transform:none; }
.cta h2 .ff-s{ color:#c9ffb8; }
.cta p{ position:relative; z-index:2; color:rgba(255,255,255,.88); margin:16px auto 34px; max-width:52ch; }
.cta .btn{ position:relative; z-index:2; background:var(--green); color:var(--navy); }
.cta .btn:hover{ transform:translateY(-3px); box-shadow:0 16px 40px -14px rgba(0,0,0,.5); }

/* ---------- Contato ---------- */
.contact{ padding:60px 0 100px; }
.contact-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:60px; }
.contact-h2{ font-size:2.1rem; margin:12px 0 26px; }
.field{ margin-bottom:16px; }
.field label{ font-family:var(--ff-m); font-size:.78rem; letter-spacing:.02em; display:block; margin-bottom:8px; color:var(--light); }
.field input,.field textarea{ width:100%; padding:15px 16px; background:var(--navy-2); border:1px solid var(--line-2); color:#fff; font:inherit; }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--green); }
.field ::placeholder{ color:#5f7a9d; }
.cinfo li{ list-style:none; display:flex; gap:14px; padding:20px 0; border-bottom:1px solid var(--line); }
.cinfo .ic{ width:44px; height:44px; min-width:44px; background:rgba(14,99,196,.16); color:var(--blue-2); display:flex; align-items:center; justify-content:center; flex:0 0 44px; }
.cinfo .ic svg{ width:20px; height:20px; min-width:20px; flex:0 0 auto; }
.cinfo li>div{ min-width:0; }
.cinfo b{ font-family:var(--ff-d); font-weight:600; display:block; color:#fff; }
.cinfo span{ font-family:var(--ff-m); color:var(--muted); font-size:.84rem; }
.edit-fig{ position:relative; overflow:hidden; margin-top:22px; aspect-ratio:16/10; border:1px solid var(--line);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%); }
.edit-fig img{ width:100%; height:100%; object-fit:cover; }
.edit-fig .cap{ position:absolute; left:14px; bottom:14px; font-family:var(--ff-m); font-size:.7rem; letter-spacing:.04em; color:#fff; background:rgba(6,24,46,.6); backdrop-filter:blur(6px); padding:8px 12px; border:1px solid var(--line); }

/* ---------- Footer ---------- */
.foot{ border-top:1px solid var(--line); padding:70px 0 34px; background:var(--navy-2); }
.foot-top{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:40px; padding-bottom:44px; }
.foot .flogo{ height:40px; margin-bottom:18px; }
.foot p{ color:var(--muted); max-width:36ch; }
.foot h5{ font-family:var(--ff-m); font-size:.76rem; letter-spacing:.1em; text-transform:uppercase; color:var(--blue-2); margin-bottom:16px; }
.foot ul{ list-style:none; } .foot ul li{ margin-bottom:10px; }
.foot ul a{ font-family:var(--ff-b); color:var(--light); font-size:.95rem; } .foot ul a:hover{ color:var(--green); }
.foot-bot{ display:flex; justify-content:space-between; padding-top:24px; border-top:1px solid var(--line); color:var(--muted); font-family:var(--ff-m); font-size:.78rem; flex-wrap:wrap; gap:10px; }
.foot-bot a{ color:var(--green); }

/* ---------- WhatsApp ---------- */
.wa{ position:fixed; right:22px; bottom:22px; width:56px; height:56px; border-radius:50%; background:#25D366; display:flex; align-items:center; justify-content:center; z-index:900; box-shadow:0 10px 26px rgba(37,211,102,.45); transition:transform .3s; }
.wa:hover{ transform:scale(1.08); } .wa svg{ width:29px; height:29px; fill:#fff; }

/* ---------- Menu mobile ---------- */
.mnav{ position:fixed; inset:0; z-index:1200; background:var(--navy); transform:translateY(-100%); transition:transform .5s var(--ease); display:flex; flex-direction:column; padding:30px 32px; }
.mnav.open{ transform:translateY(0); }
.mnav .x{ align-self:flex-end; background:0; border:0; color:#fff; font-size:2rem; cursor:pointer; }
.mnav a{ font-family:var(--ff-d); font-weight:600; font-size:1.9rem; padding:14px 0; border-bottom:1px solid var(--line); }
.mnav a:hover{ color:var(--green); }

/* ---------- Responsivo ---------- */
@media(max-width:860px){
  .hdr .nav, .hdr-cta{ display:none; } .burger{ display:flex; }
  .hero{ padding:130px 0 80px; } .hero-grid{ grid-template-columns:1fr; gap:40px; } .hero-fig{ aspect-ratio:16/12; } .hero-scroll{ display:none; }
  .hero-stats{ gap:26px; flex-wrap:wrap; }
  .about,.brands,.statement-sec,.quality,.numbers,.quotes{ padding:80px 0; } .brands{ padding-bottom:80px; }
  .about-grid{ grid-template-columns:1fr; } .about-card{ transform:none !important; min-height:auto; }
  .steps{ grid-template-columns:1fr 1fr; } .num-grid{ grid-template-columns:1fr 1fr; } .num{ border-right:0; padding:34px 0 0; }
  .q-grid{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; gap:34px; } .cta{ padding:44px 26px; } .foot-top{ grid-template-columns:1fr; gap:26px; }

  /* horizontal → vertical stack (obrigatório) */
  .h-scroll{ height:auto; }
  .h-track{ flex-direction:column; height:auto; width:auto; transform:none !important; padding:80px 24px; gap:20px; }
  .h-intro,.h-panel{ flex:none; width:100%; height:auto; min-height:440px; }
}
@media(max-width:520px){
  .steps{ grid-template-columns:1fr; } .num-grid{ grid-template-columns:1fr; }
  .hero-stats{ gap:20px; }
}
