/* ============================================================
 * Rentalize Motion Lab v2 — full stylesheet
 * Critical CSS is inlined in page-motion-test.php; everything
 * non-critical is here, enqueued with filemtime() versioning.
 * Source of truth: docs/MOTION_TEST_DESIGN_SYSTEM.md
 * ============================================================ */

/* ---------- Variable font (M1.7) ---------- */
@font-face {
  font-family: 'Recursive';
  font-style: normal;
  font-weight: 300 1000;
  font-display: swap;
  src: url('fonts/Recursive_VF.woff2') format('woff2-variations');
}

/* ---------- Avada overrides ---------- */
.fusion-page-title-bar { display:none !important; }
#main { padding-top:0 !important; }
#main > .fusion-row { max-width:100% !important; padding:0 !important; margin:0 !important; }
#content.full-width { padding:0 !important; margin:0 !important; }
#content .post-content { padding:0 !important; margin:0 !important; }
#content .post-content > .mt-section {
  width:100vw; position:relative;
  left:50%; right:50%;
  margin-left:-50vw; margin-right:-50vw;
}
#main.clearfix { padding-left:0 !important; padding-right:0 !important; }
html { scroll-behavior:smooth; }
html.mt-lenis { scroll-behavior:auto; }

/* ---------- Tokens ---------- */
:root {
  --mt-font-display:'Recursive','Satoshi','DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --mt-font-body:'General Sans','DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --mt-wght:700;
  --mt-violet:#7c3aed; --mt-violet-2:#a855f7;
  --mt-blue:#2563eb; --mt-cyan:#22d3ee;
  --mt-orange:#f97316; --mt-orange-2:#fb923c;
  --mt-bg:#0b0d17; --mt-bg-2:#11142b; --mt-bg-3:#070815;
  --mt-glass:rgba(255,255,255,0.06);
  --mt-glass-2:rgba(255,255,255,0.10);
  --mt-border:rgba(255,255,255,0.12);
  --mt-border-2:rgba(255,255,255,0.18);
  --mt-text:#ffffff;
  --mt-text-2:rgba(255,255,255,0.72);
  --mt-text-3:rgba(255,255,255,0.55);
  --mt-text-4:rgba(255,255,255,0.35);
  --mt-mint:#10b981; --mt-amber:#f59e0b; --mt-rose:#f43f5e;
  --mt-section-y:clamp(80px,12vw,160px);
  --mt-r-md:14px; --mt-r-lg:18px; --mt-r-xl:22px; --mt-r-2xl:28px; --mt-r-pill:999px;
  --mt-shadow-md:0 12px 32px -8px rgba(0,0,0,0.4);
  --mt-shadow-lg:0 30px 60px -20px rgba(0,0,0,0.6);
  --mt-glow-v:0 0 60px rgba(124,58,237,0.40);
  --mt-glow-c:0 0 40px rgba(34,211,238,0.30);
  --mt-glow-o:0 0 50px rgba(249,115,22,0.45);
  --mt-glass-edge:inset 0 1px 0 rgba(255,255,255,0.08);
  --mt-ease-out:cubic-bezier(.22,.61,.36,1);
  --mt-ease-in:cubic-bezier(.55,.06,.68,.19);
}

/* ---------- Base ---------- */
.mt * { box-sizing:border-box; }
.mt {
  font-family:var(--mt-font-body);
  font-size:17px; line-height:1.65;
  color:var(--mt-text-2); background:var(--mt-bg);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
.mt h1, .mt h2, .mt h3 {
  font-family:var(--mt-font-display);
  color:var(--mt-text); margin:0;
  font-variation-settings:'wght' var(--mt-wght), 'MONO' 0, 'CASL' 0, 'slnt' 0;
}
.mt-display { font-size:clamp(48px,8vw,112px); font-weight:900; letter-spacing:-0.04em; line-height:0.95; }
.mt-h1 { font-size:clamp(40px,6vw,80px); font-weight:700; letter-spacing:-0.03em; line-height:1.0; }
.mt-h2 { font-size:clamp(30px,4.4vw,56px); font-weight:700; letter-spacing:-0.02em; line-height:1.05; }
.mt-h3 { font-size:clamp(20px,2vw,24px); font-weight:600; letter-spacing:-0.01em; line-height:1.3; }
.mt-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mt-font-body); font-size:12px; font-weight:600;
  letter-spacing:0.18em; text-transform:uppercase; color:var(--mt-text-3);
}
.mt-eyebrow::before { content:""; width:24px; height:1px; background:currentColor; opacity:0.8; }
.mt-tnum { font-feature-settings:"tnum"; font-variant-numeric:tabular-nums; }

