/* ─── UHB LUXURY THEME ─────────────────────────────────────────────────── */
:root {
  --black: #0a0a0a; --deep: #111111; --dark: #1a1a1a; --charcoal: #2a2a2a;
  --gold: #C9A84C; --gold-light: #E8C97A; --gold-dim: #8a6f2e;
  --cream: #F5F0E8; --white: #ffffff; --muted: #888888;
  --border: rgba(201,168,76,0.25);
  --font-display: 'Cormorant Garamond', serif;
  --font-sans: 'Montserrat', sans-serif;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--black); color:var(--cream); font-family:var(--font-sans); font-weight:300; overflow-x:hidden; line-height:1.7; }
::-webkit-scrollbar { width:4px; } ::-webkit-scrollbar-track { background:var(--black); } ::-webkit-scrollbar-thumb { background:var(--gold-dim); }
::selection { background:var(--gold); color:var(--black); }
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; }
em { font-style:italic; color:var(--gold); }

/* Typography */
.section-label { font-size:10px; font-weight:500; letter-spacing:5px; text-transform:uppercase; color:var(--gold); margin-bottom:1rem; display:block; }
.section-title { font-family:var(--font-display); font-size:clamp(32px,5vw,52px); font-weight:300; line-height:1.15; color:var(--white); }
.section-sub { font-size:14px; color:var(--muted); max-width:560px; margin-top:1rem; line-height:1.8; }
.gold-line { display:block; width:60px; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); margin:1.5rem 0; }
.gold-line.center { margin:1.5rem auto; }
.text-center { text-align:center; }
.mt-1 { margin-top:1rem; } .mt-2 { margin-top:2rem; } .mt-3 { margin-top:3rem; }
.center-text { margin-left:auto; margin-right:auto; }

/* Layout */
.container { max-width:1200px; margin:0 auto; padding:0 40px; }
.container-wide { max-width:1400px; margin:0 auto; padding:0 40px; }
section { padding:100px 0; }

/* Buttons */
.btn { display:inline-block; padding:14px 36px; font-family:var(--font-sans); font-size:11px; font-weight:500; letter-spacing:3px; text-transform:uppercase; cursor:pointer; transition:all .3s; border:none; }
.btn-gold { background:var(--gold); color:var(--black); }
.btn-gold:hover { background:var(--gold-light); transform:translateY(-2px); }
.btn-outline { background:transparent; color:var(--gold); border:1px solid var(--gold); }
.btn-outline:hover { background:var(--gold); color:var(--black); transform:translateY(-2px); }
.btn-full { width:100%; text-align:center; display:block; }

/* Alert */
.alert-success { background:rgba(201,168,76,0.15); border-bottom:1px solid var(--gold); padding:14px 0; font-size:13px; color:var(--gold); text-align:center; }

/* Ads */
.ad-slot { background:var(--black); padding:28px 40px; }
.ad-slot-label { max-width:1120px; margin:0 auto 8px; font-size:8px; letter-spacing:3px; text-transform:uppercase; color:rgba(245,240,232,.36); text-align:center; }
.ad-slot-inner { width:100%; max-width:1120px; min-height:90px; margin:0 auto; display:flex; align-items:center; justify-content:center; overflow:hidden; background:rgba(255,255,255,.025); border:1px solid rgba(201,168,76,.16); }
.ad-slot-inner > * { max-width:100%; }
.ad-slot-inner iframe,.ad-slot-inner img,.ad-slot-inner ins { max-width:100% !important; }
.ad-slot-inner:empty::before { content:"Ad slot"; font-size:10px; letter-spacing:3px; text-transform:uppercase; color:rgba(245,240,232,.28); }
.ad-slot-vertical { padding:24px 0 0; background:transparent; }
.ad-slot-vertical .ad-slot-label { max-width:100%; text-align:left; margin:0 0 8px; }
.ad-slot-vertical .ad-slot-inner { max-width:336px; min-height:250px; background:rgba(10,10,10,.32); }

