/*
Theme Name: Voyagio
Theme URI: https://example.com/voyagio
Author: Your Name
Author URI: https://example.com
Description: A lightning-fast tour & travel theme. Zero jQuery, zero bloat, built-in Tours post type, schema.org structured data, and live Customizer controls. Performance of GeneratePress, design polish of Blocksy, simplicity of Astra.
Version: 1.1.1
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: voyagio
Tags: blog, portfolio, one-column, two-columns, custom-colors, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ==========================================================================
   1. Custom properties (overridden live by the Customizer)
   ========================================================================== */
:root {
  --vg-primary: #0c5a63;        /* deep ocean teal */
  --vg-primary-dark: #073f46;
  --vg-accent: #e8a13c;         /* golden hour amber */
  --vg-ink: #1d2a2c;
  --vg-ink-soft: #51686b;
  --vg-surface: #ffffff;
  --vg-sand: #f6f3ec;           /* alternating section wash */
  --vg-line: #e3e7e6;
  --vg-radius: 14px;
  --vg-shadow: 0 10px 30px -12px rgba(12, 90, 99, .25);
  --vg-max: 1200px;
  --vg-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
}

/* ==========================================================================
   2. Reset & base
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
body {
  margin: 0;
  font-family: var(--vg-font);
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--vg-ink);
  background: var(--vg-surface);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--vg-primary); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--vg-primary-dark); }
h1, h2, h3, h4, h5, h6 {
  line-height: 1.2;
  margin: 0 0 .6em;
  font-weight: 800;
  letter-spacing: -.015em;
  color: var(--vg-ink);
}
h1 { font-size: clamp(2rem, 4.5vw, 3.25rem); }
h2 { font-size: clamp(1.6rem, 3vw, 2.25rem); }
h3 { font-size: 1.35rem; }
p { margin: 0 0 1.25em; }
:focus-visible { outline: 3px solid var(--vg-accent); outline-offset: 2px; border-radius: 3px; }
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%);
  height: 1px; width: 1px; overflow: hidden; position: absolute !important; word-wrap: normal !important;
}
.skip-link { position: absolute; left: -9999px; top: 0; background: var(--vg-primary); color: #fff; padding: .6em 1em; z-index: 999; }
.skip-link:focus { left: 0; }

.vg-container { max-width: var(--vg-max); margin: 0 auto; padding: 0 1.25rem; }

/* ==========================================================================
   3. Header
   ========================================================================== */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--vg-line);
}
.site-header .vg-container { display: flex; align-items: center; justify-content: space-between; min-height: 72px; gap: 1.5rem; }
.site-branding { display: flex; align-items: center; gap: .75rem; }
.site-branding img { max-height: 44px; width: auto; }
.site-title { font-size: 1.35rem; font-weight: 800; margin: 0; letter-spacing: -.02em; }
.site-title a { text-decoration: none; color: var(--vg-ink); }
.site-title a span { color: var(--vg-primary); }
.site-description { display: none; }

.main-navigation ul { list-style: none; margin: 0; padding: 0; display: flex; gap: .25rem; }
.main-navigation a {
  display: block; padding: .55em .9em; text-decoration: none; color: var(--vg-ink);
  font-weight: 600; font-size: .95rem; border-radius: 8px; transition: background .18s, color .18s;
}
.main-navigation a:hover, .main-navigation .current-menu-item > a { background: var(--vg-sand); color: var(--vg-primary); }
.main-navigation ul ul {
  position: absolute; display: none; flex-direction: column; min-width: 200px;
  background: #fff; border: 1px solid var(--vg-line); border-radius: 10px; padding: .35rem; box-shadow: var(--vg-shadow);
}
.main-navigation li { position: relative; }
.main-navigation li:hover > ul, .main-navigation li:focus-within > ul { display: flex; }

