/* ═══════════════════════════════════════════════════════════════
   THE WEDDING BELL — v5  |  Glamorous · Vibrant · Professional
   ═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,600&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');

:root {
  /* Palette */
  --cream:#faf8f4; --ivory:#f3efe8; --light:#ebe5dc; --border:#ddd6ca; --border-dark:#c8bfb0;
  --ink:#1e1a16; --ink-soft:#32291f; --mid:#6a5f52; --muted:#9a8e82; --faint:#c4b9ae;
  --gold:#c49a35; --gold-deep:#a07c20; --gold-light:#ddb84e; --gold-pale:#f7edd8; --gold-subtle:#fdf4e3;
  --dark:#0f0d0a; --dark-2:#1a1510; --dark-3:#241e16; --dark-border:rgba(255,255,255,0.08);
  --rose:#b85555; --nav-h:70px;
}
body.fs-small{font-size:13px} body.fs-medium{font-size:15px} body.fs-large{font-size:17px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--ink);font-size:15px;line-height:1.75;overflow-x:hidden;max-width:100vw}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--dark)}::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px}
h1,h2,h3,h4,h5{font-family:'Cormorant Garamond',serif;font-weight:400;line-height:1.12;color:var(--ink-soft)}
p{color:var(--mid);line-height:1.8}
a{color:inherit;text-decoration:none}
strong{color:var(--ink)}
img{display:block}

/* ──────────── NAV ──────────── */
nav.site-nav{position:fixed;top:0;left:0;right:0;z-index:900;height:var(--nav-h);background:rgba(10,8,5,0.92);border-bottom:1px solid rgba(196,154,53,0.18);display:flex;align-items:center;justify-content:space-between;padding:0 52px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:all 0.35s}
nav.site-nav.scrolled{background:rgba(10,8,5,0.97);box-shadow:0 4px 40px rgba(0,0,0,0.5)}
.nav-brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.nav-brand-logo{height:38px;width:auto;object-fit:contain}
.nav-brand-text{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:600;color:rgba(255,255,255,0.9);letter-spacing:0.02em;line-height:1}
.nav-brand-text span{color:var(--gold-light)}
.nav-links{display:flex;gap:30px;list-style:none;align-items:center}
.nav-links a{font-size:10.5px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.5);transition:color 0.2s;padding:4px 0;border-bottom:1px solid transparent}
.nav-links a:hover,.nav-links a.active{color:var(--gold-light);border-bottom-color:var(--gold-light)}
.nav-cta{background:var(--gold);color:var(--dark);padding:9px 24px;font-size:10.5px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;border-radius:1px;transition:all 0.25s}
.nav-cta:hover{background:var(--gold-light);transform:translateY(-1px);box-shadow:0 6px 20px rgba(196,154,53,0.4)}
.nav-hamburger{display:none;background:none;border:none;cursor:pointer;font-size:22px;color:rgba(255,255,255,0.7)}
.page-wrapper{padding-top:var(--nav-h)}

/* ──────────── HERO SLIDER ──────────── */
.hero-slider{position:relative;height:92vh;min-height:580px;overflow:hidden;background:var(--dark)}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease}
.hero-slide.active{opacity:1;z-index:2}
.hero-slide-img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);transition:transform 6s ease}
.hero-slide.active .hero-slide-img{transform:scale(1)}
.hero-slide-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(10,8,5,0.75) 0%,rgba(10,8,5,0.35) 60%,transparent 100%)}
.hero-slide-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding:0 80px;z-index:3}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:10px;letter-spacing:0.3em;text-transform:uppercase;color:var(--gold-light);font-weight:500;margin-bottom:18px;opacity:0;transform:translateY(16px);transition:all 0.7s 0.3s}
.hero-slide.active .hero-eyebrow{opacity:1;transform:translateY(0)}
.hero-eyebrow-icon{font-size:18px}
.hero-title{font-size:clamp(44px,6.5vw,88px);font-weight:300;color:rgba(255,255,255,0.96);line-height:1.04;max-width:680px;opacity:0;transform:translateY(22px);transition:all 0.8s 0.5s}
.hero-slide.active .hero-title{opacity:1;transform:translateY(0)}
.hero-title em{font-style:italic;color:var(--gold-light)}
.hero-subtitle{font-size:16px;color:rgba(255,255,255,0.5);max-width:420px;margin-top:16px;font-weight:300;line-height:1.9;opacity:0;transform:translateY(16px);transition:all 0.8s 0.7s}
.hero-slide.active .hero-subtitle{opacity:1;transform:translateY(0)}
.hero-slide-cta{display:flex;gap:12px;margin-top:32px;opacity:0;transform:translateY(14px);transition:all 0.7s 0.9s}
.hero-slide.active .hero-slide-cta{opacity:1;transform:translateY(0)}
/* Stats bar */
.hero-stats-bar{position:static;display:flex;width:100%;background:#1a1510;border-top:2px solid rgba(196,154,53,0.3)}
.hero-stat{flex:1;text-align:center;padding:14px 10px;border-right:1px solid var(--dark-border)}
.hero-stat:last-child{border-right:none}
.hero-stat-num{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:500;color:var(--gold-light);line-height:1}
.hero-stat-label{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-top:3px}
/* Slider controls */
.hero-dots{position:absolute;bottom:72px;right:52px;z-index:11;display:flex;gap:7px}
.hero-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.3);border:none;cursor:pointer;padding:0;transition:all 0.3s}
.hero-dot.active{background:var(--gold);width:22px;border-radius:3px}
.hero-arrows{position:absolute;top:50%;transform:translateY(-50%);z-index:11;width:100%;display:flex;justify-content:space-between;padding:0 20px;pointer-events:none}
.hero-arrow{pointer-events:all;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);color:rgba(255,255,255,0.6);font-size:22px;cursor:pointer;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all 0.2s;backdrop-filter:blur(4px)}
.hero-arrow:hover{background:rgba(196,154,53,0.3);border-color:var(--gold);color:var(--gold-light)}