/* WhatsApp Float */
.whatsapp-float { position:fixed; bottom:32px; right:32px; z-index:999; width:52px; height:52px; background:#25D366; border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; box-shadow:0 4px 20px rgba(37,211,102,.35); transition:transform .2s; }
.whatsapp-float:hover { transform:scale(1.08); }

/* NAV */
.navbar { position:fixed; top:0; left:0; right:0; z-index:1000; padding:20px 40px; transition:all .4s; }
.navbar.scrolled { background:rgba(10,10,10,.97); padding:14px 40px; border-bottom:1px solid var(--border); }
.nav-container { max-width:1400px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; }
.nav-logo { display:flex; align-items:center; gap:12px; min-width:0; }
.nav-logo-img { width:42px; height:42px; object-fit:contain; flex:0 0 auto; filter:drop-shadow(0 8px 18px rgba(0,0,0,.35)); }
.nav-logo-text { display:block; min-width:0; }
.nav-logo-main { font-family:var(--font-display); font-size:20px; font-weight:500; color:var(--white); line-height:1; display:block; max-width:290px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.nav-logo-sub { font-size:9px; letter-spacing:4px; color:var(--gold); text-transform:uppercase; margin-top:3px; display:block; max-width:290px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.nav-links { display:flex; gap:28px; list-style:none; }
.nav-links a { font-size:11px; font-weight:400; letter-spacing:2px; text-transform:uppercase; color:rgba(245,240,232,.7); transition:color .2s; }
.nav-links a:hover, .nav-links a.active { color:var(--gold); }
.nav-cta { font-size:10px; font-weight:500; letter-spacing:3px; text-transform:uppercase; color:var(--black); background:var(--gold); padding:10px 24px; transition:all .2s; }
.nav-cta:hover { background:var(--gold-light); }
.nav-dropdown { position:relative; }
.dropdown-menu { display:none; position:absolute; top:100%; left:0; background:rgba(17,17,17,.98); border:1px solid var(--border); min-width:200px; padding:8px 0; z-index:100; }
.nav-dropdown:hover .dropdown-menu { display:block; }
.dropdown-menu li a { display:block; padding:10px 20px; font-size:12px; color:rgba(245,240,232,.7); }
.dropdown-menu li a:hover { color:var(--gold); background:rgba(201,168,76,.05); }
.hamburger { display:none; background:none; border:none; cursor:pointer; }
.hamburger span { display:block; width:24px; height:1px; background:var(--cream); margin:6px 0; transition:all .3s; }
.mobile-nav { position:fixed; inset:0; background:radial-gradient(circle at top left,rgba(201,168,76,.13),transparent 34%),rgba(10,10,10,.98); z-index:999; display:flex; flex-direction:column; align-items:stretch; justify-content:center; gap:10px; transform:translateX(100%); transition:transform .4s; padding:84px 24px 34px; overflow-y:auto; }
.mobile-nav.open { transform:translateX(0); }
.mobile-nav a { font-family:var(--font-sans); font-size:13px; font-weight:500; letter-spacing:2.8px; text-transform:uppercase; color:var(--cream); padding:13px 16px; border:1px solid rgba(201,168,76,.14); background:rgba(255,255,255,.025); text-align:center; }
.mobile-nav a:hover,.mobile-nav a.active { color:var(--gold); border-color:rgba(201,168,76,.42); background:rgba(201,168,76,.08); }
.mobile-nav-group { display:flex; flex-direction:column; align-items:stretch; gap:8px; }
.mobile-submenu { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:8px; }
.mobile-submenu a { font-family:var(--font-sans); font-size:9px; font-weight:600; letter-spacing:1.6px; text-transform:uppercase; color:rgba(245,240,232,.68); border:1px solid rgba(201,168,76,.2); padding:9px 8px; background:rgba(0,0,0,.22); }
.mobile-submenu a:hover { color:var(--gold-light); border-color:rgba(201,168,76,.48); background:rgba(201,168,76,.08); }
.mobile-nav-close { position:absolute; top:24px; right:24px; background:none; border:none; color:var(--cream); font-size:28px; cursor:pointer; }

/* HERO */
.hero { height:100vh; min-height:700px; display:flex; align-items:center; position:relative; overflow:hidden; padding:0; }
.hero-bg { position:absolute; inset:0; background:url('/images/hero-hotel.svg') center/cover no-repeat; }
.hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(10,10,10,.92) 0%,rgba(10,10,10,.6) 50%,rgba(10,10,10,.85) 100%); }
.hero-media-set { position:absolute; inset:0; }
.hero-media-mobile { display:none; }
.hero-media { position:absolute; inset:0; width:100%; height:100%; }
.hero-media img, .hero-media video, .hero-video { width:100%; height:100%; object-fit:cover; }
.hero-video { position:absolute; inset:0; }
.hero-fallback-image { display:none; }
.hero-video:not([src]) + .hero-fallback-image { display:block; }
.hero-pattern { position:absolute; inset:0; background-image:linear-gradient(rgba(201,168,76,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(201,168,76,.04) 1px,transparent 1px); background-size:80px 80px; }
.hero-content { position:relative; z-index:2; width:100%; }
.hero-eyebrow { display:flex; align-items:center; gap:16px; margin-bottom:2rem; }
.hero-eyebrow span { font-size:10px; letter-spacing:5px; text-transform:uppercase; color:var(--gold); }
.hero-eyebrow::before { content:''; display:block; width:40px; height:1px; background:var(--gold); }
.hero-title { font-family:var(--font-display); font-size:clamp(48px,8vw,96px); font-weight:300; line-height:1.05; color:var(--white); max-width:800px; margin-bottom:1.5rem; }
.hero-subtitle { font-size:13px; color:rgba(245,240,232,.65); max-width:480px; margin-bottom:3rem; line-height:1.9; }
.hero-actions { display:flex; gap:20px; align-items:center; flex-wrap:wrap; }
.hero-scroll { position:absolute; bottom:40px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; z-index:2; animation:bounce 2s ease-in-out infinite; }
.hero-scroll span { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--muted); }
.hero-scroll::after { content:''; display:block; width:1px; height:40px; background:linear-gradient(to bottom,var(--gold),transparent); }
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(-8px)} }

