/* ================================================================
   SKYLINE — Premium Snack Bar | Guest House | Fine Wine Lounge
   style.css  |  White-Gold Luxury Theme
   Buea, Cameroon
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,600&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Jost:wght@300;400;500;600&display=swap');

:root {
  --gold:           #C9A84C;
  --gold-light:     #E8C76A;
  --gold-bright:    #F5C518;
  --gold-dark:      #A8872A;
  --gold-pale:      #F9EED0;
  --gold-tint:      #FDF6E3;
  --white:          #FFFFFF;
  --ivory:          #FAF8F4;
  --cream:          #F5F0E8;
  --parchment:      #EDE5D5;
  --linen:          #E8DFD0;
  --ink:            #1A1512;
  --charcoal:       #2D2820;
  --warm-grey:      #6B6258;
  --mid-grey:       #9E9690;
  --light-grey:     #D4CEC8;
  --border:         #E2D9CC;
  --burgundy:       #4A0F1F;
  --nav-height:     80px;
  --transition:     0.35s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow:0.6s cubic-bezier(0.4, 0, 0.2, 1);
  --shadow-sm:      0 2px 12px rgba(26,21,18,0.08);
  --shadow-md:      0 8px 32px rgba(26,21,18,0.12);
  --shadow-lg:      0 20px 60px rgba(26,21,18,0.15);
  --shadow-gold:    0 8px 40px rgba(201,168,76,0.25);
  --radius:         3px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--ivory);
  color: var(--ink);
  font-family: 'Jost', sans-serif;
  font-weight: 300;
  line-height: 1.8;
  overflow-x: hidden;
}
h1,h2,h3,h4,h5,h6 { font-family: 'Playfair Display', serif; line-height: 1.18; color: var(--ink); font-weight: 700; }
a { color: inherit; text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--gold-dark); }
img { max-width: 100%; display: block; }
button { font-family: 'Jost', sans-serif; }
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--cream); }
::-webkit-scrollbar-thumb { background: var(--gold); border-radius: 3px; }
::selection { background: var(--gold-pale); color: var(--ink); }

.text-gold       { color: var(--gold) !important; }
.text-gold-dark  { color: var(--gold-dark) !important; }
.bg-ivory        { background: var(--ivory) !important; }
.bg-cream        { background: var(--cream) !important; }
.bg-ink          { background: var(--ink) !important; }
.bg-parchment    { background: var(--parchment) !important; }
.font-playfair   { font-family: 'Playfair Display', serif !important; }
.font-cormorant  { font-family: 'Cormorant Garamond', serif !important; }
.section-pad     { padding: 100px 0; }
.section-pad-sm  { padding: 64px 0; }

/* Eyebrow / section labels */
.eyebrow {
  font-family: 'Jost', sans-serif;
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 4.5px;
  text-transform: uppercase;
  color: var(--gold-dark);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.eyebrow::before,.eyebrow::after { content:''; width:28px; height:1px; background:var(--gold); }
.section-title { font-size: clamp(2rem,4vw,3rem); font-weight: 800; margin-bottom: 16px; line-height: 1.15; }
.section-title em { font-style: italic; color: var(--gold-dark); }
.section-subtitle { font-family:'Cormorant Garamond',serif; font-size:1.15rem; color:var(--warm-grey); max-width:520px; line-height:1.7; }
.title-center { text-align: center; }
.title-center .section-subtitle { margin: 0 auto; }
.title-center .eyebrow { justify-content: center; }
.gold-rule { display:flex; align-items:center; gap:14px; margin: 20px 0 44px; }
.gold-rule-line { flex:1; height:1px; background:linear-gradient(to right, transparent, var(--gold), transparent); }
.gold-rule-diamond { width:7px; height:7px; background:var(--gold); transform:rotate(45deg); flex-shrink:0; }

/* Buttons */
.btn-gold {
  display:inline-flex; align-items:center; gap:10px;
  background:linear-gradient(135deg, var(--gold-dark) 0%, var(--gold) 50%, var(--gold-light) 100%);
  color:var(--white) !important;
  font-family:'Jost',sans-serif; font-size:11px; font-weight:500;
  letter-spacing:3px; text-transform:uppercase;
  padding:15px 38px; border:none; border-radius:var(--radius);
  cursor:pointer; transition:all var(--transition); box-shadow:var(--shadow-gold);
}
.btn-gold:hover { transform:translateY(-2px); box-shadow:0 14px 40px rgba(201,168,76,0.4); filter:brightness(1.07); }
.btn-outline-gold {
  display:inline-flex; align-items:center; gap:10px;
  background:transparent; color:var(--gold-dark) !important;
  font-family:'Jost',sans-serif; font-size:11px; font-weight:500;
  letter-spacing:3px; text-transform:uppercase;
  padding:14px 38px; border:1.5px solid var(--gold); border-radius:var(--radius);
  cursor:pointer; transition:all var(--transition);
}
.btn-outline-gold:hover { background:var(--gold); color:var(--white) !important; transform:translateY(-2px); box-shadow:var(--shadow-gold); }
.btn-dark-outline {
  display:inline-flex; align-items:center; gap:10px;
  background:transparent; color:var(--white) !important;
  font-family:'Jost',sans-serif; font-size:11px; font-weight:500;
  letter-spacing:3px; text-transform:uppercase;
  padding:14px 38px; border:1.5px solid rgba(255,255,255,0.6); border-radius:var(--radius);
  cursor:pointer; transition:all var(--transition);
}
.btn-dark-outline:hover { background:rgba(255,255,255,0.12); border-color:var(--white); transform:translateY(-2px); }
.btn-sm-gold {
  display:inline-flex; align-items:center; gap:7px;
  background:var(--gold); color:var(--white) !important;
  font-family:'Jost',sans-serif; font-size:10px; font-weight:500;
  letter-spacing:2px; text-transform:uppercase;
  padding:9px 20px; border:none; border-radius:var(--radius);
  cursor:pointer; transition:all var(--transition); white-space:nowrap;
}
.btn-sm-gold:hover { background:var(--gold-dark); transform:translateY(-1px); box-shadow:0 6px 20px rgba(201,168,76,0.3); }

/* Navigation */
#mainNav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:var(--nav-height); transition:all var(--transition); background:transparent;
}
#mainNav.scrolled {
  background:rgba(250,248,244,0.97);
  backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border); box-shadow:var(--shadow-sm);
}
.nav-logo-text {
  font-family:'Playfair Display',serif; font-size:24px; font-weight:900;
  letter-spacing:4px; text-transform:uppercase; color:var(--white); line-height:1;
  transition:color var(--transition);
}
#mainNav.scrolled .nav-logo-text { color:var(--ink); }
.nav-logo-sub {
  font-family:'Jost',sans-serif; font-size:7.5px; letter-spacing:4px;
  text-transform:uppercase; color:var(--gold); font-weight:400; margin-top:2px;
}
#mainNav .nav-link {
  font-family:'Jost',sans-serif; font-size:10.5px; font-weight:500;
  letter-spacing:2.5px; text-transform:uppercase;
  color:rgba(255,255,255,0.85) !important;
  padding:8px 13px !important; position:relative; transition:color var(--transition);
}
#mainNav.scrolled .nav-link { color:var(--warm-grey) !important; }
#mainNav .nav-link::after {
  content:''; position:absolute; bottom:0; left:13px; right:13px;
  height:1.5px; background:var(--gold);
  transform:scaleX(0); transform-origin:left; transition:transform var(--transition);
}
#mainNav .nav-link:hover,
#mainNav .nav-link.active-link { color:var(--gold-light) !important; }
#mainNav.scrolled .nav-link:hover,
#mainNav.scrolled .nav-link.active-link { color:var(--gold-dark) !important; }
#mainNav .nav-link:hover::after,
#mainNav .nav-link.active-link::after { transform:scaleX(1); }
.nav-cart-btn {
  display:flex; align-items:center; gap:7px;
  background:none; border:1.5px solid rgba(255,255,255,0.35);
  color:var(--white); font-family:'Jost',sans-serif; font-size:10px;
  letter-spacing:1.5px; padding:8px 16px; border-radius:var(--radius);
  cursor:pointer; transition:all var(--transition); position:relative;
  white-space:nowrap; margin-left:6px;
}
#mainNav.scrolled .nav-cart-btn { border-color:var(--gold); color:var(--gold-dark); }
.nav-cart-btn:hover { background:var(--gold); border-color:var(--gold); color:var(--white); }
.cart-count {
  background:var(--burgundy); color:var(--white); font-size:8px; font-weight:600;
  width:16px; height:16px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.navbar-toggler { border:1.5px solid rgba(255,255,255,0.4); padding:6px 10px; border-radius:var(--radius); }
#mainNav.scrolled .navbar-toggler { border-color:var(--gold); }
.navbar-toggler:focus { box-shadow:none; }
.navbar-toggler-icon { background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255,255,255,0.9%29' stroke-linecap='round' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); }
#mainNav.scrolled .navbar-toggler-icon { background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23C9A84C' stroke-linecap='round' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); }
@media (max-width:991.98px) {
  #mainNav .navbar-collapse {
    background:var(--ivory); border:1px solid var(--border); border-radius:4px;
    padding:20px 24px; margin-top:12px; box-shadow:var(--shadow-md);
  }
  #mainNav .nav-link { color:var(--warm-grey) !important; }
  #mainNav .nav-link:hover { color:var(--gold-dark) !important; }
}

/* Hero */
#hero { position:relative; min-height:100vh; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.hero-bg {
  position:absolute; inset:0;
  background:url('https://images.unsplash.com/photo-1517248135467-4c7edcad34c4?w=1920&q=90') center/cover no-repeat;
  transform:scale(1.06); animation:heroZoom 22s ease-in-out infinite alternate;
}
@keyframes heroZoom { from{transform:scale(1.06)} to{transform:scale(1.13)} }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(165deg,rgba(10,8,6,0.82) 0%,rgba(74,15,31,0.45) 45%,rgba(10,8,6,0.75) 100%); }
.hero-shimmer {
  position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,transparent 0%,var(--gold-dark) 20%,var(--gold-bright) 50%,var(--gold-dark) 80%,transparent 100%);
}
.hero-content { position:relative; z-index:2; text-align:center; padding:0 20px; max-width:900px; margin:0 auto; }
.hero-badge {
  display:inline-flex; align-items:center; gap:14px;
  background:rgba(255,255,255,0.07); border:1px solid rgba(201,168,76,0.45);
  backdrop-filter:blur(8px); color:var(--gold-light);
  font-family:'Jost',sans-serif; font-size:10px; font-weight:400;
  letter-spacing:5px; text-transform:uppercase;
  padding:9px 24px; border-radius:100px; margin-bottom:28px;
  animation:fadeInDown 0.9s ease both;
}
.hero-badge-dot { width:5px; height:5px; background:var(--gold); border-radius:50%; animation:pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.4;transform:scale(0.6)} }
.hero-title {
  font-family:'Playfair Display',serif; font-size:clamp(3.8rem,10vw,9rem);
  font-weight:900; color:var(--white); letter-spacing:-1px; line-height:0.95;
  margin-bottom:8px; animation:fadeInUp 0.9s ease 0.15s both;
}
.hero-title-accent { display:block; font-style:italic; color:var(--gold-light); font-size:0.5em; letter-spacing:14px; font-weight:400; line-height:2; text-transform:uppercase; }
.hero-tagline { font-family:'Cormorant Garamond',serif; font-size:clamp(1.1rem,2.8vw,1.6rem); font-weight:300; font-style:italic; color:rgba(255,255,255,0.75); margin-bottom:44px; animation:fadeInUp 0.9s ease 0.3s both; }
.hero-cta-row { display:flex; flex-wrap:wrap; gap:14px; justify-content:center; animation:fadeInUp 0.9s ease 0.45s both; }
.hero-scroll-indicator { position:absolute; bottom:36px; left:50%; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:9px; animation:fadeIn 1.5s ease 1s both; }
.scroll-line { width:1px; height:48px; background:linear-gradient(to bottom,var(--gold-light),transparent); animation:scrollDrop 2.2s ease-in-out infinite; }
@keyframes scrollDrop { 0%{transform:scaleY(0);transform-origin:top;opacity:1} 50%{transform:scaleY(1);transform-origin:top;opacity:1} 100%{transform:scaleY(1);transform-origin:bottom;opacity:0} }
.scroll-label { font-family:'Jost',sans-serif; font-size:8px; letter-spacing:4px; text-transform:uppercase; color:rgba(255,255,255,0.45); }

