/* ===========================================================
   Yariv Oppenheimer — Democrats primaries campaign
   Palette: blue primary · red accent · black ink · (WhatsApp green kept)
   Type: Heebo (Hebrew) / Cairo (Arabic). Both RTL.
   =========================================================== */

:root{
  /* names kept for compatibility — primary RED, accent BLUE (peace), black ink */
  --purple:#e01f2b;         /* primary (red) */
  --purple-600:#c2151f;
  --purple-700:#9e1119;
  --purple-deep:#14151c;    /* near-black (footer/dark) */
  --ink:#15161d;            /* black ink */
  --green:#1d5ae0;          /* accent (blue — peace) */
  --green-600:#1648bd;
  --green-tint:#e7eefc;
  --wa:#1aa371;             /* WhatsApp green (kept) */
  --wa-600:#138a5e;
  --tint:#f4f1f1;           /* light warm-neutral tint */
  --tint-2:#fbe3e4;         /* light red tint */
  --paper:#ffffff;
  --muted:#5a5560;
  --line:rgba(20,16,18,.11);
  --shadow-sm:0 2px 10px rgba(20,16,18,.07);
  --shadow-md:0 14px 40px rgba(20,16,18,.13);
  --shadow-lg:0 30px 70px rgba(20,16,18,.20);
  --r:18px;
  --maxw:1180px;
  --nav-h:74px;
}

*{box-sizing:border-box;margin:0;padding:0}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(12px,-18px)}}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Heebo',system-ui,sans-serif;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
body[data-lang="ar"]{font-family:'Cairo',system-ui,sans-serif;--nav-h:78px}
body[data-lang="en"],
body[data-lang="ru"],
body[data-lang="uk"]{font-family:'Montserrat',system-ui,sans-serif}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
section{position:relative}
section[id],div[id="contact"]{scroll-margin-top:90px}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:28px}

/* ---------- typography helpers ---------- */
h1,h2,h3{line-height:1.08;letter-spacing:-.01em;font-weight:800}
.kicker{
  display:inline-flex;align-items:center;gap:9px;
  font-size:15px;font-weight:700;letter-spacing:.02em;
  color:var(--purple-600);text-transform:none;margin-bottom:18px;
}
.kicker::before{content:"";width:26px;height:3px;border-radius:3px;background:var(--green)}
.eyebrow{
  display:inline-block;font-size:15px;font-weight:700;letter-spacing:.04em;
  color:var(--purple-700);background:var(--tint-2);
  padding:8px 16px;border-radius:999px;margin-bottom:24px;
}
.lead{font-size:20px;color:var(--muted);font-weight:400}

/* ===========================================================
   NAV
   =========================================================== */