/* MARQUEE */
.marquee-wrapper { background:var(--gold); padding:14px 0; overflow:hidden; white-space:nowrap; }
.marquee-track { display:inline-flex; animation:marquee 25s linear infinite; }
.marquee-item { font-size:10px; letter-spacing:4px; text-transform:uppercase; color:var(--black); font-weight:500; padding:0 32px; }
.marquee-dot { color:rgba(0,0,0,.3); }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ABOUT */
.section-about { background:var(--deep); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-image-wrapper { position:relative; }
.about-img { width:100%; aspect-ratio:4/5; object-fit:cover; }
.about-img-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(201,168,76,.08),transparent); }
.about-stat-row { display:flex; gap:40px; margin-top:3rem; padding-top:2rem; border-top:1px solid var(--border); }
.about-stat-num { font-family:var(--font-display); font-size:48px; font-weight:300; color:var(--gold); line-height:1; }
.about-stat-label { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-top:6px; }
.trust-stamps { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; margin-top:28px; }
.trust-stamp { display:flex; align-items:center; gap:12px; min-width:0; padding:12px; border:1px solid rgba(201,168,76,.2); background:rgba(255,255,255,.025); }
.trust-stamp-mark { width:46px; height:46px; flex:0 0 46px; display:flex; align-items:center; justify-content:center; border:1px solid rgba(201,168,76,.26); background:rgba(10,10,10,.38); }
.trust-stamp-mark img { width:100%; height:100%; object-fit:contain; padding:4px; }
.trust-stamp-mark span { font-family:var(--font-display); font-size:22px; color:var(--gold); }
.trust-stamp-copy { min-width:0; display:flex; flex-direction:column; gap:2px; }
.trust-stamp-copy strong { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--cream); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.trust-stamp-copy span { font-size:10px; color:var(--muted); line-height:1.45; overflow-wrap:anywhere; }
.trust-stamps-footer { grid-template-columns:1fr; gap:8px; margin:18px 0 20px; }
.trust-stamps-footer .trust-stamp { padding:9px 10px; }
.trust-stamps-footer .trust-stamp-mark { width:34px; height:34px; flex-basis:34px; }
.trust-stamps-footer .trust-stamp-copy strong { font-size:9px; letter-spacing:1.8px; }
.trust-stamps-footer .trust-stamp-copy span { font-size:9px; }

