/* =====================================================================
   MILA — Marketing site design system  ·  "Sand & Ink"
   Warm sand #F6F1E7 · ink #211C16 · deep emerald #0F6E54
   Display: Fraunces (EN) / Cairo (AR)
   Body:    Hanken Grotesk (EN) / Cairo (AR)
   ---------------------------------------------------------------------
   Bilingual mechanism (no JS required for content):
     <span data-l="en">English</span><span data-l="ar">عربي</span>
     html[lang="en"] hides [data-l="ar"];  html[lang="ar"] hides [data-l="en"].
   Direction flips via <html dir>.  Layout uses logical properties.
   ---------------------------------------------------------------------
   Component classes available to every page:
     Layout   .container(.--narrow/.--wide) .section(.--alt/.--ink) .grid(.--2/.--3)
     Type     .display .eyebrow .section-head .section-title .lead .balance
     Buttons  .btn(.--primary/.--outline/.--ghost/.--lg) .btn-row .pill .badge
     Cards    .card .feature .feature__icon .usecase .stat .stats
     Blocks   .hero .zigzag .logos .marquee .testimonial .faq .price .cta-band
     Forms    .form .field .form-row
     Legal    .legal
     Chrome   .site-header .footer .wa-fab  (injected by main.js)
     Motion   [data-reveal] (+ .is-visible)
   ===================================================================== */

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{min-height:100%;line-height:1.6;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit;color:inherit}
button{cursor:pointer;background:none;border:none}
ul{list-style:none}
:focus-visible{outline:2px solid var(--emerald);outline-offset:3px;border-radius:4px}
::selection{background:var(--emerald);color:#fff}

/* ---------- Tokens ---------- */
:root{
  --sand:#F6F1E7;
  --sand-2:#EFE7D7;
  --sand-3:#EAE0CC;
  --paper:#FCFAF4;
  --ink:#211C16;
  --ink-2:#4C453A;
  --ink-3:#766C5C;
  --line:#E4DAC7;
  --line-2:#D9CDB5;
  --emerald:#0F6E54;
  --emerald-600:#137a5e;
  --emerald-700:#0B5440;
  --emerald-900:#0a3a2d;
  --emerald-tint:#E6EFE9;
  --emerald-tint-2:#D7E6DE;
  --clay:#BE5E37;        /* warm secondary, used sparingly */
  --gold:#B5852F;        /* certificates / premium accents, sparingly */
  --white:#ffffff;

  --shadow-sm:0 1px 2px rgba(33,28,22,.05), 0 2px 6px -2px rgba(33,28,22,.06);
  --shadow:0 1px 2px rgba(33,28,22,.04), 0 14px 34px -16px rgba(33,28,22,.18);
  --shadow-lg:0 2px 4px rgba(33,28,22,.05), 0 34px 64px -28px rgba(33,28,22,.28);
  --shadow-emerald:0 18px 40px -18px rgba(15,110,84,.45);

  --r-xs:8px; --r-sm:12px; --r:18px; --r-lg:26px; --r-xl:34px; --r-pill:999px;

  --container:1200px;
  --pad-x:clamp(1.15rem,5vw,2.5rem);
  --section-y:clamp(4.5rem,9vw,8rem);

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);

  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-body:'Hanken Grotesk','Segoe UI',system-ui,sans-serif;
  --font-mono:'Spline Sans Mono',ui-monospace,'SFMono-Regular',monospace;
}
html[lang="ar"]{
  --font-display:'Cairo','Segoe UI',sans-serif;
  --font-body:'Cairo','Segoe UI',system-ui,sans-serif;
}

/* ---------- Base ---------- */
body{
  font-family:var(--font-body);
  background:var(--sand);
  color:var(--ink);
  font-size:clamp(1rem,.97rem + .2vw,1.075rem);
  font-weight:420;
  overflow-x:hidden;
  position:relative;
}
/* warm grain overlay for atmosphere */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
main{position:relative;z-index:2;display:block}

/* ---------- Bilingual visibility ---------- */
html[lang="en"] [data-l="ar"]{display:none !important}
html[lang="ar"] [data-l="en"]{display:none !important}

