/* ============================================================
   Salma — salma.fit
   Light clinical-premium design system. One stylesheet serves
   both the English (LTR) and Arabic (RTL) pages: layout uses
   logical properties, and html[lang="ar"] swaps the type system.
   ============================================================ */

/* ---------- Display face (bold grotesque, clean) ---------- */
@font-face{font-family:'Bricolage Grotesque';font-style:normal;font-weight:300 800;font-display:swap;
  src:url('/assets/fonts/bricolage-grotesque-300-800-latin.woff2') format('woff2')}

/* ---------- Tokens ---------- */
:root{
  --bone:#F6F3EC;          /* page ground — warm porcelain */
  --card:#FFFFFF;
  --ink:#17323B;           /* deep petrol-ink text */
  --ink-soft:#5A6E74;      /* secondary text */
  --petrol:#0C5C6E;        /* primary accent */
  --petrol-deep:#0A4756;   /* hover / dark band */
  --teal:#178578;          /* confirmations, positive marks */
  --clay:#B5453A;          /* red-flag moments only */
  --hairline:#E5DFD2;      /* warm rules */
  --hairline-strong:#D5CDBC;

  /* WhatsApp artifact — authentic colors live only inside .chat */
  --wa-head:#075E54;
  --wa-bg:#EFE8DE;
  --wa-out:#E2F6CE;
  --wa-tick:#4FB6EC;

  --font-display:'Bricolage Grotesque','Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-body:'IBM Plex Sans',system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  --font-chat:-apple-system,'Segoe UI',Roboto,'Helvetica Neue','IBM Plex Sans Arabic',Arial,sans-serif;

  --maxw:1320px;
  --radius:14px;
}
html[lang="ar"]{
  --font-display:'Amiri','Newsreader',Georgia,serif;
  --font-body:'IBM Plex Sans Arabic','IBM Plex Sans',system-ui,'Segoe UI',Tahoma,Arial,sans-serif;
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bone);color:var(--ink);
  font-family:var(--font-body);font-size:15.5px;line-height:1.62;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--petrol);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
:focus-visible{outline:2px solid var(--petrol);outline-offset:2px;border-radius:2px}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:24px}
.skip{position:absolute;inset-inline-start:-9999px;top:0;background:var(--ink);color:var(--bone);padding:10px 16px;z-index:1000;border-radius:0 0 8px 8px}
.skip:focus{inset-inline-start:16px}

/* ---------- Type ---------- */
h1,h2,h3{font-family:var(--font-display);font-weight:700;margin:0;color:var(--ink)}
h1{font-size:clamp(1.95rem,3.1vw,2.95rem);line-height:1.07;letter-spacing:-.025em}
h2{font-size:clamp(1.5rem,2.4vw,2.05rem);line-height:1.15;letter-spacing:-.02em;margin-bottom:14px}
h3{font-family:var(--font-body);font-weight:600;font-size:.98rem;line-height:1.4}
h1 em,h2 em{font-style:normal;color:var(--petrol)}
html[lang="ar"] h1{line-height:1.4;letter-spacing:0;font-weight:700;font-size:clamp(1.95rem,3.6vw,2.8rem)}
html[lang="ar"] h2{line-height:1.5;letter-spacing:0;font-weight:700}
html[lang="ar"] h1 em,html[lang="ar"] h2 em{font-style:normal}
p{margin:0 0 1em}
.lead{font-size:clamp(.98rem,1.15vw,1.08rem);color:var(--ink-soft);max-width:36em;line-height:1.62}
.muted{color:var(--ink-soft)}
.eyebrow{
  display:block;font-family:var(--font-body);font-weight:600;font-size:.7rem;
  letter-spacing:.15em;text-transform:uppercase;color:var(--petrol);margin-bottom:12px;
}
html[lang="ar"] .eyebrow{letter-spacing:0;font-size:.88rem}
.eyebrow.pill{
  display:inline-flex;align-items:center;gap:8px;border:1px solid var(--hairline-strong);
  background:#fff;border-radius:999px;padding:6px 13px 6px 11px;color:var(--ink-soft);
  letter-spacing:.06em;margin-bottom:20px;
}
.eyebrow.pill::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 3px rgba(23,133,120,.15)}
html[lang="ar"] .eyebrow.pill{letter-spacing:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--font-body);
  font-weight:600;font-size:.95rem;padding:13px 24px;border-radius:11px;cursor:pointer;
  background:var(--petrol);color:#fff;border:1px solid var(--petrol);
  transition:background .18s ease,transform .18s ease,box-shadow .18s ease;
  box-shadow:0 1px 2px rgba(23,50,59,.14),0 8px 22px -12px rgba(12,92,110,.55);
}
.btn:hover{background:var(--petrol-deep);border-color:var(--petrol-deep);transform:translateY(-1px);text-decoration:none}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--hairline-strong);box-shadow:none}
.btn.ghost:hover{border-color:var(--ink);background:transparent}
.btn.light{background:var(--bone);color:var(--petrol-deep);border-color:var(--bone)}
.btn.light:hover{background:#fff;border-color:#fff}
.btn.big{padding:14px 26px;font-size:.96rem;border-radius:12px}

/* ---------- Header ---------- */
header.site{
  position:sticky;top:0;z-index:50;background:rgba(246,243,236,.9);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--hairline);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-block:11px}
