/* ============================================================
   makn.ai — modern design system
   Premium warm-dark theme · Space Grotesk + IBM Plex Mono
   ============================================================ */

:root {
  --ink: #15110e;          /* near-black espresso */
  --ink-2: #1c1714;
  --ink-3: #241d18;
  --ink-soft: #5e5346;
  --muted: #8a7c6a;
  --terra: #d77f54;        /* brighter accent for dark bg */
  --terra-1: #bc5b36;
  --terra-deep: #a8452a;
  --sand: #e8c9a0;
  --cream: #f3ead9;
  --cream-2: #f6f0e4;
  --paper: #faf6ee;
  --line: #e4d8c4;
  --line-dark: rgba(243,234,217,.12);
  --white: #fffdf9;

  --maxw: 1180px;
  --radius: 16px;
  --radius-lg: 26px;
  --shadow: 0 1px 2px rgba(21,17,14,.05), 0 12px 36px rgba(21,17,14,.07);
  --shadow-lg: 0 40px 90px rgba(21,17,14,.18);
  --glow: 0 0 60px rgba(215,127,84,.35);
  --font: 'Space Grotesk', system-ui, -apple-system, Segoe UI, sans-serif;
  --mono: 'IBM Plex Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --ease: cubic-bezier(.2,.7,.2,1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--font); color: var(--ink-2);
  background: var(--paper); line-height: 1.6; font-size: 18px;
  -webkit-font-smoothing: antialiased; overflow-x: hidden;
}

h1,h2,h3,h4 { font-weight: 700; line-height: 1.04; letter-spacing: -.03em; margin: 0 0 .5em; }
h1 { font-size: clamp(2.6rem, 6vw, 5rem); }
h2 { font-size: clamp(2rem, 4.4vw, 3.4rem); }
h3 { font-size: 1.35rem; letter-spacing: -.02em; }
p { margin: 0 0 1.1em; }
a { color: var(--terra-deep); text-decoration: none; }
a:hover { text-decoration: none; opacity: .85; }
em { font-style: normal; color: var(--terra-deep); }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 26px; }
.narrow { max-width: 860px; }

/* eyebrow / mono label */
.eyebrow {
  font-family: var(--mono); font-size: .8rem; letter-spacing: .16em;
  text-transform: uppercase; color: var(--terra-deep);
  margin: 0 0 1.1rem; display: inline-flex; align-items: center; gap: 8px;
}
.eyebrow::before { content:""; width: 22px; height:1px; background: var(--terra); display:inline-block; }
.bg-dark .eyebrow { color: var(--terra); }
.bg-dark .eyebrow::before { background: var(--terra); }

/* ============================================================
   Header
   ============================================================ */
.site-header {
  position: sticky; top: 0; z-index: 60;
  background: rgba(250,246,238,.72);
  backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--line);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 74px; }
.brand { font-size: 1.75rem; font-weight: 700; letter-spacing: -.05em; color: var(--ink); display: inline-flex; align-items: center; }
.brand .dot { color: var(--terra-1); }
.brand-ic { height: 30px; width: auto; margin-right: 9px; display: block; }
.nav-links { display: flex; align-items: center; gap: 32px; }
.nav-links a { color: var(--ink-soft); font-size: .98rem; font-weight: 500; }
.nav-links a:hover { color: var(--ink); }
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; }

/* ============================================================
   Buttons
   ============================================================ */
.btn {
  display: inline-flex; align-items:center; gap:8px; cursor: pointer;
  font-family: var(--font); font-weight: 600; font-size: 1rem;
  padding: 14px 26px; border-radius: 999px; border: 1.5px solid transparent;
  transition: transform .2s var(--ease), box-shadow .2s var(--ease), background .2s, color .2s, border-color .2s;
  line-height: 1; position: relative;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: var(--terra-1); color: var(--white); box-shadow: 0 10px 30px rgba(188,91,54,.32); }
