/* =====================================================================
   Travel theme — v2 homepage + footer
   Static 3-tile hero · continents row · tips block · 4×4 portrait grid
   Instrument Sans only (per rules.md). Customizer CSS vars drive colors.
   ===================================================================== */

:root {
    --text-color: var(--color-text);
    --text-primary: var(--color-text);
    --bg-color: var(--color-bg);
    --bg-primary: var(--color-bg);
    --c-surface: var(--color-bg);
    --c-text: var(--color-text);
    --fs-base: 16px;
    --wave-color: var(--color-accent);
}

body {
    font-family: var(--font-body, 'Instrument Sans', system-ui, sans-serif);
    color: var(--color-text);
    background: var(--color-bg);
    font-size: var(--fs-base);
    -webkit-font-smoothing: antialiased;
}

.container { max-width: 1400px; margin: 0 auto; padding: 0 24px; }

/* --- Shared section header --- */
.section-header {
    text-align: center;
    margin: 0 auto 48px;
    max-width: 720px;
}
.section-header--split {
    display: flex; align-items: flex-end; justify-content: space-between;
    text-align: left; max-width: none; gap: 24px; flex-wrap: wrap;
}
.section-eyebrow {
    font-size: 12px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--color-accent-strong, #C2410C); /* AA kontrast (acik zemin) */
    font-weight: 600;
    margin: 0 0 12px;
}
.section-title {
    font-family: var(--font-heading, 'Instrument Sans', system-ui, sans-serif);
    font-size: clamp(28px, 3.4vw, 42px);
    line-height: 1.12;
    letter-spacing: -0.015em;
    font-weight: 600;
    margin: 0 0 12px;
    color: var(--color-text);
}
.section-link {
    font-size: 13px;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 600;
    color: var(--color-text);
    text-decoration: none;
    border-bottom: 1px solid var(--color-text);
    padding-bottom: 2px;
    transition: color .15s, border-color .15s;
}
.section-link:hover { color: var(--color-accent); border-color: var(--color-accent); }

/* ======================================================================
   HERO CAROUSEL — peek carousel, center slide full, sides half (8s auto)
   ====================================================================== */
.hero-slider {
    position: relative;
    padding: 0;
    margin: 0;
    background: var(--color-bg);
    overflow: hidden;  /* clip peeking side slides */
}
.hero-slider-viewport {
    overflow: visible;
    padding: 14px 0;
}
.hero-slider-track {
    display: flex;
    gap: 14px;
    will-change: transform;
    transition: transform .9s cubic-bezier(.5, .05, .25, 1);
}
.hero-slide {
    /* ~60% of viewport → sides peek ~20% each side, center fully framed. */
    flex: 0 0 60%;
    position: relative;
    background: #111;
    overflow: hidden;
    aspect-ratio: 16/9;
    transition: transform .4s ease;
}
.hero-slide__link {
    position: absolute; inset: 0;
    display: block;
    text-decoration: none;
    color: #fff;
}
.hero-slide picture,
.hero-slide img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 1.4s ease;
}
.hero-slide:hover img { transform: scale(1.04); }

