/* ============================================================
   EXPERTS PLACE — Real Estate Marketing Services
   Brand stylesheet (complements Tailwind Play CDN)
   Palette derived from the EXPERTS PLACE logo:
     electric cyan ring, platinum silver ring, near-black field
   ============================================================ */

:root{
  /* Core field — near-black with a faint orbital-blue tint */
  --ink:        #06090F;
  --ink-2:      #090E17;
  --surface:    #0B111C;
  --surface-2:  #101A29;
  --line:       rgba(199,207,218,0.10);
  --line-strong:rgba(199,207,218,0.18);

  /* Brand accents (from logo) */
  --cyan:       #22C5EC;   /* bright ring highlight — primary accent */
  --cyan-soft:  #6FDCF4;
  --cyan-deep:  #0E7FB8;
  --azure:      #2E6FB7;   /* mid royal-blue of the ring */
  --navy:       #0A2A52;   /* deep navy gradient base */

  /* Platinum (silver ring + EXPERTS wordmark) */
  --silver:     #C9D1DC;   /* primary light text */
  --silver-2:   #E7ECF2;
  --muted:      #818D9F;   /* secondary text */
  --muted-2:    #5A6576;

  --radius:     16px;
  --radius-sm:  10px;
  --maxw:       1200px;

  --font-display:'Space Grotesk', 'Inter', system-ui, sans-serif;
  --font-body:   'Inter', system-ui, -apple-system, sans-serif;
  --font-mono:   'JetBrains Mono', ui-monospace, 'SFMono-Regular', monospace;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--ink);
  color:var(--silver);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* Ambient field: faint graticule + corner glow, sitewide */
body::before{
  content:"";
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(1100px 700px at 78% -8%, rgba(34,197,236,0.10), transparent 60%),
    radial-gradient(900px 600px at 8% 108%, rgba(46,111,183,0.10), transparent 60%),
    linear-gradient(transparent 0 39px, rgba(199,207,218,0.022) 39px 40px),
    linear-gradient(90deg, transparent 0 39px, rgba(199,207,218,0.022) 39px 40px);
  background-size:auto,auto,40px 40px,40px 40px;
}
main, header, footer{ position:relative; z-index:1; }

::selection{ background:rgba(34,197,236,0.28); color:#fff; }

h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; color:var(--silver-2); line-height:1.08; letter-spacing:-0.02em; margin:0; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,40px); }
.section{ padding-block:clamp(72px,11vw,140px); }