.btn-primary:hover { background: var(--terra-deep); box-shadow: 0 16px 40px rgba(188,91,54,.42); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--ink); }
.btn-nav { background: #ffffff; color: var(--ink); border-color: var(--sand); box-shadow: 0 2px 10px rgba(21,17,14,.08); font-weight: 600; }
.btn-nav:hover { background: #ffffff; border-color: var(--terra-1); color: var(--terra-deep); }
.bg-dark .btn-ghost { color: var(--cream); border-color: var(--line-dark); }
.bg-dark .btn-ghost:hover { border-color: var(--cream); }
.btn-lg { padding: 17px 34px; font-size: 1.08rem; }
.btn-row { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }

/* ============================================================
   Sections / backgrounds
   ============================================================ */
section { padding: 96px 0; position: relative; }
.section-sm { padding: 60px 0; }
.bg-cream { background: var(--cream); }
.bg-paper { background: var(--paper); }
.bg-dark { background: var(--ink); color: var(--cream); }
.bg-dark h1, .bg-dark h2, .bg-dark h3, .bg-dark h4 { color: var(--white); }
.bg-dark p { color: #cbbca8; }
.center { text-align: center; }
.center .btn-row, .center .eyebrow { justify-content: center; }
.center .eyebrow { display: inline-flex; }
.lead { font-size: 1.24rem; color: var(--ink-soft); max-width: 660px; }
.bg-dark .lead { color: #cbbca8; }
.center .lead { margin-left: auto; margin-right: auto; }

/* ============================================================
   Scroll reveal
   ============================================================ */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .8s var(--ease), transform .8s var(--ease); will-change: opacity, transform; }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; } .reveal.d2 { transition-delay: .16s; }
.reveal.d3 { transition-delay: .24s; } .reveal.d4 { transition-delay: .32s; }
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .aurora::before, .aurora::after, .marquee-track, .mock-msg, .mock-chip, .mock-bar .live { animation: none !important; }
  .mock-msg, .mock-chip { opacity:1 !important; transform:none !important; }
  html { scroll-behavior: auto; }
}

/* visible keyboard focus */
a:focus-visible, .btn:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 3px solid var(--terra-2); outline-offset: 2px; border-radius: 6px;
}

/* ============================================================
   Trust strip
   ============================================================ */
.trust-strip {
  background: var(--ink); color: var(--cream);
  font-family: var(--mono); font-size: clamp(.82rem, 1.7vw, 1.04rem);
  letter-spacing: .05em; text-align: center; padding: 18px 24px;
}
.trust-strip b { color: var(--terra); font-weight: 500; }

/* ============================================================
   Hero
   ============================================================ */
/* light hero (inner pages) */
.hero { padding: 92px 0 60px; position: relative; overflow: hidden; }
.hero::after { content:""; position:absolute; right:-160px; top:-120px; width:480px; height:480px; border-radius:50%; background: radial-gradient(circle, rgba(215,127,84,.16), transparent 65%); z-index:0; }
.hero .wrap { position: relative; z-index: 1; }
.hero h1 { max-width: 16ch; }
.hero .lead { margin-top: 1.2rem; }

.hero-dark { background: var(--ink); color: var(--cream); position: relative; overflow: hidden; padding: 110px 0 96px; }
.hero-dark .lead { color: #cdbfac; }
.aurora { position:absolute; inset:0; z-index:0; pointer-events:none; }
.aurora::before, .aurora::after {
  content:""; position:absolute; border-radius:50%; filter: blur(70px); opacity:.5;
}
.aurora::before { width:560px; height:560px; right:-120px; top:-160px;
  background: radial-gradient(circle, rgba(215,127,84,.55), transparent 60%); animation: drift 14s ease-in-out infinite; }
.aurora::after { width:460px; height:460px; left:-140px; bottom:-180px;
  background: radial-gradient(circle, rgba(232,201,160,.35), transparent 60%); animation: drift 18s ease-in-out infinite reverse; }
@keyframes drift { 0%,100%{transform:translate(0,0)} 50%{transform:translate(40px,30px)} }
.hero-dark > .wrap { position: relative; z-index: 1; }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center; }
.hero-dark h1 { max-width: 15ch; }
.hero-dark .lead { font-size: 1.3rem; max-width: 540px; margin-top: 1.3rem; }
.hero-badge {
  display:inline-flex; align-items:center; gap:10px; padding:7px 14px 7px 8px;
  border:1px solid var(--line-dark); border-radius:999px; background: rgba(243,234,217,.04);
  font-size:.84rem; color: var(--sand); margin-bottom: 26px; font-family: var(--mono);
}
.hero-badge .pip { background: var(--terra); color: var(--ink); font-weight:600; padding:3px 9px; border-radius:999px; font-size:.74rem; letter-spacing:.04em; }
.microline { font-family: var(--mono); font-size: .8rem; color: var(--muted); margin-top: 22px; }