/* Overlay only on the center slide. Black gradient at bottom for legibility. */
.hero-slide__overlay {
    position: absolute; inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: center;
    text-align: center;
    padding: 48px 36px 36px;
    background: linear-gradient(180deg, transparent 45%, rgba(0,0,0,0.82) 100%);
    opacity: 0;
    transition: opacity .6s ease;
    pointer-events: none;
}
.hero-slide.is-center .hero-slide__overlay { opacity: 1; pointer-events: auto; }
.hero-slide__chip {
    display: inline-block;
    background: var(--color-accent-strong, #C2410C); /* beyaz metin icin AA kontrast */
    color: #fff;
    font-size: 10.5px;
    letter-spacing: .24em;
    text-transform: uppercase;
    font-weight: 700;
    padding: 6px 12px;
    margin-bottom: 14px;
}
.hero-slide__title {
    font-family: var(--font-heading, 'Instrument Sans', system-ui, sans-serif);
    font-size: clamp(22px, 2.6vw, 38px);
    line-height: 1.12;
    margin: 0 0 10px;
    font-weight: 700;
    letter-spacing: -0.015em;
    color: #fff;
    max-width: 640px;
    text-shadow: 0 2px 24px rgba(0,0,0,.4);
}
.hero-slide__meta {
    font-size: 10.5px;
    letter-spacing: .18em;
    text-transform: uppercase;
    opacity: .92;
    display: inline-flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
}
/* Dim the non-center slides slightly so the center one pops */
.hero-slide:not(.is-center) img { filter: saturate(.92) brightness(.92); }

/* Arrows */
.hero-slider-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 46px; height: 46px;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,.95);
    color: var(--color-text);
    border: 0;
    border-radius: 9999px;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(0,0,0,.12);
    transition: background .15s, color .15s;
    z-index: 2;
}
.hero-slider-arrow:hover { background: var(--color-accent); color: #fff; }
.hero-slider-arrow--prev { left: 24px; }
.hero-slider-arrow--next { right: 24px; }

@media (max-width: 1100px) {
    .hero-slide { flex-basis: 75%; }
}
@media (max-width: 700px) {
    .hero-slide { flex-basis: 92%; aspect-ratio: 16/10; }
    .hero-slider-arrow--prev { left: 12px; }
    .hero-slider-arrow--next { right: 12px; }
    .hero-slide__overlay { padding: 32px 24px 28px; }
}

/* ======================================================================
   CONTINENTS ROW (inline SVG stub — replaceable by user assets)
   ====================================================================== */
.continents-section { padding: 96px 0 72px; background: var(--color-bg); }
.continents-row {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 32px;
    max-width: 1100px;
    margin: 0 auto;
}
.continent-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 18px;
    padding: 16px 8px;
    text-decoration: none;
    color: var(--color-accent);
    transition: transform .2s ease, color .2s ease;
}
.continent-item:hover { transform: translateY(-4px); color: var(--color-primary); }
.continent-shape {
    width: 150px; height: 150px;
    display: flex; align-items: center; justify-content: center;
}
.continent-shape svg,
.continent-shape img,
.continent-shape picture { width: 100%; height: 100%; display: block; object-fit: contain; }
.continent-shape picture img { width: 100%; height: 100%; object-fit: contain; }
.continent-label {
    font-size: 11px;
    letter-spacing: .24em;
    font-weight: 600;
    color: var(--color-text);
    text-transform: uppercase;
}

@media (max-width: 768px) {
    .continents-row { grid-template-columns: repeat(3, 1fr); gap: 16px; }
    .continent-shape { width: 100px; height: 100px; }
}

/* ======================================================================
   TIPS BLOCK ("Pack Smart" layout)
   ====================================================================== */