/* ---------- Eyebrow + corner-bracket motif (targeting/precision) ---------- */
.eyebrow{
  font-family:var(--font-mono);
  font-size:12px; letter-spacing:0.32em; text-transform:uppercase;
  color:var(--cyan); display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{
  content:""; width:26px; height:1px; background:linear-gradient(90deg,transparent,var(--cyan));
}
[dir="rtl"] .eyebrow::before{ background:linear-gradient(270deg,transparent,var(--cyan)); }

/* Reticle: animated corner brackets used on hero + key cards */
.reticle{ position:relative; }
.reticle::before,.reticle::after{
  content:""; position:absolute; width:18px; height:18px; pointer-events:none;
  border:1.5px solid var(--cyan); opacity:.6;
}
.reticle::before{ top:-1px; left:-1px; border-right:0; border-bottom:0; }
.reticle::after{ bottom:-1px; right:-1px; border-left:0; border-top:0; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em; justify-content:center;
  font-family:var(--font-display); font-weight:500; font-size:15px;
  padding:14px 26px; border-radius:999px; cursor:pointer; border:1px solid transparent;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease, color .25s ease;
  white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(135deg,var(--cyan),var(--cyan-deep));
  color:#04121a; box-shadow:0 10px 34px -12px rgba(34,197,236,0.7);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 44px -12px rgba(34,197,236,0.85); }
.btn-ghost{ border-color:var(--line-strong); color:var(--silver-2); background:rgba(255,255,255,0.015); }
.btn-ghost:hover{ border-color:var(--cyan); color:var(--cyan); transform:translateY(-2px); }
.btn:focus-visible, a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:2px solid var(--cyan); outline-offset:3px;
}

/* ---------- Cards / glass surfaces ---------- */
.glass{
  background:linear-gradient(180deg, rgba(16,26,41,0.72), rgba(11,17,28,0.72));
  border:1px solid var(--line);
  border-radius:var(--radius);
  backdrop-filter:blur(10px);
}
.card{
  background:linear-gradient(180deg, rgba(16,26,41,0.55), rgba(9,14,23,0.55));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:30px;
  transition:transform .35s ease, border-color .35s ease, background .35s ease;
  position:relative; overflow:hidden;
}
.card::after{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:radial-gradient(420px 200px at var(--mx,80%) -20%, rgba(34,197,236,0.14), transparent 70%);
  opacity:0; transition:opacity .4s ease;
}
.card:hover{ transform:translateY(-6px); border-color:var(--line-strong); }
.card:hover::after{ opacity:1; }

/* ---------- Header / Nav ---------- */
.site-header{
  position:fixed; inset-inline:0; top:0; z-index:50;
  transition:background .35s ease, border-color .35s ease, backdrop-filter .35s ease, padding .35s ease;
  border-bottom:1px solid transparent; padding-block:18px;
}
.site-header.scrolled{
  background:rgba(6,9,15,0.82); backdrop-filter:blur(14px);
  border-bottom-color:var(--line); padding-block:10px;
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:46px; width:auto; transition:height .35s ease; }
.scrolled .brand img{ height:38px; }
.nav-links{ display:flex; align-items:center; gap:34px; list-style:none; margin:0; padding:0; }
.nav-links a{
  font-size:15px; color:var(--silver); position:relative; padding-block:4px; transition:color .2s ease;
}
.nav-links a::after{
  content:""; position:absolute; bottom:0; inset-inline-start:0; height:1px; width:0;
  background:var(--cyan); transition:width .3s ease;
}
.nav-links a:hover{ color:var(--silver-2); }
.nav-links a:hover::after, .nav-links a.active::after{ width:100%; }
.nav-actions{ display:flex; align-items:center; gap:14px; }
.lang-switch{
  font-family:var(--font-mono); font-size:12.5px; letter-spacing:.12em;
  border:1px solid var(--line-strong); border-radius:999px; padding:8px 14px; color:var(--silver);
  transition:border-color .25s, color .25s, background .25s; display:inline-flex; align-items:center; gap:7px;
}
.lang-switch:hover{ border-color:var(--cyan); color:var(--cyan); }
.hamburger{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.hamburger span{ display:block; width:24px; height:2px; background:var(--silver-2); margin:5px 0; transition:transform .3s, opacity .3s; }
.hamburger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2){ opacity:0; }
.hamburger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobile-menu{
  position:fixed; inset:0 0 0 0; top:0; z-index:49;
  background:rgba(6,9,15,0.97); backdrop-filter:blur(8px);
  display:flex; flex-direction:column; justify-content:center; align-items:center; gap:8px;
  opacity:0; visibility:hidden; transition:opacity .35s ease, visibility .35s ease;
}
.mobile-menu.open{ opacity:1; visibility:visible; }
.mobile-menu a{ font-family:var(--font-display); font-size:30px; color:var(--silver-2); padding:14px; }
.mobile-menu a:hover{ color:var(--cyan); }

/* ============================================================
   HERO — Satellite Intelligence Terminal (signature)
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; padding-top:120px; padding-bottom:60px; }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; opacity:.42; filter:saturate(.85) contrast(1.05); }
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(6,9,15,0.55) 0%, rgba(6,9,15,0.35) 40%, var(--ink) 96%),
    linear-gradient(90deg, var(--ink) 0%, rgba(6,9,15,0.55) 45%, transparent 80%);
}
[dir="rtl"] .hero-bg::after{
  background:
    linear-gradient(180deg, rgba(6,9,15,0.55) 0%, rgba(6,9,15,0.35) 40%, var(--ink) 96%),
    linear-gradient(270deg, var(--ink) 0%, rgba(6,9,15,0.55) 45%, transparent 80%);
}

/* HUD overlay — scan sweep + radar ping + graticule */
.hud{ position:absolute; inset:0; z-index:1; pointer-events:none; overflow:hidden; }
.hud-grid{
  position:absolute; inset:0; opacity:.5;
  background:
    linear-gradient(transparent 0 79px, rgba(34,197,236,0.07) 79px 80px),
    linear-gradient(90deg, transparent 0 79px, rgba(34,197,236,0.07) 79px 80px);
  background-size:80px 80px;
  mask-image:radial-gradient(120% 100% at 70% 30%, #000 35%, transparent 80%);
}
.scanline{
  position:absolute; inset-inline:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  box-shadow:0 0 26px 6px rgba(34,197,236,0.35);
  animation:scan 7s linear infinite;
}
@keyframes scan{ 0%{ top:-2%; opacity:0;} 8%{opacity:1;} 92%{opacity:1;} 100%{ top:102%; opacity:0;} }

/* Parcel reticles that "lock on" to white-land plots */
.parcel{
  position:absolute; width:108px; height:74px; opacity:0;
  animation:lock 9s ease-in-out infinite;
}
.parcel i{ position:absolute; width:14px; height:14px; border:1.5px solid var(--cyan); }
.parcel i:nth-child(1){ top:0; left:0; border-right:0; border-bottom:0; }
.parcel i:nth-child(2){ top:0; right:0; border-left:0; border-bottom:0; }
.parcel i:nth-child(3){ bottom:0; left:0; border-right:0; border-top:0; }
.parcel i:nth-child(4){ bottom:0; right:0; border-left:0; border-top:0; }
.parcel .tag{
  position:absolute; top:-26px; inset-inline-start:0; white-space:nowrap;
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:.08em; color:var(--cyan);
  background:rgba(6,9,15,0.7); padding:2px 7px; border:1px solid rgba(34,197,236,0.4);
}
.parcel.p1{ top:30%; inset-inline-start:62%; animation-delay:0s; }
.parcel.p2{ top:60%; inset-inline-start:78%; animation-delay:3s; }
.parcel.p3{ top:46%; inset-inline-start:70%; animation-delay:5.5s; }
@keyframes lock{
  0%,100%{ opacity:0; transform:scale(1.25); }
  6%{ opacity:1; transform:scale(1); }
  30%{ opacity:1; transform:scale(1); }
  40%{ opacity:0; transform:scale(.96); }
}

.hero-content{ position:relative; z-index:2; display:grid; grid-template-columns:1.15fr .85fr; gap:54px; align-items:center; width:100%; }
.hero h1{
  font-size:clamp(2.6rem,6vw,4.6rem); font-weight:700; letter-spacing:-0.03em; margin-bottom:22px;
}
.hero h1 .accent{ color:var(--cyan); }
.hero .lede{ font-size:clamp(1.05rem,1.7vw,1.22rem); color:var(--muted); max-width:34em; margin-bottom:34px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:40px; }
.hero-stats{ display:flex; flex-wrap:wrap; gap:38px; }
.hero-stats .num{ font-family:var(--font-display); font-size:1.9rem; font-weight:700; color:var(--silver-2); }
.hero-stats .lbl{ font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); }

/* Floating "analysis console" card */
.console{ padding:22px; }
.console-head{ display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--line); padding-bottom:14px; margin-bottom:18px; }
.console-head .title{ font-family:var(--font-mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.led{ width:8px; height:8px; border-radius:50%; background:var(--cyan); box-shadow:0 0 10px var(--cyan); animation:blink 2.4s ease-in-out infinite; }
@keyframes blink{ 0%,100%{opacity:1;} 50%{opacity:.35;} }
.console-row{ display:flex; justify-content:space-between; align-items:center; padding:9px 0; border-bottom:1px dashed var(--line); font-family:var(--font-mono); font-size:12.5px; }
.console-row .k{ color:var(--muted); }
.console-row .v{ color:var(--silver-2); }
.console-row .v.cyan{ color:var(--cyan); }
.meter{ height:6px; border-radius:99px; background:rgba(255,255,255,0.06); overflow:hidden; margin-top:4px; }
.meter > i{ display:block; height:100%; width:0; border-radius:99px; background:linear-gradient(90deg,var(--azure),var(--cyan)); transition:width 1.4s cubic-bezier(.2,.7,.2,1); }
.console-foot{ font-family:var(--font-mono); font-size:11px; color:var(--muted-2); letter-spacing:.1em; margin-top:16px; }

/* ---------- Marquee differentiator strip ---------- */
.marquee{ overflow:hidden; border-block:1px solid var(--line); background:rgba(9,14,23,0.6); }
.marquee-track{ display:flex; gap:0; white-space:nowrap; animation:marq 38s linear infinite; }
.marquee-track span{ font-family:var(--font-display); font-size:clamp(1rem,2vw,1.4rem); color:var(--muted); padding:18px 30px; display:inline-flex; align-items:center; gap:30px; }
.marquee-track span::after{ content:"◍"; color:var(--cyan); font-size:.7em; }
@keyframes marq{ to{ transform:translateX(-50%); } }
[dir="rtl"] .marquee-track{ animation-name:marq-rtl; }
@keyframes marq-rtl{ to{ transform:translateX(50%); } }

/* ---------- Section headers ---------- */
.sec-head{ max-width:760px; margin-bottom:54px; }
.sec-head h2{ font-size:clamp(2rem,4vw,3rem); margin-top:18px; margin-bottom:18px; }
.sec-head p{ color:var(--muted); font-size:1.06rem; }
.center{ margin-inline:auto; text-align:center; }
.center .eyebrow::before{ display:none; }

/* ---------- Capability / service grids ---------- */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.cap-ico{
  width:54px; height:54px; border-radius:13px; display:grid; place-items:center; margin-bottom:20px;
  background:linear-gradient(135deg, rgba(34,197,236,0.16), rgba(46,111,183,0.10));
  border:1px solid rgba(34,197,236,0.25); color:var(--cyan);
}
.card h3{ font-size:1.28rem; margin-bottom:12px; }
.card p{ color:var(--muted); font-size:.97rem; margin:0; }
.card .idx{ position:absolute; top:18px; inset-inline-end:22px; font-family:var(--font-mono); font-size:12px; color:var(--muted-2); letter-spacing:.1em; }

/* Service cards with imagery */
.svc{ padding:0; }
.svc .ph{ height:190px; overflow:hidden; position:relative; }
.svc .ph img{ width:100%; height:100%; object-fit:cover; transition:transform .7s ease; opacity:.85; }
.svc:hover .ph img{ transform:scale(1.07); }
.svc .ph::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 30%, rgba(9,14,23,0.9)); }
.svc .body{ padding:26px 28px 30px; }

