/* ───────────────────────────────────────────────────────────────────────────
   وش نطبخ اليوم؟ — نظام التصميم «الهادئ» (Serene)
   سيج ناعم + عاجي دافئ + لمسة طينيّة. حواف ناعمة، ظلال خفيفة، خطوط راقية.
   كل ألوان النص تعدّي WCAG AA. RTL بخصائص منطقية.
   ─────────────────────────────────────────────────────────────────────────── */

/* ── خطوط مستضافة ذاتياً (self-hosted) — تشتغل خلف CSP fontSrc 'self' وداخل السعودية ──
   النصّ (body): IBM Plex Sans Arabic. خطّ العرض الموثّق هو Readex Pro (CDN في بيئة
   الإنتاج)؛ عند غيابه نرجع لـ IBM Plex فلا يسقط النص لخطّ النظام أبداً. */
@font-face { font-family: "IBM Plex Sans Arabic"; font-weight: 300; font-style: normal; font-display: swap; src: url("/fonts/IBMPlexSansArabic-Light.ttf") format("truetype"); }
@font-face { font-family: "IBM Plex Sans Arabic"; font-weight: 400; font-style: normal; font-display: swap; src: url("/fonts/IBMPlexSansArabic-Regular.ttf") format("truetype"); }
@font-face { font-family: "IBM Plex Sans Arabic"; font-weight: 500; font-style: normal; font-display: swap; src: url("/fonts/IBMPlexSansArabic-Medium.ttf") format("truetype"); }
@font-face { font-family: "IBM Plex Sans Arabic"; font-weight: 600; font-style: normal; font-display: swap; src: url("/fonts/IBMPlexSansArabic-Bold.ttf") format("truetype"); }
@font-face { font-family: "IBM Plex Sans Arabic"; font-weight: 700; font-style: normal; font-display: swap; src: url("/fonts/IBMPlexSansArabic-Bold.ttf") format("truetype"); }

