@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

:root {
  --ink:#100e0b; --ink2:#1c1914; --ink3:#26211a;
  --sand:#faf7f2; --card:#ffffff;
  --gold:#b8842a; --gold2:#d4a247; --gold3:#f0c870;
  --gd:rgba(184,132,42,.15); --gb:rgba(184,132,42,.3);
  --terra:#a8482a; --sage:#3d6b50;
  --text:#1a1612; --muted:#6b6357; --bdr:#ede8e0;
  --sh:0 4px 28px rgba(16,14,11,.08);
  --shlg:0 24px 80px rgba(16,14,11,.18);
  --r:20px; --rsm:12px;
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth }
body { font-family:'DM Sans',sans-serif; background:var(--sand); color:var(--text); -webkit-font-smoothing:antialiased; overflow-x:hidden }
img { display:block; max-width:100% }
a { text-decoration:none; color:inherit }

/* ── FLASH TOASTS ──────────────────────────────────────────── */
.flash-toast { position:fixed; top:68px; left:0; right:0; z-index:300; padding:14px 32px; font-size:.9rem; font-weight:500; display:flex; align-items:center; justify-content:center; gap:10px; animation:slideDown .3s ease; }
.flash-toast.flash-success { background:#dcfce7; color:#065f46; border-bottom:2px solid #86efac; }
.flash-toast.flash-error   { background:#fee2e2; color:#991b1b; border-bottom:2px solid #fca5a5; }
.flash-toast.flash-info    { background:#dbeafe; color:#1e40af; border-bottom:2px solid #93c5fd; }
@keyframes slideDown { from { transform:translateY(-100%); opacity:0; } to { transform:translateY(0); opacity:1; } }

/* ── TOPBAR NAV ────────────────────────────────────────────── */
.topbar { position:fixed; top:0; left:0; right:0; z-index:200; background:rgba(16,14,11,.92); backdrop-filter:blur(18px) saturate(160%); border-bottom:1px solid rgba(184,132,42,.18); transition:background .3s; }
.topbar-inner { max-width:1260px; margin:0 auto; padding:0 32px; height:68px; display:flex; align-items:center; justify-content:space-between; gap:20px; }
.logo { display:flex; align-items:center; gap:12px; flex-shrink:0; }
.logo-mark { width:48px; height:48px; border-radius:999px; object-fit:cover; border:2px solid rgba(212,162,71,.85); box-shadow:0 0 0 3px rgba(212,162,71,.12); background:#201912; flex-shrink:0; }
.logo-copy { display:flex; flex-direction:column; gap:2px; line-height:1; }
.logo-copy strong { font-family:'Cormorant Garamond',serif; font-size:1.95rem; font-weight:700; color:#fff; letter-spacing:.01em; }
.logo-copy small { font-size:.8rem; font-weight:600; letter-spacing:.22em; color:var(--gold2); text-transform:uppercase; }
.topnav { display:flex; align-items:center; gap:2px; }
.topnav a { padding:8px 14px; border-radius:8px; font-size:.88rem; font-weight:500; color:rgba(255,255,255,.6); transition:.18s; }
.topnav a:hover { color:#fff; background:rgba(255,255,255,.07); }
.topbar-cta { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.topbar-cta .btn { flex-shrink:0; }

/* ── BUTTONS ───────────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:9px; border:0; cursor:pointer; border-radius:var(--rsm); padding:14px 26px; font-family:'DM Sans',sans-serif; font-size:.93rem; font-weight:600; transition:.2s ease; min-height:48px; white-space:nowrap; text-decoration:none; }
.btn:active { transform:scale(.98); }
.btn-gold,.btn-primary { background:var(--gold); color:var(--ink); box-shadow:0 6px 24px rgba(184,132,42,.38); }
.btn-gold:hover,.btn-primary:hover { background:var(--gold2); }
.btn-outline { background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.35); }
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }
.btn-ghost { background:var(--card); color:var(--text); border:1.5px solid var(--bdr); }
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); }
.btn-dark { background:var(--ink2); color:#fff; }
.btn-dark:hover { background:var(--ink3); }
.btn-wa { background:#25d366; color:#fff; border:0; }
.btn-wa:hover { background:#1ebe57; }
.btn-sm { padding:8px 16px; font-size:.83rem; min-height:36px; }
.btn-full { width:100%; justify-content:center; }

/* ── LAYOUT UTILITIES ──────────────────────────────────────── */
.wrap { max-width:1260px; margin:0 auto; padding:0 32px; }
.section { padding:96px 0; }
.eyebrow { display:flex; align-items:center; gap:10px; font-size:.73rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); font-weight:600; margin-bottom:14px; }
.eyebrow::after { content:''; flex:0 0 26px; height:1px; background:var(--gold); opacity:.6; }
.sec-title { font-family:'Cormorant Garamond',serif; font-size:clamp(1.9rem,3.5vw,3rem); font-weight:700; line-height:1.1; letter-spacing:-.02em; margin-bottom:10px; }
.sec-desc { color:var(--muted); line-height:1.84; font-size:.97rem; max-width:54ch; font-weight:300; }

/* ── HERO ──────────────────────────────────────────────────── */
.hero { min-height:100vh; padding-top:68px; position:relative; overflow:hidden; background:linear-gradient(160deg,var(--ink2) 0%,var(--ink3) 60%,#1e1510 100%); display:flex; align-items:center; }
.hero-pat { position:absolute; inset:0; background:radial-gradient(circle at 20% 50%,rgba(184,132,42,.08),transparent 50%),radial-gradient(circle at 80% 20%,rgba(168,72,42,.06),transparent 40%); pointer-events:none; }
.hero-inner { width:100%; display:grid; grid-template-columns:1fr; gap:48px; align-items:center; position:relative; z-index:2; padding:80px 32px 60px; max-width:1260px; margin:0 auto; }
.hero-eyebrow { display:inline-flex; align-items:center; gap:10px; font-size:.75rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:22px; }
.hero-eyebrow::before,.hero-eyebrow::after { content:''; width:22px; height:1px; background:var(--gold); opacity:.6; }
.hero h1 { font-family:'Cormorant Garamond',serif; font-size:clamp(2.8rem,7vw,5.2rem); font-weight:700; line-height:1.06; color:#fff; letter-spacing:-.02em; margin-bottom:18px; }
.hero h1 em { font-style:italic; color:var(--gold2); }
.hero-sub { font-size:1.05rem; color:rgba(255,255,255,.65); line-height:1.84; max-width:500px; margin-bottom:36px; font-weight:300; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; }
.hero-img { position:relative; max-width:480px; margin:0 auto; width:100%; }
.hero-frame { border-radius:28px; overflow:hidden; box-shadow:0 32px 100px rgba(0,0,0,.5); aspect-ratio:4/5; }
.hero-frame img { width:100%; height:100%; object-fit:cover; object-position:top center; }
.hero-stat { position:absolute; bottom:24px; left:-18px; background:rgba(255,255,255,.96); backdrop-filter:blur(12px); border-radius:16px; padding:16px 20px; box-shadow:0 16px 48px rgba(0,0,0,.22); }
.hero-stat .num { font-family:'Cormorant Garamond',serif; font-size:2.4rem; font-weight:700; color:var(--gold); line-height:1; }
.hero-stat .txt { font-size:.76rem; color:var(--muted); font-weight:500; line-height:1.4; margin-top:2px; }

/* ── SERVICE CARDS ─────────────────────────────────────────── */
.svc-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(270px,1fr)); gap:22px; }
.svc-card { background:var(--card); border:1px solid var(--bdr); border-radius:var(--r); overflow:hidden; box-shadow:var(--sh); transition:.22s ease; display:flex; flex-direction:column; position:relative; }
.svc-card:hover { transform:translateY(-5px); box-shadow:var(--shlg); border-color:var(--gb); }
.svc-badge { position:absolute; top:14px; right:14px; background:var(--gold); color:var(--ink); font-size:.7rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:4px 10px; border-radius:20px; z-index:2; }
.svc-card-img { width:100%; aspect-ratio:16/10; overflow:hidden; }
.svc-card-img img { width:100%; height:100%; object-fit:cover; transition:.3s; }
.svc-card:hover .svc-card-img img { transform:scale(1.04); }
.svc-card-body { padding:20px; display:flex; flex-direction:column; gap:10px; flex:1; }
.svc-icon { width:48px; height:48px; border-radius:12px; background:var(--gd); border:1px solid var(--gb); display:grid; place-items:center; flex-shrink:0; }
.svc-icon i { font-size:1.1rem; color:var(--gold); }
.svc-cat { font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); font-weight:600; }
.svc-card h3 { font-family:'Cormorant Garamond',serif; font-size:1.28rem; font-weight:700; line-height:1.2; }
.svc-card p { color:var(--muted); line-height:1.8; font-size:.91rem; font-weight:300; flex:1; }
.svc-meta { display:flex; gap:12px; flex-wrap:wrap; font-size:.79rem; color:var(--muted); }
.svc-meta span { display:flex; align-items:center; gap:5px; }
.svc-meta i { color:var(--gold); }
.svc-actions { display:flex; gap:9px; margin-top:auto; padding-top:8px; border-top:1px solid var(--bdr); }
.category-card { text-decoration:none; color:inherit; }
.category-card .svc-card-body { gap:12px; }
.category-card:hover .category-card-link { color:var(--gold); }
.category-service-count { display:inline-flex; align-items:center; gap:8px; font-size:.82rem; font-weight:600; color:var(--text); }
.category-service-count i { color:var(--gold); }
.category-service-list { display:flex; flex-wrap:wrap; gap:8px; margin-top:auto; }
.category-service-list span { display:inline-flex; align-items:center; padding:7px 10px; border-radius:999px; background:var(--sand); border:1px solid var(--bdr); color:var(--muted); font-size:.78rem; line-height:1.2; }
.category-card-link { margin-top:6px; padding-top:14px; border-top:1px solid var(--bdr); display:flex; align-items:center; justify-content:space-between; color:var(--text); font-size:.88rem; font-weight:600; transition:.18s; }
.category-card-link i { color:var(--gold); }

/* ── ABOUT ─────────────────────────────────────────────────── */
.about { background:var(--card); }
.about-inner { max-width:1260px; margin:0 auto; padding:96px 32px; display:grid; grid-template-columns:1fr; gap:64px; align-items:center; }
.about-img-wrap { position:relative; max-width:440px; margin:0 auto; width:100%; }
.about-frame { border-radius:24px; overflow:hidden; box-shadow:var(--shlg); aspect-ratio:3/4; }
.about-frame img { width:100%; height:100%; object-fit:cover; object-position:top center; }
.about-deco { position:absolute; top:-14px; right:-14px; width:80px; height:80px; border-radius:18px; background:var(--gold); display:grid; place-items:center; box-shadow:0 12px 36px rgba(184,132,42,.4); }
.about-deco i { font-size:1.9rem; color:var(--ink); }
.about-title { font-family:'Cormorant Garamond',serif; font-size:clamp(2rem,4vw,3rem); font-weight:700; line-height:1.1; letter-spacing:-.02em; margin-bottom:20px; }
.about-title em { font-style:italic; color:var(--gold); }
.about-body p { color:var(--muted); line-height:1.9; font-size:.97rem; font-weight:300; margin-bottom:16px; }
.about-stats { display:flex; gap:32px; flex-wrap:wrap; margin:28px 0 32px; }
.about-stat .n { font-family:'Cormorant Garamond',serif; font-size:2.7rem; font-weight:700; color:var(--gold); line-height:1; }
.about-stat .l { font-size:.76rem; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:.08em; margin-top:4px; }

/* ── MINI CTA ──────────────────────────────────────────────── */
.mini-cta { background:var(--ink2); text-align:center; padding:96px 32px; border-top:1px solid var(--gb); border-bottom:1px solid var(--gb); }
.mini-cta .eyebrow { justify-content:center; }
.mini-cta .sec-title { color:#fff; }

/* ── FOOTER ────────────────────────────────────────────────── */
.site-footer { background:var(--ink); border-top:1px solid var(--gb); padding:64px 0 0; }
.footer-inner { max-width:1260px; margin:0 auto; padding:0 32px 48px; display:grid; grid-template-columns:1fr; gap:36px; }
.footer-logo { font-family:'Cormorant Garamond',serif; font-size:1.4rem; font-weight:700; color:#fff; margin-bottom:12px; }
.footer-logo em { font-style:italic; color:var(--gold2); }
.footer-brand p { font-size:.87rem; color:rgba(255,255,255,.38); line-height:1.9; max-width:28ch; }
.footer-social { display:flex; gap:14px; margin-top:18px; }
.footer-social a { color:rgba(255,255,255,.35); font-size:1.1rem; transition:.18s; }
.footer-social a:hover { color:var(--gold); }
.footer-links h4,.footer-contact h4 { font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); font-weight:700; margin-bottom:14px; }
.footer-links ul,.footer-contact ul { list-style:none; }
.footer-links a { display:block; font-size:.87rem; color:rgba(255,255,255,.38); line-height:2.1; transition:.18s; }
.footer-links a:hover { color:var(--gold); }
.footer-contact li { display:flex; align-items:center; gap:9px; font-size:.87rem; color:rgba(255,255,255,.38); line-height:2.1; }
.footer-contact i { color:var(--gold); width:14px; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.06); padding:20px 32px; max-width:1260px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap; font-size:.8rem; color:rgba(255,255,255,.22); }

/* ── MOBILE BOTTOM NAV ─────────────────────────────────────── */
.bottom-nav { display:none; position:fixed; bottom:0; left:0; right:0; z-index:100; grid-template-columns:repeat(3,1fr); background:rgba(16,14,11,.97); backdrop-filter:blur(16px); border-top:1px solid var(--gb); padding:10px 10px calc(10px + env(safe-area-inset-bottom)); gap:4px; }
.bottom-nav-item { border:0; background:rgba(255,255,255,.06); color:rgba(255,255,255,.48); border-radius:10px; min-height:48px; cursor:pointer; font:600 .72rem 'DM Sans',sans-serif; transition:.18s; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; text-decoration:none; }
.bottom-nav-item.active { background:var(--gold); color:var(--ink); }
.bottom-nav-item i { font-size:.98rem; }

/* ── TOAST ─────────────────────────────────────────────────── */
#toast-container { position:fixed; bottom:24px; right:24px; z-index:9999; display:flex; flex-direction:column; gap:8px; }
.toast-msg { background:var(--ink2); color:#fff; border:1px solid var(--gb); border-radius:var(--rsm); padding:12px 20px; font-size:.87rem; font-weight:500; display:flex; align-items:center; gap:10px; box-shadow:var(--shlg); animation:toastIn .3s ease; min-width:280px; max-width:380px; }
.toast-msg.success { background:#0a2218; border-color:#16a34a; color:#86efac; }
.toast-msg.error   { background:#2d0909; border-color:#991b1b; color:#fca5a5; }
.toast-msg.info    { background:#081d3e; border-color:#2563eb; color:#93c5fd; }
@keyframes toastIn { from { opacity:0; transform:translateX(20px); } to { opacity:1; transform:translateX(0); } }

/* ── BOOKING MODAL ─────────────────────────────────────────── */
.modal-overlay { position:fixed; inset:0; z-index:500; background:rgba(16,14,11,.8); backdrop-filter:blur(6px); display:none; align-items:center; justify-content:center; padding:20px; }
.modal-overlay.open { display:flex; }
.modal { background:var(--card); border-radius:22px; width:min(820px,100%); max-height:92vh; overflow:hidden; box-shadow:0 40px 120px rgba(0,0,0,.46); animation:mUp .3s ease; display:flex; flex-direction:column; }
@keyframes mUp { from { opacity:0; transform:translateY(22px); } to { opacity:1; transform:translateY(0); } }
.modal-body { overflow-y:auto; padding:32px; }
.m-head { display:flex; justify-content:space-between; align-items:flex-start; gap:14px; margin-bottom:22px; }
.m-title { font-family:'Cormorant Garamond',serif; font-size:1.7rem; font-weight:700; }
.m-sub { font-size:.87rem; color:var(--gold); font-weight:600; margin-top:4px; }
.modal-close { width:40px; height:40px; border:0; border-radius:10px; background:var(--sand); cursor:pointer; font-size:1.1rem; color:var(--muted); transition:.18s; flex-shrink:0; }
.modal-close:hover { background:var(--bdr); }
.fg { display:grid; grid-template-columns:1fr; gap:14px; }
.fl { grid-column:1/-1; }
.f { display:flex; flex-direction:column; gap:6px; }
.f label { font-size:.79rem; font-weight:700; color:var(--muted); letter-spacing:.04em; text-transform:uppercase; display:flex; align-items:center; gap:6px; }
.f label i { color:var(--gold); }
.f input,.f textarea,.f select { width:100%; border:1.5px solid var(--bdr); border-radius:var(--rsm); padding:11px 13px; font:400 .93rem 'DM Sans',sans-serif; background:var(--sand); color:var(--text); outline:none; transition:.18s; }
.f input:focus,.f textarea:focus,.f select:focus { border-color:var(--gold); box-shadow:0 0 0 4px rgba(184,132,42,.12); background:#fff; }
.f textarea { resize:vertical; min-height:80px; }
.booking-picker-grid { display:grid; grid-template-columns:1fr; gap:16px; margin:18px 0; }
.booking-picker-card { border:1px solid var(--bdr); border-radius:18px; background:linear-gradient(180deg,#fff, #fbf8f3); padding:18px; }
.picker-head { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:14px; }
.picker-head strong { display:flex; align-items:center; gap:8px; font-size:1rem; color:var(--ink2); }
.picker-head strong i { color:var(--gold); }
.picker-head span { display:block; color:var(--muted); font-size:.8rem; margin-top:4px; line-height:1.6; }
.picker-nav { display:flex; align-items:center; gap:10px; }
.picker-nav-btn { width:36px; height:36px; border-radius:10px; border:1px solid var(--bdr); background:#fff; color:var(--ink2); cursor:pointer; transition:.18s; }
.picker-nav-btn:hover:not(:disabled) { border-color:var(--gold); color:var(--gold); }
.picker-nav-btn:disabled { opacity:.4; cursor:not-allowed; }
.picker-month { min-width:136px; text-align:center; font-size:.88rem; font-weight:700; color:var(--ink2); }
.booking-weekdays,.booking-days { display:grid; grid-template-columns:repeat(7,1fr); gap:8px; }
.booking-weekdays { margin-bottom:8px; }
.booking-weekday { text-align:center; font-size:.72rem; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; padding:4px 0; }
.booking-day { min-height:62px; border-radius:16px; border:1px solid var(--bdr); background:#fff; cursor:pointer; display:flex; flex-direction:column; align-items:flex-start; justify-content:space-between; padding:10px; transition:.18s; text-align:left; }
.booking-day:hover:not(:disabled) { border-color:var(--gold); box-shadow:0 8px 24px rgba(184,132,42,.12); transform:translateY(-1px); }
.booking-day-num { font-weight:700; color:var(--ink2); }
.booking-day.is-selected { background:linear-gradient(135deg,var(--gold),var(--gold2)); border-color:var(--gold2); box-shadow:0 14px 28px rgba(184,132,42,.28); }
.booking-day.is-selected .booking-day-num { color:var(--ink2); }
.booking-day.is-today { border-color:rgba(184,132,42,.55); }
.booking-day.is-disabled { background:repeating-linear-gradient(135deg,#f5efe6,#f5efe6 10px,#f0e8dc 10px,#f0e8dc 20px); border-style:dashed; opacity:.72; cursor:not-allowed; }
.booking-day.is-disabled .booking-day-num { color:#a0907c; text-decoration:line-through; text-decoration-thickness:2px; }
.booking-day-empty { min-height:62px; }
.slot-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(122px,1fr)); gap:10px; }
.slot-chip { display:inline-flex; align-items:center; justify-content:center; gap:8px; min-height:46px; border-radius:999px; border:1px solid var(--bdr); background:#fff; color:var(--ink2); font:600 .88rem 'DM Sans',sans-serif; cursor:pointer; transition:.18s; padding:0 14px; }
.slot-chip:hover:not(:disabled) { border-color:var(--gold); color:var(--gold); }
.slot-chip.active { background:var(--ink2); border-color:var(--ink2); color:#fff; box-shadow:0 12px 24px rgba(16,14,11,.16); }
.slot-chip:disabled { opacity:.45; cursor:not-allowed; background:#f5f1eb; }
.booking-selection-note { margin-top:12px; font-size:.82rem; color:var(--muted); line-height:1.7; }
.payment-method-note { margin-top:12px; display:flex; flex-wrap:wrap; justify-content:center; gap:8px; }
.payment-method-note span { display:inline-flex; align-items:center; gap:8px; min-height:34px; padding:0 12px; border-radius:999px; border:1px solid var(--bdr); background:#fff; color:var(--muted); font-size:.78rem; font-weight:700; }
.payment-method-note i { color:var(--gold); }
.price-summary { background:var(--ink2); border-radius:var(--rsm); padding:16px; color:#fff; margin:16px 0; }
.p-row { display:flex; justify-content:space-between; gap:12px; padding:6px 0; font-size:.88rem; border-bottom:1px solid rgba(255,255,255,.08); color:rgba(255,255,255,.52); }
.p-row:last-child { border-bottom:0; }
.p-row.tot { color:var(--gold); font-weight:700; font-size:.97rem; }

/* ── BOOKING STATUS BADGES ─────────────────────────────────── */
.badge-status { display:inline-flex; align-items:center; gap:5px; padding:4px 10px; border-radius:6px; font-size:.74rem; font-weight:700; white-space:nowrap; }
.badge-status-pending   { background:#fffbeb; color:#92400e; }
.badge-status-confirmed { background:#dcfce7; color:#065f46; }
.badge-status-cancelled { background:#fee2e2; color:#991b1b; }
.badge-status-paid      { background:#dcfce7; color:#065f46; }
.badge-status-unpaid    { background:#fff7ed; color:#9a3412; }
.badge-status-refunded  { background:#f1f5f9; color:#475569; }

/* ── BOOKINGS PAGE ─────────────────────────────────────────── */
.bookings-list { display:flex; flex-direction:column; gap:16px; }
.booking-card { background:var(--card); border:1px solid var(--bdr); border-radius:var(--r); overflow:hidden; display:flex; box-shadow:var(--sh); transition:.2s; }
.booking-card:hover { box-shadow:var(--shlg); border-color:var(--gb); }
.bc-img { width:180px; min-width:180px; overflow:hidden; }
.bc-img img { width:100%; height:100%; object-fit:cover; }
.bc-body { padding:20px; display:flex; flex-direction:column; gap:10px; flex:1; }
.bc-top { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; flex-wrap:wrap; }
.bc-ref { font-size:.75rem; font-family:monospace; background:var(--sand); padding:3px 8px; border-radius:5px; color:var(--muted); margin-bottom:4px; display:inline-block; }
.bc-title { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:700; }
.bc-badges { display:flex; gap:6px; flex-wrap:wrap; }
.bc-meta { display:flex; gap:14px; flex-wrap:wrap; font-size:.82rem; color:var(--muted); }
.bc-meta span { display:flex; align-items:center; gap:5px; }
.bc-meta i { color:var(--gold); }
.bc-footer { display:flex; justify-content:space-between; align-items:center; margin-top:auto; padding-top:12px; border-top:1px solid var(--bdr); flex-wrap:wrap; gap:8px; }
.modal-overlay.order-success-overlay { z-index:650; align-items:center; justify-content:center; padding:20px; }
.order-success-modal { width:min(640px,100%); max-height:min(88vh, 760px); overflow:auto; }
.order-success-card { border:1px solid var(--bdr); border-radius:20px; background:linear-gradient(180deg,#fff,#faf6ef); padding:22px; }
.order-success-pill { display:inline-flex; align-items:center; gap:8px; min-height:34px; padding:0 14px; border-radius:999px; background:#ecfdf3; color:#177245; font-size:.82rem; font-weight:700; margin-bottom:14px; }
.order-success-card h3 { font-family:'Cormorant Garamond',serif; font-size:1.8rem; margin-bottom:16px; }
.order-success-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.order-success-grid div { border:1px solid var(--bdr); border-radius:14px; background:#fff; padding:14px; }
.order-success-grid span { display:block; font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); font-weight:700; margin-bottom:6px; }
.order-success-grid strong { display:block; color:var(--ink2); line-height:1.5; word-break:break-word; }
.order-success-contact { display:grid; gap:10px; margin-top:16px; }
.order-success-contact div { display:flex; align-items:center; gap:10px; color:var(--muted); font-size:.92rem; }
.order-success-contact i { color:var(--gold); width:16px; }
.order-success-note { margin-top:14px; padding:14px; border-radius:14px; background:var(--sand); color:var(--muted); line-height:1.7; }
.order-success-text { margin-top:16px; color:var(--muted); line-height:1.8; }

/* ── SERVICES PAGE ─────────────────────────────────────────── */
.services-header { padding:120px 0 48px; background:linear-gradient(160deg,var(--ink2),var(--ink3)); }
.services-header .eyebrow { color:var(--gold2); }
.services-header .sec-title { color:#fff; }
.services-header .sec-desc { color:rgba(255,255,255,.52); }
.services-filter-bar { background:var(--card); border-bottom:1px solid var(--bdr); padding:16px 0; position:sticky; top:68px; z-index:100; }
.services-filter-form { display:flex; flex-direction:column; gap:12px; }
.filter-search { border:1.5px solid var(--bdr); border-radius:var(--rsm); padding:10px 14px; font:400 .9rem 'DM Sans',sans-serif; outline:none; transition:.18s; background:var(--sand); color:var(--text); width:100%; }
.filter-search:focus { border-color:var(--gold); }
.filter-cats { display:flex; gap:8px; flex-wrap:wrap; }
.cat-pill { display:inline-flex; align-items:center; gap:6px; padding:6px 14px; border-radius:20px; font-size:.82rem; font-weight:600; border:1.5px solid var(--bdr); color:var(--muted); transition:.18s; }
.cat-pill:hover { border-color:var(--gold); color:var(--gold); }
.cat-pill.active { background:var(--gold); color:var(--ink); border-color:var(--gold); }

/* ── SERVICE DETAIL ────────────────────────────────────────── */
.service-detail-hero { position:relative; min-height:55vh; overflow:hidden; }
.service-detail-hero > img { width:100%; height:55vh; object-fit:cover; object-position:center; }
.sdh-overlay { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(transparent,rgba(16,14,11,.85) 60%); padding:48px 0 40px; }
.sdh-meta-bar { background:var(--card); border-bottom:1px solid var(--bdr); position:sticky; top:68px; z-index:90; padding:0; }
.sdh-meta-grid { display:flex; flex-wrap:wrap; gap:0; padding:0; border-left:1px solid var(--bdr); }
.sdh-meta-item { display:flex; align-items:center; gap:12px; padding:16px 20px; border-right:1px solid var(--bdr); flex:1; min-width:120px; }
.sdh-meta-item i { color:var(--gold); font-size:1.1rem; }
.sdh-meta-item strong { display:block; font-weight:700; font-size:.9rem; }
.sdh-meta-item span { font-size:.75rem; color:var(--muted); }
.service-layout { display:grid; grid-template-columns:1fr; gap:40px; }
.sdh-section { margin-bottom:36px; }
.sdh-h2 { font-family:'Cormorant Garamond',serif; font-size:1.55rem; font-weight:700; margin-bottom:14px; display:flex; align-items:center; gap:10px; }
.sdh-longdesc p { color:var(--muted); line-height:1.9; font-weight:300; margin-bottom:14px; }
.service-highlights { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.highlight-item { display:flex; align-items:center; gap:12px; }
.hi-icon { width:40px; height:40px; background:var(--gd); border:1px solid var(--gb); border-radius:10px; display:grid; place-items:center; flex-shrink:0; }
.hi-icon i { color:var(--gold); font-size:.95rem; }
.included-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.inc-title { display:flex; align-items:center; gap:8px; font-size:.95rem; font-weight:700; margin-bottom:12px; }
.inc-list { list-style:none; display:flex; flex-direction:column; gap:8px; }
.inc-list li { font-size:.9rem; color:var(--muted); padding-left:22px; position:relative; line-height:1.6; }
.inc-yes li::before { content:'\f00c'; font-family:'Font Awesome 6 Free'; font-weight:900; position:absolute; left:0; color:var(--sage); }
.inc-no li::before { content:'\f00d'; font-family:'Font Awesome 6 Free'; font-weight:900; position:absolute; left:0; color:var(--terra); }
.booking-sidebar-card { background:var(--card); border:1px solid var(--bdr); border-radius:var(--r); padding:28px; box-shadow:var(--sh); position:sticky; top:90px; }
.bsc-price { display:flex; align-items:baseline; gap:8px; margin-bottom:12px; }
.bsc-from { font-size:.8rem; color:var(--muted); }
.bsc-amount { font-family:'Cormorant Garamond',serif; font-size:2.4rem; font-weight:700; color:var(--gold); }
.bsc-per { font-size:.83rem; color:var(--muted); }
.bsc-rating { display:flex; align-items:center; gap:4px; margin-bottom:18px; font-size:.83rem; color:var(--muted); }
.bsc-trust { margin-top:16px; border-top:1px solid var(--bdr); padding-top:16px; display:flex; flex-direction:column; gap:8px; }
.bsc-trust div { display:flex; align-items:center; gap:8px; font-size:.82rem; color:var(--muted); }
.bsc-trust i { color:var(--gold); width:14px; }
.bsc-slot-preview { margin-top:14px; padding:14px; border-radius:16px; background:var(--sand); border:1px solid var(--bdr); }
.bsc-slot-preview-title { font-size:.82rem; font-weight:700; color:var(--ink2); display:flex; align-items:center; gap:8px; margin-bottom:10px; }
.bsc-slot-preview-title i { color:var(--gold); }
.bsc-slot-preview-list { display:flex; flex-wrap:wrap; gap:8px; }
.bsc-slot-preview-list span { display:inline-flex; align-items:center; justify-content:center; min-height:32px; padding:0 12px; border-radius:999px; background:#fff; border:1px solid var(--bdr); font-size:.8rem; color:var(--muted); font-weight:600; }
.service-gallery-shell { padding:28px 0 0; background:linear-gradient(180deg,var(--card),var(--sand)); }
.service-gallery-panel { background:var(--card); border:1px solid var(--bdr); border-radius:28px; padding:18px; box-shadow:var(--sh); }
.service-gallery-main { border-radius:22px; overflow:hidden; background:#f3ede3; min-height:280px; }
.service-gallery-main img { width:100%; height:min(58vw, 520px); min-height:280px; object-fit:cover; }
.service-gallery-thumbs { display:grid; grid-template-columns:repeat(auto-fit,minmax(88px,1fr)); gap:12px; margin-top:14px; }
.service-gallery-thumb { border:1.5px solid transparent; border-radius:18px; padding:0; background:#fff; overflow:hidden; cursor:pointer; transition:.18s; box-shadow:none; }
.service-gallery-thumb img { width:100%; aspect-ratio:1/1; object-fit:cover; }
.service-gallery-thumb:hover,
.service-gallery-thumb.is-active { border-color:var(--gold); box-shadow:0 10px 24px rgba(184,132,42,.18); transform:translateY(-1px); }

/* ── AUTH PAGES ────────────────────────────────────────────── */
.auth-page { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:100px 20px 40px; background:linear-gradient(160deg,var(--ink2),var(--ink3)); }
.auth-card { background:var(--card); border-radius:var(--r); padding:40px; width:min(420px,100%); box-shadow:0 40px 100px rgba(0,0,0,.4); }
.auth-logo { display:flex; flex-direction:column; align-items:center; margin-bottom:24px; }
.auth-logo-mark { width:52px; height:52px; background:linear-gradient(135deg,var(--gold),#9c6e1a); border-radius:14px; display:grid; place-items:center; font-family:'Cormorant Garamond',serif; font-size:1.6rem; font-weight:700; color:var(--ink); margin-bottom:8px; }
.auth-logo-name { font-family:'Cormorant Garamond',serif; font-size:1.2rem; font-weight:700; }
.auth-logo-name em { font-style:italic; color:var(--gold); }
.auth-title { font-family:'Cormorant Garamond',serif; font-size:1.8rem; font-weight:700; text-align:center; margin-bottom:6px; }
.auth-sub { color:var(--muted); text-align:center; font-size:.9rem; margin-bottom:28px; }
.auth-form { display:flex; flex-direction:column; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-label { font-size:.78rem; font-weight:700; color:var(--muted); letter-spacing:.04em; text-transform:uppercase; display:flex; align-items:center; gap:6px; }
.form-label i { color:var(--gold); }
.form-control { border:1.5px solid var(--bdr); border-radius:var(--rsm); padding:11px 13px; font:400 .93rem 'DM Sans',sans-serif; background:var(--sand); color:var(--text); outline:none; transition:.18s; width:100%; }
.form-control:focus { border-color:var(--gold); box-shadow:0 0 0 4px rgba(184,132,42,.12); background:#fff; }
.auth-footer { text-align:center; margin-top:18px; font-size:.87rem; color:var(--muted); }
.auth-footer a { color:var(--gold); font-weight:600; }

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media (min-width:768px) {
  .hero-inner { grid-template-columns:1fr 1fr; }
  .about-inner { grid-template-columns:1fr 1fr; }
  .service-layout { grid-template-columns:1fr 320px; }
  .footer-inner { grid-template-columns:2fr 1fr 1fr 1fr; }
  .fg { grid-template-columns:repeat(2,1fr); }
  .booking-picker-grid { grid-template-columns:1.25fr .95fr; }
  .services-filter-form { flex-direction:row; align-items:center; }
  .filter-search { flex:1; }
}
@media (max-width:1040px) {
  .topbar-inner { padding:0 18px; gap:12px; }
  .logo-copy strong { font-size:1.6rem; }
  .logo-copy small { font-size:.68rem; letter-spacing:.18em; }
  .topnav a { padding:8px 10px; font-size:.82rem; }
  .topbar-cta { gap:6px; }
}
@media (max-width:767px) {
  .topnav { display:none; }
  .topbar-inner { height:64px; padding:0 14px; gap:10px; }
  .topbar-cta .btn:not(.btn-primary) { display:none; }
  .bottom-nav { display:grid; }
  body { padding-bottom:80px; }
  .logo-mark { width:42px; height:42px; }
  .logo-copy strong { font-size:1.45rem; }
  .logo-copy small { font-size:.66rem; letter-spacing:.18em; }
  .topbar-cta .btn-primary { min-height:38px; padding:8px 12px; font-size:.78rem; }
  .hero-stat { display:none; }
  .modal-overlay { padding:0; align-items:flex-end; }
  .modal-overlay.order-success-overlay { padding:12px; align-items:flex-end; }
  .modal { width:100%; max-height:min(92dvh, 100vh); border-radius:24px 24px 0 0; }
  .modal-body { padding:16px 16px 24px; overscroll-behavior:contain; }
  .m-head { position:sticky; top:-16px; z-index:5; background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.94)); padding:14px 0 12px; margin-bottom:14px; backdrop-filter:blur(10px); }
  .m-title { font-size:1.45rem; }
  .m-sub { font-size:.82rem; }
  .f label { font-size:.74rem; }
  .f input,.f textarea,.f select { min-height:48px; font-size:16px; padding:12px 13px; }
  .booking-picker-grid { gap:12px; margin:14px 0; }
  .booking-picker-card { padding:14px; border-radius:16px; }
  .picker-head { flex-direction:column; align-items:stretch; gap:10px; margin-bottom:12px; }
  .picker-nav { justify-content:space-between; }
  .picker-month { min-width:0; flex:1; }
  .booking-weekdays,.booking-days { gap:5px; }
  .booking-weekday { font-size:.62rem; letter-spacing:.05em; padding:2px 0; }
  .booking-day,.booking-day-empty { min-height:52px; }
  .booking-day { border-radius:14px; padding:8px; justify-content:flex-start; }
  .booking-day-num { font-size:1rem; }
  .slot-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); gap:8px; }
  .slot-chip { width:100%; min-height:44px; padding:0 10px; font-size:.84rem; }
  .booking-selection-note { margin-top:10px; font-size:.78rem; }
  .payment-method-note { justify-content:flex-start; }
  .payment-method-note span { flex:1 1 calc(50% - 6px); justify-content:center; }
  .price-summary { position:sticky; bottom:-24px; z-index:4; margin:16px -16px 0; padding:14px 16px calc(14px + env(safe-area-inset-bottom)); border-radius:18px 18px 0 0; box-shadow:0 -16px 34px rgba(16,14,11,.16); }
  .p-row { font-size:.83rem; }
  #bookSubmitBtn { min-height:52px; position:sticky; bottom:0; z-index:4; }
  .booking-card { flex-direction:column; }
  .bc-img { display:none; }
  .bc-body { padding:16px; }
  .bc-top { flex-direction:column; align-items:stretch; }
  .bc-badges { gap:8px; }
  .bc-meta { gap:8px; flex-direction:column; }
  .bc-meta span { width:100%; }
  .bc-footer { flex-direction:column; align-items:stretch; }
  .bc-footer .btn { width:100%; justify-content:center; }
  .svc-actions { flex-wrap:wrap; }
  .svc-actions .btn { flex:1 1 calc(50% - 5px); justify-content:center; }
  .booking-sidebar-card { padding:20px; }
  .bsc-slot-preview-list span { flex:1 1 calc(50% - 8px); }
  .order-success-card { padding:16px; }
  .order-success-card h3 { font-size:1.5rem; }
  .order-success-grid { grid-template-columns:1fr; gap:10px; }
  .order-success-grid div { padding:12px; }
  .service-highlights,.included-grid { grid-template-columns:1fr; }
  .sdh-meta-item:nth-child(n+5) { display:none; }
  .service-gallery-panel { padding:12px; border-radius:20px; }
  .service-gallery-main { border-radius:18px; min-height:220px; }
  .service-gallery-main img { min-height:220px; height:56vw; }
  .service-gallery-thumbs { grid-template-columns:repeat(4,minmax(0,1fr)); gap:8px; }
  .service-gallery-thumb { border-radius:14px; }
  .wrap { padding:0 16px; }
}
@media (max-width:520px) {
  .logo-copy small { display:none; }
  .logo-copy strong { font-size:1.2rem; }
}
