/* =====================================================
   Metro Hotel Gusinje — Main Stylesheet v1.0
===================================================== */
:root {
  --black:   #0a0a0a;
  --dark:    #111111;
  --charcoal:#1c1c1c;
  --gold:    #c9a96e;
  --gold2:   #e8c98a;
  --cream:   #f5f0e8;
  --white:   #ffffff;
  --muted:   #888880;
  --border:  rgba(201,169,110,0.2);
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Jost', sans-serif;
  --radius: 0px;
  --transition: 0.35s cubic-bezier(0.25,0.1,0.25,1);
}

/* ===== RESET ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { background:var(--dark); color:var(--cream); font-family:var(--font-body); font-weight:300; overflow-x:hidden; cursor:none; }
@media (max-width:768px) { body { cursor:auto; } }
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
button { font-family:var(--font-body); cursor:pointer; }
ul { list-style:none; }

/* ===== CURSOR ===== */
.metro-cursor { width:8px; height:8px; background:var(--gold); border-radius:50%; position:fixed; pointer-events:none; z-index:99999; transition:transform 0.15s ease; mix-blend-mode:difference; }
.metro-cursor-ring { width:36px; height:36px; border:1px solid rgba(201,169,110,0.5); border-radius:50%; position:fixed; pointer-events:none; z-index:99998; transition:all 0.35s cubic-bezier(0.25,0.1,0.25,1); }

/* ===== LOADER ===== */
#metro-loader { position:fixed; inset:0; background:var(--black); z-index:99990; display:flex; align-items:center; justify-content:center; flex-direction:column; gap:24px; transition:opacity 0.6s ease, visibility 0.6s ease; pointer-events:none; }
#metro-loader.hidden { opacity:0; visibility:hidden; pointer-events:none; }
#metro-loader.blocking { pointer-events:all; }
.loader-logo { font-family:var(--font-display); font-size:clamp(28px,5vw,48px); color:var(--cream); letter-spacing:0.3em; text-transform:uppercase; }
.loader-logo span { color:var(--gold); font-style:italic; }
.loader-sub { font-size:11px; letter-spacing:0.5em; color:var(--muted); text-transform:uppercase; }
.loader-bar { width:180px; height:1px; background:rgba(255,255,255,0.1); position:relative; overflow:hidden; }
.loader-bar::after { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:var(--gold); animation:loaderBar 2s cubic-bezier(0.65,0,0.35,1) forwards; }
@keyframes loaderBar { to { left:0; } }

/* ===== NAV ===== */
#metro-nav { position:fixed; top:0; left:0; right:0; z-index:1000; padding:28px 60px; display:flex; align-items:center; justify-content:space-between; transition:all 0.5s ease; }
#metro-nav.scrolled { background:rgba(10,10,10,0.92); backdrop-filter:blur(20px); padding:18px 60px; border-bottom:1px solid var(--border); }
.nav-logo-wrap { text-decoration:none; display:flex; flex-direction:column; line-height:1.1; }
.nav-logo-main { font-family:var(--font-display); font-size:20px; color:var(--cream); letter-spacing:0.15em; }
.nav-logo-sub { font-family:var(--font-body); font-size:9px; letter-spacing:0.5em; color:var(--gold); text-transform:uppercase; font-weight:400; }
.nav-menu { display:flex; gap:48px; }
.nav-menu a { font-size:11px; letter-spacing:0.25em; text-transform:uppercase; color:rgba(245,240,232,0.7); transition:color 0.3s; position:relative; }
.nav-menu a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:1px; background:var(--gold); transition:width 0.3s; }
.nav-menu a:hover, .nav-menu a:focus { color:var(--gold); }
.nav-menu a:hover::after { width:100%; }
.nav-book-btn { font-size:10px; letter-spacing:0.3em; text-transform:uppercase; color:var(--black); background:var(--gold); padding:12px 28px; font-weight:500; border:none; transition:all 0.3s; text-decoration:none; display:inline-block; }
.nav-book-btn:hover { background:var(--gold2); transform:translateY(-1px); }
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:4px; }
.nav-toggle span { display:block; width:24px; height:1px; background:var(--cream); transition:all 0.3s; }