:root {
  /* ── خلفيات (أبيض نظيف بأسلوب iOS) ──────────────────── */
  --color-bg: #FFFFFF;          /* خلفية بيضاء نقية */
  --color-surface: #FFFFFF;     /* بطاقات بيضاء */
  --color-raised: #FFFFFF;
  --color-sand: #F2F4F1;        /* مسار/تعبئة رمادية خفيفة */
  --color-sand-2: #F4F6F3;      /* hover */

  /* ── أساسي: سيج أوضح وأشبع ──────────────────────────── */
  --color-primary: #3F7D5C;        /* أغمق وأوضح من قبل */
  --color-primary-hover: #336B4D;
  --color-primary-dark: #2C5A40;   /* عناوين/نص أخضر */
  --color-primary-soft: #E3F0E8;   /* تعبئة خضراء فاتحة على أبيض */

  /* ── لكنة: طينيّ أوضح ────────────────────────────────── */
  --color-accent: #C26A3D;         /* أشبع */
  --color-accent-dark: #9C4F2A;    /* نص لكنة */
  --color-accent-soft: #FBEADF;

  /* ── نص (أغمق للوضوح) ───────────────────────────────── */
  --color-ink: #1C2621;     /* شبه أسود مخضرّ */
  --color-muted: #586259;   /* ثانوي أوضح */
  --color-faint: #6A7269;

  /* ── حدود أوضح (رمادية على أبيض) ────────────────────── */
  --color-border: #E3E6E2;
  --color-border-strong: #CDD2CC;

  /* ── دلالي ───────────────────────────────────────────── */
  --color-success: #3F7D5C;
  --color-success-soft: #E3F0E8;
  --color-danger: #B23A2E;
  --color-whatsapp: #2C5A40;
  --color-whatsapp-bg: #F2F4F1;

  /* ── خطوط ───────────────────────────────────────────── */
  --font-display: "Readex Pro", "IBM Plex Sans Arabic", system-ui, sans-serif;
  --font-body: "IBM Plex Sans Arabic", system-ui, sans-serif;

  /* ── مقياس النص ─────────────────────────────────────── */
  --text-display: 2.85rem;
  --text-h1: 2.1rem;
  --text-h2: 1.6rem;
  --text-h3: 1.3rem;
  --text-lg: 1.13rem;
  --text-body: 1rem;
  --text-sm: 0.875rem;
  --text-caption: 0.8rem;

  /* ── مسافات (4px) ───────────────────────────────────── */
  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem;
  --space-4: 1rem; --space-5: 1.5rem; --space-6: 2rem;
  --space-8: 3rem; --space-12: 4.5rem;

  /* ── حواف ناعمة ─────────────────────────────────────── */
  --radius-sm: 10px; --radius-md: 16px; --radius-lg: 22px; --radius-xl: 28px;
  --radius-pill: 999px;

  /* ── ظلال خفيفة دافئة (طبقات، شفافية منخفضة) ─────────── */
  --shadow-xs: 0 1px 2px rgba(66,52,42,0.04);
  --shadow-sm: 0 1px 2px rgba(66,52,42,0.04), 0 4px 12px rgba(66,52,42,0.05);
  --shadow-md: 0 2px 4px rgba(66,52,42,0.05), 0 10px 26px rgba(66,52,42,0.07);
  --shadow-lg: 0 4px 8px rgba(66,52,42,0.06), 0 18px 42px rgba(66,52,42,0.10);

  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

* { box-sizing: border-box; }
html { font-size: 17.5px; }
html, body { overflow-x: hidden; max-inline-size: 100%; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.85;
  color: var(--color-ink);
  background: var(--color-bg);
  letter-spacing: 0;            /* لا تباعد على العربية أبداً */
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3 {
  font-family: var(--font-display);
  line-height: 1.28;
  margin: 0 0 var(--space-3);
  font-weight: 700;
  color: var(--color-ink);
  letter-spacing: 0;
}
p { margin: 0 0 var(--space-3); }
a { color: var(--color-primary-hover); text-decoration: none; }
img { max-inline-size: 100%; display: block; }

/* أرقام مصطفّة للكميات والسعرات */
.num, .nutri__cal, .macro__v, .day-card__cal b, .wa-item__pack, .ing__qty, .dish__cal {
  font-variant-numeric: tabular-nums;
}

.container { max-inline-size: 920px; margin-inline: auto; padding-inline: var(--space-5); }
.container--narrow { max-inline-size: 640px; }

/* ── شريط سدو هادئ (رفيع، منخفض الحدّة) ─────────────────── */
.sadu-band {
  block-size: 10px;
  background-image: url('/sadu-band.svg');
  background-repeat: repeat-x;
  background-size: auto 100%;
  opacity: 0.85;
}

/* ── الترويسة ──────────────────────────────────────────── */
.appbar {
  background: color-mix(in srgb, var(--color-surface) 88%, transparent);
  backdrop-filter: saturate(1.1) blur(8px);
  border-block-end: 1px solid var(--color-border);
  position: sticky; inset-block-start: 0; z-index: 10;
}
.appbar__inner { display: flex; align-items: center; gap: var(--space-3); padding-block: var(--space-3); }
.brand { display: flex; align-items: center; gap: var(--space-3); }
.brand__logo { inline-size: 42px; block-size: 42px; flex: none; }
.brand__name { font-family: var(--font-display); font-size: var(--text-h3); font-weight: 700; color: var(--color-primary-dark); }
.brand__tag { font-size: var(--text-caption); color: var(--color-muted); margin-block-start: -4px; }
.appbar__nav { margin-inline-start: auto; display: flex; gap: var(--space-1); }
.appbar__nav a {
  font-size: var(--text-sm); font-weight: 500; color: var(--color-muted);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-pill);
  transition: background-color 150ms var(--ease), color 150ms var(--ease);
}
.appbar__nav a:hover { background: var(--color-sand-2); }
.appbar__nav a.is-active { color: var(--color-primary-dark); background: var(--color-primary-soft); font-weight: 600; }

/* ── أزرار هادئة ───────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font-family: inherit; font-size: var(--text-lg); font-weight: 600;
  min-block-size: 48px; padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-md); border: 1px solid transparent; cursor: pointer;
  transition: background-color 180ms var(--ease), border-color 180ms var(--ease),
              box-shadow 180ms var(--ease), transform 180ms var(--ease);
}
.btn:active { transform: translateY(1px); }
.btn:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--color-bg), 0 0 0 5px color-mix(in srgb, var(--color-primary) 55%, transparent); }
.btn--primary { background: var(--color-primary-hover); color: #fff; box-shadow: var(--shadow-xs); }
.btn--primary:hover { background: var(--color-primary-dark); }
.btn--accent { background: var(--color-accent-dark); color: #fff; box-shadow: var(--shadow-xs); }
.btn--accent:hover { background: #95593f; }
.btn--ghost { background: var(--color-surface); color: var(--color-ink); border-color: var(--color-border-strong); }
.btn--ghost:hover { background: var(--color-sand-2); }
.btn--block { display: flex; inline-size: 100%; }
.btn--lg { font-size: var(--text-h3); padding-block: var(--space-4); }
.btn .icon { inline-size: 20px; block-size: 20px; }

/* ── شرائح/وسوم ─────────────────────────────────────────── */
.chips { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: var(--text-sm); font-weight: 500;
  padding: 6px var(--space-3); border-radius: var(--radius-pill);
  background: var(--color-surface); border: 1px solid var(--color-border); color: var(--color-muted);
  white-space: nowrap;
}
.chip--green { background: var(--color-primary-soft); border-color: transparent; color: var(--color-primary-dark); }
.chip--gold { background: var(--color-accent-soft); border-color: transparent; color: var(--color-accent-dark); }

/* ── بطاقات ────────────────────────────────────────────── */
.card {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); overflow: hidden;
}
.card__pad { padding: var(--space-5); }

