/* ============================================================
   Metforce Blocks — "Engineered / Precision-Tech" design system
   for the custom Elementor widgets. Fully scoped under .mfb so it
   NEVER collides with the legacy .mf configurator/product styles.
   Hierarchy: 1) balustrades  2) interactive 3D  3) 3D scanning.
   Hand-authored — bundled into the plugin by build-wp-plugin.mjs.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@600;700;800;900&family=Inter:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap');

.mfb{
  --ink:#0B0D0F; --graphite:#121519; --carbon:#1a1e23; --steel-900:#23282e;
  --steel:#6b7280; --fog:#9aa3ad; --mist:#c9cfd6;
  --paper:#ffffff; --paper-dim:#f5f6f8; --line:#e4e7ea; --line-dk:rgba(255,255,255,.10);
  --accent:#2563eb; --accent-deep:#1d4ed8; --accent-bright:#6ea0ff;
  --scan:#1fb6cc;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --disp:'Archivo',system-ui,sans-serif;
  font-family:'Inter',system-ui,sans-serif; color:var(--ink); line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.mfb *,.mfb *::before,.mfb *::after{box-sizing:border-box}
.mfb img{max-width:100%;display:block}
.mfb a{text-decoration:none;color:inherit}
.mfb .wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.mfb h1,.mfb h2,.mfb h3{font-family:var(--disp);font-weight:800;letter-spacing:-.025em;margin:0;line-height:1.05}
.mfb p{margin:0}

.mfb .eyebrow{font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:.6rem}
.mfb .eyebrow::before{content:"";width:24px;height:1px;background:currentColor;display:inline-block;opacity:.8}
.mfb .eyebrow.light{color:var(--accent-bright)}
.mfb .eyebrow.scan{color:var(--scan)}

.mfb .btn{display:inline-flex;align-items:center;gap:.55rem;padding:.95rem 1.7rem;font-size:.85rem;font-weight:600;border-radius:2px;transition:.16s;cursor:pointer;border:1px solid transparent}
.mfb .btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}
.mfb .btn-accent:hover{background:var(--accent-deep);border-color:var(--accent-deep)}
.mfb .btn-line{background:transparent;border-color:rgba(255,255,255,.28);color:#fff}
.mfb .btn-line:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.mfb .btn-line.dark{border-color:var(--line);color:var(--ink)}
.mfb .btn-line.dark:hover{border-color:var(--ink);background:var(--paper-dim)}
.mfb .btn .ar{font-family:var(--mono);font-size:.95em}

.mfb .chip{font-family:var(--mono);font-size:.66rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:.5rem .75rem;border:1px solid rgba(255,255,255,.22);border-radius:2px;color:var(--mist);display:inline-flex;align-items:center;gap:.45rem}
.mfb .chip.accent{border-color:rgba(110,160,255,.5);color:var(--accent-bright)}
.mfb .chip.cyan{border-color:rgba(31,182,204,.5);color:var(--scan)}

.mfb .framed{position:relative}
.mfb .framed::before,.mfb .framed::after{content:"";position:absolute;width:16px;height:16px;z-index:3;pointer-events:none}
.mfb .framed::before{left:-1px;top:-1px;border-left:2px solid rgba(255,255,255,.55);border-top:2px solid rgba(255,255,255,.55)}
.mfb .framed::after{right:-1px;bottom:-1px;border-right:2px solid rgba(255,255,255,.55);border-bottom:2px solid rgba(255,255,255,.55)}
.mfb .framed.cy::before{border-color:var(--scan)}.mfb .framed.cy::after{border-color:var(--scan)}

/* sections */
.mfb .sec{padding:104px 0}
.mfb .sec.tight{padding:84px 0}
.mfb .sec.dark{background:var(--ink);color:#fff}
.mfb .sec.graphite{background:var(--graphite);color:#fff}
.mfb .sec.dim{background:var(--paper-dim)}
.mfb .sec .head{max-width:46rem}
.mfb .sec .head.center{margin:0 auto;text-align:center}
.mfb .sec h2{font-size:clamp(2rem,3.4vw,2.9rem);margin-top:18px}
.mfb .sec .head p{margin-top:18px;font-size:1.12rem;color:var(--steel)}
.mfb .sec.dark .head p,.mfb .sec.graphite .head p{color:var(--mist)}
.mfb .lead-row{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}

/* HERO */
.mfb .hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.mfb .hero .bg{position:absolute;inset:0}
.mfb .hero .bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.mfb .hero .scrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,9,11,.93) 0%,rgba(7,9,11,.74) 40%,rgba(7,9,11,.3) 74%,rgba(7,9,11,.12) 100%),linear-gradient(0deg,rgba(7,9,11,.8) 0%,rgba(7,9,11,0) 40%)}
.mfb .hero .wrap{position:relative;z-index:2;padding:124px 0 104px}
.mfb .hero .inner{max-width:730px}
.mfb .hero h1{font-size:clamp(2.6rem,5.4vw,4.7rem);font-weight:900;margin-top:24px;letter-spacing:-.03em}
.mfb .hero .strap{margin-top:26px;max-width:39rem;font-size:1.18rem;line-height:1.62;color:#d6dbe0}
.mfb .hero .cta{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.mfb .hero .sub3d{margin-top:24px;display:inline-flex}
@media(max-width:980px){.mfb .hero .wrap{padding:84px 0 68px}}

/* CREDS */
.mfb .creds{background:var(--graphite);border-top:1px solid var(--line-dk);border-bottom:1px solid var(--line-dk)}
.mfb .creds .row{display:grid;grid-template-columns:repeat(4,1fr)}
.mfb .creds .cell{padding:26px 24px;border-left:1px solid var(--line-dk);display:flex;flex-direction:column;gap:6px}
.mfb .creds .cell:first-child{border-left:0}
.mfb .creds .k{font-family:var(--mono);font-size:1.35rem;font-weight:500;color:#fff;letter-spacing:-.01em}
.mfb .creds .v{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--fog)}
@media(max-width:760px){.mfb .creds .row{grid-template-columns:repeat(2,1fr)}.mfb .creds .cell:nth-child(odd){border-left:0}.mfb .creds .cell:nth-child(3),.mfb .creds .cell:nth-child(4){border-top:1px solid var(--line-dk)}}

/* SYSTEMS */
.mfb .pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:34px}
.mfb .pill{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--line);background:#fff;color:var(--steel);border-radius:2px;padding:9px 16px;cursor:pointer}
.mfb .pill.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.mfb .grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:34px}
@media(max-width:980px){.mfb .grid4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.mfb .grid4{grid-template-columns:1fr}}
.mfb .pcard{position:relative;display:block;border:1px solid var(--line);background:#fff;border-radius:3px;overflow:hidden;transition:.18s}
.mfb .pcard:hover{border-color:var(--ink);transform:translateY(-3px);box-shadow:0 18px 40px rgba(0,0,0,.10)}
.mfb .pcard .ph{aspect-ratio:4/3;background:var(--paper-dim);position:relative;overflow:hidden}
.mfb .pcard .ph img{width:100%;height:100%;object-fit:cover}
.mfb .pcard .load{position:absolute;right:10px;top:10px;font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;background:rgba(11,13,15,.82);color:#fff;padding:4px 7px;border-radius:2px}
.mfb .pcard .bd{padding:18px 18px 20px}
.mfb .pcard .cat{font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.mfb .pcard h3{font-size:1.18rem;font-weight:700;margin-top:8px}
.mfb .pcard p{margin-top:7px;font-size:.88rem;color:var(--steel)}
.mfb .pcard .more{margin-top:14px;font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:6px}

/* EXPLORE IN 3D */
.mfb .v3d{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center}
@media(max-width:980px){.mfb .v3d{grid-template-columns:1fr;gap:36px}}
.mfb .viewer{position:relative;aspect-ratio:16/11;border-radius:3px;overflow:hidden;background:radial-gradient(120% 120% at 50% 30%,#22272d 0%,#0c0e11 100%);display:grid;place-items:center}
.mfb .viewer img{width:74%;height:auto;filter:drop-shadow(0 30px 40px rgba(0,0,0,.5))}
.mfb .viewer .floor{position:absolute;inset:auto 0 0 0;height:42%;background:linear-gradient(0deg,rgba(110,160,255,.07),transparent);border-top:1px solid rgba(110,160,255,.14)}
.mfb .viewer .hud{position:absolute;left:14px;top:14px;display:flex;gap:8px}
.mfb .viewer .hud .chip{background:rgba(8,10,12,.6);color:var(--mist)}
.mfb .viewer .rotate{position:absolute;right:14px;bottom:14px;font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mist);display:flex;align-items:center;gap:7px}
.mfb .viewer .rotate .ic{width:20px;height:20px;border:1px solid var(--mist);border-radius:50%;display:grid;place-items:center;font-size:.7rem}
.mfb .swatches{margin-top:26px;display:flex;gap:10px}
.mfb .sw{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);cursor:pointer}
.mfb .sw.on{outline:2px solid var(--accent);outline-offset:2px}
.mfb .feat-list{margin-top:24px;padding:0;display:flex;flex-direction:column;gap:12px}
.mfb .feat-list li{list-style:none;display:flex;gap:12px;align-items:flex-start;color:var(--steel);font-size:1rem}
.mfb .feat-list .bx{font-family:var(--mono);color:var(--accent);font-size:.9rem;margin-top:2px}

/* PROJECTS */
.mfb .projgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
@media(max-width:980px){.mfb .projgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.mfb .projgrid{grid-template-columns:1fr}}
.mfb .proj{position:relative;aspect-ratio:4/5;border-radius:3px;overflow:hidden;background:#0a0c0e}
.mfb .proj img{width:100%;height:100%;object-fit:cover;transition:.5s}
.mfb .proj:hover img{transform:scale(1.05)}
.mfb .proj .ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(7,9,11,.86) 0%,rgba(7,9,11,.05) 55%)}
.mfb .proj .cap{position:absolute;left:0;bottom:0;padding:22px;z-index:2}
.mfb .proj .cap .m{font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-bright)}
.mfb .proj .cap h3{color:#fff;font-size:1.25rem;font-weight:700;margin-top:8px}

/* PROCESS */
.mfb .proc{margin-top:30px;border-top:1px solid var(--line)}
.mfb .proc .r{display:grid;grid-template-columns:90px 1fr auto;gap:28px;align-items:center;padding:26px 0;border-bottom:1px solid var(--line)}
.mfb .proc .no{font-family:var(--mono);font-size:2.4rem;font-weight:500;color:var(--line)}
.mfb .proc .r:hover .no{color:var(--accent)}
.mfb .proc h3{font-size:1.4rem;font-weight:700}
.mfb .proc p{margin-top:8px;color:var(--steel);max-width:42rem}
.mfb .proc .tag{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--steel)}
@media(max-width:760px){.mfb .proc .r{grid-template-columns:60px 1fr}.mfb .proc .tag{display:none}}

/* 3D SCANNING (tertiary feature) */
.mfb .scanfeat{background:var(--graphite);color:#fff;position:relative;overflow:hidden}
.mfb .scanfeat .blue{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:42px 42px;opacity:.7}
.mfb .scanfeat .grid{position:relative;display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:center}
@media(max-width:900px){.mfb .scanfeat .grid{grid-template-columns:1fr;gap:34px}}
.mfb .scanfeat .vis{position:relative;aspect-ratio:16/10;border-radius:3px;overflow:hidden;background:#0a0c0e}
.mfb .scanfeat .vis img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.9)}
.mfb .scanfeat .vis .dots{position:absolute;inset:0;background-image:radial-gradient(rgba(31,182,204,.6) 1px,transparent 1.2px);background-size:14px 14px;mix-blend-mode:screen;opacity:.45}
.mfb .scanfeat .vis .tag{position:absolute;left:14px;bottom:14px;z-index:4}
.mfb .scanfeat h2{font-size:clamp(1.7rem,2.8vw,2.3rem)}
.mfb .scanfeat p{margin-top:16px;color:var(--mist);font-size:1.05rem;max-width:32rem}
.mfb .scanfeat .uses{margin-top:22px;display:flex;flex-wrap:wrap;gap:10px}
.mfb .scanfeat .go{margin-top:26px;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--scan);display:inline-flex;align-items:center;gap:8px}

/* SPECIFIERS */
.mfb .spec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
@media(max-width:760px){.mfb .spec-grid{grid-template-columns:1fr}}
.mfb .dl{border:1px solid var(--line-dk);border-radius:3px;padding:26px;background:rgba(255,255,255,.02);transition:.18s}
.mfb .dl:hover{border-color:rgba(110,160,255,.4);background:rgba(110,160,255,.05)}
.mfb .dl .ic{font-family:var(--mono);color:var(--accent-bright);font-size:.8rem}
.mfb .dl h3{font-size:1.18rem;font-weight:700;margin-top:14px;color:#fff}
.mfb .dl p{margin-top:8px;color:var(--mist);font-size:.92rem}
.mfb .dl .go{margin-top:16px;font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-bright)}

/* CTA */
.mfb .endcta{text-align:center}
.mfb .endcta h2{font-size:clamp(2.2rem,4vw,3.4rem)}
.mfb .endcta .cta{margin-top:34px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* When placed inside Elementor's constrained column, let sections still go full-bleed-ish */
.mfb .sec,.mfb .hero,.mfb .creds{width:100%}
