/* ============================================================
   SPIDERS EVENTS — shared site styles
   Built on the Spiders Mobility design system tokens.
   Flat blue (#0F11FA) + green (#5BDB84) + white, ink for text
   & control-room bands. Arabic-first, bilingual RTL/LTR.
   ============================================================ */

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--white);color:var(--ink);
  font-family:var(--font-arabic);
  font-size:17px;line-height:var(--leading-normal);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
html.lang-en body{font-family:var(--font-sans)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.lucide{stroke-width:2}
::selection{background:var(--green-200);color:var(--ink)}

/* ---------- bilingual visibility ---------- */
html.lang-en .ar{display:none!important}
html.lang-ar .en{display:none!important}

/* ---------- headings ---------- */
h1,h2,h3,h4{color:var(--ink);letter-spacing:var(--tracking-tight);line-height:var(--leading-snug)}
html.lang-ar h1,html.lang-ar h2,html.lang-ar h3,html.lang-ar .display-2,html.lang-ar .stat-big{font-family:var(--font-arabic-display);font-weight:800;letter-spacing:-.01em}
html.lang-en h1,html.lang-en h2,html.lang-en h3,html.lang-en .display-2,html.lang-en .stat-big{font-family:var(--font-display);text-transform:uppercase}
html.lang-en .no-caps{text-transform:none!important}

/* ---------- layout ---------- */
.wrap{max-width:1200px;margin-inline:auto;padding-inline:40px}
section{position:relative}
.sec{padding-block:96px}
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head.center{margin-inline:auto;text-align:center}
.kicker{font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--spiders-blue);display:inline-flex;align-items:center;gap:10px}
.kicker::before{content:"";width:26px;height:2px;background:var(--spiders-blue);border-radius:2px}
.sec-head.center .kicker{justify-content:center}
h2.title{font-size:clamp(30px,4.4vw,52px);line-height:1.04;margin-top:16px}
.sec-head p{font-size:19px;line-height:1.65;color:var(--gray-600);margin-top:18px}

/* on dark / color bands */
.band-ink{background:var(--ink);color:var(--white)}
.band-ink h1,.band-ink h2,.band-ink h3{color:var(--white)}
.band-ink .kicker{color:var(--spiders-green)}
.band-ink .kicker::before{background:var(--spiders-green)}
.band-ink .sec-head p{color:rgba(255,255,255,.7)}
.band-blue{background:var(--spiders-blue);color:var(--white)}
.band-blue h1,.band-blue h2,.band-blue h3{color:var(--white)}
.band-blue .kicker{color:var(--spiders-green)}
.band-blue .kicker::before{background:var(--spiders-green)}
.band-blue .sec-head p{color:rgba(255,255,255,.82)}
.band-green{background:var(--spiders-green)}
.band-green h1,.band-green h2,.band-green h3{color:var(--spiders-blue)}
.band-green .kicker{color:var(--spiders-blue)}
.band-green .kicker::before{background:var(--spiders-blue)}
.band-muted{background:var(--gray-50)}

/* ---------- buttons ---------- */
.btn{font-family:var(--font-sans);font-weight:700;font-size:16px;border:1.5px solid transparent;cursor:pointer;
  padding:14px 26px;border-radius:var(--radius-pill);display:inline-flex;align-items:center;gap:9px;white-space:nowrap;
  transition:transform var(--dur-base) var(--ease-out),background var(--dur-base),box-shadow var(--dur-base),border-color var(--dur-base)}
