@import url('https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700&family=Poppins:ital,wght@0,300;0,400;0,500;0,600;1,300&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Dancing+Script:wght@500;600;700&display=swap');

/* ═══════════════════════════════════════
   VARIABLES — Light / White Theme
═══════════════════════════════════════ */
:root {
  --gold:        #C9A84C;
  --gold-2:      #D4AF37;
  --gold-light:  #E8C97A;
  --gold-dark:   #9A7B1E;
  --gold-muted:  rgba(201,168,76,0.08);
  --gold-border: rgba(201,168,76,0.30);

  /* Backgrounds */
  --bg-white:  #ffffff;
  --bg-soft:   #FAF8F4;      /* very light cream */
  --bg-cream:  #F4EFE6;      /* warm cream */

  /* Text */
  --text-dark:   #1a1a1a;
  --text-body:   #3d3d3d;
  --text-muted:  #777;
  --text-light:  #aaa;

  /* Borders / dividers */
  --border:      #e8e2d8;
  --border-soft: #f0ebe2;

  /* Cards */
  --card-bg:     #ffffff;
  --card-shadow: 0 2px 20px rgba(0,0,0,.07);
  --card-shadow-hover: 0 8px 40px rgba(0,0,0,.12);

  /* Accents (keep dark for admin + footer) */
  --dark-footer: #111111;
  --dark-admin:  #0f0f0f;

  --success: #5ea864;
  --error:   #e05252;
  --warn:    #ffaa00;

  --serif:   'Cormorant Garamond', Georgia, serif;
  --sans:    'Poppins', Arial, sans-serif;
  --display: 'Cinzel Decorative', 'Cormorant Garamond', serif;
  --script:  'Dancing Script', cursive;

  --shadow-gold: 0 6px 30px rgba(201,168,76,.22);
  --radius:    5px;
  --radius-lg: 16px;
  --t: all .3s ease;

  /* ── backwards-compat aliases (for old inline styles) ── */
  --dark-1: var(--bg-white);
  --dark-2: var(--bg-soft);
  --dark-3: var(--bg-cream);
  --dark-4: var(--border);
  --dark-5: var(--border-soft);
  --cream:  var(--text-dark);
  --gray-1: var(--text-body);
  --gray-2: var(--text-muted);
  --gray-3: var(--text-light);
  --gold-muted: rgba(201,168,76,0.08);
  --gold-border:rgba(201,168,76,0.30);
  --shadow: 0 4px 24px rgba(0,0,0,.10);
}

/* ═══════════════════════════════════════
   RESET
═══════════════════════════════════════ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--sans); background:var(--bg-white); color:var(--text-body); line-height:1.7; font-size:15px; overflow-x:hidden; }
img  { max-width:100%; height:auto; display:block; }
a    { color:var(--gold-dark); text-decoration:none; transition:var(--t); }
a:hover { color:var(--gold); }
ul   { list-style:none; }
button, input, textarea, select { font-family:var(--sans); }

/* ═══════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════ */
/* h2–h5: Poppins clean */
h2,h3,h4,h5 { font-family:'Poppins', Arial, sans-serif; font-weight:500; line-height:1.2; color:var(--text-dark); }
/* h1 default (non-hero): Poppins */
h1 { font-family:'Poppins', Arial, sans-serif; font-weight:600; line-height:1.15; color:var(--text-dark); }
h1 { font-size:clamp(2.8rem,6vw,5.2rem); }
h2 { font-size:clamp(2rem,4vw,3.2rem); }
h3 { font-size:clamp(1.4rem,2.5vw,2rem); }
h4 { font-size:1.25rem; }

.gold-text  { color:var(--gold); }
.script     { font-family:var(--script); color:var(--gold); }
.section-label {
  font-size:11px; letter-spacing:4px; text-transform:uppercase;
  color:var(--gold); display:block; margin-bottom:12px;
}
.section-sub {
  color:var(--text-muted); font-size:15px; line-height:1.8;
  max-width:620px; margin-bottom:50px;
}
.divider {
  width:50px; height:1px;
  background:linear-gradient(to right, var(--gold), transparent);
  margin:18px 0;
}
.divider-c {
  margin-inline:auto;
  background:linear-gradient(to right, transparent, var(--gold), transparent);
  width:120px;
}

/* ═══════════════════════════════════════
   LAYOUT
═══════════════════════════════════════ */
.container { max-width:1200px; margin:0 auto; padding:0 28px; }
section    { padding:100px 0; }

