/* ============================================================
   Rihla (رحلة) — premium expat-finance & halal-investing theme
   Finance, relocation & halal investing for African
   professionals building a life in Europe.
   Static site (no Node/Python). Edit accent tokens below.
   ============================================================ */

:root {
  /* Palette: calming lavender + wellness green (UI/UX Pro Max). Light + WCAG-AA. */
  --bg:        #faf5ff;   /* calm lavender background */
  --bg-2:      #f3ecfd;
  --panel:     #ffffff;
  --ink:       #3b1d6e;   /* deep violet text — ~12:1 on bg */
  --ink-soft:  #5a4a82;   /* muted violet — AA body-secondary */
  --ink-faint: #8a7caa;
  --line:      #ece4fb;
  --teal:      #7c3aed;   /* PRIMARY violet (links/fills) — AA-safe vs old #8b5cf6 */
  --teal-deep: #5b21b6;
  --teal-soft: #f1ecfe;
  --gold:      #059669;   /* ACCENT wellness green (CTA) */
  --gold-soft: #d7f3e7;
  --gold-deep: #047857;
  --terra:     #7c3aed;   /* tertiary → violet (was terracotta) */
  --radius:    16px;
  --radius-sm: 12px;
  --shadow:    0 1px 2px rgba(76,29,149,.05), 0 10px 28px rgba(76,29,149,.08);
  --shadow-lg: 0 16px 44px rgba(76,29,149,.14);
  --maxw:      1140px;
  --readw:     730px;
  --serif:     "Lora", Georgia, "Times New Roman", serif;
  --sans:      "Raleway", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { margin: 0; font-family: var(--sans); color: var(--ink); background: var(--bg); line-height: 1.7; font-size: 17px; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }
a { color: var(--teal); text-decoration: none; }
a:hover { color: var(--teal-deep); }

h1,h2,h3,h4 { font-family: var(--serif); font-weight: 600; line-height: 1.18; color: var(--ink); letter-spacing: -.01em; }
h1 { font-size: clamp(2rem, 5vw, 3rem); }
h2 { font-size: clamp(1.5rem, 3.3vw, 2.05rem); }
h3 { font-size: 1.3rem; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 22px; }
.read { max-width: var(--readw); margin: 0 auto; padding: 0 22px; }

/* slim gradient accent line at the very top */
.zellige { height: 3px; background: linear-gradient(90deg, var(--teal), var(--gold) 55%, var(--teal-deep)); }

/* ---------- Header ---------- */
.site-head { position: sticky; top: 0; z-index: 50; background: rgba(250,245,255,.82); backdrop-filter: saturate(180%) blur(14px); -webkit-backdrop-filter: saturate(180%) blur(14px); border-bottom: 1px solid var(--line); box-shadow: 0 1px 0 rgba(124,58,237,.04), 0 8px 24px rgba(76,29,149,.05); }
.nav { display: flex; align-items: center; gap: 16px; max-width: var(--maxw); margin: 0 auto; padding: 14px 22px; }

/* brand: logo glyph + wordmark + divided tagline */
.brand { display: inline-flex; align-items: center; gap: 12px; color: var(--ink); font-family: var(--serif); font-weight: 700; font-size: 1.38rem; letter-spacing: -.015em; line-height: 1; }
.brand:hover { color: var(--ink); }
.brand .mark {
  width: 40px; height: 40px; border-radius: 12px; flex-shrink: 0;
  background:
    url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M4%2017%20Q12%204%2020%2017'%20fill='none'%20stroke='%23ffffff'%20stroke-width='2.3'%20stroke-linecap='round'/%3E%3Ccircle%20cx='12'%20cy='8.6'%20r='2'%20fill='%23d7f3e7'/%3E%3C/svg%3E") center/26px 26px no-repeat,
    linear-gradient(140deg, #8b5cf6 0%, var(--teal) 45%, var(--teal-deep) 100%);
  box-shadow: 0 6px 16px rgba(124,58,237,.38), inset 0 1px 0 rgba(255,255,255,.3);
  transition: transform .18s ease, box-shadow .18s ease;
}
.brand:hover .mark { transform: translateY(-1px) rotate(-3deg); box-shadow: 0 9px 22px rgba(124,58,237,.5), inset 0 1px 0 rgba(255,255,255,.35); }
.brand .mark::after { content: none; }
.brand-word { font-family: var(--serif); font-weight: 700; font-size: 1.38rem; letter-spacing: -.015em; line-height: 1; }
.brand small {
  display: inline-flex; align-items: center; flex-wrap: wrap; gap: 6px;
  padding-inline-start: 13px; margin-inline-start: 1px; border-inline-start: 1px solid var(--line);
}
.brand-pill {
  font-family: var(--sans); font-weight: 600; font-size: .7rem; letter-spacing: .01em;
  color: var(--ink-soft); background: rgba(124,58,237,.06); border: 1px solid var(--glass-brd, var(--line));
  border-radius: 999px; padding: 4px 11px; line-height: 1.15; white-space: nowrap;
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  transition: background .16s, color .16s, border-color .16s, transform .16s, box-shadow .16s;
}
a.brand-pill { cursor: pointer; }
a.brand-pill:hover { background: var(--teal-soft); color: var(--teal-deep); border-color: var(--teal); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(124,58,237,.18); }
a.brand-pill:focus-visible { outline: none; border-color: var(--teal); box-shadow: 0 0 0 3px var(--teal-soft); }
@media (max-width: 760px) { .brand small { display: none; } }

.nav-links { display: flex; gap: 2px; margin-inline-start: auto; align-items: center; }
.nav-links a { color: var(--ink-soft); font-size: .93rem; font-weight: 600; padding: 9px 14px; border-radius: 10px; transition: background .16s, color .16s; }
.nav-links a:hover { background: var(--teal-soft); color: var(--teal-deep); }
.nav-links a.active { background: var(--teal-soft); color: var(--teal-deep); }
.nav-links a.nav-cta { margin-inline-start: 6px; background: linear-gradient(135deg, #8b5cf6, var(--teal-deep)); color: #fff !important; padding: 10px 20px !important; border-radius: 999px !important; box-shadow: 0 8px 18px rgba(124,58,237,.32); }
.nav-links a.nav-cta:hover { filter: brightness(1.07); background: linear-gradient(135deg, #8b5cf6, var(--teal-deep)) !important; color: #fff !important; transform: translateY(-1px); }
.menu-btn { display: none; margin-inline-start: auto; background: var(--panel); border: 1px solid var(--line); border-radius: 11px; padding: 9px 12px; font-size: 1.15rem; line-height: 1; cursor: pointer; color: var(--teal-deep); box-shadow: var(--shadow); }
@media (max-width: 880px) {
  .nav-links { display: none; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; background: rgba(255,255,255,.98); backdrop-filter: blur(8px); padding: 12px; gap: 3px; border-bottom: 1px solid var(--line); box-shadow: var(--shadow-lg); }
  .nav-links.open { display: flex; }
  .nav-links a { padding: 13px 14px; }
  .nav-links a.nav-cta { margin: 6px 0 2px; text-align: center; }
  .menu-btn { display: block; }
}

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden; background:
  radial-gradient(900px 420px at 82% -12%, var(--teal-soft) 0%, transparent 62%),
  radial-gradient(680px 360px at 2% 115%, var(--gold-soft) 0%, transparent 58%), var(--bg);
  padding: 70px 0 60px; border-bottom: 1px solid var(--line); }
.hero .eyebrow { display: inline-flex; align-items: center; gap: 8px; background: #fff; border: 1px solid var(--line); color: var(--teal-deep); font-size: .8rem; font-weight: 600; letter-spacing: .03em; text-transform: uppercase; padding: 6px 14px; border-radius: 999px; box-shadow: var(--shadow); }
.hero h1 { margin: 20px 0 0; max-width: 17ch; }
.hero p.lede { font-size: 1.2rem; color: var(--ink-soft); max-width: 58ch; margin: 18px 0 28px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.btn { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; font-weight: 600; font-size: 1rem; padding: 13px 24px; border-radius: 999px; border: 1px solid transparent; transition: .18s; text-align: center; }
.btn-primary { background: var(--teal); color: #fff; box-shadow: 0 8px 22px rgba(124,58,237,.28); }
.btn-primary:hover { background: var(--teal-deep); color: #fff; transform: translateY(-1px); }
.btn-ghost { background: #fff; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--teal); color: var(--teal-deep); }
.btn-gold { background: var(--gold); color: #fff; box-shadow: 0 8px 22px rgba(5,150,105,.3); }
.btn-gold:hover { background: var(--gold-deep); color: #fff; }

.hero-stats { display: flex; gap: 30px; flex-wrap: wrap; margin-top: 36px; }
.hero-stats .s b { display: block; font-family: var(--serif); font-size: 1.7rem; color: var(--teal-deep); }
.hero-stats .s span { font-size: .85rem; color: var(--ink-faint); }

/* ---------- Sections ---------- */
.section { padding: 62px 0; }
.section-head { max-width: 62ch; margin-bottom: 34px; }
.section-head .kicker { color: var(--gold-deep); font-weight: 700; font-size: .82rem; letter-spacing: .08em; text-transform: uppercase; }
.section-head h2 { margin: 10px 0 8px; }
.section-head p { color: var(--ink-soft); font-size: 1.07rem; margin: 0; }

/* ---------- Pillar split ---------- */
.pillars-split { display: grid; gap: 22px; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }
.pillar-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 30px 28px; box-shadow: var(--shadow); border-top: 4px solid var(--teal); }
.pillar-card.gold { border-top-color: var(--gold); }
.pillar-card.terra { border-top-color: var(--terra); }
.pillar-card .ic { font-size: 1.7rem; }
.pillar-card h3 { margin: 12px 0 8px; font-size: 1.4rem; }
.pillar-card p { color: var(--ink-soft); font-size: .98rem; margin: 0 0 16px; }
.pillar-card ul { list-style: none; padding: 0; margin: 0 0 18px; }
.pillar-card li { padding: 6px 0 6px 24px; position: relative; font-size: .95rem; }
.pillar-card li::before { content: "→"; position: absolute; left: 0; color: var(--gold); font-weight: 700; }

/* ---------- Article cards ---------- */
.grid { display: grid; gap: 22px; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); transition: .2s; display: flex; flex-direction: column; }
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: #ddd5c2; }
.card .thumb { height: 150px; position: relative; display: grid; place-items: center; }
.card .thumb svg { width: 100%; height: 100%; }
.card .body { padding: 20px 22px 22px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.tag { align-self: flex-start; font-size: .7rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; padding: 4px 11px; border-radius: 999px; }
.tag.finance { color: var(--teal-deep); background: var(--teal-soft); }
.tag.immig { color: var(--terra); background: #f1ecfe; }
.tag.halal { color: var(--gold-deep); background: var(--gold-soft); }
.tag.life { color: #5b21b6; background: #f1ecfe; }
.card h3 { font-size: 1.2rem; margin: 2px 0; }
.card p { color: var(--ink-soft); font-size: .96rem; margin: 0; flex: 1; }
.card .meta { color: var(--ink-faint); font-size: .82rem; margin-top: 6px; }

/* ---------- CTA band ---------- */
.cta-band { background: linear-gradient(135deg, var(--teal-deep), var(--teal)); border-radius: 24px; padding: 48px 40px; color: #fff; text-align: center; box-shadow: var(--shadow-lg); position: relative; overflow: hidden; }
.cta-band::after { content:""; position: absolute; inset: 0; background: repeating-linear-gradient(45deg, transparent 0 18px, rgba(192,146,46,.06) 18px 36px); pointer-events: none; }
.cta-band h2 { color: #fff; position: relative; }
.cta-band p { color: rgba(255,255,255,.9); max-width: 52ch; margin: 12px auto 24px; position: relative; }
.subscribe { display: flex; gap: 10px; max-width: 460px; margin: 0 auto; flex-wrap: wrap; justify-content: center; position: relative; }
.subscribe input { flex: 1; min-width: 220px; padding: 13px 18px; border-radius: 999px; border: none; font-size: 1rem; font-family: inherit; }
.subscribe .btn { background: var(--gold); color: #fff; }
.subscribe .btn:hover { background: var(--gold-deep); }
.cta-band small { display: block; margin-top: 14px; color: rgba(255,255,255,.75); font-size: .82rem; position: relative; }

/* ---------- Article ---------- */
.article-head { background: var(--bg-2); border-bottom: 1px solid var(--line); padding: 46px 0 38px; }
.crumbs { font-size: .85rem; color: var(--ink-faint); margin-bottom: 16px; }
.crumbs a { color: var(--ink-soft); }
.article-head h1 { max-width: 24ch; margin: 8px 0 14px; }
.article-head .dek { font-size: 1.16rem; color: var(--ink-soft); max-width: 62ch; margin: 0; }
.byline { display: flex; align-items: center; gap: 12px; margin-top: 22px; }
.byline .avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--teal-soft); color: var(--teal-deep); display: grid; place-items: center; font-weight: 700; font-family: var(--serif); }
.byline .who { font-size: .9rem; line-height: 1.4; }
.byline .who b { color: var(--ink); }
.byline .who span { color: var(--ink-faint); }

.prose { padding: 42px 0 20px; }
.prose p, .prose ul, .prose ol { font-size: 1.08rem; color: #2b332e; }
.prose h2 { margin: 38px 0 14px; }
.prose h3 { margin: 26px 0 10px; }
.prose ul, .prose ol { padding-left: 1.3em; }
.prose li { margin: 8px 0; }
.prose blockquote { margin: 28px 0; padding: 18px 24px; border-left: 4px solid var(--gold); background: var(--gold-soft); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; font-family: var(--serif); font-size: 1.18rem; font-style: italic; color: var(--gold-deep); }
.prose .arabic { font-size: 1.45rem; line-height: 2; text-align: right; direction: rtl; color: var(--teal-deep); font-family: "Traditional Arabic","Scheherazade New",serif; }

/* data table */
.prose table { width: 100%; border-collapse: collapse; margin: 24px 0; font-size: .98rem; }
.prose th, .prose td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--line); }
.prose th { background: var(--teal-soft); color: var(--teal-deep); font-family: var(--sans); font-weight: 600; font-size: .85rem; }
.prose tr:last-child td { border-bottom: none; }

/* callouts */
.callout { border-radius: var(--radius); padding: 20px 24px; margin: 30px 0; border: 1px solid var(--line); background: var(--panel); box-shadow: var(--shadow); }
.callout h4 { margin: 0 0 6px; font-family: var(--sans); font-size: 1rem; font-weight: 700; display: flex; align-items: center; gap: 8px; }
.callout p { margin: 0; font-size: .98rem; color: var(--ink-soft); }
.callout.note { border-color: #ddd0fb; background: var(--teal-soft); }
.callout.note h4 { color: var(--teal-deep); }
.callout.warn { border-color: #ecd9b0; background: var(--gold-soft); }
.callout.warn h4 { color: var(--gold-deep); }
.callout.tip { border-color: #e6cdc2; background: #f7ece6; }
.callout.tip h4 { color: var(--terra); }
.callout.crisis { border-color: #e6c9bf; background: #f7ece6; }
.callout.crisis h4 { color: var(--terra); }

/* wellbeing pillar tags */
.tag.mind { color: var(--teal-deep); background: var(--teal-soft); }
.tag.faith { color: var(--gold-deep); background: var(--gold-soft); }

/* affiliate */
.affiliate { border: 1px solid var(--line); border-radius: var(--radius); padding: 26px; background: linear-gradient(180deg, #fff, var(--bg-2)); box-shadow: var(--shadow); margin: 34px 0; }
.affiliate .label { font-size: .7rem; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-faint); font-weight: 700; }
.affiliate h4 { font-family: var(--serif); font-size: 1.32rem; margin: 8px 0 6px; }
.affiliate p { margin: 0 0 16px; color: var(--ink-soft); font-size: .97rem; }

/* ad slots */
.ad-slot { margin: 34px auto; max-width: var(--readw); text-align: center; min-height: 90px; }
.ad-slot small { display: block; font-size: .66rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 6px; }

/* blended banner — sits quietly above the footer on every page */
.ad-blend { margin: 8px auto 0; padding: 18px 22px 24px; max-width: var(--maxw); text-align: center; border-top: 1px solid var(--line); }
.ad-blend .ad-blend__label { display: block; font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); opacity: .65; margin-bottom: 8px; }
.ad-blend ins { background: transparent; }

/* in-feed native unit — styled to read like a content card so it blends into the grid */
.ad-infeed { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px 18px; box-shadow: var(--shadow); min-height: 120px; display: flex; flex-direction: column; justify-content: center; }
.ad-infeed .ad-blend__label { font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); opacity: .55; margin-bottom: 8px; }

/* sources + bio */
.sources { border-top: 1px solid var(--line); margin-top: 40px; padding-top: 22px; font-size: .92rem; color: var(--ink-soft); }
.sources h4 { font-family: var(--sans); font-size: .95rem; margin: 0 0 8px; }
.sources ol { padding-left: 1.2em; }
.author-bio { display: flex; gap: 16px; align-items: flex-start; margin: 36px 0 0; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius); padding: 22px 24px; }
.author-bio .avatar { width: 56px; height: 56px; flex-shrink: 0; border-radius: 50%; background: var(--teal-soft); color: var(--teal-deep); display: grid; place-items: center; font-weight: 700; font-family: var(--serif); font-size: 1.3rem; }
.author-bio b { display: block; }
.author-bio p { margin: 4px 0 0; font-size: .93rem; color: var(--ink-soft); }
.related { background: var(--bg-2); border-top: 1px solid var(--line); }

/* footer */
.site-foot { background: #2e1065; color: #cbbfe6; padding: 52px 0 28px; }
.foot-grid { display: grid; gap: 32px; grid-template-columns: 1.4fr repeat(3, 1fr); }
.site-foot .brand { color: #fff; }
.site-foot h5 { color: #fff; font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; margin: 0 0 14px; font-family: var(--sans); }
.site-foot a { color: #aeb6af; display: block; padding: 5px 0; font-size: .93rem; }
.site-foot a:hover { color: #fff; }
.site-foot p.tag-desc { color: #8c958d; font-size: .9rem; margin: 14px 0 0; max-width: 34ch; }
.foot-bottom { border-top: 1px solid #2c3a34; margin-top: 36px; padding-top: 20px; font-size: .84rem; color: #828b83; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
@media (max-width: 760px) { .foot-grid { grid-template-columns: 1fr 1fr; } .hero-stats { gap: 20px; } }

.center { text-align: center; }
.disclosure-inline { font-size: .82rem; color: var(--ink-faint); font-style: italic; }

/* ---------- Language switcher ---------- */
.lang-switch {
  margin-left: 10px; padding: 7px 10px; border: 1px solid var(--line); border-radius: 999px;
  background: #fff; color: var(--ink-soft); font-family: inherit; font-size: .85rem; cursor: pointer;
}
.lang-switch:hover { border-color: var(--teal); color: var(--teal-deep); }
@media (max-width: 880px) { .lang-switch { margin: 6px 14px; width: calc(100% - 28px); } }

/* ---------- RTL (Arabic) ---------- */
[dir="rtl"] body { direction: rtl; }
[dir="rtl"] .nav-links { margin-left: 0; margin-right: auto; }
[dir="rtl"] .menu-btn { margin-left: 0; margin-right: auto; }
[dir="rtl"] .hero h1, [dir="rtl"] .hero p.lede, [dir="rtl"] .section-head,
[dir="rtl"] .pillar-card, [dir="rtl"] .article-head, [dir="rtl"] .prose { text-align: right; }
[dir="rtl"] .pillar-card li { padding: 6px 24px 6px 0; }
[dir="rtl"] .pillar-card li::before { left: auto; right: 0; content: "←"; }
[dir="rtl"] .crumbs, [dir="rtl"] .byline, [dir="rtl"] .hero-actions, [dir="rtl"] .hero-stats { flex-direction: row-reverse; }
[dir="rtl"] .prose blockquote { border-left: none; border-right: 4px solid var(--gold); border-radius: var(--radius-sm) 0 0 var(--radius-sm); }
[dir="rtl"] .callout, [dir="rtl"] .affiliate, [dir="rtl"] .sources { text-align: right; }
[dir="rtl"] .foot-grid, [dir="rtl"] .foot-bottom { text-align: right; }
[dir="rtl"] .byline .who, [dir="rtl"] .crumbs { text-align: right; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* ============================================================
   Interactive tools / calculators (light theme — same palette)
   ============================================================ */
.tool-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); padding: 22px 22px 20px; display: flex; flex-direction: column; gap: 7px; transition: transform .15s, border-color .15s; }
a.tool-card:hover { transform: translateY(-3px); border-color: #d8d0bf; color: var(--ink); }
.tool-card .tc-ic { width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; font-size: 1.35rem; background: var(--teal-soft); margin-bottom: 4px; }
.tool-card h3 { margin: 0; font-size: 1.14rem; }
.tool-card p { margin: 0; color: var(--ink-soft); font-size: .95rem; flex: 1; }
.tool-card .tc-go { color: var(--teal); font-weight: 700; font-size: .9rem; margin-top: 6px; }

.tool-wrap { display: grid; gap: 20px; grid-template-columns: 1fr; margin: 8px 0; }
.calc { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); padding: 24px; }
.calc h2, .calc h3 { margin-top: 0; }
.field { margin-bottom: 16px; }
.field > label { display: block; font-size: .92rem; font-weight: 600; color: var(--ink-soft); margin-bottom: 7px; }
.field .hint { font-size: .8rem; color: var(--ink-faint); margin-top: 5px; }
.input, select.input, textarea.input { width: 100%; padding: 12px 14px; font-size: 1rem; font-family: inherit; color: var(--ink); background: #fff; border: 1px solid var(--line); border-radius: var(--radius-sm); }
.input:focus { outline: none; border-color: var(--teal); box-shadow: 0 0 0 3px var(--teal-soft); }
.input-prefix { position: relative; }
.input-prefix > span { position: absolute; top: 50%; transform: translateY(-50%); inset-inline-start: 13px; color: var(--ink-faint); font-weight: 600; pointer-events: none; }
.input-prefix .input { padding-inline-start: 30px; }
input[type=range] { width: 100%; accent-color: var(--teal); }
.tool-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 16px; }

.result-card { background: linear-gradient(135deg, var(--teal-soft), var(--gold-soft)); border: 1px solid #ddd0fb; border-radius: var(--radius); padding: 24px; }
.result-card .lbl { color: var(--ink-soft); font-size: .9rem; }
.result-card .big { font-size: clamp(2rem, 6vw, 2.7rem); font-weight: 700; font-family: var(--serif); letter-spacing: -.02em; line-height: 1.1; color: var(--teal-deep); font-variant-numeric: tabular-nums; }
.result-grid { display: grid; gap: 12px; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); margin-top: 16px; }
.result-grid .cell { background: rgba(255,255,255,.7); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 12px 14px; }
.result-grid .cell b { display: block; font-size: 1.15rem; font-variant-numeric: tabular-nums; color: var(--ink); }
.result-grid .cell span { font-size: .8rem; color: var(--ink-faint); }
.badge { display: inline-block; padding: 4px 12px; border-radius: 999px; font-weight: 700; font-size: .85rem; }
.badge-good { color: var(--teal-deep); background: var(--teal-soft); }
.badge-warn { color: var(--gold-deep); background: var(--gold-soft); }
.badge-bad  { color: #b91c1c; background: #fbe3e3; }

.table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--radius-sm); margin: 14px 0; }
table.data { width: 100%; border-collapse: collapse; font-size: .9rem; font-variant-numeric: tabular-nums; }
table.data th, table.data td { padding: 10px 12px; text-align: end; white-space: nowrap; border-bottom: 1px solid var(--line); }
table.data th:first-child, table.data td:first-child { text-align: start; }
table.data thead th { background: var(--teal-soft); color: var(--teal-deep); font-weight: 700; font-family: var(--sans); }
.chart { width: 100%; height: auto; }
.chart .axis { stroke: var(--line); stroke-width: 1; }
.chart text { fill: var(--ink-faint); font-size: 11px; font-family: var(--sans); }

.faq details { border: 1px solid var(--line); border-radius: var(--radius-sm); margin-bottom: 10px; background: var(--panel); overflow: hidden; }
.faq summary { padding: 15px 18px; font-weight: 700; cursor: pointer; list-style: none; display: flex; justify-content: space-between; gap: 10px; color: var(--ink); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; color: var(--teal); font-size: 1.3rem; line-height: 1; }
.faq details[open] summary::after { content: "−"; }
.faq .ans { padding: 0 18px 16px; color: var(--ink-soft); }
.debt-row { display: grid; grid-template-columns: 1.4fr 1fr 1fr auto; gap: 8px; margin-bottom: 8px; align-items: center; }
@media (max-width: 560px) { .debt-row { grid-template-columns: 1fr 1fr; } }

/* floating Support / Donate button (light theme, RTL-aware, reduced-motion safe) */
.donate-fab { position: fixed; inset-block-end: 18px; inset-inline-end: 18px; z-index: 80; display: inline-flex; align-items: center; gap: 8px; padding: 12px 18px; border-radius: 999px; font-weight: 700; font-size: .92rem; color: #fff; background: linear-gradient(135deg, var(--gold), var(--terra)); border: 1px solid rgba(255,255,255,.4); box-shadow: 0 10px 28px rgba(124,58,237,.35); animation: donate-pulse 2.6s ease-in-out infinite; }
.donate-fab:hover { color: #fff; filter: brightness(1.05); }
@keyframes donate-pulse { 0%,100%{ box-shadow: 0 10px 28px rgba(124,58,237,.32); } 50%{ box-shadow: 0 10px 36px rgba(124,58,237,.6); } }
[dir="rtl"] .donate-fab { inset-inline-end: auto; inset-inline-start: 18px; }
@media (prefers-reduced-motion: reduce) { .donate-fab { animation: none; } }


/* ===== Floating action buttons: Support + Services (AMAADOR network) ===== */
.fab-stack{position:fixed;right:18px;bottom:18px;z-index:1200;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
[dir=rtl] .fab-stack{right:auto;left:18px;align-items:flex-start}
.fab-btn{display:inline-flex;align-items:center;height:54px;width:54px;border-radius:27px;padding:0;overflow:hidden;white-space:nowrap;border:1px solid var(--line);background:linear-gradient(135deg,var(--teal-deep),var(--teal));color:#fff;box-shadow:0 14px 34px -10px rgba(124,58,237,.55);cursor:pointer;text-decoration:none;font-family:inherit;font-weight:600;font-size:.92rem;transition:width .4s cubic-bezier(.16,1,.3,1),box-shadow .3s,transform .25s}
.fab-btn>span[aria-hidden]{flex:none;width:54px;height:54px;display:grid;place-items:center;font-size:1.3rem}
.fab-btn .fab-label{opacity:0;max-width:0;padding-right:0;transition:opacity .3s,max-width .4s,padding .4s}
[dir=rtl] .fab-btn .fab-label{padding-right:0}
.fab-btn:hover,.fab-btn:focus-visible{width:auto;text-decoration:none;color:#fff;transform:translateY(-2px);box-shadow:0 20px 44px -10px rgba(124,58,237,.6)}
.fab-btn:hover .fab-label,.fab-btn:focus-visible .fab-label{opacity:1;max-width:180px;padding-right:18px}
[dir=rtl] .fab-btn:hover .fab-label,[dir=rtl] .fab-btn:focus-visible .fab-label{padding-right:0;padding-left:18px}
.fab-donate{background:linear-gradient(135deg,var(--gold-deep),var(--gold))}
.fab-svc{position:relative;display:flex;justify-content:flex-end}
.fab-panel{position:absolute;bottom:64px;right:0;width:250px;max-height:62vh;overflow:auto;background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:0 24px 60px -16px rgba(46,16,101,.4);padding:8px;animation:fabIn .25s cubic-bezier(.16,1,.3,1)}
[dir=rtl] .fab-panel{right:auto;left:0}
.fab-panel[hidden]{display:none!important}
@keyframes fabIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.fab-panel-h{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:700;padding:8px 12px 6px}
.fab-panel a{display:block;padding:9px 12px;border-radius:9px;color:var(--ink-soft);text-decoration:none;font-size:.9rem;font-weight:500;transition:background .2s,color .2s}
.fab-panel a:hover{background:var(--teal-soft);color:var(--teal-deep);text-decoration:none}
.fab-panel a[aria-current]{color:var(--teal);font-weight:700}
.fab-panel a em{color:var(--ink-faint);font-style:normal;font-size:.76rem;font-weight:400}
@media(max-width:560px){.fab-stack{right:12px;bottom:12px;gap:10px}.fab-panel{width:min(82vw,250px)}.fab-btn{height:50px;width:50px}.fab-btn>span[aria-hidden]{width:50px;height:50px}}

/* AMAADOR Corporation network row in the footer */
.foot-network{border-top:1px solid rgba(255,255,255,.14);margin-top:20px;padding-top:16px;display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;font-size:.82rem;line-height:1.5}
.foot-network-h{font-weight:700;letter-spacing:.04em;opacity:.9;margin-right:4px}
.foot-network a{opacity:.72;text-decoration:none}
.foot-network a:hover{opacity:1;text-decoration:underline}
.foot-network a[aria-current]{opacity:1;font-weight:700;text-decoration:underline}

/* Mobile: wide data tables scroll horizontally instead of overflowing the page */
.table-wrap{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
@media(max-width:680px){
  table.data{display:block;width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
}

/* ============ PREMIUM DARK HEADER — "Midnight Slate Indigo" (calming palette via ui-ux-pro-max judge panel)
   Deep slate-indigo base; brand violet desaturated to a restful periwinkle; a single grounded green CTA;
   cool, low-arousal, AA/AAA throughout. ============ */
:root{
  --hd-bg-from:#161a2d; --hd-bg-to:#0f1320; --hd-hairline:rgba(184,192,224,.10);
  --hd-brand:#f3f5fd; --hd-brand-soft:#aab2d4;
  --hd-nav:#bcc4e4; --hd-nav-hover:#eef1fb; --hd-nav-hover-bg:rgba(139,145,201,.10);
  --hd-active-bg:#262b46; --hd-active:#dfe4f7;
  --hd-accent:#9aa2e0; --hd-accent-soft:rgba(154,162,224,.16);
  --hd-cta-from:#1f6f57; --hd-cta-to:#15634f;
  --hd-dd-bg:#141828; --hd-dd-brd:rgba(184,192,224,.12); --hd-dd-hover:#212640; --hd-dd-hover-text:#eef1fb;
  --hd-glow:rgba(91,143,126,.18); --hd-lang-bg:rgba(139,145,201,.08);
}
/* calming luminous top accent line (periwinkle -> sage -> teal, fading to transparent) */
.zellige{height:2px;background:linear-gradient(90deg,
  rgba(154,162,224,0) 0%, rgba(154,162,224,.40) 45%, rgba(91,143,126,.30) 72%, rgba(106,212,190,.18) 88%, rgba(154,162,224,0) 100%);}

.site-head{
  background:linear-gradient(180deg, var(--hd-bg-from), var(--hd-bg-to));
  -webkit-backdrop-filter:saturate(150%) blur(16px); backdrop-filter:saturate(150%) blur(16px);
  border-bottom:1px solid var(--hd-hairline);
  box-shadow:0 1px 0 rgba(255,255,255,.03), 0 18px 44px -16px rgba(8,10,20,.62);
}
/* brand wordmark + tagline */
.site-head .brand, .site-head .brand:hover{color:var(--hd-brand);}
.site-head .brand small{color:var(--hd-brand-soft);border-inline-start-color:var(--hd-hairline);}
/* logo mark recolored to periwinkle -> sage (brand hues, calmed) */
.site-head .brand .mark{
  background:
    url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M4%2017%20Q12%204%2020%2017'%20fill='none'%20stroke='%23ffffff'%20stroke-width='2.3'%20stroke-linecap='round'/%3E%3Ccircle%20cx='12'%20cy='8.6'%20r='2'%20fill='%23d7f3e7'/%3E%3C/svg%3E") center/26px 26px no-repeat,
    linear-gradient(140deg, #8b91c9 0%, #6f88ad 52%, #5b8f7e 100%);
  box-shadow:0 7px 20px -4px var(--hd-glow), inset 0 0 0 1px rgba(184,192,224,.12), inset 0 1px 0 rgba(255,255,255,.22);
}
.site-head .brand:hover .mark{box-shadow:0 10px 26px -4px rgba(91,143,126,.4), inset 0 1px 0 rgba(255,255,255,.28);}
/* tagline glass pill on dark */
.site-head .brand-pill{color:var(--hd-brand-soft);background:var(--hd-accent-soft);border-color:var(--hd-dd-brd);}
.site-head a.brand-pill:hover{background:rgba(154,162,224,.26);color:var(--hd-nav-hover);border-color:var(--hd-accent);box-shadow:0 4px 12px -2px var(--hd-glow);}
.site-head a.brand-pill:focus-visible{border-color:var(--hd-accent);box-shadow:0 0 0 3px var(--hd-accent-soft);}
/* nav links */
.site-head .nav-links a{color:var(--hd-nav);}
.site-head .nav-links a:hover{background:var(--hd-nav-hover-bg);color:var(--hd-nav-hover);}
.site-head .nav-links a.active{background:var(--hd-active-bg);color:var(--hd-active);}
.site-head .nav-links a.nav-cta,
.site-head .nav-links a.nav-cta:hover{
  background:linear-gradient(135deg, var(--hd-cta-from), var(--hd-cta-to)) !important;
  color:#fff !important; box-shadow:0 8px 22px -6px rgba(31,111,87,.55);
}
.site-head .nav-links a.nav-cta:hover{filter:brightness(1.08); transform:translateY(-1px);}
/* mobile hamburger button */
.menu-btn{background:var(--hd-accent-soft);border:1px solid var(--hd-dd-brd);color:var(--hd-brand);box-shadow:none;}
.menu-btn:hover{background:rgba(154,162,224,.22);}
/* "Content" dropdown */
.nav-dd{position:relative;display:inline-flex;}
.nav-dd-btn{display:inline-flex;align-items:center;gap:6px;color:var(--hd-nav);font-family:inherit;font-size:.93rem;font-weight:600;padding:9px 14px;border:0;background:none;border-radius:10px;cursor:pointer;transition:background .16s,color .16s;}
.nav-dd-btn:hover,.nav-dd.open>.nav-dd-btn{background:var(--hd-nav-hover-bg);color:var(--hd-nav-hover);}
.nav-dd-btn:focus-visible{outline:2px solid var(--hd-accent);outline-offset:2px;}
.nav-dd-btn .dd-caret{transition:transform .2s;opacity:.72;}
.nav-dd.open>.nav-dd-btn .dd-caret{transform:rotate(180deg);}
/* panel: HARD default-hidden; only .open (JS) or desktop hover/focus reveals it */
.nav-dd-menu{
  position:absolute; top:calc(100% + 10px); inset-inline-start:0; min-width:262px; display:none;
  background:linear-gradient(180deg, #181d31, var(--hd-dd-bg));
  -webkit-backdrop-filter:blur(18px); backdrop-filter:blur(18px);
  border:1px solid var(--hd-dd-brd); border-radius:16px;
  box-shadow:0 28px 70px -20px rgba(5,7,16,.78), inset 0 1px 0 rgba(184,192,224,.06);
  padding:8px; z-index:60;
}
@keyframes ddIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.nav-dd.open>.nav-dd-menu{display:block;animation:ddIn .18s ease-out;}
@media(hover:hover) and (min-width:881px){.nav-dd:hover>.nav-dd-menu,.nav-dd:focus-within>.nav-dd-menu{display:block;animation:ddIn .18s ease-out;}}
.nav-dd-menu a{display:block;padding:11px 14px;border-radius:11px;color:var(--hd-nav) !important;font-size:.9rem;font-weight:600;background:none !important;transition:background .16s,color .16s,padding-inline-start .16s;}
.nav-dd-menu a:hover,.nav-dd-menu a.active{background:var(--hd-dd-hover) !important;color:var(--hd-dd-hover-text) !important;padding-inline-start:18px;}
/* language switch */
.site-head .nav-links select,.site-head #rihla-lang{background:var(--hd-lang-bg);color:var(--hd-brand);border:1px solid var(--hd-dd-brd);border-radius:10px;padding:7px 10px;}
.site-head .nav-links select:hover{border-color:var(--hd-accent);}
.site-head .nav-links select option{color:#1a1030;background:#fff;}
/* mobile (<=880px, matches the hamburger breakpoint — fixes the old 761-880 seam) */
@media(max-width:880px){
  .site-head .nav-links{background:linear-gradient(180deg, #141828, #0f1320);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--hd-dd-brd);box-shadow:0 24px 50px -18px rgba(5,7,16,.72);}
  .nav-dd{display:block;width:100%;}
  .nav-dd-btn{width:100%;justify-content:space-between;padding:13px 14px;}
  .nav-dd-menu{position:static;display:none;min-width:0;border:0;background:none;box-shadow:none;padding:2px 0 6px 14px;-webkit-backdrop-filter:none;backdrop-filter:none;animation:none;}
  .nav-dd.open>.nav-dd-menu{display:block;animation:none;}
}
@media(prefers-reduced-motion:reduce){.nav-dd-menu{animation:none !important}.nav-dd-btn .dd-caret{transition:none}}
