/*
Theme Name: Dubai Local SEO
Theme URI: https://dubailocalseo.com
Author: Dubai Local SEO
Author URI: https://dubailocalseo.com
Description: Immersive, conversion-focused WordPress theme for a Dubai SEO agency. Dynamic header & footer, animated 3D background, custom cursor, smooth scroll, and a full set of Gutenberg block patterns. Built for English + Arabic local SEO.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dubai-local-seo
Tags: business, portfolio, custom-colors, custom-menu, block-patterns, full-width-template, footer-widgets, translation-ready
*/

/* =========================================================================
   Dubai Local SEO — immersive rebuild
   ========================================================================= */
:root{
  --bg:#05070F;
  --bg-2:#0A0E1A;
  --panel:#0E1426;
  --gold:#F5B829;
  --gold-soft:#FFD56B;
  --amber:#FF7A45;
  --violet:#7C5CFF;
  --teal:#2DE0C5;
  --ink:#F6F8FF;
  --muted:#93A0BC;
  --muted-2:#6A7796;
  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.18);
  --glass:rgba(255,255,255,.045);
  --glass-2:rgba(255,255,255,.07);
  --maxw:1280px;
  --pad:clamp(80px,11vw,160px);
  --r:22px;
  --font-d:"Space Grotesk",system-ui,sans-serif;
  --font-b:"Sora",system-ui,sans-serif;
  --font-m:"Space Mono",ui-monospace,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}
body{
  font-family:var(--font-b);
  background:var(--bg);
  color:var(--ink);
  font-size:18px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  cursor:none;
}
@media (max-width:900px){body{cursor:auto}}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:rgba(245,184,41,.3);color:#fff}

/* ambient field */
.field{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
   radial-gradient(60% 50% at 50% -8%,rgba(124,92,255,.20),transparent 60%),
   radial-gradient(50% 40% at 88% 6%,rgba(45,224,197,.12),transparent 60%),
   radial-gradient(50% 40% at 8% 4%,rgba(255,122,69,.12),transparent 60%);}
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,40px);position:relative;z-index:2}
section{position:relative;z-index:2}
.pad{padding:var(--pad) 0}

/* ---------------- type ---------------- */
.eyebrow{font-family:var(--font-m);font-size:12px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}
.eyebrow.c{justify-content:center}.eyebrow.c::before{display:none}
h1,h2,h3{font-family:var(--font-d);font-weight:600;line-height:1.02;letter-spacing:-.025em}
h1{font-size:clamp(40px,8.4vw,116px);font-weight:700}
h2{font-size:clamp(34px,5.2vw,68px)}
h3{font-size:clamp(20px,2.4vw,26px)}
.lede{font-size:clamp(17px,1.7vw,21px);color:var(--muted);max-width:58ch}
.gold{color:var(--gold)}.teal{color:var(--teal)}.muted{color:var(--muted)}
.grad-text{background:linear-gradient(100deg,var(--gold-soft),var(--gold) 45%,var(--amber));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ---------------- buttons ---------------- */
.btn{font-family:var(--font-b);font-weight:600;font-size:16px;border:none;cursor:none;
  border-radius:100px;padding:16px 30px;display:inline-flex;align-items:center;gap:11px;
  transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .35s,background .3s;white-space:nowrap;position:relative}
@media(max-width:900px){.btn{cursor:pointer}}
.btn .arrow{transition:transform .3s}
.btn:hover .arrow{transform:translateX(5px)}
.btn-gold{background:linear-gradient(180deg,var(--gold-soft),var(--gold));color:#231702;
  box-shadow:0 10px 40px -10px rgba(245,184,41,.6)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 18px 60px -12px rgba(245,184,41,.75)}
.btn-ghost{background:var(--glass);color:var(--ink);border:1px solid var(--line-2);backdrop-filter:blur(10px)}
.btn-ghost:hover{background:var(--glass-2);transform:translateY(-3px)}

.glass{background:var(--glass);border:1px solid var(--line);border-radius:var(--r);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  box-shadow:0 30px 80px -40px rgba(0,0,0,.8)}

/* ---------------- custom cursor ---------------- */
.cursor{position:fixed;top:0;left:0;width:9px;height:9px;border-radius:50%;background:var(--gold);
  pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s}
.cursor-ring{position:fixed;top:0;left:0;width:42px;height:42px;border:1px solid rgba(245,184,41,.5);
  border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);
  transition:width .3s,height .3s,border-color .3s,background .3s}