/* hero mock — animated agent → blueprint */
.mock {
  background: linear-gradient(180deg, rgba(36,29,24,.9), rgba(28,23,20,.92));
  border:1px solid var(--line-dark); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg), var(--glow); overflow:hidden; backdrop-filter: blur(6px);
}
.mock-bar { display:flex; align-items:center; gap:8px; padding:14px 18px; border-bottom:1px solid var(--line-dark); font-family:var(--mono); font-size:.76rem; color: var(--sand); }
.mock-bar .live { width:8px;height:8px;border-radius:50%;background:#5fbf7f; box-shadow:0 0 0 0 rgba(95,191,127,.6); animation: pulse 2s infinite; }
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(95,191,127,.5)}70%{box-shadow:0 0 0 9px rgba(95,191,127,0)}100%{box-shadow:0 0 0 0 rgba(95,191,127,0)}}
.mock-body { padding: 20px; min-height: 300px; display:flex; flex-direction:column; gap:12px; }
.mock-msg { max-width: 82%; padding: 11px 15px; border-radius: 13px; font-size:.95rem; line-height:1.45; opacity:0; transform: translateY(8px); animation: rise .5s var(--ease) forwards; }
.mock-msg.bot { background: rgba(243,234,217,.08); color: var(--cream); border-bottom-left-radius:4px; align-self:flex-start; }
.mock-msg.user { background: var(--terra-1); color: var(--white); border-bottom-right-radius:4px; align-self:flex-end; }
@keyframes rise { to { opacity:1; transform:none; } }
.mock-bp { margin-top:6px; border:1px solid var(--line-dark); border-radius:14px; padding:14px; background: rgba(21,17,14,.5); }
.mock-bp .mlabel { font-family:var(--mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color: var(--terra); margin-bottom:10px; }
.mock-chips { display:flex; flex-wrap:wrap; gap:7px; }
.mock-chip { font-size:.8rem; padding:6px 11px; border-radius:8px; background: rgba(243,234,217,.07); border:1px solid var(--line-dark); color: var(--cream); opacity:0; transform: scale(.9); animation: pop .4s var(--ease) forwards; }
@keyframes pop { to { opacity:1; transform:none; } }

/* ============================================================
   Marquee
   ============================================================ */
.marquee { overflow: hidden; padding: 26px 0; -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: 16px; width: max-content; animation: marquee 38s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes marquee { to { transform: translateX(-50%); } }
.mpill { display:inline-flex; align-items:center; gap:9px; white-space:nowrap; padding:11px 20px; border:1px solid var(--line); border-radius:999px; background: var(--white); font-size:.96rem; color: var(--ink-2); box-shadow: var(--shadow); }
.mpill .d { width:6px;height:6px;border-radius:50%;background: var(--terra-1); }
.bg-dark .mpill { background: rgba(243,234,217,.05); border-color: var(--line-dark); color: var(--cream); }

/* ============================================================
   Cards / grids
   ============================================================ */
.grid { display: grid; gap: 24px; }
.grid-2 { grid-template-columns: repeat(2,1fr); }
.grid-3 { grid-template-columns: repeat(3,1fr); }
.grid-4 { grid-template-columns: repeat(4,1fr); }

.card {
  background: var(--white); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 32px; box-shadow: var(--shadow);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s;
}
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--sand); }
.card h3 { margin-bottom: .45em; }
.card p { color: var(--ink-soft); margin: 0; font-size: 1.02rem; }
.bg-dark .card { background: rgba(243,234,217,.04); border-color: var(--line-dark); }
.bg-dark .card p { color: #c3b4a0; }
.bg-dark .card:hover { border-color: rgba(215,127,84,.5); }
.card .num {
  font-family: var(--mono); font-size: .95rem; color: var(--white); background: var(--terra-1);
  width: 42px; height: 42px; display:flex; align-items:center; justify-content:center;
  border-radius: 11px; margin-bottom: 18px; font-weight: 600;
}

.pillars { display: grid; grid-template-columns: repeat(2,1fr); gap: 22px; }
.pillar { padding: 26px; border-left: 3px solid var(--terra-1); background: var(--white); border-radius: 0 var(--radius) var(--radius) 0; box-shadow: var(--shadow); transition: transform .3s var(--ease); }
.pillar:hover { transform: translateX(4px); }
.pillar h3 { font-size: 1.18rem; } .pillar p { color: var(--ink-soft); margin:0; font-size: 1.02rem; }
.bg-dark .pillar { background: rgba(243,234,217,.04); }
.bg-dark .pillar p { color:#c3b4a0; }

/* ============================================================
   Stats
   ============================================================ */
.stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 30px; }
.stat { text-align: center; padding: 20px; }
.stat .val { font-size: clamp(2.6rem, 6vw, 4rem); font-weight: 700; letter-spacing: -.04em; color: var(--terra); line-height: 1; }
.stat .lab { font-family: var(--mono); font-size: .82rem; letter-spacing: .06em; text-transform: uppercase; color: var(--sand); margin-top: 12px; }

/* ============================================================
   Comparison table
   ============================================================ */
.compare { width:100%; border-collapse: collapse; background: var(--white); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.compare th, .compare td { padding: 18px 22px; text-align: left; border-bottom: 1px solid var(--line); font-size: 1.02rem; }
.compare thead th { background: var(--ink); color: var(--cream); font-family: var(--mono); font-size: .82rem; letter-spacing: .06em; text-transform: uppercase; }
.compare thead th:last-child { color: var(--terra); }
.compare td:first-child { color: var(--muted); font-family: var(--mono); font-size: .92rem; }
.compare td:last-child { font-weight: 600; color: var(--ink); }
.compare tbody tr { transition: background .2s; }
.compare tbody tr:hover { background: var(--cream-2); }
.compare tr:last-child td { border-bottom: 0; }

/* ============================================================
   Lead-magnet / generic flex helpers
   ============================================================ */
.magnet .card { display:flex; flex-direction:column; gap:14px; height:100%; }
.magnet .card .btn { align-self:flex-start; margin-top:auto; }

/* ============================================================
   Forms
   ============================================================ */
.form-card { background: var(--white); border:1px solid var(--line); border-radius: var(--radius-lg); padding: 40px; box-shadow: var(--shadow-lg); max-width: 560px; }
.field { margin-bottom: 18px; }
.field label { display:block; font-size:.92rem; font-weight:600; margin-bottom:6px; color: var(--ink); }
.field input, .field select, .field textarea { width:100%; padding:14px 16px; font-family:var(--font); font-size:1rem; border:1.5px solid var(--line); border-radius:11px; background: var(--paper); color: var(--ink); transition: border-color .2s, background .2s; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color: var(--terra-1); background: var(--white); }
.form-note { font-family: var(--mono); font-size:.78rem; color: var(--muted); margin-top: 14px; }
.form-success { display:none; } .form-success.show { display:block; }

/* ============================================================
   Footer
   ============================================================ */
.site-footer { background: var(--ink); color: var(--cream); padding: 72px 0 36px; }
.site-footer a { color: var(--cream); opacity: .8; font-size: .96rem; }
.site-footer a:hover { opacity: 1; }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 32px; margin-bottom: 44px; }
.footer-grid h4 { font-family: var(--mono); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color: var(--terra); margin-bottom: 14px; }
.footer-grid ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:9px; }
.footer-brand .brand { color: var(--white); }
.footer-brand p { color: var(--muted); font-size:.96rem; max-width: 30ch; margin-top: 12px; }
.footer-bottom { border-top:1px solid var(--line-dark); padding-top: 24px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:.85rem; color: var(--muted); font-family: var(--mono); }