/* PACKAGES */
.section-packages { background:var(--black); }
.packages-header { margin-bottom:60px; }
.packages-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.package-card { background:var(--deep); padding:44px 28px; position:relative; transition:all .4s; border-bottom:2px solid transparent; }
.package-card:hover,.package-card.featured { background:var(--dark); border-bottom-color:var(--gold); transform:translateY(-4px); }
.package-badge { position:absolute; top:16px; right:16px; font-size:8px; letter-spacing:3px; text-transform:uppercase; color:var(--black); background:var(--gold); padding:5px 12px; }
.package-tier { font-size:9px; letter-spacing:4px; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.package-name { font-family:var(--font-display); font-size:28px; font-weight:300; color:var(--white); margin-bottom:8px; }
.package-price { font-family:var(--font-display); font-size:20px; font-weight:400; color:var(--gold-light); margin-bottom:24px; }
.package-price span { font-size:12px; color:var(--muted); font-family:var(--font-sans); }
.package-divider { width:40px; height:1px; background:var(--border); margin-bottom:24px; }
.package-benefits { list-style:none; margin-bottom:28px; }
.package-benefits li { font-size:12px; color:rgba(245,240,232,.7); padding:7px 0; display:flex; gap:10px; border-bottom:1px solid rgba(201,168,76,.08); }
.package-benefits li::before { content:'—'; color:var(--gold); flex-shrink:0; }
.package-vouchers { font-size:11px; color:var(--gold); margin-bottom:24px; }
.package-vouchers.muted { color:var(--muted); }

/* TRUST */
.section-how { background:linear-gradient(180deg,var(--black),var(--deep)); }
.trust-header { max-width:680px; margin-bottom:48px; }
.how-steps-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.how-step { background:rgba(255,255,255,.025); border:1px solid rgba(201,168,76,.14); padding:34px 26px; min-height:220px; transition:all .25s; }
.how-step:hover { border-color:rgba(201,168,76,.42); background:rgba(201,168,76,.05); transform:translateY(-3px); }
.how-step-num { font-family:var(--font-display); font-size:34px; color:var(--gold); line-height:1; margin-bottom:24px; }
.how-step h3 { font-family:var(--font-display); font-size:22px; font-weight:300; color:var(--white); margin-bottom:12px; }
.how-step p { font-size:12px; color:var(--muted); line-height:1.8; }
.section-partner-strip { background:var(--black); padding:70px 0; border-top:1px solid rgba(201,168,76,.14); border-bottom:1px solid rgba(201,168,76,.14); }
.partner-strip-head { display:flex; justify-content:space-between; align-items:center; gap:20px; margin-bottom:24px; }
.partner-strip-head .section-label { margin-bottom:0; }
.partner-strip-head a { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); }
.partner-logo-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.partner-logo-item { min-height:110px; border:1px solid rgba(201,168,76,.14); background:rgba(255,255,255,.02); display:flex; align-items:center; gap:14px; padding:18px; transition:all .25s; }
.partner-logo-item:hover { border-color:var(--gold); background:rgba(201,168,76,.06); }
.partner-logo-item img,.partner-logo-item span { width:52px; height:52px; object-fit:cover; flex:0 0 auto; background:var(--deep); border:1px solid rgba(201,168,76,.2); }
.partner-logo-item span { display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:28px; color:var(--gold); }
.partner-logo-item strong { font-family:var(--font-display); font-size:18px; font-weight:300; color:var(--cream); line-height:1.2; }

/* VOUCHERS */
.section-vouchers { background:var(--deep); }
.vouchers-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:24px; margin-top:48px; }
.voucher-card { border:1px solid var(--border); padding:36px 24px; position:relative; overflow:hidden; transition:all .3s; }
.voucher-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--gold),transparent); transform:scaleX(0); transition:transform .4s; }
.voucher-card:hover { background:rgba(201,168,76,.04); } .voucher-card:hover::before { transform:scaleX(1); }
.voucher-icon { font-size:28px; margin-bottom:16px; }
.voucher-title { font-family:var(--font-display); font-size:20px; font-weight:300; color:var(--white); margin-bottom:10px; }
.voucher-desc { font-size:12px; color:var(--muted); line-height:1.8; }

