/* ============================================================
   Nashir — Pricing page
   Light · minimal · developer-first
   ============================================================ */

@font-face{
  font-family:"SaudiRiyal";
  src:url("https://cdn.jsdelivr.net/npm/@emran-alhaddad/saudi-riyal-font/fonts/regular/saudi_riyal.woff2") format("woff2");
  font-weight:400 700; font-display:swap;
}

:root{
  /* type */
  --sans: "Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* surfaces */
  --page:  #f6f6f9;
  --card:  #ffffff;
  --raise: #ffffff;

  /* ink */
  --ink:   #16161d;
  --ink-2: #45454f;
  --muted: #74747f;
  --faint: #9a9aa4;

  /* lines */
  --line:   #e7e7ec;
  --line-2: #efeff3;

  /* brand */
  --brand:      #4A3FFF;
  --brand-ink:  #3a2fe0;
  --brand-deep: #2c22b8;
  --brand-tint: #f1f0ff;
  --brand-tint-2: #e7e5ff;
  --brand-soft: #b7b1ff;

  /* status */
  --ok: #1f9d57;

  --shadow-sm: 0 1px 2px rgba(20,20,40,.05), 0 1px 1px rgba(20,20,40,.04);
  --shadow-md: 0 4px 14px rgba(30,28,80,.07), 0 1px 3px rgba(20,20,40,.05);
  --shadow-lg: 0 18px 50px -18px rgba(55,48,180,.30), 0 6px 18px rgba(30,28,80,.08);

  --r-card: 18px;
  --r-ctrl: 10px;
  --maxw: 1280px;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
html[lang="ar"]{ --sans:"IBM Plex Sans Arabic", ui-sans-serif, system-ui, sans-serif; }

/* Saudi Riyal glyph (open-source webfont, U+20C1) */
.riyal{ font-family:"SaudiRiyal"; font-style:normal; line-height:1; display:inline-block; vertical-align:-0.02em; }
.cur-opt{ display:inline-flex; align-items:center; gap:5px; }
.cur-opt .riyal{ font-size:1.05em; }
/* numeral group — always LTR so the symbol sits left of the number */
.money{ direction:ltr; unicode-bidi:isolate; display:inline-flex; align-items:baseline; gap:.12em; }
.money .cur{ font-weight:600; }
.money.big{ font-size:inherit; }
body{
  margin:0;
  font-family:var(--sans);
  background:var(--page);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.5;
}
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
::selection{ background:var(--brand-tint-2); }

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

/* ---------- header ---------- */
.nav{
  position:sticky; top:0; z-index:40;
  background:rgba(246,246,249,.78);
  -webkit-backdrop-filter:blur(14px) saturate(150%);
  backdrop-filter:blur(14px) saturate(150%);
  border-bottom:1px solid var(--line);
}
.nav-in{
  height:64px; display:flex; align-items:center; justify-content:space-between;
}
.brand{ display:flex; align-items:center; gap:0; }
.brand img{ height:24px; width:auto; display:block; }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{
  font-size:14px; color:var(--ink-2); font-weight:500; letter-spacing:-.01em;
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a[aria-current]{ color:var(--brand-ink); }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.lang-btn{
  appearance:none; cursor:pointer; height:34px; padding:0 13px; border-radius:8px;
  border:1px solid var(--line); background:#fff; color:var(--ink-2);
  font-family:var(--sans); font-size:13.5px; font-weight:600; letter-spacing:-.01em;
  box-shadow:var(--shadow-sm); transition:border-color .15s, color .15s, background .15s;
}
.lang-btn:hover{ border-color:#d7d7df; color:var(--ink); background:#fcfcfd; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  height:44px; padding:0 18px; border-radius:var(--r-ctrl);
  font-size:14.5px; font-weight:600; letter-spacing:-.01em;
  border:1px solid transparent; cursor:pointer; white-space:nowrap;
  transition:transform .12s ease, background .15s ease, box-shadow .15s ease, border-color .15s;
}
.btn:active{ transform:translateY(1px); }
.btn-sm{ height:36px; padding:0 14px; font-size:13.5px; }
.btn-primary{ background:var(--brand); color:#fff; box-shadow:var(--shadow-sm); }
.btn-primary:hover{ background:var(--brand-ink); box-shadow:0 6px 18px -6px rgba(74,63,255,.55); }
.btn-ghost{ background:#fff; color:var(--ink); border-color:var(--line); box-shadow:var(--shadow-sm); }
.btn-ghost:hover{ border-color:#d7d7df; background:#fcfcfd; }
.btn-soft{ background:var(--brand-tint); color:var(--brand-ink); }
.btn-soft:hover{ background:var(--brand-tint-2); }
.btn-text{ background:transparent; color:var(--ink-2); }
.btn-text:hover{ color:var(--ink); }
.btn-block{ width:100%; }

/* ---------- hero ---------- */
.hero{ padding:74px 0 34px; text-align:center; }
.eyebrow{
  font-family:var(--mono); font-size:12px; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase; color:var(--brand-ink);
  display:inline-flex; align-items:center; gap:9px; margin:0 0 20px;
}
.eyebrow::before{ content:""; width:18px; height:1px; background:var(--brand-soft); }
.eyebrow::after{ content:""; width:18px; height:1px; background:var(--brand-soft); }
.hero h1{
  font-size:clamp(34px, 4.4vw, 56px); line-height:1.04; letter-spacing:-.03em;
  font-weight:700; margin:0 auto 18px; max-width:20ch; text-wrap:balance;
}
.hero h1 .accent{ color:var(--brand-ink); }
.hero p.sub{
  font-size:clamp(16px,1.4vw,18.5px); color:var(--muted); margin:0 auto;
  max-width:54ch; line-height:1.55; text-wrap:pretty;
}

/* trust strip */
.trust{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:center;
  gap:10px 22px; margin:30px auto 0; max-width:760px;
}
.trust span{
  display:inline-flex; align-items:center; gap:9px;
  font-size:13.5px; color:var(--ink-2); font-weight:500;
}
.trust span svg{ color:var(--brand); flex:none; }
.trust .dot{ width:3px; height:3px; border-radius:50%; background:var(--faint); }

/* ---------- controls bar ---------- */
.controls{
  display:flex; align-items:center; justify-content:center; gap:18px;
  flex-wrap:wrap; margin:38px 0 8px;
}
.segment{
  display:inline-flex; align-items:center; gap:4px;
  padding:4px; background:#eeeef2; border-radius:12px; position:relative;
  border:1px solid var(--line);
}
.segment button{
  appearance:none; border:0; background:transparent; cursor:pointer;
  position:relative; z-index:1; height:34px; padding:0 18px; border-radius:8px;
  font-size:13.5px; font-weight:600; color:var(--ink-2); letter-spacing:-.01em;
  display:inline-flex; align-items:center; gap:8px; transition:color .18s;
}
.segment button[aria-pressed="true"]{ color:var(--ink); }
.segment .seg-thumb{
  position:absolute; z-index:0; top:4px; bottom:4px; border-radius:8px;
  background:#fff; box-shadow:var(--shadow-sm);
  transition:left .2s cubic-bezier(.34,1.2,.4,1), width .2s cubic-bezier(.34,1.2,.4,1);
}
.save-badge{
  font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.02em;
  color:var(--ok); background:#e8f6ee; border-radius:6px; padding:3px 7px;
}
.ctrl-label{ font-size:13px; color:var(--muted); font-weight:500; }

/* ---------- plan grid ---------- */
.plans{
  display:grid; grid-template-columns:repeat(5, 1fr); gap:14px;
  margin:34px 0 14px; align-items:start;
}
.card{
  position:relative; background:var(--card); border:1px solid var(--line);
  border-radius:var(--r-card); padding:24px 22px 26px;
  display:flex; flex-direction:column; box-shadow:var(--shadow-sm);
  transition:box-shadow .2s, transform .2s, border-color .2s;
}
.card:hover{ box-shadow:var(--shadow-md); }
.card.featured{
  border-color:var(--brand); box-shadow:var(--shadow-lg);
  transform:translateY(-8px); z-index:2;
}
.card.featured:hover{ transform:translateY(-10px); }
.card.free{ background:linear-gradient(180deg,#fbfbff 0%, #ffffff 46%); border-color:#dedcf6; }

.ribbon{
  position:absolute; top:0; left:50%; transform:translate(-50%,-50%);
  font-family:var(--mono); font-size:10.5px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:#fff; background:var(--brand);
  padding:5px 12px; border-radius:999px; box-shadow:0 6px 16px -6px rgba(74,63,255,.7);
  white-space:nowrap;
}
.tag-line{ min-height:18px; margin:0 0 2px; }
.tag{
  font-family:var(--mono); font-size:10px; font-weight:600; letter-spacing:.08em;
  text-transform:uppercase; padding:3px 7px; border-radius:5px;
}
.tag.regulated{ color:var(--ink-2); background:#f0f0f4; }
.tag.freever{ color:var(--ok); background:#e8f6ee; }

.plan-name{ font-size:19px; font-weight:700; letter-spacing:-.02em; margin:2px 0 4px; }
.plan-desc{ font-size:12.8px; color:var(--muted); line-height:1.4; margin:0 0 18px; min-height:36px; }

.price-row{ display:flex; align-items:baseline; gap:3px; min-height:46px; }
.price{
  font-family:var(--mono); font-size:38px; font-weight:600; letter-spacing:-.04em;
  color:var(--ink); line-height:1; font-variant-numeric:tabular-nums;
}
.price .money.big{ font-family:var(--mono); font-size:38px; font-weight:600; letter-spacing:-.04em; }
.price .money.big .cur{ font-size:20px; font-weight:600; color:var(--ink-2); }
.price .money.big .riyal.cur{ font-size:25px; }
.per{ font-size:13px; color:var(--muted); font-weight:500; }
.price-note{ font-size:12px; color:var(--faint); margin:7px 0 0; font-family:var(--sans); min-height:16px; }
.price-note .money{ font-family:var(--mono); }
.price-note b{ color:var(--ok); font-weight:600; }
.contact-price{ font-family:var(--sans); font-size:24px; font-weight:700; letter-spacing:-.02em; line-height:1.1; }

.card .btn{ margin:20px 0 22px; }

.feat-head{
  font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.03em;
  color:var(--ink-2); margin:0 0 13px; padding-bottom:13px; border-bottom:1px solid var(--line-2);
}
.feat-head .em{ color:var(--brand-ink); }
.feats{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.feats li{ display:flex; gap:9px; font-size:13px; color:var(--ink-2); line-height:1.42; }
.feats li svg{ color:var(--brand); flex:none; margin-top:2px; }
.feats li b{ color:var(--ink); font-weight:600; }
.feats li .mono{ font-family:var(--mono); font-size:12px; }

/* Audience sub-header inside a plan's feats (e.g. Business: managed / BYOS) */
.feats li.feat-sub{
  display:block; margin:8px 0 -3px; padding-top:8px;
  border-top:1px dashed var(--line-2);
  font-family:var(--mono); font-size:11px; font-weight:600;
  letter-spacing:.04em; text-transform:uppercase; color:var(--muted);
}
.feats li.feat-sub:first-child{ border-top:0; padding-top:0; margin-top:0; }

/* Overage / metering footer row */
.feats li.feat-overage{
  margin-top:6px; padding-top:10px; border-top:1px dashed var(--line-2);
  color:var(--muted); font-size:12.5px;
}
.feats li.feat-overage svg{ color:var(--muted); opacity:.85; }
.feats li.feat-overage .mono{ color:var(--ink); }

/* ---------- comparison table ---------- */
.compare{ margin:72px 0 26px; }
.compare-h{ text-align:center; margin-bottom:34px; }
.compare-h h2{ font-size:clamp(26px,2.6vw,34px); letter-spacing:-.025em; font-weight:700; margin:0 0 10px; }
.compare-h p{ color:var(--muted); font-size:15.5px; margin:0; }

.table-shell{
  background:#fff; border:1px solid var(--line); border-radius:16px; overflow:hidden;
  box-shadow:var(--shadow-sm);
}
table.cmp{ width:100%; border-collapse:collapse; }
table.cmp th, table.cmp td{ text-align:center; padding:15px 14px; font-size:13.5px; }
table.cmp thead th{
  position:sticky; top:64px; background:#fff; z-index:5;
  border-bottom:1px solid var(--line); padding-top:18px; padding-bottom:18px;
}
.cmp-plan{ font-size:15px; font-weight:700; letter-spacing:-.01em; }
.cmp-plan.is-pro{ color:var(--brand-ink); }
.cmp-plan small{ display:block; font-family:var(--mono); font-size:10px; font-weight:500; letter-spacing:.04em; color:var(--muted); margin-top:3px; text-transform:none; }
.cmp-price{ font-family:var(--mono); font-size:13px; color:var(--ink-2); font-weight:600; margin-top:5px; font-variant-numeric:tabular-nums; }
table.cmp th:first-child, table.cmp td:first-child{
  text-align:start; padding-inline-start:24px; font-weight:600; color:var(--ink); width:22%;
}
table.cmp tbody tr{ border-bottom:1px solid var(--line-2); }
table.cmp tbody tr:last-child{ border-bottom:0; }
table.cmp tbody tr:hover{ background:#fafafb; }
.row-group td{
  text-align:start !important; padding:14px 24px !important;
  font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.08em;
  text-transform:uppercase; color:var(--faint); background:#fafafc;
}
html[lang="ar"] .row-group td{ letter-spacing:0; font-family:var(--sans); font-size:12px; }
html[lang="ar"] .feat-head{ letter-spacing:0; font-family:var(--sans); font-size:12.5px; }
html[lang="ar"] .eyebrow{ letter-spacing:.1em; }
.col-pro{ background:rgba(74,63,255,.035); }
table.cmp thead th.col-pro{ background:rgba(74,63,255,.05); }
td .val{ color:var(--ink-2); }
td .val.strong{ color:var(--ink); font-weight:600; }
td .val.mono{ font-family:var(--mono); font-size:12.5px; }
/* keep technical tokens (vCPU, MB, $/min, sizes) in LTR order inside RTL */
.mono, .val.mono, .price-note .money{ unicode-bidi:isolate; }
html[lang="ar"] .mono, html[lang="ar"] .val.mono{ direction:ltr; }
.save-badge{ unicode-bidi:isolate; direction:ltr; }
.tick{ color:var(--brand); }
.dash{ color:#cdcdd5; }

.overage{
  display:flex; flex-wrap:wrap; gap:10px 26px; justify-content:center;
  margin:22px auto 0; max-width:920px;
}
.overage span{ font-size:12.5px; color:var(--muted); display:inline-flex; align-items:center; gap:8px; }
.overage span .mono{ font-family:var(--mono); color:var(--ink-2); font-weight:600; }
.overage span svg{ color:var(--faint); flex:none; }

/* ---------- bottom cta ---------- */
.endcta{
  margin:60px 0 28px; padding:48px 40px; text-align:center;
  background:linear-gradient(135deg,#1a1530 0%, #2c22b8 60%, var(--brand) 130%);
  border-radius:22px; color:#fff; position:relative; overflow:hidden;
}
.endcta::after{
  content:""; position:absolute; inset:0;
  background:radial-gradient(620px 300px at 80% -20%, rgba(255,255,255,.16), transparent 60%);
  pointer-events:none;
}
.endcta h2{ font-size:clamp(24px,2.4vw,32px); letter-spacing:-.025em; margin:0 0 10px; position:relative; }
.endcta p{ color:rgba(255,255,255,.78); font-size:16px; margin:0 0 24px; position:relative; }
.endcta .btn-primary{ background:#fff; color:var(--brand-deep); }
.endcta .btn-primary:hover{ background:#f2f1ff; }
.endcta .btn-ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.34); box-shadow:none; }
.endcta .btn-ghost:hover{ background:rgba(255,255,255,.1); }
.endcta .row{ display:flex; gap:12px; justify-content:center; position:relative; }

footer.foot{ padding:30px 0 60px; text-align:center; color:var(--faint); font-size:12.5px; }
footer.foot .mono{ font-family:var(--mono); }

/* ---------- responsive ---------- */
@media (max-width:1180px){
  .plans{ grid-template-columns:repeat(2,1fr); gap:16px; }
  .card.featured{ transform:none; }
  .card.featured:hover{ transform:translateY(-2px); }
  .ribbon{ top:0; }
  .nav-links{ display:none; }
  .table-shell{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
  table.cmp{ min-width:820px; }
}
@media (max-width:680px){
  .wrap{ padding:0 16px; }
  .plans{ grid-template-columns:1fr; gap:14px; }
  .hero{ padding:46px 0 22px; }
  .nav-in{ height:58px; }
  .signin{ display:none; }
  .controls{ gap:12px 16px; margin-top:30px; }
  .trust{ gap:8px 16px; }
  table.cmp{ min-width:660px; }
  table.cmp th, table.cmp td{ padding:13px 11px; font-size:13px; }
  table.cmp th:first-child, table.cmp td:first-child{
    width:42%; padding-inline-start:16px;
    position:sticky; inset-inline-start:0; background:#fff; z-index:3;
    box-shadow:1px 0 0 var(--line-2);
  }
  html[lang="ar"] table.cmp th:first-child,
  html[lang="ar"] table.cmp td:first-child{ box-shadow:-1px 0 0 var(--line-2); }
  table.cmp tbody tr:hover td:first-child{ background:#fafafb; }
  table.cmp thead th{ top:0; }
  table.cmp thead th:first-child{ z-index:6; }
  .endcta{ padding:38px 22px; margin:48px 0 24px; }
  .endcta .row{ flex-direction:column; }
  .endcta .row .btn{ width:100%; }
  .compare{ margin-top:56px; }
}