.nav{
  position:fixed;inset-block-start:0;inset-inline:0;z-index:80;
  height:var(--nav-h);display:flex;align-items:center;
  transition:background .3s,box-shadow .3s,backdrop-filter .3s;
}
.nav.scrolled{
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(14px) saturate(1.3);
  box-shadow:0 1px 0 var(--line),0 10px 30px rgba(40,22,80,.07);
}
.nav .wrap{display:flex;align-items:center;gap:24px;width:100%}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.party-logo{height:34px;width:auto;display:block}
.brand-divider{width:1px;height:30px;background:var(--line);flex-shrink:0}
.brand-logo{
  width:42px;height:42px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--purple),var(--purple-700));
  display:grid;place-items:center;color:#fff;font-weight:900;font-size:20px;
  box-shadow:var(--shadow-sm);
}
.brand-txt{display:flex;flex-direction:column;line-height:1.15}
.brand-name{font-weight:800;font-size:18px;color:var(--ink)}
.brand-sub{font-size:12.5px;color:var(--muted);font-weight:600}
.nav-links{display:flex;align-items:center;gap:4px;margin-inline-start:auto}
.nav-links a{
  font-size:15.5px;font-weight:600;color:var(--ink);white-space:nowrap;
  padding:9px 14px;border-radius:10px;position:relative;
  transition:color .2s,background .2s;
}
.nav-links a:hover{background:var(--tint);color:var(--purple-700)}
.nav-links a.active{color:var(--purple-700)}
.nav-links a.active::after{
  content:"";position:absolute;inset-block-end:2px;inset-inline:14px;
  height:3px;border-radius:3px;background:var(--green);
}
.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
/* language dropdown */
.lang{position:relative}
.lang-toggle{
  display:flex;align-items:center;gap:8px;
  font-weight:700;font-size:15px;color:var(--purple-700);
  padding:9px 14px;border-radius:999px;border:1.5px solid var(--line);
  background:rgba(255,255,255,.5);transition:border-color .2s,background .2s;
}
.lang-toggle:hover{border-color:var(--purple);background:var(--tint)}
.lang-toggle .globe{width:17px;height:17px;display:inline-block}
.lang-toggle .chev{width:12px;height:12px;transition:transform .2s}
.lang.open .lang-toggle .chev{transform:rotate(180deg)}
.lang-menu{
  position:absolute;inset-block-start:calc(100% + 10px);inset-inline-end:0;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-md);padding:7px;min-width:172px;z-index:90;
  opacity:0;transform:translateY(-8px);pointer-events:none;transition:opacity .2s,transform .2s;
}
.lang.open .lang-menu{opacity:1;transform:none;pointer-events:auto}
.lang-menu button{
  display:flex;align-items:center;gap:10px;width:100%;text-align:start;
  font-family:inherit;font-weight:600;font-size:15.5px;color:var(--ink);
  padding:10px 12px;border-radius:9px;transition:background .15s;
}
.lang-menu button:hover{background:var(--tint)}
.lang-menu button.sel{color:var(--purple-700);background:var(--tint)}
.lang-menu button .nm{flex:1}
.lang-menu button .ck{width:16px;height:16px;color:var(--purple);opacity:0}
.lang-menu button.sel .ck{opacity:1}
.lang-menu button[lang="ar"]{font-family:'Cairo',sans-serif}
.lang-menu button[lang="he"]{font-family:'Heebo',sans-serif}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:800;font-size:16px;border-radius:999px;
  padding:13px 26px;transition:transform .15s,box-shadow .2s,background .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--purple);color:#fff;box-shadow:0 8px 22px rgba(224,31,43,.30)}
