/* ══════════════════════════════════════════════════════════
   COLLAGEN AESTHETICS — MAIN STYLESHEET
   Consolidated from all HTML demo pages
══════════════════════════════════════════════════════════ */

/* ── RESET & BASE ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Raleway',sans-serif;
  background:#0d0b09;
  color:#e8ddd0;
  overflow-x:hidden;
}
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; object-fit:cover; }
ul { list-style:none; }

/* ── CSS VARIABLES ── */
:root {
  --gold:#c9a461;   --gold-lt:#e2c88a;  --gold-dk:#9e7c3e;
  --d1:#0d0b09;     --d2:#131109;       --d3:#1c1810;       --d4:#242019;
  --cream:#f5efe6;  --txt:#e8ddd0;      --muted:#8a7a6a;    --faint:#4d4135;
}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4 { font-family:'Cormorant Garamond',serif; font-weight:400; line-height:1.15; }
h1 { font-size:clamp(2.6rem,5.5vw,5.2rem); }
h2 { font-size:clamp(1.9rem,3.5vw,3rem); }
h3 { font-size:clamp(1.2rem,2vw,1.65rem); }
h4 { font-size:clamp(1rem,1.5vw,1.25rem); }
em { font-style:italic; color:var(--gold-lt); }

/* ── UTILITY ── */
.container { max-width:1200px; margin:0 auto; padding:0 28px; }
.tag {
  display:inline-block;
  font-size:.68rem; font-weight:600;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--gold); margin-bottom:14px;
}
.rule {
  width:52px; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  margin:18px 0;
}
.rule.c { margin:18px auto; }
.sec-head { text-align:center; margin-bottom:60px; }
.sec-head h2 { color:var(--cream); }
.sec-head p { color:var(--muted); max-width:520px; margin:14px auto 0; font-size:.92rem; line-height:1.85; font-weight:300; }

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 36px;
  font-family:'Raleway',sans-serif; font-size:.78rem; font-weight:700;
  letter-spacing:2.5px; text-transform:uppercase;
  border:none; border-radius:2px; cursor:pointer;
  transition:all .3s ease; position:relative; overflow:hidden;
}
.btn-gold { background:linear-gradient(135deg,var(--gold),var(--gold-dk)); color:var(--d1); }
.btn-gold::after {
  content:''; position:absolute; inset:0;
  background:rgba(255,255,255,.12);
  transform:translateX(-110%); transition:transform .35s ease;
}
.btn-gold:hover::after { transform:translateX(0); }
.btn-gold:hover { transform:translateY(-2px); box-shadow:0 14px 42px rgba(201,164,97,.35); }
.btn-ghost { background:transparent; color:#fff; border:1px solid rgba(255,255,255,.55); }
.btn-ghost:hover { background:rgba(255,255,255,.08); border-color:#fff; transform:translateY(-2px); }
.btn-outline-gold { background:transparent; color:var(--gold); border:1px solid var(--gold); }
.btn-outline-gold:hover { background:var(--gold); color:var(--d1); transform:translateY(-2px); }

/* ══════════════════════════════════════════════════════════
   NAVBAR
══════════════════════════════════════════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  padding:14px 0; transition:all .4s ease;
}
.nav.stuck {
  background:rgba(10,9,7,.96);
  backdrop-filter:blur(14px);
  padding:8px 0;
  border-bottom:1px solid rgba(201,164,97,.15);
}
.nav-wrap {
  display:flex; align-items:center; justify-content:space-between;
  max-width:1200px; margin:0 auto; padding:0 28px;
}
.nav-logo { display:flex; align-items:center; }
.nav-logo img {
  height:70px; width:auto; object-fit:contain;
  transition:height .4s ease;
  filter:drop-shadow(0 2px 8px rgba(201,164,97,.2));
}
.nav.stuck .nav-logo img { height:48px; }

/* Desktop menu */
.nav-menu { display:flex; align-items:center; gap:34px; }
.nav-menu > li { position:relative; }
.nav-menu a {
  font-size:.76rem; font-weight:500; letter-spacing:1.5px; text-transform:uppercase;
  color:rgba(255,255,255,.65); transition:color .3s;
  position:relative; padding-bottom:3px; display:flex; align-items:center; gap:5px;
}
.nav-menu a::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:1px; background:var(--gold); transform:scaleX(0); transition:transform .3s;
}
.nav-menu a:hover, .nav-menu a.active { color:#fff; }
.nav-menu a:hover::after, .nav-menu a.active::after { transform:scaleX(1); }

.nav-arrow { font-size:.6rem; opacity:.5; transition:transform .3s; }
.has-dropdown:hover > a .nav-arrow { transform:rotate(180deg); }

/* ── LEVEL 2 DROPDOWN ── */
.dropdown-menu {
  position:absolute; top:calc(100% + 12px); left:50%;
  transform:translateX(-50%) translateY(-6px);
  background:rgba(10,9,7,.98); backdrop-filter:blur(18px);
  border:1px solid rgba(201,164,97,.15); border-radius:4px;
  min-width:240px; padding:6px 0;
  opacity:0; visibility:hidden;
  transition:opacity .25s ease, transform .25s ease, visibility .25s;
  z-index:999;
  max-height:400px; overflow-y:auto;
}
.has-dropdown:hover > .dropdown-menu {
  opacity:1; visibility:visible; transform:translateX(-50%) translateY(0);
}
.dropdown-menu > li { position:relative; }
.dropdown-menu > li > a {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 20px;
  font-size:.75rem; letter-spacing:.8px; text-transform:none;
  color:rgba(255,255,255,.7); transition:all .2s;
  font-weight:400; font-family:'Raleway',sans-serif;
}
.dropdown-menu > li > a:hover { color:var(--gold); background:rgba(201,164,97,.06); }
.dropdown-menu > li > a::after { display:none; }
.dropdown-menu > li.has-dropdown > a::before {
  content:'›'; color:var(--gold); font-size:.9rem; margin-left:auto; padding-left:8px;
}

/* Scrollbar */
.dropdown-menu::-webkit-scrollbar { width:3px; }
.dropdown-menu::-webkit-scrollbar-thumb { background:rgba(201,164,97,.2); border-radius:2px; }

/* ── LEVEL 3 FLYOUT (right side) ── */
.flyout-menu {
  position:absolute; top:0; left:100%;
  transform:translateX(6px);
  background:rgba(10,9,7,.98); backdrop-filter:blur(18px);
  border:1px solid rgba(201,164,97,.15); border-radius:4px;
  min-width:220px; padding:6px 0;
  opacity:0; visibility:hidden;
  transition:opacity .2s ease, transform .2s ease, visibility .2s;
  z-index:1000;
  max-height:360px; overflow-y:auto;
}
.dropdown-menu > li.has-dropdown:hover > .flyout-menu {
  opacity:1; visibility:visible; transform:translateX(4px);
}
.flyout-menu li a {
  display:block; padding:9px 18px;
  font-size:.74rem; letter-spacing:.5px; text-transform:none;
  color:rgba(255,255,255,.65); transition:all .2s;
  font-weight:400; font-family:'Raleway',sans-serif;
}
.flyout-menu li a:hover { color:var(--gold); background:rgba(201,164,97,.06); padding-left:24px; }
.flyout-menu li a::after { display:none; }

/* Flyout scrollbar */
.flyout-menu::-webkit-scrollbar { width:3px; }
.flyout-menu::-webkit-scrollbar-thumb { background:rgba(201,164,97,.2); border-radius:2px; }

.nav-book { margin-left:10px; }

/* ── HAMBURGER ── */
.hamburger {
  display:none; flex-direction:column; justify-content:center;
  gap:5px; cursor:pointer; padding:6px; background:none; border:none;
  width:36px; height:36px;
}
.hamburger span {
  display:block; width:22px; height:1.5px; background:var(--gold);
  transition:all .35s cubic-bezier(.4,0,.2,1); transform-origin:center;
}
.hamburger.is-open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.hamburger.is-open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.is-open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

/* ── MOBILE OVERLAY ── */
.mob-overlay {
  display:none; position:fixed; inset:0; z-index:790;
  background:rgba(0,0,0,.55); backdrop-filter:blur(2px);
  opacity:0; transition:opacity .35s ease;
}
.mob-overlay.is-open { display:block; opacity:1; }

/* ── MOBILE PANEL (slide from right) ── */
.mob-panel {
  position:fixed; top:0; right:0; bottom:0; z-index:800;
  width:min(360px, 90vw);
  background:var(--d1);
  border-left:1px solid rgba(201,164,97,.12);
  display:flex; flex-direction:column;
  transform:translateX(100%);
  transition:transform .38s cubic-bezier(.4,0,.2,1);
  overflow:hidden;
}
.mob-panel.is-open { transform:translateX(0); }

/* Panel Header */
.mob-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 24px;
  border-bottom:1px solid rgba(201,164,97,.08);
  flex-shrink:0;
}
.mob-logo img { height:56px; width:auto; object-fit:contain; }
.mob-logo .custom-logo { height:56px; width:auto; }

.mob-close {
  width:36px; height:36px; background:rgba(201,164,97,.08);
  border:1px solid rgba(201,164,97,.2); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; flex-shrink:0; padding:0;
}
.mob-close span {
  display:block; width:14px; height:1.5px; background:var(--gold);
  transform-origin:center; transition:transform .25s;
}
.mob-close span:nth-child(1) { transform:rotate(45deg) translate(0.5px, 0.5px); }
.mob-close span:nth-child(2) { transform:rotate(-45deg) translate(0.5px, -0.5px); }

/* Nav list */
.mob-nav {
  flex:1; overflow-y:auto; padding:10px 0;
  scrollbar-width:thin; scrollbar-color:rgba(201,164,97,.15) transparent;
}
.mob-nav::-webkit-scrollbar { width:3px; }
.mob-nav::-webkit-scrollbar-thumb { background:rgba(201,164,97,.2); border-radius:2px; }

.mob-nav ul { list-style:none; padding:0; margin:0; }
.mob-nav > ul > li { border-bottom:1px solid rgba(201,164,97,.06); }

.mob-nav > ul > li > a,
.mob-item-row > a {
  display:block; padding:16px 24px;
  font-family:'Cormorant Garamond',serif;
  font-size:1.3rem; font-weight:400; letter-spacing:1.5px;
  color:var(--cream); transition:color .25s;
  text-decoration:none;
}
.mob-nav > ul > li > a:hover,
.mob-item-row > a:hover { color:var(--gold); }
.mob-nav > ul > li.mob-active > a,
.mob-nav > ul > li.mob-active .mob-item-row > a { color:var(--gold); }

/* Active indicator bar */
.mob-nav > ul > li.mob-active { border-left:2px solid var(--gold); }

/* Services accordion row */
.mob-item-row {
  display:flex; align-items:center; justify-content:space-between;
  padding-right:16px;
}
.mob-item-row > a { flex:1; padding-right:0; }

.mob-acc-toggle {
  width:32px; height:32px; background:none; border:none;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--gold); flex-shrink:0;
  transition:transform .3s;
}
.mob-acc-toggle.is-open { transform:rotate(180deg); }