.brand{display:flex;align-items:center;gap:11px;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand .avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;object-position:50% 16%;border:1px solid var(--hairline-strong)}
.brand .wordmark{font-family:'Newsreader',serif;font-weight:600;font-size:1.5rem;letter-spacing:-.01em;line-height:1}
.brand .wordmark-ar{font-family:'Amiri',serif;font-weight:700;font-size:1.28rem;color:var(--petrol);line-height:1;margin-top:2px}
nav.links{display:flex;gap:28px;align-items:center}
nav.links a{color:var(--ink-soft);font-size:.93rem;font-weight:500}
nav.links a:hover{color:var(--ink);text-decoration:none}
nav.links a.lang{color:var(--petrol);font-weight:600;border:1px solid var(--hairline-strong);border-radius:8px;padding:5px 11px}
nav.links a.lang:hover{border-color:var(--petrol)}
html[lang="ar"] nav.links a.lang{font-family:'IBM Plex Sans',sans-serif}
nav.links .btn{padding:10px 18px;font-size:.9rem}
nav.links a.btn,nav.links a.btn:hover{color:#fff}
.burger{display:none;background:none;border:1px solid var(--hairline-strong);color:var(--ink);border-radius:9px;padding:8px 12px;cursor:pointer;font-family:var(--font-body);font-size:.9rem}

/* ---------- EKG divider (borrowed from the original — the clinic's pulse) ---------- */
.ekg{max-width:var(--maxw);margin:0 auto;padding:10px 24px}
.ekg svg{width:100%;height:36px;display:block}
.ekg path{fill:none;stroke-linecap:round;stroke-linejoin:round}
.ekg .base{stroke:var(--teal);stroke-width:2;opacity:.28}
.ekg .pulse{
  stroke:var(--teal);stroke-width:2.6;
  stroke-dasharray:46 1300;stroke-dashoffset:1346;
  filter:drop-shadow(0 0 7px rgba(23,133,120,.85));
  animation:ekgrun 2.6s linear infinite;
}
@keyframes ekgrun{from{stroke-dashoffset:1346}to{stroke-dashoffset:-46}}
@media (prefers-reduced-motion:reduce){.ekg .pulse{display:none}}

/* ---------- Sections ---------- */
section{padding-block:clamp(52px,6vw,84px)}
section.hairline{border-top:1px solid var(--hairline)}
.sect-head{max-width:600px;margin-bottom:clamp(30px,4vw,44px)}
.sect-head .lead{margin-bottom:0}

/* ---------- Hero ---------- */
.hero{padding-block:clamp(36px,4.5vw,64px) clamp(48px,6vw,80px)}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,4.5vw,64px);align-items:start}
.hero-grid > div:first-child{padding-top:clamp(4px,2vw,28px)}
.hero .lead{margin-block:15px 22px;max-width:30em}
.cta-row{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.cta-note{margin-top:16px;font-size:.82rem;color:var(--ink-soft)}
.cta-note b{color:var(--ink);font-weight:600}
.hero-more{font-size:.9rem;font-weight:500;color:var(--ink-soft)}
.hero-more:hover{color:var(--ink);text-decoration:none}
.hero-trust{list-style:none;padding:0;margin:20px 0 0;display:flex;flex-direction:column;gap:10px}
.hero-trust li{display:flex;gap:11px;align-items:flex-start;font-size:.9rem;line-height:1.45;color:var(--ink)}
.hero-trust svg{color:var(--teal);flex:0 0 auto;margin-top:3px;width:16px;height:16px}
.hero-trust b{font-weight:600}

/* ---------- Trust strip ---------- */
.trust{border-block:1px solid var(--hairline);padding-block:18px}
.trust .wrap{display:flex;gap:14px 40px;flex-wrap:wrap;align-items:center;justify-content:space-between}
.trust span{font-size:.84rem;color:var(--ink-soft);display:inline-flex;align-items:center;gap:9px}
.trust svg{color:var(--teal);flex:0 0 auto}

/* ---------- Hero inbox: a phone mockup with channel tabs (signature) ---------- */
.chat-col{position:relative}
.chat-col::before{content:"";position:absolute;inset:2% 0;z-index:0;pointer-events:none;
  background:radial-gradient(closest-side,rgba(23,133,120,.12),transparent 70%);filter:blur(24px)}
.inbox{position:relative;z-index:1;display:flex;flex-direction:column;gap:12px;width:min(320px,100%);margin-inline:auto}
.inbox-head{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--ink-soft);padding-inline:2px}
.inbox-head b{color:var(--ink);font-weight:600}
.inbox-head .iht{margin-inline-start:auto;font-size:.8rem}
.inbox-head .pulse{width:9px;height:9px;border-radius:50%;background:var(--teal);flex:0 0 auto;animation:pulse 2.2s ease-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(23,133,120,.45)}70%{box-shadow:0 0 0 10px rgba(23,133,120,0)}100%{box-shadow:0 0 0 0 rgba(23,133,120,0)}}
.cchat{border-radius:15px;overflow:hidden;border:1px solid var(--hairline-strong);background:#fff;
  box-shadow:0 1px 2px rgba(23,50,59,.08),0 18px 44px -24px rgba(23,50,59,.3)}