/* HOTELS */
.section-hotels { background:var(--black); }
.hotels-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px; margin-top:48px; }
.hotel-card { position:relative; overflow:hidden; aspect-ratio:4/3; }
.hotel-card img { width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.hotel-card:hover img { transform:scale(1.06); }
.hotel-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.1) 60%); display:flex; flex-direction:column; justify-content:flex-end; padding:24px; }
.hotel-city { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.hotel-name { font-family:var(--font-display); font-size:20px; font-weight:300; color:var(--white); }
.hotel-discount { font-size:11px; color:var(--gold-light); margin-top:4px; }
.hotel-card.large { grid-column:span 2; }

/* COVERAGE */
.city-coverage-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:3px; }
.city-coverage-card { position:relative; overflow:hidden; aspect-ratio:4/3; display:block; text-decoration:none; background:var(--deep); }
.city-coverage-card img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.city-coverage-card:hover img { transform:scale(1.06); }
.city-coverage-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.85),rgba(0,0,0,.1)); display:flex; flex-direction:column; justify-content:flex-end; padding:24px; }
.city-coverage-count { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.city-coverage-name { font-family:var(--font-display); font-size:22px; font-weight:300; color:var(--white); }

/* TESTIMONIALS */
.section-testimonials { background:var(--deep); }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px; margin-top:60px; }
.testimonial-card { background:var(--dark); padding:40px 32px; }
.testimonial-quote { font-family:var(--font-display); font-size:60px; color:var(--gold); line-height:.5; margin-bottom:20px; opacity:.4; }
.testimonial-text { font-family:var(--font-display); font-size:16px; font-style:italic; color:rgba(245,240,232,.85); line-height:1.7; margin-bottom:24px; }
.testimonial-stars { color:var(--gold); font-size:12px; letter-spacing:3px; margin-bottom:16px; }
.testimonial-author { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); }
.testimonial-role { font-size:11px; color:var(--muted); margin-top:4px; }

/* CTA */
.cta-banner { padding:120px 0; background:linear-gradient(135deg,rgba(201,168,76,.08) 0%,transparent 50%,rgba(201,168,76,.04) 100%); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.cta-title { font-family:var(--font-display); font-size:clamp(36px,6vw,68px); font-weight:300; color:var(--white); margin-bottom:1.5rem; }
.cta-sub { font-size:13px; color:var(--muted); max-width:480px; margin:0 auto 3rem; line-height:1.8; }
.cta-actions { display:flex; gap:20px; justify-content:center; align-items:center; flex-wrap:wrap; }

/* FOOTER */
.footer { background:var(--deep); padding:80px 0 40px; border-top:1px solid var(--border); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:60px; margin-bottom:48px; }
.footer-logo-name { font-family:var(--font-display); font-size:26px; font-weight:300; color:var(--white); }
.footer-logo-tagline { font-size:9px; letter-spacing:4px; color:var(--gold); text-transform:uppercase; margin-top:4px; }
.footer-brand p { font-size:13px; color:var(--muted); line-height:1.8; margin-top:14px; max-width:280px; }
.footer-social { display:flex; gap:10px; margin-top:24px; }
.social-link { width:36px; height:36px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--muted); transition:all .2s; }
.social-link:hover { border-color:var(--gold); color:var(--gold); }
.footer-col h4 { font-size:10px; letter-spacing:4px; text-transform:uppercase; color:var(--gold); margin-bottom:24px; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:12px; }
.footer-links a { font-size:13px; color:var(--muted); transition:color .2s; }
.footer-links a:hover { color:var(--cream); }
.footer-contact-bar { display:flex; gap:40px; padding:24px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); flex-wrap:wrap; margin-bottom:24px; }
.footer-contact-item { display:flex; align-items:center; gap:10px; font-size:12px; color:var(--muted); }
.footer-contact-item a:hover { color:var(--gold); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; }
.footer-copy { font-size:11px; color:var(--muted); }
.footer-bottom-actions { display:flex; align-items:center; gap:16px; flex-wrap:wrap; justify-content:flex-end; }
.footer-whatsapp { display:flex; align-items:center; gap:10px; font-size:11px; color:var(--gold); border:1px solid var(--border); padding:8px 18px; transition:all .2s; }
.footer-whatsapp:hover { background:rgba(201,168,76,.08); }
.footer-developer { margin-top:28px; padding-top:18px; border-top:1px solid rgba(201,168,76,.12); display:flex; flex-direction:column; align-items:flex-end; gap:12px; }
.footer-dev-line { display:flex; justify-content:flex-end; align-items:center; gap:10px; font-size:10px; letter-spacing:2.5px; text-transform:uppercase; color:rgba(245,240,232,.38); }
.footer-dev-line strong { display:inline-flex; align-items:center; justify-content:center; min-width:34px; min-height:28px; padding:0 10px; border:1px solid rgba(201,168,76,.36); background:linear-gradient(135deg,rgba(201,168,76,.2),rgba(201,168,76,.06)); color:var(--gold-light); font-weight:600; letter-spacing:1px; box-shadow:0 10px 24px rgba(0,0,0,.25); }
.footer-dev-socials { display:flex; align-items:center; justify-content:flex-end; gap:8px; flex-wrap:wrap; }
.footer-dev-socials a { width:30px; height:30px; border:1px solid rgba(201,168,76,.24); background:rgba(255,255,255,.025); color:rgba(245,240,232,.52); display:flex; align-items:center; justify-content:center; transition:all .2s; }
.footer-dev-socials a:hover { border-color:var(--gold); color:var(--gold-light); background:rgba(201,168,76,.1); transform:translateY(-2px); }