/* ═══════════════════════════════════════
   NAVIGATION
═══════════════════════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  background:#fff;
  border-bottom:1px solid var(--border-soft);
  box-shadow:0 2px 20px rgba(0,0,0,.07);
  transition:box-shadow .3s;
}
.nav.scrolled {
  box-shadow:0 4px 30px rgba(0,0,0,.12);
}
.nav-inner {
  max-width:1200px; margin:0 auto; padding:0 28px;
  display:flex; align-items:center; justify-content:space-between;
  height:82px;
}
.nav-logo img { height:60px; transition:var(--t); }
.nav.scrolled .nav-logo img { height:50px; }
.nav-links { display:flex; align-items:center; gap:34px; }
.nav-links a {
  font-size:11px; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--text-body); font-weight:500; position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-4px; left:0;
  width:0; height:1px; background:var(--gold); transition:var(--t);
}
.nav-links a:hover, .nav-links a.active { color:var(--gold) !important; }
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }
.nav-cta {
  background:var(--gold) !important; color:#fff !important;
  padding:9px 22px !important; border-radius:3px;
  font-size:10px !important; letter-spacing:2px; transition:var(--t) !important;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { background:var(--gold-dark) !important; }

/* ── Hamburger elegant ── */
.hamburger {
  display:none; flex-direction:column; gap:6px;
  cursor:pointer; z-index:1001; padding:4px;
  background:none; border:none;
}
.hamburger span {
  display:block; height:1px; background:var(--text-dark);
  transition:all .35s cubic-bezier(.4,0,.2,1);
  transform-origin:center;
}
.hamburger span:nth-child(1) { width:22px; }
.hamburger span:nth-child(2) { width:14px; }
.hamburger span:nth-child(3) { width:18px; }
.hamburger.open span:nth-child(1) { width:20px; transform:rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity:0; width:0; }
.hamburger.open span:nth-child(3) { width:20px; transform:rotate(-45deg) translate(5px,-5px); }

/* ── Mobile drawer ── */
.mob-backdrop {
  position:fixed; inset:0; background:rgba(0,0,0,.35);
  z-index:998; opacity:0; pointer-events:none;
  transition:opacity .35s;
}
.mob-backdrop.open { opacity:1; pointer-events:all; }

.mobile-menu {
  position:fixed; top:0; right:0; bottom:0;
  width:min(300px, 82vw);
  background:#fff;
  z-index:999;
  display:flex; flex-direction:column;
  padding:0;
  transform:translateX(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  box-shadow:-8px 0 40px rgba(0,0,0,.12);
  pointer-events:none;
}
.mobile-menu.open { transform:translateX(0); pointer-events:all; }

/* Drawer header */
.mobile-menu .mob-hd {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 24px;
  border-bottom:1px solid var(--border-soft);
}
.mobile-menu .mob-hd img { height:44px; }
.mobile-menu .mob-close {
  width:32px; height:32px; border-radius:50%;
  background:var(--bg-soft); border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-size:16px; color:var(--text-muted); transition:var(--t);
}
.mobile-menu .mob-close:hover { background:var(--gold-muted); color:var(--gold-dark); }

/* Drawer nav links */
.mobile-menu nav {
  display:flex; flex-direction:column;
  padding:10px 0; flex:1; overflow-y:auto;
}
.mobile-menu nav a {
  font-family:var(--sans); font-size:14px;
  font-weight:500; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--text-body);
  padding:15px 24px;
  border-bottom:1px solid var(--border-soft);
  transition:var(--t); display:block;
}
.mobile-menu nav a:hover,
.mobile-menu nav a.active { color:var(--gold-dark); background:var(--gold-muted); }
.mobile-menu nav a:last-child { border-bottom:none; }

/* Drawer footer CTA */
.mobile-menu .mob-cta {
  padding:20px 24px;
  border-top:1px solid var(--border-soft);
}
.mobile-menu .mob-cta a {
  display:block; text-align:center;
  background:var(--gold); color:#fff !important;
  padding:13px; border-radius:6px;
  font-size:11px; font-weight:600;
  letter-spacing:2.5px; text-transform:uppercase;
  text-decoration:none; transition:var(--t);
}
.mobile-menu .mob-cta a:hover { background:var(--gold-dark); }

