﻿.hotels-hero-bg { background: url('https://images.unsplash.com/photo-1566073771259-6a8506099945?w=1800&q=85') center/cover no-repeat, linear-gradient(160deg,#0a1a2e 0%,#0e3a5a 50%,#1a4a6e 100%); }

    .filter-bar { background:var(--navy); padding:1.5rem 3rem; display:flex; gap:1rem; flex-wrap:wrap; align-items:center; }
    .filter-btn { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); color:rgba(255,255,255,.75); padding:.45rem 1.1rem; border-radius:20px; font-size:.8rem; cursor:pointer; transition:all .2s; font-family:'DM Sans',sans-serif; }
    .filter-btn:hover, .filter-btn.active { background:var(--turq); border-color:var(--turq); color:#fff; }
    .filter-label { color:rgba(255,255,255,.82); font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; }

    .hotels-section { padding:5rem 3rem; }
    .hotels-section.alt { background:var(--sand); }
    .section-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:3rem; flex-wrap:wrap; gap:1rem; }
    .hotels-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
    .hotel-card { background:#fff; border-radius:2px; overflow:hidden; display:flex; flex-direction:column; transition:transform .3s,box-shadow .3s; }
    .hotel-card:hover { transform:translateY(-4px); box-shadow:0 14px 40px rgba(26,43,69,.12); }
    .hotel-card img { width:100%; height:220px; object-fit:cover; }
    .hotel-body { padding:1.4rem; flex:1; display:flex; flex-direction:column; }
    .hotel-stars { color:var(--terra); font-size:.88rem; margin-bottom:.4rem; }
    .hotel-name { font-family:'Cormorant Garamond',serif; font-size:1.35rem; font-weight:400; margin-bottom:.3rem; color:var(--navy); }
    .hotel-location { font-size:.78rem; color:var(--muted); margin-bottom:.6rem; }
    .hotel-tags { display:flex; gap:.4rem; flex-wrap:wrap; margin-bottom:.8rem; }
    .hotel-tag { font-size:.67rem; padding:.2rem .55rem; border-radius:20px; background:var(--sand); color:var(--navy); }
    .hotel-desc { font-size:.82rem; color:var(--muted); line-height:1.65; flex:1; margin-bottom:.8rem; }
    .hotel-footer { display:flex; justify-content:space-between; align-items:center; margin-top:auto; padding-top:.8rem; border-top:1px solid var(--sand); }
    .hotel-price { font-size:.82rem; color:var(--muted); }
    .hotel-price strong { font-size:1.15rem; color:var(--ink); font-weight:600; }
    .hotel-btn { background:var(--turq); color:#fff; padding:.5rem 1.1rem; border-radius:2px; text-decoration:none; font-size:.8rem; transition:background .2s; white-space:nowrap; }
    .hotel-btn:hover { background:var(--turq-light); }

    .types-section { background:var(--navy); color:#fff; padding:5rem 3rem; }
    .types-section h2 { color:#fff; margin-bottom:1rem; }
    .types-section .lead { color: rgba(255,255,255,.9); }
    .types-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:3rem; }
    .type-card { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); padding:2rem 1.5rem; border-radius:2px; }
    .type-icon { font-size:2rem; margin-bottom:1rem; }
    .type-card h3 { color:#fff; font-size:1.15rem; margin-bottom:.5rem; }
    .type-card p { font-size:.82rem; color:rgba(255,255,255,.88); line-height:1.65; }
    .type-card .price-range { margin-top:1rem; color:var(--turq-light); font-size:.82rem; font-weight:500; }

    .booking-tips { background:var(--cream); padding:5rem 3rem; }
    .booking-tips h2 { margin-bottom:3rem; }
    .tips-cols { display:grid; grid-template-columns:1fr 1fr; gap:3rem; }
    .tip-item { display:flex; gap:1.2rem; align-items:flex-start; margin-bottom:1.5rem; }
    .tip-num { font-family:'Bebas Neue',sans-serif; font-size:2.5rem; color:var(--sand-dark); line-height:1; flex-shrink:0; width:2rem; }
    .tip-text h3 { font-family:'Cormorant Garamond',serif; font-size:1.15rem; font-weight:400; color:var(--navy); margin-bottom:.3rem; }
    .tip-text p { font-size:.83rem; color:var(--muted); line-height:1.65; }

    @media(max-width:900px){ .hotels-grid,.types-grid { grid-template-columns:1fr; } .tips-cols { grid-template-columns:1fr; } .filter-bar { padding:1rem 1.5rem; } .hotels-section { padding:3.5rem 1.5rem; } }
  
    /* ── MOBILE MENU ── */
    .hamburger {
      display: none; flex-direction: column; gap: 5px;
      background: none; border: none; cursor: pointer; padding: 4px; z-index: 200;
    }
    .hamburger span {
      display: block; width: 24px; height: 2px;
      background: #fff; border-radius: 2px;
      transition: all .3s ease;
    }
    .hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .hamburger.open span:nth-child(2) { opacity: 0; }
    .hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    .mobile-menu {
      display: none; position: fixed; inset: 0; z-index: 150;
      background: rgba(10,20,40,.97);
      flex-direction: column; align-items: center; justify-content: center;
      gap: 2rem;
    }
    .mobile-menu.open { display: flex; }
    .mobile-menu a {
      color: #fff; text-decoration: none;
      font-family: 'Cormorant Garamond', serif;
      font-size: 2.2rem; font-weight: 300; letter-spacing: .05em;
      transition: color .2s;
    }
    .mobile-menu a:hover { color: var(--turq-light); }
    .mobile-menu .mobile-cta {
      margin-top: 1rem;
      background: var(--terra); color: #fff;
      padding: .8rem 2.5rem; border-radius: 2px;
      font-family: 'DM Sans', sans-serif;
      font-size: .9rem; letter-spacing: .06em; text-transform: uppercase;
    }

    @media (max-width: 768px) {
      .hamburger { display: flex; }
      .nav-links, .nav-cta { display: none !important; }
    }