/* FORMS */
.form-section { background:var(--black); }
.form-section.alt { background:var(--deep); }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:8px; margin-bottom:4px; }
.form-label { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--muted); }
.form-input,.form-select,.form-textarea { background:var(--deep); border:1px solid rgba(255,255,255,.07); color:var(--cream); padding:14px 18px; font-family:var(--font-sans); font-size:13px; font-weight:300; transition:border-color .2s; outline:none; width:100%; appearance:none; }
.form-input:focus,.form-select:focus,.form-textarea:focus { border-color:var(--gold); }
.form-input::placeholder,.form-textarea::placeholder { color:rgba(255,255,255,.2); }
.form-textarea { resize:vertical; min-height:120px; }
.form-select option { background:var(--deep); }
.form-error { font-size:11px; color:#e74c3c; margin-top:4px; }
.booking-form { display:flex; flex-direction:column; gap:16px; }

/* PAGE HEADER */
.page-header { padding:140px 0 80px; background:var(--deep); border-bottom:1px solid var(--border); text-align:center; position:relative; }
.page-header::before { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(201,168,76,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(201,168,76,.03) 1px,transparent 1px); background-size:60px 60px; }
.page-header-cover { background-image:linear-gradient(rgba(10,10,10,.78),rgba(10,10,10,.82)),var(--page-cover); background-size:cover; background-position:center; }
.page-header .container,.page-header .section-title { position:relative; z-index:1; }
.contact-layout,.package-detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.contact-layout > *,.package-detail-grid > * { min-width:0; }
.contact-details-panel a,.contact-details-panel div { overflow-wrap:anywhere; }
.package-stats-grid { display:grid; grid-template-columns:1fr 1fr; gap:2px; margin-top:32px; }
.vouchers-page-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
.detail-rich-text { overflow-wrap:anywhere; word-break:break-word; }
.page-breadcrumb { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-top:16px; }
.page-breadcrumb a { color:var(--gold); }

/* HOTEL GRID PAGE */
.hotel-listing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.hotel-listing-card { background:var(--deep); border:1px solid var(--border); overflow:hidden; transition:all .3s; }
.hotel-listing-card:hover { border-color:var(--gold); transform:translateY(-4px); }
.hotel-listing-img { aspect-ratio:16/9; overflow:hidden; position:relative; }
.hotel-listing-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.hotel-listing-card:hover .hotel-listing-img img { transform:scale(1.04); }
.hotel-listing-body { padding:24px; }
.hotel-listing-city { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:8px; }
.hotel-listing-name { font-family:var(--font-display); font-size:22px; font-weight:300; color:var(--white); margin-bottom:8px; }
.hotel-listing-discount { font-size:12px; color:var(--gold-light); }
.hotel-type-switch { display:flex; gap:12px; margin-bottom:18px; flex-wrap:wrap; padding-bottom:18px; border-bottom:1px solid rgba(201,168,76,.14); }
.hotel-type-badge { position:absolute; top:14px; left:14px; padding:7px 12px; background:rgba(10,10,10,.78); border:1px solid rgba(201,168,76,.34); color:var(--gold-light); font-size:9px; font-weight:500; letter-spacing:2px; text-transform:uppercase; backdrop-filter:blur(10px); }
.hotel-type-badge.demand { color:rgba(245,240,232,.82); border-color:rgba(245,240,232,.24); }
.hotel-filter-bar { display:flex; gap:12px; margin-bottom:40px; flex-wrap:wrap; }
.filter-btn { display:inline-flex; align-items:center; justify-content:center; min-height:38px; padding:10px 24px; border:1px solid var(--border); background:transparent; color:var(--muted); font-size:11px; letter-spacing:2px; text-transform:uppercase; cursor:pointer; transition:all .2s; text-decoration:none; }
.filter-btn:hover,.filter-btn.active { border-color:var(--gold); color:var(--gold); background:rgba(201,168,76,.05); }

/* PAGINATION */
.uhb-pagination { margin:56px auto 0; padding:14px; border:1px solid rgba(201,168,76,.36); background:linear-gradient(135deg,rgba(201,168,76,.16),rgba(17,17,17,.94) 42%,rgba(232,201,122,.08)); display:flex; align-items:center; justify-content:space-between; gap:18px; box-shadow:0 24px 70px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.06); position:relative; overflow:hidden; }
.uhb-pagination::before { content:''; position:absolute; inset:0; background:linear-gradient(90deg,transparent,rgba(201,168,76,.14),transparent); opacity:.55; pointer-events:none; }
.uhb-pagination-summary { position:relative; color:rgba(245,240,232,.68); font-size:10px; letter-spacing:2.4px; text-transform:uppercase; white-space:nowrap; padding-left:8px; }
.uhb-pagination-links { position:relative; display:flex; align-items:center; justify-content:flex-end; gap:8px; flex-wrap:wrap; }
.uhb-page-btn,.uhb-page-number,.uhb-page-ellipsis { min-width:42px; height:42px; padding:0 14px; display:inline-flex; align-items:center; justify-content:center; border:1px solid rgba(201,168,76,.28); background:rgba(10,10,10,.58); color:rgba(245,240,232,.74); font-size:11px; font-weight:500; letter-spacing:1.4px; text-transform:uppercase; text-decoration:none; transition:all .22s ease; box-shadow:inset 0 1px 0 rgba(255,255,255,.04); }
.uhb-page-btn { min-width:98px; background:linear-gradient(135deg,rgba(201,168,76,.18),rgba(201,168,76,.06)); color:var(--gold-light); }
.uhb-page-number { border-radius:50%; padding:0; width:42px; }
.uhb-page-number.active { border-color:var(--gold-light); background:radial-gradient(circle at 30% 20%,var(--gold-light),var(--gold)); color:var(--black); box-shadow:0 12px 28px rgba(201,168,76,.34); }
.uhb-page-btn:hover,.uhb-page-number:hover { border-color:var(--gold); background:rgba(201,168,76,.2); color:var(--gold-light); transform:translateY(-2px); }
.uhb-page-number.active:hover { color:var(--black); background:var(--gold-light); }
.uhb-page-btn.disabled,.uhb-page-ellipsis { opacity:.42; pointer-events:none; transform:none; }