/* ═══════════════════════════════════════
   BUTTONS
═══════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 32px; font-size:11px; font-weight:600;
  letter-spacing:2.5px; text-transform:uppercase;
  border:none; cursor:pointer; transition:var(--t);
  border-radius:3px; white-space:nowrap;
}
.btn-gold {
  background:linear-gradient(135deg, var(--gold), var(--gold-2));
  color:#fff;
}
.btn-gold:hover {
  background:linear-gradient(135deg, var(--gold-2), var(--gold-dark));
  transform:translateY(-2px); box-shadow:var(--shadow-gold);
  color:#fff;
}
.btn-outline {
  background:transparent; border:1.5px solid var(--gold); color:var(--gold-dark);
}
.btn-outline:hover { background:var(--gold); color:#fff; }
.btn-dark {
  background:var(--bg-cream); color:var(--text-body);
  border:1px solid var(--border);
}
.btn-dark:hover { border-color:var(--gold-border); color:var(--gold-dark); }
.btn-sm  { padding:9px 20px; font-size:10px; }
.btn-danger { background:rgba(224,82,82,.08); color:var(--error); border:1px solid rgba(224,82,82,.25); }
.btn-danger:hover { background:var(--error); color:#fff; }

/* ═══════════════════════════════════════
   HERO — full-screen with overlay
═══════════════════════════════════════ */
.hero {
  position:relative; height:100vh; min-height:620px;
  display:flex; align-items:stretch; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center top;
}
/* Gradient only on left side — right side shows photo clearly */
.hero-bg::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(
    to right,
    rgba(8,6,4,.82) 0%,
    rgba(8,6,4,.72) 30%,
    rgba(8,6,4,.40) 58%,
    rgba(8,6,4,.0)  100%
  );
}
/* Content panel — left 50% */
.hero-content {
  position:relative; z-index:1;
  display:flex; flex-direction:column; justify-content:center;
  width:50%; max-width:620px;
  padding:0 60px 0 64px;
}
.hero-label {
  display:inline-flex; align-items:center; gap:14px;
  font-size:11px; letter-spacing:5px; text-transform:uppercase;
  color:var(--gold-light); margin-bottom:22px;
}
.hero-label::before { content:''; width:32px; height:1px; background:var(--gold-light); }
.hero h1 {
  font-family:'Cinzel Decorative', 'Cormorant Garamond', serif;
  font-weight:400;
  font-size:clamp(2.2rem,4.5vw,4.2rem);
  margin-bottom:20px;
  color:#fff;
  letter-spacing:.04em;
  line-height:1.2;
  text-shadow:0 2px 24px rgba(0,0,0,.4);
}
.hero h1 em {
  font-style:italic; color:var(--gold-light);
  font-family:'Cormorant Garamond',serif;
  font-size:1.15em;
}
.hero-sub { color:rgba(255,255,255,.78); font-size:15px; max-width:440px; margin-bottom:42px; line-height:1.9; }
.hero-btns { display:flex; gap:12px; flex-wrap:wrap; }
.hero .btn-outline { border-color:rgba(255,255,255,.55); color:#fff; }
.hero .btn-outline:hover { background:rgba(255,255,255,.12); }

.hero-scroll {
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:6px;
  color:rgba(255,255,255,.4); font-size:10px; letter-spacing:3px;
  text-transform:uppercase; animation:bob 2s infinite;
}
.hero-scroll::after {
  content:''; width:1px; height:44px;
  background:linear-gradient(to bottom, rgba(201,168,76,.7), transparent);
  margin-top:4px;
}
@keyframes bob {
  0%,100% { transform:translateX(-50%) translateY(0); }
  50%      { transform:translateX(-50%) translateY(8px); }
}

/* ═══════════════════════════════════════
   PAGE BANNER (inner pages)
═══════════════════════════════════════ */
.page-banner {
  height:38vh; min-height:280px; position:relative;
  display:flex; align-items:flex-end; padding-bottom:48px;
  overflow:hidden; margin-top:82px;
}
.page-banner-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center; opacity:.45;
}
.page-banner::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(10,10,10,.85) 0%, rgba(10,10,10,.5) 60%, rgba(10,10,10,.15) 100%);
}
.page-banner-content { position:relative; z-index:1; }
.page-banner h1 { color:#fff; font-family:'Cinzel Decorative','Cormorant Garamond',serif; font-weight:400; letter-spacing:.04em; }
.breadcrumb {
  display:flex; align-items:center; gap:10px;
  font-size:11px; letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,.45); margin-bottom:10px;
}
.breadcrumb span { color:var(--gold-light); }
.breadcrumb a { color:rgba(255,255,255,.45); }

/* ═══════════════════════════════════════
   ABOUT GRID
═══════════════════════════════════════ */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-img-wrap { position:relative; }
.about-img-wrap img { width:100%; height:580px; object-fit:cover; border-radius:var(--radius); }
.about-img-wrap::before {
  content:''; position:absolute; top:-14px; left:-14px; right:28px; bottom:28px;
  border:1px solid var(--gold-border); border-radius:var(--radius); z-index:-1;
}
.about-img-wrap::after {
  content:''; position:absolute; top:14px; left:14px; right:-28px; bottom:-28px;
  background:var(--gold-muted); border-radius:var(--radius); z-index:-1;
}

.about-stats { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:32px; }
.stat-card {
  padding:20px; background:var(--bg-soft);
  border:1px solid var(--border); border-radius:var(--radius);
}
.stat-num { font-family:var(--serif); font-size:2.8rem; color:var(--gold); line-height:1; margin-bottom:4px; }
.stat-lbl { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); }

/* ═══════════════════════════════════════
   SERVICE CARDS
═══════════════════════════════════════ */
.services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:24px; }
.svc-card {
  background:var(--card-bg); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:38px 32px;
  position:relative; overflow:hidden; transition:var(--t);
  box-shadow:var(--card-shadow);
}
.svc-card::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(to right, transparent, var(--gold), transparent);
  opacity:0; transition:var(--t);
}
.svc-card:hover { transform:translateY(-5px); box-shadow:var(--card-shadow-hover); border-color:var(--gold-border); }
.svc-card:hover::after { opacity:1; }