/* Accordion body */
.mob-acc-body {
  max-height:0; overflow:hidden;
  transition:max-height .4s cubic-bezier(.4,0,.2,1);
}
.mob-acc-body.is-open { max-height:75vh; overflow-y:auto; }

.mob-acc-inner {
  padding:8px 0 16px;
  background:var(--d2);
}

.mob-cat-label {
  padding:10px 24px 6px;
  font-size:.6rem; letter-spacing:3px; text-transform:uppercase;
  color:var(--gold); font-weight:700; font-family:'Raleway',sans-serif;
}

.mob-service-link {
  display:flex; align-items:center; gap:10px;
  padding:10px 24px;
  font-size:.82rem; font-weight:400; letter-spacing:.5px;
  color:var(--muted); transition:all .2s; text-decoration:none;
  font-family:'Raleway',sans-serif;
}
.mob-service-link:hover { color:var(--cream); background:rgba(201,164,97,.04); padding-left:30px; }

.mob-service-icon {
  font-size:1rem; flex-shrink:0; width:20px; text-align:center;
}

.mob-service-all {
  display:block; margin:12px 24px 0;
  padding:9px 16px;
  font-size:.7rem; letter-spacing:2px; text-transform:uppercase;
  color:var(--gold); font-weight:700; font-family:'Raleway',sans-serif;
  border:1px solid rgba(201,164,97,.25); border-radius:2px;
  text-align:center; text-decoration:none; transition:all .25s;
}
.mob-service-all:hover { background:var(--gold); color:var(--d1); }

/* CTA */
.mob-cta {
  padding:16px 24px;
  border-top:1px solid rgba(201,164,97,.08);
  flex-shrink:0;
}
.mob-book-btn {
  width:100%; justify-content:center;
  padding:14px; font-size:.78rem;
}

/* Contact strip */
.mob-contact-strip {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 24px;
  background:var(--d2);
  border-top:1px solid rgba(201,164,97,.06);
  flex-shrink:0;
}
.mob-contact-strip > a {
  display:flex; align-items:center; gap:8px;
  font-size:.75rem; color:var(--muted); letter-spacing:.5px;
  font-family:'Raleway',sans-serif; text-decoration:none;
  transition:color .2s;
}
.mob-contact-strip > a:hover { color:var(--gold); }
.mob-contact-strip svg { color:var(--gold); flex-shrink:0; }

.mob-socials { display:flex; gap:8px; }
.mob-socials a {
  width:30px; height:30px;
  border:1px solid rgba(201,164,97,.2); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:.65rem; font-weight:700; color:var(--muted);
  text-decoration:none; transition:all .25s; font-family:'Raleway',sans-serif;
}
.mob-socials a:hover { border-color:var(--gold); color:var(--gold); }

/* ══════════════════════════════════════════════════════════
   PAGE HERO
══════════════════════════════════════════════════════════ */
.page-hero {
  padding:160px 0 90px;
  background:var(--d2); position:relative; overflow:hidden; text-align:center;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(201,164,97,.04) 0%,transparent 60%);
}
.page-hero-bg {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; opacity:.18;
}
.page-hero-content { position:relative; z-index:2; }
.page-hero h1 { color:var(--cream); font-size:clamp(2.4rem,5vw,4rem); }
.page-hero p {
  color:var(--muted); font-size:1rem; max-width:540px;
  margin:16px auto 0; line-height:1.85; font-weight:300;
}
.breadcrumb {
  display:flex; align-items:center; justify-content:center;
  gap:10px; margin-bottom:20px;
  font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--muted);
}
.breadcrumb a { color:var(--gold); transition:color .3s; }
.breadcrumb a:hover { color:var(--gold-lt); }
.breadcrumb span { color:var(--faint); }