.btn-primary:hover{background:var(--purple-600);box-shadow:0 12px 30px rgba(224,31,43,.40)}
.btn-green{background:var(--green);color:#fff;box-shadow:0 8px 22px rgba(29,90,224,.30)}
.btn-green:hover{background:var(--green-600);box-shadow:0 12px 30px rgba(29,90,224,.40)}
.btn-ghost{background:#fff;color:var(--purple-700);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--purple);background:var(--tint)}
.btn-lg{padding:16px 32px;font-size:17.5px}
.nav .btn{padding:11px 22px;font-size:15.5px}
.hamburger{display:none;width:46px;height:46px;border-radius:12px;
  align-items:center;justify-content:center;border:1.5px solid var(--line);background:#fff}
.hamburger span{display:block;width:20px;height:2px;background:var(--ink);position:relative}
.hamburger span::before,.hamburger span::after{content:"";position:absolute;inset-inline:0;height:2px;background:var(--ink)}
.hamburger span::before{top:-6px}.hamburger span::after{top:6px}

/* ===========================================================
   HERO + SIGNUP
   =========================================================== */
.hero{
  position:relative;min-height:100dvh;display:flex;align-items:center;
  padding-block:calc(var(--nav-h) + 20px) 30px;overflow:hidden;
}
.hero .wrap.hero-grid{
  display:grid;grid-template-columns:minmax(380px,440px) 1fr;gap:56px;
  align-items:center;width:100%;
}

/* --- signup side --- */
.hero-signup{position:relative;z-index:2}
.signup-id{display:flex;align-items:flex-start;gap:16px;margin-bottom:18px}
.signup-avatar{
  width:88px;height:104px;border-radius:18px;object-fit:cover;object-position:50% 20%;
  border:3px solid #fff;box-shadow:var(--shadow-md);flex-shrink:0;background:var(--tint-2);
}
.signup-id-txt{display:flex;flex-direction:column;align-items:flex-start;gap:3px}
.signup-id-txt b{font-weight:800;font-size:21px;color:var(--ink);line-height:1.18}
.signup-id-txt span{font-size:14px;color:var(--muted);font-weight:600}
/* "switch to Arabic" pill — two fixed positions: nav (desktop), identity row (mobile). Hebrew only. */
.ar-switch{
  align-self:center;display:none;align-items:center;gap:7px;
  font-family:'Cairo',sans-serif;font-weight:700;font-size:13.5px;
  color:var(--green-600);background:var(--green-tint);
  border:1.5px solid transparent;border-radius:999px;padding:8px 13px;
  white-space:nowrap;transition:background .2s,border-color .2s;
}
.ar-switch:hover{border-color:var(--green);background:#dbe7fb}
.ar-switch svg{width:15px;height:15px;flex-shrink:0}
.nav .ar-switch-nav{padding:8px 14px}
/* compact version that sits under פריימריז הדמוקרטים on mobile */
.ar-switch-id{align-self:flex-start;margin-block-start:5px;margin-inline-start:-11px;padding:3px 11px;font-size:12.5px;gap:6px}
.ar-switch-id svg{width:13px;height:13px}
/* desktop: show the nav one only */
body[data-lang="he"] .ar-switch-nav{display:inline-flex}
/* mobile (≤980px): show the by-the-name one only, hide the nav one */
@media (max-width:980px){
  body[data-lang="he"] .ar-switch-nav{display:none}
  body[data-lang="he"] .ar-switch-id{display:inline-flex}
}
.signup-card{
  background:#fff;border:1px solid var(--line);border-radius:22px;
  padding:26px 24px;box-shadow:var(--shadow-lg);
}
.signup-title{font-size:27px;font-weight:900;color:var(--ink);margin-bottom:16px;letter-spacing:-.01em}
.signup-card .field{margin-bottom:12px}
.signup-card .btn{width:100%;margin-block-start:6px;line-height:1.25}
.signup-note{
  margin-block-start:14px;font-size:13.5px;color:var(--muted);
  text-align:center;line-height:1.55;text-wrap:pretty;
}

/* --- pitch / slogan side --- */
.hero-pitch{position:relative;z-index:2}
.hero-slogan{
  font-size:clamp(28px,3.5vw,50px);font-weight:900;letter-spacing:-.02em;
  line-height:1.1;color:var(--ink);
}
.hero-slogan .ln{display:block}
.hero-slogan .l3{color:var(--green)}
.hero p.sub{margin-block-start:22px;font-size:19px;color:var(--muted);max-width:520px}
.hero-wa{margin-block-start:24px}
.hero-btns{margin-block-start:24px;display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-btns .hero-wa{margin-block-start:0}

/* Entrance: opacity is ALWAYS 1 (never invisible, even mid-transition or in exports);
   only a subtle slide-up animates in while JS is active. */
.hero-eyebrow,.hero-signup,.hero-slogan .ln,.hero p.sub,.hero-btns{
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
}
html.js body:not(.loaded) .hero-eyebrow,
html.js body:not(.loaded) .hero-signup,
html.js body:not(.loaded) .hero-slogan .ln,
html.js body:not(.loaded) .hero p.sub,
html.js body:not(.loaded) .hero-btns{transform:translateY(18px)}
.hero-signup{transition-delay:.12s}
.hero-slogan .l2{transition-delay:.10s}
.hero-slogan .l3{transition-delay:.20s}
.hero p.sub{transition-delay:.34s}
.hero-btns{transition-delay:.44s}


/* floating blobs */
.blob{position:absolute;border-radius:50%;filter:blur(40px);opacity:.5;z-index:0;pointer-events:none}
.blob-1{width:420px;height:420px;background:radial-gradient(circle,#a9c2ff,transparent 70%);
  inset-block-start:-120px;inset-inline-end:-80px;animation:float 16s ease-in-out infinite}
.blob-2{width:360px;height:360px;background:radial-gradient(circle,#ffb3b8,transparent 70%);
  inset-block-end:-100px;inset-inline-start:-60px;animation:float 20s ease-in-out infinite reverse}

/* ---------- credentials strip ---------- */
.cred{border-block:1px solid var(--line);background:var(--tint)}
.cred .wrap{display:flex;justify-content:center;gap:14px 48px;flex-wrap:wrap;
  padding-block:22px;text-align:center}
.cred-item{display:flex;align-items:center;gap:11px;font-weight:700;font-size:16.5px;color:var(--ink)}
.cred-item .ic{width:34px;height:34px;border-radius:10px;background:#fff;border:1px solid var(--line);
  display:grid;place-items:center;color:var(--purple-600);flex-shrink:0}
.cred-item .ic svg{width:18px;height:18px}

/* ===========================================================
   SECTION SHELL
   =========================================================== */
.sec{padding-block:96px}
.sec-tint{background:var(--tint)}
.sec-head{max-width:680px;margin-bottom:52px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(30px,3.6vw,46px);color:var(--ink)}
.sec-head p{margin-block-start:16px;font-size:19px;color:var(--muted)}

/* reveal animation (gated on body.loaded so no-JS / exports stay visible) */
.reveal{transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
body.loaded .reveal{opacity:0;transform:translateY(28px)}
body.loaded .reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.40s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero-eyebrow,.hero-signup,.hero-slogan .ln,.hero p.sub,.hero-btns{opacity:1 !important;transform:none !important;animation:none;transition:none}
  .blob{animation:none}
}

/* ---------- ABOUT ---------- */
.about .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.about-photo{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:4/4.7;box-shadow:var(--shadow-md)}
.about-photo img{width:100%;height:100%;object-fit:cover;object-position:50% 26%}
.about-photo .frame{position:absolute;inset-block-end:-14px;inset-inline-end:-14px;
  width:120px;height:120px;border-radius:20px;border:3px solid var(--green);z-index:-1}
.about-body p{font-size:18.5px;color:#3a4253;margin-block-start:18px;max-width:620px;text-wrap:pretty}
.about-body p:first-of-type{margin-block-start:0}

/* ---------- PLATFORM ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:30px 28px;box-shadow:var(--shadow-sm);
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:transparent}
.card .ic{
  width:54px;height:54px;border-radius:15px;display:grid;place-items:center;margin-bottom:20px;
  background:var(--green-tint);color:var(--green-600);
}
.card .ic svg{width:27px;height:27px}
.card h3{font-size:21px;color:var(--ink);margin-bottom:9px;font-weight:800}
.card p{font-size:16px;color:var(--muted);text-wrap:pretty}

/* ---------- VIDEO ---------- */
.video-frame{
  position:relative;border-radius:24px;overflow:hidden;aspect-ratio:16/9;
  background:
    repeating-linear-gradient(135deg,#efe8ff 0 22px,#e8dfff 22px 44px);
  border:1px solid var(--line);box-shadow:var(--shadow-md);
  display:grid;place-items:center;
}
.video-frame .play{
  width:96px;height:96px;border-radius:50%;background:#fff;box-shadow:var(--shadow-md);
  display:grid;place-items:center;transition:transform .2s;
}
.video-frame:hover .play{transform:scale(1.07)}
.video-frame .play svg{width:34px;height:34px;color:var(--purple);margin-inline-start:4px}
.video-note{position:absolute;inset-block-end:22px;inset-inline-start:0;inset-inline-end:0;text-align:center;
  font-family:ui-monospace,'SF Mono',Menlo,monospace;font-size:13.5px;color:var(--purple-700);
  letter-spacing:.02em}
.video-cap{text-align:center;margin-block-start:22px;font-size:17px;color:var(--muted);font-weight:600}

/* ---------- JOIN / STEPS ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-block-start:8px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;position:relative;box-shadow:var(--shadow-sm)}
.step .num{
  width:46px;height:46px;border-radius:13px;background:var(--purple);color:#fff;
  font-weight:900;font-size:21px;display:grid;place-items:center;margin-bottom:18px;
}
.step:nth-child(2) .num{background:var(--purple-600)}
.step:nth-child(3) .num{background:var(--green)}
.step h3{font-size:20px;margin-bottom:8px;color:var(--ink)}
.step p{font-size:16px;color:var(--muted)}
.join-note{
  margin-block-start:34px;display:inline-flex;align-items:center;gap:12px;
  background:var(--green-tint);color:var(--green-600);font-weight:700;font-size:17px;
  padding:14px 22px;border-radius:14px;
}
.join-note svg{width:21px;height:21px;flex-shrink:0}

/* ---------- FORM ---------- */
.form-sec{background:linear-gradient(180deg,var(--tint),#fff)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.form-aside h2{font-size:clamp(28px,3.4vw,42px);color:var(--ink)}
.form-aside .kicker{margin-bottom:16px}
.form-aside p{font-size:18px;color:var(--muted);margin-block-start:18px;max-width:460px}
.form-aside .mini-list{margin-block-start:26px;display:flex;flex-direction:column;gap:14px}
.form-aside .mini-list div{display:flex;align-items:center;gap:13px;font-weight:600;font-size:16.5px;color:var(--ink)}
.form-aside .mini-list .tick{width:28px;height:28px;border-radius:50%;background:var(--green);color:#fff;
  display:grid;place-items:center;flex-shrink:0}
.form-aside .mini-list .tick svg{width:15px;height:15px}
.form-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:38px 34px;box-shadow:var(--shadow-lg)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:700;font-size:15px;margin-bottom:8px;color:var(--ink)}
.field input{
  width:100%;font-family:inherit;font-size:16.5px;padding:14px 16px;
  border:1.5px solid var(--line);border-radius:12px;background:#fcfbff;color:var(--ink);
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 4px rgba(224,31,43,.15);background:#fff}
.field input::placeholder{color:#b09a9c}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.consent{display:flex;align-items:flex-start;gap:11px;margin-block:6px 22px;cursor:pointer}
.consent input{width:20px;height:20px;margin-top:2px;accent-color:var(--purple);flex-shrink:0;cursor:pointer}
.consent span{font-size:14.5px;color:var(--muted)}
.form-card .btn{width:100%}
.form-disclaimer{margin-block-start:16px;font-size:13px;color:var(--muted);text-align:center;line-height:1.5}
.form-disclaimer a{color:var(--purple-700);font-weight:700;text-decoration:underline}
.form-success{
  display:none;text-align:center;padding:30px 10px;
}
.form-success.show{display:block;animation:rise .5s ease forwards}
.form-success .official-btn{width:100%;margin-block-start:10px}
.form-success .ok{width:72px;height:72px;border-radius:50%;background:#e7f8f0;color:var(--wa-600);
  display:grid;place-items:center;margin:0 auto 18px}
.form-success .ok svg{width:36px;height:36px}
.form-success h3{font-size:24px;color:var(--ink);margin-bottom:8px}
.form-success p{color:var(--muted);font-size:17px}

/* ---------- DONATE BAND ---------- */
.donate{
  background:linear-gradient(120deg,#14151c,var(--purple-700) 55%,var(--purple));
  color:#fff;overflow:hidden;
}
.donate::before{content:"";position:absolute;inset-block-start:-140px;inset-inline-end:-100px;
  width:420px;height:420px;border-radius:50%;background:rgba(255,255,255,.10)}
.donate::after{content:"";position:absolute;inset-block-end:-160px;inset-inline-start:-120px;
  width:380px;height:380px;border-radius:50%;background:rgba(29,90,224,.34);filter:blur(20px)}
.donate .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.4fr .6fr;gap:40px;align-items:center}
.donate .kicker{color:#ffd2d4}
.donate .kicker::before{background:#6f9bff}
.donate h2{font-size:clamp(28px,3.6vw,44px);color:#fff}
.donate p{margin-block-start:16px;font-size:19px;color:#f0dcdd;max-width:620px}
.donate-actions{display:flex;justify-content:flex-end}
.donate .btn-green{box-shadow:0 12px 30px rgba(0,0,0,.22)}
@media (max-width:820px){.donate .wrap{grid-template-columns:1fr}.donate-actions{justify-content:flex-start}}

/* ---------- CONTACT ---------- */
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:34px;box-shadow:var(--shadow-md)}
.contact-row{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
.contact-row:last-child{border-bottom:none}
.contact-row .ic{width:48px;height:48px;border-radius:14px;background:var(--tint-2);color:var(--purple-700);
  display:grid;place-items:center;flex-shrink:0}
.contact-row .ic.wa{background:#e7f8f0;color:var(--wa-600)}
.contact-row .ic svg{width:23px;height:23px}
.contact-row .meta{display:flex;flex-direction:column}
.contact-row .meta small{font-size:13px;color:var(--muted);font-weight:600}
.contact-row .meta b{font-size:17px;color:var(--ink);font-weight:700}
.contact-row.link{cursor:pointer;transition:background .2s;border-radius:12px;margin-inline:-8px;padding-inline:8px}
.contact-row.link:hover{background:var(--tint)}
.socials{margin-block-start:26px}
.socials .lbl{font-weight:700;font-size:15px;color:var(--muted);margin-bottom:14px}
.social-row{display:flex;gap:12px}
.social-row a{
  width:52px;height:52px;border-radius:15px;display:grid;place-items:center;
  background:#fff;border:1px solid var(--line);color:var(--ink);
  transition:transform .2s,background .2s,color .2s,border-color .2s;
}
.social-row a:hover{transform:translateY(-3px);background:var(--purple);color:#fff;border-color:var(--purple)}
.social-row a svg{width:24px;height:24px}

/* ---------- CLOSING CTA ---------- */
.final-cta{
  background:var(--tint);border-block-start:1px solid var(--line);
  padding-block:74px;text-align:center;
}
.final-cta h2{font-size:clamp(28px,3.6vw,44px);color:var(--ink);max-width:760px;margin-inline:auto;text-wrap:balance}
.final-cta p{margin-block-start:14px;font-size:19px;color:var(--muted);max-width:560px;margin-inline:auto}
.final-cta .btn{margin-block-start:30px}

/* ---------- FOOTER ---------- */
.footer{background:var(--purple-deep);color:#cfc4ec;padding-block:48px}
.footer .wrap{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.footer .brand-logo{box-shadow:none}
.footer .fbrand{display:flex;flex-direction:column;align-items:center;gap:12px}
.footer-logo{height:46px;width:auto;display:block}
.fbrand-name{color:#fff;font-weight:800;font-size:18px}
.footer p{font-size:15px;max-width:560px;color:#bcaee6}
.footer .rights{font-size:13.5px;color:#8d7fc0;margin-block-start:6px}

/* ---------- WHATSAPP FLOAT ---------- */
.wa-float{
  position:fixed;inset-block-end:26px;inset-inline-end:26px;z-index:90;
  display:flex;align-items:center;gap:0;
  background:var(--wa);color:#fff;border-radius:999px;
  box-shadow:0 12px 34px rgba(26,163,113,.5);
  height:60px;padding-inline:18px;overflow:hidden;
  transition:transform .2s,box-shadow .2s;
}
.wa-float:hover{transform:translateY(-3px) scale(1.02)}
.wa-float svg{width:30px;height:30px;flex-shrink:0}
.wa-float .lbl{font-weight:800;font-size:16px;max-width:0;opacity:0;white-space:nowrap;
  transition:max-width .35s,opacity .25s,margin .35s}
.wa-float:hover .lbl{max-width:220px;opacity:1;margin-inline-start:12px}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:980px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .hero{min-height:auto;padding-block:calc(var(--nav-h) + 18px) 40px}
  .hero .wrap.hero-grid{grid-template-columns:1fr;gap:30px}
  .hero-signup{max-width:460px;margin-inline:auto;width:100%}
  .hero-pitch{text-align:center;max-width:560px;margin-inline:auto}
  .hero p.sub{margin-inline:auto}
  .about .wrap{grid-template-columns:1fr;gap:36px}
  .about-photo{max-width:380px;margin-inline:auto}
  .cards{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:1fr;gap:36px}
  .contact .wrap{grid-template-columns:1fr;gap:36px}
}
@media (max-width:620px){
  .wrap{padding-inline:20px}
  .sec{padding-block:70px}
  .hero{padding-block:calc(var(--nav-h) + 14px) 32px}
  .signup-title{font-size:24px}
  .cards,.steps{grid-template-columns:1fr}
  .row2{grid-template-columns:1fr}
  .nav-actions .nav-cta-text{display:none}
  .brand-sub{display:none}
  .wa-float .lbl{display:none}
  .wa-float{padding-inline:0;width:60px;justify-content:center}
}

/* mobile menu — direction-agnostic top sheet */
.mobile-menu{
  position:fixed;inset:0;z-index:99;background:rgba(29,22,64,.5);backdrop-filter:blur(4px);
  opacity:0;pointer-events:none;transition:opacity .25s;
}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu .panel{
  position:absolute;inset-block-start:0;inset-inline:0;
  background:#fff;box-shadow:var(--shadow-lg);padding:18px 22px 26px;
  display:flex;flex-direction:column;gap:4px;
  transform:translateY(-100%);transition:transform .32s cubic-bezier(.2,.7,.2,1);
  border-end-start-radius:22px;border-end-end-radius:22px;
}
.mobile-menu.open .panel{transform:translateY(0)}
.mobile-menu .mhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.mobile-menu a{font-size:19px;font-weight:700;padding:13px 12px;border-radius:12px;color:var(--ink)}
.mobile-menu a:hover{background:var(--tint)}
.mobile-menu .mobile-cta{background:var(--purple);color:#fff;text-align:center;font-weight:800;margin-bottom:6px;box-shadow:0 8px 22px rgba(224,31,43,.28)}
.mobile-menu .mobile-cta:hover{background:var(--purple-600)}
.mobile-menu .mclose{font-size:30px;color:var(--muted);padding:2px 10px;line-height:1}
.mobile-menu .btn{margin-block-start:14px}
/* language row inside the hamburger menu (mobile) */
.mobile-langs{display:none}
.mobile-menu .mobile-langs{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-block-start:16px;padding-block-start:16px;border-block-start:1px solid var(--line);
}
.mobile-langs button{
  font-family:inherit;font-weight:700;font-size:15px;color:var(--ink);
  background:var(--tint);border:1.5px solid transparent;border-radius:999px;
  padding:9px 16px;transition:background .2s,border-color .2s,color .2s;
}
.mobile-langs button[lang="ar"]{font-family:'Cairo',sans-serif}
.mobile-langs button.sel{color:var(--green-600);background:var(--green-tint);border-color:var(--green)}

@media (max-width:560px){.nav-cta{display:none}}
/* on mobile the language selector lives in the hamburger menu, not the bar */
@media (max-width:980px){.nav .lang{display:none}.nav-actions{margin-inline-start:auto}.nav-cta{display:none}}

/* ---------- top bar: blue accents (kept from earlier iteration) ---------- */
.nav-cta{background:var(--green);box-shadow:0 8px 22px rgba(29,90,224,.30)}
.nav-cta:hover{background:var(--green-600);box-shadow:0 12px 30px rgba(29,90,224,.40)}
.lang-toggle{color:var(--green-600)}
.lang-toggle:hover{border-color:var(--green);background:var(--tint)}
.nav-links a:hover{color:var(--green-600);background:var(--tint)}
.nav-links a.active{color:var(--green-600)}
.mobile-menu .btn{background:var(--green);box-shadow:0 8px 22px rgba(29,90,224,.30)}