html.lang-ar .btn{font-family:var(--font-arabic);font-weight:700}
.btn svg{width:18px;height:18px}
html.lang-ar .btn .arrow{transform:scaleX(-1)}
.btn-primary{background:var(--spiders-blue);color:#fff}
.btn-primary:hover{background:var(--blue-600);transform:translateY(-2px);box-shadow:var(--shadow-blue)}
.btn-primary:active{background:var(--blue-700);transform:scale(.98)}
.btn-accent{background:var(--spiders-green);color:var(--ink)}
.btn-accent:hover{background:var(--green-500);transform:translateY(-2px);box-shadow:var(--shadow-green)}
.btn-ghost{background:transparent;color:var(--spiders-blue);border-color:var(--spiders-blue)}
.btn-ghost:hover{background:var(--blue-50)}
.btn-on-ink{background:transparent;color:#fff;border-color:rgba(255,255,255,.34)}
.btn-on-ink:hover{border-color:var(--spiders-green);background:rgba(91,219,132,.1)}
.btn-on-blue{background:var(--spiders-green);color:var(--ink)}
.btn-on-blue:hover{background:var(--green-500);transform:translateY(-2px)}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.88);backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--gray-200)}
.nav{display:flex;align-items:center;gap:28px;height:94px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:60px;height:60px;flex:0 0 auto}
.brand .nm{display:flex;flex-direction:column;line-height:1}
.brand .nm .t{font-family:var(--font-display);font-weight:700;font-size:27px;letter-spacing:.02em;color:var(--spiders-blue)}
html.lang-ar .brand .nm .t{font-family:var(--font-arabic-display);font-weight:800;letter-spacing:0}
.brand .nm .s{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--gray-500);text-transform:uppercase;margin-top:4px}
.nav-links{display:flex;gap:28px;margin-inline-start:auto;align-items:center}
.nav-links>a{font-weight:600;font-size:15.5px;color:var(--gray-700);transition:color .2s;white-space:nowrap}
.nav-links>a:hover,.nav-links>a.active{color:var(--spiders-blue)}
.nav-actions{display:flex;gap:10px;align-items:center}
.lang-btn{font-family:var(--font-mono);font-size:13px;color:var(--gray-700);border:1.5px solid var(--gray-300);background:#fff;border-radius:var(--radius-pill);padding:8px 13px;cursor:pointer;transition:.2s;letter-spacing:.04em}
.lang-btn:hover{color:var(--spiders-blue);border-color:var(--spiders-blue)}
.menu-btn{display:none;background:#fff;border:1.5px solid var(--gray-300);border-radius:10px;width:44px;height:42px;cursor:pointer;color:var(--ink);place-items:center}
.menu-btn svg{width:22px;height:22px}
a:focus-visible,button:focus-visible{outline:none;box-shadow:var(--ring-blue);border-radius:6px}

/* ---------- generic card grid ---------- */
.grid{display:grid;gap:18px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:30px 28px;transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base),border-color var(--dur-base)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--gray-300)}
.card .ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;margin-bottom:20px;background:var(--blue-50);color:var(--spiders-blue)}
.card .ic.green{background:var(--green-50);color:var(--green-700)}
.card .ic svg{width:26px;height:26px}
.card h3{font-size:20px;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.card p{color:var(--gray-600);font-size:15.5px;line-height:1.6;margin-bottom:16px}
.card.feat{background:var(--spiders-blue);border-color:transparent}
.card.feat h3,.card.feat p{color:#fff}
.card.feat p{color:rgba(255,255,255,.82)}
.card.feat .ic{background:var(--spiders-green);color:var(--ink)}

/* tag chips inside cards */
.tags{display:flex;flex-wrap:wrap;gap:8px}
.tags > span{font-size:13px;color:var(--gray-600);background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:5px 11px}
.card.feat .tags > span{color:#fff;background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.22)}

/* flags / badges */
.flag{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;padding:4px 10px;border-radius:var(--radius-pill);font-weight:700}
.flag.lic{background:var(--green-50);color:var(--green-700);border:1px solid var(--green-200)}
.flag.fl{background:var(--blue-50);color:var(--spiders-blue);border:1px solid var(--blue-100)}
.card.feat .flag.fl{background:rgba(255,255,255,.16);color:#fff;border-color:rgba(255,255,255,.3)}

/* ---------- footer ---------- */
footer{background:var(--ink);color:#fff;padding-block:72px 36px;margin-top:0}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:44px}
.foot-brand .brand .nm .t{color:#fff}
.foot-brand .mark{filter:brightness(0) invert(1);width:66px;height:66px}
.foot-tag{font-family:var(--font-display);font-weight:700;font-size:26px;text-transform:uppercase;line-height:1.05;letter-spacing:-.02em;color:var(--spiders-green);margin-top:20px}
html.lang-ar .foot-tag{font-family:var(--font-arabic-display);font-weight:800;text-transform:none}
.foot-brand p{color:rgba(255,255,255,.6);font-size:14.5px;margin-top:16px;line-height:1.6;max-width:34ch}
footer h4{font-family:var(--font-display);font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--spiders-green);margin-bottom:16px}
html.lang-ar footer h4{font-family:var(--font-arabic-display);letter-spacing:.02em}
footer ul{list-style:none}
footer li{padding:7px 0}
footer li a{color:rgba(255,255,255,.7);font-size:15px;transition:color .2s}
footer li a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:54px;padding-top:26px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:rgba(255,255,255,.5);font-size:13px;font-family:var(--font-mono);letter-spacing:.02em}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .g-4{grid-template-columns:repeat(2,1fr)}
  .g-3{grid-template-columns:repeat(2,1fr)}
  .wrap{padding-inline:24px}
  .sec{padding-block:72px}
}
@media(max-width:680px){
  body{font-size:16px}
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:34px}
  .nav-links{position:fixed;inset-block-start:94px;inset-inline:0;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(255,255,255,.98);backdrop-filter:blur(16px);border-bottom:1px solid var(--gray-200);
    padding:14px 24px 22px;transform:translateY(-135%);transition:transform .35s var(--ease-out);margin:0;z-index:55;box-shadow:var(--shadow-md)}
  .nav-links.open{transform:none}
  .nav-links>a{padding:14px 0;border-bottom:1px solid var(--gray-200);font-size:17px}
  .menu-btn{display:grid}
  .sec-head p{font-size:17px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   SHARED SUB-PAGE COMPONENTS
   ============================================================ */
/* page hero (compact banner at top of inner pages) */
.page-hero{position:relative;overflow:hidden}
.page-hero .wrap{position:relative;z-index:2}
.page-hero-inner{padding-block:72px 64px;max-width:760px}
.page-hero .eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:22px;border-radius:var(--radius-pill);padding:7px 15px;white-space:nowrap}
.page-hero h1{font-size:clamp(34px,5vw,60px);line-height:1.03;margin-bottom:0}
.page-hero p{font-size:clamp(17px,1.7vw,21px);line-height:1.6;margin-top:22px;max-width:60ch}
.page-hero.band-green .eyebrow{background:rgba(255,255,255,.55);border:1px solid rgba(15,17,250,.18);color:var(--spiders-blue)}
.page-hero.band-green p{color:#0a3d1d;font-weight:500}
.page-hero.band-blue .eyebrow{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff}
.page-hero.band-blue p{color:rgba(255,255,255,.85)}
.page-hero.band-ink .eyebrow{background:rgba(91,219,132,.12);border:1px solid rgba(91,219,132,.3);color:var(--spiders-green)}
.page-hero.band-ink p{color:rgba(255,255,255,.72)}

/* breadcrumb-ish back / meta is handled inline */

/* process steps */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.step{position:relative}
.step .num{font-family:var(--font-mono);font-weight:700;font-size:14px;color:var(--spiders-blue);letter-spacing:.05em}
.step .sic{width:58px;height:58px;border-radius:16px;background:var(--blue-50);display:grid;place-items:center;color:var(--spiders-blue);margin:16px 0}
.step .sic svg{width:26px;height:26px}
.step h3{font-size:19px;font-weight:700;margin-bottom:8px}
.step p{font-size:15px;color:var(--gray-600);line-height:1.55}
.band-ink .step .num{color:var(--spiders-green)}
.band-ink .step .sic{background:rgba(91,219,132,.12);color:var(--spiders-green)}
.band-ink .step p{color:rgba(255,255,255,.66)}

/* feature list (icon + text rows) */
.feat-list{display:flex;flex-direction:column;gap:6px}
.feat-row{display:flex;gap:15px;padding:16px 18px;border-radius:var(--radius-md);border:1px solid var(--gray-200);background:#fff;transition:.22s}
.feat-row:hover{border-color:var(--spiders-blue);box-shadow:var(--shadow-sm)}
.feat-row .fic{width:42px;height:42px;border-radius:11px;flex:0 0 auto;display:grid;place-items:center;background:var(--green-50);color:var(--green-700)}
.feat-row .fic svg{width:21px;height:21px}
.feat-row b{display:block;font-weight:700;font-size:16.5px;margin-bottom:3px}
.feat-row span{color:var(--gray-600);font-size:15px;line-height:1.55}

/* stat tiles */
.stat-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat-tile{border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:28px 24px;background:#fff}
.stat-tile .sv{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,3.4vw,46px);line-height:1;color:var(--spiders-blue);letter-spacing:-.02em;font-feature-settings:"tnum" 1}
.stat-tile .sv .u{font-size:.5em;color:var(--gray-500)}
.stat-tile .sl{color:var(--gray-600);font-size:14.5px;margin-top:12px;line-height:1.5}
.band-ink .stat-tile{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12)}
.band-ink .stat-tile .sv{color:var(--spiders-green)}
.band-ink .stat-tile .sl{color:rgba(255,255,255,.62)}

@media(max-width:980px){.steps-grid,.stat-tiles{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.steps-grid,.stat-tiles{grid-template-columns:1fr}.page-hero-inner{padding-block:54px 48px}}