/* ══════════════════════════════════════════════════════════
   MARQUEE
══════════════════════════════════════════════════════════ */
.marquee-strip {
  background:var(--gold); padding:13px 0;
  overflow:hidden; display:flex;
}
.marquee-track {
  display:flex; gap:0;
  animation:marq 22s linear infinite; white-space:nowrap;
}
.marquee-track span {
  font-size:.7rem; font-weight:700; letter-spacing:3px;
  text-transform:uppercase; color:var(--d1); padding:0 30px;
}
.marquee-track .sep { color:rgba(0,0,0,.3); }
@keyframes marq { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ══════════════════════════════════════════════════════════
   SCROLL REVEAL
══════════════════════════════════════════════════════════ */
.rv  { opacity:0; transform:translateY(28px); transition:opacity .7s ease,transform .7s ease; }
.rv.in  { opacity:1; transform:translateY(0); }
.rv-l { opacity:0; transform:translateX(-28px); transition:opacity .7s ease,transform .7s ease; }
.rv-l.in { opacity:1; transform:translateX(0); }
.rv-r { opacity:0; transform:translateX(28px); transition:opacity .7s ease,transform .7s ease; }
.rv-r.in { opacity:1; transform:translateX(0); }

/* ══════════════════════════════════════════════════════════
   HERO SLIDER
══════════════════════════════════════════════════════════ */
.hero { position:relative; width:100%; height:100vh; min-height:620px; overflow:hidden; }
.slides { position:relative; width:100%; height:100%; }
.slide { position:absolute; inset:0; opacity:0; transition:opacity 1.2s ease; display:flex; align-items:center; }
.slide.active { opacity:1; z-index:2; }
.slide-bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center top; transition:transform 8s ease; }
.slide.active .slide-bg { transform:scale(1.05); }
.slide::after {
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(110deg,rgba(10,8,6,.85) 0%,rgba(10,8,6,.52) 52%,rgba(10,8,6,.18) 100%);
}
.slide-content { position:relative; z-index:3; max-width:1200px; margin:0 auto; padding:0 28px; width:100%; }
.slide-tag {
  display:inline-flex; align-items:center; gap:10px;
  padding:7px 18px; border:1px solid rgba(201,164,97,.4); border-radius:100px;
  margin-bottom:26px; font-size:.68rem; letter-spacing:3.5px; text-transform:uppercase;
  color:var(--gold-lt); font-weight:500;
  opacity:0; transform:translateY(20px); transition:all .8s ease .3s;
}
.slide-tag::before { content:""; width:5px; height:5px; border-radius:50%; background:var(--gold); flex-shrink:0; }
.slide h1 { color:#fff; max-width:700px; opacity:0; transform:translateY(28px); transition:all .9s ease .5s; }
.slide-sub {
  color:rgba(255,255,255,.72); font-size:1.02rem; font-weight:300;
  line-height:1.8; max-width:500px; margin:20px 0 38px;
  opacity:0; transform:translateY(20px); transition:all .85s ease .7s;
}
.slide-btns { display:flex; gap:14px; flex-wrap:wrap; opacity:0; transform:translateY(16px); transition:all .8s ease .9s; }
.slide.active .slide-tag,
.slide.active h1,
.slide.active .slide-sub,
.slide.active .slide-btns { opacity:1; transform:translateY(0); }

/* Slider controls */
.s-arrow {
  position:absolute; top:50%; z-index:10; width:54px; height:54px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.22);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  cursor:pointer; transform:translateY(-50%); transition:all .3s;
  color:#fff; font-size:1.1rem; backdrop-filter:blur(6px);
}
.s-arrow:hover { background:var(--gold); border-color:var(--gold); color:var(--d1); }
.s-arrow.prev { left:28px; }
.s-arrow.next { right:28px; }
.s-dots {
  position:absolute; bottom:38px; left:50%; transform:translateX(-50%);
  z-index:10; display:flex; gap:10px; align-items:center;
}
.s-dot { width:7px; height:7px; border-radius:4px; background:rgba(255,255,255,.35); cursor:pointer; transition:all .35s; }
.s-dot.active { width:28px; background:var(--gold); }
.s-counter { position:absolute; bottom:40px; right:36px; z-index:10; font-size:.7rem; letter-spacing:2px; color:rgba(255,255,255,.4); }
.s-counter span { color:var(--gold); }
.s-progress { position:absolute; bottom:0; left:0; z-index:10; height:2px; background:var(--gold); animation:sprg 5s linear infinite; }
@keyframes sprg { from{width:0} to{width:100%} }
.s-thumbs { position:absolute; bottom:36px; right:100px; z-index:10; display:flex; gap:8px; }
.s-thumb { width:70px; height:46px; border-radius:2px; overflow:hidden; cursor:pointer; border:2px solid transparent; opacity:.55; transition:all .3s; }
.s-thumb.active { border-color:var(--gold); opacity:1; }
.s-thumb img { width:100%; height:100%; object-fit:cover; }

/* ══════════════════════════════════════════════════════════
   HOME — SERVICES GRID
══════════════════════════════════════════════════════════ */
.services { padding:110px 0; background:var(--d2); }
.srv-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.srv-card { position:relative; overflow:hidden; border-radius:3px; cursor:pointer; }
.srv-card img { width:100%; height:340px; transition:transform .6s ease; }
.srv-card:hover img { transform:scale(1.06); }
.srv-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(10,8,6,.93) 0%,rgba(10,8,6,.28) 55%,transparent 100%);
  transition:background .4s;
}
.srv-card:hover .srv-overlay {
  background:linear-gradient(to top,rgba(10,8,6,.97) 0%,rgba(10,8,6,.55) 65%,rgba(10,8,6,.1) 100%);
}
.srv-body { position:absolute; bottom:0; left:0; right:0; padding:26px 28px 30px; }
.srv-icon {
  width:42px; height:42px; border:1px solid rgba(201,164,97,.3); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; margin-bottom:12px; transition:all .3s;
}
.srv-card:hover .srv-icon { background:var(--gold); border-color:var(--gold); }
.srv-body h3 { color:#fff; font-size:1.35rem; margin-bottom:6px; }
.srv-body p { color:rgba(255,255,255,.6); font-size:.82rem; line-height:1.7; font-weight:300; max-height:0; overflow:hidden; transition:max-height .4s ease,opacity .4s; opacity:0; }
.srv-card:hover .srv-body p { max-height:80px; opacity:1; }
.srv-link {
  display:inline-flex; align-items:center; gap:7px;
  margin-top:14px; font-size:.72rem; letter-spacing:2px;
  text-transform:uppercase; color:var(--gold); font-weight:600;
  opacity:0; transform:translateY(8px); transition:all .35s ease .1s;
}
.srv-card:hover .srv-link { opacity:1; transform:translateY(0); }

/* ══════════════════════════════════════════════════════════
   HOME — ABOUT SECTION
══════════════════════════════════════════════════════════ */
.about { padding:110px 0; background:var(--d1); }
.ab-grid { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.ab-imgs { position:relative; }
.ab-img-main { width:100%; height:560px; border-radius:3px; overflow:hidden; position:relative; }
.ab-img-main img { width:100%; height:100%; object-fit:cover; }
.ab-img-main::after { content:""; position:absolute; inset:0; background:linear-gradient(135deg,rgba(10,8,6,.12),transparent); }
.ab-img-sm { position:absolute; bottom:-30px; right:-30px; width:210px; height:260px; border-radius:3px; overflow:hidden; border:6px solid var(--d1); }
.ab-img-sm img { width:100%; height:100%; object-fit:cover; }
.ab-badge {
  position:absolute; top:28px; left:-24px;
  background:var(--gold); padding:18px 22px; border-radius:3px;
  text-align:center; box-shadow:0 12px 40px rgba(0,0,0,.5);
}
.ab-badge strong { display:block; font-family:'Cormorant Garamond',serif; font-size:2.4rem; color:var(--d1); line-height:1; }
.ab-badge span { font-size:.62rem; letter-spacing:2px; text-transform:uppercase; color:rgba(0,0,0,.65); font-weight:700; }
.ab-txt h2 { color:var(--cream); margin-bottom:20px; }
.ab-txt p { color:var(--muted); font-size:.92rem; line-height:1.9; font-weight:300; margin-bottom:16px; }
.ab-quote {
  border-left:2px solid var(--gold); padding:18px 24px;
  margin:28px 0; background:rgba(201,164,97,.04); border-radius:0 3px 3px 0;
}
.ab-quote p { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-style:italic; color:var(--cream); line-height:1.65; margin:0; }
.ab-quote cite { display:block; margin-top:10px; font-size:.7rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-style:normal; font-family:'Raleway',sans-serif; }
.ab-feats { display:flex; flex-direction:column; gap:12px; margin:28px 0 36px; }
.ab-feat { display:flex; align-items:flex-start; gap:12px; }
.ab-feat-dot { width:20px; height:20px; flex-shrink:0; background:linear-gradient(135deg,var(--gold),var(--gold-dk)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.6rem; color:var(--d1); margin-top:2px; }
.ab-feat span { font-size:.87rem; color:var(--txt); line-height:1.65; font-weight:300; }

/* ══════════════════════════════════════════════════════════
   HOME — BEFORE & AFTER
══════════════════════════════════════════════════════════ */
.results { padding:110px 0; background:var(--d3); }
.res-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.res-card { border-radius:3px; overflow:hidden; border:1px solid rgba(201,164,97,.1); transition:border-color .3s,transform .3s; }
.res-card:hover { border-color:rgba(201,164,97,.3); transform:translateY(-4px); }
.res-split { display:grid; grid-template-columns:1fr 1fr; }
.res-side { position:relative; height:240px; }
.res-side img { width:100%; height:100%; object-fit:cover; object-position:center top; }
.res-lbl { position:absolute; top:10px; left:10px; font-size:.62rem; letter-spacing:2px; text-transform:uppercase; font-weight:700; padding:4px 10px; border-radius:2px; }
.lbl-before { background:rgba(10,8,6,.75); color:var(--muted); }
.lbl-after  { background:var(--gold); color:var(--d1); }
.res-info { padding:20px 22px 24px; background:var(--d4); }
.res-tag { font-size:.62rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:600; margin-bottom:8px; }
.res-info h4 { color:var(--cream); font-size:1.05rem; margin-bottom:5px; }
.res-info p { color:var(--muted); font-size:.8rem; line-height:1.65; font-weight:300; }

/* ══════════════════════════════════════════════════════════
   STATS BAR
══════════════════════════════════════════════════════════ */
.stats-bar {
  padding:70px 0; background:var(--d1);
  border-top:1px solid rgba(201,164,97,.1);
  border-bottom:1px solid rgba(201,164,97,.1);
}
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); }
.stat-item { text-align:center; padding:30px 20px; border-right:1px solid rgba(201,164,97,.1); }
.stat-item:last-child { border-right:none; }
.stat-num { font-family:'Cormorant Garamond',serif; font-size:3.8rem; color:var(--gold); line-height:1; }
.stat-label { font-size:.7rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--muted); margin-top:8px; }