/* ── الرئيسية: البطل ───────────────────────────────────── */
.hero { text-align: center; padding-block: var(--space-8) var(--space-5); }
.hero__kicker { color: var(--color-accent-dark); font-weight: 600; font-size: var(--text-sm); margin-block-end: var(--space-2); }
.hero__title { font-size: var(--text-display); color: var(--color-primary-dark); }
.hero__sub { font-size: var(--text-lg); color: var(--color-muted); max-inline-size: 38ch; margin-inline: auto; }

/* ── صندوق التفضيلات الحرة ─────────────────────────────── */
.pref { display: flex; gap: var(--space-2); max-inline-size: 30rem; margin: var(--space-5) auto 0; }
.pref { flex-wrap: wrap; }
.pref__input {
  flex: 1; min-inline-size: 0; inline-size: 100%; font-family: inherit; font-size: var(--text-body); color: var(--color-ink);
  background: var(--color-surface); border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-pill); padding: var(--space-3) var(--space-5); min-block-size: 48px;
  transition: border-color 150ms var(--ease), box-shadow 150ms var(--ease);
}
.pref__input::placeholder { color: var(--color-faint); }
.pref__input:focus-visible { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-primary-soft); }
.pref__btn { flex: none; }
.pref__note { text-align: center; color: var(--color-muted); font-size: var(--text-sm); margin-block-start: var(--space-3); }

.dish {
  position: relative; aspect-ratio: 16/9;
  background:
    radial-gradient(130% 120% at 78% 12%, rgba(243,230,222,0.55) 0%, rgba(243,230,222,0) 50%),
    linear-gradient(140deg, #4E916B 0%, #3F7D5C 52%, #2F6044 100%);
  display: grid; place-items: center;
}
.dish__emoji { font-size: 4.2rem; filter: drop-shadow(0 6px 14px rgba(0,0,0,.18)); }
.dish__cal {
  position: absolute; inset-block-start: var(--space-3); inset-inline-end: var(--space-3);
  background: rgba(255,255,255,0.92); color: var(--color-primary-dark);
  font-weight: 600; font-size: var(--text-sm); padding: 6px var(--space-3);
  border-radius: var(--radius-pill); box-shadow: var(--shadow-sm);
}

.suggest-meta { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); margin-block-end: var(--space-3); }
.suggest-title { font-size: var(--text-h2); margin: 0; color: var(--color-primary-dark); }

.actions { display: grid; gap: var(--space-3); margin-block-start: var(--space-4); }
@media (min-width: 560px) { .actions { grid-template-columns: 1fr 1fr; } }

/* ── التغذية ───────────────────────────────────────────── */
.nutri { display: grid; grid-template-columns: auto 1fr; gap: var(--space-4); align-items: center;
  background: var(--color-primary-soft); border-radius: var(--radius-md); padding: var(--space-4); }
.nutri__big { text-align: center; padding-inline-end: var(--space-4); border-inline-end: 1px solid color-mix(in srgb, var(--color-primary) 30%, transparent); }
.nutri__cal { font-family: var(--font-display); font-size: 2.5rem; font-weight: 700; color: var(--color-primary-dark); line-height: 1; }
.nutri__unit { font-size: var(--text-sm); color: var(--color-muted); }
.macros { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-2); }
.macro { text-align: center; background: var(--color-surface); border-radius: var(--radius-sm); padding: var(--space-2); }
.macro__v { font-weight: 600; color: var(--color-ink); }
.macro__l { font-size: var(--text-caption); color: var(--color-muted); }

/* ── عناوين الأقسام ────────────────────────────────────── */
.section-title { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-h3); color: var(--color-primary-dark); margin-block: var(--space-6) var(--space-3); }
.section-title::before { content: ""; inline-size: 5px; block-size: 20px; border-radius: 3px; background: var(--color-accent); opacity: .85; }

/* ── المكوّنات ─────────────────────────────────────────── */
.ing-list { list-style: none; margin: 0; padding: 0; }
.ing { display: flex; align-items: center; gap: var(--space-3); padding-block: var(--space-3); border-block-end: 1px solid var(--color-border); }
.ing:last-child { border-block-end: 0; }
.ing__dot { inline-size: 8px; block-size: 8px; border-radius: 50%; background: var(--color-primary); flex: none; opacity: .7; }
.ing__name { font-weight: 600; }
.ing__prep { color: var(--color-muted); font-size: var(--text-sm); }
.ing__qty { margin-inline-start: auto; text-align: end; white-space: nowrap; }
.ing__qty b { color: var(--color-primary-dark); font-weight: 600; }
.ing__grams { display: block; font-size: var(--text-caption); color: var(--color-faint); }

