/* =======================================================
   SAGE THEME — Site-wide tokens, components & utilities
   ======================================================= */

/* ---- Brand & base tokens (LIGHT) ---- */
:root{
  /* Sage palette (choose shades that match your reference image) */
  --brand-sage:       #8FAA93;  /* primary sage (light) */
  --brand-sage-deep:  #6F8978;  /* deeper sage for contrast */
  --brand-sage-ink:   #50665A;  /* ink-tinted sage for outlines */

  /* Map legacy names so older CSS keeps working */
  --brand-indigo: var(--brand-sage);
  --brand-rose:   var(--brand-sage-deep);
  --brand-saffron: var(--brand-sage);

  /* Surfaces & text (light) */
  --bg:        #ffffff;
  --bg-soft:   #f6f8f7;            /* soft paper white with tiny green */
  --text:      #0f172a;            /* slate-900 */
  --text-muted:#6b7280;            /* gray-500/600 */
  --border:    rgba(15,23,42,.08);

  /* Glass & elevation */
  --glass-bg:      rgba(255,255,255,.60);
  --glass-border:  rgba(15,23,42,.10);
  --shadow-soft:   0 20px 50px rgba(0,0,0,.08);
  --shadow-glow:   0 0 30px rgba(143,170,147,.20);

  /* Gradients (sage → deep sage) */
  --grad-a: linear-gradient(135deg, var(--brand-sage) 0%, var(--brand-sage-deep) 100%);
  --grad-b: linear-gradient(135deg, #9bd3a7 0%, var(--brand-sage) 100%);

  /* Generic aliases some templates use */
  --primary: var(--brand-sage);
  --accent:  var(--brand-sage-deep);
}

/* ---- Brand & base tokens (DARK) ---- */
.dark{
  --bg:        #0f172a;   /* deep slate */
  --bg-soft:   #111827;   /* slate-900 */
  --text:      #e5e7eb;   /* slate-200 */
  --text-muted:#a7b0bd;   /* softened */
  --border:    rgba(255,255,255,.12);

  --glass-bg:     rgba(17,24,39,.70);
  --glass-border: rgba(255,255,255,.12);
  --shadow-soft:  0 24px 60px rgba(0,0,0,.42);

  /* Slightly punchier gradient for dark */
  --grad-a: linear-gradient(135deg, #7ea58b 0%, #597466 100%);
}

/* =======================================================
   Base layout & primitives
   ======================================================= */

*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  font-family:'Inter', ui-sans-serif, system-ui, -apple-system, sans-serif;
  color:var(--text);
  background:
    radial-gradient(1400px 800px at -10% 0%, color-mix(in oklab, var(--brand-sage) 12%, transparent), transparent 60%),
    radial-gradient(1200px 600px at 110% 0%, color-mix(in oklab, var(--brand-sage-deep) 10%, transparent), transparent 55%),
    linear-gradient(180deg, var(--bg), var(--bg-soft) 60%, color-mix(in oklab, var(--bg-soft) 90%, var(--bg)));
  min-height:100vh;
  overflow-x:hidden;
}

.container{ max-width:1200px; margin-inline:auto; padding-inline:1rem; }
@media(min-width:640px){ .container{ padding-inline:1.5rem; } }
@media(min-width:1024px){ .container{ padding-inline:2rem; } }

.title-font{ font-family:'Playfair Display', serif; font-weight:600; letter-spacing:-.02em; }

/* Primitives */
.glass{ background:var(--glass-bg); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border:1px solid var(--glass-border); }
.bordered{ border-color:var(--border) !important; }
.text-muted{ color:var(--text-muted); }
.surface-2{ background:color-mix(in oklab, var(--glass-bg) 60%, transparent); }

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .75rem 1.25rem;
  border-radius: 12px;
  font-weight: 600;
  font-size: .95rem;
  border: 0;
  cursor: pointer;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: all .25s cubic-bezier(.2,.8,.2,1);
}

/* Shared light sweep effect */

.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  left: -120%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.25), transparent);
  transition: left .45s;
}

.btn:hover::before {
  left: 120%;
}

/* Solid primary (hero CTAs) */

.btn-primary {
  background: var(--grad-a);
  color: #fff;
  box-shadow: var(--shadow-glow);
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 40px rgba(143,170,147,.28);
}

/* Subtle transparent button */

.btn-ghost {
  background: transparent;
  color: var(--brand-sage);
  border: 1px solid var(--glass-border);
}

.btn-ghost:hover {
  background: color-mix(in oklab, var(--glass-bg) 70%, transparent);
  transform: translateY(-1px);
}

.dark .btn-ghost {
  color: #cfe0d4;
}

/* Outline button (used for Clear / Cancel / secondary CTAs) */

.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  padding: 0.45rem 0.9rem;
  border-radius: 10px;
  font-size: 0.8rem;
  font-weight: 500;
  background: transparent;
  color: var(--text);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: background-color 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, transform 0.12s ease;
}

.btn-outline:hover {
  background: color-mix(in oklab, var(--brand-sage) 10%, transparent);
  border-color: color-mix(in oklab, var(--brand-sage) 50%, var(--border));
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.10);
  transform: translateY(-0.5px);
}

/* Danger CTA (destructive modals, irreversible) */

.btn-danger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.45rem 1rem;
  border-radius: 10px;
  font-size: 0.8rem;
  font-weight: 600;
  background: #dc2626;
  color: #fef2f2;
  border: 1px solid #b91c1c;
  cursor: pointer;
  transition: background-color 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, transform 0.12s ease;
}

.btn-danger:hover {
  background: #b91c1c;
  border-color: #991b1b;
  box-shadow: 0 6px 16px rgba(127, 29, 29, 0.4);
  transform: translateY(-1px);
}

.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.45rem 1rem;
  border-radius: 10px;
  font-size: 0.8rem;
  font-weight: 600;
  background: #616060;
  color: #fef2f2;
  border: 1px solid #756b6b;
  cursor: pointer;
  transition: background-color 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, transform 0.12s ease;
}

.btn-secondary:hover {
  background: #615959;
  border-color: #685f5f;
  box-shadow: 0 6px 16px rgba(127, 29, 29, 0.4);
  transform: translateY(-1px);
}

/* Table */

.table-cell {
  padding: 8px 12px;
  font-size: 0.85rem;
  vertical-align: middle;
}

.table-actions {
  text-align: right;
  white-space: nowrap;
}

.table-empty {
  padding: 12px;
  font-size: 0.75rem;
  color: var(--text-muted);
  text-align: center;
}

/* ---------------------------------------
   2. Size utilities (shared)
   --------------------------------------- */

.btn-sm {
  padding: 0.55rem 0.9rem;
  font-size: 0.85rem;
  border-radius: 10px;
}

.btn-xs {
  font-size: 0.78rem;
  padding: 0.35rem 0.75rem;
  border-radius: 8px;
}

.btn-xxs {
  font-size: 0.7rem;
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
}

/* ---------------------------------------
   3. Pill buttons (admin / dashboard)
   --------------------------------------- */

/* Base pill — used for all admin/action buttons and compact UI controls */

.pill-btn,
.btn-admin-action,
.admin-refresh-btn,
.appt-pagination .pager-btn,
#booking-page-form .coupon-apply-btn,
.bk-coupon-wrapper button#bk-coupon-apply,
.appt-view-toggle-btn,
.appt-slot-pill,
.btn-danger-soft {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.3rem 0.8rem;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  border: 1px solid var(--border-soft);
  background: color-mix(in oklab, var(--bg) 92%, var(--bg-soft) 8%);
  color: var(--text-strong);
  cursor: pointer;
  transition: background-color 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, transform 0.12s ease;
}

/* Hover baseline (non-disabled) */

.pill-btn:hover,
.btn-admin-action:hover:not(.disabled),
.admin-refresh-btn:hover,
.appt-pagination .pager-btn:hover:not(.disabled),
#booking-page-form .coupon-apply-btn:hover,
.bk-coupon-wrapper button#bk-coupon-apply:hover,
.appt-view-toggle-btn:hover,
.appt-slot-pill:hover:not([aria-disabled="true"]),
.btn-danger-soft:hover {
  background: var(--bg-hover);
  border-color: var(--border-strong);
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.12);
  transform: translateY(-0.5px);
}

/* Disabled state helper */