/* Welcome section */
#welcome { background:var(--white); overflow:hidden; position:relative; }
#welcome::before { content:'SKY'; position:absolute; top:50%; right:-3%; transform:translateY(-50%); font-family:'Playfair Display',serif; font-size:22vw; font-weight:900; color:rgba(201,168,76,0.04); line-height:1; pointer-events:none; }
.welcome-img-frame { position:relative; }
.welcome-img-frame img { width:100%; height:540px; object-fit:cover; border-radius:var(--radius); box-shadow:var(--shadow-lg); }
.welcome-img-frame::before { content:''; position:absolute; top:-18px; left:-18px; width:70px; height:70px; border-top:2px solid var(--gold); border-left:2px solid var(--gold); border-radius:var(--radius); z-index:1; }
.welcome-img-frame::after { content:''; position:absolute; bottom:-18px; right:-18px; width:70px; height:70px; border-bottom:2px solid var(--gold); border-right:2px solid var(--gold); border-radius:var(--radius); }
.welcome-badge-overlay { position:absolute; bottom:30px; left:-20px; background:var(--gold); color:var(--white); padding:20px 24px; border-radius:var(--radius); box-shadow:var(--shadow-md); text-align:center; z-index:2; }
.welcome-badge-num { font-family:'Playfair Display',serif; font-size:2.4rem; font-weight:800; line-height:1; }
.welcome-badge-label { font-size:9px; letter-spacing:2px; text-transform:uppercase; opacity:0.85; font-weight:500; }
.feature-tag { display:inline-flex; align-items:center; gap:8px; background:var(--gold-tint); border:1px solid var(--linen); color:var(--gold-dark); font-size:10.5px; font-weight:500; letter-spacing:1.5px; padding:7px 16px; border-radius:100px; margin:4px 3px; }
.feature-tag i { font-size:12px; color:var(--gold); }

