/* === central base/nav === */

/* Central site styles: typography, layout, and responsive navigation */
:root{
  --text:#111;
  --bg:#fff;
  --brand:#0f62fe;
  --muted:#666;
  --border:#e5e7eb;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.container{max-width:1100px;margin-inline:auto;padding:0 1rem}

/* Header / Nav */
.site-header{border-bottom:1px solid var(--border);background:#fff;position:sticky;top:0;z-index:50}
.navbar{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.75rem 1rem}
.brand{font-weight:700;font-size:1.1rem}
.nav-actions{display:flex;align-items:center;gap:.5rem}

.nav-links{display:flex;align-items:center;gap:.25rem}
.menu{display:flex;list-style:none;margin:0;padding:0;gap:.25rem}
.menu > li{position:relative}
.menu a{display:block;padding:.5rem .75rem;border-radius:.5rem}
.menu a:focus{outline:2px solid var(--brand);outline-offset:2px}

/* Dropdown */
.dropdown-toggle[aria-expanded="true"] + .dropdown,
.menu li:focus-within > .dropdown{display:block}
.dropdown{
  display:none;
  position:absolute;left:0;top:100%;
  min-width:220px;
  background:#fff;border:1px solid var(--border);border-radius:.75rem;
  padding:.5rem;margin-top:.25rem;
  box-shadow:0 10px 20px rgba(0,0,0,.08);
}
.dropdown a{padding:.5rem .75rem;white-space:nowrap;display:block;border-radius:.5rem}
.dropdown a:hover{background:#f6f7f9;text-decoration:none}

/* Mobile nav */
.mobile-toggle{
  display:none;
  background:transparent;border:1px solid var(--border);
  padding:.5rem .75rem;border-radius:.75rem
}
.mobile-toggle:focus{outline:2px solid var(--brand);outline-offset:2px}

@media (max-width: 900px){
  .nav-links{display:none}
  .mobile-toggle{display:inline-flex;align-items:center;gap:.5rem}
  .mobile-drawer[hidden]{display:none}
  .mobile-drawer{
    position:fixed;inset:0 0 auto 0;top:0;
    background:#fff;border-bottom:1px solid var(--border);
    padding:1rem;
  }
  .mobile-menu{list-style:none;margin:0;padding:0}
  .mobile-menu li{margin:.25rem 0}
  .mobile-menu a{display:block;padding:.75rem 1rem;border-radius:.5rem}
  .mobile-menu .section{margin-top:.5rem;padding-top:.5rem;border-top:1px dashed var(--border);color:var(--muted);font-size:.9rem}
}

/* Utils */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--border);border-radius:.75rem;background:#fff}
.btn:hover{background:#f6f7f9;text-decoration:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}


/* === extracted inline styles from pages === */
/* from best-time.html */
:root {
      --bg: #0e0f11;       /* site background */
      --fg: #eae9e6;       /* main text */
      --muted: #bdb9b3;      /* secondary text */
      --brand: #ffb703;      /* accent */
      --card: #17181b;     /* card background */
      --border: #2a2c31;     /* subtle borders */
    }

    * { box-sizing: border-box; }
    html, body { margin:0; padding:0; background: var(--bg); color: var(--fg); font-family: Poppins, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji"; }
    a { color: inherit; }
    img { max-width: 100%; height: auto; }
    .container { width: min(1120px, 92vw); margin: 0 auto; }

    header {
      position: sticky; top: 0; z-index: 50; backdrop-filter: saturate(180%) blur(10px);
      background: linear-gradient(to bottom, rgba(14,15,17,.9), rgba(14,15,17,.6));
      border-bottom: 1px solid var(--border);
    }
    .nav { display:flex; align-items:center; justify-content:space-between; padding: .8rem 0; }
    .logo { font-weight:800; letter-spacing:.5px; }
    .logo span { color: var(--brand); }
    .nav a { text-decoration:none; margin-left: 1rem; color: var(--muted); font-weight:600; }
    .nav a:hover { color: var(--fg); }

    /* ===== HERO (updated to match mockup) ===== */
    .hero {
      position: relative;
      min-height: 70vh;
      display: flex;
      align-items: center;
      padding: 4rem 0;
    }
    .hero::after { display: none; } /* remove old background overlay */
    .hero-grid {
      display: grid;
      grid-template-columns: 1.6fr 1fr; /* text : image */
      gap: 2rem;
      align-items: center;
    }
    .hero-media {
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: 18px;
      overflow: hidden;
      box-shadow: 0 12px 30px rgba(0,0,0,.35);
    }
    .hero-media img { display:block; width:100%; height:auto; }

    .kicker { letter-spacing: .16em; text-transform: uppercase; color: var(--muted); font-size:.9rem; }
    .display { font-family: "Playfair Display", serif; font-weight:800; line-height:1.02; font-size: clamp(2.2rem, 4vw + 1rem, 4.4rem); margin: .25rem 0 1rem; }
    .lead { color: var(--muted); max-width: 60ch; font-size: 1.1rem; }
    .cta { margin-top: 1.5rem; display:flex; gap:.75rem; flex-wrap:wrap; }

    @media (max-width: 980px) {
      .hero-grid { grid-template-columns: 1fr; }
      .hero-media { max-width: 560px; justify-self: center; }
    }

    /* Buttons (single source of truth) */
    .btn {
      display:inline-flex; align-items:center; gap:.6rem;
      border:1px solid var(--border); background: var(--card);
      padding:.85rem 1.1rem; border-radius: 999px; text-decoration:none;
      font-weight:700; cursor:pointer; color: var(--fg);
    }
    .btn:disabled { opacity:.6; cursor:not-allowed; }
    .btn.primary { background: var(--brand); color: #111; border-color: #eaa502; }

    section { padding: 4rem 0; border-top: 1px solid var(--border); }
    .section-title { font-weight:800; font-size: clamp(1.6rem, 1.2rem + 1vw, 2rem); margin: 0 0 .5rem; }
    .section-sub { color: var(--muted); margin: 0 0 1.5rem; }

    .grid { display: grid; gap: 1.25rem; }
    .grid.cols-2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
    @media (max-width: 860px) { .grid.cols-2 { grid-template-columns: 1fr; } }

    .card { background: var(--card); border:1px solid var(--border); border-radius: 18px; overflow:hidden; }
    .card .body { padding: 1.25rem; }
    .pill { display:inline-block; font-size:.8rem; padding:.35rem .6rem; border-radius:999px; background:#1e2025; border:1px solid var(--border); color: var(--muted); }
    .facts { display:flex; gap:1rem; flex-wrap:wrap; margin:.75rem 0 0; }
    .fact { padding:.35rem .6rem; border-radius: 999px; background:#1c1e22; border:1px solid var(--border); font-weight:600; font-size:.9rem; }

    .itinerary .day { display:grid; grid-template-columns: 3fr 2fr; gap:1rem; }
    @media (max-width: 900px) { .itinerary .day { grid-template-columns: 1fr; } }
    .day h3 { margin:.2rem 0 .25rem; font-size: 1.25rem; }
    .day p { color: var(--muted); }

    .footer { color: var(--muted); padding: 2rem 0 4rem; text-align:center; }
    .footer a { color: var(--fg); text-decoration: underline; }
    .small { font-size:.95rem; color: var(--muted); }
    .emoji { filter: grayscale(100%); opacity:.8; }

    /* Simple inputs look-and-feel */
    input[type="text"], input[type="email"], textarea {
      width:100%; padding:.6rem; margin:.4rem 0;
      border-radius:10px; border:1px solid var(--border);
      background:var(--card); color:var(--fg);
    }
    label.small { display:block; margin-top:.4rem; }
    form .btn.primary { margin-top:.6rem; }
    
    /* BLOG-SPECIFIC STYLES - designed to fit your existing site's look */
    .blog-post { 
      max-width: 800px;
      margin: 0 auto;
      line-height: 1.7;
    }
    .blog-post h1 { 
      font-family: "Playfair Display", serif;
      font-weight: 800;
      font-size: clamp(2.2rem, 4vw + 1rem, 4.4rem);
      margin-bottom: 0.5rem; 
    }
    .blog-post h2 { 
      font-weight: 800; 
      font-size: clamp(1.6rem, 1.2rem + 1vw, 2rem);
      margin-top: 3rem;
    }
    .blog-post h3 { 
      font-weight: 800; 
      font-size: 1.4rem;
      margin-top: 2rem;
    }
    .blog-post p {
      color: var(--muted);
      margin-bottom: 1rem;
    }
    .blog-post ul {
      list-style-type: disc;
      padding-left: 20px;
      color: var(--muted);
      margin-bottom: 1rem;
    }
    .blog-post li {
      margin-bottom: 0.5rem;
    }
    .blog-post strong {
      color: var(--fg);
    }

/* from gallery.html */
:root {
      --bg: #0e0f11;         /* site background (same as index) */
      --fg: #eae9e6;         /* main text */
      --muted: #bdb9b3;      /* secondary text */
      --brand: #ffb703;      /* accent */
      --card: #17181b;       /* card background */
      --border: #2a2c31;     /* subtle borders */
    }

    * { box-sizing: border-box; }
    html, body { margin:0; padding:0; background: var(--bg); color: var(--fg); font-family: Poppins, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji"; }
    a { color: inherit; text-decoration: none; }
    img { max-width: 100%; height: auto; display: block; }
    .container { width: min(1120px, 92vw); margin: 0 auto; }

    /* Header / nav cloned from index with small tweak to show active link */
    header { position: sticky; top: 0; z-index: 50; backdrop-filter: saturate(180%) blur(10px); background: linear-gradient(to bottom, rgba(14,15,17,.9), rgba(14,15,17,.6)); border-bottom: 1px solid var(--border); }
    .nav { display:flex; align-items:center; justify-content:space-between; padding: .8rem 0; }
    .logo { font-weight:800; letter-spacing:.5px; }
    .logo span { color: var(--brand); }
    .nav a { margin-left: 1rem; color: var(--muted); font-weight:600; }
    .nav a:hover { color: var(--fg); }
    .nav a.active { color: var(--fg); }

    .page-hero { padding: 3.5rem 0 2rem; border-bottom: 1px solid var(--border); background: radial-gradient(1200px 300px at 50% -50px, rgba(255,183,3,.12), transparent 60%); }
    .kicker { letter-spacing: .16em; text-transform: uppercase; color: var(--muted); font-size:.9rem; }
    .display { font-family: "Playfair Display", serif; font-weight:800; line-height:1.02; font-size: clamp(2rem, 3.2vw + 1rem, 3.2rem); margin: .25rem 0 .5rem; }
    .lead { color: var(--muted); max-width: 72ch; }

    /* Gallery grid */
    .gallery { padding: 2rem 0 3rem; }
    .grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: .9rem; }
    .tile { position: relative; overflow: hidden; border-radius: 16px; border:1px solid var(--border); background: var(--card); cursor: zoom-in; }
    .tile img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/3; }

    /* Simple span utilities for a varied layout */
    .span-3 { grid-column: span 3; }
    .span-4 { grid-column: span 4; }
    .span-6 { grid-column: span 6; }
    @media (max-width: 980px) {
      .grid { grid-template-columns: repeat(6, 1fr); }
      .span-6 { grid-column: span 6; }
      .span-4 { grid-column: span 6; }
      .span-3 { grid-column: span 3; }
    }
    @media (max-width: 640px) {
      .grid { grid-template-columns: repeat(2, 1fr); }
      .span-6, .span-4, .span-3 { grid-column: span 2; }
    }

    /* Lightbox */
    .lightbox { position: fixed; inset: 0; background: rgba(0,0,0,.9); display: none; align-items: center; justify-content: center; z-index: 100; }
    .lightbox.open { display: flex; }
    .lightbox img { max-width: 92vw; max-height: 86vh; border-radius: 14px; box-shadow: 0 20px 60px rgba(0,0,0,.6); }
    .lightbox .close, .lightbox .prev, .lightbox .next { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(23,24,27,.8); border: 1px solid var(--border); color: var(--fg); padding: .7rem 1rem; border-radius: 999px; font-weight: 800; cursor: pointer; user-select: none; }
    .lightbox .close { top: 28px; right: 28px; transform: none; }
    .lightbox .prev { left: 24px; }
    .lightbox .next { right: 24px; }

    footer.footer { color: var(--muted); padding: 2rem 0 4rem; text-align:center; border-top: 1px solid var(--border); }
    .small { font-size:.95rem; color: var(--muted); }

/* from index.html */
:root {
      --bg: #0e0f11;         /* site background */
      --fg: #eae9e6;         /* main text */
      --muted: #bdb9b3;      /* secondary text */
      --brand: #ffb703;      /* accent */
      --card: #17181b;       /* card background */
      --border: #2a2c31;     /* subtle borders */
    }

    * { box-sizing: border-box; }
    html, body { margin:0; padding:0; background: var(--bg); color: var(--fg); font-family: Poppins, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji"; }
    a { color: inherit; }
    img { max-width: 100%; height: auto; }
    .container { width: min(1120px, 92vw); margin: 0 auto; }

    header {
      position: sticky; top: 0; z-index: 50; backdrop-filter: saturate(180%) blur(10px);
      background: linear-gradient(to bottom, rgba(14,15,17,.9), rgba(14,15,17,.6));
      border-bottom: 1px solid var(--border);
    }
    .nav { display:flex; align-items:center; justify-content:space-between; padding: .8rem 0; flex-wrap: nowrap;}
    /* Update the .nav-links to use flexbox */
	.nav-links {
  	display: flex; /* Make the nav-links a flex container */
  	align-items: center; /* Vertically align the nav items */
	}

	/* Update the nav a rule */
	.nav a {
  	text-decoration: none; 
  	margin-left: 1rem; 
  	color: var(--muted); 
  	font-weight: 600; 
  	white-space: nowrap; /* Prevents text inside links from wrapping */
	}

	/* Ensure the dropdowns are also treated as flex items */
	.dropdown {
  	margin-left: 1rem;
	}
    	.logo { font-weight:800; letter-spacing:.5px; }
    	.logo span { color: var(--brand); }
    	.nav a { text-decoration:none; margin-left: 1rem; color: var(--muted); font-weight:600; }
    	.nav a:hover { color: var(--fg); }

    /* ===== HERO (updated to match mockup) ===== */
    .hero {
      position: relative;
      min-height: 70vh;
      display: flex;
      align-items: center;
      padding: 4rem 0;
    }
    .hero::after { display: none; } /* remove old background overlay */
    .hero-grid {
      display: grid;
      grid-template-columns: 1.6fr 1fr; /* text : image */
      gap: 2rem;
      align-items: center;
    }
    .hero-media {
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: 18px;
      overflow: hidden;
      box-shadow: 0 12px 30px rgba(0,0,0,.35);
    }
    .hero-media img { display:block; width:100%; height:auto; }

    .kicker { letter-spacing: .16em; text-transform: uppercase; color: var(--muted); font-size:.9rem; }
    .display { font-family: "Playfair Display", serif; font-weight:800; line-height:1.02; font-size: clamp(2.2rem, 4vw + 1rem, 4.4rem); margin: .25rem 0 1rem; }
    .lead { color: var(--muted); max-width: 60ch; font-size: 1.1rem; }
    .cta { margin-top: 1.5rem; display:flex; gap:.75rem; flex-wrap:wrap; }

    @media (max-width: 980px) {
      .hero-grid { grid-template-columns: 1fr; }
      .hero-media { max-width: 560px; justify-self: center; }
    }

    /* Buttons (single source of truth) */
    .btn {
      display:inline-flex; align-items:center; gap:.6rem;
      border:1px solid var(--border); background: var(--card);
      padding:.85rem 1.1rem; border-radius: 999px; text-decoration:none;
      font-weight:700; cursor:pointer; color: var(--fg);
    }
    .btn:disabled { opacity:.6; cursor:not-allowed; }
    .btn.primary { background: var(--brand); color: #111; border-color: #eaa502; }

    section { padding: 4rem 0; border-top: 1px solid var(--border); }
    .section-title { font-weight:800; font-size: clamp(1.6rem, 1.2rem + 1vw, 2rem); margin: 0 0 .5rem; }
    .section-sub { color: var(--muted); margin: 0 0 1.5rem; }

    .grid { display: grid; gap: 1.25rem; }
    .grid.cols-2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
    @media (max-width: 860px) { .grid.cols-2 { grid-template-columns: 1fr; } }

    .card { background: var(--card); border:1px solid var(--border); border-radius: 18px; overflow:hidden; }
    .card .body { padding: 1.25rem; }
    .pill { display:inline-block; font-size:.8rem; padding:.35rem .6rem; border-radius:999px; background:#1e2025; border:1px solid var(--border); color: var(--muted); }
    .facts { display:flex; gap:1rem; flex-wrap:wrap; margin:.75rem 0 0; }
    .fact { padding:.35rem .6rem; border-radius: 999px; background:#1c1e22; border:1px solid var(--border); font-weight:600; font-size:.9rem; }

    .itinerary .day { display:grid; grid-template-columns: 3fr 2fr; gap:1rem; }
    @media (max-width: 900px) { .itinerary .day { grid-template-columns: 1fr; } }
    .day h3 { margin:.2rem 0 .25rem; font-size: 1.25rem; }
    .day p { color: var(--muted); }

    .footer { color: var(--muted); padding: 2rem 0 4rem; text-align:center; }
    .footer a { color: var(--fg); text-decoration: underline; }
    .small { font-size:.95rem; color: var(--muted); }
    .emoji { filter: grayscale(100%); opacity:.8; }

    /* Simple inputs look-and-feel */
    input[type="text"], input[type="email"], textarea {
      width:100%; padding:.6rem; margin:.4rem 0;
      border-radius:10px; border:1px solid var(--border);
      background:var(--card); color:var(--fg);
    }
    label.small { display:block; margin-top:.4rem; }
    form .btn.primary { margin-top:.6rem; }
    
    /* --- Dropdown Menu --- */
.dropdown {
  position: relative;
}

.dropdown-menu {
  list-style-type: none;
  padding: 0;
  margin: 0;
  position: absolute;
  top: 100%; /* Position below the link */
  left: 0;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  min-width: 150px;
  z-index: 100;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.dropdown:hover .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.dropdown-menu li a {
  display: block;
  padding: 10px 15px;
  white-space: nowrap;
  color: var(--fg); /* Ensure submenu links are visible */
  margin: 0;
}

.dropdown-menu li a:hover {
  background: rgba(255, 255, 255, 0.05);
  text-decoration: none;
  color: var(--brand); /* Highlight on hover */
}

/* Adjustments for existing navigation links */
.nav a {
  margin-left: 1rem;
  color: var(--muted);
  font-weight: 600;
  text-decoration: none;
}

.nav a:hover {
  color: var(--fg);
}


/* === Robust desktop hover fallback (works even on touch-capable laptops) === */
@media (min-width: 900px) {
  /* Hide submenus by default on desktop */
  .has-submenu > .submenu[hidden] { display: none !important; }
  /* Show on hover or keyboard focus */
  .has-submenu:hover > .submenu[hidden],
  .has-submenu:focus-within > .submenu[hidden] { display: block !important; }
  /* Positioning for flyouts */
  .has-submenu { position: relative; }
  .has-submenu > .submenu {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 50;
  }
}