/* ===== MOBILE MENU ===== */
#mobile-menu { position:fixed; inset:0; background:var(--black); z-index:9000; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:36px; transform:translateX(100%); transition:transform 0.5s cubic-bezier(0.76,0,0.24,1); }
#mobile-menu.open { transform:translateX(0); }
#mobile-menu a { font-family:var(--font-display); font-size:38px; color:var(--cream); font-style:italic; transition:color 0.3s; }
#mobile-menu a:hover { color:var(--gold); }
.mobile-close-btn { position:absolute; top:28px; right:40px; background:none; border:none; color:var(--cream); font-size:28px; }

/* ===== BUTTONS ===== */
.btn-primary { display:inline-flex; align-items:center; gap:12px; padding:16px 36px; background:var(--gold); color:var(--black); font-size:10px; letter-spacing:0.3em; text-transform:uppercase; font-weight:500; transition:all 0.3s; border:none; font-family:var(--font-body); }
.btn-primary:hover { background:var(--gold2); transform:translateY(-2px); box-shadow:0 12px 40px rgba(201,169,110,0.25); color:var(--black); }
.btn-outline { display:inline-flex; align-items:center; gap:12px; padding:16px 36px; background:transparent; border:1px solid rgba(245,240,232,0.4); color:var(--cream); font-size:10px; letter-spacing:0.3em; text-transform:uppercase; font-weight:400; transition:all 0.3s; font-family:var(--font-body); }
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }
.btn-gold-sm { padding:12px 24px; background:var(--gold); color:var(--black); font-size:10px; letter-spacing:0.25em; text-transform:uppercase; font-weight:500; border:none; transition:all 0.3s; font-family:var(--font-body); display:inline-block; }
.btn-gold-sm:hover { background:var(--gold2); color:var(--black); }

/* ===== SECTION BASE ===== */
.section-eyebrow { font-size:10px; letter-spacing:0.6em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; display:flex; align-items:center; gap:12px; }
.section-eyebrow::before { content:''; display:block; width:30px; height:1px; background:var(--gold); }
.section-title { font-family:var(--font-display); font-size:clamp(36px,4vw,64px); font-weight:400; line-height:1.05; color:var(--cream); }
.section-title em { font-style:italic; color:var(--gold); }