/* ── الخطوات ───────────────────────────────────────────── */
.steps { list-style: none; margin: 0; padding: 0; counter-reset: step; }
.step { display: flex; gap: var(--space-3); padding-block: var(--space-3); }
.step__num { counter-increment: step; flex: none; inline-size: 32px; block-size: 32px; border-radius: 50%;
  background: var(--color-primary-soft); color: var(--color-primary-dark); font-weight: 700; display: grid; place-items: center; }
.step__num::before { content: counter(step); }

/* ── قائمة الواتساب ────────────────────────────────────── */
.wa { background: var(--color-whatsapp-bg); border-radius: var(--radius-lg); padding: var(--space-5); box-shadow: var(--shadow-sm); border: 1px solid var(--color-border); }
.wa__bubble { background: var(--color-raised); border-radius: var(--radius-md); border-start-end-radius: 4px; padding: var(--space-4) var(--space-5); box-shadow: var(--shadow-sm); max-inline-size: 560px; margin-inline: auto; }
.wa__head { display: flex; align-items: center; gap: var(--space-2); font-weight: 700; color: var(--color-whatsapp); font-size: var(--text-lg); margin-block-end: var(--space-3); }
.wa-list { list-style: none; margin: 0 0 var(--space-3); padding: 0; }
.wa-item { display: flex; align-items: baseline; gap: var(--space-2); padding-block: 5px; }
.wa-item__bullet { color: var(--color-primary); font-weight: 700; }
.wa-item__name { font-weight: 500; }
.wa-item__pack { margin-inline-start: auto; font-size: var(--text-sm); color: var(--color-muted); white-space: nowrap; }
.wa__sub { margin-block: var(--space-3) var(--space-2); font-weight: 600; color: var(--color-accent-dark); display: flex; align-items: center; gap: 6px; }
.wa__pantry .wa-item__name { color: var(--color-muted); font-weight: 400; }
.wa__time { text-align: end; font-size: var(--text-caption); color: var(--color-faint); margin-block-start: var(--space-2); }

/* ── تحكم الحصص ────────────────────────────────────────── */
.servings { display: flex; align-items: center; gap: var(--space-3); justify-content: center; margin-block: var(--space-4); }
.servings__btn { inline-size: 44px; block-size: 44px; border-radius: 50%; border: 1px solid var(--color-border-strong); background: var(--color-surface); color: var(--color-primary-dark); font-size: var(--text-h3); font-weight: 700; cursor: pointer; display: grid; place-items: center; }
.servings__v { font-family: var(--font-display); font-size: var(--text-h2); font-weight: 700; color: var(--color-primary-dark); min-inline-size: 3ch; text-align: center; }
.servings__l { color: var(--color-muted); font-size: var(--text-sm); }

/* ── خطة الأسبوع ───────────────────────────────────────── */
.plan-grid { display: grid; gap: var(--space-3); grid-template-columns: 1fr; }
@media (min-width: 560px) { .plan-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 860px) { .plan-grid { grid-template-columns: 1fr 1fr 1fr; } }
.day-card { display: flex; align-items: center; gap: var(--space-3); background: var(--color-surface);
  border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-xs); border-inline-start: 4px solid var(--color-primary);
  transition: box-shadow 200ms var(--ease), transform 200ms var(--ease); }
.day-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.day-card__emoji { inline-size: 48px; block-size: 48px; flex: none; border-radius: var(--radius-md);
  display: grid; place-items: center; font-size: 1.7rem; background: var(--color-primary-soft); }
.day-card__day { font-size: var(--text-caption); color: var(--color-accent-dark); font-weight: 600; }
.day-card__name { font-weight: 700; color: var(--color-primary-dark); font-family: var(--font-display); }
.day-card__meta { font-size: var(--text-caption); color: var(--color-muted); }
.day-card__cal { margin-inline-start: auto; text-align: center; }
.day-card__cal b { display: block; font-size: var(--text-lg); color: var(--color-primary-dark); }
.day-card__cal span { font-size: var(--text-caption); color: var(--color-faint); }

/* ── شريط «طبخة بلس» (هادئ) ────────────────────────────── */
.premium {
  display: flex; align-items: center; gap: var(--space-4); flex-wrap: wrap;
  background: linear-gradient(135deg, var(--color-accent-soft), var(--color-sand-2));
  border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5); margin-block-start: var(--space-5);
}
.premium__txt { flex: 1 1 220px; }
.premium__title { font-family: var(--font-display); font-weight: 700; color: var(--color-accent-dark); margin: 0 0 2px; }
.premium__sub { font-size: var(--text-sm); color: var(--color-muted); margin: 0; }
.premium__price { font-family: var(--font-display); font-weight: 700; color: var(--color-primary-dark); font-size: var(--text-h3); white-space: nowrap; }
.premium__price small { font-weight: 500; color: var(--color-muted); font-size: var(--text-caption); }

/* ── إقران السلطة (طبق جانبي) ──────────────────────────── */
.pair { display: flex; align-items: center; gap: var(--space-3); background: var(--color-success-soft);
  border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); }