.menu-toggle {
  display: none; background: none; border: 2px solid var(--vg-line); border-radius: 10px;
  padding: .45em .7em; font: inherit; font-weight: 700; cursor: pointer; color: var(--vg-ink);
}

@media (max-width: 900px) {
  .menu-toggle { display: inline-flex; align-items: center; gap: .4em; }
  .main-navigation ul { display: none; }
  .main-navigation.toggled ul {
    display: flex; flex-direction: column; position: absolute; left: 0; right: 0; top: 100%;
    background: #fff; border-bottom: 1px solid var(--vg-line); padding: .75rem 1.25rem 1rem;
  }
  .main-navigation.toggled ul ul { position: static; box-shadow: none; border: 0; padding-left: 1rem; display: flex; }
}

/* ==========================================================================
   4. Hero
   ========================================================================== */
.vg-hero {
  position: relative; color: #fff; text-align: center;
  padding: clamp(5rem, 12vw, 9rem) 1.25rem;
  background: linear-gradient(160deg, var(--vg-primary-dark), var(--vg-primary) 60%, #12707a);
  background-size: cover; background-position: center;
  overflow: hidden;
}
.vg-hero::after { /* horizon line — the theme's signature */
  content: ""; position: absolute; inset: auto 0 0 0; height: 90px;
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1440 90" preserveAspectRatio="none"><path d="M0,60 C360,10 720,100 1080,50 C1260,25 1380,45 1440,35 L1440,90 L0,90 Z" fill="white"/></svg>') bottom / 100% 100% no-repeat;
}
.vg-hero-inner { position: relative; max-width: 760px; margin: 0 auto; }
.vg-hero .vg-kicker {
  display: inline-block; font-size: .8rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: var(--vg-accent); margin-bottom: 1rem;
}
.vg-hero h1 { color: #fff; }
.vg-hero p { font-size: 1.15rem; color: rgba(255,255,255,.85); max-width: 560px; margin: 0 auto 2rem; }
.vg-hero.has-image { background-blend-mode: multiply; background-color: rgba(7,63,70,.55); }

.vg-btn {
  display: inline-block; background: var(--vg-accent); color: #26200f; font-weight: 800; text-decoration: none;
  padding: .85em 1.9em; border-radius: 999px; border: 0; cursor: pointer; font-size: 1rem;
  transition: transform .18s, box-shadow .18s;
}
.vg-btn:hover { transform: translateY(-2px); box-shadow: 0 12px 24px -10px rgba(232,161,60,.7); color: #26200f; }
.vg-btn--ghost { background: transparent; color: #fff; border: 2px solid rgba(255,255,255,.5); margin-left: .6rem; }
.vg-btn--ghost:hover { border-color: #fff; color: #fff; box-shadow: none; }

/* ==========================================================================
   5. Sections
   ========================================================================== */
.vg-section { padding: clamp(3rem, 7vw, 5.5rem) 0; }
.vg-section--sand { background: var(--vg-sand); }
.vg-section-head { max-width: 640px; margin: 0 auto 2.75rem; text-align: center; }
.vg-section-head .vg-kicker {
  font-size: .78rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--vg-primary);
}
.vg-section-head p { color: var(--vg-ink-soft); }

/* ==========================================================================
   6. Tour cards — the "boarding pass"
   ========================================================================== */
.vg-tour-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); gap: 1.75rem; }
.vg-tour-card {
  background: #fff; border-radius: var(--vg-radius); overflow: hidden; border: 1px solid var(--vg-line);
  display: flex; flex-direction: column; transition: transform .2s, box-shadow .2s; position: relative;
}
.vg-tour-card:hover { transform: translateY(-5px); box-shadow: var(--vg-shadow); }
.vg-tour-card__media { aspect-ratio: 16/10; overflow: hidden; background: var(--vg-sand); }
.vg-tour-card__media img { width: 100%; height: 100%; object-fit: cover; }
.vg-tour-card__body { padding: 1.35rem 1.35rem 1.1rem; flex: 1; }
.vg-tour-card__dest {
  font-size: .78rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--vg-primary);
}
.vg-tour-card__title { font-size: 1.2rem; margin: .35rem 0 .5rem; }
.vg-tour-card__title a { text-decoration: none; color: inherit; }
.vg-tour-card__title a::after { content: ""; position: absolute; inset: 0; }
.vg-tour-card__excerpt { font-size: .93rem; color: var(--vg-ink-soft); margin: 0; }
/* perforated boarding-pass stub */
.vg-tour-card__stub {
  border-top: 2px dashed var(--vg-line); padding: .9rem 1.35rem;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem; position: relative;
}
.vg-tour-card__stub::before, .vg-tour-card__stub::after {
  content: ""; position: absolute; top: -9px; width: 18px; height: 18px; border-radius: 50%;
  background: var(--vg-surface); border: 1px solid var(--vg-line);
}
.vg-section--sand .vg-tour-card__stub::before, .vg-section--sand .vg-tour-card__stub::after { background: var(--vg-sand); }
.vg-tour-card__stub::before { left: -10px; }
.vg-tour-card__stub::after { right: -10px; }
.vg-tour-card__duration { font-size: .85rem; font-weight: 600; color: var(--vg-ink-soft); }
.vg-tour-card__price { font-weight: 800; color: var(--vg-primary); font-size: 1.1rem; }
.vg-tour-card__price small { font-weight: 600; color: var(--vg-ink-soft); font-size: .75rem; }

/* ==========================================================================
   7. Feature trio
   ========================================================================== */
.vg-features { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.5rem; }
.vg-feature { text-align: center; padding: 2rem 1.5rem; background: #fff; border: 1px solid var(--vg-line); border-radius: var(--vg-radius); }
.vg-feature__icon {
  width: 56px; height: 56px; margin: 0 auto 1rem; display: grid; place-items: center;
  background: var(--vg-sand); color: var(--vg-primary); border-radius: 16px; font-size: 1.5rem;
}
.vg-feature h3 { font-size: 1.1rem; }
.vg-feature p { font-size: .93rem; color: var(--vg-ink-soft); margin: 0; }

/* ==========================================================================
   8. Blog / archive
   ========================================================================== */
.vg-content-area { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 3rem; padding: 3rem 0; }
.vg-content-area.no-sidebar { grid-template-columns: minmax(0, 1fr); max-width: 820px; margin: 0 auto; }
@media (max-width: 960px) { .vg-content-area { grid-template-columns: 1fr; } }

.vg-post-list { display: grid; gap: 2rem; }
.vg-post-card { display: grid; grid-template-columns: 280px 1fr; gap: 1.5rem; align-items: center; }
@media (max-width: 640px) { .vg-post-card { grid-template-columns: 1fr; } }
.vg-post-card__media { border-radius: var(--vg-radius); overflow: hidden; aspect-ratio: 16/10; }
.vg-post-card__media img { width: 100%; height: 100%; object-fit: cover; }
.vg-post-card .entry-title { font-size: 1.3rem; margin-bottom: .4rem; }
.vg-post-card .entry-title a { text-decoration: none; color: inherit; }
.vg-post-card .entry-title a:hover { color: var(--vg-primary); }
.entry-meta { font-size: .84rem; color: var(--vg-ink-soft); margin-bottom: .5rem; }
.entry-meta a { color: inherit; text-decoration: none; }
.entry-meta a:hover { color: var(--vg-primary); }

.page-header { padding: 3rem 0 0; }
.page-title { margin-bottom: .25rem; }
.archive-description { color: var(--vg-ink-soft); }

/* single */
.entry-content { font-size: 1.08rem; }
.entry-content h2, .entry-content h3 { margin-top: 1.8em; }
.entry-content img { border-radius: var(--vg-radius); }
.entry-content blockquote {
  margin: 1.5em 0; padding: 1em 1.5em; border-left: 4px solid var(--vg-accent);
  background: var(--vg-sand); border-radius: 0 10px 10px 0; font-style: italic;
}
.post-thumbnail-hero { border-radius: var(--vg-radius); overflow: hidden; margin: 1.5rem 0 2rem; }
.entry-footer { margin-top: 2rem; padding-top: 1.25rem; border-top: 1px solid var(--vg-line); font-size: .9rem; }
.vg-tags a {
  display: inline-block; background: var(--vg-sand); color: var(--vg-ink-soft); text-decoration: none;
  padding: .25em .8em; border-radius: 999px; font-size: .82rem; margin: 0 .3em .4em 0;
}
.vg-tags a:hover { background: var(--vg-primary); color: #fff; }

/* tour single meta bar */
.vg-tour-meta {
  display: flex; flex-wrap: wrap; gap: 1.25rem 2.5rem; padding: 1.25rem 1.5rem; margin: 1.5rem 0 2rem;
  background: var(--vg-sand); border-radius: var(--vg-radius);
}
.vg-tour-meta div span { display: block; font-size: .75rem; text-transform: uppercase; letter-spacing: .1em; color: var(--vg-ink-soft); font-weight: 700; }
.vg-tour-meta div strong { font-size: 1.15rem; color: var(--vg-primary); }

/* breadcrumbs */
.vg-breadcrumbs { font-size: .84rem; color: var(--vg-ink-soft); padding: 1rem 0 0; }
.vg-breadcrumbs a { color: var(--vg-ink-soft); text-decoration: none; }
.vg-breadcrumbs a:hover { color: var(--vg-primary); }
.vg-breadcrumbs .sep { margin: 0 .45em; opacity: .5; }

/* pagination */
.vg-pagination { margin-top: 2.5rem; display: flex; gap: .4rem; flex-wrap: wrap; }
.vg-pagination .page-numbers {
  display: inline-grid; place-items: center; min-width: 42px; height: 42px; padding: 0 .6em;
  border: 1px solid var(--vg-line); border-radius: 10px; text-decoration: none; color: var(--vg-ink); font-weight: 600;
}
.vg-pagination .page-numbers.current, .vg-pagination .page-numbers:hover { background: var(--vg-primary); color: #fff; border-color: var(--vg-primary); }

/* ==========================================================================
   9. Sidebar & widgets
   ========================================================================== */
.widget { margin-bottom: 2.25rem; }
.widget-title { font-size: .95rem; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 1rem; }
.widget ul { list-style: none; margin: 0; padding: 0; }
.widget li { padding: .45em 0; border-bottom: 1px solid var(--vg-line); }
.widget a { text-decoration: none; }

/* search form */
.search-form { display: flex; gap: .5rem; }
.search-form input[type="search"] {
  flex: 1; padding: .65em 1em; border: 1px solid var(--vg-line); border-radius: 10px; font: inherit;
}
.search-form button { border-radius: 10px; padding: .65em 1.2em; }

/* comments */
.comments-area { margin-top: 3rem; }
.comment-list { list-style: none; padding: 0; }
.comment-body { padding: 1.25rem; border: 1px solid var(--vg-line); border-radius: var(--vg-radius); margin-bottom: 1rem; }
.comment-form textarea, .comment-form input[type="text"], .comment-form input[type="email"], .comment-form input[type="url"] {
  width: 100%; padding: .7em 1em; border: 1px solid var(--vg-line); border-radius: 10px; font: inherit;
}

/* ==========================================================================
   10. Footer
   ========================================================================== */
.site-footer { background: var(--vg-primary-dark); color: rgba(255,255,255,.8); margin-top: 4rem; }
.site-footer a { color: #fff; text-decoration: none; }
.site-footer a:hover { color: var(--vg-accent); }
.vg-footer-widgets {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 2.5rem;
  padding: 3.5rem 0;
}
.site-footer .widget-title { color: #fff; }
.site-footer .widget li { border-color: rgba(255,255,255,.12); }
.site-info { border-top: 1px solid rgba(255,255,255,.12); padding: 1.5rem 0; font-size: .85rem; text-align: center; }

/* WP core alignment classes */
.alignwide { margin-left: -60px; margin-right: -60px; }
.alignfull { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); max-width: 100vw; }
.aligncenter { margin-left: auto; margin-right: auto; }
.alignleft { float: left; margin: 0 1.5em 1em 0; }
.alignright { float: right; margin: 0 0 1em 1.5em; }
@media (max-width: 940px) { .alignwide { margin-left: 0; margin-right: 0; } }
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: .85rem; color: var(--vg-ink-soft); text-align: center; padding: .4em 0; }
.sticky { border-left: 4px solid var(--vg-accent); padding-left: 1rem; }
.bypostauthor { display: block; }

/* ==========================================================================
   11. Top bar
   ========================================================================== */
.vg-topbar { background: var(--vg-primary-dark); color: rgba(255,255,255,.85); font-size: .84rem; }
.vg-topbar .vg-container { display: flex; justify-content: space-between; align-items: center; min-height: 38px; flex-wrap: wrap; gap: .25rem 1.5rem; }
.vg-topbar a { color: rgba(255,255,255,.85); text-decoration: none; margin-right: 1.25rem; }
.vg-topbar a:hover { color: var(--vg-accent); }
.vg-topbar__social a { margin: 0 0 0 1rem; }

/* ==========================================================================
   12. Tour search bar
   ========================================================================== */
.vg-hero--search { text-align: center; padding-bottom: clamp(6rem, 14vw, 10rem); }
.vg-hero--search .vg-hero-inner { max-width: 980px; }
.vg-tour-search {
  display: flex; flex-wrap: wrap; gap: .75rem; align-items: flex-end;
  background: #fff; border-radius: var(--vg-radius); padding: 1.1rem;
  box-shadow: 0 20px 45px -18px rgba(0,0,0,.4); text-align: left; margin-top: 2rem;
}
.vg-tour-search__field { flex: 1 1 160px; }
.vg-tour-search__field--grow { flex: 2 1 220px; }
.vg-tour-search label {
  display: block; font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--vg-ink-soft); margin-bottom: .3rem;
}
.vg-tour-search input, .vg-tour-search select {
  width: 100%; padding: .65em .8em; font: inherit; color: var(--vg-ink);
  border: 1px solid var(--vg-line); border-radius: 10px; background: #fff;
}
.vg-tour-search .vg-btn { flex: 0 0 auto; }

/* ==========================================================================
   13. Badges, sale prices, star ratings
   ========================================================================== */
.vg-badge {
  position: absolute; top: 14px; left: -6px; z-index: 2;
  background: var(--vg-accent); color: #26200f; font-size: .72rem; font-weight: 800;
  letter-spacing: .06em; text-transform: uppercase; padding: .4em .9em;
  border-radius: 0 6px 6px 0; box-shadow: 0 4px 10px -4px rgba(0,0,0,.4);
}
.vg-badge::before {
  content: ""; position: absolute; left: 0; top: 100%;
  border: 3px solid transparent; border-top-color: #a76f1e; border-right-color: #a76f1e;
}
.vg-badge--inline { position: static; display: inline-block; vertical-align: middle; border-radius: 6px; margin-left: .4em; }
.vg-badge--inline::before { display: none; }

.vg-tour-card__price del { color: var(--vg-ink-soft); font-weight: 600; font-size: .85em; margin-right: .25em; }
.vg-tour-card__price ins { text-decoration: none; }

.vg-stars { display: inline-flex; gap: 1px; }
.vg-star { color: var(--vg-line); font-size: .95rem; }
.vg-star.is-full { color: var(--vg-accent); }
.vg-star.is-half { background: linear-gradient(90deg, var(--vg-accent) 50%, var(--vg-line) 50%); -webkit-background-clip: text; background-clip: text; color: transparent; }
.vg-tour-card__rating { display: flex; align-items: center; gap: .45rem; margin-top: .1rem; }
.vg-review-count { font-size: .82rem; color: var(--vg-ink-soft); }

/* ==========================================================================
   14. Destination cards
   ========================================================================== */
.vg-dest-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.5rem; }
.vg-dest-grid > .vg-dest-card:first-child { grid-column: span 2; }
@media (max-width: 640px) { .vg-dest-grid > .vg-dest-card:first-child { grid-column: span 1; } }
.vg-dest-card {
  position: relative; display: flex; flex-direction: column; justify-content: flex-end;
  min-height: 240px; padding: 1.5rem; border-radius: var(--vg-radius); overflow: hidden;
  background: var(--vg-primary) center / cover no-repeat; color: #fff; text-decoration: none;
  transition: transform .2s, box-shadow .2s;
}
.vg-dest-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(7,63,70,.85)); transition: background .2s; }
.vg-dest-card:hover { transform: translateY(-4px); box-shadow: var(--vg-shadow); color: #fff; }
.vg-dest-card > * { position: relative; }
.vg-dest-card__count {
  position: absolute; top: 1.25rem; right: 1.25rem; font-size: .74rem; font-weight: 700;
  background: rgba(255,255,255,.92); color: var(--vg-primary); padding: .3em .8em; border-radius: 999px;
}
.vg-dest-card__name { font-size: 1.35rem; font-weight: 800; letter-spacing: -.01em; }
.vg-dest-card__cta { font-size: .84rem; font-weight: 600; opacity: 0; transform: translateY(4px); transition: opacity .2s, transform .2s; }
.vg-dest-card:hover .vg-dest-card__cta, .vg-dest-card:focus-visible .vg-dest-card__cta { opacity: 1; transform: none; }

/* section head with side link */
.vg-section-head--split {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem;
  max-width: none; text-align: left; margin-bottom: 2.25rem;
}
.vg-section-head--split h2 { margin-bottom: 0; }
.vg-link-arrow { font-weight: 700; text-decoration: none; white-space: nowrap; }

/* ==========================================================================
   15. Promo banner
   ========================================================================== */
.vg-promo {
  background: linear-gradient(120deg, var(--vg-primary-dark), var(--vg-primary));
  color: #fff; padding: clamp(2.5rem, 6vw, 4rem) 0; position: relative; overflow: hidden;
}
.vg-promo::after {
  content: "\2708"; position: absolute; right: 4%; top: 50%; transform: translateY(-50%) rotate(-12deg);
  font-size: clamp(5rem, 12vw, 9rem); opacity: .12;
}
.vg-promo__inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; }
.vg-promo h2 { color: #fff; margin: 0; }
.vg-promo .vg-kicker { color: var(--vg-accent); font-size: .8rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; }

/* ==========================================================================
   16. Testimonials — CSS scroll-snap carousel, zero JS
   ========================================================================== */
.vg-reviews {
  display: grid; grid-auto-flow: column; grid-auto-columns: min(360px, 82vw);
  gap: 1.5rem; overflow-x: auto; scroll-snap-type: x mandatory;
  padding: .25rem .25rem 1.25rem; scrollbar-width: thin;
}
.vg-review {
  scroll-snap-align: start; margin: 0; background: #fff; border: 1px solid var(--vg-line);
  border-radius: var(--vg-radius); padding: 1.75rem;
}
.vg-review blockquote { margin: 0 0 1.25rem; font-style: italic; color: var(--vg-ink-soft); }
.vg-review blockquote::before { content: "\201C"; display: block; font-size: 3rem; line-height: .5; color: var(--vg-accent); font-style: normal; margin-bottom: .5rem; }
.vg-review figcaption { display: flex; align-items: center; gap: .8rem; }
.vg-review figcaption img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; }
.vg-review figcaption span { display: block; font-size: .82rem; color: var(--vg-ink-soft); }