/* FADE IN */
.fade-up { opacity:0; transform:translateY(30px); transition:opacity .7s ease,transform .7s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }
.fade-up:nth-child(2){transition-delay:.1s} .fade-up:nth-child(3){transition-delay:.2s} .fade-up:nth-child(4){transition-delay:.3s}

/* RESPONSIVE */
@media(max-width:1024px) {
  .packages-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hotels-grid{grid-template-columns:repeat(2,1fr)}
  .hotel-card.large{grid-column:span 1}
  .hotel-listing-grid{grid-template-columns:repeat(2,1fr)}
  .how-steps-grid,.partner-logo-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px) {
  .hero-media-desktop{display:none}
  .hero-media-mobile{display:block}
  .container,.container-wide{padding:0 20px}
  section{padding:60px 0}
  .navbar{padding:14px 20px}
  .navbar.scrolled{padding:10px 20px}
  .nav-logo-main{font-size:18px;max-width:220px}
  .nav-logo-sub{font-size:8px;letter-spacing:2.4px;max-width:220px}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:block}
  .about-grid,.form-grid{grid-template-columns:1fr;gap:40px}
  .contact-layout,.package-detail-grid{grid-template-columns:1fr;gap:42px}
  .contact-form-panel{order:1}
  .contact-details-panel{order:2}
  .packages-grid,.testimonials-grid{grid-template-columns:1fr}
  .how-steps-grid,.partner-logo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .how-step{min-height:auto;padding:26px 18px}
  .partner-strip-head{align-items:flex-start;flex-direction:column}
  .partner-logo-item{min-height:96px;flex-direction:column;align-items:flex-start}
  .partner-logo-item img,.partner-logo-item span{width:46px;height:46px}
  .partner-logo-item strong{font-size:16px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px 22px}
  .footer-brand{grid-column:1/-1}
  .form-row{grid-template-columns:1fr}
  .hotels-grid,.hotel-listing-grid,.city-coverage-grid,.vouchers-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:12px}
  .vouchers-page-grid{grid-template-columns:1fr !important}
  .package-detail-grid .btn{width:100%;text-align:center}
  .package-stats-grid{grid-template-columns:1fr 1fr}
  .detail-rich-text{padding:18px !important}
  .voucher-card{padding:24px 16px}
  .voucher-title{font-size:17px;line-height:1.15}
  .voucher-desc{font-size:11px}
  .hotel-listing-body{padding:14px}
  .hotel-listing-city,.city-coverage-count{font-size:8px;letter-spacing:2px}
  .hotel-listing-name,.city-coverage-name{font-size:17px;line-height:1.15}
  .hotel-listing-discount{font-size:11px}
  .city-coverage-overlay{padding:16px}
  .hotel-listing-card .btn{padding:11px 10px;font-size:9px;letter-spacing:2px}
  .ad-slot{padding:18px 20px}
  .ad-slot-hide-mobile{display:none}
  .ad-slot-inner{min-height:74px}
  .ad-slot-vertical{padding:18px 0 0}
  .ad-slot-vertical .ad-slot-inner{max-width:100%;min-height:160px}
  .uhb-pagination{align-items:stretch;flex-direction:column}
  .uhb-pagination-links{justify-content:flex-start}
  .uhb-page-btn{min-width:82px}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center}
  .footer-bottom-actions{justify-content:center}
  .footer-developer{align-items:center}
  .footer-dev-line{justify-content:center;flex-wrap:wrap;text-align:center}
  .footer-dev-socials{justify-content:center}
  .footer-contact-bar{flex-direction:column;gap:16px}
  .about-stat-row{flex-wrap:wrap;gap:24px}
  .trust-stamps{grid-template-columns:1fr}
}
@media(max-width:420px) {
  .nav-logo{gap:9px}
  .nav-logo-img{width:36px;height:36px}
  .nav-logo-main{font-size:16px;max-width:170px}
  .nav-logo-sub{font-size:7px;letter-spacing:1.8px;max-width:170px}
  .mobile-nav{gap:8px;padding:76px 18px 28px}
  .mobile-nav a{font-size:11px;letter-spacing:2.2px;padding:11px 12px}
  .mobile-submenu{grid-template-columns:1fr}
  .mobile-submenu a{font-size:9px;padding:9px 10px}
  .package-stats-grid{grid-template-columns:1fr}
}