/* Dish cards */
#dishes { background:var(--ivory); }
.dish-card { background:var(--white); border:1px solid var(--border); border-radius:4px; overflow:hidden; transition:all var(--transition); height:100%; }
.dish-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:var(--gold); }
.dish-card-img { height:240px; overflow:hidden; position:relative; }
.dish-card-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s ease; }
.dish-card:hover .dish-card-img img { transform:scale(1.1); }
.dish-price-tag { position:absolute; bottom:14px; right:14px; background:var(--white); border:1.5px solid var(--gold); color:var(--gold-dark); font-family:'Playfair Display',serif; font-size:15px; font-weight:700; padding:5px 14px; border-radius:2px; box-shadow:var(--shadow-sm); }
.dish-badge { position:absolute; top:14px; left:14px; background:var(--burgundy); color:var(--white); font-size:9px; font-weight:500; letter-spacing:2px; text-transform:uppercase; padding:5px 12px; border-radius:2px; }
.dish-card-body { padding:22px; }
.dish-category { font-size:10px; font-weight:500; letter-spacing:3px; text-transform:uppercase; color:var(--gold-dark); margin-bottom:7px; }
.dish-title { font-family:'Playfair Display',serif; font-size:1.15rem; font-weight:700; margin-bottom:8px; }
.dish-desc { font-size:13px; color:var(--warm-grey); line-height:1.6; margin-bottom:18px; }
.dish-card-footer { display:flex; justify-content:space-between; align-items:center; }