/* ==========================================================================
   17. Categories + newsletter, article cards
   ========================================================================== */
.vg-two-col { display: grid; grid-template-columns: 1.2fr 1fr; gap: 3rem; }
@media (max-width: 820px) { .vg-two-col { grid-template-columns: 1fr; } }
.vg-cat-list { list-style: none; margin: 0; padding: 0; columns: 2; gap: 2rem; }
@media (max-width: 560px) { .vg-cat-list { columns: 1; } }
.vg-cat-list li { break-inside: avoid; border-bottom: 1px solid var(--vg-line); }
.vg-cat-list a { display: flex; justify-content: space-between; padding: .6em 0; text-decoration: none; color: var(--vg-ink); font-weight: 600; }
.vg-cat-list a:hover { color: var(--vg-primary); }
.vg-cat-list a span { color: var(--vg-ink-soft); font-weight: 400; }

.vg-article-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.75rem; }
.vg-article-card__media { display: block; border-radius: var(--vg-radius); overflow: hidden; aspect-ratio: 4/3; margin-bottom: 1rem; }
.vg-article-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.vg-article-card:hover .vg-article-card__media img { transform: scale(1.04); }
.vg-article-card h3 { font-size: 1.15rem; margin-bottom: .3rem; }
.vg-article-card h3 a { text-decoration: none; color: inherit; }
.vg-article-card h3 a:hover { color: var(--vg-primary); }