/* ---------- Typography ---------- */
.display,h1,h2,h3{
  font-family:var(--font-display);
  font-weight:560;
  line-height:1.04;
  letter-spacing:-.018em;
  color:var(--ink);
  font-optical-sizing:auto;
  text-wrap:balance;
}
html[lang="ar"] .display,
html[lang="ar"] h1,html[lang="ar"] h2,html[lang="ar"] h3{
  font-weight:700;letter-spacing:0;line-height:1.22;
}
h1{font-size:clamp(2.6rem,1.7rem + 4.4vw,5rem)}
h2{font-size:clamp(2rem,1.4rem + 2.7vw,3.35rem)}
h3{font-size:clamp(1.3rem,1.1rem + 1vw,1.85rem)}
p{max-width:68ch}
.lead{font-size:clamp(1.12rem,1.04rem + .5vw,1.4rem);color:var(--ink-2);line-height:1.55;font-weight:430}
.balance{text-wrap:balance}
.muted{color:var(--ink-3)}
strong{font-weight:680}
em{font-style:italic}

.eyebrow{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-mono);font-size:.78rem;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;color:var(--emerald-700);
}
html[lang="ar"] .eyebrow{font-family:var(--font-body);letter-spacing:.04em;font-weight:600}
.eyebrow::before{content:"";inline-size:1.9rem;block-size:2px;border-radius:2px;background:var(--emerald);opacity:.85}
.eyebrow.is-center{justify-content:center}

.section-head{max-width:none}
.section-head.is-center{text-align:center;margin-inline:auto;max-width:none}
.section-head .eyebrow{margin-block-end:1.1rem}
.section-title{margin-block-end:1rem}
.section-head p{font-size:1.12rem;color:var(--ink-2)}
.section-head.is-center p{margin-inline:auto}

.text-emerald{color:var(--emerald)}
a.link{color:var(--emerald-700);font-weight:600;border-block-end:1.5px solid color-mix(in srgb,var(--emerald) 38%,transparent);transition:border-color .25s,color .25s}
a.link:hover{color:var(--emerald);border-color:var(--emerald)}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--pad-x)}
.container.--wide{max-width:1340px}
.container.--narrow{max-width:760px}
.section{padding-block:var(--section-y)}
.section.--tight{padding-block:clamp(3rem,6vw,5rem)}
.section.--alt{background:var(--sand-2)}
.section.--ink{background:var(--emerald-900);color:#EBE6D9}
.section.--ink h1,.section.--ink h2,.section.--ink h3{color:#FCFAF4}
.section.--ink .lead,.section.--ink p{color:#CBD8CF}
.section.--ink .eyebrow{color:#7FD9BE}
.section.--ink .eyebrow::before{background:#7FD9BE}

.grid{display:grid;gap:clamp(1.1rem,2.4vw,1.9rem)}
.grid.--2{grid-template-columns:repeat(2,1fr)}
.grid.--3{grid-template-columns:repeat(3,1fr)}
.grid.--4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.grid.--3,.grid.--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.grid.--2,.grid.--3,.grid.--4{grid-template-columns:1fr}}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ink);--fg:var(--sand);
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:.85em 1.45em;border-radius:var(--r-pill);
  font-weight:620;font-size:.98rem;letter-spacing:-.01em;line-height:1;
  background:var(--bg);color:var(--fg);
  border:1.5px solid transparent;
  transition:transform .25s var(--ease),box-shadow .3s,background .25s,color .25s,border-color .25s;
  will-change:transform;white-space:nowrap;
}
.btn svg{inline-size:1.05em;block-size:1.05em;transition:transform .3s var(--ease)}
html[lang="ar"] .btn svg{transform:scaleX(-1)}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn:active{transform:translateY(0) scale(.985)}
.btn:hover svg{transform:translateX(.18em)}
html[lang="ar"] .btn:hover svg{transform:scaleX(-1) translateX(.18em)}
.btn.--primary{--bg:var(--emerald);--fg:#fff}
.btn.--primary:hover{--bg:var(--emerald-600);box-shadow:var(--shadow-emerald)}
.btn.--outline{--bg:transparent;--fg:var(--ink);border-color:var(--line-2)}
.btn.--outline:hover{border-color:var(--ink);background:color-mix(in srgb,var(--ink) 5%,transparent)}
.btn.--ghost{--bg:transparent;--fg:var(--emerald-700);padding-inline:.4em}
.btn.--ghost:hover{box-shadow:none;color:var(--emerald)}
.btn.--lg{padding:1.05em 1.8em;font-size:1.05rem}
.section.--ink .btn.--outline{--fg:#FCFAF4;border-color:rgba(255,255,255,.28)}
.section.--ink .btn.--outline:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}

.pill,.badge{
  display:inline-flex;align-items:center;gap:.5em;
  padding:.42em .85em;border-radius:var(--r-pill);
  font-size:.8rem;font-weight:600;letter-spacing:-.005em;
  background:var(--emerald-tint);color:var(--emerald-700);
  border:1px solid color-mix(in srgb,var(--emerald) 16%,transparent);
}
.badge.--clay{background:color-mix(in srgb,var(--clay) 14%,transparent);color:var(--clay);border-color:color-mix(in srgb,var(--clay) 24%,transparent)}
.badge.--gold{background:color-mix(in srgb,var(--gold) 15%,transparent);color:#8a6420;border-color:color-mix(in srgb,var(--gold) 30%,transparent)}
.pill .dot{inline-size:.5em;block-size:.5em;border-radius:50%;background:var(--emerald);box-shadow:0 0 0 0 color-mix(in srgb,var(--emerald) 60%,transparent);animation:pulse 2.4s var(--ease-soft) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--emerald) 55%,transparent)}70%{box-shadow:0 0 0 .55em transparent}100%{box-shadow:0 0 0 0 transparent}}

/* ---------- Cards ---------- */
.card{
  background:var(--paper);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:clamp(1.5rem,3vw,2.1rem);
  box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease),box-shadow .4s,border-color .4s;
}
.card.--hover:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-2)}