/* ──────────── PORTFOLIO GRID (snapshotbd style) ──────────── */
.portfolio-section{background:var(--ink)}
.portfolio-section-header{padding:56px 52px 40px;display:flex;align-items:flex-end;justify-content:space-between}
.portfolio-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;padding:0 0 3px}
.portfolio-col{display:flex;flex-direction:column;gap:3px}
/* Landscape items */
.portfolio-col.landscape .portfolio-item{aspect-ratio:4/3}
/* Portrait items */
.portfolio-col.portrait .portfolio-item{aspect-ratio:2/3}
.portfolio-item{position:relative;overflow:hidden;cursor:pointer;background:var(--dark-3)}
.portfolio-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.65s ease,filter 0.4s}
.portfolio-item:hover img{transform:scale(1.06);filter:brightness(0.7)}
.portfolio-item-info{position:absolute;bottom:0;left:0;right:0;padding:20px 20px 16px;background:linear-gradient(to top,rgba(10,8,5,0.85) 0%,transparent 100%);transform:translateY(8px);opacity:0;transition:all 0.35s}
.portfolio-item:hover .portfolio-item-info{opacity:1;transform:translateY(0)}
.portfolio-item-name{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;color:rgba(255,255,255,0.92)}
.portfolio-item-type{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold-light);margin-top:2px}
.portfolio-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px;color:rgba(255,255,255,0.1)}

/* ──────────── SECTIONS ──────────── */
.section{padding:88px 52px}
.section-dark{background:var(--dark)}
.section-dark-2{background:var(--dark-2)}
.section-ivory{background:var(--ivory)}
.section-light{background:var(--light)}
.section-gold{background:var(--gold-subtle)}
.section-inner{max-width:1300px;margin:0 auto}
.eyebrow{font-size:10px;letter-spacing:0.28em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:10px}
.eyebrow::before{content:'';display:block;width:24px;height:1px;background:var(--gold)}
.eyebrow-center{justify-content:center}
.eyebrow-center::before,.eyebrow-center::after{content:'';display:block;width:24px;height:1px;background:var(--gold)}
.section-title{font-size:clamp(28px,3.8vw,50px);font-weight:400;color:var(--ink-soft);line-height:1.14;margin-bottom:12px}
.section-title em{font-style:italic;color:var(--gold)}
.section-title-light{color:rgba(255,255,255,0.94)}
.section-body{font-size:15px;color:var(--mid);max-width:520px;line-height:1.85}
.section-body-light{color:rgba(255,255,255,0.45)}
.divider{width:40px;height:1.5px;background:var(--gold);margin:16px 0}
.divider-center{margin:16px auto}
.text-center{text-align:center}
.text-center .section-body{margin:0 auto}

/* ──────────── BUTTONS ──────────── */
.btn{display:inline-block;border:none;border-radius:1px;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;transition:all 0.25s;padding:12px 30px;line-height:1}
.btn-gold{background:var(--gold);color:var(--dark)}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-1px);box-shadow:0 6px 20px rgba(196,154,53,0.35)}
.btn-ink{background:var(--ink);color:var(--cream)}
.btn-ink:hover{background:var(--ink-soft);transform:translateY(-1px)}
.btn-dark{background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.85);border:1px solid rgba(255,255,255,0.15)}
.btn-dark:hover{background:rgba(255,255,255,0.14);border-color:var(--gold);color:var(--gold-light)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--cream)}
.btn-outline-gold{background:transparent;color:var(--gold);border:1.5px solid var(--gold)}
.btn-outline-gold:hover{background:var(--gold);color:var(--dark)}
.btn-outline-light{background:transparent;color:rgba(255,255,255,0.75);border:1px solid rgba(255,255,255,0.25)}
.btn-outline-light:hover{border-color:var(--gold-light);color:var(--gold-light)}
.btn-sm{padding:7px 17px;font-size:9.5px}

/* ──────────── SERVICES (glamorous grid) ──────────── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:linear-gradient(135deg,var(--dark) 0%,var(--dark-3) 100%);border:2px solid rgba(196,154,53,0.15);margin-top:48px}
.service-card{position:relative;overflow:hidden;cursor:pointer;min-height:280px;display:flex;flex-direction:column;background:var(--dark-2);transition:background 0.3s}
.service-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(196,154,53,0.06) 0%,transparent 60%);opacity:0;transition:opacity 0.3s;z-index:1}
.service-card:hover{background:var(--dark-3)}
.service-card:hover::before{opacity:1}
.service-card-img{width:100%;height:180px;object-fit:cover;filter:brightness(0.7) saturate(0.9);transition:all 0.5s;flex-shrink:0}
.service-card:hover .service-card-img{filter:brightness(0.85) saturate(1.1);transform:scale(1.04)}
.service-card-img-ph{width:100%;height:180px;background:var(--dark-3);display:flex;align-items:center;justify-content:center;font-size:36px;flex-shrink:0}
.service-card-body{padding:22px 22px 20px;flex:1;position:relative;z-index:2}
.service-card-num{font-family:'Cormorant Garamond',serif;font-size:11px;color:var(--gold);letter-spacing:0.2em;margin-bottom:8px}
.service-title{font-size:22px;font-weight:500;color:rgba(255,255,255,0.9);margin-bottom:7px;transition:color 0.3s}
.service-card:hover .service-title{color:var(--gold-light)}
.service-desc{font-size:12.5px;color:rgba(255,255,255,0.4);line-height:1.75;transition:color 0.3s}
.service-card:hover .service-desc{color:rgba(255,255,255,0.6)}
.service-albums{margin-top:14px;padding-top:12px;border-top:1px solid rgba(255,255,255,0.06);display:flex;flex-wrap:wrap;gap:5px}
.service-album-link{display:flex;align-items:center;gap:6px;font-size:11px;color:rgba(255,255,255,0.4);padding:4px 8px;border:1px solid rgba(255,255,255,0.08);border-radius:1px;transition:all 0.2s}
.service-album-link:hover{border-color:var(--gold);color:var(--gold-light)}
.service-album-link img{width:20px;height:20px;object-fit:cover;border-radius:1px}
.service-card-arrow{position:absolute;top:18px;right:18px;width:28px;height:28px;border:1px solid rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;font-size:13px;color:rgba(255,255,255,0.3);transition:all 0.3s;z-index:2}
.service-card:hover .service-card-arrow{border-color:var(--gold);color:var(--gold-light);transform:rotate(45deg)}

/* ──────────── WHY US ──────────── */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.why-img-wrap{position:relative}
.why-img{width:100%;aspect-ratio:3/4;object-fit:cover}
.why-img-ph{width:100%;aspect-ratio:3/4;background:var(--dark-3);display:flex;align-items:center;justify-content:center;font-size:72px}
.why-accent-box{position:absolute;bottom:-20px;right:-20px;background:var(--gold);padding:18px 22px;text-align:center}
.why-accent-num{font-family:'Cormorant Garamond',serif;font-size:40px;font-weight:600;color:var(--dark);line-height:1}
.why-accent-lbl{font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--dark);opacity:0.7;margin-top:3px}
.why-points{display:flex;flex-direction:column;gap:22px;margin-top:30px}
.why-point{display:flex;gap:18px;align-items:flex-start}
.why-num{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:300;color:var(--gold);line-height:1;min-width:30px}
.why-point-text h4{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;margin-bottom:3px;color:var(--ink)}
.why-point-text p{font-size:13px;color:var(--mid)}

/* ──────────── FEATURED PACKAGES (glamorous) ──────────── */
.featured-pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid rgba(196,154,53,0.2);margin-top:44px}
.featured-pkg-card{background:var(--dark-2);border-right:1px solid rgba(196,154,53,0.12);position:relative;overflow:hidden;transition:background 0.3s;cursor:pointer}
.featured-pkg-card:last-child{border-right:none}
.featured-pkg-card:hover{background:var(--dark-3)}
.featured-pkg-card.highlight{background:linear-gradient(160deg,var(--dark-3) 0%,rgba(196,154,53,0.08) 100%)}
.featured-pkg-img{width:100%;aspect-ratio:3/2;overflow:hidden;position:relative}
.featured-pkg-img img{width:100%;height:100%;object-fit:cover;filter:brightness(0.75);transition:all 0.5s}
.featured-pkg-card:hover .featured-pkg-img img{transform:scale(1.05);filter:brightness(0.9)}
.featured-pkg-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--dark-3) 0%,transparent 50%)}
.featured-pkg-label{position:absolute;top:14px;left:14px;background:var(--gold);color:var(--dark);font-size:8px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;padding:3px 9px}
.featured-pkg-body{padding:22px 22px 26px}
.featured-pkg-series{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:7px}
.featured-pkg-title{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:rgba(255,255,255,0.92);margin-bottom:10px}
.featured-pkg-feats{list-style:none;display:flex;flex-direction:column;gap:5px;margin-bottom:16px}
.featured-pkg-feats li{font-size:12px;color:rgba(255,255,255,0.45);display:flex;align-items:flex-start;gap:7px}
.featured-pkg-feats li::before{content:'';width:3px;height:3px;background:var(--gold);border-radius:50%;flex-shrink:0;margin-top:7px}
.featured-pkg-price-wrap{border-top:1px solid rgba(196,154,53,0.15);padding-top:14px;display:flex;align-items:flex-end;justify-content:space-between}
.featured-pkg-orig{font-size:12px;color:rgba(255,255,255,0.25);text-decoration:line-through;display:block}
.featured-pkg-price{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:500;color:var(--gold-light);line-height:1}
.featured-pkg-price-lbl{font-family:'DM Sans',sans-serif;font-size:10px;color:rgba(255,255,255,0.3)}
.featured-pkg-quote{font-size:13px;color:rgba(255,255,255,0.3);font-style:italic}
@media(max-width:900px){.featured-pkg-grid{grid-template-columns:1fr}}

/* ──────────── OFFERS ──────────── */
.offers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:36px}
.offer-card{background:var(--dark-2);border:1px solid rgba(196,154,53,0.15);overflow:hidden;transition:transform 0.25s,border-color 0.25s}
.offer-card:hover{transform:translateY(-3px);border-color:rgba(196,154,53,0.4)}
.offer-card-img{height:150px;overflow:hidden;background:var(--dark-3);display:flex;align-items:center;justify-content:center;font-size:36px;color:var(--gold)}
.offer-card-img img{width:100%;height:100%;object-fit:cover}
.offer-card-body{padding:20px}
.offer-card-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:rgba(255,255,255,0.9);margin-bottom:8px}
.offer-card-desc{font-size:12.5px;color:rgba(255,255,255,0.4);margin-bottom:12px;line-height:1.75}
.offer-combo{font-size:11px;color:var(--gold);background:rgba(196,154,53,0.08);padding:6px 10px;border-left:2px solid var(--gold);margin-bottom:10px}
.offer-time{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;color:rgba(255,255,255,0.3);background:rgba(255,255,255,0.04);padding:4px 10px;border:1px solid rgba(255,255,255,0.08)}
/* Offer topbar in package detail */
.offer-topbar{background:rgba(196,154,53,0.08);border:1px solid rgba(196,154,53,0.2);border-left:3px solid var(--gold);padding:12px 16px;display:flex;align-items:center;gap:12px;margin-bottom:10px}
.offer-topbar-icon{font-size:20px}
.offer-topbar-body{flex:1}
.offer-topbar-title{font-weight:600;font-size:13px;color:rgba(255,255,255,0.9)}
.offer-topbar-time{font-size:11px;color:rgba(255,255,255,0.4)}
.offer-topbar a{font-size:11px;color:var(--gold-light);font-weight:600;white-space:nowrap;flex-shrink:0}

/* ──────────── TESTIMONIALS (dark, glamorous) ──────────── */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1px;background:rgba(255,255,255,0.06);margin-top:44px}
.tcard{background:var(--dark-2);padding:32px 28px;position:relative;overflow:hidden;transition:background 0.3s}
.tcard:hover{background:var(--dark-3)}
.tcard::before{content:'"';position:absolute;top:-10px;right:20px;font-family:'Cormorant Garamond',serif;font-size:120px;color:rgba(196,154,53,0.06);line-height:1}
.tcard-stars{display:flex;gap:3px;margin-bottom:14px}
.tcard-star{font-size:14px;color:rgba(255,255,255,0.15)}
.tcard-star.filled{color:var(--gold-light)}
.tcard-text{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:300;font-style:italic;color:rgba(255,255,255,0.7);line-height:1.65;margin-bottom:22px;position:relative;z-index:1}
.tcard-author{display:flex;align-items:center;gap:12px}
.tcard-avatar{width:38px;height:38px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:500;color:var(--dark);flex-shrink:0}
.tcard-name{font-size:13px;font-weight:600;color:rgba(255,255,255,0.8)}
.tcard-event{font-size:10.5px;color:var(--gold-light);margin-top:1px}

/* ──────────── CTA BANNER ──────────── */
.cta-banner{background:linear-gradient(135deg,var(--dark) 0%,var(--dark-3) 100%);padding:80px 52px;text-align:center;position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(196,154,53,0.08) 0%,transparent 70%)}

/* ──────────── FOOTER ──────────── */
.site-footer{background:var(--dark);padding:60px 52px 28px;overflow-x:hidden}
.footer-inner{max-width:1300px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.footer-brand-logo{height:34px;width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:0.7}
.footer-brand-text{font-family:'Cormorant Garamond',serif;font-size:20px;color:rgba(255,255,255,0.85);font-weight:600}
.footer-brand-text span{color:var(--gold-light)}
.footer-tagline{font-size:13px;color:rgba(255,255,255,0.26);line-height:1.85;max-width:220px}
.footer-col h5{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold-light);font-weight:600;margin-bottom:16px;font-family:'DM Sans',sans-serif}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-col ul li a{font-size:13px;color:rgba(255,255,255,0.32);transition:color 0.2s}
.footer-col ul li a:hover{color:var(--gold-light)}
.footer-map-wrap{margin-top:16px;border-radius:1px;overflow:hidden;opacity:0.7;transition:opacity 0.2s}
.footer-map-wrap:hover{opacity:1}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.06);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:11px;color:rgba(255,255,255,0.18)}
.footer-socials{display:flex;gap:8px}
.footer-social{width:38px;height:38px;border:1px solid rgba(255,255,255,0.09);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.3);font-size:15px;border-radius:50%;transition:all 0.2s}
.footer-social:hover{border-color:var(--gold);color:var(--gold-light);background:rgba(196,154,53,0.1)}

/* ──────────── WHATSAPP ──────────── */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:800;width:52px;height:52px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:0 4px 20px rgba(37,211,102,0.45);transition:transform 0.2s}
.wa-float:hover{transform:scale(1.1)}

/* ──────────── LIGHTBOX ──────────── */
.lightbox-overlay{position:fixed;inset:0;z-index:9000;background:rgba(5,4,2,0.97);display:none;align-items:center;justify-content:center}
.lightbox-overlay.open{display:flex}
.lightbox-img{max-width:90vw;max-height:88vh;object-fit:contain}
.lightbox-close{position:absolute;top:18px;right:22px;font-size:28px;color:rgba(255,255,255,0.35);cursor:pointer;background:none;border:none;transition:color 0.2s}
.lightbox-close:hover{color:white}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.06);border:none;color:rgba(255,255,255,0.4);font-size:28px;cursor:pointer;padding:10px 14px;transition:all 0.2s}
.lightbox-nav:hover{background:rgba(196,154,53,0.2);color:var(--gold-light)}
.lightbox-prev{left:18px}.lightbox-next{right:18px}

/* ──────────── PAGE HEADER ──────────── */
.page-header{background:linear-gradient(135deg,var(--dark) 0%,var(--dark-3) 100%);border-bottom:1px solid rgba(196,154,53,0.15);padding:56px 52px 44px;text-align:center;position:relative}
.page-header::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:80px;height:2px;background:linear-gradient(to right,transparent,var(--gold),transparent)}

/* ──────────── PACKAGES ──────────── */
.pkg-layout{display:grid;grid-template-columns:220px 1fr;max-width:1400px;margin:0 auto;min-height:80vh}
.pkg-sidebar{background:var(--ink);border-right:1px solid rgba(255,255,255,0.06);padding:20px 14px;position:sticky;top:var(--nav-h);height:calc(100vh - var(--nav-h));overflow-y:auto}
.pkg-sidebar::-webkit-scrollbar{width:2px}
.pkg-sidebar-section{margin-bottom:22px}
.pkg-sidebar-title{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,0.07)}
.pkg-filter-link{display:flex;align-items:center;justify-content:space-between;padding:7px 9px;font-size:12.5px;color:rgba(255,255,255,0.4);text-decoration:none;transition:all 0.15s;margin-bottom:1px;border-left:2px solid transparent}
.pkg-filter-link:hover{color:rgba(255,255,255,0.8);background:rgba(255,255,255,0.04);border-left-color:rgba(196,154,53,0.4)}
.pkg-filter-link.active{color:var(--gold-light);background:rgba(196,154,53,0.08);border-left-color:var(--gold)}
.pkg-filter-link .cnt{font-size:9px;background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.3);padding:1px 6px;border-radius:8px}
.pkg-filter-link.active .cnt{background:rgba(196,154,53,0.15);color:var(--gold-light)}
.pkg-main{background:var(--ivory)}
.pkg-topbar{background:var(--cream);border-bottom:1px solid var(--border);padding:11px 22px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;position:sticky;top:var(--nav-h);z-index:90}
.pkg-sort-inline{display:flex;align-items:center;gap:8px}
.pkg-sort-inline label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.pkg-sort-inline select{padding:5px 10px;border:1px solid var(--border);background:var(--cream);font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);border-radius:1px}
.pkg-grid-wrap{padding:22px 22px 64px}
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:14px}

/* Package card — square image */
.pkg-card{background:var(--cream);border:1px solid var(--border);overflow:hidden;transition:transform 0.25s,box-shadow 0.25s;position:relative}
.pkg-card:hover{transform:translateY(-4px);box-shadow:0 14px 44px rgba(30,26,22,0.14)}
.pkg-card.featured{border-color:var(--gold)}
.pkg-card-img{aspect-ratio:1/1;background:var(--light);overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;font-size:40px}
.pkg-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.45s}
.pkg-card:hover .pkg-card-img img{transform:scale(1.05)}
.pkg-card-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(30,26,22,0.45),transparent 55%)}
.pkg-badge-featured{position:absolute;top:12px;left:12px;z-index:2;background:var(--gold);color:var(--dark);font-size:8.5px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:3px 9px}
.pkg-badge-series{position:absolute;top:12px;right:12px;z-index:2;font-size:8.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 9px;background:rgba(30,26,22,0.78);color:rgba(255,255,255,0.85);backdrop-filter:blur(4px)}
.pkg-body{padding:15px}
.pkg-title{font-size:17px;font-weight:500;margin-bottom:8px;color:var(--ink-soft);cursor:pointer}
.pkg-features{list-style:none;margin-bottom:12px;display:flex;flex-direction:column;gap:3px}
.pkg-features li{font-size:12px;color:var(--mid);display:flex;align-items:flex-start;gap:6px}
.pkg-features li::before{content:'';width:3px;height:3px;background:var(--gold);border-radius:50%;flex-shrink:0;margin-top:7px}
.pkg-footer{display:flex;align-items:flex-end;justify-content:space-between;padding-top:11px;border-top:1px solid var(--border)}
.pkg-price-original{font-size:12px;color:var(--muted);text-decoration:line-through}
.pkg-price-discounted{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:500;color:var(--gold);line-height:1.1}
.pkg-price-main{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;color:var(--ink);line-height:1.1}
.pkg-price-label{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--muted)}
.pkg-price-quote{font-size:13px;color:var(--muted);font-style:italic}

/* Package detail */
.detail-wrap{max-width:1200px;margin:0 auto;padding:38px 52px 90px}
.detail-grid{display:grid;grid-template-columns:1fr 340px;gap:52px;align-items:start}
.detail-series-badge{display:inline-block;padding:3px 10px;font-size:8.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px;background:var(--gold-subtle);color:var(--gold-deep);border:1px solid rgba(196,154,53,0.25)}
.detail-title{font-size:clamp(28px,4vw,48px);margin-bottom:8px;color:var(--ink-soft)}
.detail-img{aspect-ratio:1/1;overflow:hidden;margin:20px 0;background:var(--light)}
.detail-img img{width:100%;height:100%;object-fit:cover}
.detail-criteria{border:1px solid var(--border);margin:20px 0}
.detail-criteria summary{padding:12px 16px;cursor:pointer;font-size:13px;font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center;background:var(--ivory)}
.detail-criteria summary::-webkit-details-marker{display:none}
.detail-criteria summary::after{content:'+';font-size:20px;color:var(--gold);font-weight:300}
.detail-criteria[open] summary::after{content:'−'}
.detail-criteria-table{width:100%;border-collapse:collapse}
.detail-criteria-table td{padding:9px 16px;border-bottom:1px solid var(--border);font-size:13px}
.detail-criteria-table tr:last-child td{border-bottom:none}
.detail-criteria-table td:first-child{color:var(--muted);width:50%;background:var(--ivory)}
.detail-criteria-table td:last-child{font-weight:500;color:var(--ink)}

/* Compare table */
.compare-section{margin-top:52px;padding-top:40px;border-top:1px solid var(--border)}
.compare-table-wrap{overflow-x:auto;margin-top:16px;border:1px solid var(--border)}
.compare-table{width:100%;border-collapse:collapse;min-width:500px}
.compare-table th{background:var(--ink);color:var(--cream);padding:12px 16px;font-size:10.5px;font-weight:600;letter-spacing:.08em;text-align:left;white-space:nowrap}
.compare-table th:first-child{background:var(--ink-soft)}
.compare-table td{padding:10px 16px;border-bottom:1px solid var(--border);font-size:13px}
.compare-table tr:nth-child(even) td{background:var(--ivory)}
.compare-table td:first-child{font-weight:600;color:var(--ink);background:var(--light);white-space:nowrap}
.compare-check{color:#3a7d35;font-weight:700}
.compare-cross{color:var(--muted)}
/* Booking card */
.booking-card{background:var(--cream);border:1px solid var(--border);padding:26px;position:sticky;top:calc(var(--nav-h)+16px)}
.booking-price-original{font-size:13px;color:var(--muted);text-decoration:line-through}
.booking-price-main{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:500;line-height:1;color:var(--ink)}
.booking-price-main.discounted{color:var(--gold)}
.booking-price-label{font-size:11px;color:var(--muted);margin-top:2px}
.booking-divider{border:none;border-top:1px solid var(--border);margin:16px 0}
.booking-meta{font-size:12px;color:var(--mid);display:flex;flex-direction:column;gap:5px;margin-bottom:16px}
.booking-meta span{display:flex;align-items:center;gap:7px}

/* Add-ons */
.addons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-top:10px}
.addon-card{border:1px solid var(--border);background:var(--cream);padding:12px;transition:border-color 0.2s}
.addon-card:hover{border-color:var(--gold)}
.addon-img{aspect-ratio:1/1;background:var(--light);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:10px;overflow:hidden}
.addon-img img{width:100%;height:100%;object-fit:cover}
.addon-code{font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:2px}
.addon-name{font-weight:600;font-size:13px;margin-bottom:2px;color:var(--ink)}
.addon-desc{font-size:11px;color:var(--muted);line-height:1.5;margin-bottom:5px}
.addon-price{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--ink)}

/* ──────────── GALLERY ──────────── */
.gallery-wrap{max-width:1400px;margin:0 auto;padding:0 52px 80px}
.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-top:28px}
.album-card{background:var(--dark-2);border:1px solid rgba(196,154,53,0.1);overflow:hidden;cursor:pointer;transition:transform 0.25s,border-color 0.25s}
.album-card:hover{transform:translateY(-3px);border-color:rgba(196,154,53,0.35)}
.album-thumb{aspect-ratio:4/3;background:var(--dark-3);overflow:hidden;position:relative}
.album-thumb img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s,filter 0.3s}
.album-card:hover .album-thumb img{transform:scale(1.06);filter:brightness(0.85)}
.album-thumb-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:36px}
.album-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,8,5,0.75),transparent);display:flex;align-items:flex-end;padding:16px;opacity:0;transition:opacity 0.3s}
.album-card:hover .album-overlay{opacity:1}
.album-overlay-cta{font-size:11px;font-weight:600;color:rgba(255,255,255,0.9);letter-spacing:.1em;text-transform:uppercase}
.album-body{padding:14px 16px}
.album-title{font-size:16px;font-weight:500;color:rgba(255,255,255,0.85);margin-bottom:4px}
.album-meta{font-size:11px;color:rgba(255,255,255,0.3);display:flex;gap:8px;flex-wrap:wrap}
.album-type-badge{display:inline-block;padding:2px 8px;background:rgba(196,154,53,0.12);color:var(--gold-light);font-size:9px;text-transform:uppercase;letter-spacing:.08em}
.gallery-filter{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:22px}

/* ──────────── TEAM ──────────── */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:22px;margin-top:44px}
.team-card{text-align:center;background:var(--dark-2);border:1px solid rgba(196,154,53,0.1);padding:30px 22px;transition:all 0.3s}
.team-card:hover{border-color:rgba(196,154,53,0.35);transform:translateY(-3px)}
.team-photo{width:100px;height:100px;border-radius:50%;margin:0 auto 16px;overflow:hidden;background:var(--dark-3);display:flex;align-items:center;justify-content:center;font-size:32px;border:2px solid rgba(196,154,53,0.25)}
.team-photo img{width:100%;height:100%;object-fit:cover}
.team-name{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:rgba(255,255,255,0.9)}
.team-role{font-size:9.5px;color:var(--gold-light);letter-spacing:.12em;text-transform:uppercase;margin-top:3px}
.team-exp{font-size:11px;color:rgba(255,255,255,0.3);margin-top:4px}
.team-bio{font-size:12.5px;color:rgba(255,255,255,0.4);margin-top:10px;line-height:1.7}
.team-socials{display:flex;gap:8px;justify-content:center;margin-top:14px}
.team-social{width:30px;height:30px;border:1px solid rgba(255,255,255,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:rgba(255,255,255,0.3);transition:all 0.2s;text-decoration:none}
.team-social:hover{border-color:var(--gold);color:var(--gold-light)}

/* ──────────── BLOG ──────────── */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:22px;margin-top:36px}
.blog-card{background:var(--dark-2);border:1px solid rgba(196,154,53,0.1);overflow:hidden;transition:transform 0.25s,border-color 0.25s}
.blog-card:hover{transform:translateY(-3px);border-color:rgba(196,154,53,0.3)}
.blog-cover{aspect-ratio:16/9;background:var(--dark-3);overflow:hidden;position:relative}
.blog-cover img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s}
.blog-card:hover .blog-cover img{transform:scale(1.04)}
.blog-cover-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:40px}
.blog-body{padding:22px}
.blog-meta{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,0.25);margin-bottom:10px;display:flex;gap:12px;flex-wrap:wrap}
.blog-meta .author{color:var(--gold-light);font-weight:600}
.blog-title{font-family:'Cormorant Garamond',serif;font-size:23px;font-weight:400;color:rgba(255,255,255,0.88);margin-bottom:10px;line-height:1.25}
.blog-excerpt{font-size:13px;color:rgba(255,255,255,0.38);line-height:1.75;margin-bottom:16px}
.blog-read-more{font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:5px;transition:gap 0.2s}
.blog-read-more:hover{gap:9px}
.blog-post-wrap{max-width:800px;margin:0 auto;padding:52px 52px 90px}
.blog-img-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;margin:28px 0}
.blog-img-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;cursor:pointer}
.blog-story{font-size:16px;line-height:2;color:var(--ink)}
.blog-story p{margin-bottom:1.5em}

/* ──────────── CONTACT ──────────── */
.contact-tabs-wrap{background:var(--dark-2);border-bottom:1px solid rgba(196,154,53,0.15)}
.contact-tabs{display:flex;justify-content:flex-end;padding:0 48px}
.contact-tab{padding:16px 28px;font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border:none;background:none;color:rgba(255,255,255,0.35);border-bottom:2px solid transparent;margin-bottom:-1px;font-family:'DM Sans',sans-serif;transition:all .25s}
.contact-tab:hover{color:rgba(255,255,255,0.7);background:rgba(255,255,255,0.03)}
.contact-tab.active{color:var(--gold-light);background:rgba(196,154,53,0.07);border-bottom-color:var(--gold)}
.contact-layout{display:grid;grid-template-columns:1fr 1.5fr;min-height:72vh}
.contact-info-panel{background:var(--dark-3);padding:52px 44px}
.contact-form-panel{background:var(--cream);padding:52px 48px}
.contact-details{margin-top:30px;display:flex;flex-direction:column;gap:20px}
.contact-item{display:flex;gap:14px}
.contact-icon{width:38px;height:38px;border:1px solid rgba(196,154,53,0.25);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.contact-lbl{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-light);margin-bottom:2px}
.contact-val{font-size:13px;color:rgba(255,255,255,0.7);line-height:1.65}

/* FORM */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:22px}
.form-field{display:flex;flex-direction:column;gap:4px}
.form-field.full{grid-column:1/-1}
.form-field label{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700;font-family:'DM Sans',sans-serif}
.form-field input,.form-field select,.form-field textarea{padding:10px 13px;border:1px solid var(--border);background:var(--ivory);font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);outline:none;border-radius:1px;transition:border-color 0.2s}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--gold)}
.form-field textarea{resize:vertical;min-height:90px}
.event-item{border:1px solid var(--border);border-left:2px solid var(--gold);padding:16px;margin-bottom:10px;background:var(--ivory);position:relative}
.event-item-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.event-item-remove{position:absolute;top:10px;right:12px;background:none;border:none;cursor:pointer;color:var(--muted);font-size:16px;transition:color .2s}
.event-item-remove:hover{color:var(--rose)}
.time-range{display:grid;grid-template-columns:1fr 1fr;gap:8px}

/* ALERTS */
.alert{padding:12px 16px;border-radius:1px;margin-bottom:18px;font-size:13px}
.alert-success{background:#edf7e8;border:1px solid #b8d9a8;color:#2d6e20}
.alert-error{background:#fdf0f0;border:1px solid #f0b0a8;color:#8a2020}

/* ──────────── RESPONSIVE ──────────── */
@media(max-width:1024px){
  .pkg-layout,.detail-grid,.why-grid,.contact-layout{grid-template-columns:1fr}
  .pkg-sidebar{position:static;height:auto;border-right:none;border-bottom:1px solid rgba(255,255,255,0.06)}
  .booking-card{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-slide-content{padding:0 40px}
  .featured-pkg-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  nav.site-nav{padding:0 20px}
  .nav-links{display:none}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:var(--nav-h);left:0;right:0;background:rgba(10,8,5,0.97);border-bottom:1px solid rgba(196,154,53,0.15);padding:12px 20px 16px;gap:0}
  .nav-links.open a{padding:11px 0;font-size:13px;border-bottom:none}
  .nav-hamburger{display:block}
  .section{padding:52px 22px}
  .page-header{padding:40px 22px 32px}
  .portfolio-grid{grid-template-columns:1fr}
  .hero-slide-content{padding:0 22px}
  .hero-title{font-size:clamp(34px,8vw,56px)}
  .hero-stats-bar{flex-wrap:wrap}
  .hero-stat{padding:10px 18px}
  .site-footer{padding:44px 22px 24px}
  .gallery-wrap{padding:0 18px 52px}
  .detail-wrap{padding:22px 18px 52px}
  .contact-tabs{justify-content:flex-start;padding:0 18px}
  .contact-form-panel,.contact-info-panel{padding:34px 22px}
  .blog-post-wrap{padding:30px 18px 52px}
  .footer-grid{grid-template-columns:1fr}
  .cta-banner{padding:52px 22px}
  .portfolio-section-header{flex-direction:column;gap:14px;align-items:flex-start}
}