/* Wine section */
#wines { background:var(--ink); position:relative; overflow:hidden; }
#wines::before { content:''; position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1510812431401-41d2bd2722f3?w=1600&q=60') center/cover no-repeat; opacity:0.08; }
#wines .section-title { color:var(--white); }
#wines .section-title em { color:var(--gold-light); }
#wines .eyebrow { color:var(--gold-light); }
#wines .eyebrow::before,#wines .eyebrow::after { background:var(--gold-light); }
#wines .section-subtitle { color:rgba(255,255,255,0.55); }
.wine-card { background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.09); border-radius:4px; overflow:hidden; transition:all var(--transition); height:100%; }
.wine-card:hover { border-color:var(--gold); transform:translateY(-8px); box-shadow:0 20px 60px rgba(0,0,0,0.5),var(--shadow-gold); }
.wine-card-img { height:280px; overflow:hidden; position:relative; background:radial-gradient(ellipse at center,rgba(74,15,31,0.6) 0%,rgba(10,8,6,0.9) 100%); display:flex; align-items:center; justify-content:center; }
.wine-card-img img { height:260px; width:auto; object-fit:contain; filter:drop-shadow(0 10px 30px rgba(0,0,0,0.7)); transition:transform 0.5s ease; }
.wine-card:hover .wine-card-img img { transform:translateY(-6px) scale(1.03); }
.wine-year-badge { position:absolute; top:14px; right:14px; border:1.5px solid rgba(201,168,76,0.5); color:var(--gold-light); font-family:'Playfair Display',serif; font-size:12px; font-weight:700; padding:4px 12px; background:rgba(10,8,6,0.5); }
.wine-card-body { padding:22px; }
.wine-origin { font-size:10px; font-weight:500; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:7px; }
.wine-name { font-family:'Playfair Display',serif; font-size:1.15rem; color:var(--white); margin-bottom:6px; }
.wine-notes { font-family:'Cormorant Garamond',serif; font-size:14px; font-style:italic; color:rgba(255,255,255,0.5); line-height:1.6; margin-bottom:16px; }
.wine-rating { display:flex; gap:3px; color:var(--gold-light); font-size:11px; margin-bottom:14px; }
.wine-price { font-family:'Playfair Display',serif; font-size:1.35rem; font-weight:700; color:var(--gold-light); }
.wine-price small { font-family:'Jost',sans-serif; font-size:11px; color:rgba(255,255,255,0.35); font-weight:300; }
.wine-card-footer { display:flex; justify-content:space-between; align-items:center; padding:0 22px 22px; }

/* Room preview (home) */
#rooms-preview { background:var(--cream); }
.room-preview-card { position:relative; overflow:hidden; border-radius:4px; height:440px; cursor:pointer; }
.room-preview-card img { width:100%; height:100%; object-fit:cover; transition:transform 0.8s ease; }
.room-preview-card:hover img { transform:scale(1.07); }
.room-preview-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(10,8,6,0.92) 0%,rgba(10,8,6,0.3) 55%,transparent 100%); }
.room-preview-content { position:absolute; bottom:0; left:0; right:0; padding:32px; transform:translateY(28px); transition:transform var(--transition-slow); }
.room-preview-card:hover .room-preview-content { transform:translateY(0); }
.room-type-badge { display:inline-block; background:var(--gold); color:var(--white); font-size:9px; font-weight:500; letter-spacing:3px; text-transform:uppercase; padding:5px 14px; border-radius:2px; margin-bottom:10px; }
.room-preview-name { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:700; color:var(--white); margin-bottom:4px; }
.room-preview-price { font-family:'Playfair Display',serif; font-size:1.2rem; color:var(--gold-light); font-weight:600; }
.room-preview-price small { font-family:'Jost',sans-serif; font-size:11px; color:rgba(255,255,255,0.5); font-weight:300; }
.room-preview-amenities { display:flex; flex-wrap:wrap; gap:12px; margin-top:14px; opacity:0; transition:opacity var(--transition-slow) 0.1s; }
.room-preview-card:hover .room-preview-amenities { opacity:1; }
.room-preview-amenity { font-size:11px; color:rgba(255,255,255,0.65); display:flex; align-items:center; gap:5px; }
.room-preview-amenity i { color:var(--gold); font-size:10px; }

/* Stats */
#stats-strip { background:var(--white); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.stat-block { padding:48px 24px; text-align:center; }
.stat-num { font-family:'Playfair Display',serif; font-size:3.2rem; font-weight:800; color:var(--gold-dark); line-height:1; margin-bottom:8px; }
.stat-label { font-family:'Jost',sans-serif; font-size:10.5px; font-weight:500; letter-spacing:3px; text-transform:uppercase; color:var(--warm-grey); }

/* Testimonials */
#testimonials { background:var(--ivory); }
.testimonial-card { background:var(--white); border:1px solid var(--border); border-radius:4px; padding:38px 36px; transition:all var(--transition); height:100%; }
.testimonial-card:hover { box-shadow:var(--shadow-md); border-color:var(--gold); }
.testimonial-quote-mark { font-family:'Playfair Display',serif; font-size:96px; color:var(--gold); opacity:0.15; line-height:0.6; margin-bottom:18px; }
.testimonial-text { font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-style:italic; color:var(--charcoal); line-height:1.75; margin-bottom:26px; }
.testimonial-stars { color:var(--gold); font-size:12px; margin-bottom:14px; }
.testimonial-author-row { display:flex; align-items:center; gap:14px; }
.t-avatar { width:46px; height:46px; border-radius:50%; object-fit:cover; border:2px solid var(--gold-pale); }
.t-name { font-size:14px; font-weight:600; color:var(--ink); }
.t-role { font-size:11px; color:var(--gold-dark); letter-spacing:1px; }