.feature{position:relative;overflow:hidden}
.feature__icon{
  display:grid;place-items:center;inline-size:3.1rem;block-size:3.1rem;
  border-radius:var(--r-sm);margin-block-end:1.25rem;
  background:var(--emerald-tint);color:var(--emerald-700);
  border:1px solid color-mix(in srgb,var(--emerald) 14%,transparent);
}
.feature__icon svg{inline-size:1.5rem;block-size:1.5rem}
.feature h3{font-size:1.32rem;margin-block-end:.5rem;letter-spacing:-.01em}
html[lang="ar"] .feature h3{font-size:1.4rem}
.feature p{color:var(--ink-2);font-size:.98rem;max-width:42ch}
.feature.--accent{background:var(--emerald-900);border-color:transparent;color:#E7F0EB}
.feature.--accent h3{color:#fff}
.feature.--accent p{color:#C2D4CB}
.feature.--accent .feature__icon{background:rgba(255,255,255,.1);color:#9FE7CF;border-color:rgba(255,255,255,.16)}

/* bento spans (opt-in on .grid.--bento) */
.grid.--bento{grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(0,auto)}
.grid.--bento>.col-2{grid-column:span 2}
.grid.--bento>.col-3{grid-column:span 3}
.grid.--bento>.col-4{grid-column:span 4}
.grid.--bento>.col-6{grid-column:span 6}
@media (max-width:900px){.grid.--bento{grid-template-columns:repeat(2,1fr)}.grid.--bento>[class*="col-"]{grid-column:span 2}}

/* use-case */
.usecase{display:flex;flex-direction:column;gap:1rem}
.usecase .feature__icon{margin-block-end:.5rem}
.usecase ul{display:flex;flex-direction:column;gap:.55rem;margin-block-start:.3rem}
.usecase li{position:relative;padding-inline-start:1.5rem;color:var(--ink-2);font-size:.96rem}
.usecase li::before{content:"";position:absolute;inset-inline-start:0;inset-block-start:.55em;inline-size:.5rem;block-size:.5rem;border-radius:2px;background:var(--emerald);transform:rotate(45deg)}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,3vw,2.5rem)}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr);gap:2rem 1.5rem}}
.stat{display:flex;flex-direction:column;gap:.35rem}
.stat-num{font-family:var(--font-display);font-size:clamp(2.4rem,1.8rem + 2.4vw,3.4rem);font-weight:600;line-height:1;color:var(--emerald-700);letter-spacing:-.02em}
html[lang="ar"] .stat-num{font-family:var(--font-body)}
.stat-label{font-size:.92rem;color:var(--ink-2);font-weight:480}
.stat-rule{block-size:1px;background:var(--line-2);margin-block:0}