/* ══════════════════════════════════════════════════════════
   TESTIMONIALS
══════════════════════════════════════════════════════════ */
.testi { padding:110px 0; background:var(--d2); }
.testi-track {
  display:flex; gap:22px;
  overflow-x:auto; scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch; scrollbar-width:none;
  padding-bottom:6px;
}
.testi-track::-webkit-scrollbar { display:none; }
.tc {
  min-width:360px; scroll-snap-align:start;
  background:var(--d3); border:1px solid rgba(201,164,97,.1);
  border-radius:3px; padding:36px 32px; flex-shrink:0; transition:border-color .3s;
}
.tc:hover { border-color:rgba(201,164,97,.28); }
.tc-stars { display:flex; gap:4px; margin-bottom:18px; }
.tc-stars span { color:var(--gold); font-size:.9rem; }
.tc-text { font-family:'Cormorant Garamond',serif; font-size:1.18rem; font-style:italic; line-height:1.75; color:var(--txt); margin-bottom:26px; }
.tc-author { display:flex; align-items:center; gap:13px; }
.tc-av {
  width:44px; height:44px; border-radius:50%; overflow:hidden;
  background:linear-gradient(135deg,var(--gold-dk),#3a2a14);
  display:flex; align-items:center; justify-content:center;
  font-family:'Cormorant Garamond',serif; font-size:1.1rem; color:var(--gold-lt); flex-shrink:0;
}
.tc-av img { width:100%; height:100%; object-fit:cover; }
.tc-name { font-weight:600; font-size:.84rem; color:var(--cream); }
.tc-role { font-size:.7rem; color:var(--muted); margin-top:2px; }
.tc-dots { display:flex; justify-content:center; gap:8px; margin-top:36px; }
.tc-dot { width:6px; height:6px; border-radius:3px; background:var(--faint); cursor:pointer; transition:all .3s; }
.tc-dot.active { width:24px; background:var(--gold); }

/* ══════════════════════════════════════════════════════════
   WHY US
══════════════════════════════════════════════════════════ */
.why { padding:110px 0; background:var(--d3); position:relative; overflow:hidden; }
.why::before {
  content:"EXCELLENCE"; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family:'Cormorant Garamond',serif; font-weight:700;
  font-size:clamp(60px,12vw,160px); letter-spacing:8px;
  color:rgba(201,164,97,.03); white-space:nowrap; pointer-events:none;
}
.why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(201,164,97,.08); }
.why-item { background:var(--d3); padding:40px 28px; text-align:center; transition:background .3s; }
.why-item:hover { background:var(--d4); }
.why-num { font-family:'Cormorant Garamond',serif; font-size:3.4rem; color:rgba(201,164,97,.13); line-height:1; margin-bottom:18px; font-weight:700; }
.why-icon { font-size:1.75rem; margin-bottom:14px; }
.why-item h4 { color:var(--gold); font-size:1.1rem; margin-bottom:10px; }
.why-item p { color:var(--muted); font-size:.83rem; line-height:1.75; font-weight:300; }

/* ══════════════════════════════════════════════════════════
   GALLERY (with lightbox)
══════════════════════════════════════════════════════════ */
.gallery { padding:110px 0; background:var(--d1); }
.gal-grid { display:grid; grid-template-columns:repeat(4,1fr); grid-template-rows:auto auto; gap:10px; }
.gal-item { overflow:hidden; border-radius:3px; position:relative; cursor:pointer; }
.gal-item:nth-child(1) { grid-column:span 2; grid-row:span 2; }
.gal-item img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.gal-item:hover img { transform:scale(1.07); }
.gal-item:nth-child(1) img { height:460px; }
.gal-item:not(:nth-child(1)) img { height:225px; }
.gal-overlay { position:absolute; inset:0; background:rgba(10,8,6,0); display:flex; align-items:center; justify-content:center; transition:background .3s; }
.gal-item:hover .gal-overlay { background:rgba(10,8,6,.45); }
.gal-plus { color:#fff; font-size:1.8rem; opacity:0; transition:opacity .3s; }
.gal-item:hover .gal-plus { opacity:1; }

/* Lightbox */
.lightbox {
  display:none; position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,.95); align-items:center; justify-content:center;
}
.lightbox.open { display:flex; }
.lightbox-img { max-width:90vw; max-height:88vh; object-fit:contain; border-radius:3px; }
.lightbox-close {
  position:absolute; top:20px; right:24px;
  font-size:2rem; color:#fff; cursor:pointer; background:none; border:none;
  opacity:.7; transition:opacity .2s;
}
.lightbox-close:hover { opacity:1; }
.lightbox-prev, .lightbox-next {
  position:absolute; top:50%; transform:translateY(-50%);
  font-size:2rem; color:#fff; cursor:pointer; background:none; border:none;
  opacity:.7; transition:opacity .2s;
}
.lightbox-prev { left:24px; }
.lightbox-next { right:24px; }
.lightbox-prev:hover, .lightbox-next:hover { opacity:1; }
.lightbox-counter { position:absolute; bottom:20px; left:50%; transform:translateX(-50%); font-size:.75rem; letter-spacing:2px; color:rgba(255,255,255,.45); }

/* ══════════════════════════════════════════════════════════
   CTA BANNER
══════════════════════════════════════════════════════════ */
.cta-banner { position:relative; padding:120px 0; overflow:hidden; text-align:center; }
.cta-banner img.cta-bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.cta-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(10,8,6,.9) 0%,rgba(10,8,6,.7) 100%); }
.cta-banner-content { position:relative; z-index:2; }
.cta-banner h2 { color:#fff; max-width:720px; margin:0 auto 18px; }
.cta-banner p { color:rgba(255,255,255,.7); max-width:500px; margin:0 auto 44px; font-size:.95rem; line-height:1.85; font-weight:300; }
.cta-btns { display:flex; justify-content:center; gap:16px; flex-wrap:wrap; }
.cta-trust { display:flex; justify-content:center; gap:30px; margin-top:44px; flex-wrap:wrap; }
.cta-trust-item { display:flex; align-items:center; gap:8px; font-size:.72rem; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.5); }
.cta-trust-item em { color:var(--gold); font-style:normal; }