.cc-head{display:flex;align-items:center;gap:8px;padding:13px 16px 11px;font-size:.83rem;color:#fff}
.cc-head b{font-weight:600}
.cc-head span{opacity:.85;font-size:.76rem}
.cc-head span:last-child{margin-inline-start:auto}
.cchat.wa .cc-head{background:#075E54}
.cchat.ig .cc-head{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF)}
.cchat.ms .cc-head{background:#0084FF}
.cc-body{height:418px;padding:14px 11px;display:flex;flex-direction:column;gap:8px;justify-content:flex-end;overflow:hidden;font-family:var(--font-chat)}
@media (max-width:600px){.cc-body{height:58vh;max-height:460px}}
.cchat.wa .cc-body{background:#EFE8DE}
.cchat.ig .cc-body,.cchat.ms .cc-body{background:#FAFAFA}
.bb{position:relative;max-width:84%;padding:7px 11px;border-radius:15px;font-size:.9rem;line-height:1.4;box-shadow:0 1px 1px rgba(23,50,59,.06)}
.bb.in{align-self:flex-start;background:#fff;border:1px solid rgba(23,50,59,.08);border-start-start-radius:5px}
.cchat.ig .bb.in,.cchat.ms .bb.in{background:#EFEFEF;border:0}
.bb.out{align-self:flex-end;border-start-end-radius:5px}
.cchat.wa .bb.out{background:#DCF7C8;color:var(--ink)}
.cchat.ig .bb.out{background:linear-gradient(45deg,#7B3FC4,#D62E88);color:#fff}
.cchat.ms .bb.out{background:#0084FF;color:#fff}
.bb.done{align-self:center;display:inline-flex;gap:7px;align-items:center;background:rgba(23,133,120,.09);color:#0E6B60;
  border:1px solid rgba(23,133,120,.3);font-weight:600;font-size:.84rem;border-radius:999px;padding:6px 14px;box-shadow:none}
.bb.done svg{flex:0 0 auto}
/* channel tabs — click to switch conversation; auto-advances after each plays */
.chan-tabs{display:flex;gap:7px;justify-content:center;flex-wrap:wrap}
.chan-tabs button{
  display:inline-flex;align-items:center;gap:5px;cursor:pointer;
  border:1px solid var(--hairline-strong);background:#fff;color:var(--ink-soft);
  border-radius:999px;padding:7px 11px;font-family:var(--font-body);font-size:.76rem;font-weight:600;
  transition:background .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease;
}
.chan-tabs button svg{width:13px;height:13px}
.chan-tabs button:hover{color:var(--ink);border-color:var(--ink)}
.chan-tabs button svg{flex:0 0 auto}
.chan-tabs button.wa[aria-selected="true"]{background:#075E54;border-color:#075E54;color:#fff}
.chan-tabs button.ig[aria-selected="true"]{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF);border-color:transparent;color:#fff}
.chan-tabs button.ms[aria-selected="true"]{background:#0084FF;border-color:#0084FF;color:#fff}

/* the device — narrow, tall phone proportions */
.phone{position:relative;background:#0C1526;border-radius:40px;padding:11px 9px 13px;
  box-shadow:0 0 0 1px rgba(23,50,59,.1),0 40px 80px -26px rgba(23,50,59,.55),0 2px 6px rgba(23,50,59,.2)}
.phone::before{content:"";position:absolute;top:5px;left:50%;transform:translateX(-50%);
  width:34px;height:5px;border-radius:5px;background:rgba(255,255,255,.22);z-index:4}
.phone .cchat{border:0;border-radius:30px;box-shadow:none;overflow:hidden}
.cchat[hidden]{display:none}

/* live playback: each message (and the typing bubble before it) pops in */
.cc-body > *{animation:pop .32s ease}
.bb.typing{display:inline-flex;gap:4px;align-items:center;padding:11px 13px}
.bb.typing i{width:6px;height:6px;border-radius:50%;animation:tp 1.1s infinite}
.bb.typing i:nth-child(2){animation-delay:.18s}
.bb.typing i:nth-child(3){animation-delay:.36s}
.bb.typing.in i{background:rgba(23,50,59,.4)}
.cchat.wa .bb.typing.out i{background:rgba(23,50,59,.4)}
.cchat.ig .bb.typing.out i,.cchat.ms .bb.typing.out i{background:rgba(255,255,255,.85)}

/* ---------- WhatsApp chat (used on the Arabic page) ---------- */
.chat-col{display:flex;flex-direction:column;align-items:center;gap:14px}
.chat-tabs{display:flex;gap:6px;background:#fff;border:1px solid var(--hairline);border-radius:999px;padding:4px}
.chat-tabs button{
  border:0;background:transparent;border-radius:999px;padding:6px 16px;cursor:pointer;
  font-family:var(--font-body);font-size:.82rem;font-weight:600;color:var(--ink-soft);
  transition:background .2s ease,color .2s ease;
}
.chat-tabs button[aria-selected="true"]{background:var(--petrol);color:#fff}
.chat{
  width:min(430px,100%);border-radius:20px;overflow:hidden;background:var(--wa-bg);
  border:1px solid var(--hairline-strong);
  box-shadow:0 1px 3px rgba(23,50,59,.12),0 32px 72px -28px rgba(23,50,59,.4);
}
.chat-head{display:flex;align-items:center;gap:11px;background:var(--wa-head);color:#fff;padding:12px 16px}
.chat-head img{width:38px;height:38px;border-radius:50%;object-fit:cover;object-position:50% 16%}
.chat-head .who{line-height:1.25;min-width:0}
.chat-head .who b{font-family:var(--font-chat);font-size:.95rem;font-weight:600;display:flex;align-items:center;gap:6px}
.chat-head .who small{font-size:.74rem;opacity:.8;font-family:var(--font-chat)}
.chat-head svg.badge{flex:0 0 auto}
.chat-body{
  min-height:380px;padding:20px 16px;display:flex;flex-direction:column;gap:11px;
  overflow:hidden;justify-content:flex-end;font-family:var(--font-chat);
}
.msg{
  max-width:84%;padding:10px 13px 8px;border-radius:12px;font-size:.98rem;line-height:1.5;
  box-shadow:0 1px 1px rgba(23,50,59,.1);position:relative;
}
.msg .t{display:block;font-size:.66rem;color:rgba(23,50,59,.45);margin-top:3px;text-align:end;direction:ltr}
.msg.in{background:#fff;align-self:flex-start;border-start-start-radius:4px}
.msg.out{background:var(--wa-out);align-self:flex-end;border-start-end-radius:4px}
.msg.out .t{display:flex;justify-content:flex-end;align-items:center;gap:4px}
.msg.out .t svg{color:var(--wa-tick)}
.chat .date,.chat .chip{
  align-self:center;font-size:.7rem;padding:5px 12px;border-radius:999px;
  background:rgba(255,255,255,.85);color:var(--ink-soft);box-shadow:0 1px 1px rgba(23,50,59,.08);
}
.chat .chip{display:inline-flex;align-items:center;gap:7px;font-weight:600;color:var(--petrol)}
.chat .chip svg{flex:0 0 auto}
.chat .chip.ok svg{color:var(--teal)}
.chat .card{
  align-self:flex-end;max-width:84%;background:#fff;border-radius:12px;padding:12px 14px;
  border-inline-start:3px solid var(--teal);box-shadow:0 1px 2px rgba(23,50,59,.14);
}
.chat .card b{font-size:.9rem;display:flex;gap:8px;align-items:center}
.chat .card b svg{color:var(--teal);flex:0 0 auto}
.chat .card span{display:block;font-size:.8rem;color:var(--ink-soft);margin-top:3px}
.typing{display:inline-flex;gap:4px;padding:12px 14px}
.typing i{width:7px;height:7px;border-radius:50%;background:rgba(23,50,59,.4);animation:tp 1.1s infinite}
.typing i:nth-child(2){animation-delay:.18s}
.typing i:nth-child(3){animation-delay:.36s}
@keyframes tp{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
html.js .msg,html.js .chat .date,html.js .chat .chip,html.js .chat .card{animation:pop .3s ease both}
@keyframes pop{from{opacity:0;transform:translateY(9px) scale(.98)}to{opacity:1;transform:none}}
.chat-caption{font-size:.8rem;color:var(--ink-soft);text-align:center;max-width:420px}

/* ---------- Problem section ---------- */
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.problem-grid article{border-top:2px solid var(--hairline-strong);padding-top:20px}
.problem-grid .when{font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--clay);margin-bottom:10px;display:block}
html[lang="ar"] .problem-grid .when{letter-spacing:0}
.problem-grid h3{margin-bottom:8px}
.problem-grid p{font-size:.95rem;color:var(--ink-soft);margin:0}

/* ---------- How it works (3 steps) ---------- */
.hiw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3.5vw,44px)}
.hiw{position:relative;padding-top:6px}
.hiw + .hiw::before{content:"";position:absolute;inset-inline-start:calc(-1 * clamp(24px,3.5vw,44px) / 2);top:14px;bottom:14px;width:1px;background:var(--hairline)}
.hiw-num{display:block;font-family:var(--font-display);font-weight:700;font-size:2rem;line-height:1;
  letter-spacing:-.02em;color:transparent;-webkit-text-stroke:1.4px var(--hairline-strong)}
.hiw-ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
  background:rgba(23,133,120,.1);color:var(--petrol);margin:16px 0 13px}
.hiw h3{font-family:var(--font-display);font-weight:700;font-size:1.12rem;margin-bottom:8px}
.hiw p{color:var(--ink-soft);font-size:.94rem;margin:0;max-width:30ch}
.hiw:last-child .hiw-ic{background:rgba(12,92,110,.12)}
@media (max-width:760px){
  .hiw-grid{grid-template-columns:1fr;gap:26px}
  .hiw + .hiw::before{display:none}
}

/* ---------- Pathway (legacy — unused) ---------- */
.pathway{max-width:820px;position:relative}
.stage{
  display:grid;grid-template-columns:64px 1fr;gap:26px;position:relative;
  padding-block:34px;
}
.stage + .stage{border-top:1px dashed var(--hairline-strong)}
.stage .n{
  font-family:'Newsreader',serif;font-style:italic;font-size:2rem;color:var(--hairline-strong);
  line-height:1;padding-top:4px;
}
html[lang="ar"] .stage .n{font-family:'Amiri',serif;font-style:normal}
.stage .lbl{font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--petrol);display:block;margin-bottom:7px}
html[lang="ar"] .stage .lbl{letter-spacing:0;font-size:.85rem}
.stage h3{font-family:var(--font-display);font-weight:500;font-size:1.45rem;margin-bottom:8px}
html[lang="ar"] .stage h3{font-weight:700}
.stage p{color:var(--ink-soft);font-size:1rem;margin:0;max-width:36em}

/* ---------- Monday brief (memo artifact) ---------- */
.brief-split{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,6vw,72px);align-items:center}
.memo{
  background:var(--card);border:1px solid var(--hairline);border-radius:var(--radius);
  box-shadow:0 1px 3px rgba(23,50,59,.1),0 28px 60px -30px rgba(23,50,59,.3);
  padding:30px 32px;
}
.memo-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;border-bottom:1px solid var(--hairline);padding-bottom:16px;margin-bottom:8px}
.memo-head b{font-family:var(--font-display);font-size:1.15rem;font-weight:500}
html[lang="ar"] .memo-head b{font-weight:700}
.memo-head span{font-size:.76rem;color:var(--ink-soft)}
.memo-row{display:flex;gap:14px;padding-block:15px;align-items:flex-start}
.memo-row + .memo-row{border-top:1px dashed var(--hairline)}
.memo-row svg{flex:0 0 auto;margin-top:3px}
.memo-row .up{color:var(--teal)} .memo-row .add{color:var(--petrol)} .memo-row .down{color:var(--clay)}
.memo-row b{font-size:.95rem;display:block}
.memo-row span{font-size:.85rem;color:var(--ink-soft)}
.memo-foot{border-top:1px solid var(--hairline);margin-top:8px;padding-top:14px;font-size:.76rem;color:var(--ink-soft)}

/* ---------- Feature list ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--hairline);border:1px solid var(--hairline);border-radius:var(--radius);overflow:hidden}
.feat{background:var(--bone);padding:28px 26px}
.feat svg{color:var(--petrol);margin-bottom:14px}
.feat h3{margin-bottom:7px}
.feat p{font-size:.92rem;color:var(--ink-soft);margin:0}

/* ---------- UAE section ---------- */
.uae-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.uae-grid article{background:var(--card);border:1px solid var(--hairline);border-radius:var(--radius);padding:26px}
.uae-grid svg{color:var(--petrol);margin-bottom:12px}
.uae-grid h3{margin-bottom:6px}
.uae-grid p{font-size:.9rem;color:var(--ink-soft);margin:0}

/* ---------- Name section ---------- */
.name-sec{text-align:center}
.name-sec .glyph{
  font-family:'Amiri',serif;font-weight:700;font-size:clamp(4.5rem,10vw,7rem);
  color:var(--petrol);line-height:1.3;display:block;margin-bottom:6px;
}
.name-sec .lead{margin-inline:auto}
.name-sec .root{font-family:'Newsreader',serif;font-style:italic}

/* ---------- FAQ ---------- */
.faq{max-width:780px}
details.q{border-top:1px solid var(--hairline)}
details.q:last-child{border-bottom:1px solid var(--hairline)}
details.q summary{
  cursor:pointer;font-weight:600;font-size:1.02rem;padding-block:20px;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
details.q summary::-webkit-details-marker{display:none}
details.q summary .pm{color:var(--petrol);font-weight:500;font-size:1.4rem;line-height:1;transition:transform .25s ease;flex:0 0 auto}
details.q[open] summary .pm{transform:rotate(45deg)}
details.q p{color:var(--ink-soft);font-size:.98rem;margin:0;padding-bottom:22px;max-width:60ch}

/* ---------- Final CTA ---------- */
.cta-band{
  background:var(--petrol-deep);color:var(--bone);border-radius:24px;
  padding:clamp(44px,7vw,76px) clamp(28px,6vw,72px);text-align:center;
}
.cta-band h2{color:#fff;margin-bottom:22px;line-height:1.12}
.cta-band .lead{color:rgba(246,243,236,.78);margin-inline:auto;margin-bottom:34px;max-width:44ch}
.cta-band .cta-row{justify-content:center}
.cta-band .btn.ghost{color:var(--bone);border-color:rgba(246,243,236,.45)}
.cta-band .btn.ghost:hover{border-color:var(--bone)}

/* ---------- Footer ---------- */
footer.site{border-top:1px solid var(--hairline);padding-block:52px 32px;font-size:.9rem;color:var(--ink-soft)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:32px}
footer.site h4{color:var(--ink);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 14px;font-weight:600}
html[lang="ar"] footer.site h4{letter-spacing:0}
footer.site ul{list-style:none;padding:0;margin:0}
footer.site li{margin-block:8px}
footer.site a{color:var(--ink-soft)}
footer.site a:hover{color:var(--ink)}
.foot-brand p{max-width:34ch;margin-top:12px}
.copy{margin-top:40px;border-top:1px solid var(--hairline);padding-top:20px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;font-size:.84rem}

/* ---------- Long-form docs (legal pages + blog articles) ---------- */
.doc{max-width:760px;margin-inline:auto;padding-block:clamp(40px,6vw,72px)}
.doc h1{font-size:clamp(2rem,4vw,2.9rem);line-height:1.08;margin-bottom:10px}
.doc-meta{color:var(--ink-soft);font-size:.9rem;margin-bottom:32px;padding-bottom:22px;border-bottom:1px solid var(--hairline)}
.doc-meta a{color:var(--petrol)}
.prose{font-size:1rem;line-height:1.75;color:#33474E}
.prose > :first-child{margin-top:0}
.prose h2{font-size:1.3rem;line-height:1.3;margin:36px 0 10px;color:var(--ink)}
.prose h3{font-size:1.05rem;margin:26px 0 8px;color:var(--ink)}
.prose p{margin:0 0 1.1em}
.prose ul,.prose ol{padding-inline-start:22px;margin:0 0 1.1em}
.prose li{margin-block:6px}
.prose a{color:var(--petrol);text-decoration:underline;text-underline-offset:2px}
.prose strong{color:var(--ink);font-weight:600}
.prose code{background:rgba(23,50,59,.07);padding:2px 6px;border-radius:6px;font-size:.88em;font-family:ui-monospace,'SF Mono',monospace}
.prose blockquote{margin:20px 0;padding:4px 0 4px 20px;border-inline-start:3px solid var(--teal);color:var(--ink);font-size:1.08rem}
.prose .box{background:var(--card);border:1px solid var(--hairline);border-radius:12px;padding:18px 20px;margin:18px 0}
.prose .box p:last-child{margin-bottom:0}
.doc-back{display:inline-block;margin-top:34px;font-weight:600;color:var(--petrol)}
.doc-cta{margin-top:40px;padding:26px 28px;background:var(--card);border:1px solid var(--hairline);border-radius:var(--radius);display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.doc-cta p{margin:0;font-weight:600;color:var(--ink)}
.doc-cta .btn{flex:0 0 auto}

/* ---------- Blog listing ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:8px}
a.post-card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--hairline);border-radius:var(--radius);padding:26px 24px;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}
a.post-card:hover{border-color:var(--hairline-strong);box-shadow:0 16px 40px -26px rgba(23,50,59,.4);transform:translateY(-2px);text-decoration:none}
.post-card .cat{font-family:var(--font-body);font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--petrol);margin-bottom:12px}
.post-card h2{font-family:var(--font-display);font-weight:700;font-size:1.18rem;line-height:1.25;margin-bottom:8px;color:var(--ink);letter-spacing:-.01em}
.post-card p{color:var(--ink-soft);font-size:.92rem;margin:0 0 16px}
.post-card .rd{margin-top:auto;font-size:.8rem;color:var(--ink-soft)}
@media (max-width:680px){.blog-grid{grid-template-columns:1fr}}

/* ---------- Reveal (IntersectionObserver fallback when GSAP absent) ---------- */
html.js .reveal{opacity:0;transform:translateY(14px);transition:opacity .65s ease,transform .65s ease}
html.js .reveal.on{opacity:1;transform:none}

/* ---------- GSAP mode: JS owns all motion ---------- */
html.gsap .reveal{opacity:1;transform:none;transition:none}
html.gsap header.site{will-change:transform}
.split-line{will-change:transform}
.path-line{
  position:absolute;inset-inline-start:31px;top:14px;bottom:14px;width:2px;border-radius:2px;
  background:linear-gradient(180deg,var(--petrol),var(--teal));transform-origin:top center;pointer-events:none;
}
@media (max-width:600px){.path-line{display:none}}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  html.js .reveal{opacity:1;transform:none;transition:none}
  html.js .msg,html.js .chat .date,html.js .chat .chip,html.js .chat .card{animation:none}
  .typing i,.bb.typing i{animation:none}
  *{transition-duration:.01ms!important;animation-duration:.01ms!important}
}

/* ---------- Responsive ---------- */
@media (min-width:921px) and (max-height:880px){
  .chat-body{min-height:340px}
  .hero{padding-block:28px 48px}
}
@media (max-width:920px){
  .hero-grid,.brief-split{grid-template-columns:1fr}
  .problem-grid,.uae-grid{grid-template-columns:1fr 1fr}
  .feat-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  nav.links{
    display:none;position:absolute;top:100%;inset-inline:0;background:var(--bone);
    border-bottom:1px solid var(--hairline);flex-direction:column;align-items:flex-start;
    padding:20px 24px;gap:16px;
  }
  nav.links.open{display:flex}
  .burger{display:inline-block}
}
@media (max-width:600px){
  .problem-grid,.uae-grid,.feat-grid,.foot-grid{grid-template-columns:1fr}
  .stage{grid-template-columns:1fr;gap:6px}
  .stage .n{font-size:1.5rem}
  .cta-band{border-radius:18px}
}