/* ============================================================
   Misc
   ============================================================ */
.tag { display:inline-block; font-family: var(--mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color: var(--terra-deep); background: var(--cream); border:1px solid var(--sand); padding:5px 11px; border-radius:999px; }
.bg-dark .tag { background: rgba(215,127,84,.12); border-color: rgba(215,127,84,.3); color: var(--terra); }
hr.soft { border:0; border-top:1px solid var(--line); margin:0; }

/* ============================================================
   Product dashboard mock ("See what makn builds")
   ============================================================ */
.erp { max-width: 1040px; margin: 0 auto; border-radius: 18px; overflow: hidden; box-shadow: var(--shadow-lg), 0 0 90px rgba(215,127,84,.20); border: 1px solid rgba(243,234,217,.18); background: #ffffff; color: var(--ink-2); font-size: 15px; }
.erp-top { display:flex; align-items:center; gap:12px; padding:13px 18px; background: #f4efe6; border-bottom:1px solid var(--line); }
.erp-dots { display:flex; gap:7px; }
.erp-dots i { width:12px; height:12px; border-radius:50%; display:block; }
.erp-url { font-family:var(--mono); font-size:.82rem; color: var(--ink-soft); background:#fff; border:1px solid var(--line); border-radius:8px; padding:6px 14px; }
.erp-body { display:grid; grid-template-columns: 210px 1fr; min-height: 440px; }
.erp-side { background: var(--ink); color: var(--cream); padding:20px 14px; }
.erp-side .brand { font-size:1.35rem; color:#fff; margin:2px 0 22px 8px; display:block; }
.erp-nav { display:flex; flex-direction:column; gap:3px; }
.erp-nav a { display:flex; align-items:center; gap:11px; padding:11px 12px; border-radius:10px; font-size:.98rem; color:#d7c9b6; }
.erp-nav a .ic { font-size:1rem; width:20px; text-align:center; }
.erp-nav a.active { background: rgba(215,127,84,.18); color:#fff; font-weight:600; }
.erp-main { padding:24px 26px; background: #fbf8f2; }
.erp-h { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom:20px; flex-wrap:wrap; }
.erp-h h4 { margin:0; font-size:1.35rem; letter-spacing:-.02em; }
.erp-approve { display:inline-flex; align-items:center; gap:7px; font-size:.86rem; font-weight:600; color:#fff; background: var(--terra-1); padding:9px 15px; border-radius:10px; box-shadow:0 6px 16px rgba(188,91,54,.28); }
.kpis { display:grid; grid-template-columns: repeat(4,1fr); gap:14px; margin-bottom:20px; }
.kpi { background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px 18px; }
.kpi .l { font-size:.82rem; color:var(--ink-soft); font-weight:500; }
.kpi .v { font-size:1.7rem; font-weight:700; letter-spacing:-.02em; margin-top:8px; color: var(--ink); }
.kpi .v.t { color: var(--terra-1); }
.kpi .d { font-size:.76rem; color:#5b8f6a; margin-top:4px; font-weight:600; }
.erp-lower { display:grid; grid-template-columns: 1.5fr 1fr; gap:16px; }
.panel { background:#fff; border:1px solid var(--line); border-radius:14px; padding:18px; }
.panel .l { font-size:.95rem; font-weight:600; color:var(--ink); margin-bottom:14px; }
.otable { width:100%; border-collapse:collapse; font-size:.9rem; }
.otable th { text-align:left; font-size:.72rem; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); font-weight:600; padding:0 8px 10px; }
.otable td { padding:10px 8px; border-top:1px solid var(--line); color:var(--ink-2); }
.otable td.amt { font-weight:600; text-align:right; white-space:nowrap; }
.pill { font-size:.74rem; font-weight:600; padding:4px 10px; border-radius:999px; white-space:nowrap; }
.pill.paid { background:#e7f3ea; color:#3f8256; }
.pill.pend { background: var(--cream); color: var(--terra-deep); border:1px solid var(--sand); }
.appr-item { display:flex; align-items:center; gap:10px; padding:12px 0; border-bottom:1px solid var(--line); font-size:.9rem; }
.appr-item:first-of-type { padding-top:2px; }
.appr-item:last-child { border-bottom:0; }
.appr-item .badge { margin-left:auto; font-size:.72rem; font-weight:600; padding:4px 10px; border-radius:999px; white-space:nowrap; }
.appr-item .badge.wait { background: var(--cream); color: var(--terra-deep); border:1px solid var(--sand); }
.appr-item .badge.ok { background:#e7f3ea; color:#3f8256; }
@media (max-width:720px){
  .erp { font-size:14px; }
  .erp-body { grid-template-columns: 1fr; }
  .erp-side { display:none; }
  .kpis { grid-template-columns: repeat(2,1fr); }
  .erp-lower { grid-template-columns: 1fr; }
}

/* Ask-AI row */
.askai { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.askai a { display:inline-flex; align-items:center; gap:8px; padding:11px 18px; border-radius:999px; border:1px solid var(--line-dark); background:rgba(243,234,217,.05); color:var(--cream); font-size:.94rem; font-weight:500; transition:border-color .2s, transform .2s; }
.askai a:hover { border-color: var(--terra-2); transform: translateY(-2px); }
.askai a .k { width:7px;height:7px;border-radius:50%;background:var(--terra-2); }

/* works-with strip */
.workswith { display:flex; flex-wrap:wrap; gap:10px 14px; justify-content:center; align-items:center; }
.workswith .w { font-family:var(--mono); font-size:.82rem; color:var(--ink-soft); border:1px solid var(--line); border-radius:999px; padding:9px 16px; background:var(--white); }
.workswith .w b { color: var(--terra-deep); }

/* ============================================================
   Arabic / RTL
   ============================================================ */
[dir="rtl"] body, .ar body { }
.ar { font-family: 'Cairo', 'Tajawal', system-ui, sans-serif; }
.ar h1, .ar h2, .ar h3, .ar h4 { font-family: 'Cairo', system-ui, sans-serif; letter-spacing: 0; line-height: 1.25; }
.ar .lead, .ar p, .ar li, .ar .btn, .ar .nav-links a, .ar .field label { letter-spacing: 0; }
/* calligraphic Arabic wordmark */
.ar .brand { font-family: 'Aref Ruqaa', serif; font-size: 2.1rem; font-weight: 700; direction: rtl; }
.ar .brand .dot { display: none; }
[dir="rtl"] .brand-ic { margin-right: 0; margin-left: 11px; }
[dir="rtl"] .eyebrow::before { margin-left: 0; }
[dir="rtl"] .eyebrow { flex-direction: row-reverse; }
[dir="rtl"] .card .num { margin-left: auto; }
[dir="rtl"] .marquee-track { animation-direction: reverse; }
[dir="rtl"] .msg.user { align-self: flex-start; }
[dir="rtl"] .footer-bottom { font-family: 'Cairo', sans-serif; }
.lang-toggle { font-family: var(--mono); font-size: .82rem; color: var(--terra-deep) !important; border: 1px solid var(--sand); border-radius: 999px; padding: 6px 12px; }
.lang-toggle:hover { border-color: var(--terra-1); }
.ar .lang-toggle { font-family: 'Cairo', sans-serif; }

/* legal / prose pages */
.legal h2 { font-size: 1.5rem; letter-spacing:-.02em; }
.legal p { font-size: 1.06rem; color: var(--ink-soft); }
.legal a { text-decoration: underline; }
.bg-dark hr.soft { border-color: var(--line-dark); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 980px){
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .grid-3, .grid-4 { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px){
  body { font-size: 17px; }
  section { padding: 64px 0; }
  .nav-links { display:none; }
  .nav-links.open { display:flex; flex-direction:column; position:absolute; top:74px; left:0; right:0; background: var(--paper); border-bottom:1px solid var(--line); padding:18px 26px; gap:16px; }
  .nav-toggle { display:block; }
  .grid-2, .grid-3, .grid-4, .pillars, .stats { grid-template-columns: 1fr; }
  .stats { gap: 26px; }
  .hero-dark { padding: 72px 0 64px; }
  .form-card { padding: 26px; }
}