/* ---------- Hero ---------- */
.hero{position:relative;padding-block:clamp(3rem,7vw,6rem) clamp(3.5rem,8vw,7rem);overflow:hidden}
.hero__glow{position:absolute;z-index:0;inset-block-start:-18%;inset-inline-end:-10%;inline-size:min(60vw,720px);block-size:min(60vw,720px);
  background:radial-gradient(circle at 50% 50%,color-mix(in srgb,var(--emerald) 26%,transparent),transparent 62%);
  filter:blur(18px);pointer-events:none;opacity:.8}
.hero .container{position:relative;z-index:2}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:clamp(2rem,5vw,4.5rem)}
@media (max-width:940px){.hero__grid{grid-template-columns:1fr;gap:2.5rem}}
.hero h1{margin-block:1.2rem .9rem}
.hero h1 .ital{font-style:italic;color:var(--emerald-700)}
.hero__sub{max-width:34ch}
.hero__cta{margin-block-start:1.9rem}
.hero__trust{margin-block-start:2.2rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;color:var(--ink-3);font-size:.9rem}
.hero__media{position:relative}

/* ---------- Zig-zag feature rows ---------- */
.zigzag{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(2rem,5vw,4.5rem)}
.zigzag+.zigzag{margin-block-start:clamp(3.5rem,7vw,6rem)}
.zigzag:nth-child(even) .zigzag__media{order:-1}
@media (max-width:860px){.zigzag{grid-template-columns:1fr;gap:2rem}.zigzag:nth-child(even) .zigzag__media{order:0}}
.zigzag__body h3{font-size:clamp(1.6rem,1.2rem + 1.6vw,2.3rem);margin-block:.8rem .8rem}
.zigzag__list{display:flex;flex-direction:column;gap:.85rem;margin-block-start:1.4rem}
.zigzag__list li{display:flex;gap:.75rem;align-items:flex-start;color:var(--ink-2)}
.zigzag__list svg{flex:none;inline-size:1.35rem;block-size:1.35rem;color:var(--emerald);margin-block-start:.1rem}