.svc-icon { display:none; }
.svc-card h3  { font-size:1.45rem; margin-bottom:12px; color:var(--text-dark); padding-top:4px; }
.svc-card p   { color:var(--text-muted); font-size:14px; line-height:1.8; margin-bottom:22px; }
.svc-meta     { display:flex; justify-content:space-between; align-items:center; padding-top:16px; border-top:1px solid var(--border-soft); }
.svc-price    { font-family:var(--serif); font-size:1.8rem; color:var(--gold); }
.svc-price small { font-size:.95rem; color:var(--text-muted); }
.svc-dur      { font-size:11px; letter-spacing:1px; text-transform:uppercase; color:var(--text-light); }

/* ═══════════════════════════════════════
   GALLERY
═══════════════════════════════════════ */
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:5px; }
.gal-item { position:relative; overflow:hidden; cursor:pointer; }
.gal-item:nth-child(1), .gal-item:nth-child(4) { grid-column:span 2; }
.gal-item img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .6s ease; }
.gal-item:nth-child(1)  { aspect-ratio:16/9; }
.gal-item:nth-child(4)  { aspect-ratio:16/9; }
.gal-item:not(:nth-child(1)):not(:nth-child(4)) { aspect-ratio:1; }
.gal-item:hover img     { transform:scale(1.06); }
.gal-overlay { position:absolute; inset:0; background:rgba(10,10,10,.5); display:flex; align-items:center; justify-content:center; opacity:0; transition:var(--t); }
.gal-item:hover .gal-overlay { opacity:1; }
.gal-overlay span { width:48px; height:48px; border:1px solid var(--gold); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:20px; }

/* Lightbox */
.lightbox { position:fixed; inset:0; background:rgba(0,0,0,.97); z-index:9999; display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .3s; }
.lightbox.open { opacity:1; pointer-events:all; }
.lightbox img  { max-width:90vw; max-height:90vh; object-fit:contain; border-radius:var(--radius); }
.lb-close,.lb-prev,.lb-next { position:absolute; width:46px; height:46px; border:1px solid rgba(255,255,255,.2); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-size:20px; cursor:pointer; transition:var(--t); background:transparent; }
.lb-close:hover,.lb-prev:hover,.lb-next:hover { border-color:var(--gold); color:var(--gold); }
.lb-close { top:24px; right:24px; }
.lb-prev  { left:24px;  top:50%; transform:translateY(-50%); }
.lb-next  { right:24px; top:50%; transform:translateY(-50%); }

/* ═══════════════════════════════════════
   CONTACT
═══════════════════════════════════════ */
.contact-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:56px; align-items:start; }
.contact-card {
  display:flex; gap:16px; padding:24px;
  background:var(--card-bg); border:1px solid var(--border);
  border-radius:var(--radius); margin-bottom:14px;
  box-shadow:var(--card-shadow); transition:var(--t);
}
.contact-card:hover { border-color:var(--gold-border); box-shadow:0 4px 20px rgba(201,168,76,.1); }
.contact-icon {
  width:46px; height:46px; flex-shrink:0;
  background:var(--gold-muted); border:1px solid var(--gold-border);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:20px; color:var(--gold);
}
.contact-card h4 { font-size:1rem; margin-bottom:3px; color:var(--text-dark); }
.contact-card p, .contact-card a { color:var(--text-muted); font-size:14px; }
.insta-link { display:inline-flex; align-items:center; gap:8px; color:var(--gold-dark); font-size:14px; }