.mt-glass {
  background:linear-gradient(135deg, var(--mt-glass-2), var(--mt-glass));
  border:1px solid var(--mt-border);
  border-radius:var(--mt-r-xl);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  box-shadow:var(--mt-shadow-lg), var(--mt-glass-edge);
}

/* ---------- Buttons ---------- */
.mt-btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 24px; min-height:48px;
  font-family:var(--mt-font-body); font-weight:600; font-size:15px;
  border-radius:var(--mt-r-pill); border:1px solid transparent;
  text-decoration:none; cursor:pointer;
  transition:background .2s var(--mt-ease-out), box-shadow .2s var(--mt-ease-out), color .2s var(--mt-ease-out);
}
.mt-btn:focus-visible { outline:2px solid var(--mt-orange); outline-offset:3px; }
.mt-btn--p {
  background:linear-gradient(135deg, var(--mt-orange), var(--mt-orange-2));
  color:#0b0d17; box-shadow:var(--mt-shadow-md);
}
.mt-btn--p:hover { box-shadow:var(--mt-glow-o), var(--mt-shadow-md); }
.mt-btn--s {
  background:var(--mt-glass); color:var(--mt-text);
  border:1px solid var(--mt-border-2); backdrop-filter:blur(10px);
}
.mt-btn--s:hover { background:var(--mt-glass-2); }
.mt-btn--t { background:transparent; color:var(--mt-text); padding:8px 0; border-radius:0; border:none; min-height:auto; }
.mt-btn--t i { transition:transform .2s var(--mt-ease-out); }
.mt-btn--t:hover i { transform:translateX(4px); }

/* ============================================================
 * Boot title-card  (M1.6)
 * ============================================================ */
.mt-boot {
  position:fixed; inset:0; z-index:9999;
  background:var(--mt-bg);
  display:grid; place-items:center;
  pointer-events:auto;
}
.mt-boot__lockup {
  font-family:var(--mt-font-display);
  font-size:clamp(48px, 10vw, 140px);
  font-weight:700; letter-spacing:-0.04em;
  background:linear-gradient(180deg, #fff 0%, #cdb6ff 60%, #8b5cf6 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  clip-path:inset(0 100% 0 0);
  animation:mtBootWipe .9s cubic-bezier(.65,.05,.36,1) forwards;
  font-variation-settings:'wght' 700;
}
.mt-boot__sub {
  position:absolute; bottom:18vh; left:50%; transform:translateX(-50%);
  font-family:var(--mt-font-body); font-size:12px; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--mt-text-3);
  opacity:0; animation:mtBootFade .5s ease .8s forwards;
}
@keyframes mtBootWipe {
  0%   { clip-path:inset(0 100% 0 0); }
  100% { clip-path:inset(0 0 0 0); }
}
@keyframes mtBootFade { to { opacity:1; } }
.mt-boot {
  /* CSS-only failsafe: even if JS never dismisses, this self-hides at 2.4s */
  animation:mtBootAutoFade 0s 2.4s forwards;
}
.mt-boot.mt-boot--exit {
  pointer-events:none;
  animation:mtBootOut .5s ease forwards;
}
@keyframes mtBootOut {
  to { opacity:0; transform:scale(1.04); visibility:hidden; }
}
@keyframes mtBootAutoFade {
  to { opacity:0; pointer-events:none; visibility:hidden; }
}

/* ============================================================
 * Magnetic cursor halo  (M2)
 * ============================================================ */
.mt-cursor {
  position:fixed; top:0; left:0; pointer-events:none; z-index:9998;
  width:24px; height:24px; border-radius:50%;
  background:radial-gradient(circle, rgba(168,85,247,0.45) 0%, rgba(34,211,238,0.20) 50%, transparent 70%);
  mix-blend-mode:screen;
  transform:translate3d(-50%,-50%,0);
  transition:width .25s var(--mt-ease-out), height .25s var(--mt-ease-out), opacity .2s ease;
  opacity:0;
}
.mt-cursor.is-on { opacity:1; }
.mt-cursor.is-magnet { width:64px; height:64px; }
@media (hover:none), (pointer:coarse) { .mt-cursor { display:none; } }

/* ============================================================
 * Chapter rail  (M4)
 * ============================================================ */