/* ---------- Pipeline (numbered — true sequence) ---------- */
.pipeline{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; counter-reset:step; }
.step{ position:relative; padding-top:28px; }
.step .n{ font-family:var(--font-mono); font-size:13px; color:var(--cyan); letter-spacing:.2em; }
.step h3{ font-size:1.35rem; margin:14px 0 12px; }
.step p{ color:var(--muted); margin:0; }
.step::before{ content:""; position:absolute; top:0; inset-inline-start:0; width:46px; height:2px; background:var(--cyan); }

/* ---------- Vision / Mission split ---------- */
.vm{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.vm .panel{ padding:40px; position:relative; overflow:hidden; }
.vm .panel .glow{ position:absolute; width:280px; height:280px; border-radius:50%; filter:blur(70px); opacity:.5; }
.vm .panel.v .glow{ background:rgba(34,197,236,0.22); top:-90px; inset-inline-end:-70px; }
.vm .panel.m .glow{ background:rgba(46,111,183,0.22); bottom:-90px; inset-inline-start:-70px; }
.vm .panel h3{ font-size:1.7rem; margin:16px 0 14px; }
.vm .panel p{ color:var(--muted); font-size:1.05rem; margin:0; position:relative; }

/* ---------- Stats band ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
.stats .num{ font-family:var(--font-display); font-weight:700; font-size:clamp(2.2rem,4vw,3.2rem); color:var(--silver-2); letter-spacing:-0.02em; }
.stats .num .u{ color:var(--cyan); }
.stats .lbl{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-top:8px; }

/* ---------- Testimonials carousel ---------- */
.tcarousel{ position:relative; max-width:880px; margin-inline:auto; }
.tviewport{ overflow:hidden; }
.ttrack{ display:flex; transition:transform .6s cubic-bezier(.5,.05,.2,1); }
.tslide{ min-width:100%; padding:6px; }
.tquote{ padding:46px; text-align:center; }
.tquote .mark{ color:var(--cyan); font-family:var(--font-display); font-size:3rem; line-height:0; opacity:.5; }
.tquote p{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.15rem,2.2vw,1.5rem); color:var(--silver-2); line-height:1.5; margin:24px 0 26px; letter-spacing:-0.01em; }
.tquote .who{ font-family:var(--font-mono); font-size:12.5px; letter-spacing:.12em; color:var(--muted); text-transform:uppercase; }
.tdots{ display:flex; gap:10px; justify-content:center; margin-top:26px; }
.tdots button{ width:9px; height:9px; border-radius:50%; border:0; background:var(--muted-2); cursor:pointer; transition:background .25s, transform .25s; }
.tdots button.active{ background:var(--cyan); transform:scale(1.25); }
.tnav{ position:absolute; top:50%; transform:translateY(-50%); background:rgba(16,26,41,0.8); border:1px solid var(--line-strong); color:var(--silver-2); width:46px; height:46px; border-radius:50%; cursor:pointer; display:grid; place-items:center; transition:border-color .25s,color .25s; }
.tnav:hover{ border-color:var(--cyan); color:var(--cyan); }
.tnav.prev{ inset-inline-start:-10px; }
.tnav.next{ inset-inline-end:-10px; }