/* ═══════════════════════════════════════
   FORMS (public)
═══════════════════════════════════════ */
.form-group   { margin-bottom:20px; }
.form-label   { display:block; font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); margin-bottom:8px; }
.form-label .req { color:var(--gold); }
.form-input, .form-textarea, .form-select {
  width:100%; background:#fff; border:1.5px solid var(--border);
  border-radius:var(--radius); padding:13px 16px; color:var(--text-dark);
  font-size:14px; transition:var(--t); outline:none; -webkit-appearance:none;
}
.form-input:focus, .form-textarea:focus, .form-select:focus {
  border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,.10);
}
.form-input::placeholder, .form-textarea::placeholder { color:var(--text-light); }
.form-textarea  { resize:vertical; min-height:120px; }
.form-select    { cursor:pointer; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23aaa' fill='none' stroke-width='1.5'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:40px; }
.form-row       { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-actions   { display:flex; justify-content:space-between; align-items:center; margin-top:24px; gap:12px; }
.form-input.error, .form-textarea.error { border-color:var(--error); }
.field-error    { color:var(--error); font-size:12px; margin-top:5px; }

/* ═══════════════════════════════════════
   BOOKING PAGE
═══════════════════════════════════════ */
.booking-steps-bar {
  display:flex; justify-content:center;
  margin-bottom:52px; position:relative;
}
.booking-steps-bar::before {
  content:''; position:absolute; top:20px; left:50%;
  transform:translateX(-50%); width:70%; height:1px; background:var(--border);
}
.step-dot-wrap { display:flex; flex-direction:column; align-items:center; gap:10px; position:relative; z-index:1; flex:1; max-width:110px; }
.step-dot {
  width:40px; height:40px; border-radius:50%; border:1.5px solid var(--border);
  background:#fff; display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-size:1.05rem; color:var(--text-light); transition:var(--t);
}
.step-dot-wrap.active .step-dot, .step-dot-wrap.done .step-dot {
  background:var(--gold); border-color:var(--gold); color:#fff;
}
.step-dot-wrap .s-label { font-size:10px; letter-spacing:1px; text-transform:uppercase; color:var(--text-light); text-align:center; }
.step-dot-wrap.active .s-label { color:var(--gold); }

.booking-panel {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:48px;
  max-width:840px; margin:0 auto;
  box-shadow:0 4px 40px rgba(0,0,0,.07);
}
.step-content { display:none; }
.step-content.active { display:block; animation:fadeUp .35s ease; }
@keyframes fadeUp { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }

/* Options */
.opts-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:12px; margin-bottom:28px; }
.opt-card {
  padding:22px 16px; border:1.5px solid var(--border); border-radius:var(--radius);
  cursor:pointer; transition:var(--t); text-align:center; background:#fff;
}
.opt-card:hover, .opt-card.sel { border-color:var(--gold); background:var(--gold-muted); }
.opt-card h4   { font-size:.95rem; margin-bottom:6px; color:var(--text-dark); }
.opt-price     { color:var(--gold); font-size:1.05rem; font-family:var(--serif); }
.opt-dur       { color:var(--text-light); font-size:11px; margin-top:3px; }

.staff-avatar {
  width:52px; height:52px; border-radius:50%; background:var(--bg-soft);
  border:2px solid var(--gold-border); margin:0 auto 10px;
  display:flex; align-items:center; justify-content:center;
  font-size:20px; color:var(--gold); overflow:hidden;
}

/* Calendar */
.cal-wrap   { margin-bottom:26px; }
.cal-head   { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.cal-nav    { width:34px; height:34px; border:1.5px solid var(--border); background:#fff; color:var(--text-body); cursor:pointer; border-radius:var(--radius); display:flex; align-items:center; justify-content:center; font-size:16px; transition:var(--t); }
.cal-nav:hover { border-color:var(--gold); color:var(--gold); }
.cal-title  { font-family:var(--serif); font-size:1.3rem; color:var(--text-dark); }
.cal-weekdays { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; margin-bottom:4px; }
.cal-weekdays div { text-align:center; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-light); padding:6px 0; }
.cal-days   { display:grid; grid-template-columns:repeat(7,1fr); gap:3px; }
.cal-day    { aspect-ratio:1; display:flex; align-items:center; justify-content:center; border-radius:var(--radius); font-size:13px; cursor:pointer; transition:var(--t); border:1px solid transparent; color:var(--text-dark); }
.cal-day.empty    { cursor:default; }
.cal-day.disabled { color:var(--text-light); cursor:not-allowed; }
.cal-day.avail:hover { border-color:var(--gold); color:var(--gold-dark); background:var(--gold-muted); }
.cal-day.sel  { background:var(--gold); color:#fff; font-weight:600; }
.cal-day.today:not(.sel) { border-color:var(--gold-border); color:var(--gold-dark); }

/* Time slots */
.slots-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(82px,1fr)); gap:8px; margin-bottom:26px; }
.slot { padding:11px 6px; border:1.5px solid var(--border); border-radius:var(--radius); text-align:center; font-size:13px; cursor:pointer; transition:var(--t); background:#fff; color:var(--text-dark); }
.slot:hover, .slot.sel { border-color:var(--gold); background:var(--gold-muted); color:var(--gold-dark); }
.slot.busy { background:var(--bg-soft); color:var(--text-light); cursor:not-allowed; text-decoration:line-through; }

/* Booking summary */
.confirm-box { text-align:center; padding:28px 16px; }
.confirm-icon { width:72px; height:72px; border-radius:50%; background:rgba(94,168,100,.08); border:2px solid var(--success); display:flex; align-items:center; justify-content:center; margin:0 auto 22px; font-size:32px; color:var(--success); }
.booking-summary { background:var(--bg-soft); border-radius:var(--radius); padding:20px; text-align:left; margin:22px 0; }
.bs-row { display:flex; justify-content:space-between; padding:8px 0; border-bottom:1px solid var(--border-soft); font-size:14px; }
.bs-row:last-child { border-bottom:none; }
.bs-row span:first-child { color:var(--text-muted); }
.bs-row span:last-child  { color:var(--text-dark); font-weight:500; }

/* ═══════════════════════════════════════
   CAROUSEL (home gallery)
═══════════════════════════════════════ */
.carousel-root    { position:relative; overflow:hidden; padding-bottom:52px; touch-action:pan-y; }
.carousel-track   { display:flex; gap:14px; padding:0 28px; transition:transform .6s cubic-bezier(.25,.46,.45,.94); }
.carousel-slide   { flex:0 0 300px; height:380px; border-radius:14px; overflow:hidden; cursor:pointer; box-shadow:0 6px 28px rgba(0,0,0,.12); }
.carousel-slide img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease; pointer-events:none; }
.carousel-slide:hover img { transform:scale(1.05); }
.car-btn {
  position:absolute; top:50%; transform:translateY(calc(-50% - 26px));
  width:46px; height:46px; border-radius:50%; border:none;
  background:#fff; box-shadow:0 3px 16px rgba(0,0,0,.15);
  display:flex; align-items:center; justify-content:center;
  font-size:22px; color:#333; cursor:pointer; z-index:10; transition:all .25s;
}
.car-btn:hover { background:var(--gold); color:#fff; transform:translateY(calc(-50% - 26px)) scale(1.05); }
.car-prev { left:10px; }
.car-next { right:10px; }
.car-dots { position:absolute; bottom:16px; left:0; right:0; display:flex; justify-content:center; gap:8px; }
.car-dot  { width:7px; height:7px; border-radius:50%; background:var(--border); border:none; cursor:pointer; transition:all .3s; padding:0; }
.car-dot.on { background:var(--gold); width:24px; border-radius:4px; }
@media(max-width:768px){
  .carousel-slide { flex:0 0 250px; height:300px; }
  .car-btn { width:38px; height:38px; font-size:18px; }
}
@media(max-width:480px){
  .carousel-slide { flex:0 0 80vw; height:260px; }
}

/* ═══════════════════════════════════════
   CTA SECTION
═══════════════════════════════════════ */
.cta-section {
  background:linear-gradient(135deg, #1a1a1a 0%, #111 100%);
  text-align:center; padding:90px 0;
  border-top:3px solid var(--gold);
}
.cta-section .section-label { color:var(--gold-light); }
.cta-section h2 { color:#fff; margin-bottom:14px; }
.cta-section p  { color:rgba(255,255,255,.6); font-size:16px; margin-bottom:34px; max-width:520px; margin-inline:auto; }


/* ═══════════════════════════════════════
   MASONRY GALLERY
═══════════════════════════════════════ */
.masonry-grid {
  column-count: 3;
  column-gap: 10px;
}
.masonry-item {
  position: relative;
  break-inside: avoid;
  margin-bottom: 10px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
}
.masonry-item img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform .55s ease;
}
.masonry-item:hover img { transform: scale(1.04); }
.masonry-item .gal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(10,10,10,.48);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .3s;
  border-radius: var(--radius-lg);
}
.masonry-item:hover .gal-overlay { opacity: 1; }
/* Give some items a gold border accent */
.masonry-item:nth-child(3n+1) { margin-top: 24px; }
.masonry-item:first-child     { margin-top: 0; }
@media(max-width:768px){
  .masonry-grid { column-count: 2; }
}
@media(max-width:480px){
  .masonry-grid { column-count: 1; }
}
/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
footer { background:#111; border-top:1px solid rgba(201,168,76,.2); padding:76px 0 36px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:44px; margin-bottom:52px; }
.footer-brand { background:#fff; border-radius:12px; padding:28px; }
.footer-brand img  { height:70px; margin-bottom:16px; }
.footer-brand p    { color:#555; font-size:14px; line-height:1.9; max-width:270px; margin-bottom:20px; }
.footer-socials    { display:flex; gap:10px; }
.footer-socials a  { width:38px; height:38px; border:1px solid var(--gold-border); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--gold-dark); font-size:15px; transition:var(--t); }
.footer-socials a:hover { border-color:var(--gold); color:var(--gold); }
.footer-col h4     { font-size:.95rem; color:#fff; margin-bottom:16px; padding-bottom:10px; border-bottom:1px solid rgba(255,255,255,.06); }
.footer-col a      { display:block; color:#666; font-size:13px; padding:5px 0; transition:var(--t); }
.footer-col a:hover { color:var(--gold); padding-left:4px; }
.footer-col p      { color:#666; font-size:13px; line-height:1.7; }
.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
  padding-top:28px; border-top:1px solid rgba(255,255,255,.05);
  color:#444; font-size:12px; flex-wrap:wrap; gap:10px;
}
.footer-bottom a { color:var(--gold-dark); }

/* ═══════════════════════════════════════
   ADMIN LAYOUT
═══════════════════════════════════════ */
.admin-body { background:#f5f5f5; min-height:100vh; }
.admin-layout { display:flex; min-height:100vh; }

.sidebar {
  width:255px; background:#fff; border-right:1px solid #e8e8e8;
  padding:0; position:fixed; top:0; left:0; height:100vh;
  overflow-y:auto; z-index:200; box-shadow:2px 0 20px rgba(0,0,0,.05);
}
.sidebar-logo { padding:22px; border-bottom:1px solid #f0f0f0; }
.sidebar-logo img { height:50px; }
.sidebar-nav { padding:12px 0; }
.sidebar-nav a {
  display:flex; align-items:center; gap:12px; padding:12px 22px;
  color:#666; font-size:13px; transition:var(--t);
  border-left:2px solid transparent;
}
.sidebar-nav a:hover, .sidebar-nav a.active {
  color:var(--text-dark); background:rgba(201,168,76,.06); border-left-color:var(--gold);
}
.sidebar-nav a.active { color:var(--gold-dark); }
.sidebar-nav .n-icon { font-size:16px; width:20px; text-align:center; }
.sidebar-sep { height:1px; background:#f0f0f0; margin:6px 0; }

.admin-main { margin-left:255px; flex:1; padding:32px; }
.admin-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:26px; padding-bottom:20px; border-bottom:1px solid #eee; flex-wrap:wrap; gap:14px; }
.admin-title { font-family:var(--serif); font-size:1.9rem; color:var(--text-dark); }
.admin-title small { font-family:var(--sans); font-size:13px; color:var(--text-muted); display:block; font-weight:400; }

/* Admin stats */
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:24px; }
.a-stat { background:#fff; border:1px solid #eee; border-radius:var(--radius); padding:22px; box-shadow:0 2px 8px rgba(0,0,0,.04); }
.a-stat .num { font-family:var(--serif); font-size:2.4rem; color:var(--gold); line-height:1; margin-bottom:4px; }
.a-stat .lbl { font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); }

/* Tables */
.table-wrap { background:#fff; border:1px solid #eee; border-radius:var(--radius); overflow:hidden; box-shadow:0 2px 10px rgba(0,0,0,.04); }
.table-head { display:flex; justify-content:space-between; align-items:center; padding:16px 22px; border-bottom:1px solid #f0f0f0; flex-wrap:wrap; gap:12px; }
.table-title { font-family:var(--serif); font-size:1.2rem; color:var(--text-dark); }
table { width:100%; border-collapse:collapse; }
th { padding:10px 18px; text-align:left; font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); background:#fafafa; font-weight:500; white-space:nowrap; }
td { padding:13px 18px; border-bottom:1px solid #f5f5f5; font-size:13px; color:var(--text-body); }
tr:last-child td { border-bottom:none; }
tr:hover td { background:#fafaf8; }
.td-actions { display:flex; gap:6px; }

/* Badges */
.badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:11px; letter-spacing:.6px; text-transform:uppercase; font-weight:500; }
.badge-pending   { background:rgba(255,170,0,.1);   color:#c78800; border:1px solid rgba(255,170,0,.25); }
.badge-confirmed { background:rgba(94,168,100,.1);  color:#3d8c43; border:1px solid rgba(94,168,100,.25); }
.badge-cancelled { background:rgba(224,82,82,.08);  color:#c94040; border:1px solid rgba(224,82,82,.2); }

/* Modal */
.modal-bg { position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:1000; display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .3s; }
.modal-bg.open { opacity:1; pointer-events:all; }
.modal { background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:36px; width:100%; max-width:560px; max-height:90vh; overflow-y:auto; transform:translateY(16px); transition:transform .3s; box-shadow:0 20px 60px rgba(0,0,0,.15); }
.modal-bg.open .modal { transform:translateY(0); }
.modal-hd { display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; }
.modal-close { width:34px; height:34px; border:1.5px solid var(--border); background:#fff; color:var(--text-muted); cursor:pointer; display:flex; align-items:center; justify-content:center; border-radius:var(--radius); font-size:17px; transition:var(--t); }
.modal-close:hover { border-color:var(--error); color:var(--error); }

/* Admin Tabs */
.a-tabs { display:flex; gap:4px; background:#f5f5f5; padding:4px; border-radius:var(--radius); margin-bottom:20px; flex-wrap:wrap; }
.a-tab { flex:1; min-width:80px; padding:8px 14px; background:transparent; border:none; color:var(--text-muted); font-size:11px; letter-spacing:1.5px; text-transform:uppercase; cursor:pointer; border-radius:var(--radius); transition:var(--t); }
.a-tab.active { background:#fff; color:var(--gold-dark); box-shadow:0 1px 4px rgba(0,0,0,.08); }
.a-tab-pane { display:none; }
.a-tab-pane.active { display:block; animation:fadeUp .3s ease; }

/* Search */
.search-bar { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.search-bar input { background:#fff; border:1.5px solid var(--border); border-radius:var(--radius); padding:8px 14px; color:var(--text-dark); font-size:13px; outline:none; width:210px; transition:var(--t); }
.search-bar input:focus { border-color:var(--gold-border); }
.filter-select { background:#fff; border:1.5px solid var(--border); border-radius:var(--radius); padding:8px 14px; color:var(--text-dark); font-size:13px; outline:none; cursor:pointer; }

/* Admin detail */
.detail-row { display:flex; gap:12px; padding:11px 0; border-bottom:1px solid #f5f5f5; align-items:flex-start; }
.detail-row .lbl { width:120px; flex-shrink:0; font-size:12px; letter-spacing:1px; text-transform:uppercase; color:var(--text-muted); }
.detail-row .val { font-size:14px; color:var(--text-dark); }

/* Admin Login */
.login-page { min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--bg-soft); }
.login-box { width:100%; max-width:400px; padding:48px 44px; background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); box-shadow:0 8px 40px rgba(0,0,0,.08); }
.login-box .logo-wrap { text-align:center; margin-bottom:30px; }
.login-box .logo-wrap img { height:80px; margin:0 auto; }
.login-box h2  { font-size:1.6rem; text-align:center; margin-bottom:6px; color:var(--text-dark); }
.login-box .sub { text-align:center; color:var(--text-muted); font-size:13px; margin-bottom:26px; }

/* Toast */
.toast-wrap { position:fixed; bottom:22px; right:22px; z-index:9998; display:flex; flex-direction:column; gap:8px; }
.toast { padding:13px 18px; border-radius:var(--radius); font-size:13px; display:flex; align-items:center; gap:10px; min-width:260px; max-width:360px; animation:toastIn .3s ease; box-shadow:0 4px 20px rgba(0,0,0,.12); }
.toast-ok  { background:#f0fdf4; border:1px solid #a3cfaa; color:#2d6a32; }
.toast-err { background:#fef2f2; border:1px solid #f5aaaa; color:#b91c1c; }
.toast-info{ background:#fffbeb; border:1px solid var(--gold-border); color:var(--gold-dark); }
@keyframes toastIn { from { transform:translateX(100%); opacity:0; } to { transform:translateX(0); opacity:1; } }

/* Spinner */
.spinner { width:30px; height:30px; border:2px solid var(--border); border-top-color:var(--gold); border-radius:50%; animation:spin .8s linear infinite; margin:0 auto; }
@keyframes spin { to { transform:rotate(360deg); } }
.loading { text-align:center; padding:40px; color:var(--text-muted); }
.empty-state { text-align:center; padding:60px 20px; color:var(--text-muted); }
.empty-state .es-icon { font-size:3rem; margin-bottom:14px; opacity:.3; }

.text-c { text-align:center; }
.text-r { text-align:right; }
.mt-4   { margin-top:16px; }
.mt-8   { margin-top:32px; }
.gap-row{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media(max-width:1024px){
  .footer-grid    { grid-template-columns:1fr 1fr; }
  .stats-row      { grid-template-columns:repeat(2,1fr); }
  .about-grid     { gap:44px; }
}
@media(max-width:768px){
  section         { padding:60px 0; }
  .nav-links      { display:none; }
  .hamburger      { display:flex; }
  .about-grid     { grid-template-columns:1fr; }
  .about-img-wrap img { height:340px; }
  .gallery-grid   { grid-template-columns:repeat(2,1fr); }
  .gal-item:nth-child(1),
  .gal-item:nth-child(4) { grid-column:span 1; aspect-ratio:1; }
  .contact-grid   { grid-template-columns:1fr; }
  .footer-grid    { grid-template-columns:1fr; }
  .form-row       { grid-template-columns:1fr; }

  /* ── Booking mobile ── */
  .booking-panel  { padding:22px 14px; border-radius:10px; }
  .booking-steps-bar::before { display:none; }
  .booking-steps-bar { gap:0; justify-content:space-around; }
  .step-dot-wrap  { max-width:none; flex:none; }
  .step-dot       { width:34px; height:34px; font-size:.9rem; }
  .s-label        { font-size:9px; letter-spacing:.5px; }
  .opts-grid      { grid-template-columns:1fr 1fr; gap:10px; }
  .opt-card       { padding:16px 10px; }
  .opt-card h4    { font-size:.82rem; line-height:1.3; }
  .opt-price      { font-size:.95rem; }
  .opt-dur        { font-size:10px; }
  .slots-grid     { grid-template-columns:repeat(3,1fr); gap:6px; }
  .slot           { padding:9px 4px; font-size:12px; }

  /* ── Page banner mobile ── */
  .page-banner    { margin-top:0; min-height:200px; height:28vh; padding-bottom:28px; }
  .page-banner h1 { font-size:clamp(1.5rem,6vw,2.4rem); letter-spacing:.02em; }

  /* ── Admin ── */
  .admin-layout   { flex-direction:column; }
  .sidebar        { width:100%; height:auto; position:relative; }
  .admin-main     { margin-left:0; padding:18px; }
  .stats-row      { grid-template-columns:repeat(2,1fr); }
}

@media(max-width:480px){
  /* Hero */
  .hero h1        { font-size:2rem; }
  .hero-btns      { flex-direction:column; gap:10px; }
  .hero-content   { width:100%; max-width:100%; padding:0 20px; }
  .hero-label     { font-size:9px; letter-spacing:3px; }
  .hero-sub       { font-size:13px; margin-bottom:28px; }

  /* Gallery */
  .gallery-grid   { grid-template-columns:1fr; }
  .gal-item:nth-child(1),
  .gal-item:nth-child(4) { grid-column:auto; }

  /* Masonry */
  .masonry-grid   { column-count:1; }

  /* Services */
  .services-grid  { grid-template-columns:1fr; }
  .svc-card       { padding:24px 20px; }

  /* Stats */
  .stats-row      { grid-template-columns:1fr 1fr; }

  /* Booking */
  .opts-grid      { grid-template-columns:1fr 1fr; gap:8px; }
  .booking-steps-bar { gap:0; }
  .step-dot-wrap  { flex:1; }
  .step-dot       { width:30px; height:30px; font-size:.8rem; }

  /* Footer */
  .footer-grid    { grid-template-columns:1fr; }
  .footer-brand   { padding:20px; }

  /* About */
  .about-stats    { grid-template-columns:1fr 1fr; }
}