.pill-disabled,
.pill-btn.disabled,
.appt-pagination .pager-btn.disabled,
.appt-slot-pill[aria-disabled="true"],
.appt-slot-pill:disabled {
  opacity: 0.4;
  cursor: default;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Semantic pill variants (used by admin actions, etc.) */

.pill-confirm,
.btn-admin-confirm {
  background: color-mix(in oklab, #22c55e 18%, transparent);
  border-color: color-mix(in oklab, #16a34a 55%, transparent);
  color: #14532d;
}

.pill-noshow,
.btn-admin-noshow {
  background: color-mix(in oklab, #facc15 16%, transparent);
  border-color: color-mix(in oklab, #f59e0b 55%, transparent);
  color: #713f12;
}

.pill-cancel,
.btn-admin-cancel {
  background: color-mix(in oklab, #ef4444 15%, transparent);
  border-color: color-mix(in oklab, #b91c1c 55%, transparent);
  color: #7f1d1d;
}

.pill-neutral {
  background: color-mix(in oklab, #64748b 16%, transparent);
  border-color: color-mix(in oklab, #475569 55%, transparent);
  color: #020617;
}

.pill-danger,
.btn-danger-soft {
  background: color-mix(in oklab, #ef4444 14%, transparent);
  border-color: color-mix(in oklab, #b91c1c 50%, transparent);
  color: #b91c1c;
}

/* Admin refresh button uses confirm-like styling */

.admin-refresh-btn {
  padding: 0.25rem 0.9rem;
  font-size: 0.75rem;
  background-color: color-mix(in oklab, var(--brand-sage) 10%, transparent);
  border-color: color-mix(in oklab, var(--brand-sage) 70%, transparent);
  color: var(--text-strong);
  box-shadow: 0 10px 25px rgba(15, 23, 42, 0.06);
}

.admin-refresh-btn:hover {
  background-color: color-mix(in oklab, var(--brand-sage) 18%, transparent);
  border-color: var(--brand-sage);
  transform: translateY(-0.5px);
  box-shadow: 0 14px 32px rgba(15, 23, 42, 0.12);
}

.admin-refresh-btn:active {
  transform: translateY(0);
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.10);
}

/* Dark mode tweaks for pill variants */

.dark .pill-confirm,
.dark .btn-admin-confirm {
  background: color-mix(in oklab, #16a34a 32%, transparent);
  border-color: color-mix(in oklab, #22c55e 70%, transparent);
  color: #dcfce7;
}

.dark .pill-noshow,
.dark .btn-admin-noshow {
  background: color-mix(in oklab, #f59e0b 32%, transparent);
  border-color: color-mix(in oklab, #fbbf24 70%, transparent);
  color: #fef9c3;
}

.dark .pill-cancel,
.dark .btn-admin-cancel {
  background: color-mix(in oklab, #b91c1c 34%, transparent);
  border-color: color-mix(in oklab, #ef4444 70%, transparent);
  color: #fee2e2;
}

.dark .pill-neutral {
  background: color-mix(in oklab, #475569 30%, transparent);
  border-color: color-mix(in oklab, #64748b 70%, transparent);
  color: #e5e7eb;
}

.dark .pill-danger,
.dark .btn-danger-soft {
  background: color-mix(in oklab, #b91c1c 32%, transparent);
  border-color: color-mix(in oklab, #ef4444 70%, transparent);
  color: #fee2e2;
}

.dark .admin-refresh-btn {
  background-color: color-mix(in oklab, var(--brand-sage) 22%, #020617 78%);
  border-color: color-mix(in oklab, var(--brand-sage) 85%, #020617 15%);
  color: #ecfdf3;
  box-shadow: 0 10px 24px rgba(0,0,0,0.55);
}

.dark .admin-refresh-btn:hover {
  background-color: color-mix(in oklab, var(--brand-sage) 30%, #020617 70%);
}

/* ---------------------------------------
   4. Context-specific buttons
   --------------------------------------- */

/* Booking form coupon apply button */

#booking-page-form .coupon-apply-btn {
  height: 48px;
  padding: 0 18px;
  font-size: 0.9rem;
  min-width: 70px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  box-shadow: none !important;
}

#booking-page-form .coupon-apply-btn:hover {
  background: color-mix(in oklab, var(--brand-sage) 12%, transparent);
  border-color: var(--brand-sage);
}

html[data-theme="dark"] #booking-page-form .coupon-apply-btn,
.theme-dark #booking-page-form .coupon-apply-btn {
  border-color: color-mix(in oklab, #64748b 60%, transparent);
  color: var(--text);
}

html[data-theme="dark"] #booking-page-form .coupon-apply-btn:hover,
.theme-dark #booking-page-form .coupon-apply-btn:hover {
  background: color-mix(in oklab, var(--brand-sage) 18%, transparent);
  border-color: var(--brand-sage);
}

/* Coupon input + apply button in booking widgets */

.bk-coupon-wrapper input#bk-coupon,
.bk-coupon-wrapper button#bk-coupon-apply {
  border: 1px solid var(--brand-sage);
  background-color: color-mix(in oklab, var(--brand-sage) 12%, transparent);
  color: var(--text);
  transition: background-color 0.25s ease, border-color 0.25s ease;
}

html[data-theme="light"] .bk-coupon-wrapper button#bk-coupon-apply:hover {
  background-color: color-mix(in oklab, var(--brand-sage) 25%, transparent);
  border-color: var(--brand-sage);
}

html[data-theme="dark"] .bk-coupon-wrapper button#bk-coupon-apply:hover {
  background-color: color-mix(in oklab, var(--brand-sage) 35%, transparent);
  border-color: var(--brand-sage);
}

#bk-coupon {
  border-radius: 1rem;
}

#bk-coupon-apply {
  border-radius: 1rem;
}

/* Admin appointment action buttons (Confirm / No-show / Cancel) */

.btn-admin-action {
  padding: 0.3rem 0.8rem;
}

/* Small soft-danger in staff/service tables */

.btn-danger-soft {
  padding: 0.3rem 0.8rem;
  font-size: 0.78rem;
}

/* Cards & chips */
.card{
  background:var(--glass-bg); border:1px solid var(--glass-border);
  border-radius:20px; padding:24px; transition:all .35s cubic-bezier(.175,.885,.32,1.275); position:relative; overflow:hidden;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-soft); border-color:color-mix(in oklab, var(--brand-sage) 30%, var(--glass-border)); }
.chip{ display:inline-flex; gap:.5rem; align-items:center; border-radius:999px; padding:.45rem .9rem; background:var(--glass-bg); border:1px solid var(--glass-border); font-size:.9rem; }
.gradient-text{ background:var(--grad-a); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.price-badge{ background:var(--grad-a); color:#fff; font-weight:700; padding:.35rem .75rem; border-radius:999px; font-size:.9rem; }

/* Animations (respect reduced motion) */
@media (prefers-reduced-motion: reduce) { *{ animation:none!important; transition:none!important; } }
@keyframes float{ 0%,100%{ transform:translateY(0)} 50%{ transform:translateY(-10px)} }
.floating{ animation:float 6s ease-in-out infinite; }
.fade-in{ opacity:0; transform:translateY(18px); animation:fadeIn .7s ease-out forwards; }
@keyframes fadeIn{ to{ opacity:1; transform:translateY(0);} }

/* =======================================================
   NAV: logo sizing & wordmark
   ======================================================= */
.brand-logo{
  display:block;
  width:48px; height:48px;        /* bigger, per request */
  border-radius:10px;
  object-fit:contain;
  box-shadow:0 4px 14px rgba(2,6,23,.12);
}
@media (max-width:640px){
  .brand-logo{ width:40px; height:40px; }
}
.dark .brand-logo{ box-shadow:0 6px 18px rgba(0,0,0,.55); }

.brand-logo--sm{ width:36px; height:36px; border-radius:8px; }
.brand-wordmark{ font-weight:900; letter-spacing:-.02em; line-height:1; white-space:nowrap; color:var(--brand-sage); }

/* =======================================================
   Services cards / grids
   ======================================================= */
.svc-grid, .grid-slim{
  display:grid; gap:14px; grid-template-columns:repeat(1, minmax(0,1fr));
}
@media (min-width:520px){ .svc-grid, .grid-slim{ grid-template-columns:repeat(2, minmax(0,1fr)); } }
@media (min-width:920px){ .svc-grid, .grid-slim{ grid-template-columns:repeat(3, minmax(0,1fr)); } }

.compact .svc-card{ padding:12px; }
.compact .svc-card h3{ font-size:1rem; margin-bottom:.25rem; }
.compact .svc-card .svc-meta{ font-size:.85rem; }

.svc-card{
  position:relative; display:flex; flex-direction:column; gap:.65rem;
  border-radius:16px; background:#fff; border:1px solid #e5e7eb; padding:16px;
  box-shadow:0 2px 6px rgba(2,6,23,.04), 0 10px 30px rgba(2,6,23,.08);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.dark .svc-card{
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  border-color: color-mix(in oklab, var(--border) 80%, transparent);
  box-shadow: 0 2px 6px rgba(0,0,0,.20), 0 14px 34px rgba(0,0,0,.30);
}
.svc-card:hover{
  transform:translateY(-2px);
  border-color: color-mix(in oklab, var(--brand-sage) 28%, #e5e7eb);
  box-shadow:0 8px 24px rgba(2,6,23,.10), 0 18px 42px rgba(2,6,23,.12);
}

.svc-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:.75rem; }
.svc-title{ font-weight:650; line-height:1.25; font-size:1.05rem; }
.svc-price{
  background: var(--grad-a); color:#fff; font-weight:700; border-radius:999px;
  padding:.35rem .7rem; font-size:.92rem; white-space:nowrap; box-shadow:0 6px 16px rgba(96,122,102,.25);
}
.svc-meta{ color:var(--text-muted); font-size:.92rem; display:flex; flex-wrap:wrap; gap:.5rem .75rem; }
.svc-desc{ color:var(--text-muted); font-size:.95rem; line-height:1.5; margin-top:.15rem; }
.svc-cta{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:.75rem; }

/* Focus */
:where(a, button).btn:focus-visible,
.svc-card:focus-within{ outline:3px solid color-mix(in oklab, var(--brand-sage) 45%, #9fc2a2); outline-offset:2px; }

/* =======================================================
   Accordion (dark readable)
   ======================================================= */
.accordion summary{ background: rgba(255,255,255,.88); color:#0f172a; }
.accordion summary:hover{ background: rgba(248,250,252,.95); }
.accordion[open] summary{ background: rgba(248,250,252,.98); }
.accordion summary *, .accordion summary .chev{ color: inherit !important; }

.dark .accordion summary{ background: rgba(18,22,29,.92); color:#F1F5F9; }
.dark .accordion summary:hover{ background: rgba(26,32,40,.92); }
.dark .accordion[open] summary{ background: rgba(22,27,36,.95); }

/* =======================================================
   Popular Services (theme-aware)
   ======================================================= */

:root{
  --home-brd: rgba(2,6,23,.12);
  --home-bg: color-mix(in oklab, #ffffff 96%, transparent);
  --home-muted: #6b7280;

  --pop-brd: var(--home-brd);
  --pop-bg: var(--home-bg);
  --pop-muted: var(--home-muted);

  --wash-a: color-mix(in oklab, var(--brand-sage) 10%, transparent);
  --wash-b: color-mix(in oklab, var(--brand-sage-deep) 10%, transparent);
}
.dark{
  --home-brd: rgba(148,163,184,.28);
  --home-bg: color-mix(in oklab, #0f172a 80%, #ffffff 20%);
  --home-muted: #cbd5e1;

  --pop-brd: var(--home-brd);
  --pop-bg: color-mix(in oklab, #0f172a 78%, #ffffff 22%);


  --wash-a: color-mix(in oklab, var(--brand-sage) 16%, transparent);
  --wash-b: color-mix(in oklab, var(--brand-sage-deep) 14%, transparent);
}

.section-box{
  border:1px solid var(--home-brd);
  border-radius:20px;
  background:var(--home-bg);
  box-shadow:0 2px 6px rgba(2,6,23,.05), 0 14px 32px rgba(2,6,23,.08);
}
.dark .section-box{
  box-shadow:0 2px 8px rgba(0,0,0,.32), 0 18px 44px rgba(0,0,0,.42);
}

.popular-card{
  position:relative;
  border:1px solid var(--pop-brd);
  border-radius:18px;
  padding:18px;
  background:
    radial-gradient(120% 140% at 0% 0%, var(--wash-a), transparent 60%),
    radial-gradient(140% 120% at 100% 0%, var(--wash-b), transparent 55%),
    var(--pop-bg);
  box-shadow:0 2px 6px rgba(2,6,23,.05), 0 14px 32px rgba(2,6,23,.08);
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.dark .popular-card{
  box-shadow:0 2px 10px rgba(0,0,0,.34), 0 20px 48px rgba(0,0,0,.46);
}
.popular-card:hover{
  transform:translateY(-2px);
  border-color:color-mix(in oklab, var(--brand-sage) 24%, var(--pop-brd));
  box-shadow:0 8px 24px rgba(2,6,23,.10), 0 20px 46px rgba(2,6,23,.12);
}
.popular-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:.75rem; margin-bottom:.45rem; }
.popular-title{ font-weight:800; font-size:1.08rem; line-height:1.25; }
.popular-meta{ color:var(--pop-muted); font-size:.92rem; }

.popular-price{
  display:inline-flex; align-items:center; justify-content:center;
  padding:.42rem .76rem; border-radius:999px;
  font-weight:900; font-size:.9rem; letter-spacing:.01em;
  background: var(--grad-a);
  color:#fff; text-shadow:0 1px 0 rgba(0,0,0,.25);
  box-shadow:0 6px 16px rgba(80,102,90,.25);
  white-space:nowrap; border:1px solid rgba(255,255,255,.18);
}

/* Highlights row inside CTA */
.hl-item{ transition: background-color .2s ease, box-shadow .2s ease; }
.hl-item:hover{ background: rgba(148,163,184,.10); box-shadow: 0 8px 22px rgba(2,6,23,.10); }

/* =======================================================
   Glossy background helpers
   ======================================================= */

.bg-gloss{
  position:relative; isolation:isolate;
  background:
    radial-gradient(1200px 600px at -10% -10%, color-mix(in oklab, var(--brand-sage) 10%, transparent), transparent 55%),
    radial-gradient(1000px 520px at 110% 0%, color-mix(in oklab, var(--brand-sage-deep) 10%, transparent), transparent 55%),
    linear-gradient(180deg, var(--bg), var(--bg-soft));
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
}
.bg-gloss::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(90% 40% at 50% -10%, rgba(255,255,255,.22), rgba(255,255,255,0) 60%);
  mix-blend-mode:screen; opacity:.7; z-index:-1;
}
.bg-gloss::after{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.05;
  background: repeating-linear-gradient(0deg, rgba(255,255,255,.35) 0, rgba(255,255,255,.35) 1px, transparent 1px, transparent 3px);
  mask-image: radial-gradient(80% 60% at 50% 0%, #000 40%, transparent 80%); z-index:-1;
}

.dark .bg-gloss{
  background:
    radial-gradient(1200px 600px at -10% -10%, color-mix(in oklab, var(--brand-sage) 18%, transparent), transparent 55%),
    radial-gradient(1000px 520px at 110% 0%, color-mix(in oklab, var(--brand-sage-deep) 16%, transparent), transparent 55%),
    linear-gradient(180deg, #0b1220, #0f172a 60%, #111827);
}
.dark .bg-gloss::before{ background: radial-gradient(90% 40% at 50% -10%, rgba(255,255,255,.12), rgba(255,255,255,0) 60%); opacity:.9; }
.dark .bg-gloss::after{ opacity:.06; }

/* CTA gradient (sage) */
.cta-gradient{ background: var(--grad-a); }

/* Panel gloss (highlight tiles) */
.panel-gloss{ background: rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
.dark .panel-gloss{ background: rgba(17,24,39,.45); border-color: rgba(255,255,255,.08); }



/* =======================================================
   Forms — inputs & textareas
   ======================================================= */
.input, .textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: var(--glass-bg);
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1.4;
  transition: all 0.2s ease;
}

.input::placeholder,
.textarea::placeholder {
  color: var(--text-muted);
}

.input:focus, .textarea:focus {
  outline: none;
  border-color: var(--brand-sage);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-sage) 30%, transparent);
  background: #fff;
}

.dark .input, .dark .textarea {
  background: rgba(17,24,39,.75);
  border-color: var(--glass-border);
  color: var(--text);
}

.dark .input:focus, .dark .textarea:focus {
  border-color: var(--brand-sage);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-sage) 35%, transparent);
  background: rgba(24,33,45,.9);
}

/* Footer headers normalized */
.footer-heading {
  margin: 0 0 1rem 0;
  font-size: 1.125rem;
}


/* ---------------------------------------
   3. Pill buttons (admin / dashboard)
   --------------------------------------- */

/* Base pill — used for all admin/action buttons and compact UI controls */

.pill-btn,
.btn-admin-action,
.admin-refresh-btn,
.appt-pagination .pager-btn,
#booking-page-form .coupon-apply-btn,
.bk-coupon-wrapper button#bk-coupon-apply,
.appt-view-toggle-btn,
.appt-slot-pill,
.btn-danger-soft {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.3rem 0.8rem;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  border: 1px solid var(--border-soft);
  background: color-mix(in oklab, var(--bg) 92%, var(--bg-soft) 8%);
  color: var(--text-strong);
  cursor: pointer;
  transition: background-color 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, transform 0.12s ease;
}

/* Hover baseline (non-disabled) */

.pill-btn:hover,
.btn-admin-action:hover:not(.disabled),
.admin-refresh-btn:hover,
.appt-pagination .pager-btn:hover:not(.disabled),
#booking-page-form .coupon-apply-btn:hover,
.bk-coupon-wrapper button#bk-coupon-apply:hover,
.appt-view-toggle-btn:hover,
.appt-slot-pill:hover:not([aria-disabled="true"]),
.btn-danger-soft:hover {
  background: var(--bg-hover);
  border-color: var(--border-strong);
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.12);
  transform: translateY(-0.5px);
}

/* Disabled state helper */

.pill-disabled,
.pill-btn.disabled,
.appt-pagination .pager-btn.disabled,
.appt-slot-pill[aria-disabled="true"],
.appt-slot-pill:disabled {
  opacity: 0.4;
  cursor: default;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Semantic pill variants (used by admin actions, etc.) */

.pill-confirm,
.btn-admin-confirm {
  background: color-mix(in oklab, #22c55e 18%, transparent);
  border-color: color-mix(in oklab, #16a34a 55%, transparent);
  color: #14532d;
}

.pill-noshow,
.btn-admin-noshow {
  background: color-mix(in oklab, #facc15 16%, transparent);
  border-color: color-mix(in oklab, #f59e0b 55%, transparent);
  color: #713f12;
}

.pill-cancel,
.btn-admin-cancel {
  background: color-mix(in oklab, #ef4444 15%, transparent);
  border-color: color-mix(in oklab, #b91c1c 55%, transparent);
  color: #7f1d1d;
}

.pill-neutral {
  background: color-mix(in oklab, #64748b 16%, transparent);
  border-color: color-mix(in oklab, #475569 55%, transparent);
  color: #020617;
}

.pill-danger,
.btn-danger-soft {
  background: color-mix(in oklab, #ef4444 14%, transparent);
  border-color: color-mix(in oklab, #b91c1c 50%, transparent);
  color: #b91c1c;
}

/* Admin refresh button uses confirm-like styling */

.admin-refresh-btn {
  padding: 0.25rem 0.9rem;
  font-size: 0.75rem;
  background-color: color-mix(in oklab, var(--brand-sage) 10%, transparent);
  border-color: color-mix(in oklab, var(--brand-sage) 70%, transparent);
  color: var(--text-strong);
  box-shadow: 0 10px 25px rgba(15, 23, 42, 0.06);
}

.admin-refresh-btn:hover {
  background-color: color-mix(in oklab, var(--brand-sage) 18%, transparent);
  border-color: var(--brand-sage);
  transform: translateY(-0.5px);
  box-shadow: 0 14px 32px rgba(15, 23, 42, 0.12);
}

.admin-refresh-btn:active {
  transform: translateY(0);
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.10);
}

/* Dark mode tweaks for pill variants */

.dark .pill-confirm,
.dark .btn-admin-confirm {
  background: color-mix(in oklab, #16a34a 32%, transparent);
  border-color: color-mix(in oklab, #22c55e 70%, transparent);
  color: #dcfce7;
}

.dark .pill-noshow,
.dark .btn-admin-noshow {
  background: color-mix(in oklab, #f59e0b 32%, transparent);
  border-color: color-mix(in oklab, #fbbf24 70%, transparent);
  color: #fef9c3;
}

.dark .pill-cancel,
.dark .btn-admin-cancel {
  background: color-mix(in oklab, #b91c1c 34%, transparent);
  border-color: color-mix(in oklab, #ef4444 70%, transparent);
  color: #fee2e2;
}

.dark .pill-neutral {
  background: color-mix(in oklab, #475569 30%, transparent);
  border-color: color-mix(in oklab, #64748b 70%, transparent);
  color: #e5e7eb;
}

.dark .pill-danger,
.dark .btn-danger-soft {
  background: color-mix(in oklab, #b91c1c 32%, transparent);
  border-color: color-mix(in oklab, #ef4444 70%, transparent);
  color: #fee2e2;
}

.dark .admin-refresh-btn {
  background-color: color-mix(in oklab, var(--brand-sage) 22%, #020617 78%);
  border-color: color-mix(in oklab, var(--brand-sage) 85%, #020617 15%);
  color: #ecfdf3;
  box-shadow: 0 10px 24px rgba(0,0,0,0.55);
}

.dark .admin-refresh-btn:hover {
  background-color: color-mix(in oklab, var(--brand-sage) 30%, #020617 70%);
}

/* ---------------------------------------
   4. Context-specific buttons
   --------------------------------------- */

/* Booking form coupon apply button */

#booking-page-form .coupon-apply-btn {
  height: 48px;
  padding: 0 18px;
  font-size: 0.9rem;
  min-width: 70px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  box-shadow: none !important;
}

#booking-page-form .coupon-apply-btn:hover {
  background: color-mix(in oklab, var(--brand-sage) 12%, transparent);
  border-color: var(--brand-sage);
}

html[data-theme="dark"] #booking-page-form .coupon-apply-btn,
.theme-dark #booking-page-form .coupon-apply-btn {
  border-color: color-mix(in oklab, #64748b 60%, transparent);
  color: var(--text);
}

html[data-theme="dark"] #booking-page-form .coupon-apply-btn:hover,
.theme-dark #booking-page-form .coupon-apply-btn:hover {
  background: color-mix(in oklab, var(--brand-sage) 18%, transparent);
  border-color: var(--brand-sage);
}

/* Coupon input + apply button in booking widgets */

.bk-coupon-wrapper input#bk-coupon,
.bk-coupon-wrapper button#bk-coupon-apply {
  border: 1px solid var(--brand-sage);
  background-color: color-mix(in oklab, var(--brand-sage) 12%, transparent);
  color: var(--text);
  transition: background-color 0.25s ease, border-color 0.25s ease;
}

html[data-theme="light"] .bk-coupon-wrapper button#bk-coupon-apply:hover {
  background-color: color-mix(in oklab, var(--brand-sage) 25%, transparent);
  border-color: var(--brand-sage);
}

html[data-theme="dark"] .bk-coupon-wrapper button#bk-coupon-apply:hover {
  background-color: color-mix(in oklab, var(--brand-sage) 35%, transparent);
  border-color: var(--brand-sage);
}

#bk-coupon {
  border-radius: 1rem;
}

#bk-coupon-apply {
  border-radius: 1rem;
}

/* Admin appointment action buttons (Confirm / No-show / Cancel) */

.btn-admin-action {
  padding: 0.3rem 0.8rem;
}

/* Small soft-danger in staff/service tables */

.btn-danger-soft {
  padding: 0.3rem 0.8rem;
  font-size: 0.78rem;
}

/* =======================================================
   Animations
   ======================================================= */

@media (prefers-reduced-motion: reduce) {
  * {
    animation: none!important;
    transition: none!important;
  }
}

@keyframes float {
  0%,100%{ transform:translateY(0)} 50%{ transform:translateY(-10px)}
}

.floating {
  animation: float 6s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) { *{ animation:none!important; transition:none!important; } }
@keyframes float{ 0%,100%{ transform:translateY(0)} 50%{ transform:translateY(-10px)} }
.floating{ animation:float 6s ease-in-out infinite; }
.fade-in{ opacity:0; transform:translateY(18px); animation:fadeIn .7s ease-out forwards; }
@keyframes fadeIn{ to{ opacity:1; transform:translateY(0);} }

/* =======================================================
   NAV: logo sizing & wordmark
   ======================================================= */

.brand-logo {
  display: block;
  width: 48px;
  height: 48px;
  border-radius: 10px;
  object-fit: contain;
  box-shadow: 0 4px 14px rgba(2,6,23,.12);
}

@media (max-width:640px) {
  .brand-logo {
    width: 40px;
    height: 40px;
  }
}

.dark .brand-logo {
  box-shadow: 0 6px 18px rgba(0,0,0,.55);
}

.brand-logo--sm {
  width: 36px;
  height: 36px;
  border-radius: 8px;
}

.brand-wordmark {
  font-weight: 900;
  letter-spacing: -.02em;
  line-height: 1;
  white-space: nowrap;
  color: var(--brand-sage);
}

/* =======================================================
   Services cards / grids
   ======================================================= */

.svc-grid, .grid-slim {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(1, minmax(0,1fr));
}

@media (min-width:520px) {
  .svc-grid, .grid-slim {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (min-width:920px) {
  .svc-grid, .grid-slim {
    grid-template-columns: repeat(3, minmax(0,1fr));
  }
}

.compact .svc-card {
  padding: 12px;
}

.compact .svc-card h3 {
  font-size: 1rem;
  margin-bottom: .25rem;
}

.compact .svc-card .svc-meta {
  font-size: .85rem;
}

.svc-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: .65rem;
  border-radius: 16px;
  background: #e6eee8;
  border: 1px solid #e5e7eb;
  padding: 16px;
  box-shadow: 0 2px 6px rgba(2,6,23,.04), 0 10px 30px rgba(2,6,23,.08);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.dark .svc-card {
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  border-color: color-mix(in oklab, var(--border) 80%, transparent);
  box-shadow: 0 2px 6px rgba(0,0,0,.20), 0 14px 34px rgba(0,0,0,.30);
}

.svc-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in oklab, var(--brand-sage) 28%, #314638);
  box-shadow: 0 8px 24px rgba(2,6,23,.10), 0 18px 42px rgba(2,6,23,.12);
}

.svc-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
}

.svc-title {
  font-weight: 650;
  line-height: 1.25;
  font-size: 1.05rem;
}

.svc-price {
  background: var(--grad-a);
  color: #fff;
  font-weight: 700;
  border-radius: 999px;
  padding: .35rem .7rem;
  font-size: .92rem;
  white-space: nowrap;
  box-shadow: 0 6px 16px rgba(96,122,102,.25);
}

.svc-meta {
  color: var(--text-muted);
  font-size: .92rem;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem .75rem;
}

.svc-desc {
  color: var(--text-muted);
  font-size: .95rem;
  line-height: 1.5;
  margin-top: .15rem;
}

.svc-cta {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
}

/* Focus */

:where(a, button).btn:focus-visible,
.svc-card:focus-within {
  outline: 3px solid color-mix(in oklab, var(--brand-sage) 45%, #e6eee8);
  outline-offset: 2px;
}

/* Old category pane wrapper */

.svc-section {
  border: 1px solid var(--home-brd);
  border-radius: 20px;
  padding: 20px;
  margin-bottom: 20px;
  background: color-mix(in oklab, var(--brand-sage) 4%, var(--home-bg));
  box-shadow: 0 2px 6px rgba(2, 6, 23, .05), 0 14px 32px rgba(2, 6, 23, .08);
}

/* =======================================================
   Hover effects for category panes
   ======================================================= */

.svc-section {
  transition: box-shadow .25s ease, transform .22s ease, border-color .25s ease, background .25s ease;
}

/* Light mode hover */

.svc-section:hover {
  transform: translateY(-3px);
  background: color-mix(in oklab, var(--brand-sage) 8%, var(--home-bg));
  border-color: color-mix(in oklab, var(--brand-sage) 35%, var(--home-brd));
  box-shadow: 0 4px 14px rgba(2, 6, 23, .08), 0 18px 38px rgba(2, 6, 23, .12);
}

/* Dark mode hover */

.dark .svc-section:hover {
  background: color-mix(in oklab, var(--bg) 90%, var(--brand-sage) 12%);
  border-color: color-mix(in oklab, var(--brand-sage) 40%, var(--border));
  box-shadow: 0 6px 18px rgba(0,0,0,.32), 0 20px 48px rgba(0,0,0,.45);
}

/* Make the whole summary area clickable with nice transitions */

.svc-category-header {
  transition: color .25s ease, opacity .25s ease;
}

.svc-section:hover .svc-category-header {
  color: var(--text);
  opacity: 0.95;
}

.svc-pill-icon {
  display: inline-flex;
  transition: transform .25s ease;
}

.svc-section:hover .svc-pill-icon {
  transform: scale(1.15);
}

/* =======================================================
   Accordion (dark readable)
   ======================================================= */

.accordion summary {
  background: rgba(255,255,255,.88);
  color: #0f172a;
}

.accordion summary:hover {
  background: rgba(248,250,252,.95);
}

.accordion[open] summary {
  background: rgba(248,250,252,.98);
}

.accordion summary *, .accordion summary .chev {
  color: inherit !important;
}

.dark .accordion summary {
  background: rgba(18,22,29,.92);
  color: #F1F5F9;
}

.dark .accordion summary:hover {
  background: rgba(26,32,40,.92);
}

.dark .accordion[open] summary {
  background: rgba(22,27,36,.95);
}

/* =======================================================
   Popular Services (theme-aware)
   ======================================================= */

:root {
  --home-brd: rgba(2,6,23,.12);
  --home-bg: color-mix(in oklab, #e6eee8 90%, var(--brand-sage) 10%);
  --home-muted: #6b7280;
  --pop-brd: var(--home-brd);
  --pop-bg: var(--home-bg);
  --pop-muted: var(--home-muted);
  --wash-a: color-mix(in oklab, var(--brand-sage) 10%, transparent);
  --wash-b: color-mix(in oklab, var(--brand-sage-deep) 10%, transparent);
}

.dark {
  --home-brd: rgba(148,163,184,.28);
  --home-bg: color-mix(in oklab, #0f172a 80%, #ffffff 20%);
  --home-muted: #cbd5e1;
  --pop-brd: var(--home-brd);
  --pop-bg: color-mix(in oklab, #0f172a 78%, #ffffff 22%);
  --wash-a: color-mix(in oklab, var(--brand-sage) 16%, transparent);
  --wash-b: color-mix(in oklab, var(--brand-sage-deep) 14%, transparent);
}

.section-box {
  border: 1px solid var(--home-brd);
  border-radius: 20px;
  background: var(--home-bg);
  box-shadow: 0 2px 6px rgba(2,6,23,.05), 0 14px 32px rgba(2,6,23,.08);
}

.dark .section-box {
  box-shadow: 0 2px 8px rgba(0,0,0,.32), 0 18px 44px rgba(0,0,0,.42);
}

.popular-card {
  position: relative;
  border: 1px solid var(--pop-brd);
  border-radius: 18px;
  padding: 18px;
  background: radial-gradient(120% 140% at 0% 0%, var(--wash-a), transparent 60%), radial-gradient(140% 120% at 100% 0%, var(--wash-b), transparent 55%), var(--pop-bg);
  box-shadow: 0 2px 6px rgba(2,6,23,.05), 0 14px 32px rgba(2,6,23,.08);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.dark .popular-card {
  box-shadow: 0 2px 10px rgba(0,0,0,.34), 0 20px 48px rgba(0,0,0,.46);
}

.popular-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in oklab, var(--brand-sage) 24%, var(--pop-brd));
  box-shadow: 0 8px 24px rgba(2,6,23,.10), 0 20px 46px rgba(2,6,23,.12);
}

.popular-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .45rem;
}

.popular-title {
  font-weight: 800;
  font-size: 1.08rem;
  line-height: 1.25;
}

.popular-meta {
  color: var(--pop-muted);
  font-size: .92rem;
}

.popular-price {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .42rem .76rem;
  border-radius: 999px;
  font-weight: 900;
  font-size: .9rem;
  letter-spacing: .01em;
  background: var(--grad-a);
  color: #fff;
  text-shadow: 0 1px 0 rgba(0,0,0,.25);
  box-shadow: 0 6px 16px rgba(80,102,90,.25);
  white-space: nowrap;
  border: 1px solid rgba(255,255,255,.18);
}

.hl-item {
  transition: background-color .2s ease, box-shadow .2s ease;
}

.hl-item:hover {
  background: rgba(148,163,184,.10);
  box-shadow: 0 8px 22px rgba(2,6,23,.10);
}

/* =======================================================
   Glossy background helpers
   ======================================================= */

.bg-gloss {
  position: relative;
  isolation: isolate;
  background: radial-gradient(1200px 600px at -10% -10%, color-mix(in oklab, var(--brand-sage) 10%, transparent), transparent 55%), radial-gradient(1000px 520px at 110% 0%, color-mix(in oklab, var(--brand-sage-deep) 10%, transparent), transparent 55%), linear-gradient(180deg, var(--bg), var(--bg-soft));
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.bg-gloss::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(90% 40% at 50% -10%, rgba(255,255,255,.22), rgba(255,255,255,0) 60%);
  mix-blend-mode: screen;
  opacity: .7;
  z-index: -1;
}

.bg-gloss::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .05;
  background: repeating-linear-gradient(0deg, rgba(255,255,255,.35) 0, rgba(255,255,255,.35) 1px, transparent 1px, transparent 3px);
  mask-image: radial-gradient(80% 60% at 50% 0%, #000 40%, transparent 80%);
  z-index: -1;
}

.dark .bg-gloss {
  background: radial-gradient(1200px 600px at -10% -10%, color-mix(in oklab, var(--brand-sage) 18%, transparent), transparent 55%), radial-gradient(1000px 520px at 110% 0%, color-mix(in oklab, var(--brand-sage-deep) 16%, transparent), transparent 55%), linear-gradient(180deg, #0b1220, #0f172a 60%, #111827);
}

.dark .bg-gloss::before {
  background: radial-gradient(90% 40% at 50% -10%, rgba(255,255,255,.12), rgba(255,255,255,0) 60%);
  opacity: .9;
}

.dark .bg-gloss::after {
  opacity: .06;
}

.cta-gradient {
  background: var(--grad-a);
}

.panel-gloss {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.dark .panel-gloss {
  background: rgba(17,24,39,.45);
  border-color: rgba(255,255,255,.08);
}


/* =======================================================
   Admin / Bookings UI helpers — badges, rows, tabs
   ======================================================= */

.appt-service-meta {
  margin-top: 0.15rem;
  font-size: 0.8rem;
  line-height: 1.35;
  color: var(--text-muted);
}

/* -------------------------------------------------
   Admin appointments: service / add-ons / notes
   ------------------------------------------------- */

.appt-service-main {
  font-weight: 600;
  font-size: 0.9rem;
  margin-bottom: 0.2rem;
}

.appt-addons-row {
  margin-top: 0.1rem;
  font-size: 0.78rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  color: var(--text-muted);
}

.appt-addons-label {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 0.68rem;
  opacity: 0.9;
}

.appt-addons-text {
  font-size: 0.78rem;
}

/* Compact client-notes chip */

.appt-notes-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.20rem 0.65rem;
  border-radius: 999px;
  border: 1px dashed color-mix(in oklab, var(--brand-sage-ink) 30%, #e5e7eb);
  background: color-mix(in oklab, var(--brand-sage) 6%, #f9fafb);
  cursor: pointer;
  font-size: 0.75rem;
  line-height: 1.2;
  white-space: nowrap;
}

.dark .appt-notes-chip {
  background: color-mix(in oklab, var(--brand-sage-deep) 12%, #020617);
  border-color: color-mix(in oklab, var(--brand-sage-ink) 42%, #1f2937);
}

.appt-notes-chip-label {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.65rem;
  opacity: 0.9;
  color: var(--text-muted);
}

.appt-notes-chip-dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--brand-sage) 65%, #16a34a);
}

/* Notes modal */

.appt-notes-modal {
  position: fixed;
  inset: 0;
  z-index: 60;
}

.appt-notes-modal.hidden {
  display: none;
}

.appt-notes-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.appt-notes-modal-card {
  position: relative;
  max-width: 480px;
  margin: 6rem auto 0;
  padding: 1.5rem 1.75rem;
}

.appt-notes-modal-title {
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--text-muted);
  margin-bottom: 0.75rem;
}

.appt-notes-modal-body {
  font-size: 0.9rem;
  line-height: 1.6;
  color: var(--text);
  white-space: pre-wrap;
}

.appt-notes-modal-footer {
  margin-top: 1.25rem;
  display: flex;
  justify-content: flex-end;
}

.appt-notes-modal-close {
  padding: 0.45rem 1.1rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in oklab, var(--bg-soft) 80%, #ffffff 20%);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  color: var(--text);
  transition: background-color 0.18s ease, border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.appt-notes-modal-close:hover {
  background: color-mix(in oklab, var(--brand-sage) 12%, var(--bg-soft));
  border-color: var(--brand-sage);
  transform: translateY(-0.5px);
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.12);
}

.dark .appt-notes-modal-close {
  background: color-mix(in oklab, #020617 80%, var(--brand-sage) 20%);
  border-color: color-mix(in oklab, var(--brand-sage) 60%, #020617);
  color: #e5e7eb;
}

.text-muted-soft {
  font-size: 0.85rem;
  color: var(--text-muted);
}

.text-error-soft {
  font-size: 0.85rem;
  color: #bc0e0e;
}

.row-placeholder,
.row-placeholder-error {
  padding: 0.75rem 0.75rem;
  text-align: center;
  font-size: 0.78rem;
}

.row-placeholder {
  color: var(--text-muted);
}

.row-placeholder-error {
  color: #f97373;
}

/* Badges */

.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.1rem 0.45rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  border: 1px solid transparent;
  line-height: 1.2;
}

.badge-ok {
  background: #16a34a;
  color: #ecfdf5;
  border-color: #15803d;
}

.dark .badge-ok {
  background: #15803d;
  color: #dcfce7;
}

.badge-warn {
  background: #facc15;
  color: #713f12;
  border-color: #f59e0b;
}

.dark .badge-warn {
  background: #f59e0b;
  color: #fef9c3;
}

.badge-danger {
  background: #ef4444;
  color: #7f1d1d;
  border-color: #b91c1c;
}

.dark .badge-danger {
  background: #b91c1c;
  color: #fee2e2;
}

.badge-muted {
  background: color-mix(in oklab, #64748b 18%, transparent);
  color: #0f172a;
  border-color: color-mix(in oklab, #64748b 28%, transparent);
}

.dark .badge-muted {
  background: color-mix(in oklab, #475569 26%, transparent);
  color: #e5e7eb;
}

/* Admin tabs */

.admin-tab {
  padding: 0.45rem 0.9rem;
  font-size: 0.8rem;
  font-weight: 500;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
}

.admin-tab-active {
  border-color: var(--brand-sage);
  color: var(--text);
}

.admin-tab-inactive {
  border-color: transparent;
  color: var(--text-muted);
}

.dark .admin-tab-active {
  color: #e5e7eb;
}

.dark .admin-tab-inactive {
  color: #9ca3af;
}

/* ==========================================
   Booking Success Page (theme-aware)
   ========================================== */

.booking-success-page {
  background: radial-gradient(1400px 720px at 10% -10%, color-mix(in oklab, var(--brand-sage) 16%, transparent), transparent 60%), radial-gradient(1200px 620px at 110% 0%, color-mix(in oklab, var(--brand-sage-deep) 12%, transparent), transparent 55%), linear-gradient(180deg, var(--bg), var(--bg-soft) 65%, var(--bg));
}

.dark .booking-success-page {
  background: radial-gradient(1100px 620px at 50% 0%, color-mix(in oklab, var(--brand-sage) 18%, transparent), transparent 55%), linear-gradient(180deg, #020617, #020617);
}

.booking-success-page .glass {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.10), 0 40px 80px rgba(15, 23, 42, 0.12);
  border-radius: 24px;
}

.booking-success-page .section-box {
  border-radius: 20px;
  box-shadow: 0 2px 6px rgba(2, 6, 23, 0.05), 0 14px 32px rgba(2, 6, 23, 0.08);
}

.dark .booking-success-page .section-box {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.34), 0 20px 48px rgba(0, 0, 0, 0.46);
}

.success-halo {
  background: radial-gradient(circle at top left, color-mix(in oklab, var(--brand-sage) 22%, transparent) 0, transparent 55%), radial-gradient(circle at bottom right, color-mix(in oklab, var(--brand-sage-deep) 16%, transparent) 0, transparent 50%);
  mix-blend-mode: soft-light;
}

.success-icon-circle {
  background: color-mix(in oklab, var(--brand-sage) 70%, #0f172a 30%);
  color: #fff;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.35);
}

.dark .success-icon-circle {
  background: color-mix(in oklab, var(--brand-sage) 80%, #020617 20%);
}

.status-pill-confirmed {
  background: color-mix(in oklab, #22c55e 18%, transparent);
  border-color: color-mix(in oklab, #16a34a 55%, transparent);
  color: #166534;
}

.dark .status-pill-confirmed {
  background: color-mix(in oklab, #16a34a 28%, transparent);
  border-color: color-mix(in oklab, #22c55e 70%, transparent);
  color: #bbf7d0;
}

.booking-summary-strip {
  font-size: 0.85rem;
}

.booking-summary-strip .summary-label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-muted);
}

.booking-summary-strip .summary-icon {
  background: color-mix(in oklab, var(--brand-sage) 12%, transparent);
  color: color-mix(in oklab, var(--brand-sage) 72%, #0f172a);
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.18);
}

.dark .booking-summary-strip .summary-icon {
  background: color-mix(in oklab, var(--brand-sage) 24%, #020617);
  color: #ecfdf5;
}

.success-bullet {
  color: var(--brand-sage);
}

.dark .success-bullet {
  color: color-mix(in oklab, var(--brand-sage) 65%, #e5e7eb);
}

/* ==========================================
   Booking Admin Layout & Table
   ========================================== */

.booking-admin-page {
  background: radial-gradient(1400px 720px at -10% 0%, color-mix(in oklab, var(--brand-sage) 14%, transparent), transparent 60%),
              linear-gradient(180deg, var(--bg), var(--bg-soft) 70%, var(--bg));
}

.appt-filter-bar .filter-label {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-muted);
}

.appt-table {
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.85rem;
  width: 100%;
  table-layout: auto;
}

.appt-table th,
.appt-table td {
  padding: 0.65rem 0.8rem;
  vertical-align: top;
}

.appt-table th {
  text-align: left;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border);
  white-space: normal; /* allow wrap like Payments */
}

.appt-table tbody tr + tr td {
  border-top: 1px solid color-mix(in oklab, var(--border) 80%, transparent);
}

/* Actions layout */
.appt-actions {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

@media (min-width: 768px) {
  .appt-actions {
    flex-direction: row;
    flex-wrap: wrap;
  }
}


/* Table / calendar toggle */

.appt-view-toggle {
  display: inline-flex;
  align-items: center;
  padding: 0.15rem;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--home-brd) 80%, transparent);
  background: color-mix(in oklab, var(--home-bg) 80%, transparent);
  box-shadow: 0 2px 6px rgba(15,23,42,.06);
}

.appt-view-toggle-btn {
  border: 0;
  background: transparent;
  padding: 0.18rem 0.7rem;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.appt-view-toggle-btn-active {
  background: color-mix(in oklab, var(--brand-sage) 18%, transparent);
  color: #064e3b;
  box-shadow: 0 3px 8px rgba(15,23,42,.15);
  transform: translateY(-0.5px);
}

.dark .appt-view-toggle-btn-active {
  color: #ecfdf5;
}

/* Weekly calendar */

.appt-calendar {
  display: grid;
  grid-template-columns: repeat(7, minmax(140px, 1fr));
  gap: 0;
  font-size: 0.8rem;
}

@media (max-width: 1024px) {
  .appt-calendar {
    grid-template-columns: repeat(4, minmax(160px, 1fr));
  }
}

@media (max-width: 768px) {
  .appt-calendar {
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }
}

@media (max-width: 520px) {
  .appt-calendar {
    grid-template-columns: 1fr;
  }
}

.appt-cal-day {
  border-right: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  min-height: 180px;
  display: flex;
  flex-direction: column;
}

.appt-cal-day:last-child {
  border-right: 0;
}

.appt-cal-day-header {
  padding: 0.55rem 0.75rem 0.4rem;
  border-bottom: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.appt-cal-day-name {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text-muted);
}

.appt-cal-day-date {
  font-weight: 600;
  font-size: 0.86rem;
}

.appt-cal-day-body {
  padding: 0.55rem 0.65rem 0.7rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.appt-cal-day-empty {
  font-size: 0.72rem;
  color: var(--text-muted);
}

/* Calendar tiles */

.appt-cal-event {
  border-radius: 1rem;
  padding: 0.75rem 0.9rem;
  background: color-mix(in oklab, var(--brand-sage) 32%, var(--home-bg) 68%);
  color: #065f46;
  border: 1px solid color-mix(in oklab, var(--brand-sage) 85%, transparent);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.6);
}

.dark .appt-cal-event {
  background: color-mix(in oklab, var(--brand-sage) 28%, #020617 72%);
  border-color: color-mix(in oklab, var(--brand-sage) 80%, #020617 20%);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.8);
  color: #ecfdf3;
}

.appt-cal-event-time {
  font-size: 0.82rem;
  font-weight: 700;
  margin-bottom: 0.2rem;
}

.appt-cal-event-service {
  font-size: 0.86rem;
  font-weight: 600;
  line-height: 1.2;
}

.appt-cal-event-staff {
  font-size: 0.72rem;
}

.appt-cal-event-footer {
  margin-top: 0.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
}

.appt-cal-note-dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--brand-saffron, #f59e0b) 80%, transparent);
}

/* Staff availability block */

.appt-cal-availability {
  border-radius: 0.65rem;
  padding: 0.35rem 0.55rem;
  background: color-mix(in oklab, var(--brand-sage) 10%, var(--home-bg) 85%);
  border: 1px dashed color-mix(in oklab, var(--brand-sage-deep) 50%, transparent);
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-bottom: 0.35rem;
}

.appt-cal-availability strong {
  font-weight: 600;
  color: var(--brand-sage-ink);
}

.appt-slot-pill[aria-disabled="true"] {
  opacity: 0.4;
  cursor: default;
  pointer-events: none;
}

/* Available slot pill */

.appt-slot-label {
  margin-top: 0.15rem;
  margin-bottom: 0.25rem;
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--text-muted);
}

.appt-slot-wrapper {
  margin-bottom: 0.15rem;
}

.appt-slot-pill {
  width: 100%;
  font-size: 0.82rem;
  font-weight: 600;
  padding: 0.35rem 0.85rem;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--brand-sage) 85%, transparent);
  background: color-mix(in oklab, var(--brand-sage) 32%, var(--home-bg) 68%);
  color: #065f46;
}

.appt-slot-pill:hover {
  background: color-mix(in oklab, var(--brand-sage) 45%, var(--home-bg) 55%);
  border-color: color-mix(in oklab, var(--brand-sage) 95%, transparent);
}

.dark .appt-slot-pill{
  background:color-mix(in oklab, var(--brand-sage) 28%, #020617 72%);
  border-color:color-mix(in oklab, var(--brand-sage) 80%, #020617 20%);
  color:#ecfdf5;
}
.dark .appt-slot-pill:hover{
  background:color-mix(in oklab, var(--brand-sage) 35%, #020617 65%);
}

/* Vacation banner */

.appt-cal-vacation-banner {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0.25rem 0.75rem;
  margin-bottom: 0.35rem;
  font-size: 11px;
  border: 1px solid rgba(248, 113, 113, 0.5);
  background: rgba(127, 29, 29, 0.25);
  color: #fecaca;
}

html[data-theme="light"] .appt-cal-vacation-banner {
  border-color: rgba(248, 113, 113, 0.35);
  background: #fee2e2;
  color: #b91c1c;
}

/* Pagination */

.appt-pagination {
  margin-top: 12px;
  padding: 12px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  background: var(--bg-soft);
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  backdrop-filter: blur(6px);
}

.appt-pagination .page-info {
  color: var(--text-strong);
  font-weight: 500;
}

.appt-pagination-controls {
  display: flex;
  gap: 8px;
  align-items: center;
}

.appt-pagination .pager-btn {
  padding: 6px 14px;
  font-size: 0.78rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text-strong);
  font-weight: 500;
}

.appt-pagination .pager-btn--primary {
  background: var(--brand-sage);
  border-color: var(--brand-sage);
  color: white;
}

.appt-pagination .pager-btn--primary:hover:not(.disabled) {
  background: color-mix(in oklab, var(--brand-sage) 85%, black 15%);
  border-color: color-mix(in oklab, var(--brand-sage) 80%, black 20%);
}

.appt-pagination .pager-btn--active {
  background: var(--bg-accent);
  border-color: var(--border-strong);
  color: white;
  font-weight: 600;
}

.appt-pagination .pager-btn--active:hover {
  background: color-mix(in oklab, var(--brand-sage) 80%, black 20%);
}

.appt-pagination .pager-btn.disabled,
.pager-btn.disabled {
  opacity: 0.35;
  cursor: not-allowed;
  pointer-events: none;
}

/* Modal backdrop */

.modal-backdrop {
  background: rgba(15, 23, 42, 0.40);
  backdrop-filter: blur(4px);
}

/* =======================================================
   Staff Admin – extra primitives (chips, modal, etc.)
   ======================================================= */

.input-sm {
  padding: 0.35rem 0.6rem;
  font-size: 0.82rem;
  border-radius: 10px;
}

.chip-filter {
  font-size: 0.78rem;
  padding: 0.3rem 0.85rem;
  border-radius: 999px;
  cursor: pointer;
  background: color-mix(in oklab, var(--glass-bg) 80%, transparent);
  border-color: var(--glass-border);
  color: var(--text-muted);
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease, transform 0.10s ease;
}

.chip-filter-active {
  background: color-mix(in oklab, var(--brand-sage) 22%, #ffffff 78%);
  border-color: color-mix(in oklab, var(--brand-sage-deep) 65%, transparent);
  color: #064e3b;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.16);
  transform: translateY(-1px);
}

.dark .chip-filter {
  background: color-mix(in oklab, var(--glass-bg) 80%, #020617 20%);
  border-color: color-mix(in oklab, var(--glass-border) 80%, transparent);
  color: var(--text-muted);
}

.dark .chip-filter-active {
  background: color-mix(in oklab, var(--brand-sage) 30%, #020617 70%);
  border-color: color-mix(in oklab, var(--brand-sage-deep) 80%, #020617 20%);
  color: #ecfdf3;
}

.modal-box {
  background: var(--glass-bg);
  border-radius: 16px;
  border: 1px solid var(--glass-border);
  padding: 1.25rem 1.5rem;
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.22), 0 40px 80px rgba(15, 23, 42, 0.35);
}

.modal-box-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.modal-box-title {
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.modal-box-footer {
  margin-top: 1.1rem;
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  flex-wrap: wrap;
}

/* Staff table cells */

.staff-name-cell .staff-name {
  font-size: 0.95rem;
  font-weight: 600;
}

.staff-services-cell {
  font-size: 0.8rem;
  color: var(--text-muted);
  white-space: nowrap;
}

.staff-bio-cell {
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--text-muted);
}

.staff-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.4rem;
}

/* Staff category + service chips */

#staffServiceCategoryList button {
  border-radius: 999px;
  padding: 0.35rem 0.9rem;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid var(--home-brd);
  background: color-mix(in oklab, var(--home-bg) 85%, var(--brand-sage) 15%);
  color: var(--text);
  box-shadow: 0 2px 5px rgba(15, 23, 42, 0.06);
  transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}

#staffServiceCategoryList button:hover {
  background: color-mix(in oklab, var(--brand-sage) 30%, var(--home-bg) 70%);
  border-color: color-mix(in oklab, var(--brand-sage) 70%, var(--home-brd) 30%);
  transform: translateY(-0.5px);
}

#staffServiceCategoryList button.bg-emerald-50 {
  background: color-mix(in oklab, var(--brand-sage) 45%, var(--home-bg) 55%);
  border-color: color-mix(in oklab, var(--brand-sage) 80%, var(--home-brd) 20%);
  color: var(--text);
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.15);
}

#staffServiceCategoryList button.bg-emerald-600 {
  background: var(--grad-a);
  border-color: color-mix(in oklab, var(--brand-sage) 80%, var(--brand-sage-deep) 20%);
  color: #ffffff;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.2);
}

#staffServicesList label {
  border-radius: 999px;
  padding: 0.35rem 0.9rem;
  font-size: 0.78rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  border: 1px solid color-mix(in oklab, var(--home-brd) 85%, transparent);
  background: color-mix(in oklab, var(--home-bg) 80%, var(--brand-sage) 20%);
  color: var(--text);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
  transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}

#staffServicesList label:hover {
  background: color-mix(in oklab, var(--brand-sage) 35%, var(--home-bg) 65%);
  border-color: color-mix(in oklab, var(--brand-sage) 70%, var(--home-brd) 30%);
  box-shadow: 0 3px 8px rgba(15, 23, 42, 0.12);
  transform: translateY(-0.5px);
}

#staffServicesList label.bg-emerald-50 {
  background: color-mix(in oklab, var(--brand-sage) 50%, var(--home-bg) 50%);
  border-color: color-mix(in oklab, var(--brand-sage) 85%, var(--home-brd) 15%);
  color: var(--text);
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.16);
}

#staffServicesList label input[type="checkbox"] {
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 0.35rem;
  border: 1px solid color-mix(in oklab, var(--border) 80%, transparent);
}

#staffServiceCategoryList {
  margin-bottom: 1rem !important;
}

#staffServicesList {
  margin-top: 0.5rem;
}

.collapsible {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height 0.35s ease, opacity 0.25s ease;
}

.collapsible.expanded {
  max-height: 2500px;
  opacity: 1;
}

/* =======================================================
   Reviews page form, rating, badges, and sort pill
   Theme-aware (light + dark) using your theme tokens
   ======================================================= */

/* ---------- Form fields (shared) ---------- */
.section-reviews .review-form input[type="text"],
.section-reviews .review-form input[type="email"],
.section-reviews .review-form input[type="number"],
.section-reviews .review-form textarea{
  width: 100%;
  padding: 0.75rem 1rem;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: color-mix(in oklab, var(--bg) 70%, var(--bg-soft) 30%);
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1.4;
  transition: background .15s ease, border-color .15s ease, box-shadow .15s ease, color .15s ease;
  box-shadow: 0 0 0 0 transparent;
  caret-color: var(--text);
}

/* Placeholders */
.section-reviews .review-form input::placeholder,
.section-reviews .review-form textarea::placeholder{
  color: var(--text-muted);
}

/* Focus */
.section-reviews .review-form input:focus,
.section-reviews .review-form textarea:focus{
  outline: none;
  border-color: var(--brand-sage);
  background: color-mix(in oklab, var(--bg) 82%, var(--bg-soft) 18%);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-sage) 30%, transparent);
}

/* ---------- Rating number input (tight size) ---------- */
.section-reviews .review-form input[type="number"]{
  width: 3.5rem;
  height: 2.75rem;
  padding: 0 0.75rem;
  text-align: center;
  font-size: 1.1rem;
  font-weight: 700;
  border-radius: 12px;
}

/* ---------- Rating bars ---------- */
.section-reviews .rating-bar-bg{
  border-radius: 999px;
  overflow: hidden;
  background: color-mix(in oklab, var(--bg-soft) 65%, #e5e7eb 35%);
}

.dark .section-reviews .rating-bar-bg{
  background: color-mix(in oklab, var(--bg-soft) 80%, #020617 20%);
}

.section-reviews .rating-bar-fill{
  height: 100%;
  border-radius: 999px;
  background-image: linear-gradient(
    to right,
    var(--brand-sage),
    color-mix(in oklab, var(--brand-sage) 45%, #22c55e)
  );
  transition: width .25s ease-out;
}

.section-reviews .rating-count{ color: var(--text-muted); }

.section-reviews .review-divider{
  border: none;
  border-bottom: 1px solid var(--glass-border);
}

.section-reviews .rating-label{
  color: color-mix(in oklab, var(--text) 88%, var(--text-muted) 12%);
}


/* =======================================================
   Source badges (theme-aware via tokens)
   ======================================================= */

.review-source-badge{
  font-size: 10px;
  line-height: 1;
  padding: 6px 10px;
  border-radius: 999px;
  letter-spacing: .12em;
  text-transform: uppercase;
  border: 1px solid color-mix(in oklab, var(--glass-border) 65%, transparent);
  background: color-mix(in oklab, var(--bg) 70%, transparent);
  color: color-mix(in oklab, var(--text) 80%, var(--text-muted) 20%);
  backdrop-filter: blur(6px);
}

/* Brighter light variants */
.review-source-google{
  background: rgba(66,133,244,.22);
  border-color: rgba(66,133,244,.48);
  color: color-mix(in oklab, var(--text) 25%, rgb(30, 64, 175) 75%);
}
.review-source-setmore{
  background: rgba(16,185,129,.22);
  border-color: rgba(16,185,129,.48);
  color: color-mix(in oklab, var(--text) 25%, rgb(6, 95, 70) 75%);
}
.review-source-site{
  background: rgba(245,158,11,.24);
  border-color: rgba(245,158,11,.52);
  color: color-mix(in oklab, var(--text) 25%, rgb(146, 64, 14) 75%);
}
.review-source-other{
  background: rgba(107,114,128,.22);
  border-color: rgba(107,114,128,.48);
  color: color-mix(in oklab, var(--text) 45%, rgb(55, 65, 81) 55%);
}

/* Dark mode badge base (token-driven) */
.dark .review-source-badge{
  border-color: color-mix(in oklab, rgba(255,255,255,.22) 55%, var(--glass-border) 45%);
  background: color-mix(in oklab, var(--bg) 55%, transparent);
  color: color-mix(in oklab, var(--text) 92%, var(--text-muted) 8%);
}

/* Dark mode variants (still vibrant, not washed out) */
.dark .review-source-google{
  background: rgba(66,133,244,.18);
  border-color: rgba(66,133,244,.62);
  color: rgba(191, 219, 254, .98);
}
.dark .review-source-setmore{
  background: rgba(16,185,129,.16);
  border-color: rgba(16,185,129,.62);
  color: rgba(167, 243, 208, .98);
}
.dark .review-source-site{
  background: rgba(245,158,11,.18);
  border-color: rgba(245,158,11,.66);
  color: rgba(254, 215, 170, .98);
}
.dark .review-source-other{
  background: rgba(148,163,184,.14);
  border-color: rgba(148,163,184,.48);
  color: rgba(226, 232, 240, .96);
}


/* =======================================================
   Sort dropdown pill (theme-aware)
   ======================================================= */

.section-reviews .sort-pill{
  position: relative;
  background: color-mix(in oklab, var(--bg) 70%, var(--bg-soft) 30%);
  border: 1px solid var(--glass-border);
  color: var(--text);
  transition: background .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.section-reviews .sort-pill:hover{
  border-color: color-mix(in oklab, var(--brand-sage) 40%, var(--glass-border));
  background: color-mix(in oklab, var(--bg) 78%, var(--bg-soft) 22%);
}

.section-reviews .sort-pill:focus-within{
  border-color: var(--brand-sage);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-sage) 30%, transparent);
}

/* Select + chevron */
.section-reviews .sort-select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 2.5rem;
}
.section-reviews .sort-chevron{
  color: var(--text-muted);
}

/* Force consistent select rendering */
.section-reviews #reviews-sort{
  -webkit-appearance: none;
  appearance: none;
  background: transparent !important;
  color: inherit !important;
}

/* Options panel colors (theme tokens; avoids #fff / hardcoded dark) */
.section-reviews #reviews-sort option{
  background: var(--bg);
  color: var(--text);
}

/* Some browsers ignore option background in dark mode; at least keep text readable */
.dark .section-reviews #reviews-sort option{
  background: var(--bg);
  color: var(--text);
}

.section-reviews .review-row-border{
  border-color: color-mix(in oklab, #0f172a 18%, transparent) !important;
}
.dark .section-reviews .review-row-border{
  border-color: color-mix(in oklab, #e2e8f0 14%, transparent) !important;
}

/* ==========================================
   About page credentials grid (light + dark)
   ========================================== */

#about-en .card,
#about-fr .card {
  border-radius: 1.75rem;
  padding: 1.5rem 1.75rem;
  /* Light base: soft panel against page bg */
  background: color-mix(in oklab, var(--bg) 88%, var(--bg-soft) 12%);
  border: 1px solid color-mix(in oklab, var(--border) 70%, var(--brand-sage-ink) 10%);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
  /* neutralise global .card hover “bounce” */
  transform: none;
  transition: background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

#about-en .card:hover,
#about-fr .card:hover {
  background: color-mix(in oklab, var(--bg-soft) 80%, var(--brand-sage) 20%);
  border-color: color-mix(in oklab, var(--brand-sage) 30%, var(--border));
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.14);
  transform: translateY(-1px);
}

/* Dark-mode version: deep navy panel with sage edge */

.dark #about-en .card,
.dark #about-fr .card {
  background: color-mix(in oklab, #020617 80%, var(--brand-sage-deep) 20%);
  border: 1px solid color-mix(in oklab, #1f2937 65%, var(--brand-sage) 25%);
  box-shadow: 0 22px 60px rgba(0, 0, 0, 0.9);
}

.dark #about-en .card:hover,
.dark #about-fr .card:hover {
  background: color-mix(in oklab, #020617 70%, var(--brand-sage) 30%);
  border-color: color-mix(in oklab, var(--brand-sage) 55%, #1f2937 45%);
}

/* Tighten the spacing between the big number and the label */

#about-en .card .text-sm,
#about-fr .card .text-sm {
  margin-top: 0.3rem;
}

/* ==========================================
   Contact page cards (light + dark)
   ========================================== */

#contact-en .card,
#contact-fr .card {
  border-radius: 22px;
  padding: 1.75rem;
  /* brighter panel so it stands off the page */
  background:
    color-mix(in oklab, var(--bg-soft) 80%, var(--brand-sage) 20%);
  border: 1px solid color-mix(in oklab, var(--border) 65%, var(--brand-sage-ink) 15%);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.08), 0 32px 80px rgba(15, 23, 42, 0.06);
  transition: background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, transform 0.16s ease;
}

#contact-en .card:hover,
#contact-fr .card:hover {
  background: color-mix(in oklab, var(--bg-soft) 80%, var(--brand-sage) 20%);
  border-color: color-mix(in oklab, var(--brand-sage) 40%, var(--border));
  box-shadow: 0 22px 52px rgba(15, 23, 42, 0.12), 0 40px 90px rgba(15, 23, 42, 0.12);
  transform: translateY(-1px);
}

/* Dark theme: deep panel with clear edge */

.dark #contact-en .card,
.dark #contact-fr .card {
  background: color-mix(in oklab, #020617 78%, var(--brand-sage-deep) 22%);
  border-color: color-mix(in oklab, #1f2937 55%, var(--brand-sage) 35%);
  box-shadow: 0 22px 60px rgba(0, 0, 0, 0.85);
}

.dark #contact-en .card:hover,
.dark #contact-fr .card:hover {
  background: color-mix(in oklab, #020617 65%, var(--brand-sage) 35%);
  border-color: color-mix(in oklab, var(--brand-sage) 60%, #1f2937 40%);
}

/* =======================================================
   Promotions / Offers slider
   ======================================================= */

/*.promo-slides {
  display: flex;
  flex-direction: column;
}
*/

/* Keep promo content visually contained */

.promo-slides {
  /* center inside wide container */
  max-width: 960px;
  /* same feel as before */
  margin: 0 auto;
}

/* Each slide: themed card inside the section box 
.promo-slide {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  padding: 1.75rem 1.75rem;
  border-radius: 1.25rem;
  transition: transform 0.25s ease, box-shadow 0.25s ease; */

/* Use per-promo theme variables, with a soft default */

/* background: var(--promo-bg, color-mix(in oklab, var(--home-panel) 90%, white));
  color: var(--promo-fg, var(--text-main));
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
}
*/

/* Subtle gloss + noise for all promo cards */

.promo-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient( 180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.04) 40%, rgba(0,0,0,0.08) ), radial-gradient(circle at top right, rgba(255,255,255,0.08), transparent 60%);
  pointer-events: none;
  mix-blend-mode: overlay;
}

.promo-slide:hover {
  transform: translateY(-2px);
  box-shadow: 0 30px 70px rgba(15, 23, 42, 0.12), inset 0 1px 0 rgba(255,255,255,0.35);
}

/* Only the active slide is shown (if you’re hiding non-active in JS) */

.promo-slide:not(.is-active) {
  display: none;
}

.promo-slide:has(.promo-media) {
  gap: 2.75rem;
}

/* Image column (if present) */

.promo-media {
  flex: 0 0 190px;
  max-width: 220px;
}

.promo-media-inner {
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.18);
}

.promo-media img {
  width: 100%;
  height: auto;
  display: block;
}

/* Text column */

.promo-content {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* Tag & meta row */

.promo-tag-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

.promo-tag {
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(15, 23, 42, 0.06);
  color: inherit;
}

.promo-meta {
  color: color-mix(in oklab, var(--promo-fg, var(--text-main)) 60%, transparent);
}

/* Title + body */

.promo-title {
  margin-top: 0.25rem;
  margin-bottom: 0.25rem;
  line-height: 1.2;
}

.promo-body {
  margin-top: 0.25rem;
  margin-bottom: 1rem;
  max-width: 42rem;
  line-height: 1.55;
}

/* CTA row */

.promo-cta-row {
  margin-top: 1.25rem;
}

@media (min-width: 768px) {
  .promo-cta-row {
    align-self: flex-start;
    /* keep current */
    /* OR */
    /* align-self: center;
    */;
  }
}

.promo-cta-row .btn {
  padding: 0.6rem 1.25rem;
  border-radius: 999px;
}

/* Controls bar under the slide */

.promo-controls {
  margin-top: 1.8rem;
  padding-top: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-top: 1px dashed color-mix(in oklab, var(--home-brd) 75%, transparent);
}

.promo-controls-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  width: 100%;
}

/* Arrows */

.promo-arrows {
  display: flex;
  gap: 0.5rem;
}

.promo-arrow {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--home-brd) 85%, transparent);
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  line-height: 1;
  cursor: pointer;
  transition: background-color 0.16s ease, border-color 0.16s ease, transform 0.12s ease, box-shadow 0.18s ease, opacity 0.16s ease;
}

.promo-arrow:hover {
  background: color-mix(in oklab, var(--brand-sage) 8%, white);
  border-color: var(--brand-sage);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.16);
}

/* Dots */

.promo-dots {
  display: flex;
  gap: 0.35rem;
  margin-left: auto;
}

.promo-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  border: 1px solid var(--home-brd);
  background: transparent;
  opacity: 0.45;
  transition: background-color 0.18s ease, border-color 0.18s ease, opacity 0.18s ease, transform 0.12s ease, box-shadow 0.18s ease;
}

.promo-dot.is-active {
  background: var(--brand-sage);
  border-color: var(--brand-sage);
  opacity: 1;
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.18);
}

/* -------------------------------------------------------
   Theme variants
   You can match these names to your promo.theme values
   ------------------------------------------------------- */

/* Sage (very similar to default, slightly deeper) */

.promo-theme-sage {
  --promo-bg: #ddebe1;
  --promo-fg: #0b1420;
}

/* Blush / pink */

.promo-theme-blush {
  --promo-bg: #f8e9f0;
  --promo-fg: #311524;
}

/* Sand / warm beige */

.promo-theme-sand {
  --promo-bg: #f5eee2;
  --promo-fg: #2c1e10;
}

/* Smoke / cool grey */

.promo-theme-smoke {
  --promo-bg: #e5e8ee;
  --promo-fg: #111827;
}

/* You can add more: .promo-theme-olive, .promo-theme-lilac, etc. */

@media (max-width: 768px) {
  .promo-slide {
    flex-direction: column;
    padding: 1.25rem 1.2rem;
  }

  .promo-media {
    flex: 0 0 auto;
    max-width: 100%;
  }

  .promo-controls-inner {
    flex-direction: row;
    align-items: center;
  }
}

/* ------------------ PROMO THEMES ------------------ */

/* Base fallback (matches your current neutral card) */

.promo-slide {
  /* so snow / effects don’t spill outside the rounded card */
  background: var(--promo-bg, radial-gradient(circle at top left, #f7faf9, #e6eee8));
  color: var(--promo-fg, #111827);
  border-radius: 18px;
  padding: 1.75rem;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.15);
  position: relative;
  overflow: hidden;
}

/* Keep content above any pseudo-element effects (holiday snow, etc.) */

.promo-content,
.promo-media {
  position: relative;
  z-index: 1;
}

/* ---------- Default (soft sage) ---------- */

.promo-theme-default {
  --promo-bg: radial-gradient(circle at top left, #f7faf9, #e2ebe6 45%, #d7e3dd);
  --promo-fg: #111827;
}

/* ---------- Warm (saffron / rose) ---------- */

.promo-theme-warm {
  --promo-bg: radial-gradient(circle at top left, #fff7ed, #fde68a 35%, #fbcfe8);
  --promo-fg: #1f2933;
}

/* ---------- Cool (indigo / teal) ---------- */

.promo-theme-cool {
  --promo-bg: radial-gradient(circle at top left, #eef2ff, #c7d2fe 35%, #99f6e4);
  --promo-fg: #0f172a;
}

/* ---------- Dark Glass ---------- */

.promo-theme-dark {
  --promo-bg: linear-gradient(135deg, #020617, #111827 45%, #020617);
  --promo-fg: #e5e7eb;
  backdrop-filter: blur(18px);
}

.promo-theme-dark .promo-tag {
  background: rgba(15, 23, 42, 0.7);
  color: #e5e7eb;
}

/* ---------- Light Glass ---------- */

.promo-theme-light {
  --promo-bg: linear-gradient(135deg, rgba(255,255,255,0.85), rgba(255,255,255,0.55));
  --promo-fg: #0f172a;
  backdrop-filter: blur(18px);
}

/* ---------- Holiday (festive) ---------- */

.promo-theme-holiday {
  --promo-bg: linear-gradient(135deg, #8b0000, #b11226 35%, #0f5132);
  --promo-fg: #ffffff;
}

/* Subtle golden glow in the top-right corner */

.promo-theme-holiday::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(255, 215, 0, 0.2), transparent 45%);
  pointer-events: none;
  z-index: 0;
}

/* Common tweaks for all themes that need a pill tag */

.promo-theme-holiday .promo-tag,
.promo-theme-dark .promo-tag {
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  background: rgba(255, 255, 255, 0.12);
  color: inherit;
  border: 1px solid rgba(255, 255, 255, 0.28);
}

/* Holiday CTA button */

.promo-theme-holiday .btn-primary {
  background: linear-gradient(135deg, #ffd700, #f4c430);
  color: #3a2a00;
  font-weight: 600;
  border: none;
}

.promo-theme-holiday .btn-primary:hover {
  filter: brightness(1.05);
  transform: translateY(-1px);
}

/* ---------- Image ratio / layout ---------- */

.promo-media-inner {
  aspect-ratio: 16 / 9;
  background: rgba(15, 23, 42, 0.06);
  border-radius: 16px;
  overflow: hidden;
}

.promo-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Slightly more inset text when there’s no image column */

.promo-slide:not(:has(.promo-media)) {
  padding-left: 3rem;
}

/* -----------------------------------------
   Holiday theme – December snow overlay
   ----------------------------------------- */

/* Only used when JS adds .has-snow in December */

.promo-theme-holiday.has-snow {
  position: relative;
  overflow: hidden;
}

/* We still keep the golden glow, but snow layers sit on top of it */

.promo-theme-holiday.has-snow::before,
.promo-theme-holiday.has-snow::after {
  content: "";
  position: absolute;
  inset: -20%;
  pointer-events: none;
  background-repeat: repeat;
  opacity: 0.35;
  mix-blend-mode: screen;
  z-index: 0;
}

/* Front layer – tiny specks */

.promo-theme-holiday.has-snow::before {
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.85) 1px, transparent 1px);
  background-size: 40px 40px;
  animation: promoSnowDrift 22s linear infinite;
}

/* Back layer – slightly larger, slower */

.promo-theme-holiday.has-snow::after {
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.55) 1.4px, transparent 1.4px);
  background-size: 60px 60px;
  animation: promoSnowDriftSlow 38s linear infinite;
}

/* Drift animations */

@keyframes promoSnowDrift {
  0% {
    transform: translate3d(0, -6%, 0);
  }
  50% {
    transform: translate3d(-3%, 3%, 0);
  }
  100% {
    transform: translate3d(0, 6%, 0);
  }
}

@keyframes promoSnowDriftSlow {
  0% {
    transform: translate3d(3%, -8%, 0);
  }
  50% {
    transform: translate3d(0, 2%, 0);
  }
  100% {
    transform: translate3d(-3%, 8%, 0);
  }
}

/* Respect reduced-motion preference: freeze the pattern */

@media (prefers-reduced-motion: reduce) {
  .promo-theme-holiday.has-snow::before,
  .promo-theme-holiday.has-snow::after {
    animation: none;
  }
}

.promo-section {
  background:
    radial-gradient(
      1200px 600px at 50% -20%,
      color-mix(in oklab, var(--brand-sage) 6%, transparent),
      transparent 60%
    ),
    var(--bg-soft);
}

/* Promotions wrapper: neutral + blends with any slide */
.section-box.promos-shell{
  /* keep your section-box look, just soften it */
  background: color-mix(in oklab, var(--bg-soft) 72%, white);
  border: 1px solid color-mix(in oklab, var(--border) 55%, transparent);

  /* subtle depth without looking like a “grey slab” */
  box-shadow:
    0 10px 28px rgba(0,0,0,0.08),
    inset 0 1px 0 rgba(255,255,255,0.55);

  /* tiny saturation/contrast lift so both promos feel “seated” */
  backdrop-filter: saturate(115%) blur(10px);
  -webkit-backdrop-filter: saturate(115%) blur(10px);
}

.dark .section-box.promos-shell{
  background: color-mix(in oklab, var(--glass-bg) 70%, black);
  border: 1px solid color-mix(in oklab, var(--border) 65%, transparent);

  box-shadow:
    0 18px 55px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.10);

  backdrop-filter: saturate(125%) blur(12px);
  -webkit-backdrop-filter: saturate(125%) blur(12px);
}
/* ---------------------------------------------------
   * BOOKING PANES – match Policies / Reviews cards
   * --------------------------------------------------- */

/* Left step cards + right summary shell.
     Make sure your markup uses class="bk-card"
     for each big pane and class="bk-summary-card"
     for the right-hand summary column.
  */

.bk-card,
  .bk-summary-card {
  border-radius: 20px;
  /* Same “pane” feel as section-box / popular-card */
    background:
      radial-gradient(
        120% 140% at 0% 0%,
        color-mix(in oklab, var(--brand-sage) 10%, transparent),
        transparent 60%
      ),
      radial-gradient(
        140% 120% at 100% 0%,
        color-mix(in oklab, var(--brand-sage-deep) 8%, transparent),
        transparent 55%
      ),
      var(--home-bg);
  border: 1px solid var(--home-brd);
  box-shadow: 0 2px 6px rgba(2, 6, 23, 0.05), 0 14px 32px rgba(2, 6, 23, 0.08);
  padding: 1.75rem 1.5rem;
  position: relative;
  overflow: hidden;
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}

.dark .bk-card,
  .dark .bk-summary-card {
  /* Same lift as section-box/popular-card in dark */
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.34),
                0 20px 48px rgba(0, 0, 0, 0.46);
}

.bk-card:hover,
  .bk-summary-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in oklab, var(--brand-sage) 24%, var(--home-brd));
  box-shadow: 0 8px 24px rgba(2, 6, 23, 0.10), 0 20px 46px rgba(2, 6, 23, 0.12);
}

/* Titles & subtitles inside panes – echo Policies/Reviews */

.bk-card > h2:first-of-type,
  .bk-card > h3:first-of-type {
  margin: 0 0 0.55rem;
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
}

.bk-card > h2:first-of-type + p,
  .bk-card > h3:first-of-type + p {
  margin: 0 0 1.1rem;
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--text-muted);
}

/* ---------------------------------------------------
   * FORM CONTROLS – reuse the same feel as .input
   * --------------------------------------------------- */

.bk-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 0.4rem;
  color: var(--text-muted);
}

.bk-input,
  .bk-select,
  .bk-textarea {
  width: 100%;
  padding: 0.7rem 1rem;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: color-mix(in oklab, #ffffff 85%, var(--bg-soft) 15%);
  color: var(--text);
  font-size: 0.9rem;
  line-height: 1.4;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.bk-input::placeholder,
  .bk-textarea::placeholder {
  color: var(--text-muted);
}

.bk-input:focus,
  .bk-select:focus,
  .bk-textarea:focus {
  outline: none;
  border-color: var(--brand-sage);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-sage) 30%, transparent);
  background: color-mix(in oklab, #ffffff 92%, var(--bg-soft) 8%);
}

.bk-textarea {
  min-height: 4.5rem;
  resize: vertical;
}

/* Dark mode inputs — remove white fill completely */
.dark .bk-input,
.dark .bk-select,
.dark .bk-textarea{
  background: rgba(17, 24, 39, 0.88); /* deep slate glass */
  border-color: color-mix(in oklab, var(--glass-border) 70%, rgba(255,255,255,.2) 30%);
  color: var(--text);

  /* subtle depth instead of white */
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 10px 30px rgba(0,0,0,.35);
}

/* Placeholder stays muted */
.dark .bk-input::placeholder,
.dark .bk-textarea::placeholder{
  color: var(--text-muted);
}

/* Focus state — still glassy, no white */
.dark .bk-input:focus,
.dark .bk-select:focus,
.dark .bk-textarea:focus{
  background: rgba(24, 33, 45, 0.95);
  border-color: var(--brand-sage);
  box-shadow:
    0 0 0 3px color-mix(in oklab, var(--brand-sage) 35%, transparent),
    inset 0 1px 0 rgba(255,255,255,.06);
}

/* ---- Kill browser autofill white/yellow in DARK mode ---- */
.dark input.bk-input:-webkit-autofill,
.dark input.bk-input:-webkit-autofill:hover,
.dark input.bk-input:-webkit-autofill:focus,
.dark textarea.bk-textarea:-webkit-autofill,
.dark textarea.bk-textarea:-webkit-autofill:hover,
.dark textarea.bk-textarea:-webkit-autofill:focus,
.dark select.bk-select:-webkit-autofill,
.dark select.bk-select:-webkit-autofill:hover,
.dark select.bk-select:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--text) !important;
  caret-color: var(--text) !important;

  /* This is the key: it “paints” over autofill background */
  -webkit-box-shadow: 0 0 0 1000px rgba(17, 24, 39, 0.88) inset !important;
  box-shadow: 0 0 0 1000px rgba(17, 24, 39, 0.88) inset !important;

  transition: background-color 9999s ease-out 0s; /* prevents flash */
}
/* Date shell */

.bk-date-shell {
  border-radius: 1rem;
  padding: 0.3rem;
  border: 1px solid var(--border);
  background: color-mix(in oklab, var(--home-bg) 88%, #ffffff 12%);
  transition: border-color 0.15s ease, background-color 0.15s ease;
}

.bk-date-input {
  width: 100%;
  border: none;
  outline: none;
  background: transparent;
  padding: 0.6rem 0.8rem;
  border-radius: 0.9rem;
  font-size: 0.9rem;
  color: var(--text);
}

/* ---------------------------------------------------
   * STEPS & TIME SLOTS
   * --------------------------------------------------- */

.bk-steps-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
  margin-bottom: 0.75rem;
}

.bk-step {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.55rem 0.7rem;
  border-radius: 9999px;
  border: 1px solid color-mix(in oklab, var(--home-brd) 80%, var(--brand-sage) 20%);
  background: color-mix(in oklab, var(--home-bg) 90%, var(--brand-sage) 10%);
  transition: all 0.15s ease-out;
}

.bk-step-circle {
  width: 1.3rem;
  height: 1.3rem;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: 600;
  background: var(--home-bg);
  border: 1px solid color-mix(in oklab, var(--border) 80%, transparent);
  color: color-mix(in oklab, var(--text-muted) 85%, #ffffff 15%);
}

.bk-step-title {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text);
}

.bk-step-sub {
  font-size: 0.7rem;
  color: var(--text-muted);
}

.bk-step-idle {
  opacity: 0.7;
}

.bk-step-active {
  border-color: var(--brand-sage);
  box-shadow: 0 0 0 1px color-mix(in oklab, var(--brand-sage) 20%, transparent);
}

.bk-step-active .bk-step-circle {
  border-color: var(--brand-sage);
  color: var(--brand-sage);
}

.bk-step-complete {
  border-color: var(--brand-sage);
  background: color-mix(in oklab, var(--brand-sage) 60%, var(--home-bg) 40%);
}

.bk-step-complete .bk-step-circle {
  background: var(--brand-sage);
  border-color: transparent;
  color: #0b1120;
}

/* Time grid */

#bk-time-grid {
  min-height: 3rem;
}

.bk-time-grid-disabled {
  opacity: 0.45;
  pointer-events: none;
}


.bk-time-slot {
  width: 100%;
  padding: 0.45rem 0.35rem;
  border-radius: 9999px;
  border: 1px solid var(--home-brd);
  background: color-mix(in oklab, var(--home-bg) 88%, var(--brand-sage) 12%);
  font-size: 0.82rem;
  text-align: center;
  color: var(--text);
  cursor: pointer;
  transition: all 0.12s ease-out;
}

/*
.bk-time-slot:hover {
  border-color: var(--brand-sage);
  background: color-mix(in oklab, var(--brand-sage) 24%, var(--home-bg) 76%);
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.12);
  transform: translateY(-0.5px);
}
*/
.bk-time-slot--active {
  border-color: var(--brand-sage-deep);
  background: var(--brand-sage);
  color: #f9fafb;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.35);
  transform: scale(0.97);
}

.dark .bk-time-slot {
  background: color-mix(in oklab, var(--brand-sage) 20%, #020617 80%);
  border-color: color-mix(in oklab, var(--brand-sage) 80%, #020617 20%);
  color: #ecfdf5;
}
/*
.dark .bk-time-slot:hover {
  background: color-mix(in oklab, var(--brand-sage) 35%, #020617 65%);
}
*/
/* Active slot – dark mode override */
.dark .bk-time-slot--active {
  background: var(--brand-sage);
  border-color: var(--brand-sage);
  color: #ecfdf5;
  box-shadow:
    0 0 0 1px rgba(16, 185, 129, 0.6),
    0 6px 16px rgba(0, 0, 0, 0.6);
}

/* ---------------------------------------------------
   * SUMMARY CONTENT INSIDE RIGHT PANE
   * --------------------------------------------------- */

.bk-summary {
  border-radius: 0.9rem;
  border: 1px solid var(--home-brd);
  background: radial-gradient( circle at top, color-mix(in oklab, var(--brand-sage) 16%, transparent), transparent 55% ), var(--home-bg);
  padding: 1rem 1.1rem;
}

.bk-summary h3 {
  font-size: 0.98rem;
  font-weight: 600;
  margin-bottom: 0.35rem;
  color: var(--text);
}

.bk-summary p,
  .bk-summary dl {
  font-size: 0.85rem;
  color: var(--text-muted);
}

/* ---------------------------------------------------
   * BUTTONS – reuse global gradient
   * --------------------------------------------------- */

.bk-btn-primary {
  border-radius: 9999px;
  padding: 0.6rem 1.3rem;
  font-size: 0.9rem;
  font-weight: 600;
  background: var(--grad-a);
  color: #f9fafb;
  border: none;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.30);
  transition: filter 0.12s ease-out, transform 0.12s ease-out, box-shadow 0.12s ease-out;
}

.bk-btn-primary:hover {
  filter: brightness(1.05);
  transform: translateY(-1px);
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.4);
}

.bk-btn-secondary {
  border-radius: 9999px;
  padding: 0.5rem 1rem;
  font-size: 0.82rem;
  border: 1px solid var(--home-brd);
  background: color-mix(in oklab, var(--home-bg) 92%, var(--brand-sage) 8%);
  color: var(--text);
  transition: border-color 0.15s ease-out, background-color 0.15s ease-out;
}

.bk-btn-secondary:hover {
  border-color: var(--brand-sage);
  background: color-mix(in oklab, var(--brand-sage) 20%, var(--home-bg) 80%);
}

#bk-submit:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  filter: grayscale(40%);
  box-shadow: none;
}

/* Layout tweak: keep panes nicely spaced */

#booking-page-form .bk-card {
  margin-bottom: 1.75rem;
}

#booking-page-form .bk-card:last-of-type {
  margin-bottom: 0;
}

/* Align Stylist & Available times on one row (desktop) */

#bk-step-2-row {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  column-gap: 1.75rem;
  align-items: flex-start;
}

/* Light mode warning message */

.text-warning-light {
  color: #b45309;
  /* amber-700 */
    font-weight: 600;
}

/* Dark mode warning message */

.text-warning-dark {
  color: #fbbf24;
  /* amber-400 */
    font-weight: 600;
}

/* This ensures the message is centered and stands out */

.bk-no-slots-message {
  font-size: 1rem;
  line-height: 1.4;
  text-align: center;
  margin-top: 1rem;
}

/* NEW CALENDAR LAYOUT */

/* Visually hidden but accessible */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

.bk-cal {
  border-radius: 1rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  padding: 0.75rem 0.9rem 0.8rem;
}

.bk-cal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.35rem;
}

.bk-cal-month {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.bk-cal-nav {
  border-radius: 999px;
  border: 1px solid var(--border-subtle);
  background: transparent;
  font-size: 0.85rem;
  width: 1.6rem;
  height: 1.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  cursor: pointer;
}

.bk-cal-nav:hover {
  background: rgba(0,0,0,0.04);
}

.bk-cal-weekdays,
  .bk-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0.1rem;
}

.bk-cal-weekdays {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted-soft);
  margin-bottom: 0.15rem;
  text-align: center;
}

.bk-cal-grid {
  font-size: 0.78rem;
}

.bk-cal-day {
  position: relative;
  height: 2rem;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border: 1px solid transparent;
  color: var(--muted);
  background: transparent;
  transition: all 0.15s ease;
}

.bk-cal-day--outside {
  opacity: 0.25;
  cursor: default;
}

.bk-cal-day--disabled {
  cursor: default;
  color: var(--muted-soft);
}

.bk-cal-day--today {
  border-color: rgba(0,0,0,0.08);
}

.bk-cal-day--has-slots::after {
  content: "";
  position: absolute;
  bottom: 0.25rem;
  width: 0.28rem;
  height: 0.28rem;
  border-radius: 999px;
  background: #16a34a;
}

.bk-cal-day--no-slots::after {
  content: "";
  position: absolute;
  bottom: 0.25rem;
  width: 0.28rem;
  height: 0.28rem;
  border-radius: 999px;
  background: #b45309;
}

.bk-cal-day--selected {
  background: var(--brand-sage);
  color: #fff;
  box-shadow: 0 10px 30px rgba(15,58,35,0.35);
}

.bk-cal-day:hover:not(.bk-cal-day--outside):not(.bk-cal-day--disabled):not(.bk-cal-day--selected) {
  background: rgba(15, 118, 110, 0.06);
}

.bk-cal-dot {
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 999px;
  display: inline-block;
}

.bk-cal-dot--has {
  background: #16a34a;
}

.bk-cal-dot--none {
  background: #b45309;
}

@media (max-width: 1023px) {
  #bk-step-2-row {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 1rem;
  }
}

.bk-time-slot {
  opacity: 0;
  animation: fadeIn 0.25s ease forwards;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(3px); }
  to   { opacity: 1; transform: translateY(0); }
}

.bk-cal-day--today {
  position: relative;
}

.bk-cal-day--today::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 9999px;
  animation: pulse 2.5s infinite;
}

@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(95, 196, 138, 0.4); }
  70%  { box-shadow: 0 0 0 8px rgba(95, 196, 138, 0); }
  100% { box-shadow: 0 0 0 0 rgba(95, 196, 138, 0); }
}


/* Base chip (unselected) */
.bk-chip{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.6rem .9rem;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.10);
  background:rgba(255,255,255,.75);
  color:#0f172a;
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease, border-color .12s ease;
  user-select:none;
}

.bk-chip:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(0,0,0,.10);
}

.bk-chip__delta{
  opacity:.75;
  font-weight:600;
  font-size:.95em;
}

/* Selected chip (VERY obvious) */
.bk-chip.is-active{
  border-color:rgba(16,185,129,.55);
  background:rgba(16,185,129,.14);
  box-shadow:0 12px 28px rgba(16,185,129,.18);
  outline:3px solid rgba(16,185,129,.25); /* strong selection */
}

/* Dark mode */
html.dark .bk-chip{
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.92);
  box-shadow:0 10px 26px rgba(0,0,0,.35);
}

html.dark .bk-chip:hover{
  box-shadow:0 14px 34px rgba(0,0,0,.45);
}

html.dark .bk-chip.is-active{
  border-color:rgba(52,211,153,.55);
  background:rgba(52,211,153,.12);
  outline:3px solid rgba(52,211,153,.22);
  box-shadow:0 14px 38px rgba(0,0,0,.55);
}


/* =================== Variants Admin UI =================== */
#svGroups{
  grid-template-columns: 1fr;
}
@media (min-width: 900px){
  #svGroups{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

.sv-group{
  border: 1px solid color-mix(in oklab, var(--border) 75%, transparent);
  background: color-mix(in oklab, var(--card, #fff) 70%, transparent);
  border-radius: 18px;
  padding: 14px;
}

.sv-group-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}
.sv-group-title h3{
  font-size: .8rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 800;
  opacity: .85;
}
.sv-pill{
  font-size: 11px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: color-mix(in oklab, var(--bg-soft) 70%, transparent);
  color: color-mix(in oklab, var(--text, #fff) 65%, transparent);
}

.sv-row{
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: color-mix(in oklab, var(--bg-soft) 70%, transparent);
  border-radius: 14px;
  padding: 10px 10px;
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:space-between;
  transition: transform .12s ease, border-color .12s ease;
}
.sv-row:hover{
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--border) 95%, transparent);
}
.sv-left{
  min-width: 0;
}
.sv-label{
  font-weight: 700;
  font-size: 14px;
}
.sv-meta{
  font-size: 11px;
  opacity: .75;
  margin-top: 2px;
  display:flex;
  gap:10px;
  flex-wrap: wrap;
}
.sv-badge-off{
  opacity:.6;
  text-decoration: line-through;
}

.sv-actions{
  display:flex;
  gap:6px;
  flex-wrap: wrap;
  justify-content:flex-end;
}
.sv-btn{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 12px;
  border: 1px solid color-mix(in oklab, var(--border) 75%, transparent);
  background: color-mix(in oklab, var(--bg) 75%, transparent);
}
.sv-btn:hover{
  border-color: color-mix(in oklab, var(--border) 95%, transparent);
}
.sv-btn-danger{
  border-color: color-mix(in oklab, #ef4444 45%, var(--border));
}

/* ---------------- modal ---------------- */
.modal.hidden{ display:none; }
.modal{
  position:fixed; inset:0; z-index:50;
}
.modal-backdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
}
.modal-card{
  position:relative;
  width: min(720px, calc(100% - 24px));
  margin: 8vh auto;
  border-radius: 22px;
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: color-mix(in oklab, var(--card, #111) 85%, transparent);
  box-shadow: 0 30px 120px rgba(0,0,0,.45);
  overflow:hidden;
}
.modal-head{
  padding: 14px 16px;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  border-bottom: 1px solid color-mix(in oklab, var(--border) 55%, transparent);
}
.modal-title{ font-weight: 800; font-size: 16px; }
.modal-x{
  border: none;
  background: transparent;
  font-size: 26px;
  line-height: 1;
  opacity: .7;
}
.modal-x:hover{ opacity:1; }
.modal-body{ padding: 14px 16px; }
.modal-foot{ padding-top: 6px; }

/* Highlight the entire row (no layout shift) */
#apptTableBody tr.appt-row-focus td{
  background: rgba(16, 185, 129, 0.14) !important;
}

/* Left accent bar using inset shadow (does NOT affect width) */
#apptTableBody tr.appt-row-focus td:first-child{
  box-shadow: inset 4px 0 0 rgba(16, 185, 129, 0.95);
}

/* Optional: subtle “ring” effect using shadow (also no layout shift) */
#apptTableBody tr.appt-row-focus td{
  box-shadow: inset 0 0 0 1px rgba(16, 185, 129, 0.55);
}

/* Optional: round the highlight edges for a nicer look */
#apptTableBody tr.appt-row-focus td:first-child{
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}
#apptTableBody tr.appt-row-focus td:last-child{
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
}

/* Base payment info text */
.payment-info{
  font-size: 0.78rem;
  line-height: 1.25;
  font-weight: 600;
  padding-left: .45rem;
  border-left: 3px solid currentColor;
  opacity: .95;
}

/* ===== LIGHT MODE COLORS ===== */

/* Paid in full */
.payment-info-paid{
  color: #047857; /* emerald-700 */
}

/* Deposit paid */
.payment-info-deposit{
  color: #0369a1; /* sky-700 */
}

/* Remaining balance */
.payment-info-remaining{
  color: #b45309; /* amber-700 */
}

/* ===== DARK MODE OVERRIDES ===== */

html.dark .payment-info-paid,
body.dark .payment-info-paid{
  color: #6ee7b7; /* emerald-300 */
}

html.dark .payment-info-deposit,
body.dark .payment-info-deposit{
  color: #7dd3fc; /* sky-300 */
}

html.dark .payment-info-remaining,
body.dark .payment-info-remaining{
  color: #fcd34d; /* amber-300 */
}