/* ══════════════════════════════════════════════════════════
   ABOUT PAGE
══════════════════════════════════════════════════════════ */
.about-story { padding:100px 0; background:var(--d1); }
.story-grid { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.story-img { border-radius:3px; overflow:hidden; position:relative; }
.story-img img { width:100%; height:560px; object-fit:cover; }
.story-badge {
  position:absolute; bottom:30px; left:-20px;
  background:var(--gold); padding:20px 24px; border-radius:3px;
  text-align:center; box-shadow:0 12px 40px rgba(0,0,0,.5);
}
.story-badge strong { display:block; font-family:'Cormorant Garamond',serif; font-size:2.8rem; color:var(--d1); line-height:1; }
.story-badge span { font-size:.62rem; letter-spacing:2px; text-transform:uppercase; color:rgba(0,0,0,.65); font-weight:700; }
.story-txt h2 { color:var(--cream); margin-bottom:20px; }
.story-txt p { color:var(--muted); font-size:.92rem; line-height:1.9; font-weight:300; margin-bottom:16px; }
.story-quote { border-left:2px solid var(--gold); padding:18px 24px; margin:28px 0; background:rgba(201,164,97,.04); border-radius:0 3px 3px 0; }
.story-quote p { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-style:italic; color:var(--cream); line-height:1.65; margin:0; }
.story-quote cite { display:block; margin-top:10px; font-size:.7rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-style:normal; font-family:'Raleway',sans-serif; }

.values { padding:100px 0; background:var(--d2); }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.value-card { padding:40px 32px; border:1px solid rgba(201,164,97,.1); border-radius:3px; transition:border-color .3s,transform .3s; background:var(--d3); }
.value-card:hover { border-color:rgba(201,164,97,.3); transform:translateY(-6px); }
.value-icon { font-size:2rem; margin-bottom:18px; }
.value-card h3 { color:var(--gold); font-size:1.25rem; margin-bottom:12px; }
.value-card p { color:var(--muted); font-size:.88rem; line-height:1.8; font-weight:300; }

.mission { padding:100px 0; background:var(--d3); }
.mission-inner { max-width:800px; margin:0 auto; text-align:center; }
.mission-inner h2 { color:var(--cream); margin-bottom:24px; }
.mission-inner p { color:var(--muted); font-size:1rem; line-height:1.9; font-weight:300; margin-bottom:16px; }
.feats-list { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:40px; text-align:left; }
.feat-item { display:flex; align-items:flex-start; gap:12px; padding:20px; background:var(--d4); border-radius:3px; }
.feat-dot { width:22px; height:22px; flex-shrink:0; background:linear-gradient(135deg,var(--gold),var(--gold-dk)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.65rem; color:var(--d1); margin-top:1px; }
.feat-item span { font-size:.87rem; color:var(--txt); line-height:1.65; font-weight:300; }

/* ══════════════════════════════════════════════════════════
   TAXONOMY — SERVICE CATEGORY PAGE
══════════════════════════════════════════════════════════ */
.tax-stats { margin-bottom:40px; }
.tax-stats-inner {
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px;
  padding:16px 24px; background:var(--d3);
  border:1px solid rgba(201,164,97,.1); border-radius:3px;
}
.tax-count { font-size:.82rem; color:var(--muted); }
.tax-count strong { color:var(--gold); font-size:1.1rem; font-family:'Cormorant Garamond',serif; margin-right:4px; }
.tax-breadcrumb {
  display:flex; align-items:center; gap:8px;
  font-size:.72rem; letter-spacing:1px; text-transform:uppercase; color:var(--faint);
}
.tax-breadcrumb a { color:var(--gold); transition:color .2s; }
.tax-breadcrumb a:hover { color:var(--gold-lt); }

.srv-price-badge {
  position:absolute; top:14px; right:14px; z-index:2;
  background:var(--gold); color:var(--d1);
  font-weight:700; font-size:.82rem; padding:4px 12px;
  border-radius:2px; letter-spacing:1px;
}
.srv-addon-note {
  font-size:.72rem; color:var(--gold); margin-top:10px; letter-spacing:1px;
}

.tax-back { text-align:center; margin-top:50px; }
.tax-empty { text-align:center; padding:60px 0; color:var(--muted); font-size:1rem; }

/* Other categories strip */
.tax-other-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(200px,1fr)); gap:14px;
}
.tax-other-card {
  display:flex; flex-direction:column; gap:6px;
  padding:20px 22px; background:var(--d4);
  border:1px solid rgba(201,164,97,.1); border-radius:3px;
  text-decoration:none; transition:all .3s; position:relative;
}
.tax-other-card:hover { border-color:rgba(201,164,97,.35); transform:translateY(-3px); }
.tax-other-name { font-size:.9rem; color:var(--cream); line-height:1.4; font-family:'Cormorant Garamond',serif; }
.tax-other-count { font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold); font-weight:600; }
.tax-other-arrow { position:absolute; bottom:18px; right:18px; color:var(--gold); font-size:.9rem; transition:transform .2s; }
.tax-other-card:hover .tax-other-arrow { transform:translateX(4px); }

/* ══════════════════════════════════════════════════════════
   SERVICES LISTING PAGE
══════════════════════════════════════════════════════════ */
.srv-section { padding:100px 0; background:var(--d2); }
.srv-full-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.srv-full-card {
  position:relative; border-radius:3px; overflow:hidden;
  background:var(--d3); border:1px solid rgba(201,164,97,.08);
  transition:border-color .3s,transform .3s; cursor:pointer;
}
.srv-full-card:hover { border-color:rgba(201,164,97,.3); transform:translateY(-6px); }
.srv-full-card-img { position:relative; overflow:hidden; height:240px; }
.srv-full-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.srv-full-card:hover .srv-full-card-img img { transform:scale(1.07); }
.srv-full-card-img::after { content:""; position:absolute; inset:0; background:linear-gradient(to top,rgba(10,8,6,.5),transparent); }
.srv-card-icon { position:absolute; bottom:14px; left:18px; z-index:2; font-size:1.5rem; }
.srv-full-card-body { padding:24px 26px 28px; }
.srv-full-card-body h3 { color:var(--cream); font-size:1.25rem; margin-bottom:8px; }
.srv-full-card-body p { color:var(--muted); font-size:.84rem; line-height:1.75; font-weight:300; margin-bottom:18px; }
.srv-meta { display:flex; align-items:center; justify-content:space-between; }
.srv-duration { font-size:.72rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--faint); }
.srv-cta-link { font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:600; transition:color .3s; }
.srv-cta-link:hover { color:var(--gold-lt); }

/* ══════════════════════════════════════════════════════════
   SERVICE DETAIL PAGE
══════════════════════════════════════════════════════════ */
.sd-hero { position:relative; min-height:85vh; display:flex; align-items:center; overflow:hidden; }
.sd-hero-bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center top; }
.sd-hero::after { content:""; position:absolute; inset:0; background:linear-gradient(100deg,rgba(8,6,4,.92) 0%,rgba(8,6,4,.7) 50%,rgba(8,6,4,.35) 100%); }
.sd-hero-content { position:relative; z-index:2; padding:160px 0 100px; width:100%; }
.sd-breadcrumb { display:flex; align-items:center; gap:8px; margin-bottom:28px; font-size:.7rem; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.45); }
.sd-breadcrumb a { color:var(--gold); transition:color .3s; }
.sd-hero-icon { font-size:2.8rem; margin-bottom:16px; }
.sd-hero h1 { color:#fff; margin-bottom:14px; max-width:700px; }
.sd-hero-tagline { font-size:1.05rem; color:rgba(255,255,255,.72); max-width:560px; line-height:1.8; font-weight:300; margin-bottom:32px; }
.sd-hero-meta { display:flex; align-items:center; gap:24px; flex-wrap:wrap; margin-bottom:36px; }
.sd-hero-meta span { display:inline-flex; align-items:center; gap:7px; font-size:.75rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold); font-weight:600; padding:8px 16px; border:1px solid rgba(201,164,97,.3); border-radius:100px; }
.sd-hero-btns { display:flex; gap:14px; flex-wrap:wrap; }

