/* tokens-ladies.css — Ladies' Haven tokens + portal overrides.
   "soft, elegant, private". Scoped to html[data-portal="ladies"] so this file
   is inert on other portals. Cream/dusty-rose, privacy-first;
   Fraunces / Reem Kufi / Tajawal. Staff photos are NEVER rendered here. */

html[data-portal="ladies"] {
  --bg:#FBF5F0;
  --bg-2:#F6ECE5;
  --surface:#FFFFFF;
  --line:#EFE0D8;
  --text:#3A2C30;
  --text-muted:#9C8A8E;
  --rose:#D98A93;
  --rose-soft:#F3D9DC;
  --mauve:#B98BB0;
  --gold:#C39A4E;
  --success:#5BA77E;
  --danger:#D2706B;
  --radius:18px;
  --radius-lg:28px;
  --shadow:0 14px 40px rgba(160,120,120,.18);
  --ring:0 0 0 3px rgba(217,138,147,.30);

  --font-head-latin: "Fraunces", "Tajawal", Georgia, serif;
  --font-head-ar:    "Reem Kufi", "Tajawal", serif;
  --font-body:       "Tajawal", "Fraunces", system-ui, sans-serif;
  --font-mono:       "Tajawal", system-ui, sans-serif;

  --head-weight: 600;
  --head-track: -0.005em;
  --motion: var(--transition-slow);

  /* aliases so shared components compile under this portal */
  --surface-2: var(--bg-2);
  --accent: var(--rose);
  --accent-press: #C2737D;
  --navy: var(--mauve);
}

html[data-portal="ladies"][lang="ar"] {
  --font-head-latin: var(--font-head-ar);
}