.tips-block { padding: 80px 0 96px; background: var(--color-bg-alt, #F8FAFC); }
.tips-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 40px;
    align-items: start;
}
.tips-intro { padding: 8px 0 8px 24px; border-left: 3px solid var(--color-accent); }
.tips-intro__title {
    font-family: var(--font-heading, 'Instrument Sans', system-ui, sans-serif);
    font-size: clamp(30px, 2.6vw, 40px);
    line-height: 1.05;
    letter-spacing: -0.02em;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 16px;
}
.tips-intro__lede {
    font-size: 15px;
    line-height: 1.6;
    color: var(--color-text-muted);
    margin: 0 0 24px;
}
.tips-intro__link {
    font-size: 13px;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 600;
    color: var(--color-text);
    text-decoration: none;
    border-bottom: 1px solid var(--color-text);
    padding-bottom: 2px;
}
.tips-intro__link:hover { color: var(--color-accent); border-color: var(--color-accent); }

.tip-card { display: flex; flex-direction: column; gap: 14px; }
.tip-card__image {
    display: block; overflow: hidden; aspect-ratio: 4/5; background: #eee; position: relative;
}
.tip-card__image picture,
.tip-card__image img {
    position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
    transition: transform 1s ease;
}
.tip-card__image:hover img { transform: scale(1.04); }
.tip-card__title {
    font-family: var(--font-heading, 'Instrument Sans', system-ui, sans-serif);
    font-size: 22px; line-height: 1.2; font-weight: 600; margin: 0;
}
.tip-card__title a { color: var(--color-text); text-decoration: none; }
.tip-card__title a:hover { color: var(--color-accent); }
.tip-card__excerpt {
    font-size: 14px; line-height: 1.55;
    color: var(--color-text-muted); margin: 0;
}
.tip-card__cta {
    align-self: flex-start;
    font-size: 12px; letter-spacing: .14em; text-transform: uppercase;
    font-weight: 600; color: #fff; background: var(--color-text);
    padding: 10px 18px; text-decoration: none;
    transition: background .2s;
}
.tip-card__cta:hover { background: var(--color-accent); }

@media (max-width: 980px) {
    .tips-grid { grid-template-columns: 1fr 1fr; }
    .tips-intro { grid-column: span 2; }
}
@media (max-width: 560px) {
    .tips-grid { grid-template-columns: 1fr; }
    .tips-intro { grid-column: auto; }
}

/* ======================================================================
   LATEST DESTINATIONS — fixed 4×4 portrait grid
   ====================================================================== */
.latest-destinations { padding: 96px 0 120px; background: var(--color-bg); }
.post-grid--portrait {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
@media (max-width: 1200px) { .post-grid--portrait { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 800px)  { .post-grid--portrait { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .post-grid--portrait { grid-template-columns: 1fr; } }

.post-card { background: #111; overflow: hidden; position: relative; }
.post-card__image {
    display: block; position: relative; aspect-ratio: 3/4; overflow: hidden;
}
.post-card__image picture,
.post-card__image img {
    position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
    transition: transform 1.1s ease;
}
.post-card:hover .post-card__image img { transform: scale(1.05); }
.post-card__placeholder {
    position: absolute; inset: 0;
    background:
        radial-gradient(circle at 30% 30%, rgba(255,255,255,.08) 0, transparent 40%),
        linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
}
.post-card__overlay {
    position: absolute; inset: auto 0 0 0;
    padding: 20px 18px 18px;
    background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.82) 100%);
    color: #fff;
    display: flex; flex-direction: column; gap: 10px;
}
.post-card__chip {
    align-self: flex-start;
    background: var(--color-accent); color: #fff;
    font-size: 9.5px; letter-spacing: .2em; text-transform: uppercase;
    font-weight: 700; padding: 4px 9px;
}
.post-card__title {
    font-family: var(--font-heading, 'Instrument Sans', system-ui, sans-serif);
    font-size: 17px; line-height: 1.22; font-weight: 600; margin: 0;
    color: #fff; letter-spacing: -0.005em;
}
.seed-notice {
    text-align: center; margin-top: 32px;
    font-size: 13px; color: var(--color-text-muted); font-style: italic;
}

/* Pagination — single global style used by homepage AND archive.
   Legacy .pagination rules in style.css get overridden by higher specificity below. */
.pagination {
    margin: 48px 0 0 !important;
    padding: 0 !important;
    display: flex !important;
    justify-content: center !important;
    background: transparent !important;
    border: 0 !important;
}
.pagination ul {
    display: flex !important;
    gap: 6px !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
}
.pagination li a,
.pagination li span {
    min-width: 42px !important;
    height: 42px !important;
    padding: 0 14px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid var(--color-border) !important;
    background: var(--color-bg) !important;
    color: var(--color-text) !important;
    text-decoration: none !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border-radius: 9999px !important;
    transition: background .15s, color .15s, border-color .15s !important;
    line-height: 1 !important;
}
.pagination li a:hover {
    border-color: var(--color-text) !important;
    color: var(--color-text) !important;
}
.pagination li.active span,
.pagination li .active {
    background: var(--color-text) !important;
    color: #fff !important;
    border-color: var(--color-text) !important;
}
.pagination li.ellipsis span {
    border: none !important;
    background: transparent !important;
}
.pagination svg { display: block; }
html[data-theme="dark"] .pagination li a,
html[data-theme="dark"] .pagination li span {
    background: var(--color-bg-alt) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text) !important;
}
html[data-theme="dark"] .pagination li.active span {
    background: var(--color-accent) !important;
    color: #fff !important;
    border-color: var(--color-accent) !important;
}

/* ======================================================================
   FOOTER v2 — matches foot.jpg (logo + newsletter · links · country pins)
   ====================================================================== */

/* Decorative wavy line — inline SVG data URI, accent-colored */
.footer-wave {
    display: block;
    height: 12px;
    width: 100%;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 12' preserveAspectRatio='none'><path d='M0 6 Q 10 0 20 6 T 40 6 T 60 6 T 80 6' stroke='%23F77F00' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");
    background-repeat: repeat-x;
    background-size: 80px 12px;
    margin: 0;
}

.site-footer-v2 {
    background: var(--color-bg);
    color: var(--color-text);
    padding: 0;
    border: 0;
    margin: 0;
}
.site-footer-v2 .container { padding-top: 56px; padding-bottom: 32px; }
.site-footer-v2 .container:last-of-type { padding-top: 14px; padding-bottom: 18px; }

.footer-main-v2 {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr;
    gap: 64px;
    align-items: start;
}

/* Left — brand + newsletter */
.footer-brand-v2 { max-width: 500px; }
.footer-brand-v2 .footer-logo-img {
    max-height: 64px; width: auto; display: block; margin-bottom: 24px;
}
.footer-brand-v2 .footer-logo-text {
    font-family: var(--font-heading, 'Instrument Sans', system-ui, sans-serif);
    font-size: 32px; font-weight: 700; letter-spacing: -0.01em;
    color: var(--color-text); margin: 0 0 24px;
}
.footer-brand-v2 .footer-blurb {
    font-size: 15px; line-height: 1.65;
    color: var(--color-text-muted); margin: 0 0 24px;
    max-width: 480px;
}
.footer-newsletter-v2 { display: flex; flex-direction: column; gap: 14px; }
.footer-newsletter-v2 .email-input {
    width: 100%;
    padding: 16px 20px;
    font-size: 15px;
    border: 1px solid var(--color-border);
    background: var(--color-bg);
    color: var(--color-text);
    font-family: inherit;
    outline: none;
    transition: border-color .15s;
}
.footer-newsletter-v2 .email-input:focus { border-color: var(--color-text); }
.footer-newsletter-v2 .submit-btn {
    align-self: flex-start;
    padding: 14px 28px;
    background: var(--color-accent-strong, #C2410C); /* beyaz metin icin AA kontrast */
    color: #fff;
    border: 0;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: .04em;
    cursor: pointer;
    font-family: inherit;
    transition: background .15s;
}
.footer-newsletter-v2 .submit-btn:hover { background: var(--color-primary); }
.footer-newsletter-v2 .terms {
    display: flex; align-items: center; gap: 10px;
    font-size: 13px; color: var(--color-text-muted);
}
.footer-newsletter-v2 .terms input { accent-color: var(--color-accent); }

/* Columns — Company / Follow / Useful Links */
.footer-col-v2 h4 {
    font-family: var(--font-heading, 'Instrument Sans', system-ui, sans-serif);
    font-size: 20px; font-weight: 700; letter-spacing: -0.01em;
    color: var(--color-text);
    margin: 0 0 20px;
}
.footer-col-v2 ul {
    list-style: none; padding: 0; margin: 0 0 32px;
    display: flex; flex-direction: column; gap: 12px;
}
.footer-col-v2 ul a {
    color: var(--color-text);
    text-decoration: none;
    font-size: 15px;
    transition: color .15s;
}
.footer-col-v2 ul a:hover { color: var(--color-accent); }

.footer-social-v2 { display: flex; gap: 18px; align-items: center; }
.footer-social-v2 a {
    color: var(--color-text);
    transition: color .15s, transform .15s;
}
.footer-social-v2 a:hover { color: var(--color-accent); transform: translateY(-2px); }
.footer-social-v2 svg { display: block; width: 22px; height: 22px; }

/* Country pin bar */
.footer-countries-v2 {
    border-top: 1px dashed var(--color-border);
    padding: 28px 0 16px;
    margin-top: 56px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
    font-size: 14px;
    letter-spacing: .02em;
}
.footer-countries-v2__icon {
    color: var(--color-accent);
    display: inline-flex; align-items: center;
    margin-right: 4px;
}
.footer-countries-v2 a {
    color: var(--color-text);
    text-decoration: none;
    position: relative;
    transition: color .15s;
}
.footer-countries-v2 a:hover { color: var(--color-accent); }
.footer-countries-v2 a + a::before {
    content: '–';
    color: var(--color-text-muted);
    margin: 0 10px 0 -4px;
    display: inline-block;
}

.footer-copyright-v2 {
    margin: 0;
    padding: 0;
    font-size: 12px;
    color: var(--color-text-muted);
    letter-spacing: .02em;
    line-height: 1.4;
}
.footer-copyright-v2 a { color: inherit; text-decoration: underline; }
.footer-countries-v2 {
    margin-top: 40px;  /* tighten gap above country bar */
}

@media (max-width: 900px) {
    .footer-main-v2 { grid-template-columns: 1fr 1fr; gap: 40px; }
    .footer-brand-v2 { grid-column: span 2; }
}
@media (max-width: 560px) {
    .footer-main-v2 { grid-template-columns: 1fr; }
    .footer-brand-v2 { grid-column: auto; }
    .footer-countries-v2 { font-size: 13px; gap: 10px; }
    .footer-countries-v2 a + a::before { margin: 0 6px 0 -2px; }
}

/* ======================================================================
   HEADER v2 — compact split-menu (top) / flex scrolled
   Refs: 331.jpg (top) · 34t.jpg (scrolled)
   ====================================================================== */
.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--color-bg);
    border-bottom: 1px solid transparent;
    transition: background-color .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.site-header .header-inner {
    max-width: 1600px;
    margin: 0 auto;
    padding: 14px 40px;
    display: flex;
    align-items: center;
    gap: 36px;
    transition: padding .2s ease;
}

/* -- Top state: Left-nav | [absolute-centered LOGO] | Right-nav + Actions (also absolute) --
   Logo AND actions are both position:absolute so the two navs are the only
   flex children, sharing 50/50 of the row. That makes the navs perfectly
   symmetric around the viewport center — logo and actions float above. */
.site-header[data-state="top"] .header-inner {
    padding: 18px 40px;
    position: relative;
    min-height: 84px;
    --logo-gap: 160px;
}
.site-header[data-state="top"] .nav-primary--left {
    flex: 1 1 0;
    justify-content: flex-end;
    padding-right: var(--logo-gap);
}
.site-header[data-state="top"] .site-logo-link {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    order: 2;
    margin: 0;
    z-index: 2;
    pointer-events: auto;
}
.site-header[data-state="top"] .nav-primary--right {
    flex: 1 1 0;
    justify-content: flex-start;
    padding-left: var(--logo-gap);
    order: 3;
}
.site-header[data-state="top"] .header-actions {
    position: absolute;
    right: 40px;
    top: 50%;
    transform: translateY(-50%);
    margin: 0;
    z-index: 2;
}

/* Narrow viewports — shrink logo gap before it crowds the nav */
@media (max-width: 1100px) {
    .site-header[data-state="top"] .header-inner { --logo-gap: 130px; }
}
@media (max-width: 980px) {
    .site-header[data-state="top"] .header-inner { --logo-gap: 110px; }
    .site-header[data-state="top"] .nav-primary--right { padding-right: 120px; }
}

/* -- Scrolled state: Logo left | spacer | Nav right | Actions -- */
.site-header[data-state="scrolled"] {
    border-bottom-color: var(--color-border);
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: saturate(180%) blur(8px);
    -webkit-backdrop-filter: saturate(180%) blur(8px);
}
.site-header[data-state="scrolled"] .header-inner {
    padding: 10px 40px;
    position: static;
    gap: 24px;
}
.site-header[data-state="scrolled"] .site-logo-link     { order: 1; margin-right: auto; }
.site-header[data-state="scrolled"] .nav-primary--left  { order: 2; }
.site-header[data-state="scrolled"] .nav-primary--right { order: 3; }
.site-header[data-state="scrolled"] .header-actions     { order: 4; position: static; transform: none; }

/* Logo sizing: big at top, compact on scroll */
.site-header .site-logo-link {
    display: inline-flex;
    align-items: center;
    line-height: 0;
    text-decoration: none;
}
.site-header .site-logo {
    display: block;
    line-height: 0;
    width: auto;
    height: 52px;
    max-width: 180px;
    object-fit: contain;
    display: block;
    transition: height .2s ease;
}
.site-header[data-state="scrolled"] .site-logo { height: 34px; }
@media (max-width: 700px) {
    .site-header[data-state="top"] .site-logo,
    .site-header[data-state="scrolled"] .site-logo {
        height: 34px;
        max-width: 152px;
    }
}

/* Light/dark logo swap — specificity must beat `.site-header .site-logo`. */
.site-header .site-logo-link .site-logo--dark,
.site-footer-v2 .footer-brand-v2 .footer-logo-img.site-logo--dark { display: none !important; }
html[data-theme="dark"] .site-header .site-logo-link .site-logo--light,
html[data-theme="dark"] .site-footer-v2 .footer-brand-v2 .footer-logo-img.site-logo--light { display: none !important; }
html[data-theme="dark"] .site-header .site-logo-link .site-logo--dark,
html[data-theme="dark"] .site-footer-v2 .footer-brand-v2 .footer-logo-img.site-logo--dark { display: block !important; }

/* Footer logo image sizing (picture wrapper + inner img) */
.footer-logo-img { display: block; line-height: 0; margin-bottom: 24px; }
.footer-logo-img img { max-height: 72px; width: auto; display: block; }

/* Dark-mode footer logo: site only ships a single light-variant logo, so
   invert + brightness gives a usable white version on dark bg. Skips imgs
   that already declare an explicit dark variant via .site-logo--dark. */
html[data-theme="dark"] .site-footer-v2 .footer-logo-img:not(.site-logo--dark):not(.site-logo--light) {
    filter: invert(1) brightness(2) hue-rotate(180deg);
}

/* Nav lists — default black + no underline; active = accent + underline */
.nav-primary { display: flex; }
.nav-primary ul {
    display: flex;
    align-items: center;
    gap: 32px;
    list-style: none;
    margin: 0;
    padding: 0;
}
.nav-primary a {
    font-size: 12px;
    letter-spacing: .22em;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--color-text);
    text-decoration: none;
    padding: 4px 0 6px;
    position: relative;
    transition: color .15s;
    white-space: nowrap;
}
.nav-primary a:hover { color: var(--color-accent); }
.nav-primary a.is-active {
    color: var(--color-accent);
}
.nav-primary a.is-active::after {
    content: '';
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 2px;
    background: var(--color-accent);
}
html[data-theme="dark"] .nav-primary a { color: var(--color-text); }
html[data-theme="dark"] .nav-primary a:hover,
html[data-theme="dark"] .nav-primary a.is-active { color: #FDBA74; }
html[data-theme="dark"] .nav-primary a.is-active::after { background: #FDBA74; }

/* Actions (search / theme / mobile) */
.header-actions {
    display: inline-flex;
    align-items: center;
    gap: 14px;
}
.header-btn {
    width: 40px; height: 40px;
    display: inline-flex; align-items: center; justify-content: center;
    background: transparent;
    border: 0;
    color: var(--color-text);
    cursor: pointer;
    border-radius: 9999px;
    transition: background .15s, color .15s;
    padding: 0;
}
.header-btn:hover { background: rgba(0,0,0,.05); color: var(--color-accent); }
.header-btn svg  { display: block; }
.header-theme-btn .icon-moon { display: none; }
html[data-theme="dark"] .header-theme-btn .icon-sun  { display: none; }
html[data-theme="dark"] .header-theme-btn .icon-moon { display: block; }
.header-menu-btn { display: none; }

/* -- Mobile (<900px): collapse navs, show hamburger -- */
@media (max-width: 900px) {
    .site-header[data-state="top"] .header-inner,
    .site-header[data-state="scrolled"] .header-inner {
        display: grid;
        grid-template-columns: auto 1fr auto;
        grid-template-areas: "logo spacer actions";
        padding: 14px 20px;
        column-gap: 12px;
        min-height: 62px;
    }
    .site-header[data-state="top"] .site-logo-link,
    .site-header[data-state="scrolled"] .site-logo-link {
        grid-area: logo;
        position: static;
        transform: none;
        justify-self: start;
        margin: 0;
        max-width: 152px;
    }
    .site-header[data-state="top"] .header-actions,
    .site-header[data-state="scrolled"] .header-actions {
        grid-area: actions;
        position: static;
        transform: none;
        justify-self: end;
        margin: 0;
        gap: 8px;
    }
    .site-header .nav-primary--left,
    .site-header .nav-primary--right { display: none; }
    .header-menu-btn { display: inline-flex; }
}

/* -- Search overlay — fixed modal band at top of viewport -- */
.header-search-overlay {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 200;
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-border);
    padding: 24px 40px;
    transform: translateY(-100%);
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    transition: transform .3s ease, opacity .2s ease, visibility 0s linear .3s;
    box-shadow: 0 10px 30px rgba(0,0,0,.08);
}
.site-header.is-search-open .header-search-overlay {
    transform: translateY(0);
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
    transition: transform .3s ease, opacity .2s ease, visibility 0s;
}
.header-search-form {
    max-width: 900px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 12px;
}
.header-search-form input {
    flex: 1;
    font-size: 20px;
    padding: 14px 0;
    border: 0;
    border-bottom: 1px solid var(--color-border);
    background: transparent;
    outline: none;
    font-family: inherit;
    color: var(--color-text);
}
.header-search-form input:focus { border-bottom-color: var(--color-accent); }
.header-search-form button {
    width: 44px; height: 44px;
    border: 0; background: transparent; color: var(--color-text);
    cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    transition: color .15s;
}
.header-search-form button:hover { color: var(--color-accent); }
.header-search-close { font-size: 28px; line-height: 1; }

.header-search-inner {
    max-width: 900px;
    margin: 0 auto;
}
.header-search-results {
    margin-top: 18px;
    max-height: 60vh;
    overflow-y: auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 2px;
}
.header-search-results:empty { display: none; }
.header-search-empty {
    margin: 24px 0 0;
    text-align: center;
    color: var(--color-text-muted);
    font-size: 14px;
}
.header-search-result {
    display: grid;
    grid-template-columns: 64px 1fr;
    gap: 14px;
    padding: 10px;
    text-decoration: none;
    color: var(--color-text);
    background: transparent;
    align-items: center;
    transition: background .15s;
}
.header-search-result:hover { background: var(--color-bg-alt, #F8FAFC); }
.header-search-result__thumb {
    display: block;
    width: 64px; height: 48px;
    background-color: #eee;
    background-size: cover;
    background-position: center;
}
.header-search-result__body {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}
.header-search-result__title {
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.25;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.header-search-result__excerpt {
    font-size: 13px;
    color: var(--color-text-muted);
    line-height: 1.35;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Hide legacy header decorations */
.site-header.transparent,
.site-header.scrolled,
.site-header .site-branding,
.site-header .mobile-nav-menu,
.site-header .main-nav,
.mobile-menu { display: none !important; }
.site-header[data-state] { display: block !important; }
.site-header[data-state] .site-branding { display: none !important; }

/* ======================================================================
   Kill old homepage AND old footer sections when v2 markup is present
   ====================================================================== */
.hero-section,
.featured-section,
.destinations-section,
.posts-section,
.categories-section,
.cta-section { display: none !important; }

body:has(.site-footer-v2) .site-footer { display: none !important; }
body:has(.site-footer-v2) .footer-newsletter { display: none !important; }
