:root{
  --bg:#0f172a;
  --panel:#0b1220;
  --border:#1f2a44;
  --muted:#94a3b8;
  --text:#e5e7eb;
  --accent:#22d3ee;
  --brand:#1270b8;
  --accent-2:#22c1c3;
  --card-radius:14px;
  --shadow:0 8px 30px rgba(0,0,0,0.35);
  --font-sans: 'Poppins', system-ui, -apple-system, 'Segoe UI', Roboto, Arial;
  --font-heading: 'Montserrat', var(--font-sans);
}

/* Import Google Fonts used for headings and body; easy to change for a site-wide restyle */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700&family=Poppins:wght@300;400;600&display=swap');

/* Hero */
.hero{padding:64px 0 36px;text-align:center}
.hero-title{font-family:var(--font-heading);font-weight:600;font-size:clamp(32px,6vw,56px);letter-spacing:0.02em;color:var(--text);margin:0}
.hero-sub{color:var(--muted);margin-top:8px}

/* Flip-card gallery shared styles */
.trip-card{position:relative;perspective:900px}
/* Let JavaScript set aspect ratio dynamically based on loaded image dimensions */
.trip-card{overflow:hidden;min-height:200px}
.trip-card .flip{position:relative;transition:transform .7s;transform-style:preserve-3d;height:100%;width:100%}
.trip-card .front,.trip-card .back{position:absolute;inset:0;display:block;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:var(--card-radius);overflow:hidden}
.trip-card .back{position:absolute;top:0;left:0;transform:rotateY(180deg);background:#000}
.trip-card.is-flipped .flip{transform:rotateY(180deg)}
.trip-card .front img{width:100%;height:100%;object-fit:cover;display:block}
.trip-card .front video{width:100%;height:100%;object-fit:cover;display:block}
.front-media{width:100%;height:100%;object-fit:cover;display:block}
.trip-card .front .card-overlay{padding:16px}
.trip-card .back .card-close{position:absolute;right:10px;top:10px;background:rgba(0,0,0,0.6);color:#fff;border:none;padding:6px 8px;border-radius:6px;cursor:pointer;z-index:10}
.trip-card .video-wrapper{position:absolute;inset:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#000}
.trip-card .video-wrapper iframe,.trip-card .video-wrapper video{width:100%;height:100%;object-fit:contain;border:0}

html,body{height:100%}
body{
  margin:0; font-family:var(--font-sans); background:var(--bg); color:var(--text); -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
a.link{color:var(--accent);text-decoration:none}
/* Utility */
.container{max-width:1200px;margin:0 auto;padding:0 16px}

/* Responsive grid used by travel pages. On desktop we use a small
   implicit row height and JS calculates per-card row spans so tiles
   pack together like a masonry layout while preserving source order. */
.grid{
  max-width:1100px;
  margin:16px auto 60px;
  padding:0 16px;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:16px; /* default spacing */
  align-items:start;
}
/* Keep layout stable but let media drive tile height; avoid forcing uniform squares.
   No desktop-only aspect-ratio is enforced here so images/videos are sized
   according to their intrinsic aspect and the JS height logic. */

/* Video caption / title shown on the back when playing */
.video-caption{position:absolute;left:12px;top:12px;background:rgba(0,0,0,0.5);color:#fff;padding:6px 10px;border-radius:8px;font-size:12px}

/* Hero helper */
.hero{position:relative;padding:60px 0 40px;text-align:center}
.hero .hero-title{font-family:var(--font-heading);font-size:clamp(28px,5vw,48px);margin:0;color:var(--text)}
.hero .hero-sub{color:var(--muted);margin-top:8px}

/* Reusable card overlay */
.card-overlay{position:absolute;left:0;right:0;bottom:0;padding:18px;background:linear-gradient(180deg,transparent 40%, rgba(4,8,14,0.85));color:#fff}

/* Buttons */
.btn{display:inline-block;padding:10px 16px;border-radius:10px;background:var(--brand);color:#fff;font-weight:600;text-decoration:none;border:none;cursor:pointer}
.btn.secondary{background:transparent;color:var(--text);border:1px solid var(--border)}

/* Blue hero variant used on travel page */
.hero--blue{background:linear-gradient(180deg, rgba(18,112,184,0.12), rgba(4,8,14,0));}

/* Player helpers to replace inline styles */
.player-video{width:100%;height:100%;background:#000;display:block;object-fit:cover}
.player-iframe{width:100%;height:100%;display:none;border:0}
.player-iframe.visible{display:block}
.player-controls{position:absolute;left:12px;bottom:12px;right:12px;display:flex;gap:10px;align-items:center;justify-content:flex-end;pointer-events:auto}

/* Expanded/centered tile when a card is focused (flipped into player mode) */
.trip-card.is-expanded{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:min(1100px,92vw);aspect-ratio:16/9;z-index:99999;border-radius:12px;box-shadow:var(--shadow);}
.trip-card.is-expanded .flip{width:100%;height:100%}
.trip-card.is-expanded .front,.trip-card.is-expanded .back{height:100%}
.trip-card.is-expanded .video-wrapper iframe,.trip-card.is-expanded .video-wrapper video{width:100%;height:100%;object-fit:contain}

/* Player UI visible in expanded state and styled consistently */
.player-ui{position:absolute;left:12px;bottom:12px;display:flex;gap:8px;align-items:center;z-index:4}
.player-ui button{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.06);color:#fff;padding:8px 10px;border-radius:8px;cursor:pointer}
.player-ui .volume{width:120px}
body.modal-open{overflow:hidden}

.unmute{position:absolute;right:12px;top:12px;background:rgba(255,255,255,0.08);color:var(--text);border:1px solid rgba(255,255,255,0.06);padding:8px 10px;border-radius:8px;cursor:pointer;z-index:3}
.unmute:hover{background:rgba(255,255,255,0.12)}

/* Rotator (multi-poster slideshow inside a tile)
  Use a selector specific to the .thumb container so inline rules such as
  ".thumb img { display: block; }" do not accidentally override the
  rotator visibility rules. */
.thumb{position:relative;height:100%;width:100%}
.thumb .rotator{position:relative;width:100%;height:100%;overflow:hidden}
.thumb .rotator img{position:absolute;left:0;top:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .45s ease}
.thumb .rotator img.visible{opacity:1}

/* Volume slider */
.volume{appearance:none;width:110px;height:6px;background:rgba(255,255,255,0.06);border-radius:999px;outline:none}
.volume::-webkit-slider-thumb{appearance:none;width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,0.3)}
.volume::-moz-range-thumb{width:14px;height:14px;background:#fff;border-radius:50%}

/* Card meta layout (replaces inline flex used in templates) */
.card-meta-row{display:flex;justify-content:space-between;align-items:center;gap:12px}
.card-meta-row .card-title{overflow:hidden}
.card-meta-row .card-title strong{display:block;font-size:1.04rem;line-height:1.1}
.card-meta-row .card-location{font-size:13px;color:var(--muted);margin-top:6px}
.card-price-amount{display:none}

/* Slight visual polish for the grid cards to appear as 'black packages' */
.card{background:linear-gradient(180deg,#02040a,#05060a);border-radius:var(--card-radius);border:1px solid rgba(255,255,255,0.03);overflow:hidden}
.badge{background:rgba(255,255,255,0.04);color:var(--text);padding:4px 8px;border-radius:999px;font-size:11px;border:1px solid rgba(255,255,255,0.03)}
