/*
Theme Name: FortMetrix
Theme URI: https://www.fortmetrix.com
Author: FORT Systems
Description: Custom theme replicating the FortMetrix Framer site. One-page marketing front page, waitlist form, legal pages.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: fortmetrix
*/

/* ---------- Fonts ---------- */
@font-face{font-family:'Inter';src:url('assets/fonts/Inter-Regular.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Inter';src:url('assets/fonts/Inter-Medium.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Inter';src:url('assets/fonts/Inter-SemiBold.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Inter Display';src:url('assets/fonts/InterDisplay-SemiBold.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Inter Display';src:url('assets/fonts/InterDisplay-Medium.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Geist Mono';src:url('assets/fonts/GeistMono-Medium.woff2') format('woff2');font-weight:500;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --ink:#161919;
  --body:#383D3D;
  --muted:#6A7175;
  --bg-light:#F5F7F7;
  --teal:#069494;
  --teal-light:#97CECD;
  --green-deep:#16594A;
  --orange:#F98F45;
  --rust:#C4421A;
  --line:#D5DCDC;
  --card-on-dark:rgba(255,255,255,.08);
  --font-display:'Inter Display','Inter',sans-serif;
  --font-body:'Inter',sans-serif;
  --font-mono:'Geist Mono',ui-monospace,monospace;
  --container:1300px;
  --radius-card:16px;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--body);background:#fff;font-size:16px;line-height:1.4;letter-spacing:-.1px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:600;color:var(--ink);letter-spacing:-1px}
h1{font-size:68px;line-height:1.15}
h2{font-size:48px;line-height:1.25}
h3{font-size:30px;line-height:1.25;letter-spacing:-.5px}
h4{font-size:24px;line-height:1.4;letter-spacing:-.5px}
h5{font-size:20px;line-height:1.7;letter-spacing:-.3px}
.container{max-width:var(--container);margin:0 auto;padding:0 32px}
.section{padding:90px 0}
.eyebrow{font-family:var(--font-mono);font-size:14px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--green-deep);text-align:center;margin-bottom:16px}
.section-head{text-align:center;max-width:900px;margin:0 auto 56px}
.section-head .sub{font-size:18px;color:var(--body);margin-top:16px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;border-radius:100px;padding:8px 10px 8px 24px;font-size:16px;font-weight:600;line-height:1.7;cursor:pointer;border:0;transition:transform .15s ease,box-shadow .15s ease}
.btn:hover{transform:translateY(-1px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-light{background:#fff;color:var(--ink);border:1px solid var(--line);padding:12px 28px}
.btn .arrow{width:36px;height:36px;border-radius:50%;background:var(--teal);display:inline-flex;align-items:center;justify-content:center;flex:0 0 36px}
.btn .arrow svg{width:16px;height:16px;stroke:#fff}

/* ---------- Header / nav ---------- */
.site-header{position:fixed;inset:0 0 auto 0;z-index:100;padding:12px 24px;transition:background .25s ease,box-shadow .25s ease}
.site-header.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(0,0,0,.05)}
.nav-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo img{height:26px;width:auto}
.nav-links{display:flex;gap:28px;font-size:14px;font-weight:500;color:var(--ink)}
.nav-links a:hover{color:var(--teal)}
.nav-actions{display:flex;gap:12px;align-items:center}
.nav-actions .btn{font-size:14px;padding:6px 8px 6px 20px}
.nav-actions .btn-light{padding:10px 22px;font-size:14px}
.nav-actions .btn .arrow{width:30px;height:30px;flex-basis:30px}
.nav-toggle{display:none;background:none;border:0;width:40px;height:40px;cursor:pointer}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);margin:5px auto;transition:.2s}

/* ---------- Hero ---------- */
.hero{background:var(--bg-light) url('assets/img/grid-pattern.png') no-repeat right -120px top -120px;background-size:1100px;padding:170px 0 110px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:530px 1fr;gap:60px;align-items:center}
.hero p.lede{font-size:18px;line-height:1.55;margin:24px 0 36px;max-width:530px}
.hero-shot{min-width:0}
.hero-shot img{border-radius:18px;box-shadow:0 30px 80px rgba(22,25,25,.12);width:100%;max-width:680px;margin-left:auto}

/* ---------- Trust (stat cards) ---------- */
.trust .section-head{max-width:560px}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);background:var(--bg-light);border-radius:var(--radius-card);overflow:hidden}
.stat{padding:50px 28px;position:relative}
.stat+.stat::before{content:'';position:absolute;left:0;top:24%;height:52%;width:1px;background:var(--line)}
.stat h3{margin-bottom:14px}
.stat p{font-size:16px;line-height:1.5}

/* ---------- Integrations (dark) ---------- */
.integrations{background:var(--ink) url('assets/img/grid-pattern.png') no-repeat center top;background-size:1400px;padding:100px 0;overflow:hidden}
.integrations .eyebrow{color:var(--teal-light)}
.integrations h2{color:#fff;max-width:760px;margin:0 auto}
.marquee{overflow:hidden;margin-top:64px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:20px;width:max-content;animation:marquee 40s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
.logo-tile{width:180px;height:150px;border-radius:var(--radius-card);background:var(--card-on-dark);display:flex;align-items:center;justify-content:center;flex:0 0 180px}
.logo-tile img{max-width:110px;max-height:64px;width:auto;height:auto;object-fit:contain;filter:none}

/* ---------- Value prop ---------- */
.valueprop-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-top:24px}
.vp-list{display:flex;flex-direction:column}
.vp-item{padding:22px 0;border-bottom:1px solid var(--line);cursor:pointer}
.vp-item:first-child{border-top:1px solid var(--line)}
.vp-item h4{color:#01071A;display:flex;justify-content:space-between;align-items:center;transition:color .2s}
.vp-item:not(.open) h4{color:var(--muted)}
.vp-item .vp-body{max-height:0;overflow:hidden;transition:max-height .3s ease}
.vp-item.open .vp-body{max-height:140px}
.vp-item .vp-body p{padding-top:10px;font-size:16px}
.vp-figure img{border-radius:16px;width:100%}

/* ---------- Pillars (tabs) ---------- */
.pillars .tabs{display:flex;gap:8px;justify-content:center;margin:8px 0 40px}
.tab-btn{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:100px;padding:10px 26px;font-size:15px;font-weight:500;font-family:var(--font-body);cursor:pointer;transition:.2s}
.tab-btn.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.pillar-panel{display:none;background:var(--bg-light);border-radius:20px;padding:70px 60px;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.pillar-panel.active{display:grid}
.pillar-icon{width:44px;height:44px;border-radius:50%;background:var(--teal);display:flex;align-items:center;justify-content:center;margin-bottom:28px}
.pillar-icon svg{width:20px;height:20px;stroke:#fff}
.pillar-panel h3{margin-bottom:18px}
.pillar-panel p{font-size:16px;line-height:1.55;max-width:460px}
.pillar-panel img{border-radius:12px;width:100%}

/* ---------- How it works ---------- */
.how{background:var(--bg-light)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-top:24px}
.step{position:relative;padding-top:8px}
.step-icon{width:44px;height:44px;border-radius:50%;background:var(--teal);display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.step-icon svg{width:20px;height:20px;stroke:#fff;fill:none}
.step h5{margin-bottom:12px}
.step p{font-size:16px;line-height:1.55}
.step .step-num{position:absolute;top:8px;right:0;font-family:var(--font-mono);font-size:13px;color:var(--muted)}

/* ---------- Use cases (dark) ---------- */
.usecases{background:var(--ink) url('assets/img/grid-pattern.png') no-repeat center -200px;background-size:1400px;padding:100px 0}
.usecases .eyebrow{color:var(--teal-light)}
.usecases h2{color:#fff}
.uc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:56px}
.uc-card{background:var(--card-on-dark);border-radius:20px;padding:28px;min-height:240px;display:flex;flex-direction:column;gap:14px}
.uc-card h3{font-family:var(--font-body);font-size:20px;font-weight:500;color:#fff;letter-spacing:-.2px;line-height:1.35}
.uc-card p{font-size:14px;line-height:1.5;color:rgba(255,255,255,.7);margin-top:auto}

/* ---------- FAQ ---------- */
.faq-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.faq-col{display:flex;flex-direction:column;gap:16px}
.faq-item{background:var(--bg-light);border-radius:var(--radius-card);padding:24px;cursor:pointer}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--ink);letter-spacing:-.3px}
.faq-q .faq-icon{flex:0 0 20px;width:20px;height:20px;position:relative}
.faq-q .faq-icon::before,.faq-q .faq-icon::after{content:'';position:absolute;background:var(--ink);transition:transform .25s}
.faq-q .faq-icon::before{left:0;top:9px;width:20px;height:2px}
.faq-q .faq-icon::after{left:9px;top:0;width:2px;height:20px}
.faq-item.open .faq-icon::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-a{max-height:300px}
.faq-a p{padding-top:14px;font-size:16px;line-height:1.55}

/* ---------- CTA ---------- */
.cta{background-color:var(--bg-light);background-image:linear-gradient(rgba(22,25,25,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(22,25,25,.055) 1px,transparent 1px);background-size:56px 56px;background-position:center;padding:130px 0;text-align:center}
.cta h2{max-width:800px;margin:0 auto 40px}
.cta .cta-actions{display:flex;gap:14px;justify-content:center}

/* ---------- Footer ---------- */
.site-footer{padding:80px 0 40px;background:#fff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px}
.footer-brand img{width:200px;margin-bottom:20px}
.footer-brand p{font-size:14px;max-width:280px}
.footer-col h6{font-family:var(--font-body);font-size:14px;font-weight:400;color:var(--muted);margin-bottom:18px}
.footer-col a{display:block;font-size:15px;color:var(--ink);margin-bottom:12px}
.footer-col a:hover{color:var(--teal)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:64px;padding-top:28px;border-top:1px solid var(--line);font-size:14px;color:var(--muted)}
.footer-social{display:flex;gap:14px}
.footer-social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--line)}
.footer-social svg{width:16px;height:16px;fill:var(--ink)}

/* ---------- Waitlist page ---------- */
.waitlist-page{min-height:100vh;background-color:var(--bg-light);background-image:linear-gradient(rgba(22,25,25,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(22,25,25,.045) 1px,transparent 1px);background-size:56px 56px;padding:90px 24px}
.waitlist-top{max-width:1400px;margin:0 auto 40px;display:flex;justify-content:space-between;align-items:center}
.waitlist-card{max-width:650px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 4px 50px rgba(0,0,0,.08);padding:56px}
.waitlist-card .wl-logo{height:30px;width:auto;margin:0 auto 28px}
.waitlist-card h1{font-size:28px;letter-spacing:-.5px;text-align:center;line-height:1.3}
.waitlist-card .wl-sub{text-align:center;font-size:15px;margin:12px 0 36px}
.wl-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.wl-field{margin-bottom:22px}
.wl-field label{display:block;font-size:14px;font-weight:500;color:var(--ink);margin-bottom:8px}
.wl-field label .req{color:var(--teal)}
.wl-field input,.wl-field textarea{width:100%;background:var(--bg-light);border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-family:var(--font-body);font-size:15px;color:var(--ink)}
.wl-field input:focus,.wl-field textarea:focus{outline:2px solid var(--teal);outline-offset:-1px}
.wl-field textarea{min-height:54px;resize:vertical}
.wl-radios{display:flex;flex-direction:column;gap:10px}
.wl-radios label{display:flex;align-items:center;gap:10px;font-size:15px;color:var(--body);font-weight:400}
.wl-radios input{accent-color:var(--teal)}
.wl-submit{width:100%;background:var(--ink);color:#fff;border:0;border-radius:46px;padding:16px;font-family:var(--font-body);font-size:16px;font-weight:600;cursor:pointer;margin-top:8px}
.wl-submit:hover{background:#000}
.wl-success{background:#E7F5F1;border:1px solid var(--teal);border-radius:10px;padding:16px;margin-bottom:24px;color:var(--green-deep);font-size:15px;text-align:center}
.hp-field{position:absolute;left:-9999px;opacity:0}

/* ---------- Legal / generic pages ---------- */
.page-plain{padding:170px 0 90px}
.page-plain .entry{max-width:820px;margin:0 auto}
.page-plain h1{font-size:48px;margin-bottom:10px}
.page-plain .effective{font-size:15px;color:var(--muted);margin-bottom:40px}
.entry-content h4{margin:36px 0 14px}
.entry-content p{margin-bottom:16px;font-size:16px;line-height:1.6}
.entry-content ul{list-style:disc;padding-left:22px;margin-bottom:16px}
.entry-content ul li{margin-bottom:8px;font-size:16px;line-height:1.55}
.entry-content a{color:var(--teal);text-decoration:underline}

/* ---------- 404 ---------- */
.error404-wrap{padding:200px 0 120px;text-align:center}
.error404-wrap h2{margin-bottom:24px}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.marquee-track{animation:none}}

/* ---------- Tablet ≤1199 ---------- */
@media (max-width:1199px){
  h1{font-size:52px}
  h2{font-size:38px}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero{padding:150px 0 80px}
  .stat-row{grid-template-columns:1fr 1fr}
  .stat+.stat::before{display:none}
  .uc-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr;gap:36px}
  .valueprop-grid,.pillar-panel.active{grid-template-columns:1fr;gap:40px}
  .pillar-panel{padding:48px 36px}
}

/* ---------- Phone ≤809 ---------- */
@media (max-width:809px){
  h1{font-size:40px}
  h2{font-size:31px}
  h3{font-size:24px}
  .section{padding:64px 0}
  .container{padding:0 20px}
  .nav-links,.nav-actions .btn-light{display:none}
  .nav-toggle{display:block}
  .nav-open .nav-links{display:flex;position:absolute;top:64px;left:16px;right:16px;background:#fff;border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,.12);flex-direction:column;padding:24px;gap:18px}
  .stat-row{grid-template-columns:1fr}
  .uc-grid{grid-template-columns:1fr}
  .faq-cols{grid-template-columns:1fr}
  .footer-grid{