/* Gallery */
#gallery { background:var(--white); overflow:hidden; }
.gallery-mosaic { display:grid; grid-template-columns:repeat(4,1fr); grid-template-rows:220px 220px; gap:6px; }
.g-item { position:relative; overflow:hidden; cursor:pointer; }
.g-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.65s ease; }
.g-item:hover img { transform:scale(1.12); }
.g-item:nth-child(1) { grid-column:span 2; grid-row:span 2; }
.g-item:nth-child(5) { grid-column:span 2; }
.g-hover-overlay { position:absolute; inset:0; background:rgba(201,168,76,0.75); display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity var(--transition); font-size:26px; color:var(--white); }
.g-item:hover .g-hover-overlay { opacity:1; }

/* Page hero */
.page-hero { height:42vh; min-height:300px; display:flex; align-items:center; justify-content:center; text-align:center; position:relative; overflow:hidden; padding-top:var(--nav-height); }
.page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; filter:brightness(0.28) saturate(0.8); transform:scale(1.04); }
.page-hero-overlay { position:absolute; inset:0; background:linear-gradient(to bottom,rgba(10,8,6,0.5) 0%,rgba(201,168,76,0.08) 100%); }
.page-hero-content { position:relative; z-index:2; }
.page-hero-title { font-size:clamp(2.6rem,6vw,5rem); color:var(--white); margin-bottom:10px; }
.breadcrumb-custom { justify-content:center; }
.breadcrumb-custom .breadcrumb-item,.breadcrumb-custom .breadcrumb-item a { color:rgba(255,255,255,0.55); font-size:12px; letter-spacing:1.5px; }
.breadcrumb-custom .breadcrumb-item.active { color:var(--gold-light); }
.breadcrumb-custom .breadcrumb-item+.breadcrumb-item::before { color:rgba(255,255,255,0.3); content:'›'; }

/* Filter tabs */
.filter-tabs { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-bottom:48px; }
.filter-tab { font-family:'Jost',sans-serif; font-size:10.5px; font-weight:500; letter-spacing:2.5px; text-transform:uppercase; color:var(--warm-grey); background:var(--white); border:1.5px solid var(--border); padding:10px 24px; border-radius:100px; cursor:pointer; transition:all var(--transition); }
.filter-tab:hover,.filter-tab.active { background:var(--gold); border-color:var(--gold); color:var(--white); box-shadow:0 4px 16px rgba(201,168,76,0.3); }