.pair__emoji { inline-size: 46px; block-size: 46px; flex: none; border-radius: var(--radius-md); display: grid; place-items: center; font-size: 1.6rem; background: var(--color-raised); }
.pair__txt { flex: 1; min-inline-size: 0; }
.pair__name { display: block; font-family: var(--font-display); font-weight: 700; color: var(--color-primary-dark); }
.pair__meta { font-size: var(--text-caption); color: var(--color-muted); }
.pair__add { flex: none; min-block-size: 40px; padding-inline: var(--space-4); font-size: var(--text-sm); }
@media (max-width: 480px) { .pair { flex-wrap: wrap; } .pair__add { inline-size: 100%; } }

/* ── وضع الطبخ (step mode) ─────────────────────────────── */
.cook { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); box-shadow: var(--shadow-md); padding: var(--space-5); margin-block-start: var(--space-6); }
.cook__top { display: flex; align-items: center; gap: var(--space-3); margin-block-end: var(--space-4); }
.cook__exit { inline-size: 44px; block-size: 44px; border-radius: 50%; display: grid; place-items: center; background: var(--color-sand-2); color: var(--color-muted); font-size: var(--text-sm); }
.cook__name { font-family: var(--font-display); font-weight: 700; color: var(--color-primary-dark); font-size: var(--text-lg); line-height: 1.4; margin: 0; }
.cook__count { margin-inline-start: auto; color: var(--color-muted); font-weight: 600; }
.cook__progress { block-size: 6px; border-radius: var(--radius-pill); background: var(--color-sand); overflow: hidden; }
.cook__progress span { display: block; block-size: 100%; background: var(--color-primary); border-radius: var(--radius-pill); transition: inline-size 300ms var(--ease-out); }
.cook__step { display: flex; gap: var(--space-4); align-items: flex-start; padding-block: var(--space-8) var(--space-6); min-block-size: 180px; }
.cook__num { flex: none; inline-size: 52px; block-size: 52px; border-radius: 50%; background: var(--color-primary-soft); color: var(--color-primary-dark); font-family: var(--font-display); font-weight: 700; font-size: var(--text-h2); display: grid; place-items: center; }
.cook__text { font-size: var(--text-h3); line-height: 1.7; color: var(--color-ink); margin: 0; }
.cook__nav { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.cook__nav .btn { min-inline-size: 130px; }
.cook__done { color: var(--color-success); font-weight: 700; }

/* ── لحظة التقييم ──────────────────────────────────────── */
.rate { text-align: center; margin-block-start: var(--space-6); padding: var(--space-6) var(--space-5); background: var(--color-primary-soft); border-radius: var(--radius-xl); }
.rate__title { color: var(--color-primary-dark); margin-block-end: var(--space-2); }
.rate__sub { color: var(--color-muted); max-inline-size: 36ch; margin-inline: auto; margin-block-end: var(--space-5); }
.rate__actions { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; }
.rate__actions .btn { min-inline-size: 150px; }
.rate__thanks { font-size: var(--text-h3); font-weight: 700; color: var(--color-primary-dark); margin-block-end: var(--space-5); }
.rate__after { margin-block-start: var(--space-5); max-inline-size: 320px; margin-inline: auto; }

/* ── تذييل ─────────────────────────────────────────────── */
.footer { text-align: center; color: var(--color-muted); font-size: var(--text-sm); padding-block: var(--space-8) var(--space-6); }
.footer strong { color: var(--color-primary-dark); }

.meta-row { display: flex; flex-wrap: wrap; gap: var(--space-2) var(--space-4); color: var(--color-muted); font-size: var(--text-sm); margin-block-end: var(--space-4); }
.meta-row span { display: inline-flex; align-items: center; gap: 6px; }

/* إمكانية الوصول والحركة */
:focus-visible { outline: 3px solid color-mix(in srgb, var(--color-primary) 55%, transparent); outline-offset: 2px; }
.icon { inline-size: 24px; block-size: 24px; display: inline-block; vertical-align: middle; color: currentColor; flex: none; }
.icon svg { inline-size: 100%; block-size: 100%; display: block; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
@media (max-width: 480px) {
  :root { --text-display: 2.15rem; --text-h1: 1.8rem; }
}

/* ── لوحة الشيف ─────────────────────────────────────────── */
.chef-tag { position: absolute; inset-block-start: var(--space-3); inset-inline-start: var(--space-3);
  background: var(--color-primary-dark); color: #fff; font-size: var(--text-caption); font-weight: 600;
  padding: 5px var(--space-3); border-radius: var(--radius-pill); box-shadow: var(--shadow-sm); }
.chef-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); margin-block: var(--space-4); }
.chef-stat { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md);
  padding: var(--space-3); text-align: center; transition: border-color 150ms var(--ease); }
.chef-stat.is-on { border-color: var(--color-primary); background: var(--color-primary-soft); }
.chef-stat b { display: block; font-family: var(--font-display); font-size: var(--text-h2); color: var(--color-primary-dark); }
.chef-stat span { font-size: var(--text-caption); color: var(--color-muted); }
.chef-progress { block-size: 8px; border-radius: var(--radius-pill); background: var(--color-sand); overflow: hidden; margin-block: var(--space-3) var(--space-2); }
.chef-progress span { display: block; block-size: 100%; background: var(--color-primary); border-radius: var(--radius-pill); }
.review-list { list-style: none; margin: var(--space-4) 0 0; padding: 0; display: grid; gap: var(--space-2); }
.review-item { display: flex; align-items: center; gap: var(--space-3); background: var(--color-surface);
  border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-2) var(--space-3); }
.review-item__main { display: flex; align-items: center; gap: var(--space-3); flex: 1; min-inline-size: 0; min-block-size: 44px; }
.review-item__emoji { inline-size: 40px; block-size: 40px; flex: none; border-radius: var(--radius-sm);
  display: grid; place-items: center; font-size: 1.4rem; background: var(--color-primary-soft); }
.review-item__name { font-weight: 600; color: var(--color-ink); }
.review-item__btn { min-block-size: 44px; padding-inline: var(--space-4); font-size: var(--text-sm); flex: none; }
.review-badge { font-size: var(--text-caption); font-weight: 600; padding: 4px var(--space-3); border-radius: var(--radius-pill); white-space: nowrap; }
.review-badge--draft { background: var(--color-sand-2); color: var(--color-muted); }
.review-badge--verified { background: var(--color-success-soft); color: var(--color-primary-dark); }
.review-badge--rejected { background: #F3E0DD; color: var(--color-danger); }
.chef-label { display: block; font-size: var(--text-sm); font-weight: 600; color: var(--color-muted); margin-block: var(--space-3) var(--space-2); }
.chef-textarea, .chef-input, .chef-select { inline-size: 100%; font-family: inherit; font-size: var(--text-body);
  color: var(--color-ink); background: var(--color-surface); border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md); padding: var(--space-3); line-height: 1.9; }
.chef-textarea:focus-visible, .chef-input:focus-visible, .chef-select:focus-visible { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-primary-soft); }
.chef-textarea { margin-block-end: var(--space-3); resize: vertical; }
.chef-actions { display: flex; gap: var(--space-3); margin-block-start: var(--space-4); }
@media (max-width: 480px) { .chef-stats { grid-template-columns: 1fr 1fr; } }

/* ── تعديل كميات الشيف (بسيط جداً) ─────────────────────── */
.qty-edit-list { list-style: none; margin: var(--space-3) 0 var(--space-4); padding: 0; display: grid; gap: var(--space-2); }
.qty-edit { display: flex; align-items: center; gap: var(--space-3); background: var(--color-surface);
  border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-2) var(--space-4); }
.qty-edit__name { flex: 1; min-inline-size: 0; font-weight: 600; color: var(--color-ink); }
.qty-edit__control { display: flex; align-items: center; gap: var(--space-2); flex: none; }
.qty-edit__num { inline-size: 84px; font-family: inherit; font-size: var(--text-lg); text-align: center;
  color: var(--color-primary-dark); font-weight: 700; background: var(--color-raised);
  border: 1px solid var(--color-border-strong); border-radius: var(--radius-sm); padding: var(--space-2); min-block-size: 44px; }
.qty-edit__num:focus-visible { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-primary-soft); }
.qty-edit__unit { color: var(--color-muted); font-size: var(--text-sm); min-inline-size: 5ch; }

/* ── تصفّح الوصفات (صفحة الفلترة للمستخدم) ──────────────── */
/* الشرائح روابط تبديل؛ كل شريحة هدف لمس ≥ 44px. لا تجاوز أفقي:
   الشبكة عمود واحد على الجوال وتتوسّع تدريجياً. خصائص منطقية فقط (RTL آمن). */
.browse-filters { display: grid; gap: var(--space-4); margin-block-end: var(--space-5); }
.browse-filters__group { display: grid; gap: var(--space-2); }
.browse-filters__label { font-size: var(--text-sm); font-weight: 600; color: var(--color-accent-dark); }
.browse-filters .chip {
  text-decoration: none;
  min-block-size: 44px;
  align-items: center;
  transition: background-color 150ms var(--ease), border-color 150ms var(--ease), color 150ms var(--ease);
}
.browse-filters .chip:hover { border-color: var(--color-primary); }
.browse-filters .chip:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--color-primary-soft); }
.browse-meta { font-size: var(--text-sm); color: var(--color-muted); margin: 0; }
.browse-meta b { color: var(--color-primary-dark); }

.browse-grid { display: grid; gap: var(--space-3); grid-template-columns: 1fr; }
@media (min-width: 560px) { .browse-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 860px) { .browse-grid { grid-template-columns: 1fr 1fr 1fr; } }
/* البطاقة تعيد استخدام نمط .day-card؛ نضمن أنها رابط بلا تسطير ولا تجاوز للنص. */
.browse-grid .day-card { text-decoration: none; min-block-size: 44px; }
.browse-grid .day-card__name { overflow-wrap: anywhere; }

/* ── شريط الشيف + تسجيل الدخول ──────────────────────────── */
.chef-bar { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3);
  padding-block: var(--space-3); color: var(--color-muted); font-size: var(--text-sm); border-block-end: 1px solid var(--color-border); }
.chef-bar__actions { display: flex; align-items: center; gap: var(--space-4); }
.chef-bar__logout { background: none; border: 0; color: var(--color-danger); font: inherit; cursor: pointer; min-block-size: 44px; }
.auth-form { max-inline-size: 26rem; margin-inline: auto; }
.auth-error { max-inline-size: 26rem; margin: 0 auto var(--space-4); padding: var(--space-3) var(--space-4);
  background: #F3E0DD; color: var(--color-danger); border-radius: var(--radius-md); text-align: center; }

/* ── شريط الثقة (صفحة الوصفة) ──────────────────────────── */
.trust { background: var(--color-primary-soft); border-radius: var(--radius-lg);
  padding: var(--space-5); margin-block-start: var(--space-6); }
.trust__title { font-family: var(--font-display); font-weight: 700; color: var(--color-primary-dark);
  font-size: var(--text-h3); margin: 0 0 var(--space-3); }
.trust__list { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--space-3); }
.trust__list li { color: var(--color-ink); font-size: var(--text-sm); line-height: 1.7; }
.trust__list strong { color: var(--color-primary-dark); }
.trust__check { display: inline-grid; place-items: center; inline-size: 22px; block-size: 22px;
  border-radius: 50%; background: var(--color-primary); color: #fff; font-size: 12px;
  margin-inline-end: 6px; vertical-align: middle; }

/* ── نماذج الشيف (إضافة وصفة / بروفايل) ─────────────────── */
.chef-form { max-inline-size: 40rem; margin-inline: auto; display: grid; gap: var(--space-4); }
.chef-field { display: flex; flex-direction: column; gap: 6px; }
.chef-field > span { font-size: var(--text-sm); font-weight: 600; color: var(--color-accent-dark); }
.chef-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
@media (max-width: 480px) { .chef-row { grid-template-columns: 1fr; } }
.ing-row { display: flex; gap: var(--space-2); margin-block-end: var(--space-2); flex-wrap: wrap; }
.ing-row .chef-input { min-inline-size: 0; }

/* ── شريط الطقس + الستريك (الرئيسية) ───────────────────── */
.day-streak { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap;
  gap: var(--space-2); margin-block-start: var(--space-6); margin-block-end: 0;
  font-size: var(--text-sm); color: var(--color-muted); }
.day-streak__fire { color: var(--color-accent-dark); font-weight: 600;
  background: var(--color-accent-soft); padding: 4px var(--space-3); border-radius: var(--radius-pill); }

/* ═══════════════════════════════════════════════════════════════════════════
   طبقة iOS الأصلية — إحساس تطبيق أبل (تبويب سفلي، عناوين، عمق ناعم، Safe Area).
   لا تغيّر ألوان الهوية؛ تُحسّن البنية والمسافات والعمق فقط.
   ═══════════════════════════════════════════════════════════════════════════ */

:root { --tabbar-h: 64px; }

/* مساحة سفلية حتى لا يغطّي شريط التبويب المحتوى (+ Safe Area للآيفون). */
body { padding-block-end: calc(var(--tabbar-h) + env(safe-area-inset-bottom, 0px)); }

/* ── شريط علوي مدمج بأسلوب iOS (شفّاف بـ blur) ─────────────────────────────── */
.navbar {
  position: sticky; inset-block-start: 0; z-index: 20;
  background: color-mix(in srgb, var(--color-bg) 80%, transparent);
  backdrop-filter: saturate(1.8) blur(20px);
  -webkit-backdrop-filter: saturate(1.8) blur(20px);
  border-block-end: 0.5px solid var(--color-border);
  padding-block-start: env(safe-area-inset-top, 0px);
}
.navbar__inner {
  max-inline-size: 920px; margin-inline: auto; padding: var(--space-3) var(--space-5);
  display: flex; align-items: center; justify-content: center; gap: var(--space-2);
  min-block-size: 44px;
}
.navbar .brand { display: inline-flex; align-items: center; gap: var(--space-2); }
.navbar .brand__logo { inline-size: 28px; block-size: 28px; }
.navbar .brand__name {
  font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg);
  color: var(--color-primary-dark);
}