.mt-rail {
  position:fixed; top:50%; right:18px; transform:translateY(-50%);
  z-index:30; display:flex; flex-direction:column; gap:14px;
  padding:14px 10px;
  background:rgba(11,13,23,0.4);
  border:1px solid var(--mt-border);
  border-radius:var(--mt-r-pill);
  backdrop-filter:blur(14px);
  opacity:0; transform:translate(40px,-50%);
  transition:opacity .4s, transform .4s var(--mt-ease-out);
}
.mt-rail.is-ready { opacity:1; transform:translate(0,-50%); }
.mt-rail__dot {
  width:10px; height:10px; border-radius:50%;
  background:var(--mt-border-2); border:none; padding:0; cursor:pointer;
  position:relative; transition:background .2s, transform .2s;
}
.mt-rail__dot:hover { background:var(--mt-text-3); }
.mt-rail__dot[aria-current="true"] { background:var(--mt-violet-2); transform:scale(1.5); }
.mt-rail__dot:focus-visible { outline:2px solid var(--mt-cyan); outline-offset:3px; }
.mt-rail__dot::after {
  content:attr(data-mt-label);
  position:absolute; right:24px; top:50%; transform:translateY(-50%);
  font-size:11px; letter-spacing:0.15em; text-transform:uppercase;
  color:var(--mt-text); background:var(--mt-bg-2); border:1px solid var(--mt-border);
  padding:6px 12px; border-radius:var(--mt-r-pill);
  white-space:nowrap; opacity:0; pointer-events:none;
  transition:opacity .2s ease;
}
.mt-rail__dot:hover::after, .mt-rail__dot:focus-visible::after { opacity:1; }
@media (max-width:1024px) { .mt-rail { display:none; } }

/* ============================================================
 * Cinematic surface  (Three.js mounts canvas inside)
 * ============================================================ */