/* ---------- Visual frame (mock surfaces) ---------- */
.frame{position:relative;border-radius:var(--r-xl);background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow-lg);overflow:hidden}
.frame__bar{display:flex;align-items:center;gap:.45rem;padding:.85rem 1.1rem;border-block-end:1px solid var(--line);background:color-mix(in srgb,var(--sand-2) 60%,var(--paper))}
.frame__bar i{inline-size:.7rem;block-size:.7rem;border-radius:50%;background:var(--line-2);display:block}
.frame__bar i:nth-child(1){background:#E0A98F}.frame__bar i:nth-child(2){background:#E5CB8C}.frame__bar i:nth-child(3){background:#9FC9B4}
.frame__body{padding:clamp(1rem,2.5vw,1.5rem)}
.float{animation:float 7s var(--ease-soft) infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ---------- Logo / trust cloud ---------- */
.logos{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(1.6rem,4vw,3.4rem)}
.logos span{font-family:var(--font-display);font-weight:600;font-size:1.25rem;color:var(--ink-3);opacity:.75;letter-spacing:-.01em;transition:opacity .3s,color .3s}
html[lang="ar"] .logos span{font-family:var(--font-body)}
.logos span:hover{opacity:1;color:var(--ink)}

/* marquee */
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;gap:3.5rem;width:max-content;animation:scroll-x 32s linear infinite}
html[lang="ar"] .marquee__track{animation-direction:reverse}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes scroll-x{to{transform:translateX(-50%)}}

/* ---------- Testimonials ---------- */
.testimonial{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.3rem);display:flex;flex-direction:column;gap:1.4rem;box-shadow:var(--shadow-sm)}
.testimonial .quote{font-family:var(--font-display);font-size:clamp(1.15rem,1rem + .6vw,1.4rem);line-height:1.4;color:var(--ink);font-weight:480}
html[lang="ar"] .testimonial .quote{font-family:var(--font-body);font-weight:500}
.testimonial .quote::before{content:"\201C";font-family:var(--font-display);color:var(--emerald);font-size:2.6rem;line-height:0;vertical-align:-.45em;margin-inline-end:.1em}
.author{display:flex;align-items:center;gap:.85rem;margin-block-start:auto}
.author .ava{inline-size:2.9rem;block-size:2.9rem;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);font-weight:600;color:#fff;background:var(--emerald-700);flex:none}
html[lang="ar"] .author .ava{font-family:var(--font-body)}
.author b{font-weight:640;font-size:.98rem}
.author span{display:block;font-size:.85rem;color:var(--ink-3)}
.stars{display:flex;gap:.15rem;color:var(--gold)}
.stars svg{inline-size:1.05rem;block-size:1.05rem}