/* Menu items */
.menu-item { background:var(--white); border:1px solid var(--border); border-radius:4px; overflow:hidden; display:flex; transition:all var(--transition); }
.menu-item:hover { border-color:var(--gold); box-shadow:var(--shadow-md); transform:translateX(4px); }
.menu-item-thumb { width:120px; min-width:120px; height:120px; overflow:hidden; flex-shrink:0; }
.menu-item-thumb img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.menu-item:hover .menu-item-thumb img { transform:scale(1.1); }
.menu-item-body { padding:16px 18px; flex:1; display:flex; flex-direction:column; justify-content:space-between; }
.menu-item-cat { font-size:9.5px; font-weight:500; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold-dark); margin-bottom:5px; }
.menu-item-name { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--ink); margin-bottom:5px; }
.menu-item-desc { font-size:12px; color:var(--warm-grey); line-height:1.55; }
.menu-item-row { display:flex; justify-content:space-between; align-items:center; margin-top:12px; }
.menu-item-price { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:var(--gold-dark); }
.menu-tag { font-size:9px; letter-spacing:1.5px; text-transform:uppercase; font-weight:500; padding:3px 9px; border-radius:100px; border:1px solid var(--border); color:var(--warm-grey); }
.menu-tag.veg { border-color:#7aab5c; color:#5d8f42; }
.menu-tag.spicy { border-color:#d4613c; color:#b84e2a; }
.menu-tag.popular { border-color:var(--gold); color:var(--gold-dark); background:var(--gold-tint); }

/* Rooms page */
.room-card-full { background:var(--white); border:1px solid var(--border); border-radius:4px; overflow:hidden; transition:all var(--transition); margin-bottom:36px; }
.room-card-full:hover { border-color:var(--gold); box-shadow:var(--shadow-lg); }
.room-card-img-wrap { position:relative; height:360px; overflow:hidden; }
.room-card-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s ease; }
.room-card-full:hover .room-card-img-wrap img { transform:scale(1.05); }
.room-tier-badge { position:absolute; top:20px; left:20px; background:var(--gold); color:var(--white); font-size:9.5px; font-weight:500; letter-spacing:2.5px; text-transform:uppercase; padding:6px 16px; border-radius:2px; }
.room-card-body { padding:28px 32px 32px; }
.room-card-name { font-family:'Playfair Display',serif; font-size:1.75rem; font-weight:700; margin-bottom:6px; }
.room-card-nightly { font-family:'Playfair Display',serif; font-size:1.9rem; font-weight:700; color:var(--gold-dark); }
.room-card-nightly small { font-family:'Jost',sans-serif; font-size:12px; color:var(--warm-grey); font-weight:300; }
.room-amenity-list { display:flex; flex-wrap:wrap; gap:10px; margin:18px 0 22px; }
.room-amenity { display:flex; align-items:center; gap:6px; background:var(--ivory); border:1px solid var(--border); padding:6px 14px; border-radius:100px; font-size:11.5px; color:var(--warm-grey); }
.room-amenity i { color:var(--gold); font-size:11px; }

/* Booking form */
#booking-form-section { background:var(--parchment); }
.booking-form-card { background:var(--white); border:1px solid var(--border); border-radius:4px; padding:44px; box-shadow:var(--shadow-md); }
.form-lbl { font-family:'Jost',sans-serif; font-size:10px; font-weight:500; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold-dark); display:block; margin-bottom:8px; }
.form-ctrl { width:100%; background:var(--ivory); border:1.5px solid var(--border); border-radius:var(--radius); color:var(--ink); font-family:'Jost',sans-serif; font-size:14px; font-weight:300; padding:13px 16px; transition:border-color var(--transition),box-shadow var(--transition); outline:none; appearance:none; }
.form-ctrl:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,0.12); background:var(--white); }
.form-ctrl::placeholder { color:var(--mid-grey); }
.form-ctrl option { background:var(--white); color:var(--ink); }
.form-ctrl-select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23C9A84C' d='M1 1l5 5 5-5'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; cursor:pointer; }
.field-error { font-size:11px; color:#c0392b; margin-top:5px; display:none; }
.field-error.show { display:block; }
.form-divider { height:1px; background:var(--border); margin:28px 0; }

/* Auth */
.auth-page { min-height:100vh; display:flex; align-items:center; justify-content:center; background:url('https://images.unsplash.com/photo-1414235077428-338989a2e8c0?w=1600&q=80') center/cover no-repeat; position:relative; padding:120px 0 60px; }
.auth-page::before { content:''; position:absolute; inset:0; background:rgba(10,8,6,0.82); }
.auth-card { position:relative; z-index:1; background:var(--white); border-radius:4px; overflow:hidden; width:100%; max-width:480px; box-shadow:var(--shadow-lg); }
.auth-card-header { background:var(--ink); padding:36px 40px 32px; text-align:center; }
.auth-logo { font-family:'Playfair Display',serif; font-size:28px; font-weight:900; letter-spacing:5px; color:var(--gold-light); text-transform:uppercase; }
.auth-logo-sub { font-family:'Jost',sans-serif; font-size:8px; letter-spacing:4px; text-transform:uppercase; color:rgba(255,255,255,0.35); margin-top:4px; }
.auth-tabs { display:flex; border-bottom:1px solid var(--border); }
.auth-tab-btn { flex:1; background:none; border:none; font-family:'Jost',sans-serif; font-size:10.5px; font-weight:500; letter-spacing:2.5px; text-transform:uppercase; color:var(--warm-grey); padding:18px; cursor:pointer; position:relative; transition:color var(--transition); }
.auth-tab-btn::after { content:''; position:absolute; bottom:-1px; left:0; right:0; height:2px; background:var(--gold); transform:scaleX(0); transition:transform var(--transition); }
.auth-tab-btn.active { color:var(--gold-dark); }
.auth-tab-btn.active::after { transform:scaleX(1); }
.auth-form-panel { display:none; padding:32px 40px 36px; }
.auth-form-panel.active { display:block; }
.auth-divider { display:flex; align-items:center; gap:14px; margin:22px 0; font-size:11px; color:var(--light-grey); letter-spacing:1px; }
.auth-divider::before,.auth-divider::after { content:''; flex:1; height:1px; background:var(--border); }
.social-auth-btn { display:flex; align-items:center; justify-content:center; gap:10px; width:100%; background:var(--ivory); border:1.5px solid var(--border); color:var(--ink); font-family:'Jost',sans-serif; font-size:12px; font-weight:500; letter-spacing:1.5px; padding:12px; border-radius:var(--radius); cursor:pointer; transition:all var(--transition); margin-bottom:10px; }
.social-auth-btn:hover { border-color:var(--gold); background:var(--gold-tint); }

/* Cart panel */
.cart-backdrop { position:fixed; inset:0; background:rgba(10,8,6,0.55); backdrop-filter:blur(4px); z-index:1998; opacity:0; pointer-events:none; transition:opacity var(--transition); }
.cart-backdrop.open { opacity:1; pointer-events:all; }
.cart-panel { position:fixed; top:0; right:0; bottom:0; width:420px; max-width:100vw; background:var(--white); border-left:1px solid var(--border); z-index:1999; transform:translateX(100%); transition:transform 0.42s cubic-bezier(0.4,0,0.2,1); display:flex; flex-direction:column; box-shadow:-12px 0 60px rgba(10,8,6,0.15); }
.cart-panel.open { transform:translateX(0); }
.cart-panel-header { padding:22px 24px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; background:var(--ivory); }
.cart-panel-title { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:var(--ink); }
.cart-panel-close { background:none; border:none; width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--warm-grey); font-size:18px; cursor:pointer; transition:all var(--transition); }
.cart-panel-close:hover { background:var(--cream); color:var(--ink); }
.cart-panel-body { flex:1; overflow-y:auto; padding:18px; }
.cart-line-item { display:flex; gap:14px; padding:14px 0; border-bottom:1px solid var(--border); align-items:flex-start; }
.cart-line-img { width:58px; height:58px; border-radius:3px; object-fit:cover; flex-shrink:0; }
.cart-line-info { flex:1; }
.cart-line-name { font-size:13px; font-weight:600; color:var(--ink); margin-bottom:4px; }
.cart-line-price { font-size:12px; color:var(--gold-dark); font-weight:500; }
.cart-qty-row { display:flex; align-items:center; gap:10px; margin-top:8px; }
.qty-btn { width:26px; height:26px; border:1.5px solid var(--border); background:none; color:var(--ink); border-radius:50%; font-size:14px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all var(--transition); }
.qty-btn:hover { border-color:var(--gold); color:var(--gold-dark); }
.qty-num { font-size:13px; font-weight:500; min-width:18px; text-align:center; color:var(--ink); }
.cart-remove { background:none; border:none; color:var(--mid-grey); font-size:15px; cursor:pointer; padding:4px; transition:color var(--transition); flex-shrink:0; }
.cart-remove:hover { color:#c0392b; }
.cart-empty-state { text-align:center; padding:60px 24px; color:var(--mid-grey); }
.cart-empty-icon { font-size:52px; color:var(--linen); margin-bottom:16px; }
.cart-panel-footer { padding:18px 24px 24px; border-top:1px solid var(--border); background:var(--ivory); }
.cart-summary-row { display:flex; justify-content:space-between; align-items:center; padding:6px 0; font-size:13px; color:var(--warm-grey); }
.cart-total-row { display:flex; justify-content:space-between; align-items:center; padding:14px 0 16px; border-top:1.5px solid var(--border); margin-top:8px; }
.cart-total-label { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--ink); }
.cart-total-amount { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:700; color:var(--gold-dark); }