.cursor-ring.hot{width:64px;height:64px;border-color:rgba(245,184,41,.9);background:rgba(245,184,41,.08)}
@media(max-width:900px){.cursor,.cursor-ring{display:none}}

/* ---------------- preloader ---------------- */
.loader{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:26px}
.loader.done{opacity:0;visibility:hidden;transition:opacity .7s ease,visibility .7s}
.loader .pin{width:46px;height:58px;animation:float 2s ease-in-out infinite}
.loader .bar{width:min(280px,60vw);height:2px;background:var(--line);overflow:hidden;border-radius:2px}
.loader .bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold-soft),var(--gold));border-radius:2px}
.loader .pct{font-family:var(--font-m);font-size:12px;letter-spacing:.3em;color:var(--muted)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ---------------- nav ---------------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .4s,border-color .4s,box-shadow .4s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(5,7,15,.72);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);box-shadow:0 10px 40px -16px rgba(0,0,0,.8)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-d);font-weight:700;font-size:20px;letter-spacing:-.01em}
.brand .mark{width:24px;height:30px;filter:drop-shadow(0 0 12px rgba(245,184,41,.55))}
.brand .dot{color:var(--muted);font-weight:400}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-links a{font-size:15px;color:var(--muted);transition:color .2s;position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-7px;height:1px;width:0;background:var(--gold);transition:width .3s}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:16px}
.nav .btn{padding:12px 22px;font-size:14px}
.nav-toggle{display:none;background:none;border:none;color:var(--ink);cursor:pointer}
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:61;
  background:linear-gradient(90deg,var(--teal),var(--gold),var(--amber));box-shadow:0 0 14px rgba(245,184,41,.6)}
body.lock{overflow:hidden}

/* ---------------- hero ---------------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
#scene{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block}
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:
  linear-gradient(90deg,rgba(5,7,15,.92) 0%,rgba(5,7,15,.6) 40%,rgba(5,7,15,.05) 72%,transparent 100%),
  linear-gradient(180deg,rgba(5,7,15,.4) 0%,transparent 26%,rgba(5,7,15,.85) 100%)}
.hero .wrap{position:relative;z-index:3}
.hero-content{max-width:760px;padding:120px 0 90px}
.hero h1{margin:24px 0 26px}
.hero h1 .l{display:block;overflow:hidden}
.hero h1 .l>span{display:inline-block}
.hero-sub{font-size:clamp(18px,2.1vw,23px);color:var(--ink);opacity:.92;max-width:42ch;line-height:1.5}
.hero-actions{display:flex;gap:16px;margin-top:40px;flex-wrap:wrap}
.trust{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:46px;
  font-family:var(--font-m);font-size:13px;color:var(--muted)}
.trust b{color:var(--ink)}
.trust .stars{color:var(--gold);letter-spacing:2px}
.trust .sep{width:4px;height:4px;border-radius:50%;background:var(--muted-2)}
.scrollhint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;
  font-family:var(--font-m);font-size:10px;letter-spacing:.3em;color:var(--muted);text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:10px}
.scrollhint .t{width:1px;height:42px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.scrollhint .t::after{content:"";position:absolute;inset:0;height:40%;background:var(--gold);animation:sd 2.2s ease-in-out infinite}
@keyframes sd{0%{transform:translateY(-100%)}100%{transform:translateY(260%)}}
.live{position:absolute;right:32px;bottom:120px;z-index:3;display:flex;align-items:center;gap:10px;
  font-family:var(--font-m);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
  padding:9px 15px;background:rgba(5,7,15,.5);border:1px solid var(--line);border-radius:100px;backdrop-filter:blur(8px)}
.live .blip{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 12px var(--teal);animation:blip 1.6s ease-in-out infinite}
@keyframes blip{0%,100%{opacity:1}50%{opacity:.2}}
@media(max-width:900px){.live{display:none}}

/* ---------------- marquee ---------------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:rgba(14,20,38,.4);padding:22px 0;overflow:hidden;white-space:nowrap}
.marquee .track{display:inline-flex;gap:50px;align-items:center;animation:scrollx 30s linear infinite}
.marquee .it{font-family:var(--font-d);font-weight:500;font-size:clamp(18px,2.2vw,26px);color:var(--muted);
  display:inline-flex;align-items:center;gap:16px}
.marquee .it .s{color:var(--gold)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------------- stats ---------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{padding:34px 30px}
.stat .n{font-family:var(--font-d);font-weight:700;font-size:clamp(40px,5vw,60px);line-height:1;letter-spacing:-.03em;
  background:linear-gradient(180deg,#fff,var(--gold-soft));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat .n .suf{-webkit-text-fill-color:var(--gold)}
.stat .l{font-family:var(--font-m);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:14px}

/* ---------------- section heads ---------------- */
.sec-head{max-width:64ch;margin-bottom:60px}
.sec-head.c{margin:0 auto 60px;text-align:center}
.sec-head h2{margin:18px 0}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}