.sd-what { padding:100px 0; background:var(--d1); }
.sd-what-grid { display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center; }
.sd-what-img { border-radius:4px; overflow:hidden; position:relative; }
.sd-what-img img { width:100%; height:480px; object-fit:cover; transition:transform .6s ease; }
.sd-what-img:hover img { transform:scale(1.04); }
.sd-what-img-badge { position:absolute; bottom:24px; left:24px; background:var(--gold); padding:14px 20px; border-radius:3px; }
.sd-what-img-badge strong { display:block; font-family:'Cormorant Garamond',serif; font-size:1.8rem; color:var(--d1); line-height:1; }
.sd-what-img-badge span { font-size:.62rem; letter-spacing:2px; text-transform:uppercase; color:rgba(0,0,0,.6); font-weight:700; }
.sd-what-txt h2 { color:var(--cream); margin-bottom:20px; }
.sd-what-txt p { color:var(--muted); font-size:.93rem; line-height:1.9; font-weight:300; margin-bottom:16px; }

.sd-how { padding:100px 0; background:var(--d2); }
.sd-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:20px; }
.sd-step { padding:32px 26px; background:var(--d3); border:1px solid rgba(201,164,97,.08); border-radius:3px; position:relative; transition:border-color .3s,transform .3s; }
.sd-step:hover { border-color:rgba(201,164,97,.3); transform:translateY(-5px); }
.sd-step-num { font-family:'Cormorant Garamond',serif; font-size:3.5rem; color:rgba(201,164,97,.15); line-height:1; margin-bottom:16px; font-weight:700; }
.sd-step h4 { color:var(--gold); font-size:1.05rem; margin-bottom:10px; }
.sd-step p { color:var(--muted); font-size:.84rem; line-height:1.75; font-weight:300; }