/* Contact */
.contact-info-card { background:var(--white); border:1px solid var(--border); border-radius:4px; padding:28px; transition:all var(--transition); height:100%; }
.contact-info-card:hover { border-color:var(--gold); box-shadow:var(--shadow-sm); }
.contact-icon-wrap { width:50px; height:50px; border:1.5px solid var(--gold-pale); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:18px; margin-bottom:16px; background:var(--gold-tint); }
.contact-info-label { font-size:10px; font-weight:500; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold-dark); margin-bottom:6px; }
.contact-info-value { font-size:14px; color:var(--ink); line-height:1.6; }

/* About */
.value-card { background:var(--white); border:1px solid var(--border); border-radius:4px; padding:32px 28px; transition:all var(--transition); height:100%; text-align:center; }
.value-card:hover { border-color:var(--gold); box-shadow:var(--shadow-md); transform:translateY(-4px); }
.value-icon { width:60px; height:60px; background:var(--gold-tint); border:1.5px solid var(--linen); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:22px; margin:0 auto 18px; }
.team-card { text-align:center; }
.team-img-wrap { width:150px; height:150px; border-radius:50%; overflow:hidden; margin:0 auto 18px; border:3px solid var(--linen); transition:border-color var(--transition); }
.team-card:hover .team-img-wrap { border-color:var(--gold); }
.team-img-wrap img { width:100%; height:100%; object-fit:cover; }
.team-name { font-size:1.1rem; margin-bottom:4px; }
.team-title { font-size:10.5px; letter-spacing:2px; text-transform:uppercase; color:var(--gold-dark); }

/* Legal */
.legal-wrapper { max-width:820px; margin:0 auto; }
.legal-h2 { font-size:1.35rem; color:var(--ink); margin:40px 0 14px; padding-bottom:10px; border-bottom:1px solid var(--border); }
.legal-p { font-size:14px; color:var(--warm-grey); line-height:1.85; margin-bottom:14px; }
.legal-ul { list-style:none; padding:0; margin-bottom:14px; }
.legal-ul li { font-size:14px; color:var(--warm-grey); padding:6px 0 6px 22px; position:relative; line-height:1.7; }
.legal-ul li::before { content:''; position:absolute; left:0; top:17px; width:8px; height:1px; background:var(--gold); }

/* Footer */
#footer { background:var(--ink); padding:80px 0 0; }
.footer-brand-name { font-family:'Playfair Display',serif; font-size:30px; font-weight:900; letter-spacing:5px; text-transform:uppercase; color:var(--gold-light); }
.footer-brand-tagline { font-family:'Cormorant Garamond',serif; font-size:14px; font-style:italic; color:rgba(255,255,255,0.4); margin:6px 0 20px; }
.footer-social-links { display:flex; gap:10px; }
.footer-social-links a { width:38px; height:38px; border:1px solid rgba(255,255,255,0.12); border-radius:50%; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,0.4); font-size:14px; transition:all var(--transition); }
.footer-social-links a:hover { border-color:var(--gold); color:var(--gold-light); background:rgba(201,168,76,0.08); }
.footer-col-title { font-family:'Jost',sans-serif; font-size:9.5px; font-weight:500; letter-spacing:3.5px; text-transform:uppercase; color:var(--gold); margin-bottom:22px; }
.footer-link-list { list-style:none; padding:0; }
.footer-link-list li { margin-bottom:11px; }
.footer-link-list a { font-size:13px; color:rgba(255,255,255,0.45); display:flex; align-items:center; gap:8px; transition:all var(--transition); }
.footer-link-list a::before { content:''; width:12px; height:1px; background:var(--gold); opacity:0; transition:all var(--transition); flex-shrink:0; }
.footer-link-list a:hover { color:var(--gold-light); padding-left:4px; }
.footer-link-list a:hover::before { opacity:1; }
.footer-contact-item { display:flex; align-items:flex-start; gap:12px; margin-bottom:14px; font-size:13px; color:rgba(255,255,255,0.45); }
.footer-contact-item i { color:var(--gold); font-size:14px; margin-top:3px; flex-shrink:0; }
.footer-bottom-bar { border-top:1px solid rgba(255,255,255,0.07); padding:20px 0; margin-top:60px; }
.footer-bottom-bar p { font-size:12px; color:rgba(255,255,255,0.25); margin:0; }
.footer-bottom-links { display:flex; gap:20px; flex-wrap:wrap; }
.footer-bottom-links a { font-size:12px; color:rgba(255,255,255,0.25); transition:color var(--transition); }
.footer-bottom-links a:hover { color:var(--gold); }