/* ── شريط التبويب السفلي (توقيع iOS) ───────────────────────────────────────── */
.tabbar {
  position: fixed; inset-inline: 0; inset-block-end: 0; z-index: 30;
  display: flex; justify-content: space-around; align-items: stretch;
  background: color-mix(in srgb, var(--color-surface) 82%, transparent);
  backdrop-filter: saturate(1.8) blur(20px);
  -webkit-backdrop-filter: saturate(1.8) blur(20px);
  border-block-start: 0.5px solid var(--color-border);
  padding-block-end: env(safe-area-inset-bottom, 0px);
}
.tab {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 3px; padding-block: 8px; min-block-size: var(--tabbar-h);
  color: var(--color-faint); font-size: 0.66rem; font-weight: 500;
  text-decoration: none; transition: color 150ms var(--ease);
}
.tab__icon { inline-size: 25px; block-size: 25px; fill: none;
  stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.tab.is-active { color: var(--color-primary); }
.tab:active { opacity: 0.55; }

/* ── تنعيم البطاقات/العمق بأسلوب أبل ───────────────────────────────────────── */
.card { border-radius: var(--radius-xl); border-color: var(--color-border); box-shadow: var(--shadow-md); }
.day-card, .premium, .nutri, .wa, .trust, .pair { border-radius: var(--radius-lg); }
.btn { border-radius: 14px; font-weight: 600; }
.btn--lg { border-radius: var(--radius-lg); }

/* عناوين أكبر وأوزن أثقل (Large Title) داخل الصفحات */
.hero__title { letter-spacing: -0.5px; }

/* السدو يبقى شعرة رفيعة تحت الشريط */
.navbar .sadu-band { block-size: 4px; opacity: 0.5; }

/* على الشاشات الواسعة: نوسّط ونحدّد العرض كتطبيق جوال */
@media (min-width: 620px) {
  .tabbar { max-inline-size: 460px; margin-inline: auto; inset-inline: 0;
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    border-inline: 0.5px solid var(--color-border); }
}

/* ═══════════════════════════════════════════════════════════════════════════
   ضبط مقياس الجوال (≤620px) — يلغي الفجوات الضخمة، يشدّ التباعد بإيقاع iOS.
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 620px) {
  html { font-size: 16px; }                 /* أساس iOS القياسي بدل 17.5 */
  :root {
    --text-display: 1.9rem; --text-h1: 1.55rem; --text-h2: 1.3rem; --text-h3: 1.12rem;
    --space-8: 1.75rem; --space-6: 1.25rem;  /* نقلّص الفجوات الكبيرة */
  }
  .container { padding-inline: var(--space-4); }       /* 16px جوانب */

  /* الأقسام: تباعد منتظم ومضغوط */
  .hero { padding-block: var(--space-5) var(--space-4); }
  .section-title { margin-block: var(--space-5) var(--space-3); }
  .card { margin-block-start: var(--space-4) !important; }

  /* صورة الطبق أقصر (كانت 16/9 تاخذ ارتفاع كبير) */
  .dish { aspect-ratio: 5 / 3; }

  /* الأزرار المتجاورة تتكدّس بمسافة منتظمة */
  .actions { gap: var(--space-2); }

  /* المسافات بين بطاقات الخطة/التصفّح أنظف */
  .plan-grid, .browse-grid { gap: var(--space-3); }
}

/* ── صورة الطبق (تملأ البطاقة) ─────────────────────────── */
.dish--photo { background: var(--color-sand); }
.dish__img { position: absolute; inset: 0; inline-size: 100%; block-size: 100%;
  object-fit: cover; display: block; }
/* التدرّجات (السعرات/الشارة) تبقى فوق الصورة مقروءة */
.dish--photo .dish__cal, .dish--photo .chef-tag { z-index: 2; }

/* ═══════════════════════════════════════════════════════════════════════════
   هرمية النصوص على الجوال — سلّم iOS منظّم: عنوان · نص · ثانوي صغير خافت.
   يهدّئ أرقام السعرات ويصغّر نصوص الشرح حتى لا تزاحم.
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 620px) {
  /* النص الثانوي (شرح/وصف): صغير + خافت — لا يزاحم العنوان */
  .hero__sub { font-size: var(--text-sm); color: var(--color-faint); line-height: 1.6; }
  .pref__note, .premium__sub, .rate__sub, .trust__list li, .meta-row { font-size: var(--text-sm); }
  .reason, .day-card__meta, .pair__meta { font-size: var(--text-caption); color: var(--color-faint); }

  /* أرقام السعرات: مهدّأة لا ضخمة (كانت 2.5rem = هلع) */
  .nutri__cal { font-size: 1.9rem; }
  .nutri { padding: var(--space-3); gap: var(--space-3); }
  .nutri__unit, .macro__l { font-size: var(--text-caption); color: var(--color-faint); }
  .dish__cal { font-size: var(--text-caption); padding: 4px 10px; }

  /* العنوان الأساسي للطبق: واضح لكن غير مبالغ */
  .card__pad h1 { font-size: var(--text-h2); }
  .hero__kicker, .premium__title { font-size: var(--text-caption); }

  /* الشيبس/التاقات أصغر وأخفّ */
  .chip { font-size: var(--text-caption); padding: 4px 10px; }
}
