﻿/* ==========================================================================
   Utopick IT · cybersecurity — landing page
   Theme: deep navy / matrix · neon cyan + violet · glass cards
   ========================================================================== */

/* Honeypot — anti-spam decoy field; never shown to humans or screen readers */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;opacity:0;pointer-events:none;}

/* Privacy / legal page + the form's privacy link */
.section-legal{padding-top:5rem;}
.legal-body{max-width:760px;margin:1.5rem auto 0;line-height:1.7;}
.legal-body h2{margin:1.8rem 0 .6rem;font-size:1.05rem;color:var(--text);}
.legal-body p,.legal-body li{color:#aeb6c6;}
.legal-body ul{margin:.4rem 0 .6rem 1.2rem;}
.legal-body li{margin:.3rem 0;}
.legal-body a{color:#19c6dd;text-decoration:underline;}
.form-privacy{margin:.4rem 0 0;font-size:.8rem;}
.form-privacy a{color:#19c6dd;}

:root{
  --bg-0:#050a18;
  --bg-1:#0a1226;
  --bg-2:#0f1d3d;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --text:#e6ecf5;
  --muted:#8a98ad;
  --dim:#5d6a82;
  --cy:#19c6dd;
  --vi:#1f4fb0;
  --warn:#ffb347;
  --bad:#ff5c7a;
  --ok:#3dffb0;
  --grad:linear-gradient(135deg,#19c6dd 0%,#16224d 100%);
  --grad-soft:linear-gradient(135deg,rgba(25,198,221,.15),rgba(31,79,176,.15));
  --glow-cy:0 0 24px rgba(25,198,221,.35);
  --glow-vi:0 0 24px rgba(31,79,176,.35);
  --radius:14px;
  --shadow-card:0 24px 60px -20px rgba(0,0,0,.55), 0 0 0 1px var(--line);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Space Grotesk",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:radial-gradient(1200px 800px at 80% -20%,rgba(31,79,176,.18),transparent 60%),
             radial-gradient(900px 700px at -10% 10%,rgba(25,198,221,.10),transparent 55%),
             var(--bg-0);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  line-height:1.55;
}

a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font:inherit}

/* Matrix canvas */
#matrix{
  position:fixed; inset:0; z-index:-2;
  opacity:.22;
  pointer-events:none;
  filter:blur(.3px);
}

/* ==========================================================================
   IMAGE LAYERS (decorative SVGs in /images)
   Note: every SVG ships with its own dark navy backdrop that already
   matches the page bg, so we DON'T blend or strip — we just dim + vignette
   so foreground content stays readable.
   ========================================================================== */
.hero-art,
.hero-art-rtl{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  z-index:-1; pointer-events:none;
  opacity:.85;
  mask-image:radial-gradient(ellipse 95% 90% at center,#000 60%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 95% 90% at center,#000 60%,transparent 100%);
}
.hero-art-rtl{display:none}
html[dir="rtl"] .hero-art{display:none}
html[dir="rtl"] .hero-art-rtl{display:block}

.section-art{
  position:absolute; top:0; bottom:0;
  /* Break out of the 1280px section container — span the full viewport so the bg
     doesn't look like a centred floating box. */
  left:50%; width:100vw; transform:translateX(-50%);
  height:100%;
  object-fit:cover; object-position:center;
  pointer-events:none; z-index:0;
  opacity:.45;
  /* Soft mask: fade in from top, fade out at sides + bottom so the SVG never
     terminates with a hard rectangular edge. */
  mask-image:
    radial-gradient(ellipse 80% 70% at center, #000 25%, transparent 95%),
    linear-gradient(180deg, transparent 0%, #000 12%, #000 78%, transparent 100%);
  -webkit-mask-image:
    radial-gradient(ellipse 80% 70% at center, #000 25%, transparent 95%),
    linear-gradient(180deg, transparent 0%, #000 12%, #000 78%, transparent 100%);
  mask-composite:intersect; -webkit-mask-composite:source-in;
}
/* per-section tuning: brighter where the art is the main point, dimmer where cards overlay */
.section-art-market { opacity:.32 }
.section-art-threats{ opacity:.28 }
.section-art-trends { opacity:.42 }
.section-art-product{ opacity:.32 }

.section{position:relative; z-index:1; overflow:hidden}
.section > *:not(.section-art){position:relative; z-index:2}

/* foreground banner (model icons sits above its 6 cards as a visual lede) */
.section-banner{
  display:block;
  width:100%; max-width:1100px;
  margin:0 auto 40px;
  height:auto;
  opacity:1;
  border-radius:14px;
  box-shadow:0 30px 80px -30px rgba(25,198,221,.18), 0 0 0 1px var(--line);
}

/* Utopick IT core image replaces CSS orb */
.ntpy-core{
  width:100%; max-width:420px;
  height:auto;
  filter:drop-shadow(0 0 60px rgba(25,198,221,.35))
         drop-shadow(0 0 120px rgba(31,79,176,.25));
  animation:floaty 8s ease-in-out infinite;
  /* fade the SVG's own rectangular dark backdrop into transparency */
  mask-image:radial-gradient(circle at center, #000 38%, transparent 72%);
  -webkit-mask-image:radial-gradient(circle at center, #000 38%, transparent 72%);
}
.orb-halo{
  position:absolute; inset:0;
  background:radial-gradient(circle at center,rgba(25,198,221,.18),transparent 60%);
  filter:blur(20px);
  pointer-events:none;
  z-index:-1;
}
@keyframes floaty{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}

/* ==========================================================================
   NAV
   ========================================================================== */
.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:24px;
  padding:14px 32px;
  background:linear-gradient(180deg,rgba(5,7,13,.78),rgba(5,7,13,.35) 70%,transparent);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-family:"JetBrains Mono",monospace;
  letter-spacing:.08em;
  font-weight:700;
}
.brand-mark{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:10px;background:var(--grad-soft);box-shadow:var(--glow-cy)}
.brand-name{font-size:14px}
.brand-dot{color:var(--cy); margin:0 6px}
.brand-sub{color:var(--muted); font-weight:500}

.nav-links{margin-left:auto; display:flex; gap:22px}
.nav-links a{
  font-size:13px; color:var(--muted);
  position:relative; padding:6px 2px;
  transition:color .2s;
}
.nav-links a:hover{color:var(--text)}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--grad); transition:width .25s ease;
}
.nav-links a:hover::after{width:100%}
/* active section — driven by IntersectionObserver in script.js */
.nav-links a.is-active{ color:var(--text) }
.nav-links a.is-active::after{ width:100%; box-shadow:0 0 8px rgba(25,198,221,.5) }
html[dir="rtl"] .nav-links a.is-active::after{ left:auto; right:0 }

/* Scroll progress bar (top of viewport, above the nav) */
.scroll-progress{
  position:fixed; top:0; left:0; right:0;
  height:2px;
  z-index:60;
  background:rgba(255,255,255,.04);
  pointer-events:none;
}
.scroll-progress > span{
  display:block; height:100%; width:100%;
  background:var(--grad);
  box-shadow:0 0 12px rgba(25,198,221,.45);
  transform:scaleX(0); transform-origin:left center;
  will-change:transform;
}
html[dir="rtl"] .scroll-progress > span{ transform-origin:right center }
@media (prefers-reduced-motion: no-preference){
  .scroll-progress > span{ transition:transform .12s linear }
}

.cta-pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px; border-radius:999px;
  font-size:12px; font-weight:600;
  background:rgba(25,198,221,.08);
  border:1px solid rgba(25,198,221,.25);
  color:var(--cy);
  transition:transform .2s, box-shadow .2s;
}
.cta-pill:hover{transform:translateY(-1px); box-shadow:var(--glow-cy)}
.dot-live{
  display:inline-block; width:8px; height:8px; border-radius:50%;
  background:var(--cy); box-shadow:0 0 12px var(--cy);
  animation:pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{transform:scale(1); opacity:1}
  50%{transform:scale(1.4); opacity:.55}
}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position:relative; min-height:calc(100vh - 60px);
  padding:80px 32px 60px;
  overflow:hidden;
}
/* Soft fade at the bottom of the hero so it blends into the next section.
   z-index:0 sits below content (default z-index:auto/0 with DOM order)
   but above the hero-art (z-index:-1) and hero-grid (z-index:-1). */
.hero::after{
  content:'';
  position:absolute; left:0; right:0; bottom:0;
  height:320px;
  background:linear-gradient(
    180deg,
    transparent 0%,
    rgba(5,7,13,.25) 25%,
    rgba(5,7,13,.7) 60%,
    var(--bg-0) 100%
  );
  pointer-events:none; z-index:0;
}
/* Ensure hero CONTENT stays above the fade — the stats row, CTAs, hub-surface */
.hero-inner{ position:relative; z-index:2 }
.hero .scroll-cue{ z-index:3 }
.hero-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(25,198,221,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(25,198,221,.06) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at center,#000 35%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at center,#000 35%,transparent 80%);
  pointer-events:none;
  z-index:-1;
}
/* Animated connected-dots network in the hero (sits above hero-art, below content) */
.hero-net{
  position:absolute; inset:0;
  width:100%; height:100%;
  z-index:-1; pointer-events:none;
  opacity:.9;
  mask-image:radial-gradient(ellipse 96% 92% at center,#000 55%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 96% 92% at center,#000 55%,transparent 100%);
}
html.a11y-motion-off .hero-net{ display:none }
.hero-inner{
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:1.15fr .85fr; gap:64px;
  align-items:center;
}
.hero-copy h1{
  font-size:clamp(36px,5.4vw,68px);
  line-height:1.04;
  letter-spacing:-.02em;
  margin:18px 0 22px;
}
.grad{background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}
.lede{font-size:18px; color:var(--muted); max-width:600px}
.lede strong{color:var(--text)}

.kicker{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:6px}
.kbox{
  font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:.08em;
  padding:6px 10px; border-radius:999px;
  border:1px solid var(--line-2);
  background:rgba(255,255,255,.03);
  color:var(--muted);
}
.kbox strong{color:var(--text); font-weight:600}
.kbox-live{display:inline-flex; align-items:center; gap:8px; color:var(--cy); border-color:rgba(25,198,221,.3)}

.hero-cta{display:flex; gap:14px; margin:30px 0 36px; flex-wrap:wrap}
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 22px; border-radius:12px;
  font-weight:600; font-size:14px;
  border:1px solid transparent;
  transition:transform .15s, box-shadow .2s, background .2s, border-color .2s;
  cursor:pointer;
}
.btn-primary{
  background:var(--grad); color:#06090f;
  box-shadow:0 10px 30px -10px rgba(25,198,221,.5), 0 0 0 1px rgba(255,255,255,.08) inset;
}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 16px 40px -10px rgba(25,198,221,.65)}
.btn-ghost{
  background:rgba(255,255,255,.03);
  border-color:var(--line-2);
  color:var(--text);
}
.btn-ghost:hover{border-color:var(--cy); color:var(--cy); box-shadow:var(--glow-cy)}
.btn-lg{padding:16px 26px; font-size:15px}

.hero-stats{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
  max-width:640px;
}
.hero-stats li{
  padding:16px 18px; border-radius:12px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid var(--line);
}
.stat-num{
  display:block; font-family:"JetBrains Mono",monospace;
  font-size:28px; font-weight:700;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;
  letter-spacing:-.02em;
}
.stat-label{font-size:12px; color:var(--muted)}

/* HUD card */
.hud{
  background:linear-gradient(180deg,rgba(14,20,36,.85),rgba(10,14,26,.85));
  border:1px solid var(--line-2);
  border-radius:18px;
  padding:18px;
  box-shadow:var(--shadow-card), inset 0 1px 0 rgba(255,255,255,.04);
  font-family:"JetBrains Mono",monospace;
  position:relative;
  overflow:hidden;
}
.hud::before{
  content:""; position:absolute; inset:-1px; border-radius:18px;
  background:linear-gradient(135deg,rgba(25,198,221,.35),transparent 40%,transparent 60%,rgba(31,79,176,.35));
  -webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
  -webkit-mask-composite:xor; mask-composite:exclude;
  padding:1px; pointer-events:none;
}
.hud-head{display:flex; justify-content:space-between; align-items:center; padding-bottom:12px; border-bottom:1px dashed var(--line)}
.hud-title{display:flex; align-items:center; gap:8px; font-size:12px; letter-spacing:.1em; color:var(--cy)}
.hud-dot{width:8px;height:8px;border-radius:50%;background:var(--cy);box-shadow:0 0 12px var(--cy)}
.hud-meta{font-size:10px; color:var(--dim); text-transform:uppercase; letter-spacing:.15em}
.hud-body{padding-top:14px; display:grid; gap:10px}
.hud-row{display:flex; justify-content:space-between; align-items:baseline; font-size:13px}
.hud-label{color:var(--muted)}
.hud-val{color:var(--text); font-weight:700}
.hud-spark{margin:6px 0 4px; height:60px; border-radius:8px; background:rgba(0,0,0,.3); border:1px solid var(--line); padding:6px; overflow:hidden; position:relative}
.hud-spark svg{width:100%;height:100%; display:block}
.hud-spark::before{
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(0deg,rgba(25,198,221,.06) 1px,transparent 1px);
  background-size:100% 12px;
  pointer-events:none; opacity:.5;
}
#sparkDot{
  filter:drop-shadow(0 0 5px #19c6dd);
  animation:sparkDotPulse 1.4s ease-in-out infinite;
}
@keyframes sparkDotPulse{
  0%,100%{ opacity:1; r:2.5 }
  50%    { opacity:.55; r:3.8 }
}
.hud-log{list-style:none; padding:0; margin:0; display:grid; gap:6px; font-size:11.5px}
.hud-log li{display:flex; gap:8px; padding:6px 8px; background:rgba(0,0,0,.25); border-radius:6px; border-left:2px solid var(--line); color:var(--muted)}
.hud-log .t{color:var(--dim)}
.hud-log .ok{color:var(--ok); font-weight:700}
.hud-log .warn{color:var(--warn); font-weight:700}
.hud-log .bad{color:var(--bad); font-weight:700}

.scroll-cue{
  position:absolute; left:50%; bottom:24px; transform:translateX(-50%);
  width:24px; height:38px; border:1px solid var(--line-2); border-radius:14px;
  display:grid; place-items:center;
}
.scroll-cue span{
  display:block; width:3px; height:8px; border-radius:2px; background:var(--cy);
  animation:cue 1.6s ease-in-out infinite;
}
@keyframes cue{
  0%{transform:translateY(-6px); opacity:0}
  40%{opacity:1}
  100%{transform:translateY(8px); opacity:0}
}

/* ==========================================================================
   SECTIONS
   ========================================================================== */
.section{
  padding:110px 32px;
  max-width:1280px; margin:0 auto;
  position:relative;
}
.section-head{max-width:880px; margin:0 auto 56px; text-align:center}
.section-head-he{text-align:right}
.eyebrow{
  display:inline-block; font-family:"JetBrains Mono",monospace;
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--cy); margin-bottom:14px;
  padding:6px 12px; border-radius:999px;
  background:rgba(25,198,221,.06); border:1px solid rgba(25,198,221,.2);
}
.section h2{
  font-size:clamp(28px,3.6vw,46px);
  line-height:1.1; letter-spacing:-.02em;
  margin:0 0 16px;
}
.section h2 em{font-style:normal; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}
.sub{color:var(--muted); font-size:17px; max-width:760px; margin:0 auto}
.section-head-he .sub{margin:0 0 0 auto}

/* MARKET */
.cards-3{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.card{
  position:relative; padding:30px;
  background:linear-gradient(180deg,rgba(14,20,36,.6),rgba(10,14,26,.6));
  border:1px solid var(--line); border-radius:var(--radius);
  transition:transform .25s, border-color .25s, box-shadow .25s;
  overflow:hidden;
}
.card::after{
  content:""; position:absolute; inset:0; border-radius:var(--radius);
  background:radial-gradient(600px 200px at var(--mx,50%) var(--my,0%),rgba(25,198,221,.12),transparent 60%);
  opacity:0; transition:opacity .25s; pointer-events:none;
}
.card.glow:hover{transform:translateY(-4px); border-color:rgba(25,198,221,.35); box-shadow:var(--shadow-card), var(--glow-cy)}
.card.glow:hover::after{opacity:1}
.card h3{margin:0 0 18px; font-size:15px; color:var(--muted); text-transform:uppercase; letter-spacing:.1em; font-weight:500}
.card .big{
  font-family:"JetBrains Mono",monospace;
  font-size:48px; font-weight:700;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;
  letter-spacing:-.03em; margin-bottom:12px;
}
.card p{margin:0; color:var(--muted); font-size:14.5px}

.market-strip{
  margin-top:36px; display:grid; grid-template-columns:1fr 1fr; gap:24px;
  padding:30px;
  border:1px dashed var(--line-2); border-radius:var(--radius);
  background:rgba(255,255,255,.015);
}
.market-strip h4{margin:0 0 8px; font-size:15px; color:var(--cy); letter-spacing:.05em}
.market-strip p{margin:0; color:var(--muted); font-size:14.5px}

/* THREATS */
.threat-grid{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
}
.threat-grid li{
  position:relative;
  padding:22px;
  border:1px solid var(--line); border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(14,20,36,.55),rgba(10,14,26,.55));
  transition:transform .25s, border-color .25s, background .25s;
  overflow:hidden;
}
.threat-grid li::before{
  content:""; position:absolute; left:0; top:0; right:0; height:2px;
  background:var(--grad); transform:scaleX(0); transform-origin:left;
  transition:transform .35s;
}
.threat-grid li:hover{transform:translateY(-3px); border-color:var(--line-2); background:rgba(14,20,36,.85)}
.threat-grid li:hover::before{transform:scaleX(1)}
.threat-grid .ti{
  display:inline-grid; place-items:center;
  width:38px; height:38px; border-radius:10px;
  background:rgba(25,198,221,.08); border:1px solid rgba(25,198,221,.25);
  color:var(--cy); font-family:"JetBrains Mono",monospace; font-weight:700;
  margin-bottom:12px; font-size:13px;
}
.threat-grid h3{margin:0 0 4px; font-size:16px}
.threat-grid p{margin:0; color:var(--muted); font-size:13.5px}

/* Utopick IT */
.split{
  display:grid; grid-template-columns:1.2fr .8fr; gap:60px; align-items:center;
}
.lede-2{font-size:18px; color:var(--muted)}
.lede-2 strong{color:var(--text)}
.check-list{list-style:none; padding:0; margin:24px 0; display:grid; gap:10px}
.check-list li{
  position:relative; padding:10px 14px 10px 38px;
  border:1px solid var(--line); border-radius:10px;
  background:rgba(255,255,255,.02);
  font-size:14.5px;
}
.check-list li::before{
  content:""; position:absolute; left:12px; top:50%; width:14px; height:14px;
  margin-top:-7px; border-radius:50%;
  background:var(--grad);
  box-shadow:0 0 12px rgba(25,198,221,.5);
}
.quote{
  border-left:2px solid var(--cy);
  padding:14px 18px; margin:0;
  background:rgba(25,198,221,.04);
  border-radius:0 10px 10px 0;
  color:var(--text); font-size:15.5px;
}
.quote em{color:var(--cy); font-style:normal}

.orb-wrap{position:relative; display:grid; place-items:center; min-height:380px}
.orb{
  position:relative; width:300px; height:300px;
  display:grid; place-items:center;
}
.orb .ring{
  position:absolute; inset:0; border-radius:50%;
  border:1px solid rgba(31,79,176,.35);
  animation:spin 18s linear infinite;
}
.orb .r1{inset:0}
.orb .r2{inset:30px; border-color:rgba(25,198,221,.35); animation-duration:22s; animation-direction:reverse}
.orb .r3{inset:60px; border-style:dashed; border-color:rgba(255,255,255,.18); animation-duration:30s}
.orb .core{
  width:120px; height:120px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(25,198,221,.4),rgba(31,79,176,.4) 60%,transparent 75%);
  display:grid; place-items:center;
  box-shadow:0 0 60px rgba(25,198,221,.4), 0 0 120px rgba(31,79,176,.3);
}
@keyframes spin{to{transform:rotate(360deg)}}

/* MODEL */
.model-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
.mcard{
  position:relative; padding:26px;
  border:1px solid var(--line); border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(14,20,36,.55),rgba(10,14,26,.55));
  transition:transform .25s, border-color .25s, box-shadow .25s;
}
.mcard:hover{transform:translateY(-4px); border-color:rgba(31,79,176,.35); box-shadow:0 24px 60px -20px rgba(31,79,176,.4)}
.mcard-num{
  font-family:"JetBrains Mono",monospace; font-size:12px;
  color:var(--vi); letter-spacing:.15em; margin-bottom:14px;
}
.mcard h3{margin:0 0 8px; font-size:18px}
.mcard p{margin:0; color:var(--muted); font-size:14px}
.mcard-accent{
  background:linear-gradient(135deg,rgba(25,198,221,.08),rgba(31,79,176,.08));
  border-color:rgba(25,198,221,.3);
}

/* PRODUCT / structure cols */
.part-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.part-col{
  padding:26px;
  border:1px solid var(--line); border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(14,20,36,.55),rgba(10,14,26,.55));
}
.part-col h3{margin:0 0 14px; font-size:16px; color:var(--cy); letter-spacing:.05em; text-transform:uppercase}
.part-col ul{list-style:none; padding:0; margin:0; display:grid; gap:10px}
.part-col li{
  padding:10px 12px 10px 28px; position:relative;
  background:rgba(255,255,255,.02); border-radius:8px;
  font-size:14px; color:var(--muted);
}
.part-col li::before{
  content:"›"; position:absolute; left:10px; top:9px;
  color:var(--cy); font-weight:700;
}

/* ARCHITECTURE */
.arch-stack{
  list-style:none; padding:0; margin:0 auto;
  max-width:1080px;
  display:grid; gap:18px;
  position:relative;
}
.arch-stack::before{
  /* the connecting vertical line down the left edge of the layer numbers */
  content:""; position:absolute;
  left:32px; top:24px; bottom:24px;
  width:2px;
  background:linear-gradient(180deg, rgba(25,198,221,.35), rgba(31,79,176,.35));
  opacity:.35;
  pointer-events:none;
}
.arch-row{
  display:grid; grid-template-columns:72px 1fr; gap:22px;
  align-items:flex-start;
  padding:22px 24px;
  border:1px solid var(--line); border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(14,20,36,.55),rgba(10,14,26,.55));
  position:relative;
  transition:transform .25s, border-color .25s, box-shadow .25s;
}
.arch-row:hover{transform:translateY(-3px); border-color:rgba(25,198,221,.3); box-shadow:0 24px 60px -20px rgba(25,198,221,.18)}
.arch-num{
  width:62px; height:62px; border-radius:14px;
  display:grid; place-items:center;
  background:rgba(25,198,221,.08);
  border:1px solid rgba(25,198,221,.3);
  color:var(--cy);
  font-family:"JetBrains Mono",monospace; font-weight:700; font-size:18px;
  letter-spacing:.05em;
  box-shadow:inset 0 0 24px rgba(25,198,221,.08);
  position:relative; z-index:1;
}
.arch-num-accent{
  background:linear-gradient(135deg,rgba(25,198,221,.22),rgba(31,79,176,.22));
  border-color:rgba(31,79,176,.45);
  color:var(--text);
  box-shadow:0 0 24px rgba(31,79,176,.35);
}
.arch-row-accent{
  border-color:rgba(31,79,176,.35);
  background:linear-gradient(135deg,rgba(25,198,221,.05),rgba(31,79,176,.07));
}
.arch-body h3{
  margin:0 0 6px; font-size:18px; letter-spacing:-.01em;
}
.arch-role{
  margin:0 0 12px; color:var(--muted); font-size:14.5px;
}
.arch-role em{
  font-style:normal;
  color:var(--cy); font-weight:600;
}
.arch-points{
  list-style:none; padding:0; margin:0;
  display:grid; gap:6px;
}
.arch-points li{
  position:relative; padding:4px 0 4px 18px;
  color:var(--muted); font-size:13.5px;
}
.arch-points li::before{
  content:"›"; position:absolute; left:0; top:3px;
  color:var(--cy); font-weight:700;
}

/* attack-flow strip */
.arch-flow{
  margin:50px auto 0; max-width:1080px;
  padding:24px;
  border:1px dashed var(--line-2); border-radius:var(--radius);
  background:rgba(255,255,255,.015);
}
.arch-flow-title{
  font-family:"JetBrains Mono",monospace; font-size:12px;
  color:var(--cy); letter-spacing:.12em; text-transform:uppercase;
  margin-bottom:14px;
}
.flow-strip{
  list-style:none; padding:0; margin:0;
  display:flex; gap:8px; flex-wrap:wrap;
  align-items:stretch;
}
.flow-strip li{
  flex:1 1 0;
  min-width:120px;
  display:flex; align-items:center; gap:8px;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(0,0,0,.25);
  font-size:13px;
  color:var(--text);
  position:relative;
  transition:border-color .25s, transform .25s;
}
.flow-strip li:hover{border-color:rgba(25,198,221,.45); transform:translateY(-2px)}
.flow-strip li:not(:last-child)::after{
  content:"›";
  position:absolute; right:-10px; top:50%; transform:translateY(-50%);
  color:var(--cy); font-weight:700; font-size:16px; line-height:1;
  z-index:2;
}
.flow-strip .flow-i{
  font-family:"JetBrains Mono",monospace; font-size:11px;
  color:var(--vi); letter-spacing:.12em;
  flex:0 0 auto;
}
.flow-strip .flow-out{
  background:linear-gradient(135deg,rgba(25,198,221,.1),rgba(31,79,176,.1));
  border-color:rgba(25,198,221,.4);
  color:var(--cy); font-weight:600;
}

/* RTL handling for arch */
html[dir="rtl"] .arch-stack::before{left:auto; right:32px}
html[dir="rtl"] .arch-row{grid-template-columns:1fr 72px}
html[dir="rtl"] .arch-row .arch-num{order:2}
html[dir="rtl"] .arch-row .arch-body{order:1; text-align:right}
html[dir="rtl"] .arch-points li{padding:4px 18px 4px 0}
html[dir="rtl"] .arch-points li::before{left:auto; right:0; content:"‹"}
html[dir="rtl"] .flow-strip li:not(:last-child)::after{
  right:auto; left:-10px; content:"‹";
}

/* TRENDS */
.trend-list{
  display:grid; grid-template-columns:repeat(5,1fr); gap:14px;
}
.trend{
  padding:24px 20px; border-radius:var(--radius);
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(14,20,36,.55),rgba(10,14,26,.55));
  transition:transform .25s, border-color .25s;
  position:relative; overflow:hidden;
}
.trend:hover{transform:translateY(-3px); border-color:var(--line-2)}
.trend span{
  font-family:"JetBrains Mono",monospace; font-size:11px;
  color:var(--vi); letter-spacing:.15em;
}
.trend h3{margin:8px 0 6px; font-size:15px}
.trend p{margin:0; color:var(--muted); font-size:13px}

/* INVEST */
.engage-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
}
.engage-card{
  padding:34px;
  border:1px solid var(--line-2); border-radius:18px;
  background:linear-gradient(180deg,rgba(14,20,36,.7),rgba(10,14,26,.7));
  box-shadow:var(--shadow-card);
}
.engage-card h3{margin:0 0 18px; font-size:20px}
.terms{margin:0; display:grid; gap:0}
.terms > div{
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
  padding:14px 0; border-bottom:1px dashed var(--line);
  align-items:center;
}
.terms > div:last-child{border-bottom:0}
.terms dt{color:var(--muted); font-size:13.5px}
.terms dd{margin:0; color:var(--text); font-size:14.5px; text-align:right}
.terms .muted{color:var(--dim)}
.badge-live{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 10px; border-radius:999px;
  background:rgba(25,198,221,.08); border:1px solid rgba(25,198,221,.3);
  color:var(--cy); font-size:12px; font-weight:600;
}

/* form */
.engage-form{display:grid; gap:14px}
.engage-form label{
  display:grid; gap:6px;
  font-size:12.5px; color:var(--muted); letter-spacing:.04em;
}
.engage-form input,.engage-form select,.engage-form textarea{
  background:rgba(0,0,0,.25);
  border:1px solid var(--line-2);
  color:var(--text);
  padding:12px 14px;
  border-radius:10px;
  font:inherit; font-size:14px;
  transition:border-color .2s, box-shadow .2s;
}
.engage-form input:focus,.engage-form select:focus,.engage-form textarea:focus{
  outline:none; border-color:var(--cy); box-shadow:0 0 0 3px rgba(25,198,221,.15);
}
.engage-form .check{
  display:flex; align-items:flex-start; gap:10px; flex-direction:row;
  font-size:12.5px; color:var(--muted);
}
.engage-form .check input{accent-color:var(--cy); width:16px; height:16px; margin-top:2px}
.engage-form button{justify-self:start}
.form-status{font-size:13px; color:var(--ok); min-height:18px}

.disclaimer{
  max-width:1000px; margin:40px auto 0;
  font-size:12.5px; color:var(--dim); line-height:1.7;
  padding:18px 22px;
  border:1px dashed var(--line); border-radius:10px;
  background:rgba(255,255,255,.015);
}
.disclaimer strong{color:var(--muted)}

/* FAQ */
.faq{max-width:880px; margin:0 auto; display:grid; gap:10px}
.faq details{
  border:1px solid var(--line); border-radius:12px;
  background:linear-gradient(180deg,rgba(14,20,36,.5),rgba(10,14,26,.5));
  overflow:hidden;
}
.faq summary{
  list-style:none; cursor:pointer;
  padding:18px 22px;
  font-weight:600; font-size:15px;
  display:flex; justify-content:space-between; align-items:center;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+"; color:var(--cy); font-size:22px; line-height:1;
  transition:transform .25s;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{
  margin:0; padding:0 22px 20px; color:var(--muted); font-size:14.5px;
}

/* ==========================================================================
   LANGUAGE SWITCHER
   ========================================================================== */
.lang-switch{
  display:inline-flex; align-items:center;
  padding:3px; gap:2px;
  border:1px solid var(--line-2);
  border-radius:999px;
  background:rgba(255,255,255,.03);
}
.lang-switch button{
  background:transparent; color:var(--muted);
  border:0; padding:6px 12px;
  border-radius:999px;
  cursor:pointer;
  font-size:12px; font-weight:600;
  letter-spacing:.08em;
  transition:color .2s, background .2s, box-shadow .2s;
  font-family:"JetBrains Mono",monospace;
}
.lang-switch button:hover{color:var(--text)}
.lang-switch button.is-active{
  background:var(--grad);
  color:#06090f;
  box-shadow:0 4px 14px -4px rgba(25,198,221,.45);
}
.lang-switch button[data-lang="he"]{font-family:"Heebo",sans-serif}

/* ==========================================================================
   HEBREW (RTL) — applied when body.lang-he or html[dir="rtl"]
   ========================================================================== */
html[dir="rtl"] body,
body.lang-he{
  font-family:"Heebo","Space Grotesk",system-ui,sans-serif;
}
html[dir="rtl"] .brand-name,
body.lang-he .brand-name{font-family:"JetBrains Mono",monospace} /* keep brand mono */

/* nav alignment flips */
html[dir="rtl"] .nav-links{margin-left:0; margin-right:auto}
html[dir="rtl"] .nav-links a::after{left:auto; right:0}

/* hero copy text-align follows dir */
html[dir="rtl"] .hero-stats{text-align:right}
html[dir="rtl"] .hero-cta{justify-content:flex-start}

/* arrow icons inside buttons — flip horizontally so they point with the text */
html[dir="rtl"] .btn .arrow{transform:scaleX(-1)}

/* check-list bullet flips side */
html[dir="rtl"] .check-list li{padding:10px 38px 10px 14px}
html[dir="rtl"] .check-list li::before{left:auto; right:12px}

/* part-col arrow flips direction */
html[dir="rtl"] .part-col li{padding:10px 28px 10px 12px}
html[dir="rtl"] .part-col li::before{left:auto; right:10px; content:"‹"}

/* terms rows */
html[dir="rtl"] .terms dd{text-align:left}
html[dir="rtl"] .terms dt{text-align:right}

/* quote bar flips side */
html[dir="rtl"] .quote{
  border-left:0; border-right:2px solid var(--cy);
  border-radius:10px 0 0 10px;
}

/* faq summary "+" stays on the right side in RTL */
html[dir="rtl"] .faq summary{flex-direction:row-reverse}

/* market strip / model / part grids — no special handling needed beyond text dir */

/* disclaimers — stay aligned to start (natural with dir=rtl) */
html[dir="rtl"] .disclaimer{text-align:right}

/* hero h1 line-break — let it breathe */
html[dir="rtl"] .hero-copy h1{letter-spacing:0}
html[dir="rtl"] .section h2{letter-spacing:0}

/* FOOTER */
.foot{
  border-top:1px solid var(--line);
  padding:36px 32px 26px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.4));
}
.foot-row{
  max-width:1280px; margin:0 auto;
  display:flex; justify-content:space-between; align-items:center;
  gap:24px; flex-wrap:wrap;
  padding-bottom:18px; border-bottom:1px solid var(--line);
}
.foot-row nav{display:flex; gap:22px}
.foot-row nav a{font-size:13px; color:var(--muted); transition:color .2s}
.foot-row nav a:hover{color:var(--cy)}
.foot-fine{
  max-width:1280px; margin:18px auto 0;
  font-size:11.5px; color:var(--dim); letter-spacing:.02em;
}

/* ==========================================================================
   REVEAL animations
   ========================================================================== */
.reveal{opacity:0; transform:translateY(20px); transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1; transform:none}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1080px){
  .hero-inner{grid-template-columns:1fr; gap:40px}
  .hud{max-width:520px; margin:0 auto}
  .threat-grid{grid-template-columns:repeat(2,1fr)}
  .cards-3,.model-grid,.part-grid{grid-template-columns:1fr 1fr}
  .trend-list{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr; gap:40px}
  .he-split{grid-template-columns:1fr}
  .market-strip{grid-template-columns:1fr}
  .engage-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .nav{padding:12px 16px; gap:12px}
  .nav-links{display:none}
  .hero{padding:48px 18px 40px; min-height:auto}
  .section{padding:72px 18px}
  .hero-stats{grid-template-columns:1fr; max-width:none}
  .cards-3,.model-grid,.part-grid{grid-template-columns:1fr}
  .threat-grid{grid-template-columns:1fr 1fr}
  .trend-list{grid-template-columns:1fr}
  .engage-card{padding:24px}
  .terms > div{grid-template-columns:1fr; gap:4px}
  .terms dd{text-align:left}
  .hero-copy h1{font-size:34px}
  .section h2{font-size:26px}
  .arch-stack::before{display:none}
  .arch-row{grid-template-columns:56px 1fr; gap:14px; padding:18px}
  .arch-num{width:50px; height:50px; font-size:15px}
  .flow-strip li{flex:1 1 100%; min-width:0}
  .flow-strip li:not(:last-child)::after{display:none}
  html[dir="rtl"] .arch-row{grid-template-columns:1fr 56px}
}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important}
  .reveal{opacity:1; transform:none}
}

/* ==========================================================================
   MULTI-VERTICAL (hub + cross-link infrastructure)
   ========================================================================== */

/* 4-card grid (hub aggregate market) */
.cards-4{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
  max-width:var(--max); margin:32px auto 0; padding:0 24px;
}
@media (max-width:980px){ .cards-4{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:560px){ .cards-4{ grid-template-columns:1fr } }

/* ----- Cross-link strip (below hero on vertical pages) ----- */
.cross-link-strip{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:center;
  gap:14px 18px;
  max-width:var(--max); margin:0 auto;
  padding:14px 24px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,rgba(10,14,26,.45),rgba(10,14,26,.15));
  font-size:13px;
  position:relative; z-index:2;
  text-align:center;
}
.cross-link-strip .cls-label{
  font-family:'JetBrains Mono',monospace;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); padding-right:6px;
}
html[dir="rtl"] .cross-link-strip .cls-label{ padding-right:0; padding-left:6px }
.cross-link-strip .cls-item{
  color:var(--text); text-decoration:none;
  padding:6px 10px; border-radius:8px;
  border:1px solid transparent;
  transition:border-color .2s, background .2s, color .2s;
}
.cross-link-strip a.cls-item:hover{
  border-color:var(--line);
  background:rgba(25,198,221,.04);
}
.cross-link-strip .cls-item.is-active{
  border-color:rgba(25,198,221,.45);
  background:linear-gradient(180deg,rgba(25,198,221,.10),rgba(31,79,176,.10));
  color:#dffefb;
  font-weight:600;
}
.cross-link-strip .cls-item.is-stub{
  color:var(--muted); opacity:.6; cursor:default;
}

/* ----- Hub surface card (right side of hub hero, replaces SOC HUD) ----- */
.hub-surface{
  position:relative; padding:22px 24px;
  background:linear-gradient(180deg,rgba(14,20,36,.78),rgba(10,14,26,.78));
  border:1px solid var(--line); border-radius:var(--radius);
  font-family:'JetBrains Mono',monospace;
  min-width:0;
}
.hub-surface-head{
  display:flex; align-items:center; gap:10px;
  padding-bottom:14px; margin-bottom:14px;
  border-bottom:1px solid var(--line);
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted);
}
.hub-surface-list{
  list-style:none; margin:0; padding:0;
  display:grid; gap:10px;
}
.hub-surface-list li{
  display:grid; grid-template-columns:42px 1fr; align-items:center; gap:12px;
  font-size:12.5px; line-height:1.45; color:var(--text);
}
.hub-surface-list .hsi{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:30px;
  border:1px solid var(--line); border-radius:6px;
  font-size:11px; font-weight:700;
  background:rgba(25,198,221,.05);
  color:#9ff5e3;
}
.hub-surface-list .hsi-accent .hsi{
  background:linear-gradient(180deg,rgba(25,198,221,.18),rgba(31,79,176,.18));
  border-color:rgba(25,198,221,.45);
  color:#dffefb;
}

/* ----- Engine strip (6 compact layer cells on hub) ----- */
.section-engine{ padding-top:88px }
.engine-strip{
  list-style:none; margin:0 auto; padding:0 24px;
  max-width:var(--max);
  display:grid; grid-template-columns:repeat(6,1fr); gap:14px;
}
.engine-cell{
  position:relative; padding:22px 18px 20px;
  background:linear-gradient(180deg,rgba(14,20,36,.6),rgba(10,14,26,.6));
  border:1px solid var(--line); border-radius:var(--radius);
  transition:border-color .25s, transform .25s, box-shadow .25s;
}
.engine-cell:hover{
  transform:translateY(-2px);
  border-color:rgba(25,198,221,.35);
  box-shadow:0 12px 32px rgba(25,198,221,.08);
}
.engine-cell .ec-tag{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:30px; margin-bottom:12px;
  border:1px solid var(--line); border-radius:6px;
  font-family:'JetBrains Mono',monospace; font-size:11px; font-weight:700;
  color:#9ff5e3; background:rgba(25,198,221,.05);
}
.engine-cell h3{
  margin:0 0 6px; font-size:16px;
}
.engine-cell p{
  margin:0; font-size:13px; color:var(--muted); line-height:1.5;
}
.engine-cell-accent{
  border-color:rgba(25,198,221,.45);
  background:linear-gradient(180deg,rgba(25,198,221,.10),rgba(31,79,176,.10));
}
.engine-cell-accent .ec-tag{
  background:linear-gradient(180deg,rgba(25,198,221,.22),rgba(31,79,176,.22));
  border-color:rgba(25,198,221,.55);
  color:#dffefb;
}
@media (max-width:980px){ .engine-strip{ grid-template-columns:repeat(3,1fr) } }
@media (max-width:560px){ .engine-strip{ grid-template-columns:repeat(2,1fr) } }