/* Floating buttons */
.wa-float { position:fixed; bottom:32px; right:32px; width:56px; height:56px; background:#25D366; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--white); font-size:24px; z-index:990; box-shadow:0 4px 20px rgba(37,211,102,0.45); transition:all var(--transition); text-decoration:none !important; }
.wa-float:hover { transform:scale(1.1) translateY(-3px); box-shadow:0 10px 32px rgba(37,211,102,0.55); color:var(--white); }
.wa-tooltip { position:absolute; right:66px; background:var(--ink); color:var(--white); font-size:11px; letter-spacing:1px; padding:7px 14px; border-radius:3px; white-space:nowrap; opacity:0; pointer-events:none; transition:opacity var(--transition); }
.wa-float:hover .wa-tooltip { opacity:1; }
.cart-fab { position:fixed; bottom:100px; right:32px; width:52px; height:52px; background:var(--gold); border-radius:50%; border:none; display:none; align-items:center; justify-content:center; color:var(--white); font-size:20px; z-index:990; cursor:pointer; box-shadow:0 4px 20px rgba(201,168,76,0.4); transition:all var(--transition); }
.cart-fab.show { display:flex; }
.cart-fab:hover { transform:scale(1.1); background:var(--gold-dark); }
.cart-fab-badge { position:absolute; top:-4px; right:-4px; background:var(--burgundy); color:var(--white); font-size:8px; font-weight:600; width:18px; height:18px; border-radius:50%; display:flex; align-items:center; justify-content:center; }

/* Toast */
#toast-stack { position:fixed; bottom:24px; left:24px; z-index:9999; display:flex; flex-direction:column-reverse; gap:10px; pointer-events:none; }
.sky-toast { background:var(--white); border:1px solid var(--border); border-left:3px solid var(--gold); box-shadow:var(--shadow-md); padding:13px 18px; border-radius:3px; font-size:13px; color:var(--ink); display:flex; align-items:center; gap:10px; min-width:260px; animation:toastSlide 0.4s ease; }
.sky-toast i { color:var(--gold); font-size:15px; flex-shrink:0; }
@keyframes toastSlide { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }

/* Reveal */
.reveal,.reveal-left,.reveal-right { transition:opacity 0.75s ease,transform 0.75s ease; }
.reveal { opacity:0; transform:translateY(36px); }
.reveal-left { opacity:0; transform:translateX(-36px); }
.reveal-right { opacity:0; transform:translateX(36px); }
.reveal.in,.reveal-left.in,.reveal-right.in { opacity:1; transform:translate(0); }
.d1{transition-delay:0.1s} .d2{transition-delay:0.2s} .d3{transition-delay:0.3s} .d4{transition-delay:0.4s} .d5{transition-delay:0.5s}

/* Active nav page highlight */
[data-active="home"] [data-nav="home"],
[data-active="about"] [data-nav="about"],
[data-active="menu"] [data-nav="menu"],
[data-active="wine"] [data-nav="wine"],
[data-active="rooms"] [data-nav="rooms"],
[data-active="contact"] [data-nav="contact"] { color:var(--gold-dark) !important; }

/* Responsive */
@media (max-width:991.98px) {
  .gallery-mosaic { grid-template-columns:repeat(2,1fr); grid-template-rows:auto; }
  .g-item { height:180px; }
  .g-item:nth-child(1),.g-item:nth-child(5) { grid-column:span 1; grid-row:span 1; }
}
@media (max-width:767.98px) {
  .section-pad { padding:70px 0; }
  .hero-cta-row { flex-direction:column; align-items:center; }
  .cart-panel { width:100vw; }
  .booking-form-card { padding:28px 22px; }
  .auth-form-panel { padding:28px 24px; }
  .welcome-badge-overlay { display:none; }
  .wa-float,.cart-fab { right:16px; }
  .wa-float { bottom:16px; }
  .cart-fab { bottom:80px; }
}
@media (max-width:575.98px) {
  .hero-title { font-size:3.2rem; }
  .gallery-mosaic { grid-template-columns:repeat(2,1fr); }
  .stat-num { font-size:2.4rem; }
  .menu-item-thumb { width:90px; min-width:90px; height:90px; }
}
@keyframes fadeInDown { from{opacity:0;transform:translateY(-20px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeInUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }