 :root {
     /* GOLD SYSTEM (slightly brighter for dark bg) */
     --gold: #D4A94E;
     --gold-light: #F0D898;
     --gold-dark: #8A6418;
     --gold-pale: #FFF3CC;

     /* DARK BACKGROUNDS */
     --warm-bg: #0E0E0E;
     --warm-mid: #151515;
     --warm-deep: #1C1C1C;
     --warm-card: #121212;

     /* TEXT COLORS (optimized for readability) */
     --text-dark: #FFFFFF;
     --text-mid: #E6D3A3;
     --text-light: #BFA77A;

     /* BASE */
     --white: #FFFFFF;

     /* BORDERS & SHADOW */
     --border: rgba(212, 169, 78, 0.25);
     --shadow: rgba(0, 0, 0, 0.6);
     --black: #000000;

     /* OPTIONAL: RICH DARK BROWN (for accents if needed) */
     --brown: #1A1208;
 }

 * {
     margin: 0;
     padding: 0;
     box-sizing: border-box
 }

 html {
     scroll-behavior: smooth
 }

 body {
     background: var(--warm-bg);
     color: var(--text-dark);
     overflow-x: hidden
 }



 .hd-outer-wrapper {
     display: flex;
     justify-content: flex-end;
     align-items: center;
     gap: 0px;
     padding: 0px 0px 10px 0;
     flex-wrap: wrap;
 }

 /* ── Helpdesk Card ── */
 .hd-outer-wrapper .hd-card {
     border-radius: 16px;
     padding-right: 0px;
     display: flex;
     align-items: center;
     gap: 16px;
     position: relative;
     overflow: hidden;
     cursor: pointer;
     transition: transform 0.18s ease, box-shadow 0.18s ease;
     text-decoration: none;
 }




 .hd-outer-wrapper .hd-card:active {
     transform: translateY(0);
 }

 /* ── Icon Wrap ── */
 .hd-outer-wrapper .hd-card .hd-icon-wrap {
     width: 36px;
     height: 36px;
     border-radius: 12px;
     background: linear-gradient(135deg, var(--gold), var(--gold-dark));
     display: flex;
     align-items: center;
     justify-content: center;
     flex-shrink: 0;
     box-shadow: 0 2px 8px rgba(184, 137, 42, 0.30);
     position: relative;
 }

 .hd-outer-wrapper .hd-card .hd-icon-wrap i {
     color: var(--gold-pale);
     font-size: 20px;
 }

 .hd-outer-wrapper .hd-card .hd-icon-wrap .hd-pulse-ring {
     position: absolute;
     inset: -4px;
     border-radius: 15px;
     border: 1.5px solid var(--gold-light);
     animation: hdPulse 2.2s ease-in-out infinite;
     opacity: 0;
 }

 @keyframes hdPulse {
     0% {
         opacity: 0;
         transform: scale(0.92);
     }

     40% {
         opacity: 0.55;
     }

     100% {
         opacity: 0;
         transform: scale(1.12);
     }
 }

 /* ── Info Block ── */
 .hd-outer-wrapper .hd-card .hd-info {
     display: flex;
     flex-direction: column;
     gap: 2px;
     text-decoration: none;
 }

 .hd-outer-wrapper .hd-card .hd-info .hd-label {
     font-size: 11px;
     font-weight: 600;
     letter-spacing: 0.09em;
     text-transform: uppercase;
     color: var(--text-light);
     display: flex;
     align-items: center;
     gap: 5px;
 }

 .hd-outer-wrapper .hd-card .hd-info .hd-label i {
     font-size: 9px;
     color: var(--gold);
 }

 .hd-outer-wrapper .hd-card .hd-info .hd-number {
     font-size: 19px;
     font-weight: 700;
     color: var(--white);
     letter-spacing: 0.02em;
 }

 .hd-outer-wrapper .hd-card .hd-info .hd-number span {
     color: var(--gold);
 }

 .hd-outer-wrapper .hd-card .hd-info .hd-avail {
     display: flex;
     align-items: center;
     gap: 5px;
     margin-top: 3px;
 }

 .hd-outer-wrapper .hd-card .hd-info .hd-avail .hd-dot {
     width: 7px;
     height: 7px;
     border-radius: 50%;
     background: #4caf50;
     animation: hdBlink 1.8s ease-in-out infinite;
 }

 @keyframes hdBlink {

     0%,
     100% {
         opacity: 1;
     }

     50% {
         opacity: 0.35;
     }
 }

 .hd-outer-wrapper .hd-card .hd-info .hd-avail .hd-avail-text {
     font-size: 11px;
     color: var(--text-light);
 }

 /* ── Divider ── */
 .hd-outer-wrapper .hd-card .hd-divider {
     width: 1px;
     height: 44px;
     background: var(--warm-deep);
     flex-shrink: 0;
 }

 /* ── Social Card ── */
 .hd-outer-wrapper .hd-social-card {
     /* padding: 18px; */
     display: flex;
     flex-direction: column;
     align-items: center;
     gap: 10px;
     position: relative;
     overflow: hidden;
 }



 .hd-outer-wrapper .hd-social-card .hd-social-label {
     font-size: 10px;
     font-weight: 600;
     letter-spacing: 0.10em;
     text-transform: uppercase;
     color: var(--text-light);
 }

 .hd-outer-wrapper .hd-social-card .hd-social-icons {
     display: flex;
     gap: 8px;
     align-items: center;
 }

 .hd-outer-wrapper .hd-social-card .hd-social-icons .hd-social-link {
     width: 36px;
     height: 36px;
     border-radius: 10px;
     background: var(--warm-mid);
     border: 1px solid var(--border);
     display: flex;
     align-items: center;
     justify-content: center;
     text-decoration: none;
     color: var(--text-mid);
     font-size: 15px;
     transition: background 0.15s, color 0.15s, transform 0.15s, border-color 0.15s;
     position: relative;
 }

 .hd-outer-wrapper .hd-social-card .hd-social-icons .hd-social-link:hover {
     background: linear-gradient(135deg, var(--gold), var(--gold-dark));
     color: var(--gold-pale);
     border-color: var(--gold-dark);
     transform: scale(1.10);
 }

 .hd-outer-wrapper .hd-social-card .hd-social-icons .hd-social-link:active {
     transform: scale(0.96);
 }

 .hd-outer-wrapper .hd-social-card .hd-social-icons .hd-social-link i {
     pointer-events: none;
 }

 /* HONEYCOMB */
 .hc {
     position: absolute;
     inset: 0;
     pointer-events: none;
     overflow: hidden;
     background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='72' height='62'%3E%3Cpolygon points='36,3 69,21 69,57 36,75 3,57 3,21' fill='none' stroke='%23B8892A' stroke-width='0.8'/%3E%3C/svg%3E");
     background-size: 72px 62px
 }

 .hc-10 {
     opacity: .10
 }

 .hc-15 {
     opacity: .15
 }

 .hc-20 {
     opacity: .20
 }

 .hc-25 {
     opacity: .25
 }

 /* NAV */
 nav {
     position: fixed;
     top: 0;
     left: 0;
     width: 100%;
     z-index: 1000;
     padding: 22px 52px;
     display: flex;
     align-items: center;
     justify-content: space-between;
     transition: all .45s ease
 }

 nav.scrolled {
     background: rgba(251, 246, 238, .97);
     backdrop-filter: blur(24px);
     border-bottom: 1px solid var(--border);
     padding: 18px 52px;
     box-shadow: 0 6px 36px var(--shadow)
 }

 .nav-logo {
     font-family: 'Cinzel', serif;
     font-size: 1.08rem;
     color: #fff;
     letter-spacing: 3px;
     text-decoration: none;
     transition: color .4s
 }

.nav-logo span {
    display: block;
    font-size: .7rem;
    letter-spacing: unset;
    font-weight: 800;
    margin-top: 2px;
    color: rgba(255, 255, 255, .65);
    transition: color .4s;
    position: absolute;
    /* top: 0; */
    bottom: -16px;
}
 nav.scrolled .nav-logo span {
     bottom: 0px;
 }
 nav.scrolled .nav-logo {
     color: var(--gold)
 }

 nav.scrolled .nav-logo span {
     color: var(--black)
 }

 .nav-links {
     display: flex;
     gap: 28px;
     list-style: none
 }

 .nav-links a {
     color: rgba(255, 255, 255, .85);
     text-decoration: none;
     font-size: .66rem;
     letter-spacing: 2.5px;
     text-transform: uppercase;
     font-weight: 300;
     position: relative;
     transition: color .3s
 }

 nav.scrolled .nav-links a {
     color: var(--black);
     font-weight: 400;
 }

 .nav-links a::after {
     content: '';
     position: absolute;
     bottom: -4px;
     left: 0;
     width: 0;
     height: 1px;
     background: var(--gold);
     transition: width .3s
 }

 .nav-links a:hover {
     color: var(--gold)
 }

 .nav-links a:hover::after {
     width: 100%
 }

 .hamburger {
     display: none;
     flex-direction: column;
     gap: 5px;
     cursor: pointer;
     background: none;
     border: none;
     padding: 4px
 }

 /* DEFAULT */
 .hamburger span {
     width: 26px;
     height: 1.5px;
     background: #fff;
     display: block;
     transition: all 0.3s ease;
 }

 /* ACTIVE → TURN INTO X */
 .hamburger.active span {
     background: #000;
     /* BLACK COLOR */
 }

 /* TOP LINE */
 .hamburger.active span:nth-child(1) {
     transform: rotate(45deg) translate(5px, 5px);
 }

 /* MIDDLE LINE → HIDE */
 .hamburger.active span:nth-child(2) {
     opacity: 0;
 }

 /* BOTTOM LINE */
 .hamburger.active span:nth-child(3) {
     transform: rotate(-45deg) translate(5px, -5px);
 }

 nav.scrolled .hamburger span {
     background: var(--gold)
 }

 nav.scrolled .nav-logo .logo {
     width: 120px;
 }

 nav.scrolled .hd-outer-wrapper {
     display: none !important;
 }

.mobile-menu {
    position: fixed;
    inset: 0;
    background: rgba(251, 246, 238, .98);
    backdrop-filter: blur(20px);
    z-index: 999;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: end;
    gap: 15px;
    transform: translateX(100%);
    transition: transform .5s cubic-bezier(.77, 0, .175, 1);
    padding-bottom: 50px;
}

 .mobile-menu.open {
     transform: translateX(0)
 }

 .mobile-menu a {
     color: var(--brown);
     font-family: 'Cinzel', serif;
     font-size: 1.05rem;
     letter-spacing: 4px;
     text-decoration: none;
     text-transform: uppercase;
     transition: color .3s
 }

 .mobile-menu a:hover {
     color: var(--gold)
 }

 /* HERO */
#home {
    position: relative;
    height: 100vh;
    display: flex;
    align-items: end;
    justify-content: center;
    overflow: hidden;
    padding-bottom: 50px;
}

 .hero-img {
     position: absolute;
     inset: 0;
     z-index: 1;
     background: url('../Images/front-view.webp') center/cover no-repeat;
     animation: heroKB 20s ease-in-out infinite alternate
 }

 @keyframes heroKB {
     0% {
         transform: scale(1.10) translate(0, 0)
     }

     50% {
         transform: scale(1.16) translate(-1%, -.5%)
     }

     100% {
         transform: scale(1.18) translate(.5%, .5%)
     }
 }

 .hero-ov {
     position: absolute;
     inset: 0;
     z-index: 2;
     background: linear-gradient(155deg, rgba(28, 14, 4, .72) 0%, rgba(28, 14, 4, .28) 55%, rgba(28, 14, 4, .60) 100%)
 }

 .hero-ov::after {
     content: '';
     position: absolute;
     inset: 0;
     background: linear-gradient(to top, rgba(28, 14, 4, .65) 0%, transparent 55%)
 }

 .hero-content {
     position: relative;
     z-index: 3;
     text-align: center;
     padding: 0 24px
 }

 .hero-eyebrow {
     display: inline-flex;
     align-items: center;
     gap: 14px;
     border: 1px solid rgba(240, 216, 152, .5);
     padding: 8px 32px;
     font-size: .6rem;
     letter-spacing: 6px;
     text-transform: uppercase;
     color: var(--gold-pale);
     margin-bottom: 24px;
     font-family: 'Cinzel', serif;
     background: rgba(184, 137, 42, .10);
     backdrop-filter: blur(8px);
     animation: fadeUp .9s .3s both
 }

 .hero-eyebrow::before,
 .hero-eyebrow::after {
     content: '✦';
     font-size: .45rem;
     opacity: .7
 }

 .hero-title {
     font-family: 'Cinzel', serif;
     font-size: clamp(2.6rem, 7.5vw, 6rem);
     font-weight: 700;
     line-height: 1.0;
     color: #fff;
     animation: fadeUp .9s .55s both;
     text-shadow: 0 4px 48px rgba(0, 0, 0, .25)
 }

 .hero-italic {
     display: block;
     font-style: italic;
     color: var(--gold-pale);
     font-family: 'Cormorant Garamond', serif;
     font-size: clamp(3rem, 8.5vw, 7rem);
     font-weight: 300;
     line-height: 1.05
 }

 .hero-sub {
     font-size: clamp(.68rem, 1.3vw, .84rem);
     letter-spacing: 5px;
     text-transform: uppercase;
     color: rgba(255, 253, 247, .7);
     margin: 20px 0 36px;
     font-weight: 200;
     animation: fadeUp .9s .78s both
 }

 .hero-btns {
     display: flex;
     gap: 14px;
     justify-content: center;
     flex-wrap: wrap;
     animation: fadeUp .9s .98s both
 }

 .btn-gold {
     display: inline-block;
     padding: 15px 46px;
     font-family: 'Cinzel', serif;
     font-size: .66rem;
     letter-spacing: 4px;
     text-transform: uppercase;
     text-decoration: none;
     background: var(--gold);
     color: #fff;
     border: 1.5px solid var(--gold);
     transition: all .4s
 }

 .btn-gold:hover {
     background: var(--gold-dark);
     border-color: var(--gold-dark);
     color: #fff;
     transform: translateY(-2px);
     box-shadow: 0 12px 40px rgba(184, 137, 42, .45)
 }

 .btn-ghost {
     display: inline-block;
     padding: 15px 46px;
     font-family: 'Cinzel', serif;
     font-size: .66rem;
     letter-spacing: 4px;
     text-transform: uppercase;
     text-decoration: none;
     background: transparent;
     color: #fff;
     border: 1.5px solid rgba(255, 255, 255, .45);
     transition: all .4s
 }

 .btn-ghost:hover {
     border-color: var(--gold-pale);
     color: var(--gold-pale);
     transform: translateY(-2px)
 }

 .hero-strip {
     position: absolute;
     bottom: 0;
     left: 0;
     right: 0;
     z-index: 3;
     display: grid;
     grid-template-columns: repeat(4, 1fr);
     border-top: 1px solid rgba(255, 255, 255, .12);
     animation: fadeUp .9s 1.2s both;
     display: none;
 }

 .hsc {
     padding: 18px 0;
     text-align: center;
     border-right: 1px solid rgba(255, 255, 255, .1);
     background: rgba(255, 253, 247, .07);
     backdrop-filter: blur(14px)
 }

 .hsc:last-child {
     border-right: none
 }

 .hsc-n {
     font-family: 'Cinzel', serif;
     font-size: 1.45rem;
     color: var(--gold-pale);
     font-weight: 600;
     line-height: 1
 }

 .hsc-l {
     letter-spacing: 3px;
     color: rgba(255, 255, 255, .55);
     text-transform: uppercase;
     margin-top: 4px
 }

 @keyframes pipeDrop {
     0% {
         transform: translateY(-100%)
     }

     100% {
         transform: translateY(200%)
     }
 }

 @keyframes fadeUp {
     from {
         opacity: 0;
         transform: translateY(26px)
     }

     to {
         opacity: 1;
         transform: translateY(0)
     }
 }

 /* SHARED */
 section {
     position: relative
 }

 .sec-label {
     font-size: .57rem;
     letter-spacing: 6px;
     color: var(--gold);
     text-transform: uppercase;
     font-family: 'Cinzel', serif;
     display: flex;
     align-items: center;
     gap: 14px;
     margin-bottom: 12px
 }

 .sec-label::before {
     content: '';
     width: 34px;
     height: 1px;
     background: var(--gold);
     flex-shrink: 0
 }

 .sec-label.center {
     justify-content: center
 }

 .sec-label.center::before {
     display: none
 }

 .sec-title {
     font-family: 'Cormorant Garamond', serif;
     font-size: clamp(1.9rem, 4vw, 3.4rem);
     font-weight: 300;
     line-height: 1.15;
     color: var(--text-dark)
 }

 .sec-title em {
     font-style: italic;
     color: var(--gold)
 }

 .gold-bar {
     width: 52px;
     height: 2px;
     background: linear-gradient(to right, var(--gold-dark), var(--gold-pale));
     margin: 20px 0
 }

 .reveal {
     opacity: 0;
     transform: translateY(36px)
 }

 /* ─── OVERVIEW ────────────────────────────────────────────── */
 #overview {
     background: var(--warm-bg);
     padding: 0;
     overflow: hidden
 }

 .ov-hero {
     display: grid;
     grid-template-columns: 55% 45%;
     min-height: 600px
 }

 .ov-img {
     position: relative;
     overflow: hidden
 }

 .ov-img img {
     width: 100%;
     height: 100%;
     object-fit: cover;
     transition: transform .9s ease;
     display: block
 }

 .ov-img:hover img {
     transform: scale(1.04)
 }

 .ov-badge {
     position: absolute;
     bottom: 28px;
     left: 28px;
     background: rgba(251, 246, 238, .93);
     border: 1px solid var(--border);
     padding: 12px 20px;
     font-family: 'Cinzel', serif;
     font-size: .58rem;
     letter-spacing: 3px;
     color: var(--gold);
     backdrop-filter: blur(8px)
 }

 .ov-panel {
     padding: 72px 64px;
     display: flex;
     flex-direction: column;
     justify-content: center;
     background: var(--warm-mid);
     position: relative;
     overflow: hidden
 }

 .ov-panel>* {
     position: relative;
     z-index: 1
 }

 .ov-body {
     color: var(--text-mid);
     line-height: 1.95;
     font-weight: 300;
     margin-top: 16px
 }

 .ov-body strong {
     color: var(--gold);
     font-weight: 500
 }

 .ov-stats {
     display: grid;
     grid-template-columns: repeat(4, 1fr);
     border: 1px solid var(--border);
     margin-top: 32px
 }

 .ov-stat {
     padding: 22px 16px;
     border-right: 1px solid var(--border);
     background: var(--warm-card);
     text-align: center;
     transition: background .3s
 }

 .ov-stat:last-child {
     border-right: none
 }

 .ov-stat:hover {
     background: var(--warm-deep)
 }

 .ov-stat-n {
     font-family: 'Cinzel', serif;
     font-size: 1.6rem;
     color: var(--gold);
     font-weight: 600
 }

 .ov-stat-l {
     font-size: .56rem;
     letter-spacing: 2px;
     color: var(--text-light);
     text-transform: uppercase;
     margin-top: 4px
 }

 .ov-ribbon {
     display: grid;
     grid-template-columns: repeat(4, 1fr);
     background: var(--brown)
 }

 .ov-rc {
     padding: 22px 28px;
     border-right: 1px solid rgba(212, 169, 78, .12)
 }

 .ov-rc:last-child {
     border-right: none
 }

 .ov-rk {
     letter-spacing: 3px;
     color: rgba(240, 216, 152, .4);
     text-transform: uppercase;
     margin-bottom: 5px
 }

 .ov-rv {
     font-family: 'Cinzel', serif;
     color: var(--gold-pale);
     font-size: .76rem;
     letter-spacing: 1px
 }

 /* ─── AMENITIES ───────────────────────────────────────────── */
 #amenities {
     background: var(--warm-bg);
     overflow: hidden
 }

 .amen-top {
     padding: 100px 0 0
 }

 /* Why Canggu — 3×2 grid */
 .why-grid {
     display: grid;
     grid-template-columns: repeat(3, 1fr);
     gap: 1px;
     background: var(--border);
     margin-top: 52px
 }

 .why-card {
     background: var(--warm-card);
     padding: 44px 34px;
     position: relative;
     overflow: hidden;
     transition: all .4s
 }

 .why-card::before {
     content: '';
     position: absolute;
     top: 0;
     left: 0;
     right: 0;
     height: 3px;
     background: linear-gradient(to right, transparent, var(--gold), transparent);
     transform: scaleX(0);
     transition: transform .4s
 }

 .why-card:hover {
     background: var(--warm-mid);
     transform: translateY(-5px);
     box-shadow: 0 14px 44px rgba(184, 137, 42, .13);
     z-index: 2
 }

 .why-card:hover::before {
     transform: scaleX(1)
 }

 .why-num {
     font-family: 'Cinzel', serif;
     font-size: 3.2rem;
     color: rgba(184, 137, 42, .10);
     font-weight: 700;
     line-height: 1;
     position: absolute;
     top: 18px;
     right: 22px
 }

 .why-icon {
     width: 52px;
     height: 52px;
     background: var(--warm-mid);
     border: 1px solid var(--border);
     display: flex;
     align-items: center;
     justify-content: center;
     color: var(--gold);
     font-size: 1.2rem;
     margin-bottom: 18px
 }

 .why-card h5 {
     font-family: 'Cinzel', serif;
     font-size: .78rem;
     letter-spacing: 2px;
     color: var(--text-dark);
     margin-bottom: 10px
 }

 .why-card p {
     font-size: .81rem;
     color: var(--text-mid);
     line-height: 1.75;
     font-weight: 300
 }

 /* Amenities split — image left, tab panel right */
 .amen-split {
     display: grid;
     grid-template-columns: 1fr 1fr;
     margin-top: 1px;
     min-height: 520px
 }

 .amen-img {
     position: relative;
     overflow: hidden
 }

 .amen-img img {
     width: 100%;
     height: 100%;
     object-fit: cover;
     display: block;
     transition: transform .8s
 }

 .amen-img:hover img {
     transform: scale(1.04)
 }

 .amen-img-ov {
     position: absolute;
     inset: 0;
     background: linear-gradient(to top, rgba(44, 26, 8, .65) 0%, transparent 55%)
 }

 .amen-img-txt {
     position: absolute;
     bottom: 36px;
     left: 36px;
     right: 36px;
     color: #fff
 }

 .amen-img-txt h4 {
     font-family: 'Cormorant Garamond', serif;
     font-size: 1.8rem;
     font-weight: 300;
     line-height: 1.25
 }

 .amen-img-txt p {
     font-size: .78rem;
     color: rgba(255, 255, 255, .68);
     margin-top: 6px;
     font-weight: 300
 }

 .amen-panel-wrap {
     background: var(--warm-mid);
     padding: 52px 48px;
     display: flex;
     flex-direction: column;
     position: relative;
     overflow: hidden
 }

 .amen-panel-wrap>* {
     position: relative;
     z-index: 1
 }

 /* Amenity tabs */
 .amen-tabs {
     display: flex;
     gap: 0;
     border-bottom: 1.5px solid var(--border);
     margin-bottom: 28px
 }

 .amen-tab {
     padding: 10px 24px;
     font-family: 'Cinzel', serif;
     letter-spacing: 2.5px;
     text-transform: uppercase;
     color: var(--text-light);
     cursor: pointer;
     border: none;
     border-bottom: 2.5px solid transparent;
     margin-bottom: -1.5px;
     background: transparent;
     transition: all .3s;
     white-space: nowrap
 }

 .amen-tab.active,
 .amen-tab:hover {
     color: var(--gold);
     border-bottom-color: var(--gold)
 }

 /* Amenity panels */
 .amen-panel {
     display: none;
     flex-direction: column;
     gap: 11px;
     animation: fadeIn .35s ease both
 }

 .amen-panel.active {
     display: flex
 }

 @keyframes fadeIn {
     from {
         opacity: 0;
         transform: translateY(10px)
     }

     to {
         opacity: 1;
         transform: translateY(0)
     }
 }

 .amen-row {
     display: flex;
     align-items: center;
     gap: 16px;
     padding: 15px 18px;
     background: var(--warm-card);
     border: 1px solid var(--border);
     border-left: 3px solid var(--gold);
     transition: all .3s
 }

 .amen-row:hover {
     background: var(--warm-deep);
     transform: translateX(5px);
     box-shadow: 4px 0 20px var(--shadow)
 }

 .amen-ico {
     width: 38px;
     height: 38px;
     background: var(--warm-mid);
     border: 1px solid var(--border);
     display: flex;
     align-items: center;
     justify-content: center;
     color: var(--gold);
     font-size: .9rem;
     flex-shrink: 0
 }

 .amen-row h6 {
     font-family: 'Cinzel', serif;
     letter-spacing: 1.5px;
     color: var(--text-dark);
     margin-bottom: 2px
 }

 .amen-row p {
     color: var(--text-light);
     margin: 0;
     font-weight: 300
 }

 /* ─── ARCHITECTURE ────────────────────────────────────────── */
 #architecture {
     padding: 0;
     background: var(--warm-mid);
     overflow: hidden
 }

 .arch-intro {
     padding: 90px 0 20px;
     text-align: center;
     background: var(--warm-bg);
     position: relative
 }

 .arch-intro>*:not(.hc) {
     position: relative;
     z-index: 1
 }

 .arch-strip {
     display: grid;
     grid-template-columns: 1fr 1fr;
     min-height: 480px
 }

 .arch-strip.flip {
     direction: rtl
 }

 .arch-strip.flip>* {
     direction: ltr
 }

 .arch-img-wrap {
     position: relative;
     overflow: hidden
 }

 .arch-img-wrap img {
     width: 100%;
     height: 100%;
     object-fit: cover;
     display: block;
     transition: transform .8s
 }

 .arch-img-wrap:hover img {
     transform: scale(1.05)
 }

 .arch-badge {
     position: absolute;
     top: 24px;
     left: 24px;
     background: rgba(251, 246, 238, .92);
     border: 1px solid var(--border);
     padding: 8px 16px;
     font-family: 'Cinzel', serif;
     font-size: .56rem;
     letter-spacing: 3px;
     color: var(--gold);
     backdrop-filter: blur(6px)
 }

 .arch-strip.flip .arch-badge {
     left: auto;
     right: 24px
 }

 .arch-content {
     padding: 64px 58px;
     display: flex;
     flex-direction: column;
     justify-content: center;
     background: var(--warm-bg);
     position: relative;
     overflow: hidden
 }

 .arch-strip.flip .arch-content {
     background: var(--warm-mid)
 }

 .arch-content>*:not(.hc) {
     position: relative;
     z-index: 1
 }

 .arch-list {
     list-style: none;
     margin-top: 20px;
     display: flex;
     flex-direction: column;
     gap: 11px
 }

 .arch-list li {
     display: flex;
     align-items: flex-start;
     gap: 12px;
     color: var(--text-mid);
     line-height: 1.65
 }

 .arch-list li::before {
     content: '◆';
     color: var(--gold);
     font-size: .42rem;
     margin-top: 7px;
     flex-shrink: 0
 }



 /* ─── GALLERY ─────────────────────────────────────────────── */
 #gallery {
     padding: 100px 0;
     background: var(--warm-bg)
 }

.g-filter {
    display: flex;
    gap: 20px;
    justify-content: center;
    margin-bottom: 44px;
    flex-wrap: wrap;
    margin-top: 20px;
}

 .g-btn {
     padding: 8px 22px;
     border: 1px solid var(--border);
     background: transparent;
     color: var(--text-mid);
     font-size: .6rem;
     letter-spacing: 3px;
     text-transform: uppercase;
     cursor: pointer;
     transition: all .3s;
     font-family: 'Cinzel', serif
 }

 .g-btn.active,
 .g-btn:hover {
     border-color: var(--gold);
     color: var(--gold);
     background: rgba(184, 137, 42, .07)
 }

 .g-masonry {
     columns: 4;
     gap: 10px
 }

 .g-item {
     break-inside: avoid;
     margin-bottom: 10px;
     cursor: pointer;
     position: relative;
     overflow: hidden;
     box-shadow: 0 2px 16px var(--shadow)
 }

 .g-item img {
     width: 100%;
     display: block;
     transition: transform .6s ease
 }

 .g-item:hover img {
     transform: scale(1.08)
 }

 .g-ov {
     position: absolute;
     inset: 0;
     background: linear-gradient(to top, rgba(44, 26, 8, .78) 0%, transparent 60%);
     opacity: 0;
     transition: opacity .4s;
     display: flex;
     align-items: flex-end;
     padding: 16px
 }

 .g-item:hover .g-ov {
     opacity: 1
 }

 .g-lbl {
     font-family: 'Cinzel', serif;
     font-size: .58rem;
     letter-spacing: 3px;
     color: var(--gold-pale);
     text-transform: uppercase
 }

 .g-item.hidden {
    display: none;
}

 /* ─── LOCATION ────────────────────────────────────────────── */
 #location {
     padding: 0;
     background: var(--warm-mid);
     overflow: hidden
 }

 .loc-intro {
     padding: 90px 0 56px;
     text-align: center;
     background: var(--warm-mid);
     position: relative
 }

 .loc-intro>*:not(.hc) {
     position: relative;
     z-index: 1
 }

 .loc-split {
     display: grid;
     grid-template-columns: 58% 42%
 }

 .loc-map {
     position: relative;
     overflow: hidden;
     min-height: 520px
 }

 .loc-map iframe {
     width: 100%;
     height: 100%;
     border: none;
     filter: sepia(.22) saturate(1.1)
 }

 .loc-right {
     background: var(--warm-bg);
     display: flex;
     flex-direction: column
 }

 .loc-head {
     padding: 34px 40px 20px;
     border-bottom: 1px solid var(--border)
 }

 .loc-cards {
     display: grid;
     grid-template-columns: 1fr 1fr;
     flex: 1
 }

 .loc-card {
     padding: 30px 26px;
     border-right: 1px solid var(--border);
     border-bottom: 1px solid var(--border);
     background: var(--warm-card);
     transition: all .3s;
     position: relative;
     overflow: hidden
 }

 .loc-card:nth-child(even) {
     border-right: none
 }

 .loc-card:nth-child(3),
 .loc-card:nth-child(4) {
     border-bottom: none
 }

 .loc-card::before {
     content: '';
     position: absolute;
     top: 0;
     left: 0;
     width: 0;
     height: 3px;
     background: var(--gold);
     transition: width .4s
 }

 .loc-card:hover::before {
     width: 100%
 }

 .loc-card:hover {
     background: var(--warm-mid)
 }

 .loc-icon {
     width: 42px;
     height: 42px;
     border: 1px solid var(--border);
     display: flex;
     align-items: center;
     justify-content: center;
     color: var(--gold);
     font-size: 1rem;
     margin-bottom: 14px
 }

 .loc-card h6 {
     font-family: 'Cinzel', serif;
     letter-spacing: 1.5px;
     color: var(--text-dark);
     margin-bottom: 4px
 }

 .loc-card p {
     color: var(--text-light);
     font-weight: 300;
     line-height: 1.6;
     margin: 0
 }

 .loc-dist {
     display: inline-block;
     font-family: 'Cinzel', serif;
     font-size: .56rem;
     letter-spacing: 2px;
     color: var(--gold);
     border: 1px solid var(--border);
     padding: 3px 10px;
     margin-top: 10px
 }

 /* ─── ABOUT ───────────────────────────────────────────────── */
 #about {
     padding: 100px 0;
     background: var(--warm-bg);
     position: relative;
     overflow: hidden
 }

 .about-grid {
     display: grid;
     grid-template-columns: 1fr 1.1fr;
     gap: 80px;
     align-items: center
 }

 .about-quote {
     font-family: 'Cormorant Garamond', serif;
     font-size: clamp(1.3rem, 2.2vw, 1.85rem);
     font-weight: 300;
     color: var(--text-dark);
     line-height: 1.5;
     border-left: 3px solid var(--gold);
     padding-left: 26px;
     margin: 26px 0
 }

 .about-quote em {
     color: var(--gold)
 }

 .inv-grid {
     display: grid;
     grid-template-columns: 1fr 1fr;
     gap: 16px
 }

 .inv-card {
     background: var(--warm-card);
     border: 1px solid var(--border);
     padding: 28px 22px;
     transition: all .4s;
     position: relative;
     overflow: hidden
 }

 .inv-card::after {
     content: '';
     position: absolute;
     bottom: 0;
     left: 0;
     width: 0;
     height: 3px;
     background: var(--gold);
     transition: width .4s
 }

 .inv-card:hover {
     transform: translateY(-5px);
     box-shadow: 0 16px 44px rgba(184, 137, 42, .13);
     border-color: var(--gold)
 }

 .inv-card:hover::after {
     width: 100%
 }

 .inv-card i {
     font-size: 1.3rem;
     color: var(--gold);
     margin-bottom: 13px;
     display: block
 }

 .inv-card h5 {
     font-family: 'Cinzel', serif;
     font-size: 0.8rem;
     letter-spacing: 2px;
     color: var(--white);
     margin-bottom: 8px
 }

 .inv-card p {
     color: var(--text-mid);
     line-height: 1.72;
     font-weight: 300;
     margin: 0
 }

 /* ─── CONTACT ─────────────────────────────────────────────── */
 #contact {
     padding: 100px 0;
     background: var(--warm-deep);
     position: relative;
     overflow: hidden
 }

 .cg {
     display: grid;
     grid-template-columns: 1fr 1px 1.2fr;
     gap: 64px;
     align-items: start;
     position: relative;
     z-index: 1
 }

 .cdiv {
     background: var(--border);
     align-self: stretch
 }

 .c-hl {
     font-family: 'Cormorant Garamond', serif;
     font-size: 1.7rem;
     font-weight: 300;
     color: var(--text-dark);
     line-height: 1.3;
     margin-bottom: 28px
 }

 .c-hl em {
     color: var(--gold)
 }

 .cinfo {
     display: flex;
     flex-direction: column
 }

 .cd {
     display: flex;
     gap: 16px;
     align-items: flex-start;
     padding: 18px 0;
     border-bottom: 1px solid var(--border)
 }

 .cd:last-child {
     border-bottom: none
 }

 .cd-ico {
     width: 40px;
     height: 40px;
     border: 1px solid var(--border);
     background: var(--warm-card);
     display: flex;
     align-items: center;
     justify-content: center;
     color: var(--gold);
     flex-shrink: 0;
     font-size: .9rem
 }

 .cd h6 {
     font-family: 'Cinzel', serif;
     font-size: .62rem;
     letter-spacing: 2px;
     color: var(--gold);
     margin-bottom: 4px
 }

 .cd p {
     color: var(--text-mid);
     font-weight: 300;
     line-height: 1.6;
     margin: 0
 }

 .cform {
     display: flex;
     flex-direction: column;
     gap: 17px
 }

 .ff {
     display: flex;
     flex-direction: column;
     gap: 6px
 }

 .fl {
     font-size: .56rem;
     letter-spacing: 3px;
     text-transform: uppercase;
     color: var(--gold);
     font-family: 'Cinzel', serif
 }

 .fi {
     background: var(--warm-card);
     border: 1px solid var(--border);
     padding: 12px 14px;
     font-size: .81rem;
     font-weight: 300;
     color: var(--text-dark);
     transition: border-color .3s, box-shadow .3s;
     outline: none;
     width: 100%
 }

 .fi:focus {
     border-color: var(--gold);
     box-shadow: 0 0 0 3px rgba(184, 137, 42, .09)
 }

 .fi::placeholder {
     color: var(--text-light);
     opacity: .7
 }

 textarea.fi {
     resize: none;
     height: 94px
 }

 select.fi {
     -webkit-appearance: none;
     appearance: none
 }

 select.fi option {
     background: var(--warm-card);
     color: var(--text-dark)
 }

 .fg {
     display: grid;
     grid-template-columns: 1fr 1fr;
     gap: 16px
 }

 .sbtn {
     align-self: flex-start;
     background: var(--gold);
     border: 1.5px solid var(--gold);
     color: #fff;
     padding: 15px 48px;
     font-family: 'Cinzel', serif;
     font-size: .65rem;
     letter-spacing: 4px;
     text-transform: uppercase;
     cursor: pointer;
     transition: all .4s;
     margin-top: 4px
 }

 .sbtn:hover {
     background: var(--gold-dark);
     border-color: var(--gold-dark);
     transform: translateY(-2px);
     box-shadow: 0 10px 36px rgba(184, 137, 42, .35)
 }

 /* FOOTER */
 footer {
     background: var(--brown);
     padding: 58px 52px 30px;
     position: relative;
     overflow: hidden
 }

 .ft {
     display: grid;
     grid-template-columns: 2fr 1fr 1fr;
     gap: 60px;
     margin-bottom: 44px;
     position: relative;
     z-index: 1
 }

 .ft-logo {
     font-family: 'Cinzel', serif;
     font-size: 1.08rem;
     color: var(--gold-light);
     letter-spacing: 3px;
     text-decoration: none
 }

 .ft-logo span {
     display: block;
     font-size: .46rem;
     letter-spacing: 6px;
     color: rgba(212, 169, 78, .4);
     font-weight: 300;
     margin-top: 3px
 }

 .ft-brand p {
     color: rgba(212, 169, 78, .45);
     font-weight: 300;
     line-height: 1.85;
     margin-top: 14px;
     max-width: 350px
 }

 .ft-col h6 {
     font-family: 'Cinzel', serif;
     font-size: .62rem;
     letter-spacing: 3px;
     color: var(--gold-light);
     margin-bottom: 17px;
     opacity: .9
 }

 .ft-col ul {
     list-style: none;
     display: flex;
     flex-direction: column;
     gap: 9px
 }

 .ft-col ul li a {
     color: rgba(212, 169, 78, .4);
     text-decoration: none;
     font-size: .73rem;
     font-weight: 300;
     transition: color .3s
 }

 .ft-col ul li a:hover {
     color: var(--gold-light)
 }

 .ft-bot {
     border-top: 1px solid rgba(212, 169, 78, .1);
     padding-top: 20px;
     display: flex;
     justify-content: space-between;
     align-items: center;
     flex-wrap: wrap;
     gap: 10px;
     position: relative;
     z-index: 1
 }

 .ft-bot p {
     font-size: 0.8rem;
     color: rgba(212, 169, 78, .25)
 }

 .socials {
     display: flex;
     gap: 10px
 }

 .socials a {
     width: 34px;
     height: 34px;
     border: 1px solid rgba(212, 169, 78, .18);
     display: flex;
     align-items: center;
     justify-content: center;
     color: rgba(212, 169, 78, .38);
     text-decoration: none;
     transition: all .3s
 }

 .socials a:hover {
     border-color: var(--gold-light);
     color: var(--gold-light);
     background: rgba(212, 169, 78, .1)
 }

 /* LIGHTBOX */
 .lightbox {
     position: fixed;
     inset: 0;
     background: rgba(251, 246, 238, .97);
     z-index: 9000;
     display: none;
     align-items: center;
     justify-content: center;
     padding: 40px
 }

 .lightbox.open {
     display: flex
 }

 .lb-wrap {
     position: relative;
     max-width: 90vw
 }

 .lb-wrap img {
     max-width: 100%;
     max-height: 80vh;
     object-fit: contain;
     border: 1px solid var(--border);
     box-shadow: 0 24px 80px var(--shadow)
 }

 .lb-close {
     position: absolute;
     top: -46px;
     right: 0;
     font-size: 1.3rem;
     color: var(--brown);
     cursor: pointer;
     background: none;
     border: none
 }

 .lb-nav {
     position: absolute;
     top: 50%;
     transform: translateY(-50%);
     font-size: .9rem;
     color: var(--brown);
     cursor: pointer;
     background: rgba(251, 246, 238, .92);
     border: 1px solid var(--border);
     width: 44px;
     height: 44px;
     display: flex;
     align-items: center;
     justify-content: center;
     transition: all .3s
 }

 .lb-nav:hover {
     background: var(--warm-mid);
     border-color: var(--gold);
     color: var(--gold)
 }

 .lb-prev {
     left: -58px
 }

 .lb-next {
     right: -58px
 }

 .lb-cap {
     text-align: center;
     margin-top: 12px;
     font-size: .6rem;
     letter-spacing: 3px;
     color: var(--gold);
     text-transform: uppercase;
     font-family: 'Cinzel', serif
 }

 /* TOAST */
 #toast {
     position: fixed;
     bottom: 36px;
     right: 36px;
     background: var(--warm-card);
     border: 1px solid var(--gold);
     padding: 18px 30px;
     z-index: 9999;
     display: none;
     font-family: 'Cinzel', serif;
     font-size: .68rem;
     letter-spacing: 2px;
     color: var(--gold);
     box-shadow: 0 8px 40px var(--shadow)
 }

 /* RESPONSIVE */
 @media(max-width:1100px) {
     .g-masonry {
         columns: 3
     }
 }

 @media(max-width:991px) {
     .nav-links {
         display: none
     }

     .hamburger {
         display: flex
     }

     .ov-hero,
     .loc-split,
     .about-grid,
     .cg {
         grid-template-columns: 1fr
     }

     .ov-ribbon,
     .ov-stats {
         grid-template-columns: 1fr 1fr
     }

     .hero-strip {
         grid-template-columns: 1fr 1fr
     }

     .why-grid {
         grid-template-columns: 1fr 1fr
     }

     .amen-split,
     .arch-strip {
         grid-template-columns: 1fr
     }

     .arch-strip.flip {
         direction: ltr
     }

     .ft {
         grid-template-columns: 1fr
     }

     .g-masonry {
         columns: 2
     }

     .loc-cards {
         grid-template-columns: 1fr 1fr
     }

     .cdiv {
         display: none
     }

     .cg {
         grid-template-columns: 1fr;
         gap: 40px
     }

     .ov-panel {
         padding: 50px 32px
     }

     .arch-content {
         padding: 44px 32px
     }

     .amen-panel-wrap {
         padding: 36px 28px
     }
 }

 @media(max-width:768px) {
     .fp-pane.active {
         grid-template-columns: 1fr
     }

     .loc-cards {
         grid-template-columns: 1fr
     }

     .loc-card:nth-child(3) {
         border-bottom: 1px solid var(--border)
     }

     .loc-card:nth-child(even) {
         border-right: none
     }
 }

 @media(max-width:576px) {
     nav {
         padding: 14px 20px
     }

         nav.scrolled {
        padding: 10px 20px 30px;
    }

     nav.scrolled .nav-logo span{
        bottom: 2px;
     }
     .g-masonry {
         columns: 1
     }

     .fp-specs,
     .fg,
     .ov-stats {
         grid-template-columns: 1fr
     }

     .ov-ribbon {
         grid-template-columns: 1fr
     }

     .ov-rc {
         border-right: none;
         border-bottom: 1px solid rgba(212, 169, 78, .12)
     }

     .why-grid {
         grid-template-columns: 1fr
     }

     .hero-strip {
         display: none
     }

     .amen-tabs {
         flex-wrap: wrap
     }
     .hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    border: 1px solid rgba(240, 216, 152, .5);
    padding: 8px 6px;
}
 }

 /* ══════════════════════════════════════════
       CTA 1 — DARK IMMERSIVE
       Deep brown bg, full-width, centred
    ══════════════════════════════════════════ */

 .cta-immersive {
     background: var(--brown);
     padding: clamp(2rem, 10vw, 3rem) 2rem;
     position: relative;
     overflow: hidden;
     text-align: center;
 }

 /* subtle cross-hatch texture overlay */
 .cta-immersive::before {
     content: '';
     position: absolute;
     inset: 0;
     background-image:
         repeating-linear-gradient(0deg,
             transparent,
             transparent 39px,
             rgba(184, 137, 42, 0.04) 39px,
             rgba(184, 137, 42, 0.04) 40px),
         repeating-linear-gradient(90deg,
             transparent,
             transparent 39px,
             rgba(184, 137, 42, 0.04) 39px,
             rgba(184, 137, 42, 0.04) 40px);
     pointer-events: none;
 }

 /* corner ornaments */
 .cta-immersive .cta-immersive__corner {
     position: absolute;
     width: 48px;
     height: 48px;
     pointer-events: none;
 }

 .cta-immersive .cta-immersive__corner--tl {
     top: 28px;
     left: 28px;
     border-top: 1px solid rgba(184, 137, 42, 0.35);
     border-left: 1px solid rgba(184, 137, 42, 0.35);
 }

 .cta-immersive .cta-immersive__corner--tr {
     top: 28px;
     right: 28px;
     border-top: 1px solid rgba(184, 137, 42, 0.35);
     border-right: 1px solid rgba(184, 137, 42, 0.35);
 }

 .cta-immersive .cta-immersive__corner--bl {
     bottom: 28px;
     left: 28px;
     border-bottom: 1px solid rgba(184, 137, 42, 0.35);
     border-left: 1px solid rgba(184, 137, 42, 0.35);
 }

 .cta-immersive .cta-immersive__corner--br {
     bottom: 28px;
     right: 28px;
     border-bottom: 1px solid rgba(184, 137, 42, 0.35);
     border-right: 1px solid rgba(184, 137, 42, 0.35);
 }

 .cta-immersive .cta-immersive__inner {
     position: relative;
     z-index: 2;
     max-width: 680px;
     margin: 0 auto;
 }

 .cta-immersive .cta-immersive__stars {
     display: flex;
     align-items: center;
     justify-content: center;
     gap: 5px;
     margin-bottom: 1.6rem;
     opacity: 0;
 }

 .cta-immersive .cta-immersive__stars span {
     display: block;
     width: 8px;
     height: 8px;
     background: var(--gold-light);
     clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
 }

 .cta-immersive .cta-immersive__tagline {
     font-family: 'Playfair Display', serif;
     font-style: italic;
     font-size: clamp(2rem, 4.5vw, 3.4rem);
     font-weight: 400;
     color: var(--gold-pale);
     line-height: 1.25;
     margin-bottom: 1rem;
     opacity: 0;
 }

 .cta-immersive .cta-immersive__sub {
     font-size: 0.82rem;
     font-weight: 300;
     letter-spacing: 0.06em;
     color: rgba(240, 216, 152, 0.55);
     margin-bottom: 2.6rem;
     opacity: 0;
 }

 /* horizontal rule with diamond */
 .cta-immersive .cta-immersive__rule {
     display: flex;
     align-items: center;
     justify-content: center;
     gap: 0.8rem;
     margin-bottom: 2.6rem;
     opacity: 0;
 }

 .cta-immersive .cta-immersive__rule span {
     display: block;
     flex: 1;
     max-width: 80px;
     height: 1px;
     background: rgba(184, 137, 42, 0.3);
 }

 .cta-immersive .cta-immersive__rule i {
     display: block;
     width: 5px;
     height: 5px;
     background: var(--gold);
     transform: rotate(45deg);
 }

 .cta-immersive .cta-immersive__actions {
     display: flex;
     align-items: center;
     justify-content: center;
     gap: 1rem;
     flex-wrap: wrap;
     opacity: 0;
 }

 /* Book Now — gold fill */
 .cta-immersive .cta-immersive__btn-book {
     font-family: 'Jost', sans-serif;
     font-size: 0.75rem;
     font-weight: 500;
     letter-spacing: 0.18em;
     text-transform: uppercase;
     color: var(--brown);
     background: var(--gold-light);
     border: 1px solid var(--gold-light);
     padding: 0.85rem 2.6rem;
     text-decoration: none;
     display: inline-block;
     transition: background 0.3s, border-color 0.3s;
 }

 .cta-immersive .cta-immersive__btn-book:hover {
     background: var(--gold-pale);
     border-color: var(--gold-pale);
     color: var(--brown);
 }

 /* Call Reservations — ghost */
 .cta-immersive .cta-immersive__btn-call {
     font-family: 'Jost', sans-serif;
     font-size: 0.75rem;
     font-weight: 500;
     letter-spacing: 0.18em;
     text-transform: uppercase;
     color: var(--gold-pale);
     background: transparent;
     border: 1px solid rgba(184, 137, 42, 0.4);
     padding: 0.85rem 2.6rem;
     text-decoration: none;
     display: inline-flex;
     align-items: center;
     gap: 0.5rem;
     transition: border-color 0.3s, color 0.3s;
 }

 .cta-immersive .cta-immersive__btn-call:hover {
     border-color: var(--gold-light);
     color: var(--gold-light);
 }

 .cta-immersive .cta-immersive__btn-call svg {
     width: 13px;
     height: 13px;
     fill: currentColor;
 }

 .cta-immersive .cta-immersive__note {
     margin-top: 1.8rem;
     font-size: 0.68rem;
     letter-spacing: 0.1em;
     color: rgba(240, 216, 152, 0.3);
     opacity: 0;
 }


 /* ══════════════════════════════════════════
       CTA 2 — FRAMED EDITORIAL
       Cream bg, double-border frame, side layout
    ══════════════════════════════════════════ */

 .cta-framed {
     background: var(--warm-mid);
     padding: 60px 0px;
 }

 .cta-framed .cta-framed__frame {
     max-width: 960px;
     margin: 0 auto;
     border: 1px solid var(--border);
     padding: clamp(2.5rem, 5vw, 4rem);
     position: relative;
     opacity: 0;
 }

 /* inner double-border inset */
 .cta-framed .cta-framed__frame::before {
     content: '';
     position: absolute;
     inset: 8px;
     border: 1px solid var(--border);
     pointer-events: none;
 }

 /* corner gold dots */
 .cta-framed .cta-framed__dot {
     position: absolute;
     width: 7px;
     height: 7px;
     background: var(--gold);
     border-radius: 50%;
 }

 .cta-framed .cta-framed__dot--tl {
     top: -4px;
     left: -4px;
 }

 .cta-framed .cta-framed__dot--tr {
     top: -4px;
     right: -4px;
 }

 .cta-framed .cta-framed__dot--bl {
     bottom: -4px;
     left: -4px;
 }

 .cta-framed .cta-framed__dot--br {
     bottom: -4px;
     right: -4px;
 }

 .cta-framed .cta-framed__layout {
     position: relative;
     z-index: 1;
     display: flex;
     align-items: center;
     gap: clamp(2rem, 5vw, 5rem);
     flex-wrap: wrap;
 }

 /* left: text block */
 .cta-framed .cta-framed__text {
     flex: 1;
     min-width: 220px;
 }

 .cta-framed .cta-framed__badge {
     display: inline-flex;
     align-items: center;
     gap: 0.5rem;
     font-size: 0.62rem;
     letter-spacing: 0.28em;
     text-transform: uppercase;
     color: var(--gold);
     margin-bottom: 1.1rem;
     opacity: 0;
 }

 .cta-framed .cta-framed__badge::before,
 .cta-framed .cta-framed__badge::after {
     content: '';
     display: block;
     width: 18px;
     height: 1px;
     background: var(--gold);
     opacity: 0.5;
 }

 .cta-framed .cta-framed__heading {
     font-family: 'Playfair Display', serif;
     font-size: clamp(1.9rem, 3.5vw, 2.8rem);
     font-weight: 700;
     color: var(--text-dark);
     line-height: 1.15;
     margin-bottom: 0.7rem;
     opacity: 0;
 }

 .cta-framed .cta-framed__heading em {
     font-style: italic;
     color: var(--gold-dark);
 }

 .cta-framed .cta-framed__desc {
     font-size: 0.83rem;
     font-weight: 300;
     color: var(--text-mid);
     line-height: 1.7;
     max-width: 34ch;
     opacity: 0;
 }

 /* vertical divider */
 .cta-framed .cta-framed__vline {
     width: 1px;
     align-self: stretch;
     min-height: 100px;
     background: var(--border);
     flex-shrink: 0;
     opacity: 0;
 }

 /* right: action block */
 .cta-framed .cta-framed__action {
     display: flex;
     flex-direction: column;
     align-items: flex-start;
     gap: 1rem;
     min-width: 200px;
     opacity: 0;
 }

 .cta-framed .cta-framed__avail {
     font-size: 0.68rem;
     letter-spacing: 0.14em;
     text-transform: uppercase;
     color: var(--text-light);
 }

 .cta-framed .cta-framed__avail strong {
     display: block;
     font-family: 'Playfair Display', serif;
     font-size: 1.05rem;
     font-weight: 400;
     letter-spacing: 0;
     text-transform: none;
     color: var(--text-dark);
     margin-top: 0.2rem;
 }

 /* Book Now */
 .cta-framed .cta-framed__btn-book {
     font-family: 'Jost', sans-serif;
     font-size: 0.74rem;
     font-weight: 500;
     letter-spacing: 0.16em;
     text-transform: uppercase;
     color: var(--white);
     background: var(--gold-dark);
     border: 1px solid var(--gold-dark);
     padding: 0.8rem 2rem;
     text-decoration: none;
     display: inline-block;
     width: 100%;
     text-align: center;
     transition: background 0.28s, border-color 0.28s;
 }

 .cta-framed .cta-framed__btn-book:hover {
     background: var(--gold);
     border-color: var(--gold);
     color: var(--white);
 }

 /* Call */
 .cta-framed .cta-framed__btn-call {
     font-family: 'Jost', sans-serif;
     font-size: 0.74rem;
     font-weight: 400;
     letter-spacing: 0.12em;
     text-transform: uppercase;
     color: var(--text-mid);
     text-decoration: none;
     display: inline-flex;
     align-items: center;
     gap: 0.45rem;
     padding: 0.5rem 0;
     border-bottom: 1px solid var(--border);
     width: 100%;
     transition: color 0.25s, border-color 0.25s;
 }

 .cta-framed .cta-framed__btn-call:hover {
     color: var(--gold-dark);
     border-color: var(--gold);
 }

 .cta-framed .cta-framed__btn-call svg {
     width: 13px;
     height: 13px;
     fill: currentColor;
 }

 @media (max-width: 600px) {
     .cta-framed .cta-framed__vline {
         display: none;
     }

     .cta-framed .cta-framed__action {
         width: 100%;
     }

     .cta-framed .cta-framed__btn-book {
         width: 100%;
     }

     .cta-framed .cta-framed__btn-call {
         width: auto;
     }

     .hd-outer-wrapper {
         display: none !important;
     }
 }


 /* HIDE ON DESKTOP */
 .nav-top {
     display: none;
 }

 /* MOBILE ONLY */
 @media (max-width: 768px) {

     .nav-top {
         display: block;
         /* background: var(--warm-bg); */
         /* border-bottom: 1px solid var(--border); */
     }

     .nav-top .nav-top-inner {
         display: flex;
         flex-direction: column;
         align-items: center;
         gap: 6px;
         padding: 8px 0;
     }

     /* CONTACT WRAPPER (PILL STYLE) */
     .nav-top .nav-contact {
         display: flex;
         align-items: center;
         gap: 10px;

         padding: 6px 14px;
         border-radius: 50px;

         background: linear-gradient(145deg, var(--warm-card), var(--warm-deep));
         border: 1px solid var(--border);

         box-shadow:
             0 2px 8px var(--shadow),
             inset 0 0 0 rgba(255, 255, 255, 0);

         transition: all 0.3s ease;
     }

     /* ICON (GOLD BADGE STYLE) */
     .nav-top .nav-contact i {
         width: 26px;
         height: 26px;

         display: flex;
         align-items: center;
         justify-content: center;

         border-radius: 50%;

         background: linear-gradient(145deg, var(--gold), var(--gold-light));
         color: var(--black);

         font-size: 11px;

         box-shadow:
             0 2px 6px rgba(212, 169, 78, 0.4);
     }

     /* TEXT */
     .nav-top .nav-contact a {
         color: var(--text-mid);
         text-decoration: none;
         font-size: 13px;
         letter-spacing: 0.3px;
         transition: 0.3s;
     }

     /* HOVER EFFECT */
     .nav-top .nav-contact:hover {
         transform: translateY(-2px);
         box-shadow:
             0 6px 18px rgba(212, 169, 78, 0.2);
     }

     .nav-top .nav-contact:hover a {
         color: var(--gold-light);
     }

     /* SOCIAL WRAPPER */
     .nav-top .nav-social {
         display: flex;
         gap: 20px;
         margin-top: 10px;
     }

     /* ICON DESIGN */
     .nav-top .nav-social a {
         width: 34px;
         height: 34px;
         display: flex;
         align-items: center;
         justify-content: center;

         border-radius: 50%;
         text-decoration: none;

         background: linear-gradient(145deg, var(--warm-card), var(--warm-deep));
         border: 1px solid var(--border);

         color: var(--gold);
         font-size: 14px;

         box-shadow:
             0 2px 6px var(--shadow),
             inset 0 0 0 rgba(255, 255, 255, 0);

         transition: all 0.35s ease;
     }

     /* HOVER / TAP EFFECT */
     .nav-top .nav-social a:hover {
         background: linear-gradient(145deg, var(--gold), var(--gold-light));
         color: var(--black);

         transform: translateY(-2px) scale(1.05);

         box-shadow:
             0 6px 18px rgba(212, 169, 78, 0.35),
             0 0 10px rgba(212, 169, 78, 0.25);
     }

     /* CLICK FEEDBACK */
     .nav-top .nav-social a:active {
         transform: scale(0.95);
         box-shadow: inset 0 2px 6px var(--shadow);
     }

     .ov-stat {
         padding: 22px 16px;
         border-right: none;
         border-bottom: 1px solid var(--border);
         background: var(--warm-card);
         text-align: center;
         transition: background .3s;
     }

     .hero-italic {
         display: block;
         font-style: italic;
         color: var(--gold-pale);
         font-family: 'Cormorant Garamond', serif;
         font-size: clamp(2.4rem, 8.5vw, 7rem);
         font-weight: 300;
         line-height: 1.05;
     }

     #home {
         position: relative;
         height: 100vh;
         display: flex;
         align-items: end;
         justify-content: center;
         overflow: hidden;
         padding-bottom: 60px;
     }

     nav .nav-logo .logo {
         width: 180px;
     }
 }