/* ----- Verticals grid (the doors) ----- */
.section-verticals{ padding-top:88px }
.verticals-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
  max-width:var(--max); margin:32px auto 0; padding:0 24px;
}
@media (max-width:980px){ .verticals-grid{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:560px){ .verticals-grid{ grid-template-columns:1fr } }

.vert-door{
  position:relative; display:block;
  padding:28px 26px 24px;
  background:linear-gradient(180deg,rgba(14,20,36,.65),rgba(10,14,26,.65));
  border:1px solid var(--line); border-radius:var(--radius);
  color:var(--text); text-decoration:none;
  transition:transform .25s, border-color .25s, box-shadow .25s;
  overflow:hidden;
}
.vert-door::before{
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(circle at 80% -10%, rgba(25,198,221,.18), transparent 50%);
  opacity:0; transition:opacity .25s;
  pointer-events:none;
}
.vert-door:hover::before{ opacity:1 }
.vert-door:hover{
  transform:translateY(-3px);
  border-color:rgba(25,198,221,.45);
  box-shadow:0 18px 48px rgba(25,198,221,.10);
}
.vert-head{
  display:flex; align-items:baseline; gap:10px;
  margin-bottom:6px;
}
.vert-tag{
  font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.16em;
  color:var(--muted);
}
.vert-door h3{
  margin:0; font-size:20px; line-height:1.25;
}
.vert-sub{
  margin:0 0 16px; font-size:13px; color:var(--muted);
  font-family:'JetBrains Mono',monospace;
}
.vert-pillars{
  list-style:none; margin:0 0 18px; padding:0;
  display:grid; gap:6px;
}
.vert-pillars li{
  position:relative;
  padding-left:16px;
  font-size:14px; line-height:1.5;
}
.vert-pillars li::before{
  content:''; position:absolute; left:0; top:8px;
  width:6px; height:6px; border-radius:50%;
  background:linear-gradient(135deg,#19c6dd,#1f4fb0);
}
html[dir="rtl"] .vert-pillars li{ padding-left:0; padding-right:16px }
html[dir="rtl"] .vert-pillars li::before{ left:auto; right:0 }
.vert-cta{
  display:inline-flex; align-items:center;
  font-family:'JetBrains Mono',monospace; font-size:12.5px; letter-spacing:.06em;
  color:#9ff5e3;
  padding-top:14px; border-top:1px solid var(--line);
  width:100%;
}

/* per-vertical hue accents on the doors (subtle border tint on hover) */
.vert-cyber:hover  { border-color:rgba(25,198,221,.55) }
.vert-fintech:hover{ border-color:rgba(31,79,176,.55) }
.vert-ecom:hover   { border-color:rgba(255,184,107,.55) }
.vert-public:hover { border-color:rgba(110,170,255,.55) }
.vert-health:hover { border-color:rgba(255,120,170,.55) }
.vert-saas:hover   { border-color:rgba(170,255,120,.55) }

.vert-stub{
  opacity:.45; pointer-events:none;
  background:linear-gradient(180deg,rgba(14,20,36,.35),rgba(10,14,26,.35));
}
.vert-stub h3{ color:var(--muted) }

/* ----- Why-one-platform grid (3 cards) ----- */
.section-why{ padding-top:88px }
.why-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
  max-width:var(--max); margin:32px auto 0; padding:0 24px;
}
.why-grid .card{ padding:26px }
.why-grid .card h3{ margin:0 0 10px; font-size:18px }
.why-grid .card p{ font-size:14px; line-height:1.6; color:var(--muted); margin:0 }
@media (max-width:980px){ .why-grid{ grid-template-columns:1fr } }

/* ----- Hub commercial model: 4 columns instead of cyber's 3×2 ----- */
.model-grid-hub{
  grid-template-columns:repeat(4,1fr) !important;
}
@media (max-width:980px){ .model-grid-hub{ grid-template-columns:repeat(2,1fr) !important } }
@media (max-width:560px){ .model-grid-hub{ grid-template-columns:1fr !important } }

/* ----- Footer verticals strip ----- */
.foot-verticals{
  display:flex; gap:14px; flex-wrap:wrap;
  font-size:13px;
  border-top:1px solid var(--line);
  padding-top:14px; margin-top:14px;
  width:100%;
}
.foot-verticals a{
  color:var(--muted); text-decoration:none;
  transition:color .2s;
}
.foot-verticals a:hover{ color:#dffefb }

/* ----- Hub hero: tighten when no HUD log present ----- */
.hero-hub .hub-surface{ align-self:start }

/* ----- Utopick IT: language switcher (EN/HE) re-enabled after services-voice Hebrew pass ----- */

/* ----- Cookie consent banner ----- */
.cookie-banner{
  position:fixed; left:16px; right:16px; bottom:16px;
  max-width:560px; margin-left:auto; margin-right:auto;
  background:rgba(14,20,36,.97); border:1px solid var(--line-2);
  border-radius:12px; padding:1rem 1.2rem; z-index:999;
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  display:flex; flex-direction:column; gap:.7rem;
  font-family:'Space Grotesk',system-ui,sans-serif;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
}
.cookie-banner[hidden]{ display:none }
.cookie-banner p{ margin:0; font-size:.88rem; color:var(--text); line-height:1.5 }
.cookie-banner a{ color:#19c6dd; text-decoration:underline }
.cookie-buttons{ display:flex; gap:.6rem; justify-content:flex-end }
.cookie-buttons .btn-sm{ padding:.45rem 1rem; font-size:.85rem; min-width:84px }
[dir="rtl"] .cookie-buttons{ justify-content:flex-start }

/* ===== A11y / WCAG: skip-link + universal keyboard focus rings ===== */
.skip-link{
  position:absolute; top:-40px; left:8px; z-index:9999;
  background:#19c6dd; color:#05070d; padding:.6rem 1rem;
  font-weight:600; text-decoration:none; border-radius:6px;
  font-family:'Space Grotesk',system-ui,sans-serif;
}
.skip-link:focus{ top:8px }
:focus-visible{
  outline:2px solid #19c6dd; outline-offset:2px;
  border-radius:4px;
}
a:focus-visible, button:focus-visible{ outline-offset:3px }
.cta-pill:focus-visible, .btn:focus-visible{ outline-offset:4px }
details > summary:focus-visible{ outline-offset:4px }
.lang-switch button:focus-visible{ outline-offset:0 }
/* Don't show focus ring on mouse interaction */
:focus:not(:focus-visible){ outline:none }

/* ===== A11y widget (bottom-left floating control) ===== */
.a11y-widget{
  position:fixed; left:24px; bottom:24px; z-index:998;
  font-family:'Space Grotesk',system-ui,sans-serif;
}
[dir="rtl"] .a11y-widget{ left:auto; right:24px }
.a11y-fab{
  width:48px; height:48px; border-radius:50%;
  background:rgba(14,20,36,.95); border:1px solid var(--line-2);
  color:#19c6dd; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 24px rgba(0,0,0,.45), 0 0 0 1px rgba(25,198,221,.05);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  transition:transform .18s, box-shadow .18s, border-color .18s, color .18s;
}
.a11y-fab:hover, .a11y-fab[aria-expanded="true"]{
  transform:translateY(-2px);
  border-color:#19c6dd; color:#19c6dd;
  box-shadow:0 12px 32px rgba(25,198,221,.2), 0 0 0 1px rgba(25,198,221,.18);
}
.a11y-panel{
  position:absolute; left:0; bottom:calc(100% + 12px);
  width:300px; padding:1.2rem 1.3rem 1.1rem;
  background:rgba(14,20,36,.97); border:1px solid var(--line-2);
  border-radius:14px;
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  box-shadow:0 16px 48px rgba(0,0,0,.55);
  display:flex; flex-direction:column; gap:.9rem;
  font-family:'Space Grotesk',sans-serif;
}
[dir="rtl"] .a11y-panel{ left:auto; right:0 }
.a11y-panel[hidden]{ display:none }
.a11y-panel::before{
  content:''; position:absolute; top:0; left:1.5rem; right:1.5rem; height:1px;
  background:linear-gradient(90deg, transparent, #19c6dd, #1f4fb0, transparent);
}
.a11y-panel h3{
  font-size:.74rem; text-transform:uppercase; letter-spacing:.14em;
  color:#19c6dd; font-family:'JetBrains Mono',monospace;
  margin:.2rem 0 .2rem; font-weight:500;
}
.a11y-row{
  display:flex; justify-content:space-between; align-items:center; gap:.8rem;
  padding:.2rem 0;
}
.a11y-row > span{ font-size:.9rem; color:var(--text) }
.a11y-group{ display:flex; gap:.3rem }
.a11y-group button{
  width:34px; height:32px; border-radius:7px;
  background:rgba(255,255,255,.04); border:1px solid var(--line);
  color:var(--text); cursor:pointer; font-family:'Space Grotesk',sans-serif;
  display:flex; align-items:center; justify-content:center;
  transition:background .15s, border-color .15s, color .15s;
}
.a11y-group button:hover{ border-color:var(--line-2) }
.a11y-group button[aria-pressed="true"]{
  background:rgba(25,198,221,.14); border-color:#19c6dd; color:#19c6dd;
}
.a11y-group button:nth-child(1){ font-size:.84rem }
.a11y-group button:nth-child(2){ font-size:.94rem; font-weight:600 }
.a11y-group button:nth-child(3){ font-size:1.05rem; font-weight:700 }
.a11y-toggle{
  display:flex; align-items:center; gap:.6rem; cursor:pointer;
  font-size:.9rem; color:var(--text);
  padding:.35rem 0;
}
.a11y-toggle input[type="checkbox"]{
  width:18px; height:18px; accent-color:#19c6dd; flex-shrink:0;
  cursor:pointer;
}
.a11y-reset{
  margin-top:.3rem; padding:.55rem 1rem;
  background:transparent; border:1px solid var(--line);
  color:var(--muted); cursor:pointer; border-radius:8px;
  font-size:.76rem; font-family:'JetBrains Mono',monospace;
  letter-spacing:.06em; text-transform:uppercase;
  transition:border-color .15s, color .15s;
}
.a11y-reset:hover{ border-color:#ff8a8a; color:#ff8a8a }

/* ===== A11y modes applied to <html> ===== */
/* Use `zoom` (not font-size) so px-defined sizes inherited from the NetPay
   stylesheet scale too. Supported in all modern browsers since Firefox 126
   (May 2024); becoming standardised in CSS Viewport. */
html.a11y-text-large{ zoom:1.15 }
html.a11y-text-xlarge{ zoom:1.32 }
html.a11y-contrast{
  --muted:#cfd5e0;
  --line:rgba(255,255,255,.2);
  --line-2:rgba(255,255,255,.32);
}
html.a11y-contrast :focus-visible{ outline-width:3px; outline-offset:3px }
html.a11y-motion-off *,
html.a11y-motion-off *::before,
html.a11y-motion-off *::after{
  animation-duration:0s !important;
  animation-iteration-count:1 !important;
  transition-duration:0s !important;
  scroll-behavior:auto !important;
}
html.a11y-motion-off canvas#matrix{ display:none }
html.a11y-underline-links main a:not(.btn):not(.cta-pill):not(.vert-door){
  text-decoration:underline !important; text-underline-offset:3px;
}

/* ===== Floating actions: Book a call + Back to top (bottom-right) ===== */
.float-actions{
  position:fixed; right:24px; bottom:24px; z-index:998;
  display:flex; flex-direction:column; gap:.6rem; align-items:flex-end;
}
[dir="rtl"] .float-actions{ right:auto; left:24px; align-items:flex-start }
.float-book{
  display:inline-flex; align-items:center; gap:.55rem;
  padding:.75rem 1.2rem;
  background:
    linear-gradient(135deg, rgba(25,198,221,.18), rgba(31,79,176,.14)),
    rgba(14,20,36,.92);
  border:1px solid rgba(25,198,221,.4);
  color:#19c6dd; font-weight:600; font-size:.9rem;
  text-decoration:none; border-radius:999px;
  box-shadow:0 10px 28px rgba(0,0,0,.45), 0 0 0 1px rgba(25,198,221,.06);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  transition:transform .2s, box-shadow .2s, border-color .2s, color .2s;
  font-family:'Space Grotesk',sans-serif;
  white-space:nowrap;
}
.float-book:hover{
  transform:translateY(-2px); color:#fff;
  border-color:#19c6dd;
  box-shadow:0 16px 40px rgba(25,198,221,.22), 0 0 0 1px rgba(25,198,221,.2);
}
.float-book .dot{
  width:8px; height:8px; border-radius:50%;
  background:#19c6dd; box-shadow:0 0 12px #19c6dd;
  animation:pulse-float-dot 1.8s ease-in-out infinite;
}
@keyframes pulse-float-dot{
  0%, 100%{ opacity:1; transform:scale(1) }
  50%{ opacity:.5; transform:scale(.82) }
}
.float-top{
  width:42px; height:42px; border-radius:50%;
  background:rgba(14,20,36,.95); border:1px solid var(--line-2);
  color:var(--text); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 20px rgba(0,0,0,.4);
  transition:transform .18s, border-color .18s, color .18s;
}
.float-top:hover{
  transform:translateY(-2px); border-color:#19c6dd; color:#19c6dd;
}
.float-book[hidden], .float-top[hidden]{ display:none }

@media (max-width:640px){
  .a11y-widget{ left:16px; bottom:16px }
  [dir="rtl"] .a11y-widget{ left:auto; right:16px }
  .a11y-panel{ width:calc(100vw - 32px); max-width:300px }
  .float-actions{ right:16px; bottom:16px }
  [dir="rtl"] .float-actions{ right:auto; left:16px }
  .float-book{ padding:.6rem 1rem; font-size:.84rem }
  .float-top{ width:38px; height:38px }
}
@media (max-width:380px){
  .a11y-fab{ width:42px; height:42px }
}

/* ===== Newsletter signup in footer ===== */
.foot-newsletter{
  position:relative;
  display:grid; grid-template-columns:1fr 1.1fr; gap:2.5rem; align-items:center;
  padding:2.2rem 2rem;
  margin:2rem 0 1.5rem;
  background:
    linear-gradient(135deg, rgba(25,198,221,.04), rgba(31,79,176,.04)),
    rgba(14,20,36,.6);
  border:1px solid var(--line-2); border-radius:18px;
  overflow:hidden;
}
.foot-newsletter::before{
  content:''; position:absolute; top:0; left:10%; right:10%; height:1px;
  background:linear-gradient(90deg, transparent, rgba(25,198,221,.5), rgba(31,79,176,.5), transparent);
}
.foot-newsletter-copy{ display:flex; flex-direction:column; gap:.5rem; min-width:0 }
.foot-newsletter-eyebrow{
  font-family:'JetBrains Mono',monospace; font-size:.7rem;
  color:#19c6dd; text-transform:uppercase; letter-spacing:.12em;
}
.foot-newsletter-copy strong{
  color:var(--text); font-size:1.25rem; font-weight:600;
  line-height:1.2; letter-spacing:-.01em;
}
.foot-newsletter-copy span{
  color:var(--muted); font-size:.88rem; line-height:1.55;
  max-width:38ch;
}
.foot-newsletter-form{
  display:flex; flex-direction:column; gap:.7rem; min-width:0;
}
.foot-newsletter-input-row{
  display:flex; gap:.6rem; align-items:stretch;
}
.foot-newsletter-form input[type="email"]{
  flex:1; min-width:0;
  background:rgba(5,7,13,.65); border:1px solid var(--line-2);
  color:var(--text); padding:.85rem 1.1rem;
  border-radius:10px; font-size:.95rem;
  font-family:'Space Grotesk',system-ui,sans-serif;
  transition:border-color .15s, background .15s, box-shadow .15s;
}
.foot-newsletter-form input[type="email"]:hover{ border-color:var(--line-2); background:rgba(5,7,13,.85) }
.foot-newsletter-form input[type="email"]:focus,
.foot-newsletter-form input[type="email"]:focus-visible{
  outline:none; border-color:#19c6dd;
  box-shadow:0 0 0 3px rgba(25,198,221,.12);
  background:rgba(5,7,13,.9);
}
.foot-newsletter-form input[type="email"]::placeholder{ color:#5a6678 }
.foot-newsletter-form .btn{
  padding:.85rem 1.4rem; font-size:.92rem; white-space:nowrap; flex-shrink:0;
}
.newsletter-note{
  font-size:.74rem; color:var(--muted);
  font-family:'JetBrains Mono',monospace; letter-spacing:.02em;
  display:flex; align-items:center; gap:.4rem;
}
.newsletter-note::before{
  content:''; width:6px; height:6px; border-radius:50%;
  background:#19c6dd; opacity:.6;
}
.newsletter-status{
  font-size:.84rem; color:var(--muted);
  min-height:1.2rem;
  font-family:'JetBrains Mono',monospace;
}
.newsletter-status.ok{ color:#19c6dd }
.newsletter-status.err{ color:#ff7c7c }
.visually-hidden{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
@media (max-width:780px){
  .foot-newsletter{ grid-template-columns:1fr; gap:1.6rem; padding:1.8rem 1.4rem }
}
@media (max-width:560px){
  .foot-newsletter-input-row{ flex-direction:column; gap:.6rem }
  .foot-newsletter-form .btn{ width:100% }
}

/* ===== Case study ===== */
.section-cases{
  padding-block:6rem;
  position:relative;
}
/* Soft vignette via pseudo-element, full viewport-width so the bg isn't a
   centred floating box inside the 1280px section container. */
.section-cases::before{
  content:''; position:absolute; top:0; bottom:0;
  left:50%; width:100vw; transform:translateX(-50%);
  background:radial-gradient(ellipse 70% 80% at 50% 50%, rgba(25,198,221,.03), transparent 70%);
  mask-image:linear-gradient(180deg, transparent 0%, #000 14%, #000 86%, transparent 100%);
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, #000 14%, #000 86%, transparent 100%);
  pointer-events:none; z-index:0;
}
.section-cases > *{ position:relative; z-index:1 }
.case{
  max-width:1080px; margin:3rem auto 0;
  background:
    linear-gradient(180deg, rgba(14,20,36,.92), rgba(10,14,26,.82)),
    radial-gradient(circle at 0% 0%, rgba(25,198,221,.05), transparent 50%),
    radial-gradient(circle at 100% 100%, rgba(31,79,176,.05), transparent 50%);
  border:1px solid var(--line-2); border-radius:20px;
  overflow:hidden; position:relative;
  box-shadow:0 24px 80px rgba(0,0,0,.4);
}
.case::before{
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, #19c6dd, #1f4fb0, transparent);
}
.case-top{
  display:grid; grid-template-columns:minmax(0, 1fr) minmax(0, 1.6fr);
  gap:2rem; padding:2.4rem 2.4rem 2rem;
  border-bottom:1px solid var(--line);
}
.case-slug{ display:flex; flex-direction:column; gap:.5rem }
.case-slug-tag{
  font-family:'JetBrains Mono',monospace; font-size:.7rem;
  color:#19c6dd; text-transform:uppercase; letter-spacing:.12em;
}
.case-slug-h{
  font-size:1.4rem; margin:.1rem 0 .4rem;
  color:var(--text); font-weight:600; line-height:1.2;
}
.case-slug-meta{
  display:flex; flex-direction:column; gap:.65rem; margin:.4rem 0 0;
  padding-top:1rem; border-top:1px solid var(--line);
}
.case-slug-meta div{
  display:flex; justify-content:space-between; align-items:baseline;
  gap:1rem; min-width:0;
}
.case-slug-meta dt{
  font-size:.78rem; color:var(--muted); margin:0; flex-shrink:0;
}
.case-slug-meta dd{
  font-size:.86rem; color:var(--text); margin:0; text-align:right;
  min-width:0; overflow:hidden; text-overflow:ellipsis;
}
.case-results{
  display:grid; grid-template-columns:1fr 1fr 1.25fr; gap:.9rem;
  list-style:none; margin:0; padding:0; min-width:0;
}
.case-results li{
  display:flex; flex-direction:column; gap:.4rem;
  padding:1.3rem 1.1rem 1.1rem;
  background:rgba(255,255,255,.025); border:1px solid var(--line);
  border-radius:12px; position:relative; min-width:0;
}
.case-result-hero{
  background:linear-gradient(135deg, rgba(25,198,221,.1), rgba(31,79,176,.06)) !important;
  border-color:rgba(25,198,221,.28) !important;
  box-shadow:inset 0 0 0 1px rgba(25,198,221,.06), 0 0 32px rgba(25,198,221,.05);
}
.case-result-num{
  font-family:'Space Grotesk',sans-serif; font-weight:700; font-size:2.2rem;
  background:linear-gradient(135deg, #19c6dd 0%, #1f4fb0 110%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; line-height:1; letter-spacing:-.02em;
}
.case-result-lbl{
  color:var(--text); font-size:.88rem; font-weight:500;
  margin-top:.35rem; line-height:1.3;
}
.case-result-delta{
  color:var(--muted); font-size:.74rem; line-height:1.4;
  font-family:'JetBrains Mono',monospace;
}
.case-story{
  padding:2.2rem 2.4rem 2.4rem;
  display:grid; grid-template-columns:1fr 1fr; gap:2.4rem;
}
.case-block{
  display:flex; flex-direction:column; gap:.8rem;
  position:relative; padding-left:3rem;
}
.case-block .case-step-num{
  position:absolute; left:0; top:.1rem;
  width:32px; height:32px; border-radius:50%;
  background:rgba(25,198,221,.08); border:1px solid rgba(25,198,221,.3);
  color:#19c6dd; font-family:'JetBrains Mono',monospace;
  font-size:.74rem; font-weight:500;
  display:flex; align-items:center; justify-content:center;
}
.case-block h4{
  color:var(--text); margin:.3rem 0 0;
  font-size:1rem; font-weight:600; letter-spacing:.01em;
}
.case-block > p{
  color:var(--text); font-size:.94rem; line-height:1.7;
  margin:0; opacity:.92;
}
.case-actions{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:.85rem;
}
.case-actions li{
  display:flex; gap:.85rem; align-items:flex-start;
  font-size:.92rem; line-height:1.6; color:var(--text); opacity:.92;
}
.case-step-i{
  font-family:'JetBrains Mono',monospace; font-size:.72rem;
  color:#19c6dd; flex-shrink:0; padding-top:.18rem;
  letter-spacing:.06em; min-width:1.6rem;
}
.case-step-t{ flex:1; min-width:0 }
.case-signal{
  grid-column:1 / -1; margin:.4rem 0 0;
  padding:1.4rem 1.8rem 1.5rem 3rem;
  background:linear-gradient(135deg, rgba(31,79,176,.06), rgba(25,198,221,.02));
  border:1px solid var(--line);
  border-left:2px solid #1f4fb0; border-radius:0 14px 14px 0;
  font-style:italic; position:relative;
}
.case-signal-mark{
  position:absolute; left:1rem; top:.3rem;
  font-family:Georgia,serif; font-size:3rem; line-height:1;
  color:rgba(31,79,176,.4); font-style:normal; user-select:none;
}
.case-signal p{
  margin:0; font-size:1.02rem; color:var(--text);
  line-height:1.5; opacity:.96;
}
.case-signal cite{
  display:block; margin-top:.6rem; font-style:normal;
  font-size:.78rem; color:var(--muted);
  font-family:'JetBrains Mono',monospace; letter-spacing:.04em;
}
[dir="rtl"] .case-block{ padding-left:0; padding-right:3rem }
[dir="rtl"] .case-block .case-step-num{ left:auto; right:0 }
[dir="rtl"] .case-signal{
  border-left:none; border-right:2px solid #1f4fb0;
  border-radius:14px 0 0 14px; padding:1.4rem 3rem 1.5rem 1.8rem;
}
[dir="rtl"] .case-signal-mark{ left:auto; right:1rem }
@media (max-width:920px){
  .case-top{ grid-template-columns:1fr; gap:1.6rem; padding:1.8rem }
  .case-results{ grid-template-columns:1fr 1fr; }
  .case-results li:last-child{ grid-column:1 / -1 }
  .case-story{ grid-template-columns:1fr; gap:1.6rem; padding:1.8rem }
}
@media (max-width:560px){
  .case-results{ grid-template-columns:1fr }
  .case-result-num{ font-size:1.9rem }
  .case-block{ padding-left:2.4rem }
}

/* ===== Booking CTA placeholder ===== */
.book-cta{
  display:inline-flex; align-items:center; gap:.5rem;
  margin-top:.8rem; padding:.6rem 1rem;
  background:transparent; border:1px dashed var(--line-2);
  border-radius:8px; color:var(--muted); font-size:.85rem;
  text-decoration:none; transition:border-color .15s, color .15s;
}
.book-cta:hover{ border-color:#19c6dd; color:var(--text) }
.book-cta .dot{ width:8px; height:8px; border-radius:50%; background:#19c6dd }