/* ---------- Contact ---------- */
.contact-wrap{ display:grid; grid-template-columns:1fr 1fr; gap:44px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-family:var(--font-mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.field input, .field textarea{
  width:100%; background:rgba(9,14,23,0.7); border:1px solid var(--line-strong); border-radius:var(--radius-sm);
  padding:14px 16px; color:var(--silver-2); font-family:var(--font-body); font-size:15px; transition:border-color .25s, box-shadow .25s;
}
.field input::placeholder, .field textarea::placeholder{ color:var(--muted-2); }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--cyan); box-shadow:0 0 0 3px rgba(34,197,236,0.12); }
.field.err input, .field.err textarea{ border-color:#ff6b6b; }
.field .msg{ color:#ff8585; font-size:12.5px; margin-top:6px; display:none; font-family:var(--font-mono); }
.field.err .msg{ display:block; }
.form-success{
  display:none; align-items:center; gap:12px; padding:16px 18px; border-radius:var(--radius-sm);
  background:rgba(34,197,236,0.10); border:1px solid rgba(34,197,236,0.4); color:var(--cyan); font-size:14.5px; margin-bottom:18px;
}
.form-success.show{ display:flex; }
.contact-info .row{ display:flex; gap:16px; align-items:flex-start; padding:20px 0; border-bottom:1px solid var(--line); }
.contact-info .row .ic{ color:var(--cyan); flex:0 0 auto; margin-top:2px; }
.contact-info .row .k{ font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); }
.contact-info .row .val{ color:var(--silver-2); font-size:1.02rem; }

/* ---------- Footer ---------- */
.site-footer{ border-top:1px solid var(--line); background:var(--ink-2); padding-block:60px 28px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:36px; }
.foot-grid h4{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-bottom:18px; font-weight:500; }
.foot-grid ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:11px; }
.foot-grid a{ color:var(--silver); font-size:.95rem; transition:color .2s; }
.foot-grid a:hover{ color:var(--cyan); }
.foot-grid img{ height:52px; width:auto; margin-bottom:16px; }
.foot-grid .tag{ color:var(--muted); font-size:.92rem; max-width:30ch; }
.socials{ display:flex; gap:12px; margin-top:4px; }
.socials a{ width:40px; height:40px; border-radius:10px; border:1px solid var(--line-strong); display:grid; place-items:center; color:var(--silver); transition:all .25s; }
.socials a:hover{ border-color:var(--cyan); color:var(--cyan); transform:translateY(-2px); }
.foot-bottom{ border-top:1px solid var(--line); margin-top:46px; padding-top:24px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.foot-bottom p{ margin:0; color:var(--muted-2); font-size:.85rem; font-family:var(--font-mono); letter-spacing:.04em; }

/* ---------- Skip link (robust, no Tailwind dependency) ---------- */
.skip-link{
  position:absolute; left:12px; top:-60px; z-index:100;
  background:var(--cyan); color:#04121a; padding:10px 16px; border-radius:8px;
  font-family:var(--font-display); font-weight:600; transition:top .2s ease;
}
.skip-link:focus{ top:12px; }

/* ---------- Scroll reveal (only hidden when JS is active) ---------- */
html.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
html.js .reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-content{ grid-template-columns:1fr; gap:40px; }
  .console{ max-width:460px; }
  .grid-4{ grid-template-columns:repeat(2,1fr); }
  .grid-3, .pipeline{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .vm, .contact-wrap, .grid-2{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:30px; }
  .nav-links{ display:none; }
  .hamburger{ display:block; }
  .tnav{ display:none; }
}
@media (max-width:560px){
  .grid-4{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr; }
  .hero-stats{ gap:24px; }
  .vm .panel, .tquote, .card{ padding:26px; }
}

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

/* ---------- Arabic / RTL typography ---------- */
/* Arabic has no letter-casing; tracking & uppercase break connected glyphs. */
[dir="rtl"] .eyebrow,
[dir="rtl"] .hero-stats .lbl,
[dir="rtl"] .console-head .title,
[dir="rtl"] .console-foot,
[dir="rtl"] .stats .lbl,
[dir="rtl"] .tquote .who,
[dir="rtl"] .field label,
[dir="rtl"] .contact-info .row .k,
[dir="rtl"] .foot-grid h4,
[dir="rtl"] .foot-bottom p,
[dir="rtl"] .step .n,
[dir="rtl"] .marquee-track span,
[dir="rtl"] .card .idx,
[dir="rtl"] .lang-switch{
  text-transform:none;
  letter-spacing:0;
}
/* Keep numeric/Latin data readouts in mono for the terminal feel */
[dir="rtl"] .console-row .v,
[dir="rtl"] [data-coord],
[dir="rtl"] [data-score]{ letter-spacing:.02em; }
/* Heading tracking is tuned for Latin; relax for Arabic */
[dir="rtl"] h1,[dir="rtl"] h2,[dir="rtl"] h3,[dir="rtl"] h4{ letter-spacing:0; line-height:1.25; }
[dir="rtl"] .lede,[dir="rtl"] p{ line-height:1.85; }
/* Hero headline line-height a touch more generous in Arabic */
[dir="rtl"] #hero-title{ line-height:1.3; }
/* Mobile menu Arabic sizing */
[dir="rtl"] .mobile-menu a{ letter-spacing:0; }
