/* ============================================================
   SALONIQA SaaS — Global theme (Phase 9)
   Single source of truth: design tokens + shared UI components.
   Load this BEFORE page-specific CSS on every page.
   Identity: emerald + gold. Presentation only — no logic.
   ============================================================ */

:root{
  /* brand */
  --emerald:#0D4F45;
  --emerald-mid:#2D6A4F;
  --emerald-deep:#072F2A;
  --gold:#D4AF37;
  --gold-dark:#B8932B;
  --ink:#1A1A1A;
  /* text */
  --text:#333333;
  --muted:#666666;
  /* surfaces */
  --line:#e0e0e0;
  --bg:#f5f5f5;
  --bg-soft:#F9F7F4;
  --card:#ffffff;
  /* status */
  --danger:#dc3545;
  --success:#28a745;
  --wa:#25D366;
  /* shape & depth */
  --radius:12px;
  --radius-lg:18px;
  --gap:16px;
  --shadow:0 1px 3px rgba(0,0,0,.06);
  --shadow-lg:0 12px 30px rgba(0,0,0,.10);
  /* type */
  --font-head:'Playfair Display', Georgia, serif;
  --font-body:'Inter', sans-serif;
}

/* ── Buttons ──────────────────────────────────────────────
   NOTE: a bare `.btn` already exists in some page CSS files; those
   load AFTER this file and intentionally win. The `.btn--*` modifiers
   below are new (no collisions) and are the shared system going forward. */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:11px 22px; border:1px solid transparent; border-radius:999px;
  font-family:var(--font-body); font-size:14px; font-weight:600; letter-spacing:.3px;
  cursor:pointer; transition:background .2s, color .2s, border-color .2s, opacity .2s;
  text-decoration:none; line-height:1;
}
.btn--gold{ background:var(--gold); color:#fff; }
.btn--gold:hover{ background:var(--gold-dark); }
.btn--emerald{ background:var(--emerald); color:#fff; }
.btn--emerald:hover{ background:var(--emerald-deep); }
.btn--ghost{ background:transparent; color:var(--emerald); border-color:var(--emerald); }
.btn--ghost:hover{ background:var(--emerald); color:#fff; }
.btn--danger{ background:var(--danger); color:#fff; }
.btn--danger:hover{ opacity:.88; }
.btn--sm{ padding:8px 14px; font-size:13px; }
.btn[disabled], .btn--gold[disabled], .btn--emerald[disabled]{ opacity:.6; cursor:default; }

/* ── Form fields ──────────────────────────────────────────── */
.fld{ display:block; margin-bottom:var(--gap); }
.fld > label, .fld > span{ display:block; font-size:12.5px; font-weight:600; color:var(--muted); margin-bottom:6px; letter-spacing:.3px; }
.fld input, .fld textarea, .fld select{
  width:100%; padding:12px 14px; border:1px solid var(--line); border-radius:10px;
  font-family:var(--font-body); font-size:14px; color:var(--text); background:var(--card);
  outline:none; transition:border-color .2s;
}
.fld textarea{ resize:vertical; min-height:60px; }
.fld input:focus, .fld textarea:focus, .fld select:focus{ border-color:var(--emerald); }

/* ── Image upload row + preview ───────────────────────────── */
.imgrow{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.imgrow input[type=text]{ flex:1; min-width:160px; }
.imgprev{ width:54px; height:54px; object-fit:cover; border-radius:10px; border:1px solid var(--line); background:var(--bg-soft); flex-shrink:0; }

/* ── Repeatable row card ──────────────────────────────────── */
.row-card{ border:1px solid var(--line); border-radius:var(--radius); padding:20px; margin-bottom:var(--gap); background:var(--card); }
.row-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.row-head strong{ font-family:var(--font-head); font-size:16px; color:var(--ink); }

/* ── Sticky save bar ──────────────────────────────────────── */
.save-bar{ position:sticky; bottom:0; z-index:30; background:rgba(255,255,255,.96); backdrop-filter:blur(8px);
  border-top:1px solid var(--line); padding:14px 20px; display:flex; align-items:center; justify-content:center; gap:18px; flex-wrap:wrap; }
.save-hint{ font-size:12.5px; color:var(--muted); max-width:420px; }

/* ── Toast notifications ──────────────────────────────────── */
.toast{ position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px); opacity:0; pointer-events:none;
  background:var(--ink); color:#fff; padding:14px 22px; border-radius:var(--radius); font-size:14px; z-index:1000; transition:.3s; max-width:90%; text-align:center; box-shadow:var(--shadow-lg); }
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }
.toast.ok{ background:var(--success); }
.toast.err{ background:var(--danger); }

/* ── Empty + loading states ───────────────────────────────── */
.empty{ color:var(--muted); font-size:14px; padding:8px 2px 14px; text-align:center; }
.loadwrap{ display:grid; place-items:center; gap:16px; padding:80px 0; color:var(--muted); }
.loadspin{ width:42px; height:42px; border:3px solid var(--line); border-top-color:var(--emerald); border-radius:50%; animation:sq-spin 1s linear infinite; }
@keyframes sq-spin{ to{ transform:rotate(360deg); } }

/* ============================================================
   LUXURY LAYER (Phase 10) — ported from nassiry-beauty-glow.
   Additive only. Keeps the emerald/gold identity; adds ivory/beige
   surfaces, gradients, luxe shadows, smooth motion, scales.
   Existing pages are unaffected (no page uses these yet).
   ============================================================ */
:root{
  /* warm surfaces */
  --ivory:#F8F4EC;
  --beige:#EFE7DA;
  --soft-white:#FCFAF6;
  /* accent companions */
  --gold-soft:#EBD9A8;
  --pink-soft:#FBE6EC;
  --pink:#E5A8B8;
  /* radius scale (complements --radius 12 / --radius-lg 18) */
  --radius-sm:8px;
  --radius-xl:24px;
  --radius-pill:999px;
  /* spacing scale */
  --space-xs:4px; --space-sm:8px; --space-md:16px; --space-lg:24px; --space-xl:40px; --space-2xl:64px;
  /* typography */
  --font-display:'Cormorant Garamond','Playfair Display',Georgia,serif;
  /* luxury shadows */
  --shadow-soft:0 10px 40px -10px rgba(7,47,42,.12);
  --shadow-luxe:0 30px 80px -20px rgba(7,47,42,.25);
  --shadow-gold:0 20px 50px -15px rgba(184,147,43,.30);
  /* smooth motion */
  --transition-smooth:all .35s cubic-bezier(.4,0,.2,1);
  /* gradients (reuse existing emerald/gold) */
  --gradient-green:linear-gradient(135deg, var(--emerald-deep) 0%, var(--emerald) 100%);
  --gradient-gold:linear-gradient(135deg, #E8C766 0%, var(--gold-dark) 100%);
  --gradient-soft:linear-gradient(180deg, var(--ivory) 0%, var(--beige) 100%);
  --gradient-hero:radial-gradient(ellipse at top right, var(--pink-soft) 0%, var(--ivory) 55%, var(--beige) 100%);
}

/* gradient / shadow / motion utilities */
.bg-gradient-green{ background:var(--gradient-green); }
.bg-gradient-gold{ background:var(--gradient-gold); }
.bg-gradient-soft{ background:var(--gradient-soft); }
.bg-gradient-hero{ background:var(--gradient-hero); }
.bg-ivory{ background:var(--ivory); }
.bg-beige{ background:var(--beige); }
.shadow-soft{ box-shadow:var(--shadow-soft); }
.shadow-luxe{ box-shadow:var(--shadow-luxe); }
.shadow-gold{ box-shadow:var(--shadow-gold); }
.transition-smooth{ transition:var(--transition-smooth); }
.font-display{ font-family:var(--font-display); letter-spacing:-.015em; }
.text-gradient-gold{ background:var(--gradient-gold); -webkit-background-clip:text; background-clip:text; color:transparent; }
.text-gradient-green{ background:var(--gradient-green); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* subtle entrance animations */
@keyframes sq-float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }
@keyframes sq-fade-up{ from{ opacity:0; transform:translateY(20px); } to{ opacity:1; transform:translateY(0); } }
.animate-float{ animation:sq-float 6s ease-in-out infinite; }
.animate-fade-up{ animation:sq-fade-up .8s ease-out both; }

/* RTL groundwork (used by Phase 10 Task 4 — harmless until [dir=rtl] is set) */
html[dir="rtl"] body{ font-family:'Tajawal','Inter',system-ui,sans-serif; }
html[dir="rtl"] .save-bar,
html[dir="rtl"] .row-head{ direction:rtl; }