.mt-cinematic {
  position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none;
  background:#0b0d17;
}
.mt-cinematic canvas { position:absolute; inset:0; width:100%; height:100%; display:block; }
.mt-cinematic__fallback { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.mt-cinematic.is-ready .mt-cinematic__fallback { opacity:0; transition:opacity .4s ease; }

.mt-hero__bg { position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.mt-hero__bg::after {
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(900px 600px at 12% 18%, rgba(124,58,237,0.38), transparent 60%),
    radial-gradient(700px 500px at 88% 80%, rgba(34,211,238,0.22), transparent 60%),
    linear-gradient(180deg, rgba(7,8,21,0.55) 0%, rgba(11,13,23,0.72) 60%, rgba(17,20,43,0.92) 100%);
}

/* ============================================================
 * HERO
 * ============================================================ */
.mt-hero {
  position:relative; min-height:100vh; overflow:hidden;
  color:var(--mt-text); background:var(--mt-bg-3);
}
.mt-hero__grid {
  position:absolute; inset:0; pointer-events:none; z-index:1;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.04) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(circle at 50% 30%, black 0%, transparent 70%);
  -webkit-mask-image:radial-gradient(circle at 50% 30%, black 0%, transparent 70%);
}
.mt-hero__canvas { position:absolute; inset:0; width:100%; height:100%; z-index:1; pointer-events:none; }
.mt-hero__inner {
  position:relative; z-index:2;
  max-width:1400px; margin:0 auto;
  padding:140px 32px 96px;
  display:grid; grid-template-columns:1.05fr 1fr; gap:64px; align-items:center;
}
.mt-hero__text .mt-eyebrow { color:var(--mt-violet-2); margin-bottom:24px; }
.mt-hero__text h1 {
  background:linear-gradient(180deg,#fff 0%,#cdb6ff 60%,#8b5cf6 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  margin-bottom:24px;
}
.mt-hero__text h1 .mt-char {
  display:inline-block; opacity:0;
  font-variation-settings:'wght' 100;
  transition:font-variation-settings .35s var(--mt-ease-out), opacity .35s ease;
}
.mt-hero__text h1.is-on .mt-char {
  opacity:1; font-variation-settings:'wght' 700;
}
.mt-hero__sub { font-size:clamp(17px,1.6vw,20px); line-height:1.6; color:var(--mt-text-2); max-width:560px; margin:0 0 32px; }

.mt-path {
  display:flex; flex-wrap:wrap; gap:8px;
  margin:0 0 32px; padding:6px;
  background:var(--mt-glass); border:1px solid var(--mt-border);
  border-radius:var(--mt-r-pill); width:fit-content;
  backdrop-filter:blur(12px);
}
.mt-path__chip {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 18px; min-height:44px;
  font-family:var(--mt-font-body); font-weight:500; font-size:14px;
  color:var(--mt-text-2); background:transparent;
  border:1px solid transparent; border-radius:var(--mt-r-pill);
  cursor:pointer;
  transition:color .2s var(--mt-ease-out), background .2s var(--mt-ease-out), border-color .2s var(--mt-ease-out);
}
.mt-path__chip:hover { color:var(--mt-text); background:var(--mt-glass-2); }
.mt-path__chip[aria-selected="true"] { color:var(--mt-text); background:rgba(124,58,237,0.18); border-color:rgba(124,58,237,0.5); }
.mt-path__chip:focus-visible { outline:2px solid var(--mt-cyan); outline-offset:2px; }

.mt-hero__ctas { display:flex; gap:14px; flex-wrap:wrap; }

.mt-stage { position:relative; height:560px; }
.mt-stage .mt-glass-card {
  position:absolute;
  background:linear-gradient(135deg, var(--mt-glass-2), var(--mt-glass));
  border:1px solid var(--mt-border);
  border-radius:var(--mt-r-xl);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  box-shadow:var(--mt-shadow-lg), var(--mt-glass-edge);
  padding:20px;
}
.mt-card--main { inset:40px 60px 80px 0; display:flex; flex-direction:column; gap:18px; }
.mt-card__head { display:flex; justify-content:space-between; align-items:center; font-size:12px; color:var(--mt-text-3); letter-spacing:0.12em; text-transform:uppercase; }
.mt-card__head i { width:8px; height:8px; border-radius:50%; display:inline-block; margin-left:6px; }

.mt-gauge {
  display:flex; align-items:center; gap:20px;
  padding:20px; border-radius:var(--mt-r-md);
  background:rgba(255,255,255,0.03); border:1px solid var(--mt-border);
}
.mt-gauge__ring {
  width:120px; height:120px; border-radius:50%; position:relative;
  background:conic-gradient(var(--mt-violet) 0deg, var(--mt-cyan) var(--gauge-deg,313deg), rgba(255,255,255,0.05) var(--gauge-deg,313deg));
  display:grid; place-items:center;
}
.mt-gauge__ring::before { content:""; position:absolute; inset:8px; border-radius:50%; background:var(--mt-bg); }
.mt-gauge__num {
  position:relative; z-index:1; color:var(--mt-text);
  font-family:var(--mt-font-display); font-size:36px; font-weight:700;
  font-feature-settings:"tnum";
}
.mt-gauge__num::after { content:" / 100"; font-size:13px; color:var(--mt-text-4); font-weight:500; }
.mt-gauge__info b { display:block; font-size:18px; color:var(--mt-text); margin-bottom:4px; font-family:var(--mt-font-display); font-weight:600; }
.mt-gauge__info span { font-size:13px; color:var(--mt-text-3); }

.mt-bars { display:flex; flex-direction:column; gap:10px; }
.mt-bars__row { display:grid; grid-template-columns:96px 1fr 36px; gap:12px; align-items:center; font-size:13px; color:var(--mt-text-3); }
.mt-bars__track { height:6px; border-radius:3px; background:rgba(255,255,255,0.06); overflow:hidden; }
.mt-bars__fill {
  height:100%; width:100%;
  background:linear-gradient(90deg, var(--mt-violet), var(--mt-cyan));
  border-radius:3px; transform-origin:left center; transform:scaleX(0);
}

.mt-card--avatar { top:0; right:80px; width:240px; padding:14px 16px; display:flex; align-items:center; gap:12px; }
.mt-av { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,#fb7185,#fbbf24); display:grid; place-items:center; color:#fff; font-weight:700; font-family:var(--mt-font-display); }
.mt-card--avatar b { font-size:14px; color:var(--mt-text); display:block; }
.mt-card--avatar small { font-size:11px; color:var(--mt-text-3); }
.mt-card--avatar .mt-dot { margin-left:auto; width:8px; height:8px; border-radius:50%; background:var(--mt-mint); box-shadow:0 0 12px var(--mt-mint); animation:mtPulse 1.6s infinite; }
@keyframes mtPulse { 0%,100% { opacity:1; } 50% { opacity:0.3; } }

.mt-card--mini { width:200px; padding:16px; bottom:30px; right:0; }
.mt-card--mini b { display:block; font-size:11px; color:var(--mt-text-3); letter-spacing:0.15em; text-transform:uppercase; margin-bottom:8px; }
.mt-mini-num { font-family:var(--mt-font-display); font-size:34px; font-weight:700; color:var(--mt-text); line-height:1; margin-bottom:4px; font-feature-settings:"tnum"; }
.mt-mini-trend { display:inline-flex; align-items:center; gap:4px; font-size:12px; color:var(--mt-mint); font-weight:600; }

.mt-scroll-cue { position:absolute; bottom:32px; left:50%; transform:translateX(-50%); font-size:11px; letter-spacing:0.2em; color:var(--mt-text-4); text-transform:uppercase; display:flex; flex-direction:column; align-items:center; gap:10px; z-index:3; }
.mt-scroll-cue::after { content:""; width:1px; height:36px; background:linear-gradient(180deg,var(--mt-text-4),transparent); animation:mtCue 1.8s ease-in-out infinite; }
@keyframes mtCue { 0% { transform:scaleY(0); transform-origin:top; } 50% { transform:scaleY(1); transform-origin:top; } 51% { transform-origin:bottom; } 100% { transform:scaleY(0); transform-origin:bottom; } }

/* ============================================================
 * TRUST STRIP
 * ============================================================ */
.mt-trust { padding:48px 24px; background:var(--mt-bg-2); border-top:1px solid var(--mt-border); border-bottom:1px solid var(--mt-border); }
.mt-trust__inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:auto 1fr auto; gap:48px; align-items:center; }
.mt-trust__label { font-family:var(--mt-font-body); font-size:12px; font-weight:600; letter-spacing:0.18em; text-transform:uppercase; color:var(--mt-text-3); }
.mt-trust__badges { display:flex; flex-wrap:wrap; gap:24px 36px; align-items:center; color:var(--mt-text-2); font-weight:500; font-size:14px; }
.mt-trust__badge { display:inline-flex; align-items:center; gap:8px; opacity:0.65; transition:opacity .2s var(--mt-ease-out); }
.mt-trust__badge:hover { opacity:1; }
.mt-trust__badge svg { flex-shrink:0; }
.mt-trust__stat { text-align:right; }
.mt-trust__stat .mt-tnum { font-family:var(--mt-font-display); font-size:32px; font-weight:700; color:var(--mt-text); background:linear-gradient(135deg, var(--mt-cyan), var(--mt-violet-2)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; line-height:1; }
.mt-trust__stat small { display:block; font-size:11px; color:var(--mt-text-3); letter-spacing:0.15em; text-transform:uppercase; margin-top:4px; }

/* ============================================================
 * INDUSTRY SWITCHER
 * ============================================================ */
.mt-ind { padding:var(--mt-section-y) 24px; }
.mt-ind__inner { max-width:1280px; margin:0 auto; }
.mt-ind__head { text-align:center; max-width:680px; margin:0 auto 64px; }
.mt-ind__head .mt-eyebrow { color:var(--mt-cyan); justify-content:center; margin-bottom:16px; }
.mt-ind__head h2 { color:var(--mt-text); margin-bottom:14px; }
.mt-ind__head p { color:var(--mt-text-3); font-size:18px; margin:0; }

.mt-ind__tabs {
  display:flex; gap:6px; padding:6px;
  background:var(--mt-glass); border:1px solid var(--mt-border);
  border-radius:var(--mt-r-pill); width:fit-content; margin:0 auto 48px;
  position:relative;
}
.mt-ind__tab {
  position:relative; z-index:1;
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 22px; min-height:44px;
  background:transparent; border:none; cursor:pointer;
  font-family:var(--mt-font-body); font-size:14px; font-weight:500;
  color:var(--mt-text-3); border-radius:var(--mt-r-pill);
  transition:color .2s var(--mt-ease-out);
}
.mt-ind__tab:hover { color:var(--mt-text-2); }
.mt-ind__tab[aria-selected="true"] { color:var(--mt-text); }
.mt-ind__tab:focus-visible { outline:2px solid var(--mt-cyan); outline-offset:2px; }
.mt-ind__indicator {
  position:absolute; z-index:0; top:6px; bottom:6px; left:6px;
  border-radius:var(--mt-r-pill); width:0; height:auto;
  background:linear-gradient(135deg, rgba(124,58,237,0.4), rgba(34,211,238,0.4));
  border:1px solid rgba(124,58,237,0.5);
  transition:transform .35s var(--mt-ease-out), width .35s var(--mt-ease-out);
}

.mt-ind__panels { position:relative; min-height:280px; }
.mt-ind__panel {
  position:absolute; inset:0; opacity:0; pointer-events:none;
  display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center;
  padding:32px; border-radius:var(--mt-r-2xl);
  background:linear-gradient(135deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
  border:1px solid var(--mt-border);
  transition:opacity .25s var(--mt-ease-out);
  overflow:hidden;
}
.mt-ind__panel[aria-hidden="false"] { opacity:1; pointer-events:auto; position:relative; }
.mt-ind__panel-bg { position:absolute; inset:0; z-index:0; pointer-events:none; opacity:0.5; }
.mt-ind__panel-bg::after { content:""; position:absolute; inset:0; z-index:2; background:linear-gradient(120deg, rgba(11,13,23,0.4), rgba(17,20,43,0.75)); }
.mt-ind__panel > div:not(.mt-ind__panel-bg) { position:relative; z-index:1; }
.mt-ind__panel h3 { color:var(--mt-text); font-size:28px; margin:0 0 12px; }
.mt-ind__panel p { color:var(--mt-text-2); font-size:17px; line-height:1.65; margin:0 0 20px; }
.mt-ind__metric {
  display:flex; align-items:baseline; gap:14px;
  padding:24px; border-radius:var(--mt-r-lg);
  background:rgba(0,0,0,0.25); border:1px solid var(--mt-border);
}
.mt-ind__metric b { font-family:var(--mt-font-display); font-size:56px; font-weight:700; color:var(--mt-text); line-height:1; font-feature-settings:"tnum"; background:linear-gradient(135deg, var(--mt-cyan), var(--mt-violet-2)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.mt-ind__metric small { color:var(--mt-text-3); font-size:14px; line-height:1.4; }

/* ============================================================
 * 3D CITY
 * ============================================================ */
.mt-city { position:relative; min-height:120vh; overflow:hidden; background:linear-gradient(180deg, var(--mt-bg-2) 0%, var(--mt-bg) 100%); color:var(--mt-text); }
.mt-city__canvas { position:sticky; top:0; width:100%; height:100vh; z-index:1; }
.mt-city__copy { position:absolute; z-index:2; top:18vh; left:50%; transform:translateX(-50%); text-align:center; max-width:720px; padding:0 24px; }
.mt-city__copy .mt-eyebrow { color:var(--mt-cyan); justify-content:center; margin-bottom:18px; }
.mt-city__copy h2 { color:var(--mt-text); margin-bottom:14px; background:linear-gradient(180deg,#fff,var(--mt-cyan)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.mt-city__copy p { color:var(--mt-text-3); font-size:18px; }
.mt-city__hud { position:absolute; z-index:3; bottom:8vh; left:50%; transform:translateX(-50%); display:flex; gap:14px; flex-wrap:wrap; justify-content:center; padding:0 24px; }
.mt-city__hud .mt-glass { padding:14px 20px; min-width:160px; border-radius:var(--mt-r-lg); }
.mt-city__hud b { font-size:11px; color:var(--mt-text-3); letter-spacing:0.15em; text-transform:uppercase; }
.mt-city__hud .mt-mini-num { font-size:28px; }

/* ============================================================
 * PRODUCTS
 * ============================================================ */
.mt-products { padding:var(--mt-section-y) 24px; background:var(--mt-bg); color:var(--mt-text); }
.mt-products__head { max-width:760px; margin:0 auto 64px; text-align:center; }
.mt-products__head .mt-eyebrow { color:var(--mt-violet-2); justify-content:center; margin-bottom:18px; }
.mt-products__head h2 { color:var(--mt-text); margin-bottom:14px; }
.mt-products__head p { font-size:18px; color:var(--mt-text-3); margin:0; }
.mt-pgrid { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.mt-pcard {
  position:relative; padding:32px 28px;
  background:linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border:1px solid var(--mt-border); border-radius:var(--mt-r-2xl);
  box-shadow:var(--mt-shadow-md), var(--mt-glass-edge);
  transition:border-color .2s var(--mt-ease-out), background .2s var(--mt-ease-out);
  cursor:pointer;
}
.mt-pcard:hover { border-color:var(--mt-border-2); background:linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02)); }
.mt-pcard__svg { width:100%; height:180px; margin-bottom:24px; border-radius:var(--mt-r-md); overflow:hidden; position:relative; background:rgba(0,0,0,0.3); border:1px solid var(--mt-border); }
.mt-pcard__tag { display:inline-block; font-size:11px; font-weight:700; letter-spacing:0.15em; text-transform:uppercase; padding:4px 10px; border-radius:var(--mt-r-pill); margin-bottom:14px; }
.mt-pcard--violet .mt-pcard__tag { color:#c4b5fd; background:rgba(124,58,237,0.18); border:1px solid rgba(124,58,237,0.35); }
.mt-pcard--blue   .mt-pcard__tag { color:#93c5fd; background:rgba(37,99,235,0.18);   border:1px solid rgba(37,99,235,0.35); }
.mt-pcard--cyan   .mt-pcard__tag { color:#67e8f9; background:rgba(34,211,238,0.18);  border:1px solid rgba(34,211,238,0.35); }
.mt-pcard h3 { color:var(--mt-text); margin:0 0 10px; }
.mt-pcard p { color:var(--mt-text-3); font-size:15px; margin:0 0 18px; }
.mt-pcard__link { display:inline-flex; align-items:center; gap:8px; font-weight:600; color:var(--mt-text); font-size:14px; text-decoration:none; }
.mt-pcard__link i { transition:transform .25s var(--mt-ease-out); }
.mt-pcard:hover .mt-pcard__link i { transform:translateX(4px); }

@keyframes mtFloat { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-6px); } }
@keyframes mtSpin { to { transform:rotate(360deg); } }
@keyframes mtBlip { 0% { transform:scale(0.3); opacity:1; } 100% { transform:scale(8); opacity:0; } }
.mt-svg-bldgs .mt-bldg { animation:mtFloat 4s ease-in-out infinite; transform-origin:center bottom; }
.mt-svg-bldgs .mt-bldg:nth-child(2) { animation-delay:0.4s; }
.mt-svg-bldgs .mt-bldg:nth-child(3) { animation-delay:0.8s; }
.mt-svg-radar .mt-radar { transform-origin:center; transform-box:fill-box; animation:mtSpin 4s linear infinite; }
.mt-svg-radar .mt-ping { transform-origin:center; transform-box:fill-box; animation:mtBlip 2s ease-out infinite; }
.mt-svg-radar .mt-ping:nth-child(odd) { animation-delay:1s; }
.mt-svg-pulse circle { transform-origin:center; transform-box:fill-box; animation:mtFloat 3s ease-in-out infinite; }

/* ============================================================
 * TESTIMONIAL
 * ============================================================ */
.mt-testi { padding:var(--mt-section-y) 24px; background:var(--mt-bg-2); border-top:1px solid var(--mt-border); border-bottom:1px solid var(--mt-border); }
.mt-testi__inner { max-width:980px; margin:0 auto; text-align:center; position:relative; }
.mt-testi__inner .mt-eyebrow { color:var(--mt-cyan); justify-content:center; margin-bottom:36px; }
.mt-testi__stage { position:relative; min-height:260px; }
.mt-testi__slide { position:absolute; inset:0; opacity:0; transition:opacity .5s var(--mt-ease-out); }
.mt-testi__slide[aria-hidden="false"] { opacity:1; position:relative; }
.mt-testi__quote { font-family:var(--mt-font-display); font-size:clamp(24px, 3vw, 36px); font-weight:500; line-height:1.35; letter-spacing:-0.01em; color:var(--mt-text); margin:0 auto 32px; max-width:840px; }
.mt-testi__quote::before { content:"\201C"; display:block; font-family:var(--mt-font-display); font-size:64px; color:var(--mt-violet-2); line-height:0.6; margin-bottom:8px; }
.mt-testi__author { display:inline-flex; align-items:center; gap:16px; text-align:left; }
.mt-testi__author .mt-av { width:56px; height:56px; font-size:18px; }
.mt-testi__author b { color:var(--mt-text); display:block; font-family:var(--mt-font-display); font-weight:600; }
.mt-testi__author small { color:var(--mt-text-3); font-size:13px; }
.mt-testi__dots { display:flex; justify-content:center; gap:8px; margin-top:36px; }
.mt-testi__dot { width:8px; height:8px; padding:0; border-radius:50%; background:var(--mt-border-2); border:none; cursor:pointer; transition:background .2s, transform .2s; }
.mt-testi__dot:focus-visible { outline:2px solid var(--mt-cyan); outline-offset:3px; }
.mt-testi__dot[aria-selected="true"] { background:var(--mt-violet-2); transform:scale(1.4); }

/* ============================================================
 * TRACTION
 * ============================================================ */
.mt-traction {
  position:relative; padding:var(--mt-section-y) 24px; overflow:hidden;
  background:
    radial-gradient(800px 500px at 80% 20%, rgba(34,211,238,0.16), transparent 60%),
    radial-gradient(700px 400px at 10% 90%, rgba(124,58,237,0.16), transparent 60%),
    linear-gradient(180deg, var(--mt-bg) 0%, var(--mt-bg-2) 100%);
  color:var(--mt-text);
}
.mt-traction__inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:0.9fr 1.1fr; gap:80px; align-items:center; }
.mt-traction__copy .mt-eyebrow { color:var(--mt-cyan); margin-bottom:18px; }
.mt-traction__copy h2 { margin-bottom:14px; color:var(--mt-text); }
.mt-traction__copy p { font-size:18px; color:var(--mt-text-2); margin:0 0 36px; }
.mt-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.mt-stat { padding:18px; border-radius:var(--mt-r-md); background:rgba(255,255,255,0.04); border:1px solid var(--mt-border); }
.mt-stat b { display:block; font-size:11px; letter-spacing:0.15em; text-transform:uppercase; color:var(--mt-text-3); margin-bottom:6px; font-weight:600; }
.mt-stat__n { font-family:var(--mt-font-display); font-size:32px; font-weight:700; line-height:1; font-feature-settings:"tnum"; background:linear-gradient(135deg, var(--mt-cyan), var(--mt-violet-2)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.mt-chart svg { width:100%; height:auto; display:block; }

/* ============================================================
 * CTA
 * ============================================================ */
.mt-cta { position:relative; padding:var(--mt-section-y) 24px; overflow:hidden; background:#0b0d17; color:var(--mt-text); text-align:center; }
.mt-cta__bg { position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden; transform:scale(1.18); transform-origin:center; will-change:transform; }
.mt-cta__bg::after { content:""; position:absolute; inset:0; z-index:2; background:linear-gradient(135deg, rgba(124,58,237,0.55) 0%, rgba(30,27,75,0.65) 50%, rgba(8,47,73,0.7) 100%); }
.mt-cta__inner { position:relative; z-index:2; max-width:760px; margin:0 auto; }
.mt-cta .mt-eyebrow { color:var(--mt-orange-2); justify-content:center; margin-bottom:18px; }
.mt-cta h2 { color:var(--mt-text); margin-bottom:16px; }
.mt-cta p { font-size:18px; color:var(--mt-text-2); margin:0 0 32px; }
.mt-cta__buttons { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.mt-cta__iso { position:absolute; inset:0; opacity:0.12; pointer-events:none; }

/* ============================================================
 * CINEMATIC MODE  (M4)
 * ============================================================ */
html.mt-cinematic-on body > *:not(.mt-section):not(.mt-cursor):not(.mt-cinematic-overlay) { opacity:0.04; pointer-events:none; transition:opacity .6s var(--mt-ease-out); }
.mt-cinematic-overlay {
  position:fixed; inset:0; pointer-events:none; z-index:9990;
  background:linear-gradient(180deg, transparent 0%, transparent 70%, rgba(0,0,0,0.4) 100%);
  opacity:0; transition:opacity .4s ease;
}
html.mt-cinematic-on .mt-cinematic-overlay { opacity:1; }
.mt-cinematic-overlay__exit {
  position:fixed; top:24px; right:24px; padding:8px 14px;
  font-family:var(--mt-font-body); font-size:11px; letter-spacing:0.18em; text-transform:uppercase;
  background:rgba(11,13,23,0.5); border:1px solid var(--mt-border); border-radius:var(--mt-r-pill);
  color:var(--mt-text-3); pointer-events:auto;
}

/* ---------- Mobile ---------- */
@media (max-width:1024px) {
  .mt-hero__inner { grid-template-columns:1fr; padding:120px 24px 80px; gap:40px; }
  .mt-stage { height:480px; }
  .mt-traction__inner { grid-template-columns:1fr; gap:48px; }
  .mt-pgrid { grid-template-columns:1fr; }
  .mt-ind__panel { grid-template-columns:1fr; gap:24px; padding:24px; }
  .mt-trust__inner { grid-template-columns:1fr; gap:24px; text-align:center; }
  .mt-trust__badges { justify-content:center; }
  .mt-trust__stat { text-align:center; }
}
@media (max-width:640px) {
  .mt-hero__inner { padding:96px 16px 64px; }
  .mt-stage { height:440px; }
  .mt-card--main { inset:60px 30px 30px 0; padding:16px; }
  .mt-card--avatar { width:200px; right:0; top:-10px; }
  .mt-card--mini { width:160px; bottom:0; }
  .mt-stats { grid-template-columns:1fr 1fr; }
  .mt-stat:nth-child(3) { grid-column:1 / -1; }
  .mt-path { flex-direction:column; align-items:stretch; border-radius:var(--mt-r-lg); }
  .mt-path__chip { justify-content:center; }
  .mt-ind__tabs { flex-wrap:wrap; }
}

/* Reveal helper */
.mt-reveal { opacity:0; transform:translateY(24px); }
.mt-reveal.mt-on { opacity:1; transform:none; transition:opacity .8s var(--mt-ease-out), transform .8s var(--mt-ease-out); }

/* ============================================================
 * Reduced motion
 * ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
    scroll-behavior:auto !important;
  }
  .mt-reveal { opacity:1 !important; transform:none !important; }
  .mt-gauge__ring { --gauge-deg:313deg; }
  .mt-bars__fill { transform:scaleX(1); }
  .mt-hero__canvas, .mt-city__canvas { display:none; }
  .mt-scroll-cue::after { display:none; }
  .mt-ind__panel-bg { transform:none !important; }
  .mt-boot { display:none; }
  .mt-cursor { display:none; }
  .mt-hero__text h1 .mt-char { opacity:1; font-variation-settings:'wght' 700; }
}