.sd-benefits-sec { padding:100px 0; background:var(--d3); }
.sd-ben-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:20px; }
.sd-ben-card { padding:30px 26px; background:var(--d4); border:1px solid rgba(201,164,97,.08); border-radius:3px; display:flex; align-items:flex-start; gap:14px; transition:border-color .3s; }
.sd-ben-card:hover { border-color:rgba(201,164,97,.25); }
.sd-ben-dot { width:28px; height:28px; flex-shrink:0; background:linear-gradient(135deg,var(--gold),var(--gold-dk)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.7rem; color:var(--d1); font-weight:700; margin-top:2px; }
.sd-ben-card span { font-size:.9rem; color:var(--txt); line-height:1.65; font-weight:300; }

.sd-suitable { padding:80px 0; background:var(--d1); }
.sd-suitable-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.sd-suitable-img { border-radius:4px; overflow:hidden; }
.sd-suitable-img img { width:100%; height:420px; object-fit:cover; }
.sd-suitable-list { list-style:none; display:flex; flex-direction:column; gap:14px; margin:24px 0 36px; }
.sd-suitable-list li { display:flex; align-items:center; gap:12px; font-size:.92rem; color:var(--txt); font-weight:300; }
.sd-suitable-list li::before { content:"✓"; width:22px; height:22px; flex-shrink:0; background:linear-gradient(135deg,var(--gold),var(--gold-dk)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.65rem; color:var(--d1); font-weight:700; }

.sd-faq { padding:100px 0; background:var(--d2); }
.faq-list { max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.faq-item { border:1px solid rgba(201,164,97,.1); border-radius:3px; overflow:hidden; }
.faq-q { display:flex; align-items:center; justify-content:space-between; padding:22px 26px; cursor:pointer; font-size:.95rem; color:var(--cream); font-weight:500; transition:background .3s; gap:16px; }
.faq-q:hover { background:rgba(201,164,97,.04); }
.faq-q.open { background:rgba(201,164,97,.06); color:var(--gold-lt); }
.faq-icon { font-size:1.2rem; color:var(--gold); flex-shrink:0; transition:transform .3s; }
.faq-q.open .faq-icon { transform:rotate(45deg); }
.faq-a { display:none; padding:0 26px 22px; color:var(--muted); font-size:.88rem; line-height:1.8; font-weight:300; }
.faq-a.open { display:block; }

.sd-related { padding:100px 0; background:var(--d3); }
.rel-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.rel-card { position:relative; overflow:hidden; border-radius:3px; cursor:pointer; border:1px solid rgba(201,164,97,.08); transition:border-color .3s,transform .3s; }
.rel-card:hover { border-color:rgba(201,164,97,.3); transform:translateY(-5px); }
.rel-card-img { overflow:hidden; height:220px; }
.rel-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.rel-card:hover .rel-card-img img { transform:scale(1.06); }
.rel-card-body { padding:22px 24px 26px; background:var(--d4); }
.rel-card-icon { font-size:1.3rem; margin-bottom:10px; }
.rel-card-body h3 { color:var(--cream); font-size:1.15rem; margin-bottom:6px; }
.rel-card-body p { color:var(--muted); font-size:.82rem; line-height:1.65; font-weight:300; margin-bottom:14px; }
.rel-card-link { font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:600; transition:color .3s; }
.rel-card-link:hover { color:var(--gold-lt); }

.sd-nav { padding:60px 0; background:var(--d1); border-top:1px solid rgba(201,164,97,.08); }
.sd-nav-inner { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.sd-nav-btn { display:flex; align-items:center; gap:12px; padding:16px 24px; border:1px solid rgba(201,164,97,.2); border-radius:2px; transition:all .3s; }
.sd-nav-btn:hover { border-color:var(--gold); background:rgba(201,164,97,.04); }
.sd-nav-btn-label { font-size:.65rem; letter-spacing:2px; text-transform:uppercase; color:var(--faint); margin-bottom:4px; }
.sd-nav-btn-name { font-size:.88rem; color:var(--cream); font-weight:500; }
.sd-nav-center a { font-size:.75rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:600; }

.sd-cta { position:relative; padding:100px 0; overflow:hidden; text-align:center; }
.sd-cta-bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.sd-cta-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(10,8,6,.92),rgba(10,8,6,.75)); }
.sd-cta-content { position:relative; z-index:2; }
.sd-cta-content h2 { color:#fff; max-width:660px; margin:0 auto 16px; }
.sd-cta-content p { color:rgba(255,255,255,.7); max-width:480px; margin:0 auto 40px; font-size:.95rem; line-height:1.85; font-weight:300; }
.sd-cta-btns { display:flex; justify-content:center; gap:16px; flex-wrap:wrap; }
.sd-cta-info { display:flex; justify-content:center; gap:28px; margin-top:36px; flex-wrap:wrap; }
.sd-cta-info-item { display:flex; align-items:center; gap:8px; font-size:.75rem; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.45); }
.sd-cta-info-item em { color:var(--gold); font-style:normal; }

/* ══════════════════════════════════════════════════════════
   CONTACT PAGE
══════════════════════════════════════════════════════════ */
.contact-section { padding:100px 0; background:var(--d1); }
.contact-grid { display:grid; grid-template-columns:1fr 1.6fr; gap:64px; align-items:start; }
.contact-info h2 { color:var(--cream); margin-bottom:20px; font-size:clamp(1.6rem,2.5vw,2.2rem); }
.contact-info p { color:var(--muted); font-size:.92rem; line-height:1.9; font-weight:300; margin-bottom:28px; }
.info-item { display:flex; align-items:flex-start; gap:16px; margin-bottom:28px; }
.info-icon { width:46px; height:46px; flex-shrink:0; border:1px solid rgba(201,164,97,.25); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.info-text label { display:block; font-size:.65rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:600; margin-bottom:5px; }
.info-text p { color:var(--txt); font-size:.9rem; line-height:1.6; margin:0; font-weight:300; }
.info-text a { color:var(--txt); transition:color .3s; }
.info-text a:hover { color:var(--gold-lt); }

.hours-box { margin-top:36px; padding:28px; background:var(--d3); border:1px solid rgba(201,164,97,.1); border-radius:3px; }
.hours-box h4 { font-family:'Raleway',sans-serif; font-size:.7rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); font-weight:700; margin-bottom:16px; }
.hours-row { display:flex; justify-content:space-between; padding:8px 0; border-bottom:1px solid rgba(201,164,97,.06); font-size:.85rem; color:var(--muted); }
.hours-row:last-child { border-bottom:none; }
.hours-row span:last-child { color:var(--txt); }

.contact-form-box { background:var(--d2); border:1px solid rgba(201,164,97,.1); border-radius:3px; padding:48px 44px; }
.contact-form-box h3 { color:var(--cream); margin-bottom:8px; font-size:1.7rem; }
.contact-form-box > p { color:var(--muted); font-size:.88rem; margin-bottom:32px; line-height:1.7; font-weight:300; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px; }
.form-group { display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.form-group label { font-size:.7rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:600; }
.form-group input, .form-group select, .form-group textarea {
  background:rgba(255,255,255,.04); border:1px solid rgba(201,164,97,.18); border-radius:2px;
  padding:13px 16px; font-family:'Raleway',sans-serif; font-size:.88rem; color:var(--txt);
  transition:border-color .3s; outline:none; width:100%;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color:var(--gold); background:rgba(201,164,97,.04);
}
.form-group select option { background:#1c1810; color:var(--txt); }
.form-group textarea { min-height:130px; resize:vertical; }
.form-honeypot { display:none !important; }
.form-submit { width:100%; justify-content:center; }
.alert { padding:16px 20px; border-radius:2px; font-size:.88rem; margin-bottom:24px; line-height:1.6; }
.alert-success { background:rgba(201,164,97,.12); border:1px solid rgba(201,164,97,.3); color:var(--gold-lt); }
.alert-error { background:rgba(220,50,50,.08); border:1px solid rgba(220,50,50,.3); color:#f08080; }
.alert ul { margin:8px 0 0 18px; }
.map-section { padding:0; background:var(--d3); }
.map-section iframe { display:block; width:100%; height:420px; border:none; filter:grayscale(60%) contrast(1.05); }

/* ══════════════════════════════════════════════════════════
   BLOG
══════════════════════════════════════════════════════════ */
.blog-section { padding:100px 0; background:var(--d2); }
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.blog-card { background:var(--d3); border:1px solid rgba(201,164,97,.08); border-radius:3px; overflow:hidden; transition:border-color .3s,transform .3s; }
.blog-card:hover { border-color:rgba(201,164,97,.28); transform:translateY(-6px); }
.blog-card-img { overflow:hidden; height:230px; position:relative; }
.blog-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.blog-card:hover .blog-card-img img { transform:scale(1.07); }
.blog-card-cat { position:absolute; top:14px; left:14px; font-size:.62rem; letter-spacing:2px; text-transform:uppercase; font-weight:700; padding:5px 12px; border-radius:2px; background:var(--gold); color:var(--d1); }
.blog-card-body { padding:26px 28px 30px; }
.blog-card-meta { display:flex; align-items:center; gap:14px; margin-bottom:14px; font-size:.72rem; color:var(--faint); letter-spacing:1px; }
.blog-card-body h3 { color:var(--cream); font-size:1.28rem; margin-bottom:10px; line-height:1.4; transition:color .3s; }
.blog-card:hover .blog-card-body h3 { color:var(--gold-lt); }
.blog-card-body p { color:var(--muted); font-size:.85rem; line-height:1.75; font-weight:300; margin-bottom:20px; }
.blog-card-link { display:inline-flex; align-items:center; gap:7px; font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:600; transition:color .3s; }
.blog-card-link:hover { color:var(--gold-lt); }

.blog-featured { padding:80px 0 0; background:var(--d2); }
.blog-feat-card { display:grid; grid-template-columns:1fr 1fr; gap:0; border-radius:3px; overflow:hidden; border:1px solid rgba(201,164,97,.12); }
.blog-feat-img { overflow:hidden; position:relative; }
.blog-feat-img img { width:100%; height:100%; min-height:440px; object-fit:cover; transition:transform .6s ease; }
.blog-feat-card:hover .blog-feat-img img { transform:scale(1.04); }
.blog-feat-img-cat { position:absolute; top:20px; left:20px; font-size:.65rem; letter-spacing:2.5px; text-transform:uppercase; font-weight:700; padding:6px 14px; border-radius:2px; background:var(--gold); color:var(--d1); }
.blog-feat-body { padding:52px 48px; background:var(--d4); display:flex; flex-direction:column; justify-content:center; }
.blog-feat-tag { display:inline-block; font-size:.68rem; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.blog-feat-body h2 { color:var(--cream); font-size:clamp(1.5rem,2.5vw,2.1rem); margin-bottom:14px; line-height:1.3; transition:color .3s; }
.blog-feat-card:hover .blog-feat-body h2 { color:var(--gold-lt); }
.blog-feat-body p { color:var(--muted); font-size:.9rem; line-height:1.85; font-weight:300; margin-bottom:28px; }
.blog-feat-meta { display:flex; align-items:center; gap:16px; margin-bottom:28px; font-size:.72rem; color:var(--faint); }

.newsletter { padding:80px 0; background:var(--d1); border-top:1px solid rgba(201,164,97,.1); border-bottom:1px solid rgba(201,164,97,.1); }
.newsletter-inner { max-width:560px; margin:0 auto; text-align:center; }
.newsletter-inner h3 { color:var(--cream); margin-bottom:10px; font-size:clamp(1.5rem,2.5vw,2.1rem); }
.newsletter-inner p { color:var(--muted); font-size:.9rem; line-height:1.75; font-weight:300; margin-bottom:28px; }
.newsletter-form { display:flex; gap:10px; }
.newsletter-form input { flex:1; background:rgba(255,255,255,.05); border:1px solid rgba(201,164,97,.2); border-radius:2px; padding:13px 18px; font-family:'Raleway',sans-serif; font-size:.88rem; color:var(--txt); outline:none; transition:border-color .3s; }
.newsletter-form input:focus { border-color:var(--gold); }
.newsletter-form input::placeholder { color:var(--faint); }

/* ── Single Post / Blog Detail ── */
.blog-single { padding:100px 0; background:var(--d1); }
.blog-single-wrap { max-width:820px; margin:0 auto; }
.blog-single-header { margin-bottom:40px; }
.blog-single-cat { display:inline-block; font-size:.65rem; letter-spacing:2.5px; text-transform:uppercase; padding:6px 14px; background:var(--gold); color:var(--d1); font-weight:700; border-radius:2px; margin-bottom:18px; }
.blog-single-header h1 { color:var(--cream); margin-bottom:18px; font-size:clamp(2rem,4vw,3.2rem); }
.blog-single-meta { display:flex; align-items:center; gap:20px; font-size:.78rem; color:var(--muted); flex-wrap:wrap; padding-bottom:32px; border-bottom:1px solid rgba(201,164,97,.1); }
.blog-single-featured { width:100%; height:480px; border-radius:3px; overflow:hidden; margin-bottom:48px; }
.blog-single-featured img { width:100%; height:100%; object-fit:cover; }
.blog-single-content { color:var(--muted); font-size:.95rem; line-height:1.95; font-weight:300; }
.blog-single-content h2, .blog-single-content h3 { color:var(--cream); margin:36px 0 16px; }
.blog-single-content p { margin-bottom:22px; }
.blog-single-content ul, .blog-single-content ol { margin:0 0 22px 24px; }
.blog-single-content li { margin-bottom:8px; }
.blog-single-content blockquote {
  border-left:2px solid var(--gold); padding:18px 24px; margin:32px 0;
  background:rgba(201,164,97,.04); font-family:'Cormorant Garamond',serif;
  font-size:1.2rem; font-style:italic; color:var(--cream);
}
.blog-single-content a { color:var(--gold); }
.blog-single-content a:hover { color:var(--gold-lt); }
.blog-single-content img { border-radius:3px; margin:24px 0; }

/* ══════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════ */
footer {
  background:#060504; padding:72px 0 32px;
  border-top:1px solid rgba(201,164,97,.1);
}
.ft-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1.6fr;
  gap:48px; margin-bottom:52px;
}
.ft-brand-logo { margin-bottom:18px; }
.ft-brand-logo img { height:150px; width:auto; object-fit:contain; filter:brightness(.92); }
.ft-brand p { color:var(--muted); font-size:.84rem; line-height:1.85; font-weight:300; max-width:270px; margin-bottom:22px; }
.ft-socials { display:flex; gap:9px; }
.ft-soc {
  width:35px; height:35px; border:1px solid rgba(201,164,97,.18);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:.7rem; color:var(--muted); cursor:pointer; transition:all .3s; text-decoration:none;
}
.ft-soc:hover { border-color:var(--gold); color:var(--gold); background:rgba(201,164,97,.07); }
.ft-col h5 { font-family:'Raleway',sans-serif; font-size:.68rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); font-weight:700; margin-bottom:20px; }
.ft-links { list-style:none; display:flex; flex-direction:column; gap:9px; }
.ft-links a { font-size:.84rem; color:var(--muted); transition:color .3s; }
.ft-links a:hover { color:var(--gold-lt); }
.ft-contact { list-style:none; display:flex; flex-direction:column; gap:13px; }
.ft-contact li { display:flex; align-items:flex-start; gap:10px; font-size:.82rem; color:var(--muted); line-height:1.6; }
.ft-contact li i { color:var(--gold); flex-shrink:0; margin-top:1px; font-style:normal; }
.ft-bottom {
  padding-top:26px; border-top:1px solid rgba(201,164,97,.07);
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px;
}
.ft-bottom p { font-size:.76rem; color:var(--faint); }
.ft-bottom-links { display:flex; gap:18px; }
.ft-bottom-links a { font-size:.73rem; color:var(--faint); transition:color .3s; }
.ft-bottom-links a:hover { color:var(--gold); }

/* ══════════════════════════════════════════════════════════
   PAGINATION
══════════════════════════════════════════════════════════ */
.pagination { display:flex; justify-content:center; gap:8px; margin-top:60px; }
.pagination a, .pagination span {
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px; border:1px solid rgba(201,164,97,.2);
  border-radius:2px; font-size:.8rem; color:var(--muted); transition:all .3s;
}
.pagination a:hover, .pagination span.current {
  background:var(--gold); border-color:var(--gold); color:var(--d1);
}

/* ══════════════════════════════════════════════════════════
   404 PAGE
══════════════════════════════════════════════════════════ */
.page-404 { padding:160px 0 120px; text-align:center; background:var(--d1); }
.page-404 .num-404 { font-family:'Cormorant Garamond',serif; font-size:clamp(120px,20vw,220px); color:rgba(201,164,97,.08); line-height:1; margin-bottom:-40px; font-weight:700; }
.page-404 h1 { color:var(--cream); margin-bottom:18px; }
.page-404 p { color:var(--muted); font-size:1rem; line-height:1.85; max-width:480px; margin:0 auto 44px; }

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════ */
@media(max-width:1024px) {
  /* Nav */
  .nav-menu, .nav-book { display:none; }
  .hamburger { display:flex; }
  /* Home */
  .srv-grid { grid-template-columns:repeat(2,1fr); }
  .ab-grid { grid-template-columns:1fr; gap:50px; }
  .ab-imgs { display:none; }
  .res-grid { grid-template-columns:repeat(2,1fr); }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .why-grid { grid-template-columns:repeat(2,1fr); }
  .gal-grid { grid-template-columns:repeat(2,1fr); }
  .gal-item:nth-child(1) { grid-column:span 2; grid-row:span 1; }
  .gal-item:nth-child(1) img { height:300px; }
  .s-thumbs { display:none; }
  /* About */
  .story-grid { grid-template-columns:1fr; gap:40px; }
  .story-img { display:none; }
  .values-grid { grid-template-columns:repeat(2,1fr); }
  /* Services */
  .srv-full-grid { grid-template-columns:repeat(2,1fr); }
  /* Service Detail */
  .sd-steps { grid-template-columns:repeat(2,1fr); }
  .sd-ben-grid { grid-template-columns:repeat(2,1fr); }
  .sd-what-grid { grid-template-columns:1fr; gap:40px; }
  .sd-suitable-grid { grid-template-columns:1fr; }
  .sd-suitable-img { display:none; }
  .rel-grid { grid-template-columns:repeat(2,1fr); }
  /* Contact */
  .contact-grid { grid-template-columns:1fr; }
  .contact-form-box { padding:36px 28px; }
  /* Blog */
  .blog-grid { grid-template-columns:repeat(2,1fr); }
  .blog-feat-card { grid-template-columns:1fr; }
  .blog-feat-img img { min-height:300px; }
  .blog-feat-body { padding:36px 32px; }
  /* Footer */
  .ft-grid { grid-template-columns:1fr 1fr; }
}

@media(max-width:768px) {
  .srv-grid { grid-template-columns:1fr; }
  .res-grid { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .why-grid { grid-template-columns:1fr; }
  .gal-grid { grid-template-columns:1fr 1fr; }
  .tc { min-width:290px; }
  .values-grid { grid-template-columns:1fr; }
  .feats-list { grid-template-columns:1fr; }
  .srv-full-grid { grid-template-columns:1fr; }
  .sd-steps { grid-template-columns:1fr; }
  .sd-ben-grid { grid-template-columns:1fr; }
  .rel-grid { grid-template-columns:1fr; }
  .blog-grid { grid-template-columns:1fr; }
  .newsletter-form { flex-direction:column; }
  .ft-grid { grid-template-columns:1fr; gap:32px; }
  .cta-trust { gap:16px; }
}

@media(max-width:640px) {
  .form-row { grid-template-columns:1fr; }
  .sd-hero-meta { flex-wrap:wrap; }
  .slide-btns { flex-direction:column; }
  .cta-btns { flex-direction:column; align-items:center; }
}

/* ══════════════════════════════════════════════════════════
   MOBILE BOTTOM TAB BAR
   Visible only on mobile (≤768px), hidden on desktop
══════════════════════════════════════════════════════════ */
.mob-tabbar { display:none; }

@media(max-width:768px) {
  /* Push footer content up so tab bar doesn't cover it */
  body { padding-bottom:68px; }

  /* Tab bar */
  .mob-tabbar {
    display:flex; position:fixed;
    bottom:0; left:0; right:0; z-index:700;
    height:68px;
    background:rgba(10,9,7,.97);
    backdrop-filter:blur(20px) saturate(1.4);
    border-top:1px solid rgba(201,164,97,.15);
    align-items:stretch;
    padding:0 4px;
    padding-bottom:env(safe-area-inset-bottom);
  }

  /* Each tab */
  .mob-tab {
    flex:1; display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    gap:4px; text-decoration:none;
    color:var(--faint); transition:color .2s;
    position:relative; padding:8px 2px 4px;
  }
  .mob-tab:hover, .mob-tab--active { color:var(--gold); }

  .mob-tab svg {
    width:22px; height:22px; flex-shrink:0;
    stroke:currentColor;
  }

  .mob-tab span {
    font-family:'Raleway',sans-serif;
    font-size:.52rem; font-weight:600;
    letter-spacing:1.5px; text-transform:uppercase;
    line-height:1;
  }

  /* Active dot indicator */
  .mob-tab--active::after {
    content:''; position:absolute; top:6px; left:50%;
    transform:translateX(-50%);
    width:4px; height:4px; border-radius:50%;
    background:var(--gold);
  }

  /* Centre BOOK tab — gold circle highlight */
  .mob-tab--book {
    color:var(--d1);
    flex:1.2;
  }
  .mob-tab--book span { color:var(--gold-lt); font-weight:700; }

  .mob-tab-book-icon {
    width:44px; height:44px;
    background:linear-gradient(135deg,var(--gold),var(--gold-dk));
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    margin-top:-18px;
    box-shadow:0 4px 20px rgba(201,164,97,.45);
    flex-shrink:0;
  }
  .mob-tab-book-icon svg {
    width:20px; height:20px;
    stroke:var(--d1); width:20px; height:20px;
  }
}