/* ---------------- problem / map pack ---------------- */
.mappack{padding:22px}
.mp-bar{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.06);border:1px solid var(--line);
  border-radius:12px;padding:11px 14px;margin-bottom:14px}
.mp-bar .mp-search{width:16px;height:16px;color:var(--muted);flex:none}
.mp-query{flex:1;font-family:var(--font-m);font-size:12.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mp-live{display:flex;align-items:center;gap:6px;font-family:var(--font-m);font-size:9px;letter-spacing:.14em;color:var(--teal);flex:none}
.mp-live i{width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:0 0 8px var(--teal);animation:blip 1.6s ease-in-out infinite}
.mp-map{position:relative;height:104px;border-radius:12px;overflow:hidden;margin-bottom:14px;border:1px solid var(--line);
  background:radial-gradient(120% 140% at 68% 22%,rgba(45,224,197,.12),transparent 55%),linear-gradient(135deg,#0c1428,#0a1020)}
.mp-map .road{position:absolute;background:rgba(255,255,255,.06)}
.mp-map .r1{top:38%;left:-5%;right:-5%;height:2px;transform:rotate(-6deg)}
.mp-map .r2{top:-5%;bottom:-5%;left:34%;width:2px;transform:rotate(8deg)}
.mp-map .r3{top:66%;left:-5%;right:-5%;height:2px}
.mp-pin{position:absolute;width:11px;height:11px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:var(--muted-2)}
.mp-pin.p1{top:30%;left:62%;background:var(--gold);box-shadow:0 0 0 4px rgba(245,184,41,.18),0 0 14px var(--gold);animation:pinpop 2.4s ease-in-out infinite}
.mp-pin.p2{top:56%;left:40%}
.mp-pin.p3{top:42%;left:80%}
@keyframes pinpop{0%,100%{transform:rotate(-45deg) scale(1)}50%{transform:rotate(-45deg) scale(1.2)}}
.mp-here{position:absolute;top:16%;left:55%;font-family:var(--font-m);font-size:9px;letter-spacing:.06em;color:#231702;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));padding:2px 7px;border-radius:100px;font-weight:700}
.slot{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:13px;margin-bottom:9px;
  border:1px solid var(--line);background:rgba(255,255,255,.03);transition:transform .35s,border-color .4s,box-shadow .4s}
.slot.win{border-color:rgba(245,184,41,.6);background:linear-gradient(90deg,rgba(245,184,41,.16),rgba(245,184,41,.02));
  box-shadow:0 0 44px -12px rgba(245,184,41,.6)}
.slot.win:hover{transform:translateY(-2px)}
.slot .rk{font-family:var(--font-m);font-weight:700;font-size:14px;width:18px;text-align:center;color:var(--muted);flex:none}
.slot.win .rk{color:var(--gold)}
.slot .av{width:34px;height:34px;border-radius:9px;flex:none;display:grid;place-items:center;font-family:var(--font-d);
  font-weight:700;font-size:15px;color:#231702;background:linear-gradient(180deg,var(--gold-soft),var(--gold))}
.slot .av.c{color:var(--muted);background:rgba(255,255,255,.06);border:1px solid var(--line)}
.slot .biz{flex:1;min-width:0}
.slot .nm{font-weight:600;font-size:14.5px;display:flex;align-items:center;gap:8px}
.slot .me{font-family:var(--font-m);font-size:10.5px;color:var(--muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.slot .badge{font-family:var(--font-m);font-size:8.5px;letter-spacing:.1em;color:#231702;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));padding:2px 7px;border-radius:100px;font-weight:700}
.callbtn{font-family:var(--font-b);font-weight:600;font-size:12px;color:#04210f;flex:none;cursor:none;
  background:#25D366;padding:7px 14px;border-radius:100px;box-shadow:0 6px 18px -6px rgba(37,211,102,.6)}
.divider{display:flex;align-items:center;gap:12px;margin:14px 0;color:var(--muted-2);font-family:var(--font-m);font-size:10px;letter-spacing:.12em;text-transform:uppercase}
.divider::before,.divider::after{content:"";height:1px;flex:1;background:repeating-linear-gradient(90deg,var(--line) 0 6px,transparent 6px 12px)}
.slot.you{border-style:dashed;opacity:.85}
.slot.you .rk{color:var(--amber)}.slot.you .av.c{color:var(--amber);border-color:rgba(255,122,69,.4)}
.mp-callout{margin-top:14px;display:inline-flex;align-items:center;gap:8px;font-family:var(--font-m);font-size:12px;
  color:var(--teal);background:rgba(45,224,197,.08);border:1px solid rgba(45,224,197,.3);padding:8px 14px;border-radius:100px}
.mp-callout b{color:var(--ink);font-size:14px}
.problem .eyebrow,.specialist .eyebrow{display:inline-flex;margin-bottom:18px}
.problem h2,.specialist h2{margin-bottom:26px}
.problem .lede{margin-bottom:30px}
.link-cta{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-m);font-size:14px;color:var(--gold)}
.link-cta .arrow{transition:transform .3s}.link-cta:hover .arrow{transform:translateX(5px)}

/* ---------------- services (tilt cards) ---------------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{padding:34px 30px 36px;position:relative;overflow:hidden;transform-style:preserve-3d;transition:transform .25s ease,border-color .35s,background .35s}
.card::before{content:"";position:absolute;inset:0;border-radius:var(--r);opacity:0;transition:opacity .4s;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%),rgba(245,184,41,.16),transparent 45%)}
.card:hover::before{opacity:1}
.card:hover{border-color:var(--line-2)}
.card .num{position:absolute;top:24px;right:28px;font-family:var(--font-m);font-size:12px;color:var(--muted-2)}
.card .ico{width:50px;height:50px;border-radius:14px;border:1px solid var(--line);display:grid;place-items:center;
  margin-bottom:22px;color:var(--gold);background:rgba(245,184,41,.07)}
.card .ico svg{width:24px;height:24px}
.card .lab{font-family:var(--font-m);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.card h3{margin-bottom:12px}
.card p{font-size:15.5px;color:var(--muted);line-height:1.55}
.cta-strip{margin-top:22px;padding:30px 36px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cta-strip .t{font-family:var(--font-d);font-size:clamp(18px,2.2vw,24px);font-weight:600}
.cta-strip .t span{color:var(--muted)}

/* ---------------- in-depth SEO breakdown ---------------- */
.deep-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.deep-card{padding:34px 32px 32px}
.deep-card .lab{font-family:var(--font-m);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.deep-card h3{margin-bottom:14px}
.deep-card p{color:var(--muted);font-size:15.5px;line-height:1.62}
.deep-card ul{list-style:none;margin-top:20px;display:grid;gap:10px;padding-top:18px;border-top:1px solid var(--line)}
.deep-card li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:var(--ink)}
.deep-card li .ck{color:var(--teal);flex:none}

/* ---------------- backlinks showcase ---------------- */
.backlinks{background:linear-gradient(180deg,transparent,rgba(245,184,41,.05),transparent)}
.bl-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:0;margin-bottom:34px;overflow:hidden}
.bl-stats .it{padding:30px 24px;text-align:center;border-right:1px solid var(--line)}
.bl-stats .it:last-child{border-right:none}
.bl-stats .n{font-family:var(--font-d);font-weight:700;font-size:clamp(30px,3.8vw,46px);line-height:1;letter-spacing:-.02em;
  background:linear-gradient(180deg,#fff,var(--gold-soft));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.bl-stats .n .suf{-webkit-text-fill-color:var(--gold)}
.bl-stats .l{font-family:var(--font-m);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:12px}
.bl-industries{margin-top:34px;text-align:center}
.bl-ind-title{font-family:var(--font-m);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.chips{display:flex;flex-wrap:wrap;gap:11px;justify-content:center;margin-top:22px;max-width:920px;margin-left:auto;margin-right:auto}
.chip{font-family:var(--font-m);font-size:13.5px;color:var(--ink);padding:9px 17px;border-radius:100px;
  border:1px solid var(--line);background:var(--glass);transition:border-color .25s,color .25s,transform .25s}
.chip:hover{border-color:rgba(245,184,41,.55);color:var(--gold);transform:translateY(-2px)}

/* ---------------- process (pinned) ---------------- */
.process{background:linear-gradient(180deg,transparent,rgba(14,20,38,.55),transparent)}
.proc-stage{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center;min-height:62vh}
.proc-left{position:sticky;top:0;height:100svh;display:flex;flex-direction:column;justify-content:center}
.proc-num{font-family:var(--font-d);font-weight:700;font-size:clamp(120px,22vw,300px);line-height:.85;letter-spacing:-.04em;
  background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(245,184,41,.1));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  position:relative}
.proc-track{display:flex;gap:10px;margin-top:26px}
.proc-track .d{height:3px;flex:1;background:var(--line);border-radius:3px;overflow:hidden;position:relative}
.proc-track .d span{position:absolute;inset:0;width:0;background:var(--gold)}
.proc-step{padding:46px 44px;margin:18vh 0}
.proc-step .tag{font-family:var(--font-m);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);
  padding:8px 15px;border:1px solid rgba(245,184,41,.35);border-radius:100px;display:inline-block;margin-bottom:22px}
.proc-step h3{font-size:clamp(26px,3.4vw,38px);margin-bottom:16px}
.proc-step p{color:var(--muted);font-size:17px;max-width:48ch}
.proc-step ul{list-style:none;margin-top:22px;display:grid;gap:12px}
.proc-step li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px}
.proc-step li .ck{color:var(--teal);flex:none;margin-top:3px}

/* ---------------- results ---------------- */
.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.case{padding:34px 32px;display:flex;flex-direction:column;gap:22px;min-height:330px;transition:transform .35s,border-color .35s}
.case:hover{transform:translateY(-6px);border-color:var(--line-2)}
.case .tag{font-family:var(--font-m);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.jump{display:flex;align-items:center;gap:16px}
.jump .from{font-family:var(--font-d);font-weight:700;font-size:46px;color:var(--muted);opacity:.5}
.jump .to{font-family:var(--font-d);font-weight:700;font-size:76px;line-height:1;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.jump .ar{display:flex;flex-direction:column;align-items:center;color:var(--teal);font-family:var(--font-m);font-size:10px;letter-spacing:.1em;gap:3px}
.jump .ar svg{width:32px}
.case p{color:var(--muted);font-size:15px;line-height:1.5}
.case .metric{margin-top:auto;font-family:var(--font-m);font-weight:700;font-size:22px;color:var(--teal)}

/* ---------------- specialist ---------------- */
.specialist .split{gap:80px}
.checklist{margin-top:28px;display:grid;gap:14px;list-style:none}
.checklist li{display:flex;align-items:center;gap:14px;font-size:16px}
.checklist .ck{width:24px;height:24px;border-radius:50%;background:rgba(45,224,197,.12);border:1px solid rgba(45,224,197,.4);
  display:grid;place-items:center;color:var(--teal);flex:none}
.specialist{position:relative}
/* site-wide interactive magnetic line field (fixed background behind everything) */
.magnet-bg{position:fixed;inset:0;z-index:0;display:grid;justify-items:center;align-items:center;
  pointer-events:none;opacity:.4;
  -webkit-mask:radial-gradient(130% 130% at 50% 42%,#000 60%,transparent 100%);
  mask:radial-gradient(130% 130% at 50% 42%,#000 60%,transparent 100%)}
.magnet-bg span{display:block;width:2.5px;height:24px;border-radius:3px;transform-origin:center;
  transform:rotate(var(--rotate,-10deg));background:rgba(245,184,41,.72);
  transition:transform .15s cubic-bezier(.2,.8,.2,1)}
.emirate{position:relative;aspect-ratio:1;display:grid;place-items:center}
.emirate .ring{position:absolute;border:1px solid var(--line-2);border-radius:50%}
.emirate .ring.r1{width:92%;height:92%;animation:spin 42s linear infinite}
.emirate .ring.r2{width:64%;height:64%;animation:spin 30s linear infinite reverse}
.emirate .ring.r3{width:38%;height:38%;animation:spin 22s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.emirate .lab{position:absolute;bottom:3%;left:50%;transform:translateX(-50%);white-space:nowrap;
  font-family:var(--font-m);font-size:11px;letter-spacing:.14em;color:var(--muted)}
@media (prefers-reduced-motion:reduce){.magnet-bg span{transition:none}}

/* ---------------- pricing ---------------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.tier{padding:40px 34px;display:flex;flex-direction:column;position:relative;transition:transform .35s,border-color .35s}
.tier:hover{transform:translateY(-6px)}
.tier.feat{border-color:rgba(245,184,41,.55);background:linear-gradient(180deg,rgba(245,184,41,.08),rgba(14,20,38,.3));
  box-shadow:0 40px 90px -34px rgba(245,184,41,.45);transform:translateY(-14px)}
.tier.feat:hover{transform:translateY(-20px)}
.tier .pop{position:absolute;top:-13px;left:50%;transform:translateX(-50%);font-family:var(--font-m);font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;color:#231702;background:linear-gradient(180deg,var(--gold-soft),var(--gold));
  padding:7px 16px;border-radius:100px;white-space:nowrap;box-shadow:0 10px 26px -6px rgba(245,184,41,.6)}
.tier .nm{font-family:var(--font-m);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.tier.feat .nm{color:var(--gold)}
.tier .price{font-family:var(--font-d);font-weight:700;font-size:54px;line-height:1;margin:20px 0 4px;letter-spacing:-.02em}
.tier .price .cur{font-size:22px;color:var(--muted);vertical-align:super;margin-right:4px}
.tier .price .per{font-family:var(--font-m);font-size:13px;color:var(--muted)}
.tier .desc{color:var(--muted);font-size:15px;margin:12px 0 26px;min-height:44px}
.tier ul{list-style:none;display:grid;gap:13px;margin-bottom:30px;flex:1}
.tier li{display:flex;gap:12px;font-size:15px;align-items:flex-start}
.tier li .ck{color:var(--gold);flex:none;margin-top:2px}
.tier .btn{width:100%;justify-content:center}
.pricing-note{text-align:center;margin-top:28px;font-family:var(--font-m);font-size:13px;color:var(--muted)}

/* ---------------- faq ---------------- */
.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:64px;align-items:start}
.faq-side p{color:var(--muted);margin:16px 0 26px}
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:none;cursor:none;color:var(--ink);text-align:left;padding:26px 4px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;font-family:var(--font-d);font-weight:500;font-size:20px}
@media(max-width:900px){.faq-q{cursor:pointer}}
.faq-q .pm{width:24px;height:24px;flex:none;position:relative}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--gold);transition:transform .3s,opacity .3s}
.faq-q .pm::before{top:11px;left:4px;width:16px;height:2px}
.faq-q .pm::after{left:11px;top:4px;width:2px;height:16px}
.faq-item.open .pm::after{transform:rotate(90deg);opacity:0}
.faq-a{overflow:hidden;max-height:0;transition:max-height .45s ease}
.faq-a .in{padding:0 4px 28px;color:var(--muted);font-size:16px;line-height:1.6;max-width:62ch}

/* ---------------- contact form ---------------- */
.contact .split{align-items:start}
.contact .checklist{margin-top:30px}
.contact-info{margin-top:30px;font-family:var(--font-m);font-size:14px;color:var(--muted);line-height:1.9}
.contact-info a{color:var(--ink)}.contact-info a:hover{color:var(--gold)}
.lead-form{padding:32px 30px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}
.fld{display:flex;flex-direction:column;gap:8px}
.fld.full{grid-column:1/-1}
.fld label{font-family:var(--font-m);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.fld label .req{color:var(--gold)}
.fld input,.fld select,.fld textarea{font-family:var(--font-b);font-size:15px;color:var(--ink);width:100%;
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px;padding:13px 14px;outline:none;
  transition:border-color .25s,box-shadow .25s}
.fld input{cursor:text}.fld textarea{cursor:text;resize:vertical;min-height:96px}
.fld select{cursor:pointer;appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%2393A0BC' stroke-width='1.8'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px}
.fld select option{background:#0E1426;color:var(--ink)}
.fld input::placeholder,.fld textarea::placeholder{color:var(--muted-2)}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:rgba(245,184,41,.55);box-shadow:0 0 0 3px rgba(245,184,41,.12)}
.fld.invalid input,.fld.invalid select,.fld.invalid textarea{border-color:rgba(255,90,90,.65)}
.lead-form .btn{width:100%;justify-content:center}
.lead-form .btn svg{width:19px;height:19px}
.form-note{font-family:var(--font-m);font-size:11.5px;color:var(--muted);margin-top:14px;text-align:center;line-height:1.6}
.form-ok{margin-top:16px;text-align:center;color:var(--teal);font-family:var(--font-m);font-size:13.5px;
  background:rgba(45,224,197,.08);border:1px solid rgba(45,224,197,.3);border-radius:12px;padding:12px}

/* ---------------- final cta ---------------- */
.final{position:relative;min-height:80vh;display:flex;align-items:center;text-align:center;overflow:hidden}
#scene2{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.final::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:
  radial-gradient(60% 50% at 50% 45%,rgba(5,7,15,.78) 0%,rgba(5,7,15,.3) 60%,transparent 84%),
  radial-gradient(100% 100% at 50% 60%,transparent 50%,rgba(5,7,15,.75) 85%,var(--bg) 100%)}
.final .wrap{position:relative;z-index:2}
.final h2{font-size:clamp(42px,7vw,90px);margin-bottom:24px}
.final p{color:var(--ink);opacity:.88;max-width:54ch;margin:0 auto 38px;font-size:19px}
.final .hero-actions{justify-content:center}

/* ---------------- footer ---------------- */
.footer{padding:90px 0 40px;border-top:1px solid var(--line);background:rgba(14,20,38,.5);position:relative;z-index:2}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}
.footer .brand{margin-bottom:18px}
.footer .nap{font-style:normal;color:var(--muted);font-size:14.5px;line-height:1.75}
.footer .nap a:hover{color:var(--gold)}
.footer h4{font-family:var(--font-m);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;font-weight:400}
.footer ul{list-style:none;display:grid;gap:11px}
.footer ul a{color:var(--muted);font-size:14.5px;transition:color .2s}
.footer ul a:hover{color:var(--ink)}
.footer-bottom{margin-top:56px;padding-top:26px;border-top:1px solid var(--line);display:flex;justify-content:space-between;
  align-items:center;gap:16px;flex-wrap:wrap;font-family:var(--font-m);font-size:12px;color:var(--muted)}
.socials{display:flex;gap:12px}
.socials a{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);transition:.2s}
.socials a:hover{color:var(--gold);border-color:rgba(245,184,41,.4)}
.socials svg{width:16px}

/* whatsapp float */
.wa{position:fixed;right:22px;bottom:22px;z-index:55;width:60px;height:60px;border-radius:50%;
  background:#25D366;display:grid;place-items:center;box-shadow:0 14px 40px -8px rgba(37,211,102,.6);
  transition:transform .3s;animation:wapulse 2.6s ease-in-out infinite}
.wa:hover{transform:scale(1.08)}
.wa svg{width:30px;height:30px}
@keyframes wapulse{0%,100%{box-shadow:0 14px 40px -8px rgba(37,211,102,.6)}50%{box-shadow:0 14px 50px -4px rgba(37,211,102,.9)}}

/* reveal */
.rv{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}.rv.d4{transition-delay:.32s}.rv.d5{transition-delay:.4s}

/* ---------------- responsive ---------------- */
@media(max-width:1024px){
  .stats,.bl-stats{grid-template-columns:repeat(2,1fr)}
  .bl-stats .it:nth-child(2){border-right:none}
  .cards,.results-grid,.tiers{grid-template-columns:repeat(2,1fr)}
  .split,.faq-grid{grid-template-columns:1fr;gap:46px}
  .specialist .split{gap:46px}
  .proc-stage{grid-template-columns:1fr;gap:0}
  .proc-left{position:relative;height:auto;padding:40px 0 0}
  .proc-num{font-size:120px}
  .proc-step{margin:0 0 24px}
  .tier.feat{transform:none}.tier.feat:hover{transform:translateY(-6px)}
}
@media(max-width:720px){
  body{font-size:17px}
  .nav-links{display:none}
  .nav-links.open{display:flex;flex-direction:column;align-items:flex-start;gap:0;position:fixed;top:78px;left:0;right:0;bottom:0;
    background:rgba(5,7,15,.97);backdrop-filter:blur(20px);padding:24px 26px;z-index:59}
  .nav-links.open a{font-size:22px;font-family:var(--font-d);color:var(--ink);padding:18px 0;width:100%;border-bottom:1px solid var(--line)}
  .nav-toggle{display:block}
  .stats,.cards,.results-grid,.tiers,.deep-grid,.bl-stats{grid-template-columns:1fr}
  .bl-stats .it{border-right:none;border-bottom:1px solid var(--line)}
  .bl-stats .it:last-child{border-bottom:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cta-strip{flex-direction:column;align-items:flex-start}
}
@media(max-width:420px){
  .footer-grid{grid-template-columns:1fr}
  h1{font-size:36px}
  .brand{font-size:17px}
  .hero-content{padding-top:108px}
  .btn{padding:15px 24px;font-size:15px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .rv{opacity:1;transform:none}
}

/* ============================================================
   SUB-PAGE STYLES (about, services, backlinks, local-seo, contact)
   ============================================================ */
.page-hero{position:relative;padding:160px 0 50px;overflow:hidden}
.page-hero .eyebrow{margin-bottom:20px}
.page-hero h1{font-size:clamp(40px,6.4vw,82px);margin-bottom:24px}
.page-hero .lede{font-size:clamp(18px,2vw,22px);color:var(--muted);max-width:64ch}
.breadcrumb{font-family:var(--font-m);font-size:12px;letter-spacing:.08em;color:var(--muted-2);margin-bottom:26px}
.breadcrumb a{color:var(--muted)}.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span{color:var(--gold)}

/* long-form prose */
.prose{max-width:840px}
.prose>p{color:var(--muted);margin-bottom:20px;font-size:17px;line-height:1.75}
.prose h2{margin:52px 0 18px}
.prose h2:first-child{margin-top:0}
.prose h3{margin:36px 0 12px;font-size:clamp(20px,2.3vw,25px)}
.prose ul{list-style:none;margin:0 0 22px;display:grid;gap:11px}
.prose ul li{position:relative;padding-left:28px;color:var(--ink);font-size:16px;line-height:1.6}
.prose ul li::before{content:"✦";position:absolute;left:0;top:1px;color:var(--gold)}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:var(--gold);text-decoration:underline;text-underline-offset:2px}
.prose blockquote{margin:26px 0;padding:22px 26px;border-left:2px solid var(--gold);
  background:var(--glass);border-radius:0 14px 14px 0;font-family:var(--font-d);font-size:20px;color:var(--ink);line-height:1.4}

/* two-column content layout with sticky aside */
.doc-grid{display:grid;grid-template-columns:1fr 320px;gap:56px;align-items:start}
.doc-aside{position:sticky;top:100px;display:grid;gap:18px}
.aside-card{padding:26px}
.aside-card h4{font-family:var(--font-d);font-weight:600;font-size:18px;margin-bottom:10px}
.aside-card p{color:var(--muted);font-size:14.5px;line-height:1.6;margin-bottom:16px}
.aside-card .btn{width:100%;justify-content:center}
.aside-toc{padding:24px 26px}
.aside-toc .t{font-family:var(--font-m);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.aside-toc ul{list-style:none;display:grid;gap:10px}
.aside-toc a{color:var(--muted);font-size:14.5px;transition:color .2s}
.aside-toc a:hover{color:var(--gold)}

/* feature/value grid reused on sub-pages */
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:14px 0}
.value{padding:28px 26px}
.value .ico{width:44px;height:44px;border-radius:12px;border:1px solid var(--line);display:grid;place-items:center;color:var(--gold);background:rgba(245,184,41,.06);margin-bottom:16px}
.value .ico svg{width:22px;height:22px}
.value h3{font-size:19px;margin-bottom:9px}
.value p{color:var(--muted);font-size:15px;line-height:1.55}

@media(max-width:1024px){
  .doc-grid{grid-template-columns:1fr;gap:40px}
  .doc-aside{position:relative;top:0;grid-template-columns:1fr 1fr;display:grid}
  .value-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:720px){
  .page-hero{padding:128px 0 40px}
  .doc-aside{grid-template-columns:1fr}
  .value-grid{grid-template-columns:1fr}
}