/* ===== HERO ===== */
.metro-hero { height:100vh; min-height:700px; position:relative; overflow:hidden; display:flex; align-items:flex-end; padding-bottom:80px; }
.hero-slides { position:absolute; inset:0; }
.hero-slide { position:absolute; inset:0; background-size:cover; background-position:center top; opacity:0; transition:opacity 1.5s ease; transform:scale(1.05); }
.hero-slide.active { opacity:1; transform:scale(1); transition:opacity 1.5s ease, transform 8s ease; }
.hero-slide::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom, rgba(10,10,10,0.3) 0%, rgba(10,10,10,0.1) 40%, rgba(10,10,10,0.75) 100%); }
.hero-content { position:relative; z-index:10; padding:0 60px; width:100%; max-width:1400px; margin:0 auto; }
.hero-eyebrow { font-size:10px; letter-spacing:0.6em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; display:flex; align-items:center; gap:16px; }
.hero-eyebrow::before { content:''; display:block; width:40px; height:1px; background:var(--gold); }
.hero-title { font-family:var(--font-display); font-size:clamp(52px,7vw,110px); font-weight:400; line-height:0.9; color:var(--white); margin-bottom:32px; }
.hero-title em { color:var(--gold); font-style:italic; display:block; }
.hero-meta { display:flex; align-items:center; gap:40px; }
.hero-subtitle { font-size:14px; color:rgba(245,240,232,0.7); line-height:1.6; max-width:320px; }
.hero-cta { display:flex; gap:16px; flex-wrap:wrap; }
.hero-indicators { position:absolute; right:60px; bottom:80px; display:flex; flex-direction:column; gap:10px; z-index:10; }
.hero-dot { width:2px; height:20px; background:rgba(255,255,255,0.2); cursor:pointer; transition:all 0.3s; }
.hero-dot.active { background:var(--gold); height:40px; }
.hero-scroll-hint { position:absolute; bottom:40px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; z-index:10; }
.hero-scroll-hint span { font-size:9px; letter-spacing:0.5em; text-transform:uppercase; color:rgba(255,255,255,0.5); }
.scroll-line { width:1px; height:50px; background:linear-gradient(to bottom, rgba(201,169,110,0.8), transparent); animation:scrollAnim 2s ease infinite; }
@keyframes scrollAnim { 0%{transform:scaleY(0);transform-origin:top} 50%{transform:scaleY(1);transform-origin:top} 51%{transform:scaleY(1);transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* ===== BOOKING BAR ===== */
.booking-bar { background:var(--charcoal); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:0 60px; }
.booking-bar-inner { max-width:1400px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr 1fr auto; }
.booking-field { padding:28px 40px; border-right:1px solid var(--border); display:flex; flex-direction:column; gap:6px; }
.booking-label { font-size:9px; letter-spacing:0.5em; text-transform:uppercase; color:var(--gold); }
.booking-input { background:transparent; border:none; color:var(--cream); font-family:var(--font-display); font-size:18px; padding:0; width:100%; }
.booking-input:focus { outline:none; }
.booking-input::placeholder { color:rgba(245,240,232,0.35); }
.booking-input option { background:var(--charcoal); color:var(--cream); }
.booking-submit-btn { padding:28px 48px; background:var(--gold); border:none; color:var(--black); font-size:10px; letter-spacing:0.4em; text-transform:uppercase; font-weight:500; font-family:var(--font-body); cursor:pointer; transition:all 0.3s; white-space:nowrap; }
.booking-submit-btn:hover { background:var(--gold2); }

/* ===== ABOUT ===== */
.about-section { padding:140px 60px; display:grid; grid-template-columns:1fr 1fr; gap:100px; max-width:1400px; margin:0 auto; align-items:center; }
.about-body { margin-top:32px; font-size:16px; line-height:1.9; color:rgba(245,240,232,0.7); max-width:480px; }
.about-body + .about-body { margin-top:16px; }
.about-stats { display:flex; gap:48px; margin-top:48px; padding-top:48px; border-top:1px solid var(--border); }
.about-stat-num { font-family:var(--font-display); font-size:52px; font-weight:400; color:var(--gold); line-height:1; }
.about-stat-label { font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); margin-top:4px; }
.about-visual { position:relative; height:560px; }
.about-img-main { width:80%; height:100%; object-fit:cover; position:absolute; right:0; filter:brightness(0.85); }
.about-img-accent { width:55%; height:260px; object-fit:cover; position:absolute; left:0; bottom:-40px; border:6px solid var(--dark); filter:brightness(0.85); }
.about-badge { position:absolute; bottom:20px; right:20px; width:100px; height:100px; background:var(--gold); border-radius:50%; display:flex; flex-direction:column; align-items:center; justify-content:center; z-index:2; }
.about-badge-year { font-family:var(--font-display); font-size:28px; color:var(--black); font-weight:700; line-height:1; }
.about-badge-label { font-size:8px; letter-spacing:0.2em; color:rgba(0,0,0,0.6); text-transform:uppercase; }

/* ===== ROOMS ===== */
.rooms-section { background:var(--black); padding:120px 60px; }
.section-header-row { max-width:1400px; margin:0 auto 70px; display:flex; justify-content:space-between; align-items:flex-end; }
.metro-rooms-grid { max-width:1400px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.metro-rooms-grid .room-card:first-child { grid-column:1/3; }
.room-card { position:relative; overflow:hidden; background:var(--charcoal); cursor:pointer; }
.room-img-wrap { overflow:hidden; aspect-ratio:4/3; }
.room-card:first-child .room-img-wrap { aspect-ratio:16/9; }
.room-img { width:100%; height:100%; object-fit:cover; transition:transform 0.8s cubic-bezier(0.25,0.1,0.25,1); display:block; }
.room-card:hover .room-img { transform:scale(1.06); }
.room-info { padding:28px 28px 32px; border-top:1px solid var(--border); display:flex; justify-content:space-between; align-items:flex-end; }
.room-name { font-family:var(--font-display); font-size:22px; font-weight:400; color:var(--cream); margin-bottom:8px; }
.room-price { font-size:13px; color:var(--gold); margin-bottom:8px; font-weight:400; }
.room-features { display:flex; gap:14px; flex-wrap:wrap; }
.room-feature { font-size:11px; letter-spacing:0.1em; color:var(--muted); display:flex; align-items:center; gap:5px; }
.room-feature::before { content:'—'; color:var(--gold); font-size:10px; }

/* ===== AMENITIES ===== */
.amenities-section { padding:140px 60px; max-width:1400px; margin:0 auto; }
.amenities-grid { display:grid; grid-template-columns:1fr 1fr; gap:3px; margin-top:70px; }
.amenity-card { position:relative; overflow:hidden; height:500px; }
.amenity-img { width:100%; height:100%; object-fit:cover; transition:all 0.8s ease; filter:brightness(0.6); }
.amenity-card:hover .amenity-img { transform:scale(1.05); filter:brightness(0.75); }
.amenity-content { position:absolute; bottom:0; left:0; right:0; padding:48px 40px; background:linear-gradient(to top, rgba(0,0,0,0.85), transparent); }
.amenity-tag { font-size:9px; letter-spacing:0.5em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.amenity-name { font-family:var(--font-display); font-size:32px; color:var(--white); margin-bottom:12px; }
.amenity-desc { font-size:14px; color:rgba(255,255,255,0.7); line-height:1.6; max-width:380px; }

/* ===== GALLERY ===== */
.gallery-section { background:var(--black); padding:120px 60px; }
.metro-gallery-grid { max-width:1400px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:280px; gap:3px; }
.metro-gallery-grid.cols-3 { grid-template-columns:repeat(3,1fr); }
.metro-gallery-grid.cols-2 { grid-template-columns:repeat(2,1fr); }
.gallery-item { overflow:hidden; position:relative; cursor:pointer; }
.gallery-item:nth-child(1) { grid-column:1/3; }
.gallery-item:nth-child(4) { grid-row:span 2; }
.gallery-img { width:100%; height:100%; object-fit:cover; transition:transform 0.8s ease; filter:brightness(0.75); }
.gallery-item:hover .gallery-img { transform:scale(1.06); filter:brightness(0.9); }
.gallery-overlay { position:absolute; inset:0; background:rgba(0,0,0,0); transition:background 0.4s; display:flex; align-items:center; justify-content:center; }
.gallery-item:hover .gallery-overlay { background:rgba(201,169,110,0.15); }
.gallery-plus { font-size:32px; color:var(--white); opacity:0; transition:opacity 0.4s; }
.gallery-item:hover .gallery-plus { opacity:1; }

/* ===== LIGHTBOX ===== */
#metro-lightbox { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.95); z-index:99000; align-items:center; justify-content:center; }
#metro-lightbox.open { display:flex; }
#metro-lightbox img { max-width:90vw; max-height:90vh; object-fit:contain; }
.lightbox-close { position:absolute; top:24px; right:40px; background:none; border:none; color:var(--cream); font-size:32px; cursor:pointer; }

/* ===== NATURE ===== */
.nature-section { padding:140px 60px; max-width:1400px; margin:0 auto; }
.nature-grid { margin-top:70px; display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.nature-card { position:relative; overflow:hidden; height:460px; cursor:pointer; }
.nature-img { width:100%; height:100%; object-fit:cover; transition:transform 0.8s ease; filter:brightness(0.55); }
.nature-card:hover .nature-img { transform:scale(1.05); filter:brightness(0.7); }
.nature-content { position:absolute; bottom:0; left:0; right:0; padding:36px 32px; background:linear-gradient(to top, rgba(0,0,0,0.9), transparent); }
.nature-distance { font-size:10px; letter-spacing:0.4em; text-transform:uppercase; color:var(--gold); margin-bottom:8px; }
.nature-name { font-family:var(--font-display); font-size:26px; color:var(--white); margin-bottom:10px; font-style:italic; }
.nature-desc { font-size:13px; color:rgba(255,255,255,0.65); line-height:1.6; }

/* ===== QUOTE ===== */
.quote-section { background:var(--charcoal); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:100px 60px; text-align:center; }
.quote-mark { font-family:var(--font-display); font-size:120px; color:var(--gold); opacity:0.2; line-height:0.5; margin-bottom:40px; display:block; }
.quote-text { font-family:var(--font-display); font-size:clamp(22px,3vw,44px); font-style:italic; color:var(--cream); max-width:900px; margin:0 auto 32px; line-height:1.4; }
.quote-source { font-size:11px; letter-spacing:0.4em; text-transform:uppercase; color:var(--gold); }

/* ===== BLOG ===== */
.blog-section { background:var(--black); padding:120px 60px; }
.blog-grid { max-width:1400px; margin:0 auto; display:grid; grid-template-columns:2fr 1fr 1fr; gap:2px; }
.blog-card { background:var(--charcoal); overflow:hidden; cursor:pointer; transition:transform 0.3s ease; }
.blog-card:hover { transform:translateY(-4px); }
.blog-card a { text-decoration:none; color:inherit; }
.blog-thumb { width:100%; aspect-ratio:16/9; object-fit:cover; filter:brightness(0.75); transition:all 0.5s ease; display:block; }
.blog-card:hover .blog-thumb { filter:brightness(0.9); transform:scale(1.02); }
.blog-info { padding:24px 24px 28px; }
.blog-cat { font-size:9px; letter-spacing:0.4em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.blog-title { font-family:var(--font-display); font-size:20px; color:var(--cream); line-height:1.3; margin-bottom:10px; }
.blog-excerpt { font-size:13px; color:var(--muted); line-height:1.6; }
.blog-meta { margin-top:16px; font-size:11px; color:var(--muted); }

/* ===== TESTIMONIALS ===== */
.testimonials-section { padding:100px 60px; background:var(--charcoal); }
.testimonials-grid { max-width:1400px; margin:24px auto 0; display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.testimonial-card { background:var(--dark); padding:40px 36px; }
.testimonial-stars { font-size:18px; margin-bottom:16px; }
.testimonial-text { font-family:var(--font-display); font-size:18px; font-style:italic; color:var(--cream); line-height:1.5; margin-bottom:20px; }
.testimonial-author { font-size:12px; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold); }

/* ===== CONTACT ===== */
.contact-section { padding:140px 60px; max-width:1400px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:100px; align-items:start; }
.contact-details { margin-top:48px; display:flex; flex-direction:column; gap:32px; }
.contact-item-label { font-size:9px; letter-spacing:0.5em; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.contact-item-value { font-size:16px; color:var(--cream); line-height:1.5; }
.contact-item-value a { color:var(--cream); transition:color 0.3s; }
.contact-item-value a:hover { color:var(--gold); }
.contact-form-wrap { display:flex; flex-direction:column; gap:2px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:2px; }
.form-field { display:flex; flex-direction:column; }
.form-label { font-size:9px; letter-spacing:0.5em; text-transform:uppercase; color:var(--gold); padding:16px 20px 0; background:var(--charcoal); }
.form-control { background:var(--charcoal); border:none; border-bottom:1px solid var(--border); color:var(--cream); font-family:var(--font-body); font-size:14px; font-weight:300; padding:10px 20px 16px; transition:border-color 0.3s; }
.form-control:focus { outline:none; border-bottom-color:var(--gold); }
.form-control::placeholder { color:rgba(245,240,232,0.25); }
textarea.form-control { resize:vertical; min-height:120px; }
.form-submit-btn { margin-top:2px; padding:20px 40px; background:var(--gold); border:none; color:var(--black); font-family:var(--font-body); font-size:10px; letter-spacing:0.4em; text-transform:uppercase; font-weight:500; cursor:pointer; transition:all 0.3s; align-self:flex-start; }
.form-submit-btn:hover { background:var(--gold2); }
.form-success { display:none; padding:20px; background:rgba(201,169,110,0.15); border:1px solid var(--gold); color:var(--gold); font-size:14px; }

/* ===== BOOKING PAGE (HCM Integration) ===== */
.booking-page-wrap { max-width:1100px; margin:0 auto; padding:120px 60px 80px; }
.booking-page-title { font-family:var(--font-display); font-size:clamp(36px,4vw,64px); color:var(--cream); margin-bottom:48px; }
.booking-page-title em { color:var(--gold); font-style:italic; }
.hcm-booking-widget { max-width:100%; box-shadow:none; border-color:var(--border); background:var(--charcoal); }
.hcm-bw-header { background:linear-gradient(135deg,var(--charcoal),var(--dark)); border-bottom:1px solid var(--border); }
.hcm-bw-body { background:var(--charcoal); }
.hcm-bw-field input,.hcm-bw-field select,.hcm-bw-field textarea { background:var(--dark); border-color:var(--border); color:var(--cream); }
.hcm-bw-btn { background:var(--gold); color:var(--black); border-radius:0; }

/* ===== SINGLE BLOG POST ===== */
.post-hero { height:55vh; position:relative; overflow:hidden; }
.post-hero-img { width:100%; height:100%; object-fit:cover; filter:brightness(0.5); }
.post-hero-overlay { position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; padding:60px; background:linear-gradient(to top, rgba(0,0,0,0.8), transparent); }
.post-cat { font-size:10px; letter-spacing:0.4em; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.post-title { font-family:var(--font-display); font-size:clamp(28px,4vw,56px); color:var(--white); max-width:800px; line-height:1.15; }
.post-meta { margin-top:16px; font-size:12px; color:rgba(255,255,255,0.5); display:flex; gap:24px; }
.post-content-wrap { max-width:760px; margin:0 auto; padding:80px 40px; }
.post-content-wrap p { font-size:17px; line-height:1.9; color:rgba(245,240,232,0.8); margin-bottom:24px; }
.post-content-wrap h2 { font-family:var(--font-display); font-size:32px; color:var(--cream); margin:48px 0 20px; }
.post-content-wrap h3 { font-family:var(--font-display); font-size:24px; color:var(--cream); margin:36px 0 16px; }
.post-content-wrap img { width:100%; height:400px; object-fit:cover; margin:32px 0; }
.post-content-wrap blockquote { border-left:3px solid var(--gold); padding:16px 24px; margin:32px 0; font-family:var(--font-display); font-style:italic; font-size:22px; color:var(--gold); }

/* ===== FOOTER ===== */
#metro-footer { background:var(--black); border-top:1px solid var(--border); padding:70px 60px 40px; }
.footer-inner { max-width:1400px; margin:0 auto; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:60px; padding-bottom:60px; border-bottom:1px solid var(--border); }
.footer-logo { font-family:var(--font-display); font-size:28px; color:var(--cream); margin-bottom:16px; }
.footer-tagline { font-size:13px; color:var(--muted); line-height:1.7; max-width:260px; margin-bottom:28px; }
.footer-social { display:flex; gap:12px; }
.footer-social a { width:38px; height:38px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--muted); font-size:13px; transition:all 0.3s; }
.footer-social a:hover { border-color:var(--gold); color:var(--gold); }
.footer-col-title { font-size:10px; letter-spacing:0.4em; text-transform:uppercase; color:var(--gold); margin-bottom:24px; }
.footer-col ul { display:flex; flex-direction:column; gap:12px; }
.footer-col a { font-size:14px; color:var(--muted); transition:color 0.3s; }
.footer-col a:hover { color:var(--cream); }
.footer-bottom { padding-top:32px; display:flex; justify-content:space-between; align-items:center; }
.footer-copy { font-size:12px; color:rgba(136,136,128,0.5); }

/* ===== REVEAL ANIMATIONS ===== */
.reveal { opacity:0; transform:translateY(40px); transition:opacity 0.8s ease, transform 0.8s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:0.1s; }
.reveal-delay-2 { transition-delay:0.2s; }
.reveal-delay-3 { transition-delay:0.3s; }

/* ===== PAGE GENERAL ===== */
.page-header-simple { padding:160px 60px 60px; background:var(--black); border-bottom:1px solid var(--border); }
.page-header-simple h1 { font-family:var(--font-display); font-size:clamp(36px,5vw,80px); color:var(--cream); }
.page-header-simple h1 em { color:var(--gold); font-style:italic; }
.page-content { max-width:1400px; margin:0 auto; padding:60px; }

/* ===== ADMIN BAR FIX ===== */
.admin-bar #metro-nav { top:32px; }
@media screen and (max-width:782px) { .admin-bar #metro-nav { top:46px; } }

/* ===== RESPONSIVE ===== */
@media (max-width:1100px) {
  #metro-nav, #metro-nav.scrolled { padding:20px 32px; }
  .nav-menu { display:none; }
  .nav-toggle { display:flex; }
  .hero-content, .booking-bar { padding-left:32px; padding-right:32px; }
  .about-section, .amenities-section, .nature-section, .contact-section, .rooms-section, .gallery-section, .blog-section, .testimonials-section, .quote-section, #metro-footer { padding-left:32px; padding-right:32px; }
  .metro-rooms-grid { grid-template-columns:1fr; }
  .metro-rooms-grid .room-card:first-child { grid-column:1; }
  .about-section { grid-template-columns:1fr; gap:60px; }
  .about-visual { height:400px; }
  .amenities-grid { grid-template-columns:1fr; }
  .nature-grid { grid-template-columns:1fr; }
  .blog-grid { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .contact-section { grid-template-columns:1fr; gap:60px; }
  .footer-top { grid-template-columns:1fr 1fr; gap:40px; }
  .booking-bar-inner { grid-template-columns:1fr 1fr; }
  .metro-gallery-grid { grid-template-columns:1fr 1fr; grid-auto-rows:220px; }
  .gallery-item:nth-child(1), .gallery-item:nth-child(4) { grid-column:auto; grid-row:auto; }
}
@media (max-width:600px) {
  /* Hero — foto e plotë sipër, content poshtë */
  .metro-hero {
    height: auto;
    min-height: unset;
    flex-direction: column;
    align-items: stretch;
    padding-bottom: 0;
  }
  .hero-slides {
    position: relative;
    inset: unset;
    width: 100%;
    height: 55vw;
    min-height: 240px;
    max-height: 340px;
  }
  .hero-slide {
    position: absolute;
    inset: 0;
  }
  .hero-slide::after {
    background: linear-gradient(to bottom, rgba(10,10,10,0.15) 0%, rgba(10,10,10,0.55) 100%);
  }
  .hero-content {
    position: relative;
    z-index: 10;
    padding: 28px 20px 24px;
    background: var(--black);
  }
  .hero-title { font-size: 36px; line-height: 1; margin-bottom: 20px; }
  .hero-meta { flex-direction: column; align-items: flex-start; gap: 16px; }
  .hero-eyebrow { font-size: 9px; }
  .hero-cta { gap: 10px; }
  .hero-cta .btn { padding: 14px 24px; font-size: 9px; }
  .hero-indicators { right: 14px; bottom: unset; top: 12px; }
  .hero-scroll-hint { display: none; }

  /* Booking bar — full width stacked */
  .booking-bar { padding: 0; }
  .booking-bar-inner { grid-template-columns: 1fr 1fr; }
  .booking-field {
    padding: 16px 18px;
    border-right: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
  }
  .booking-field:nth-child(2) { border-right: none; }
  .booking-field:nth-child(3) { border-right: 1px solid var(--border); border-bottom: none; }
  .booking-input { font-size: 15px; }
  .booking-submit-btn {
    grid-column: 1 / -1;
    padding: 18px;
    font-size: 10px;
    width: 100%;
  }

  /* Other mobile fixes */
  .hero-title-desktop { display: none; }
  .about-stats { flex-direction:column; gap:20px; }
  .footer-top { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; gap:12px; text-align:center; }
  .form-row { grid-template-columns:1fr; }
  .section-header-row { flex-direction:column; align-items:flex-start; gap:20px; }
  .page-header-simple, .page-content, .booking-page-wrap { padding-left:20px; padding-right:20px; }
  .mobile-close-btn { right:20px; }
}

/* ── Footer Credit ─────────────────────────────────────────────────────────── */
.footer-credit-link {
  color: var(--gold, #c9a96e);
  text-decoration: none;
  font-weight: 500;
  letter-spacing: .04em;
  transition: opacity .2s;
}
.footer-credit-link:hover { opacity: .7; }

/* ── Language Switcher — Professional ─────────────────────────────────────── */
.metro-lang-switcher {
  position: relative;
  margin-left: 12px;
  z-index: 1000;
}

/* Current language button */
.lang-current {
  background: transparent;
  border: 1px solid rgba(201,169,110,.35);
  color: var(--cream, #f5f0e8);
  padding: 7px 12px 7px 10px;
  cursor: pointer;
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 7px;
  border-radius: 2px;
  transition: background .2s, border-color .2s;
  font-family: var(--font-body, inherit);
  white-space: nowrap;
  line-height: 1;
}
.lang-current:hover,
.metro-lang-switcher.open .lang-current {
  background: rgba(201,169,110,.1);
  border-color: var(--gold, #c9a96e);
}
.lang-flag { font-size: 16px; line-height: 1; }
.lang-label { font-size: 11px; letter-spacing: .12em; font-weight: 500; }
.lang-arrow {
  font-size: 8px;
  opacity: .5;
  transition: transform .25s ease, opacity .2s;
  margin-left: 2px;
}
.metro-lang-switcher.open .lang-arrow {
  transform: rotate(180deg);
  opacity: 1;
}

/* Gold accent line under current */
.lang-current::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--gold, #c9a96e);
  transform: scaleX(0);
  transition: transform .2s;
}
.metro-lang-switcher.open .lang-current::after { transform: scaleX(1); }

/* Dropdown */
.lang-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  background: #111;
  border: 1px solid rgba(201,169,110,.25);
  border-top: 2px solid var(--gold, #c9a96e);
  min-width: 130px;
  z-index: 9999;
  box-shadow: 0 16px 40px rgba(0,0,0,.6);
  overflow: hidden;
  animation: langDrop .18s ease;
}
@keyframes langDrop {
  from { opacity:0; transform:translateY(-6px); }
  to   { opacity:1; transform:translateY(0); }
}
.metro-lang-switcher.open .lang-dropdown { display: block; }

.lang-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  color: rgba(245,240,232,.7);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background .15s, color .15s, padding-left .15s;
  border-bottom: 1px solid rgba(255,255,255,.04);
  font-family: var(--font-body, inherit);
}
.lang-option:last-child { border-bottom: none; }
.lang-option .lang-flag { font-size: 15px; }
.lang-option:hover {
  background: rgba(201,169,110,.1);
  color: var(--gold, #c9a96e);
  padding-left: 20px;
}

/* ── Mobile / Tablet ───────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .metro-lang-switcher { margin-left: 4px; }
  .lang-label { display: none; }
  .lang-current { padding: 7px 9px; gap: 4px; border-radius: 2px; }
  .lang-flag { font-size: 18px; }
  .lang-dropdown { right: 0; min-width: 110px; }
  .lang-option { padding: 12px 14px; font-size: 11px; }
  .lang-option:hover { padding-left: 18px; }


  /* Tablet/mobile hero — foto reale sipër, tekst poshtë */
  .metro-hero {
    height: auto;
    min-height: unset;
    flex-direction: column;
    padding-bottom: 0;
  }
  .hero-slides {
    position: relative;
    inset: unset;
    width: 100%;
    height: 56vw;
    min-height: 280px;
    max-height: 420px;
  }
  .hero-slide { position: absolute; inset: 0; }
  .hero-content {
    position: relative;
    z-index: 10;
    padding: 32px 32px 28px;
    background: var(--black);
  }
  .hero-indicators { top: 14px; bottom: unset; right: 18px; }
  .hero-scroll-hint { display: none; }
  .booking-bar { padding: 0; }
}

/* ── Language Switcher ──────────────────────────────────────────────────────── */
.metro-lang-sw { position:relative; margin-right:10px; }
.lang-btn {
  background: transparent;
  border: 1px solid rgba(201,169,110,.3);
  color: var(--cream);
  padding: 7px 11px;
  cursor: pointer;
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 6px;
  border-radius: 2px;
  transition: border-color .2s, background .2s;
  font-family: var(--font-body);
  line-height: 1;
}
.lang-btn:hover,
.metro-lang-sw.open .lang-btn {
  border-color: var(--gold);
  background: rgba(201,169,110,.08);
}
.lang-flag { font-size: 15px; line-height: 1; }
.lang-code { font-size: 11px; font-weight: 500; }
.lang-arr  { font-size: 8px; opacity: .6; transition: transform .2s; }
.metro-lang-sw.open .lang-arr { transform: rotate(180deg); }
.lang-drop {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: #0f0f0e;
  border: 1px solid rgba(201,169,110,.25);
  border-top: 2px solid var(--gold);
  min-width: 100px;
  z-index: 9999;
  box-shadow: 0 12px 32px rgba(0,0,0,.6);
  animation: ldrop .15s ease;
}
@keyframes ldrop { from { opacity:0; transform:translateY(-4px); } to { opacity:1; transform:none; } }
.metro-lang-sw.open .lang-drop { display: block; }
.lang-opt {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(242,237,228,.65);
  text-decoration: none;
  transition: background .15s, color .15s;
  border-bottom: 1px solid rgba(255,255,255,.04);
  font-family: var(--font-body);
}
.lang-opt:last-child { border-bottom: none; }
.lang-opt:hover { background: rgba(201,169,110,.1); color: var(--gold); }

@media (max-width: 768px) {
  .lang-code { display: none; }
  .lang-btn  { padding: 7px 8px; gap: 3px; }
  .lang-flag { font-size: 17px; }
}