/* ---------- FAQ ---------- */
.faq{display:flex;flex-direction:column;gap:.85rem}
.faq-item{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:border-color .3s,box-shadow .3s}
.faq-item[open]{border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.15rem 1.4rem;font-weight:600;font-size:1.05rem;list-style:none;cursor:pointer}
.faq-q::-webkit-details-marker{display:none}
.faq-q .ic{flex:none;inline-size:1.5rem;block-size:1.5rem;position:relative;transition:transform .35s var(--ease)}
.faq-q .ic::before,.faq-q .ic::after{content:"";position:absolute;inset-block-start:50%;inset-inline-start:50%;background:var(--emerald);border-radius:2px;transform:translate(-50%,-50%)}
.faq-q .ic::before{inline-size:1rem;block-size:2px}
.faq-q .ic::after{inline-size:2px;block-size:1rem;transition:transform .35s var(--ease)}
.faq-item[open] .faq-q .ic::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{padding:0 1.4rem 1.3rem;color:var(--ink-2);max-width:75ch}
.faq-item[open] .faq-a{animation:fade-in .4s var(--ease)}
@keyframes fade-in{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ---------- Pricing ---------- */
.price{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.1rem,2.5vw,1.8rem);align-items:start}
@media (max-width:960px){.price{grid-template-columns:1fr;max-width:460px;margin-inline:auto}}
.price-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.7rem,3vw,2.3rem);display:flex;flex-direction:column;gap:1.3rem;box-shadow:var(--shadow-sm);transition:transform .4s var(--ease),box-shadow .4s}
.price-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.price-card.--featured{background:var(--emerald-900);border-color:transparent;color:#E7F0EB;box-shadow:var(--shadow-lg);position:relative}
.price-card.--featured .price-name,.price-card.--featured .price-amount{color:#fff}
.price-card.--featured .price-desc,.price-card.--featured .price-list li{color:#C2D4CB}
.price-card.--featured .price-list svg{color:#9FE7CF}
.price-tag{position:absolute;inset-block-start:1.4rem;inset-inline-end:1.4rem}
.price-name{font-family:var(--font-display);font-size:1.4rem;font-weight:600;letter-spacing:-.01em}
html[lang="ar"] .price-name{font-family:var(--font-body)}
.price-amount{font-family:var(--font-display);font-size:clamp(2.4rem,2rem + 1.6vw,3rem);font-weight:600;line-height:1;letter-spacing:-.02em}
html[lang="ar"] .price-amount{font-family:var(--font-body)}
.price-amount small{font-family:var(--font-body);font-size:.95rem;font-weight:480;color:var(--ink-3)}
.price-card.--featured .price-amount small{color:#A9C2B7}
.price-desc{color:var(--ink-2);font-size:.95rem}
.price-list{display:flex;flex-direction:column;gap:.7rem;margin-block:.3rem}
.price-list li{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem;color:var(--ink-2)}
.price-list svg{flex:none;inline-size:1.2rem;block-size:1.2rem;color:var(--emerald);margin-block-start:.12em}
.price-cta{margin-block-start:auto}
.price-cta .btn{width:100%}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--emerald-900);color:#EDF3EF;border-radius:var(--r-xl);padding:clamp(2.6rem,6vw,4.5rem);text-align:center}
.cta-band::after{content:"";position:absolute;inset-block-start:-40%;inset-inline-start:50%;transform:translateX(-50%);inline-size:130%;block-size:120%;background:radial-gradient(circle at 50% 0,color-mix(in srgb,var(--emerald) 55%,transparent),transparent 60%);pointer-events:none}
.cta-band>*{position:relative;z-index:2}
.cta-band h2{color:#fff;margin-block-end:.9rem}
.cta-band p{color:#C7D7CD;margin-inline:auto;margin-block-end:2rem}
.cta-band .btn-row{justify-content:center}
.cta-band .btn.--outline{--fg:#fff;border-color:rgba(255,255,255,.3)}
.cta-band .btn.--outline:hover{border-color:#fff;background:rgba(255,255,255,.1)}

/* ---------- Forms ---------- */
.form{display:flex;flex-direction:column;gap:1.15rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.5rem}
.field label{font-weight:600;font-size:.92rem;color:var(--ink)}
.field .req{color:var(--clay)}
.field input,.field textarea,.field select{
  padding:.9em 1.05em;border-radius:var(--r-sm);
  background:var(--paper);border:1.5px solid var(--line-2);
  color:var(--ink);transition:border-color .25s,box-shadow .25s,background .25s;
}
.field textarea{resize:vertical;min-height:8.5rem}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3);opacity:.7}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--emerald);box-shadow:0 0 0 4px var(--emerald-tint)}
.field .help{font-size:.82rem;color:var(--ink-3)}
.form .btn{align-self:flex-start}
html[lang="ar"] .form .btn{align-self:flex-end}
.form-note{font-size:.85rem;color:var(--ink-3)}
.form-status{display:none;padding:.95rem 1.15rem;border-radius:var(--r-sm);font-size:.95rem;font-weight:500}
.form-status.is-on{display:block}
.form-status.--ok{background:var(--emerald-tint);color:var(--emerald-700);border:1px solid color-mix(in srgb,var(--emerald) 20%,transparent)}

/* ---------- Legal / prose ---------- */
.legal{max-width:760px}
.legal .updated{font-family:var(--font-mono);font-size:.82rem;color:var(--ink-3);letter-spacing:.02em;margin-block-end:2.4rem}
html[lang="ar"] .legal .updated{font-family:var(--font-body)}
.legal h2{font-size:clamp(1.4rem,1.2rem + 1vw,1.9rem);margin-block:2.6rem 1rem;padding-block-start:2.2rem;border-block-start:1px solid var(--line)}
.legal h2:first-of-type{border-block-start:none;padding-block-start:0;margin-block-start:1rem}
.legal h3{font-size:1.2rem;margin-block:1.6rem .6rem}
.legal p{margin-block-end:1rem;color:var(--ink-2);max-width:none}
.legal ul{display:flex;flex-direction:column;gap:.6rem;margin-block:1rem 1.5rem}
.legal ul li{position:relative;padding-inline-start:1.5rem;color:var(--ink-2)}
.legal ul li::before{content:"";position:absolute;inset-inline-start:.1rem;inset-block-start:.6em;inline-size:.45rem;block-size:.45rem;border-radius:2px;background:var(--emerald);transform:rotate(45deg)}
.legal a{color:var(--emerald-700);font-weight:600;text-decoration:underline;text-underline-offset:3px}

/* ---------- Page hero (interior pages) ---------- */
.pagehero{padding-block:clamp(3.5rem,8vw,6.5rem) clamp(2.5rem,5vw,4rem);position:relative}
.pagehero .eyebrow{margin-block-end:1.2rem}
.pagehero h1{font-size:clamp(2.4rem,1.7rem + 3.4vw,4rem);margin-block-end:1.1rem}
.pagehero p{font-size:clamp(1.1rem,1.02rem + .5vw,1.35rem);color:var(--ink-2);max-width:62ch}

/* =====================================================================
   CHROME (injected by main.js) — header, footer, WhatsApp, lang toggle
   ===================================================================== */
.site-header{position:sticky;inset-block-start:0;z-index:100;transition:background .3s,box-shadow .3s,border-color .3s;border-block-end:1px solid transparent}
.site-header.is-scrolled{background:color-mix(in srgb,var(--sand) 82%,transparent);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border-block-end-color:var(--line);box-shadow:0 6px 24px -18px rgba(33,28,22,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:1rem}
.brand{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-weight:600;font-size:1.4rem;letter-spacing:-.02em;color:var(--ink)}
html[lang="ar"] .brand{font-family:var(--font-body);font-weight:700}
.brand .glyph{inline-size:2.05rem;block-size:2.05rem;flex:none}
.nav-links{display:flex;align-items:center;gap:.35rem}
.nav-link{padding:.55em .85em;border-radius:var(--r-sm);font-weight:520;font-size:.97rem;color:var(--ink-2);transition:color .2s,background .2s}
.nav-link:hover{color:var(--ink);background:color-mix(in srgb,var(--ink) 5%,transparent)}
.nav-link.is-active{color:var(--emerald-700);font-weight:620}
.nav-right{display:flex;align-items:center;gap:.7rem}
.lang-toggle{display:inline-flex;align-items:center;gap:.4em;padding:.5em .85em;border-radius:var(--r-pill);border:1.5px solid var(--line-2);font-weight:600;font-size:.9rem;color:var(--ink);transition:border-color .2s,background .2s}
.lang-toggle:hover{border-color:var(--ink);background:color-mix(in srgb,var(--ink) 4%,transparent)}
.lang-toggle svg{inline-size:1.05em;block-size:1.05em;color:var(--emerald-700)}
.menu-btn{display:none;inline-size:2.7rem;block-size:2.7rem;border-radius:var(--r-sm);border:1.5px solid var(--line-2);place-items:center}
.menu-btn span{position:relative;inline-size:1.1rem;block-size:2px;background:var(--ink);border-radius:2px;transition:background .2s}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;inset-inline:0;block-size:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease)}
.menu-btn span::before{inset-block-start:-6px}.menu-btn span::after{inset-block-start:6px}
body.menu-open .menu-btn span{background:transparent}
body.menu-open .menu-btn span::before{transform:translateY(6px) rotate(45deg)}
body.menu-open .menu-btn span::after{transform:translateY(-6px) rotate(-45deg)}

@media (max-width:920px){
  .menu-btn{display:grid}
  .nav-links{position:fixed;inset-block-start:0;inset-inline-end:0;z-index:99;
    flex-direction:column;align-items:stretch;gap:.2rem;
    inline-size:min(82vw,340px);block-size:100dvh;padding:6rem 1.5rem 2rem;
    background:var(--paper);border-inline-start:1px solid var(--line);
    box-shadow:var(--shadow-lg);
    transform:translateX(100%);transition:transform .4s var(--ease);overflow-y:auto}
  html[dir="rtl"] .nav-links{transform:translateX(-100%)}
  body.menu-open .nav-links{transform:translateX(0)}
  .nav-link{font-size:1.15rem;padding:.7em .9em}
  .nav-links .btn{margin-block-start:1rem}
}

/* footer */
.footer{position:relative;z-index:2;background:var(--emerald-900);color:#C2D4CB;padding-block:clamp(3.5rem,7vw,5rem) 2.2rem;margin-block-start:0}
.footer a{transition:color .2s}
.footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:clamp(1.8rem,4vw,3rem)}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer-brand .brand{color:#fff;margin-block-end:1rem}
.footer-brand p{color:#A9C2B7;font-size:.95rem;max-width:34ch}
.footer-social{display:flex;gap:.6rem;margin-block-start:1.4rem}
.footer-social a{display:grid;place-items:center;inline-size:2.4rem;block-size:2.4rem;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.16);color:#C2D4CB}
.footer-social a:hover{background:rgba(255,255,255,.1);color:#fff}
.footer-social svg{inline-size:1.15rem;block-size:1.15rem}
.footer-col h4{font-family:var(--font-body);color:#fff;font-size:.85rem;font-weight:680;letter-spacing:.1em;text-transform:uppercase;margin-block-end:1.1rem}
html[lang="ar"] .footer-col h4{letter-spacing:0}
.footer-col ul{display:flex;flex-direction:column;gap:.7rem}
.footer-col a{color:#A9C2B7;font-size:.95rem}
.footer-bottom{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-block-start:clamp(2.5rem,5vw,3.5rem);padding-block-start:1.8rem;border-block-start:1px solid rgba(255,255,255,.13);color:#8FA99E;font-size:.88rem}
.footer-bottom .links{display:flex;gap:1.3rem;flex-wrap:wrap}

/* WhatsApp floating button */
.wa-fab{position:fixed;z-index:90;inset-block-end:clamp(1.1rem,3vw,1.7rem);inset-inline-end:clamp(1.1rem,3vw,1.7rem);
  display:inline-flex;align-items:center;gap:.65rem;
  padding:.7rem .7rem;border-radius:var(--r-pill);
  background:#1FA957;color:#fff;font-weight:620;font-size:.97rem;
  box-shadow:0 12px 30px -8px rgba(31,169,87,.55);
  transition:transform .3s var(--ease),box-shadow .3s,padding .3s}
.wa-fab:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 18px 38px -10px rgba(31,169,87,.65)}
.wa-fab .wa-ic{inline-size:2.5rem;block-size:2.5rem;flex:none;display:grid;place-items:center;background:rgba(255,255,255,.16);border-radius:50%}
.wa-fab .wa-ic svg{inline-size:1.5rem;block-size:1.5rem}
.wa-fab .wa-label{max-inline-size:0;overflow:hidden;white-space:nowrap;opacity:0;transition:max-inline-size .4s var(--ease),opacity .3s,margin .4s;margin-inline-end:0}
.wa-fab:hover .wa-label,.wa-fab:focus-visible .wa-label{max-inline-size:14rem;opacity:1;margin-inline-end:.4rem}
.wa-fab::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:0 0 0 0 rgba(31,169,87,.5);animation:wa-pulse 3s ease-out infinite;pointer-events:none}
@keyframes wa-pulse{0%{box-shadow:0 0 0 0 rgba(31,169,87,.45)}70%{box-shadow:0 0 0 16px rgba(31,169,87,0)}100%{box-shadow:0 0 0 0 rgba(31,169,87,0)}}
@media (max-width:560px){.wa-fab .wa-ic{inline-size:2.2rem;block-size:2.2rem}}

/* ---------- Scroll reveal ---------- */
html.js [data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js [data-reveal].is-visible{opacity:1;transform:none}
html.js [data-reveal][data-delay="1"]{transition-delay:.08s}
html.js [data-reveal][data-delay="2"]{transition-delay:.16s}
html.js [data-reveal][data-delay="3"]{transition-delay:.24s}
html.js [data-reveal][data-delay="4"]{transition-delay:.32s}
html.js [data-reveal][data-delay="5"]{transition-delay:.40s}
@media (prefers-reduced-motion:reduce){
  html.js [data-reveal]{opacity:1 !important;transform:none !important;transition:none}
  .float,.marquee__track,.pill .dot,.wa-fab::after{animation:none !important}
}

/* ---------- Helpers ---------- */
.mt-0{margin-block-start:0}.mt-1{margin-block-start:1rem}.mt-2{margin-block-start:2rem}.mt-3{margin-block-start:3rem}
.center{text-align:center}
.flow>*+*{margin-block-start:1.1rem}
.divider{block-size:1px;background:var(--line);border:0;margin-block:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