/* ==========================================================================
   18. Itinerary accordion
   ========================================================================== */
.vg-itinerary { margin: 2.5rem 0; }
.vg-itinerary__day { border: 1px solid var(--vg-line); border-radius: 12px; margin-bottom: .75rem; overflow: hidden; }
.vg-itinerary__day summary {
  display: flex; align-items: center; gap: 1rem; padding: 1rem 1.25rem;
  font-weight: 700; cursor: pointer; list-style: none;
}
.vg-itinerary__day summary::-webkit-details-marker { display: none; }
.vg-itinerary__day summary::after { content: "+"; margin-left: auto; font-size: 1.3rem; color: var(--vg-primary); transition: transform .2s; }
.vg-itinerary__day[open] summary::after { transform: rotate(45deg); }
.vg-itinerary__day[open] summary { background: var(--vg-sand); }
.vg-itinerary__num {
  flex: 0 0 auto; background: var(--vg-primary); color: #fff; font-size: .74rem;
  font-weight: 800; letter-spacing: .06em; text-transform: uppercase;
  padding: .35em .8em; border-radius: 999px;
}
.vg-itinerary__day p { padding: 0 1.25rem 1.1rem; margin: 0; color: var(--vg-ink-soft); }

/* ==========================================================================
   19. Booking form
   ========================================================================== */
.vg-booking { margin: 2.5rem 0 0; padding: 2rem; background: var(--vg-sand); border-radius: var(--vg-radius); }
.vg-booking__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 1.25rem; }
@media (max-width: 560px) { .vg-booking__grid { grid-template-columns: 1fr; } }
.vg-booking label { display: block; font-weight: 700; font-size: .88rem; margin-bottom: .3rem; }
.vg-booking input, .vg-booking textarea {
  width: 100%; padding: .7em 1em; border: 1px solid var(--vg-line); border-radius: 10px; font: inherit; background: #fff;
}
.vg-hp { position: absolute !important; left: -9999px; }
.vg-alert { padding: .8em 1.2em; border-radius: 10px; font-weight: 600; }
.vg-alert--success { background: #e2f3e8; color: #1a6b3c; }
.vg-alert--error { background: #fbe4e4; color: #a12626; }