html[data-portal="ladies"] body {
  background:
    radial-gradient(900px 600px at 10% -10%, #F8E7DA 0%, transparent 55%),
    radial-gradient(700px 500px at 110% 0%, #F4DDE0 0%, transparent 60%),
    var(--bg);
}

html[data-portal="ladies"] .app-header { background: color-mix(in oklab, var(--bg) 78%, transparent); border-bottom-color: var(--line); }
html[data-portal="ladies"] .app-header .brand .dot { background: var(--rose); box-shadow: none; }

html[data-portal="ladies"] h1, html[data-portal="ladies"] h2 { font-style: normal; }
html[data-portal="ladies"][lang="en"] h1 em,
html[data-portal="ladies"][lang="en"] h2 em { font-style: italic; font-weight: 500; color: var(--rose); }

/* ---- Hero ---- */
html[data-portal="ladies"] .hero {
  position: relative;
  border-radius: var(--radius-lg);
  background: linear-gradient(160deg, #FFFFFF 0%, #FBEBE6 60%, #F6DDE3 100%);
  padding: 26px 22px 28px;
  border: 1px solid var(--line);
  overflow: hidden;
}
html[data-portal="ladies"] .hero::before {
  content: ""; position: absolute; inset: -40% -40% auto auto;
  width: 220px; height: 220px; border-radius: 50%;
  border: 1px solid color-mix(in oklab, var(--gold) 60%, transparent);
  opacity: .55; pointer-events: none;
}
html[data-portal="ladies"] .hero::after {
  content: ""; position: absolute; inset: auto auto -60% -30%;
  width: 280px; height: 280px; border-radius: 50%;
  border: 1px solid color-mix(in oklab, var(--gold) 50%, transparent);
  opacity: .35; pointer-events: none;
}
html[data-portal="ladies"] .hero .eyebrow {
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .28em;
  text-transform: uppercase; color: var(--gold); margin-bottom: 14px;
}
html[data-portal="ladies"] .hero h1 {
  font-family: var(--font-head-latin); font-weight: 500; letter-spacing: -.01em;
  font-size: clamp(28px, 8vw, 40px); line-height: 1.1;
}
html[data-portal="ladies"] .hero .hero-sub { color: var(--text-muted); margin-top: 12px; max-width: 34ch; font-size: 14.5px; }
html[data-portal="ladies"] .hero .hero-cta { margin-top: 22px; display: flex; gap: 10px; }

/* ---- Buttons ---- */
html[data-portal="ladies"] .btn { background: var(--rose); font-family: var(--font-head-latin); font-weight: 500; letter-spacing: .01em; }
html[data-portal="ladies"] .btn:hover { background: var(--accent-press); }
html[data-portal="ladies"] .btn--ghost { background: transparent; border: 1px solid color-mix(in oklab, var(--gold) 55%, var(--line)); color: var(--text); }
html[data-portal="ladies"] .btn--gold { background: var(--gold); color: #2A1F0A; }

/* ---- Service card ---- */
html[data-portal="ladies"] .service-card { padding: 18px; display: grid; grid-template-columns: 1fr auto; gap: 6px 14px; background: var(--surface); }
html[data-portal="ladies"] .service-card .name { font-family: var(--font-head-latin); font-weight: 500; font-size: 18px; letter-spacing: -.005em; }
html[data-portal="ladies"] .service-card .meta { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: 10px; color: var(--text-muted); font-size: 13px; margin-top: 6px; }
html[data-portal="ladies"] .service-card .price { font-family: var(--font-head-latin); font-weight: 500; font-size: 16px; color: var(--text); white-space: nowrap; }
html[data-portal="ladies"] .service-card .price .iqd { color: var(--text-muted); font-weight: 400; font-size: 12.5px; margin-inline-start: 4px; }

/* ---- Stylist card (monogram only, NO photos) ---- */
html[data-portal="ladies"] .barber-card { display: grid; grid-template-columns: 72px 1fr auto; gap: 16px; align-items: center; padding: 18px; background: var(--surface); }
html[data-portal="ladies"] .barber-card .avatar {
  width: 72px; height: 72px; border-radius: 50%;
  background: radial-gradient(120% 100% at 30% 25%, #FFFFFF 0%, var(--rose-soft) 70%);
  border: 1px solid color-mix(in oklab, var(--gold) 50%, var(--line));
  display: grid; place-items: center;
  font-family: var(--font-head-latin); font-weight: 500; font-style: italic; font-size: 28px;
  color: var(--rose); letter-spacing: -.02em; position: relative;
}
html[data-portal="ladies"] .barber-card .avatar::after {
  content: ""; position: absolute; inset: 4px; border-radius: 50%;
  border: 1px solid color-mix(in oklab, var(--gold) 35%, transparent);
}
html[data-portal="ladies"] .barber-card .name { font-family: var(--font-head-latin); font-weight: 500; font-size: 18px; }
html[data-portal="ladies"] .barber-card .spec { color: var(--text-muted); font-size: 13px; margin-top: 2px; }

/* Privacy note */
html[data-portal="ladies"] .privacy-note {
  display: flex; gap: 10px; padding: 12px 14px;
  background: #FFFFFF; border: 1px solid color-mix(in oklab, var(--gold) 40%, var(--line));
  border-radius: var(--radius); color: var(--text-muted); font-size: 12.5px;
}
html[data-portal="ladies"] .privacy-note .ic { color: var(--gold); }

/* ---- Slot tweaks (gentle) ---- */
html[data-portal="ladies"] .slot { background: var(--surface); border-radius: var(--radius); }
html[data-portal="ladies"] .slot.is-selected { background: var(--rose); color: #fff; border-color: var(--rose); }
html[data-portal="ladies"] .slot .tag { color: var(--gold); }
html[data-portal="ladies"] .slot.is-selected .tag { color: rgba(255,255,255,.9); }
html[data-portal="ladies"] .day { background: var(--surface); border-radius: var(--radius); }
html[data-portal="ladies"] .day.is-selected { background: var(--rose); color: #fff; border-color: var(--rose); }

/* ---- Section titles get a serif accent ---- */
html[data-portal="ladies"] .section-title h2 { font-family: var(--font-head-latin); font-weight: 500; }
