/* =========================================================
   KrajZaKrajem – Main Stylesheet
   @version 1.0.0
========================================================= */

/* === GOOGLE FONTS === */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400;1,700&family=Lato:wght@300;400;700&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400;1,600&display=swap');

/* === CSS VARIABLES === */
:root {
    --dark:        #393639;
    --green:       #03845c;
    --green-light: #05a873;
    --green-dark:  #026b4a;
    --cream:       #f5f0e8;
    --warm-white:  #faf8f4;
    --gold:        #c9a84c;
    --gold-light:  #e8d5a3;
    --text:        #2e2c2e;
    --text-light:  #6b6970;
    --border:      #e8e4dc;
}

/* === RESET & BASE === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
    font-family: 'Lato', sans-serif;
    background: var(--warm-white);
    color: var(--text);
    overflow-x: hidden;
    line-height: 1.6;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--green); text-decoration: none !important; transition: color .3s; }
a:hover { color: var(--green-dark); }

/* Override Bootstrap link colours in card/sidebar components */
.article-card-title a { color: var(--dark); text-decoration: none !important; }
.article-card-title a:hover { color: var(--green); }
.article-card-excerpt a { color: var(--green); text-decoration: none !important; }
.sidebar-post-title { color: var(--dark); text-decoration: none !important; }
.sidebar-post-title:hover { color: var(--green); }
.pretavel-title a { color: var(--dark); text-decoration: none !important; }
.pretavel-read { text-decoration: none !important; }
ul { list-style: none; }

/* === ACCESSIBILITY === */
.skip-link {
    position: absolute; top: -100px; left: 16px; z-index: 9999;
    background: var(--green); color: #fff; padding: 10px 18px;
    font-size: .85rem; font-weight: 700; letter-spacing: .08em;
    transition: top .3s;
}
.skip-link:focus { top: 10px; color: #fff; }

/* === READING PROGRESS === */
#reading-progress {
    position: fixed; top: 0; left: 0; height: 3px;
    background: var(--green); z-index: 9999; width: 0;
    transition: width .1s linear;
    pointer-events: none;
}

/* =========================================================
   NAVBAR
========================================================= */
#site-header {
    position: fixed; top: 0; width: 100%; z-index: 1000;
    padding: 18px 0;
    background: transparent;
    transition: background .4s, padding .4s, box-shadow .4s;
}
#site-header.scrolled {
    background: rgba(57,54,57,.97);
    padding: 10px 0;
    backdrop-filter: blur(10px);
    box-shadow: 0 2px 30px rgba(0,0,0,.3);
}
#site-header.solid {
    background: rgba(57,54,57,.97);
    padding: 10px 0;
    box-shadow: 0 2px 30px rgba(0,0,0,.3);
}

.site-header-inner {
    display: flex; align-items: center; justify-content: space-between;
    gap: 20px; flex-wrap: nowrap;
}

/* Logo */
.site-logo { display: flex; align-items: center; flex-shrink: 0; }
.site-logo img,
.site-logo .custom-logo {
    height: 48px;
    width: auto;
    max-width: 200px;
    filter: drop-shadow(0 2px 8px rgba(0,0,0,.5));
    transition: height .3s;
}
.site-logo .custom-logo-link { display: flex; align-items: center; }
#site-header.scrolled .site-logo img,
#site-header.scrolled .site-logo .custom-logo,
#site-header.solid .site-logo img,
#site-header.solid .site-logo .custom-logo { height: 36px; }

/* Nav toggle */
.nav-toggle {
    display: none; background: none; border: 1px solid rgba(255,255,255,.35);
    color: #fff; width: 40px; height: 36px; cursor: pointer;
    align-items: center; justify-content: center; flex-direction: column; gap: 5px;
    padding: 6px 8px;
}
.nav-toggle span {
    display: block; width: 22px; height: 2px;
    background: #fff; transition: all .3s;
}
.nav-toggle.open span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }

/* Main nav */
.main-nav { display: flex; align-items: stretch; flex: 1; justify-content: center; }

/* Only the top-level ul is horizontal flex; sub-menus stay block */
.main-nav > ul { display: flex; align-items: stretch; gap: 0; }
.main-nav > ul > li { position: relative; display: flex; align-items: stretch; }

.main-nav a {
    display: flex; align-items: center;
    font-weight: 700; font-size: .76rem; letter-spacing: .12em;
    text-transform: uppercase; color: rgba(255,255,255,.88);
    padding: 8px 14px; transition: color .3s; position: relative;
    white-space: nowrap; text-decoration: none;
}
.main-nav > ul > li > a::after {
    content: ''; position: absolute; bottom: 2px; left: 14px; right: 14px;
    height: 1px; background: var(--green);
    transform: scaleX(0); transition: transform .3s;
}
.main-nav > ul > li:hover > a::after,
.main-nav > ul > li.current-menu-item > a::after { transform: scaleX(1); }
.main-nav > ul > li:hover > a,
.main-nav > ul > li.current-menu-item > a { color: #fff; }

/* Dropdown */
.main-nav .sub-menu {
    position: absolute; top: 100%; left: 0; min-width: 210px;
    background: rgba(57,54,57,.97); border-top: 2px solid var(--green);
    border-radius: 0 0 6px 6px; padding: 8px 0;
    box-shadow: 0 12px 40px rgba(0,0,0,.4);
    opacity: 0; visibility: hidden; transform: translateY(4px);
    transition: all .25s; margin-top: 0;
}
/* All levels — keeps sub-sub-menus working */
.main-nav li:hover > .sub-menu { opacity: 1; visibility: visible; transform: none; }

.main-nav .sub-menu a {
    font-size: .74rem; letter-spacing: .08em; padding: 7px 20px;
    color: rgba(255,255,255,.75);
}
.main-nav .sub-menu a:hover { color: #fff; padding-left: 28px; background: rgba(3,132,92,.18); }
.main-nav .sub-menu a::after { display: none; }

/* Sub-sub-menu */
.main-nav .sub-menu .sub-menu {
    top: 0; left: 100%; border-top: 2px solid var(--green); border-radius: 0 0 6px 6px;
}
.main-nav .sub-menu li { position: relative; }
.main-nav .sub-menu li > a.has-children::after {
    content: '\203A'; font-size: 1rem; float: right; margin-top: -1px; display: block;
}

/* Nav actions */
.nav-actions { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.nav-social a {
    color: rgba(255,255,255,.7); font-size: 1rem; transition: color .3s;
}
.nav-social a:hover { color: var(--green); }
.nav-social { display: flex; gap: 10px; }

.btn-sklep {
    background: var(--green); color: #fff !important; border-radius: 0;
    padding: 8px 18px; font-size: .73rem; letter-spacing: .1em;
    text-transform: uppercase; font-weight: 700; transition: background .3s;
    clip-path: polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);
    white-space: nowrap;
}
.btn-sklep:hover { background: var(--green-light); color: #fff; }

/* =========================================================
   HERO SLIDER (strona główna)
========================================================= */
.hero-slider {
    position: relative; height: 100vh; min-height: 600px; overflow: hidden;
}

.hero-slide {
    position: absolute; inset: 0; opacity: 0; transition: opacity 1s ease;
}
.hero-slide.active { opacity: 1; }

.hero-slide-bg {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
    transform: scale(1.05);
    transition: transform 8s ease-out;
}
.hero-slide.active .hero-slide-bg { transform: scale(1); }

/* dark overlay */
.hero-slide-bg::before {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(57,54,57,.85) 0%, rgba(57,54,57,.3) 45%, rgba(3,132,92,.08) 100%);
    z-index: 1;
}
/* grain */
.hero-slide-bg::after {
    content: ''; position: absolute; inset: 0; z-index: 2;
    opacity: .45; mix-blend-mode: multiply; pointer-events: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.88' numOctaves='4'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.18'/%3E%3C/svg%3E");
}

.hero-content {
    position: absolute; bottom: 10%; left: 0; right: 0; z-index: 10;
}
.hero-category {
    display: inline-block; background: var(--green); color: #fff;
    font-size: .65rem; letter-spacing: .18em; text-transform: uppercase;
    padding: 5px 14px; margin-bottom: 16px; font-weight: 700;
}
.hero-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.9rem,4.5vw,4rem); font-weight: 900;
    color: #fff; line-height: 1.1;
    text-shadow: 0 4px 30px rgba(0,0,0,.5);
    max-width: 820px; margin-bottom: 20px;
}
.hero-title em { font-style: italic; color: var(--gold-light); }
.hero-meta { color: rgba(255,255,255,.6); font-size: .76rem; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 24px; }
.hero-meta i { color: var(--green); margin-right: 4px; }
.hero-meta span { margin-right: 20px; }

.hero-read-btn {
    display: inline-block; border: 1px solid rgba(255,255,255,.5);
    color: #fff; padding: 12px 36px; font-size: .73rem; letter-spacing: .14em;
    text-transform: uppercase; font-weight: 700; transition: all .3s;
    backdrop-filter: blur(4px); background: rgba(255,255,255,.05);
}
.hero-read-btn:hover { background: var(--green); border-color: var(--green); color: #fff; }

/* Arrows */
.hero-arrow {
    position: absolute; top: 50%; transform: translateY(-50%); z-index: 20;
    background: rgba(57,54,57,.5); border: 1px solid rgba(255,255,255,.2);
    color: #fff; width: 52px; height: 52px; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: all .3s; backdrop-filter: blur(4px);
}
.hero-arrow:hover { background: var(--green); border-color: var(--green); }
.hero-prev { left: 30px; }
.hero-next { right: 30px; }

/* Dots */
.hero-dots { position: absolute; bottom: 4%; left: 50%; transform: translateX(-50%); z-index: 20; display: flex; gap: 8px; }
.hero-dot { width: 28px; height: 2px; background: rgba(255,255,255,.35); cursor: pointer; transition: all .3s; }
.hero-dot.active { background: var(--green); width: 44px; }

/* Scroll hint */
.scroll-hint {
    position: absolute; bottom: 28px; right: 40px; z-index: 20;
    writing-mode: vertical-rl; color: rgba(255,255,255,.4);
    font-size: .62rem; letter-spacing: .2em; text-transform: uppercase;
    display: flex; align-items: center; gap: 10px;
}
.scroll-hint::after { content: ''; width: 1px; height: 50px; background: rgba(255,255,255,.3); }

/* =========================================================
   SECTION UTILITIES
========================================================= */
.section-label {
    display: inline-block; font-size: .67rem; letter-spacing: .25em;
    text-transform: uppercase; color: var(--green); font-weight: 700;
    margin-bottom: 10px; position: relative; padding-left: 28px;
}
.section-label::before {
    content: ''; position: absolute; left: 0; top: 50%;
    width: 20px; height: 1px; background: var(--green);
}
.section-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.7rem,2.8vw,2.7rem); font-weight: 900;
    color: var(--dark); line-height: 1.15;
}
.section-title em { font-style: italic; color: var(--green); }
.green-divider { width: 48px; height: 3px; background: var(--green); margin: 16px 0 24px; }

.btn-green {
    display: inline-block; background: var(--green); color: #fff;
    border: none; font-size: .73rem; letter-spacing: .12em;
    text-transform: uppercase; font-weight: 700; padding: 13px 34px;
    border-radius: 0; transition: background .3s; cursor: pointer;
}
.btn-green:hover { background: var(--green-light); color: #fff; }

.btn-outline-dark {
    display: inline-block; border: 1px solid var(--dark); color: var(--dark);
    background: transparent; font-size: .73rem; letter-spacing: .12em;
    text-transform: uppercase; font-weight: 700; padding: 13px 34px;
    border-radius: 0; transition: all .3s;
}
.btn-outline-dark:hover { background: var(--dark); color: #fff; }

/* =========================================================
   ABOUT SECTION
========================================================= */
.about-section {
    padding: 100px 0; background: var(--warm-white); position: relative; overflow: hidden;
}
.about-section::before {
    content: 'TRAVEL'; position: absolute; right: -2%; top: 50%; transform: translateY(-50%);
    font-family: 'Playfair Display', serif; font-size: 14vw; font-weight: 900;
    color: rgba(57,54,57,.03); pointer-events: none; white-space: nowrap;
}
.about-text {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem; line-height: 1.85; color: #4a4848; font-weight: 300;
}
.about-text strong { color: var(--green); font-weight: 600; }
.about-stats { display: flex; gap: 40px; margin-top: 32px; flex-wrap: wrap; }
.about-stat-num {
    font-family: 'Playfair Display', serif; font-size: 2.3rem; font-weight: 900;
    color: var(--green); line-height: 1;
}
.about-stat-label { font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; color: #888; margin-top: 4px; }
.about-signature { font-family: 'Playfair Display', serif; font-style: italic; font-size: 1.9rem; color: var(--dark); margin-top: 18px; }

/* Jagged photo */
.jagged-photo-wrap { position: relative; display: inline-block; width: 100%; max-width: 480px; }
.jagged-photo {
    width: 100%; aspect-ratio: 3/4; object-fit: cover; display: block;
    clip-path: polygon(0% 3%,3% 0%,97% 1%,100% 4%,99% 30%,100% 60%,98% 96%,95% 100%,5% 99%,1% 97%,0% 70%,2% 40%);
    filter: sepia(10%) contrast(1.05); transition: clip-path .6s ease;
}
.jagged-photo:hover { clip-path: polygon(0% 1%,2% 0%,98% 2%,100% 1%,99% 50%,100% 97%,97% 100%,3% 99%,0% 98%,1% 50%); }
.jagged-photo-wrap::before {
    content: ''; position: absolute; inset: -10px;
    border: 2px solid var(--green); z-index: -1;
    clip-path: polygon(0% 3%,3% 0%,97% 1%,100% 4%,99% 30%,100% 60%,98% 96%,95% 100%,5% 99%,1% 97%,0% 70%,2% 40%);
}

/* =========================================================
   ARTICLE CARDS
========================================================= */
.articles-section { padding: 100px 0; background: var(--cream); position: relative; }
.articles-section::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0;
    height: 4px; background: linear-gradient(to right,var(--green),transparent);
}

.article-card {
    background: #fff; overflow: hidden;
    transition: transform .4s, box-shadow .4s; height: 100%;
}
.article-card:hover { transform: translateY(-8px); box-shadow: 0 20px 60px rgba(57,54,57,.15); }

.article-card-img-wrap { overflow: hidden; position: relative; }
.article-card-img {
    width: 100%; height: 220px; object-fit: cover; display: block;
    transition: transform .6s; filter: sepia(8%);
}
.article-card:hover .article-card-img { transform: scale(1.06); }

.article-card.featured .article-card-img { height: 320px; }

.article-cat-badge {
    position: absolute; top: 16px; left: 16px;
    background: var(--green); color: #fff;
    font-size: .62rem; letter-spacing: .15em; text-transform: uppercase;
    padding: 4px 10px; font-weight: 700;
}

.article-card-body { padding: 24px; }
.article-card-title {
    font-family: 'Playfair Display', serif; font-size: 1.15rem; font-weight: 700;
    color: var(--dark); line-height: 1.35; margin-bottom: 10px; transition: color .3s;
}
.article-card.featured .article-card-title { font-size: 1.45rem; }
.article-card:hover .article-card-title { color: var(--green); }
.article-card-excerpt { font-size: .86rem; color: #777; line-height: 1.6; margin-bottom: 16px; }
.article-card-meta {
    font-size: .7rem; color: #aaa; letter-spacing: .08em; text-transform: uppercase;
    display: flex; align-items: center; gap: 14px;
}
.article-card-meta i { color: var(--green); }

/* Horizontal card */
.article-card-h { display: flex; flex-direction: row; }
.article-card-h .article-card-img-wrap { flex: 0 0 160px; }
.article-card-h .article-card-img { width: 100%; height: 100%; min-height: 130px; }

/* =========================================================
   COUNTRIES CAROUSEL
========================================================= */
.countries-section { padding: 100px 0; background: var(--dark); position: relative; overflow: hidden; }
.countries-section .section-title { color: #fff; }

.countries-track { display: flex; gap: 18px; overflow-x: auto; padding-bottom: 16px; scrollbar-width: none; scroll-snap-type: x mandatory; }
.countries-track::-webkit-scrollbar { display: none; }

.country-card {
    flex: 0 0 200px; scroll-snap-align: start;
    background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08);
    text-align: center; padding: 28px 20px; cursor: pointer;
    transition: all .35s; text-decoration: none; position: relative; overflow: hidden;
}
.country-card::before {
    content: ''; position: absolute; bottom: 0; left: 0; right: 0;
    height: 3px; background: var(--green); transform: scaleX(0); transition: transform .35s;
}
.country-card:hover { background: rgba(3,132,92,.12); border-color: var(--green); transform: translateY(-4px); }
.country-card:hover::before { transform: scaleX(1); }
.country-flag { font-size: 3.2rem; display: block; margin-bottom: 12px; filter: drop-shadow(0 4px 12px rgba(0,0,0,.3)); }
.country-name { font-family: 'Playfair Display', serif; font-size: 1rem; font-weight: 700; color: #fff; display: block; margin-bottom: 5px; }
.country-count { font-size: .67rem; color: rgba(255,255,255,.4); letter-spacing: .1em; text-transform: uppercase; }

.carousel-controls { display: flex; gap: 10px; margin-top: 24px; }
.carousel-btn {
    width: 44px; height: 44px; border: 1px solid rgba(255,255,255,.2);
    background: transparent; color: #fff; display: flex; align-items: center;
    justify-content: center; cursor: pointer; transition: all .3s;
}
.carousel-btn:hover { background: var(--green); border-color: var(--green); }

/* =========================================================
   PRE-TRAVEL SECTION
========================================================= */
.pretavel-section { padding: 100px 0; background: var(--warm-white); }

.pretavel-card {
    background: #fff; border-left: 3px solid var(--green);
    overflow: hidden; transition: all .35s; height: 100%;
}
.pretavel-card:hover { box-shadow: 0 12px 40px rgba(57,54,57,.12); transform: translateY(-4px); }
.pretavel-card-img-wrap { overflow: hidden; }
.pretavel-card-img {
    width: 100%; height: 180px; object-fit: cover; display: block;
    filter: sepia(8%) saturate(.9); transition: filter .4s, transform .5s;
}
.pretavel-card:hover .pretavel-card-img { filter: sepia(0%) saturate(1); transform: scale(1.04); }
.pretavel-card-body { padding: 20px; }
.pretavel-icon {
    width: 40px; height: 40px; background: var(--green); color: #fff;
    display: flex; align-items: center; justify-content: center; font-size: 1rem; margin-bottom: 12px;
}
.pretavel-title { font-family: 'Playfair Display', serif; font-size: 1rem; font-weight: 700; color: var(--dark); margin-bottom: 8px; line-height: 1.3; }
.pretavel-excerpt { font-size: .82rem; color: #888; line-height: 1.6; }
.pretavel-read {
    display: inline-block; margin-top: 12px; font-size: .7rem; letter-spacing: .1em;
    text-transform: uppercase; color: var(--green); font-weight: 700;
    border-bottom: 1px solid transparent; transition: border-color .3s;
}
.pretavel-read:hover { border-color: var(--green); color: var(--green); }

/* =========================================================
   POST HERO
========================================================= */
.post-hero {
    position: relative; height: 92vh; min-height: 560px;
    display: flex; align-items: flex-end; overflow: hidden;
}
.post-hero-img {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
    transform: scale(1.05); animation: heroZoom 12s ease-out forwards;
}
@keyframes heroZoom { from { transform: scale(1.08); } to { transform: scale(1); } }

/* grain */
.post-hero::before {
    content: ''; position: absolute; inset: 0; z-index: 2; pointer-events: none; opacity: .45;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.88' numOctaves='4'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.18'/%3E%3C/svg%3E");
    mix-blend-mode: multiply;
}
/* gradient overlay */
.post-hero::after {
    content: ''; position: absolute; inset: 0; z-index: 1;
    background: linear-gradient(to top, rgba(30,28,30,.92) 0%, rgba(30,28,30,.45) 50%, rgba(3,132,92,.07) 100%);
}

.post-hero-content { position: relative; z-index: 10; width: 100%; padding-bottom: 70px; }

.post-breadcrumb {
    display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 20px;
}
.post-breadcrumb a, .post-breadcrumb span {
    color: rgba(255,255,255,.55); font-size: .7rem; letter-spacing: .12em;
    text-transform: uppercase; transition: color .3s;
}
.post-breadcrumb a:hover { color: var(--green-light); }
.post-breadcrumb .sep { color: rgba(255,255,255,.25); font-size: .6rem; }

.post-cats { display: flex; gap: 8px; margin-bottom: 18px; flex-wrap: wrap; }
.post-cat {
    display: inline-block; background: var(--green); color: #fff;
    font-size: .63rem; letter-spacing: .18em; text-transform: uppercase;
    padding: 5px 12px; font-weight: 700; transition: background .3s;
}
.post-cat:hover { background: var(--green-light); color: #fff; }
.post-cat.secondary { background: rgba(255,255,255,.12); backdrop-filter: blur(4px); }
.post-cat.secondary:hover { background: rgba(255,255,255,.22); }

.post-hero-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.9rem,4.5vw,3.8rem); font-weight: 900;
    color: #fff; line-height: 1.1; text-shadow: 0 4px 30px rgba(0,0,0,.5);
    max-width: 860px; margin-bottom: 24px;
}
.post-hero-title em { font-style: italic; color: var(--gold-light); }

.post-hero-meta {
    display: flex; gap: 22px; align-items: center; flex-wrap: wrap;
}
.post-hero-meta-item {
    color: rgba(255,255,255,.6); font-size: .73rem;
    letter-spacing: .1em; text-transform: uppercase;
    display: flex; align-items: center; gap: 6px;
}
.post-hero-meta-item i { color: var(--green); }

.post-author-mini {
    display: flex; align-items: center; gap: 10px;
    padding-left: 20px; border-left: 1px solid rgba(255,255,255,.15);
}
.post-author-mini img { width: 34px; height: 34px; border-radius: 50%; border: 2px solid var(--green); object-fit: cover; }
.post-author-mini .author-name { color: #fff; font-size: .82rem; font-weight: 700; display: block; }
.post-author-mini .author-role { color: rgba(255,255,255,.5); font-size: .7rem; }

/* =========================================================
   POST LAYOUT
========================================================= */
.post-wrapper {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 60px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 70px 24px 100px;
    align-items: start;
}

/* =========================================================
   POST CONTENT TYPOGRAPHY
========================================================= */
.post-content {
    font-family: 'Lato', sans-serif;
    font-size: 1.05rem; line-height: 1.85; color: #3a3838;
}
.post-content p { margin-bottom: 1.6em; }

.post-content h2 {
    font-family: 'Playfair Display', serif;
    font-size: 1.85rem; font-weight: 900; color: var(--dark);
    margin: 2.4em 0 .8em; line-height: 1.2;
    position: relative; padding-left: 22px;
}
.post-content h2::before {
    content: ''; position: absolute; left: 0; top: 8px; bottom: 8px;
    width: 4px; background: var(--green);
}
.post-content h3 {
    font-family: 'Playfair Display', serif;
    font-size: 1.42rem; font-weight: 700; color: var(--dark);
    margin: 2em 0 .7em; font-style: italic;
}
.post-content h4 {
    font-family: 'Lato', sans-serif; font-size: 1rem; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase; color: var(--dark);
    margin: 1.8em 0 .6em;
}
.post-content strong { color: var(--dark); font-weight: 600; }
.post-content em { color: var(--green-dark); font-style: italic; }
.post-content a { color: var(--green); border-bottom: 1px solid rgba(3,132,92,.35); transition: border-color .3s; }
.post-content a:hover { border-color: var(--green); color: var(--green-dark); }

/* Drop cap */
.has-drop-cap::first-letter {
    font-family: 'Playfair Display', serif; font-size: 5rem; font-weight: 900;
    float: left; line-height: .75; margin: 10px 14px -4px 0;
    color: var(--green); text-shadow: 2px 3px 0 rgba(3,132,92,.15);
}

/* Blockquote */
.post-content blockquote {
    position: relative; border: none;
    padding: 28px 32px 28px 54px; margin: 2.5em 0;
    background: var(--cream); font-family: 'Playfair Display', serif;
    font-style: italic; font-size: 1.3rem; color: var(--dark); line-height: 1.6;
}
.post-content blockquote::before {
    content: '\201C'; position: absolute; left: 14px; top: 8px;
    font-size: 4.5rem; line-height: 1; color: var(--green);
    font-family: 'Playfair Display', serif; opacity: .6;
}
.post-content blockquote::after {
    content: ''; position: absolute; left: 0; top: 0; bottom: 0;
    width: 4px; background: var(--green);
}
.post-content blockquote cite {
    display: block; margin-top: 12px; font-size: .76rem;
    letter-spacing: .1em; text-transform: uppercase; color: var(--text-light);
    font-style: normal; font-family: 'Lato', sans-serif;
}

/* Lists */
.post-content ul, .post-content ol { padding-left: 1.5em; margin-bottom: 1.6em; }
.post-content ul { list-style: none; padding-left: 0; }
.post-content ul li { padding-left: 1.4em; position: relative; margin-bottom: .5em; }
.post-content ul li::before {
    content: ''; position: absolute; left: 0; top: .7em;
    width: 8px; height: 2px; background: var(--green);
}
.post-content ol li { margin-bottom: .5em; }

/* Images in content */
.post-content figure { margin: 2.5em 0; }
.post-content figure img { width: 100%; filter: sepia(6%) contrast(1.04); }
.post-content figcaption {
    font-family: 'Lato', sans-serif; font-size: .76rem; color: var(--text-light);
    text-align: center; margin-top: 8px; font-style: italic;
}
.wp-block-image.alignwide, .wp-block-image.alignfull,
.post-content .alignwide, .post-content .alignfull {
    width: 100vw; position: relative; left: 50%; transform: translateX(-50%); margin: 3em 0;
}
.post-content .alignwide img, .post-content .alignfull img { width: 100%; height: 480px; object-fit: cover; }

/* Gallery 2-col */
.post-img-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 2.5em 0; }
.post-img-grid img { width: 100%; aspect-ratio: 4/3; object-fit: cover; filter: sepia(6%) contrast(1.04); }

/* Tags */
.post-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 48px; padding-top: 28px; border-top: 1px solid var(--border); }
.post-tag {
    background: var(--cream); color: var(--text-light); font-size: .68rem;
    letter-spacing: .1em; text-transform: uppercase; padding: 6px 14px;
    font-weight: 700; transition: all .3s; border: 1px solid var(--border);
}
.post-tag:hover { background: var(--green); color: #fff; border-color: var(--green); }

/* =========================================================
   CONTENT BOXES
========================================================= */

/* Tip / Ważna info */
.box-tip {
    background: linear-gradient(135deg,#f0faf6,#e6f7f0);
    border: 1px solid rgba(3,132,92,.2); border-left: 5px solid var(--green);
    padding: 26px 26px 26px 24px; margin: 2.5em 0;
    font-family: 'Lato', sans-serif; font-size: .93rem;
}
.box-label {
    display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
    font-size: .67rem; letter-spacing: .18em; text-transform: uppercase; font-weight: 700;
}
.box-label .icon-circle {
    width: 30px; height: 30px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center; font-size: .78rem; flex-shrink: 0; color: #fff;
}
.box-tip .box-label { color: var(--green); }
.box-tip .icon-circle { background: var(--green); }
.box-tip p, .box-tip ul li { color: var(--text); line-height: 1.7; margin: 0; }
.box-tip ul { margin: 8px 0 0 18px; list-style: disc; padding: 0; }
.box-tip ul li { margin-bottom: 4px; }

/* Warning */
.box-warning {
    background: linear-gradient(135deg,#fffbf0,#fff8e6);
    border: 1px solid rgba(201,168,76,.3); border-left: 5px solid var(--gold);
    padding: 26px 26px 26px 24px; margin: 2.5em 0;
    font-family: 'Lato', sans-serif; font-size: .93rem;
}
.box-warning .box-label { color: #a07c1a; }
.box-warning .icon-circle { background: var(--gold); }
.box-warning p { color: var(--text); line-height: 1.7; margin: 0; }

/* Hotel / Nocleg */
.box-hotel {
    background: var(--dark); margin: 2.5em 0; overflow: hidden;
    display: grid; grid-template-columns: auto 1fr;
    position: relative; font-family: 'Lato', sans-serif;
}
.box-hotel::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(to right,var(--green),var(--gold));
}
.box-aff-icon {
    display: flex; align-items: center; justify-content: center;
    padding: 28px 22px; font-size: 1.9rem; color: #fff;
    flex-direction: column; gap: 5px;
}
.box-aff-icon span { font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.65); font-weight: 700; }
.box-hotel .box-aff-icon { background: var(--green); }
.box-aff-body { padding: 20px 22px; }
.box-aff-title { font-family: 'Playfair Display', serif; font-size: 1.08rem; font-weight: 700; color: #fff; margin-bottom: 5px; }
.box-aff-desc { font-size: .86rem; color: rgba(255,255,255,.58); line-height: 1.6; margin-bottom: 14px; }
.box-aff-tags { display: flex; gap: 7px; flex-wrap: wrap; margin-bottom: 14px; }
.box-aff-tag { border: 1px solid rgba(255,255,255,.14); color: rgba(255,255,255,.48); font-size: .65rem; padding: 3px 10px; letter-spacing: .1em; text-transform: uppercase; }
a.box-aff-btn {
    display: inline-block; color: #fff; text-decoration: none;
    font-size: .72rem; letter-spacing: .12em; text-transform: uppercase;
    font-weight: 700; padding: 10px 20px; transition: background .3s;
    border: none; cursor: pointer;
}
.box-hotel .box-aff-btn { background: var(--green); }
.box-hotel .box-aff-btn:hover { background: var(--green-light); color: #fff; }
.box-aff-disclaimer { font-size: .6rem; color: rgba(255,255,255,.22); margin-top: 8px; font-style: italic; }

/* Car rental */
.box-car {
    background: linear-gradient(135deg,#1a1a2e,#16213e); margin: 2.5em 0;
    overflow: hidden; display: grid; grid-template-columns: auto 1fr;
    position: relative; font-family: 'Lato', sans-serif;
}
.box-car::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(to right,#4a90d9,var(--green));
}
.box-car .box-aff-icon { background: #4a90d9; }
.box-car .box-aff-btn { background: #4a90d9; }
.box-car .box-aff-btn:hover { background: #5aa3f0; color: #fff; }
.box-car-price {
    display: inline-block; background: rgba(74,144,217,.15);
    border: 1px solid rgba(74,144,217,.3); color: #7ab8f5;
    font-size: .78rem; font-weight: 700; padding: 4px 12px;
    letter-spacing: .08em; margin-bottom: 12px;
}

/* Insurance */
.box-insurance {
    background: linear-gradient(135deg,#1c1a14,#252018); margin: 2.5em 0;
    overflow: hidden; display: grid; grid-template-columns: auto 1fr;
    position: relative; font-family: 'Lato', sans-serif;
}
.box-insurance::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(to right,var(--gold),#e8a020);
}
.box-insurance .box-aff-icon { background: var(--gold); }
.box-insurance .box-aff-btn { background: var(--gold); }
.box-insurance .box-aff-btn:hover { background: #d4a820; color: #fff; }
.box-insurance-features { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.box-insurance-feature {
    display: flex; align-items: center; gap: 5px;
    font-size: .76rem; color: rgba(255,255,255,.68);
}
.box-insurance-feature i { color: var(--gold); font-size: .68rem; }

/* Quick facts */
.box-facts {
    background: var(--cream); border: 1px solid var(--border);
    border-top: 5px solid var(--dark); padding: 26px 28px; margin: 2.5em 0;
    font-family: 'Lato', sans-serif;
}
.box-facts-title {
    font-family: 'Playfair Display', serif; font-size: 1.08rem; font-weight: 900;
    color: var(--dark); margin-bottom: 18px; display: flex; align-items: center; gap: 8px;
}
.box-facts-title i { color: var(--green); }
.facts-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px 28px; }
.fact-label { font-size: .65rem; letter-spacing: .15em; text-transform: uppercase; color: var(--text-light); font-weight: 700; margin-bottom: 2px; }
.fact-value { font-size: .88rem; color: var(--dark); line-height: 1.4; }
.fact-value strong { color: var(--green); font-weight: 700; }

/* Map box */
.box-map { background: #fff; border: 1px solid var(--border); padding: 24px 26px; margin: 2.5em 0; font-family: 'Lato', sans-serif; }
.box-map-label { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; font-size: .67rem; letter-spacing: .18em; text-transform: uppercase; font-weight: 700; color: var(--dark); }
.box-map-label i { color: var(--green); font-size: .95rem; }
.box-map iframe, .box-map .map-placeholder { width: 100%; height: 240px; border: 1px solid var(--border); display: block; }
.box-map-links { display: flex; gap: 12px; margin-top: 12px; flex-wrap: wrap; }
.box-map-link { display: inline-flex; align-items: center; gap: 5px; font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 700; color: var(--green); border-bottom: 1px solid rgba(3,132,92,.3); transition: border-color .3s; }
.box-map-link:hover { border-color: var(--green); color: var(--green); }

/* Rating */
.box-rating { background: #fff; border: 1px solid var(--border); padding: 24px 26px; margin: 2.5em 0; font-family: 'Lato', sans-serif; }
.box-rating-title { font-family: 'Playfair Display', serif; font-size: .98rem; font-weight: 700; color: var(--dark); margin-bottom: 16px; }
.rating-row { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.rating-label { font-size: .74rem; color: var(--text-light); width: 150px; flex-shrink: 0; }
.rating-bar-wrap { flex: 1; background: var(--cream); height: 6px; }
.rating-bar { height: 100%; background: var(--green); }
.rating-val { font-size: .8rem; font-weight: 700; color: var(--dark); width: 28px; text-align: right; }
.rating-overall { text-align: center; padding: 14px 0 0; border-top: 1px solid var(--border); margin-top: 14px; }
.rating-num { font-family: 'Playfair Display', serif; font-size: 3.2rem; font-weight: 900; color: var(--green); line-height: 1; }
.rating-stars { color: var(--gold); font-size: 1rem; letter-spacing: 2px; margin: 5px 0 3px; }
.rating-label-overall { font-size: .67rem; text-transform: uppercase; letter-spacing: .12em; color: var(--text-light); }

/* =========================================================
   AUTHOR BOX
========================================================= */
.author-box {
    background: var(--cream); border: 1px solid var(--border); padding: 32px;
    margin-top: 48px; display: flex; gap: 24px; align-items: flex-start;
    font-family: 'Lato', sans-serif;
}
.author-box img { width: 88px; height: 88px; border-radius: 50%; object-fit: cover; border: 3px solid var(--green); flex-shrink: 0; }
.author-box-name { font-family: 'Playfair Display', serif; font-size: 1.2rem; font-weight: 700; color: var(--dark); margin-bottom: 3px; }
.author-box-role { font-size: .67rem; letter-spacing: .15em; text-transform: uppercase; color: var(--green); font-weight: 700; margin-bottom: 10px; }
.author-box-bio { font-size: .86rem; color: var(--text-light); line-height: 1.7; }
.author-box-social { margin-top: 10px; display: flex; gap: 7px; }
.author-box-social a {
    width: 32px; height: 32px; border: 1px solid var(--border);
    display: flex; align-items: center; justify-content: center;
    color: var(--text-light); font-size: .78rem; transition: all .3s;
}
.author-box-social a:hover { background: var(--green); border-color: var(--green); color: #fff; }

/* =========================================================
   COMMENTS
========================================================= */
.comments-area { margin-top: 56px; padding-top: 48px; border-top: 1px solid var(--border); font-family: 'Lato', sans-serif; }
.comments-title { font-family: 'Playfair Display', serif; font-size: 1.45rem; font-weight: 900; color: var(--dark); margin-bottom: 28px; }

.comment-list { padding: 0; list-style: none; }
.comment { display: flex; gap: 16px; margin-bottom: 26px; padding-bottom: 26px; border-bottom: 1px solid var(--cream); align-items: flex-start; }
.comment-avatar { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 2px solid var(--border); display: block; }
.comment-avatar-letter {
    width: 46px; height: 46px; border-radius: 50%; background: var(--cream);
    border: 2px solid var(--border); display: flex; align-items: center; justify-content: center;
    font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 900;
    color: var(--green); flex-shrink: 0;
}
.comment-author-name { font-weight: 700; color: var(--dark); font-size: .86rem; }
.comment-author-name.by-author { color: var(--green); }
.comment-date { font-size: .7rem; color: var(--text-light); letter-spacing: .07em; }
.comment-text { font-size: .86rem; color: var(--text-light); line-height: 1.7; margin-top: 5px; }
.comment-reply-link { display: inline-flex; align-items: center; gap: 4px; font-size: .68rem; color: var(--green); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; margin-top: 6px; }
.comment-reply-link:hover { color: var(--green-dark); }

.comment-respond { margin-top: 40px; }
.comment-respond h3 { font-family: 'Playfair Display', serif; font-size: 1.2rem; font-weight: 700; color: var(--dark); margin-bottom: 20px; }
.comment-form p { margin-bottom: 14px; }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
    width: 100%; background: #fff; border: 1px solid var(--border);
    color: var(--text); padding: 12px 16px; font-size: .86rem;
    font-family: 'Lato', sans-serif; outline: none; transition: border-color .3s;
    border-radius: 0;
}
.comment-form input:focus, .comment-form textarea:focus { border-color: var(--green); }
.comment-form textarea { min-height: 130px; resize: vertical; }
.comment-form .submit {
    background: var(--green); color: #fff; border: none;
    padding: 13px 34px; font-size: .73rem; letter-spacing: .12em;
    text-transform: uppercase; font-weight: 700; cursor: pointer;
    font-family: 'Lato', sans-serif; transition: background .3s; border-radius: 0;
}
.comment-form .submit:hover { background: var(--green-light); }

/* =========================================================
   SIDEBAR
========================================================= */
.post-sidebar { font-family: 'Lato', sans-serif; }
.sidebar-sticky { position: sticky; top: 90px; display: flex; flex-direction: column; gap: 26px; }

.sidebar-widget { background: #fff; border: 1px solid var(--border); padding: 22px; }
.sidebar-widget-title {
    font-family: 'Playfair Display', serif; font-size: .93rem; font-weight: 900;
    color: var(--dark); margin-bottom: 16px; padding-bottom: 10px;
    border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 7px;
}
.sidebar-widget-title i { color: var(--green); font-size: .88rem; }

/* TOC */
.toc-list { padding: 0; }
.toc-list li { margin-bottom: 4px; }
.toc-list a {
    font-size: .81rem; color: var(--text-light); display: flex; align-items: flex-start;
    gap: 8px; transition: color .3s; line-height: 1.4; padding: 4px 0;
    border-bottom: 1px solid var(--cream);
}
.toc-list a:hover, .toc-list a.active { color: var(--green); }
.toc-list a.active { font-weight: 700; }
.toc-list a::before { content: ''; flex-shrink: 0; width: 14px; height: 1px; background: var(--green); margin-top: 9px; }

/* Meta */
.sidebar-meta-item { display: flex; align-items: center; gap: 10px; padding: 7px 0; border-bottom: 1px solid var(--cream); font-size: .82rem; }
.sidebar-meta-item:last-child { border-bottom: none; }
.sidebar-meta-item i { color: var(--green); width: 15px; text-align: center; }
.sidebar-meta-item span { color: var(--text-light); }
.sidebar-meta-item strong { color: var(--dark); margin-left: auto; }

/* Newsletter widget */
.sidebar-newsletter { background: var(--dark); border: none; }
.sidebar-newsletter .sidebar-widget-title { color: #fff; border-color: rgba(255,255,255,.1); }
.sidebar-newsletter p { font-size: .82rem; color: rgba(255,255,255,.5); line-height: 1.6; margin-bottom: 14px; }
.sidebar-input {
    width: 100%; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12);
    color: #fff; padding: 11px 14px; font-size: .82rem; font-family: 'Lato', sans-serif;
    margin-bottom: 8px; outline: none; transition: border-color .3s; border-radius: 0;
}
.sidebar-input::placeholder { color: rgba(255,255,255,.3); }
.sidebar-input:focus { border-color: var(--green); }
.sidebar-submit {
    width: 100%; background: var(--green); color: #fff; border: none;
    padding: 11px; font-size: .73rem; letter-spacing: .12em; text-transform: uppercase;
    font-weight: 700; cursor: pointer; font-family: 'Lato', sans-serif; transition: background .3s; border-radius: 0;
}
.sidebar-submit:hover { background: var(--green-light); }

/* Share */
.share-buttons { display: flex; flex-direction: column; gap: 7px; }
.share-btn {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 14px; font-size: .76rem; font-weight: 700; letter-spacing: .07em;
    transition: all .3s; border: 1px solid var(--border); text-decoration: none;
}
.share-btn i { width: 14px; text-align: center; }
.share-btn.fb { color: #1877f2; border-color: rgba(24,119,242,.2); }
.share-btn.fb:hover { background: #1877f2; color: #fff; border-color: #1877f2; }
.share-btn.ig { color: #e1306c; border-color: rgba(225,48,108,.2); }
.share-btn.ig:hover { background: #e1306c; color: #fff; border-color: #e1306c; }
.share-btn.pin { color: #e60023; border-color: rgba(230,0,35,.2); }
.share-btn.pin:hover { background: #e60023; color: #fff; border-color: #e60023; }
.share-btn.copy { color: var(--text-light); }
.share-btn.copy:hover { background: var(--dark); color: #fff; border-color: var(--dark); }

/* Sidebar aff */
.sidebar-aff { background: linear-gradient(135deg,var(--dark),#1a3a2a); border: 1px solid rgba(3,132,92,.2); padding: 22px; text-align: center; }
.sidebar-aff-icon { font-size: 2.2rem; color: var(--green); margin-bottom: 8px; }
.sidebar-aff-title { color: #fff; font-family: 'Playfair Display', serif; font-size: .98rem; font-weight: 700; margin-bottom: 7px; }
.sidebar-aff-desc { font-size: .78rem; color: rgba(255,255,255,.48); line-height: 1.6; margin-bottom: 12px; }
.sidebar-aff-btn {
    display: block; background: var(--green); color: #fff;
    font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 700; padding: 10px;
    transition: background .3s;
}
.sidebar-aff-btn:hover { background: var(--green-light); color: #fff; }

/* Recent posts in sidebar */
.sidebar-posts { display: flex; flex-direction: column; gap: 14px; }
.sidebar-post { display: flex; gap: 12px; align-items: flex-start; }
.sidebar-post-img { width: 70px; height: 70px; object-fit: cover; flex-shrink: 0; filter: sepia(8%); }
.sidebar-post-title { font-family: 'Playfair Display', serif; font-size: .86rem; font-weight: 700; color: var(--dark); line-height: 1.35; margin-bottom: 4px; transition: color .3s; }
.sidebar-post-title:hover { color: var(--green); }
.sidebar-post-date { font-size: .68rem; color: var(--text-light); letter-spacing: .07em; }

/* =========================================================
   RELATED ARTICLES
========================================================= */
.related-section { background: var(--cream); padding: 80px 0; border-top: 1px solid var(--border); }

/* =========================================================
   FOOTER
========================================================= */
#site-footer { background: var(--dark); color: rgba(255,255,255,.65); padding: 70px 0 0; position: relative; }
#site-footer::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(to right,var(--green),transparent 70%); }

.footer-logo { height: 42px; margin-bottom: 18px; }
.footer-desc { font-size: .84rem; line-height: 1.75; color: rgba(255,255,255,.45); max-width: 265px; }
.footer-social { margin-top: 18px; display: flex; gap: 8px; }
.footer-social a { width: 34px; height: 34px; border: 1px solid rgba(255,255,255,.12); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.45); transition: all .3s; }
.footer-social a:hover { background: var(--green); border-color: var(--green); color: #fff; }
.footer-heading { font-family: 'Playfair Display', serif; font-size: .93rem; font-weight: 700; color: #fff; margin-bottom: 18px; padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,.07); }
.footer-nav { list-style: none; padding: 0; }
.footer-nav li { margin-bottom: 7px; }
.footer-nav a { color: rgba(255,255,255,.4); font-size: .8rem; transition: all .3s; display: flex; align-items: center; gap: 6px; text-decoration: none !important; }
.footer-nav a::before { content: '›'; color: var(--green); font-size: 1.1rem; line-height: 1; }
.footer-nav a:hover { color: rgba(255,255,255,.85); padding-left: 4px; }
.footer-bottom { margin-top: 48px; border-top: 1px solid rgba(255,255,255,.06); padding: 18px 0; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px; }
.footer-bottom p { font-size: .72rem; color: rgba(255,255,255,.27); margin: 0; }

/* =========================================================
   PAGINATION
========================================================= */
.posts-navigation, .post-navigation, .pagination {
    margin: 60px 0; font-family: 'Lato', sans-serif;
}
.nav-links { display: flex; justify-content: center; gap: 8px; flex-wrap: wrap; }
.page-numbers {
    display: flex; align-items: center; justify-content: center;
    width: 44px; height: 44px; border: 1px solid var(--border);
    color: var(--text-light); font-size: .82rem; font-weight: 700; transition: all .3s;
}
.page-numbers:hover, .page-numbers.current { background: var(--green); border-color: var(--green); color: #fff; }
.nav-previous a, .nav-next a {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: .73rem; letter-spacing: .1em; text-transform: uppercase;
    font-weight: 700; color: var(--text-light); border: 1px solid var(--border);
    padding: 10px 18px; transition: all .3s;
}
.nav-previous a:hover, .nav-next a:hover { background: var(--green); border-color: var(--green); color: #fff; }

/* =========================================================
   ARCHIVE / BLOG PAGE
========================================================= */
.archive-hero { background: var(--dark); padding: 130px 0 70px; position: relative; overflow: hidden; }
.archive-hero::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: linear-gradient(135deg,rgba(3,132,92,.1),transparent); }
.archive-hero-title { font-family: 'Playfair Display', serif; font-size: clamp(2rem,4vw,3.5rem); font-weight: 900; color: #fff; }
.archive-hero-title em { color: var(--green); font-style: italic; }
.archive-hero-desc { color: rgba(255,255,255,.55); font-size: 1rem; margin-top: 12px; max-width: 560px; line-height: 1.7; }

.blog-grid { padding: 80px 0; }
.blog-grid .posts-loop { display: grid; grid-template-columns: repeat(3,1fr); gap: 30px; }

/* =========================================================
   404 PAGE
========================================================= */
.error-404 { min-height: 70vh; display: flex; align-items: center; padding: 120px 0 80px; }
.error-404-num { font-family: 'Playfair Display', serif; font-size: clamp(6rem,18vw,14rem); font-weight: 900; color: var(--dark); line-height: 1; opacity: .08; }
.error-404-title { font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 700; color: var(--dark); margin-bottom: 16px; }
.error-404-text { color: var(--text-light); font-size: 1rem; line-height: 1.7; margin-bottom: 28px; max-width: 480px; }

/* =========================================================
   SEARCH
========================================================= */
.search-form-wrap { margin: 20px 0; }
.search-form { display: flex; gap: 0; }
.search-field {
    flex: 1; border: 1px solid var(--border); border-right: none;
    padding: 12px 18px; font-size: .9rem; font-family: 'Lato', sans-serif;
    outline: none; transition: border-color .3s; background: #fff;
    color: var(--text); border-radius: 0;
}
.search-field:focus { border-color: var(--green); }
.search-submit {
    background: var(--green); color: #fff; border: none; padding: 12px 20px;
    cursor: pointer; font-size: .9rem; transition: background .3s; border-radius: 0;
}
.search-submit:hover { background: var(--green-light); }

/* =========================================================
   REVEAL ANIMATION
========================================================= */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .65s, transform .65s; }
.reveal.visible { opacity: 1; transform: none; }
.reveal-d1 { transition-delay: .15s; }
.reveal-d2 { transition-delay: .3s; }
.reveal-d3 { transition-delay: .45s; }

/* =========================================================
   RESPONSIVE
========================================================= */
/* Mobile TOC – shown only when sidebar is hidden */
.mobile-toc-section { display: none; padding: 32px 24px 0; max-width: 1200px; margin: 0 auto; }

@media (max-width: 1100px) {
    .post-wrapper { grid-template-columns: 1fr; }
    .post-sidebar { display: none; }
    .mobile-toc-section { display: block; }
}
@media (max-width: 991px) {
    .blog-grid .posts-loop { grid-template-columns: repeat(2,1fr); }
    .about-section { padding: 70px 0; }
    .hero-arrow { display: none; }
}
@media (max-width: 768px) {
    .nav-toggle { display: flex; }
    .main-nav {
        display: none;
        position: fixed; top: 60px; left: 0; /* top i height nadpisywane przez JS */
        width: 100%; box-sizing: border-box;
        background: rgba(57,54,57,.98); flex-direction: column;
        justify-content: flex-start; padding: 30px 20px;
        overflow-y: auto; overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
    }
    .main-nav.open { display: flex; }
    .main-nav > ul { flex-direction: column; width: 100%; gap: 0; }
    .main-nav > ul.mnav-hidden { display: none; }
    .main-nav .sub-menu { display: none; }
    .main-nav a { padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,.07); }
    .main-nav > ul > li > a.has-children::after { content: '›'; font-size: 1.3rem; line-height: 1; float: right; opacity: .5; display: block; margin-top: -1px; }
    .nav-social { display: none; }

    /* Drill-down panel */
    .mobile-nav-panel {
        position: absolute; top: 0; right: 0; bottom: 0; left: 0;
        background: rgba(57,54,57,.98);
        overflow-y: auto; overflow-x: hidden;
        opacity: 0; pointer-events: none;
        transform: translateX(30px);
        transition: opacity .25s ease, transform .25s ease;
    }
    .mobile-nav-panel.mnav-visible {
        opacity: 1; pointer-events: auto; transform: translateX(0);
    }

    .mobile-nav-panel-hdr {
        display: flex; align-items: center; gap: 14px;
        padding: 18px 20px 14px;
        border-bottom: 2px solid var(--green);
        position: sticky; top: 0;
        background: rgba(57,54,57,.98); z-index: 1;
    }
    .mobile-nav-back {
        background: none; border: none; color: var(--green);
        cursor: pointer; display: flex; align-items: center; gap: 7px;
        font: 700 .75rem/1 'Lato', sans-serif;
        letter-spacing: .08em; text-transform: uppercase; padding: 4px 0;
    }
    .mobile-nav-panel-ttl {
        color: rgba(255,255,255,.8); font-weight: 700;
        font-size: .85rem; letter-spacing: .1em; text-transform: uppercase;
    }
    .mobile-nav-panel > ul {
        list-style: none; margin: 0; padding: 0 20px 30px; width: 100%;
    }
    .mobile-nav-panel > ul > li > a {
        display: flex; align-items: center; justify-content: space-between;
        padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,.07);
        color: rgba(255,255,255,.88); text-decoration: none;
        font-weight: 700; font-size: .78rem; letter-spacing: .1em; text-transform: uppercase;
    }
    .mobile-nav-panel > ul > li > a:hover { color: #fff; }
    .mobile-nav-panel > ul > li.menu-item-has-children > a::after {
        content: '›'; font-size: 1.4rem; line-height: 1; opacity: .5; flex-shrink: 0;
    }
    .mobile-nav-panel .sub-menu { display: none !important; }

    .blog-grid .posts-loop { grid-template-columns: 1fr; }
    .article-card-h { flex-direction: column; }
    .article-card-h .article-card-img-wrap { flex: 0 0 auto; }
    .about-stats { gap: 20px; }
    .post-hero { height: 75vh; }
    .hero-slider { height: 75vh; }
    .post-hero-title { font-size: 1.7rem; }
    .author-box { flex-direction: column; gap: 16px; }
    .facts-grid { grid-template-columns: 1fr; }
    .scroll-hint { display: none; }
    .box-hotel, .box-car, .box-insurance { grid-template-columns: 1fr; }
    .box-aff-icon { padding: 20px; flex-direction: row; justify-content: flex-start; }

    /* Nowe komponenty – mobile */
    .weather-grid { grid-template-columns: repeat(4,1fr); }
    .checklist-cols { grid-template-columns: 1fr; }
    .transport-row { grid-template-columns: 42px 1fr auto; }
    .transport-time { display: none; }
    .box-attraction-grid { grid-template-columns: 1fr; }
    .box-attraction-item { border-right: none; }
    .box-visa-grid { grid-template-columns: 1fr; }
    .box-visa-item { border-right: none; border-bottom: 1px solid var(--border); }
    .box-visa-item:last-child { border-bottom: none; }
    .hotels-grid { grid-template-columns: 1fr; }
    .box-currency-header { grid-template-columns: 1fr; }
    .timeline-item { grid-template-columns: 44px 16px 1fr; }
    .budget-row { flex-wrap: wrap; }
}
@media (max-width: 480px) {
    .hero-dots { display: none; }
    .post-hero-meta { gap: 12px; }
    .post-author-mini { display: none; }
}

/* =========================================================
   CONTENT BOXES – NOWE KOMPONENTY (v2.0)
   N1 Budżet  N2 Pogoda  N3 Atrakcje  N4 Transport
   N5 Wiza    N6 Pakowanie  N7 Timeline  N8 Kursy walut  N9 Hotele
========================================================= */

/* ── N1: BOX-BUDGET ── */
.box-budget {
    background: var(--warm-white);
    border: 1px solid var(--border);
    padding: 28px 32px 24px;
    margin: 32px 0;
}
.box-budget-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 2px solid var(--green);
    display: flex;
    align-items: center;
    gap: 10px;
}
.budget-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border);
}
.budget-row:last-of-type { border-bottom: none; }
.budget-cat-icon {
    font-size: 1.25rem;
    width: 32px;
    text-align: center;
    flex-shrink: 0;
}
.budget-cat-name {
    flex: 1;
    font-size: .9rem;
    font-weight: 700;
    color: var(--dark);
}
.budget-cat-note {
    font-size: .8rem;
    color: var(--text-light);
    font-weight: 400;
}
.budget-price {
    font-size: .92rem;
    font-weight: 700;
    color: var(--green);
    white-space: nowrap;
}
.budget-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 18px;
    padding-top: 14px;
    border-top: 2px solid var(--dark);
}
.budget-total-label {
    font-size: .85rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--dark);
}
.budget-total-price {
    font-family: 'Playfair Display', serif;
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--green);
}
.budget-note {
    font-size: .78rem;
    color: var(--text-light);
    margin-top: 10px;
    line-height: 1.5;
}

/* ── N2: BOX-WEATHER ── */
.box-weather {
    background: var(--warm-white);
    border: 1px solid var(--border);
    padding: 28px 32px 24px;
    margin: 32px 0;
}
.box-weather-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 2px solid var(--green);
}
.weather-grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 6px;
    margin-bottom: 16px;
}
.weather-month {
    background: var(--cream);
    padding: 10px 4px;
    text-align: center;
    border: 1px solid var(--border);
}
.weather-month.peak   { background: #c8f5d0; border-color: #4caf50; }
.weather-month.good   { background: #e8f5e9; border-color: #a5d6a7; }
.weather-month.off    { background: #fff8e1; border-color: #ffe082; }
.weather-month.bad    { background: #fce4ec; border-color: #ef9a9a; }
.weather-m-name {
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--text-light);
    display: block;
    margin-bottom: 4px;
}
.weather-icon { font-size: 1.1rem; display: block; margin-bottom: 2px; }
.weather-temp {
    font-size: .7rem;
    font-weight: 700;
    color: var(--dark);
    display: block;
}
.weather-temp-min {
    font-size: .65rem;
    color: var(--text-light);
    display: block;
}
.weather-legend {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 8px;
}
.weather-legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .75rem;
    color: var(--text-light);
}
.weather-legend-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
}
.weather-legend-dot.peak { background: #4caf50; }
.weather-legend-dot.good { background: #a5d6a7; }
.weather-legend-dot.off  { background: #ffe082; }
.weather-legend-dot.bad  { background: #ef9a9a; }

/* ── N3: BOX-ATTRACTION ── */
.box-attraction {
    background: var(--warm-white);
    border: 1px solid var(--border);
    margin: 32px 0;
    overflow: hidden;
}
.box-attraction-header {
    background: var(--dark);
    color: #fff;
    padding: 18px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.box-attraction-name {
    font-family: 'Playfair Display', serif;
    font-size: 1.05rem;
    font-weight: 700;
}
.box-attraction-cat {
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    background: var(--green);
    color: #fff;
    padding: 3px 10px;
}
.box-attraction-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
}
.box-attraction-item {
    padding: 18px 20px;
    border-right: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}
.box-attraction-item:nth-child(3n) { border-right: none; }
.box-attraction-label {
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--text-light);
    display: block;
    margin-bottom: 4px;
}
.box-attraction-value {
    font-size: .9rem;
    font-weight: 700;
    color: var(--dark);
}
.box-attraction-value.free { color: var(--green); }
.box-attraction-footer {
    padding: 16px 20px;
    background: var(--cream);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}
.box-attraction-tip {
    font-size: .82rem;
    color: var(--text-light);
    line-height: 1.5;
}
.box-attraction-btn {
    display: inline-block;
    background: var(--green);
    color: #fff;
    padding: 9px 20px;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background .2s;
}
.box-attraction-btn:hover { background: var(--green-dark); color: #fff; }

/* ── N4: BOX-TRANSPORT ── */
.box-transport {
    background: var(--warm-white);
    border: 1px solid var(--border);
    margin: 32px 0;
    overflow: hidden;
}
.box-transport-header {
    background: var(--dark);
    color: #fff;
    padding: 16px 24px;
}
.box-transport-title {
    font-family: 'Playfair Display', serif;
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 2px;
}
.box-transport-subtitle {
    font-size: .75rem;
    color: rgba(255,255,255,.6);
}
.transport-row {
    display: grid;
    grid-template-columns: 42px 1fr 1fr auto;
    align-items: center;
    gap: 0;
    padding: 14px 20px;
    border-bottom: 1px solid var(--border);
}
.transport-row:last-child { border-bottom: none; }
.transport-icon { font-size: 1.3rem; text-align: center; }
.transport-mode {
    font-size: .88rem;
    font-weight: 700;
    color: var(--dark);
}
.transport-note {
    font-size: .78rem;
    color: var(--text-light);
    margin-top: 2px;
}
.transport-time {
    font-size: .82rem;
    color: var(--text-light);
    text-align: center;
}
.transport-price {
    font-size: .95rem;
    font-weight: 700;
    color: var(--green);
    text-align: right;
}
.transport-badge {
    display: inline-block;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    padding: 2px 7px;
    margin-top: 3px;
    color: #fff;
}
.transport-badge.best { background: var(--green); }
.transport-badge.fast { background: var(--gold); }

/* ── N5: BOX-VISA ── */
.box-visa {
    background: var(--warm-white);
    border: 1px solid var(--border);
    margin: 32px 0;
    overflow: hidden;
}
.box-visa-header {
    padding: 18px 24px;
    display: flex;
    align-items: center;
    gap: 16px;
}
.box-visa-header.required     { background: #fce4ec; border-bottom: 3px solid #e53935; }
.box-visa-header.not-required { background: #e8f5e9; border-bottom: 3px solid #43a047; }
.box-visa-status {
    font-family: 'Playfair Display', serif;
    font-size: 1rem;
    font-weight: 700;
}
.box-visa-badge {
    margin-left: auto;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 4px 12px;
    color: #fff;
}
.box-visa-header.required     .box-visa-badge { background: #e53935; }
.box-visa-header.not-required .box-visa-badge { background: #43a047; }
.box-visa-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
}
.box-visa-item {
    padding: 16px 20px;
    border-right: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}
.box-visa-item:nth-child(3n) { border-right: none; }
.box-visa-item-label {
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--text-light);
    display: block;
    margin-bottom: 4px;
}
.box-visa-item-value {
    font-size: .88rem;
    font-weight: 700;
    color: var(--dark);
}
.box-visa-note {
    padding: 14px 20px;
    font-size: .8rem;
    color: var(--text-light);
    background: var(--cream);
    line-height: 1.55;
}

/* ── N6: BOX-CHECKLIST ── */
.box-checklist {
    background: var(--warm-white);
    border: 1px solid var(--border);
    padding: 28px 32px;
    margin: 32px 0;
}
.box-checklist-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 2px solid var(--green);
    display: flex;
    align-items: center;
    gap: 10px;
}
.checklist-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 32px;
}
.checklist-group { margin-bottom: 20px; }
.checklist-group-name {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--green);
    margin-bottom: 10px;
}
.checklist-item {
    font-size: .88rem;
    color: var(--text);
    padding: 5px 0 5px 24px;
    position: relative;
    border-bottom: 1px dashed var(--border);
    line-height: 1.4;
}
.checklist-item::before {
    content: '☐';
    position: absolute;
    left: 0;
    color: var(--green);
    font-size: 1rem;
    line-height: 1.2;
}

/* ── N7: BOX-TIMELINE ── */
.box-timeline {
    background: var(--warm-white);
    border: 1px solid var(--border);
    padding: 28px 32px;
    margin: 32px 0;
}
.box-timeline-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 24px;
    padding-bottom: 14px;
    border-bottom: 2px solid var(--green);
}
.timeline-item {
    display: grid;
    grid-template-columns: 52px 16px 1fr;
    gap: 0 12px;
    margin-bottom: 20px;
}
.timeline-time {
    font-size: .75rem;
    font-weight: 700;
    color: var(--text-light);
    text-align: right;
    padding-top: 2px;
    white-space: nowrap;
}
.timeline-dot-wrap { display: flex; flex-direction: column; align-items: center; }
.timeline-dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--green);
    border: 2px solid #fff;
    box-shadow: 0 0 0 2px var(--green);
    flex-shrink: 0;
}
.timeline-line {
    flex: 1;
    width: 2px;
    background: var(--border);
    margin-top: 4px;
}
.timeline-item:last-child .timeline-line { display: none; }
.timeline-content { padding-bottom: 8px; }
.timeline-place {
    font-size: .9rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 3px;
}
.timeline-desc {
    font-size: .82rem;
    color: var(--text-light);
    line-height: 1.5;
}
.timeline-meta {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 6px;
}
.timeline-tag {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    background: var(--cream);
    color: var(--text-light);
    padding: 2px 8px;
    border: 1px solid var(--border);
}
.timeline-price {
    font-size: .78rem;
    font-weight: 700;
    color: var(--green);
}

/* ── N8: BOX-CURRENCY ── */
.box-currency {
    background: var(--warm-white);
    border: 1px solid var(--border);
    margin: 32px 0;
    overflow: hidden;
}
.box-currency-header {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0;
    border-bottom: 1px solid var(--border);
}
.box-currency-icon-wrap {
    background: var(--gold);
    padding: 20px 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.box-currency-emoji { font-size: 2.2rem; line-height: 1; }
.box-currency-icon-label {
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: rgba(255,255,255,.85);
    margin-top: 4px;
}
.box-currency-rate-wrap {
    padding: 20px 24px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.box-currency-rate {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.box-currency-from {
    font-family: 'Playfair Display', serif;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--dark);
}
.box-currency-arrow { font-size: 1.2rem; color: var(--text-light); }
.box-currency-to {
    font-family: 'Playfair Display', serif;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--green);
}
.box-currency-date {
    font-size: .72rem;
    color: var(--text-light);
    margin-top: 4px;
}
.box-currency-tips { padding: 20px 24px; }
.box-currency-tips-title {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--text-light);
    margin-bottom: 10px;
}
.currency-tip-item {
    font-size: .85rem;
    color: var(--text);
    padding: 6px 0;
    border-bottom: 1px dashed var(--border);
    padding-left: 16px;
    position: relative;
    line-height: 1.4;
}
.currency-tip-item::before {
    content: '→';
    position: absolute;
    left: 0;
    color: var(--green);
    font-size: .8rem;
}

/* ── N9: BOX-HOTELS ── */
.box-hotels {
    background: var(--warm-white);
    border: 1px solid var(--border);
    padding: 28px 32px 24px;
    margin: 32px 0;
}
.box-hotels-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 2px solid var(--green);
}
.hotels-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.hotel-card {
    border: 1px solid var(--border);
    overflow: hidden;
    background: #fff;
    display: flex;
    flex-direction: column;
}
.hotel-card-img {
    width: 100%;
    height: 160px;
    object-fit: cover;
    display: block;
}
.hotel-card-body { padding: 16px; flex: 1; display: flex; flex-direction: column; }
.hotel-card-stars { color: var(--gold); font-size: .8rem; margin-bottom: 6px; }
.hotel-card-name {
    font-size: .92rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 4px;
    line-height: 1.3;
}
.hotel-card-location {
    font-size: .78rem;
    color: var(--text-light);
    margin-bottom: 12px;
}
.hotel-card-ratings { flex: 1; margin-bottom: 14px; }
.hotel-card-rating-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 5px;
}
.hotel-card-rating-label {
    font-size: .7rem;
    color: var(--text-light);
    width: 72px;
    flex-shrink: 0;
}
.hotel-card-rating-bar-wrap {
    flex: 1;
    height: 4px;
    background: var(--border);
}
.hotel-card-rating-bar {
    height: 100%;
    background: var(--green);
}
.hotel-card-rating-val {
    font-size: .72rem;
    font-weight: 700;
    color: var(--dark);
    width: 24px;
    text-align: right;
}
.hotel-card-price {
    font-family: 'Playfair Display', serif;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--green);
    margin-bottom: 10px;
}
.hotel-card-btn {
    display: block;
    text-align: center;
    background: var(--dark);
    color: #fff;
    padding: 9px 16px;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background .2s;
}
.hotel-card-btn:hover { background: var(--green); color: #fff; }

/* =========================================================
   WP ALIGNMENTS
========================================================= */
.alignleft { float: left; margin: 0 24px 16px 0; }
.alignright { float: right; margin: 0 0 16px 24px; }
.aligncenter { display: block; margin: 0 auto 16px; }
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: .76rem; color: var(--text-light); text-align: center; margin-top: 6px; font-style: italic; font-family: 'Lato', sans-serif; }
.screen-reader-text { clip: rect(1px,1px,1px,1px); height: 1px; overflow: hidden; position: absolute; white-space: nowrap; width: 1px; }

/* WP Gutenberg embed */
.wp-block-embed__wrapper { position: relative; padding-top: 56.25%; }
.wp-block-embed__wrapper iframe { position: absolute; inset: 0; width: 100%; height: 100%; }

/* Woo / misc */
.entry-content .more-link { display: inline-block; margin-top: 8px; font-size: .73rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 700; color: var(--green); border-bottom: 1px solid rgba(3,132,92,.3); }

/* =========================================================
   STRONA O MNIE (page-o-mnie.php)
========================================================= */

/* Photo placeholder */
.omnie-photo-placeholder {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 10px; background: var(--cream); border: 2px dashed var(--border);
    color: var(--text-light); font-size: .68rem; letter-spacing: .12em;
    text-transform: uppercase; text-align: center;
}
.omnie-photo-placeholder i { font-size: 2rem; opacity: .3; }
.omnie-photo-placeholder--portrait { aspect-ratio: 3/4; width: 100%; max-width: 480px; margin: 0 auto; }
.omnie-photo-placeholder--landscape { aspect-ratio: 4/3; width: 100%; }
.omnie-photo-placeholder--wide { aspect-ratio: 16/10; width: 100%; }
.omnie-photo-placeholder--gallery { aspect-ratio: 1; width: 100%; }

/* --- HERO --- */
.omnie-hero {
    background: var(--dark);
    padding: 140px 0 100px;
    position: relative; overflow: hidden;
}
.omnie-hero-bg-text {
    position: absolute; right: -2%; top: 50%; transform: translateY(-50%);
    font-family: 'Playfair Display', serif; font-size: clamp(6rem,18vw,16rem);
    font-weight: 900; color: rgba(255,255,255,.03);
    pointer-events: none; white-space: nowrap; line-height: 1; z-index: 0;
}
.omnie-hero > .container { position: relative; z-index: 1; }
.omnie-hero-label { color: var(--green-light); }
.omnie-hero-label::before { background: var(--green-light); }
.omnie-hero-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.6rem, 5vw, 4.8rem); font-weight: 900;
    color: #fff; line-height: 1.1; margin: 14px 0 22px;
}
.omnie-hero-title em { font-style: italic; color: var(--gold-light); }
.omnie-hero-sub {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem; color: rgba(255,255,255,.55);
    max-width: 500px; line-height: 1.8; margin-bottom: 36px;
}
.omnie-hero-stats {
    display: flex; align-items: center; gap: 28px;
    margin-bottom: 36px; flex-wrap: wrap;
}
.omnie-hero-stat-num {
    font-family: 'Playfair Display', serif; font-size: 2.4rem; font-weight: 900;
    color: var(--green); line-height: 1;
}
.omnie-hero-stat-label {
    font-size: .65rem; letter-spacing: .14em; text-transform: uppercase;
    color: rgba(255,255,255,.4); margin-top: 3px;
}
.omnie-hero-stat-divider { width: 1px; height: 44px; background: rgba(255,255,255,.12); }
.omnie-hero-actions { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.omnie-hero-actions .btn-green { display: inline-flex; align-items: center; gap: 10px; }
.omnie-hero-btn-outline {
    display: inline-block; border: 1px solid rgba(255,255,255,.28);
    color: rgba(255,255,255,.75); padding: 13px 28px;
    font-size: .73rem; letter-spacing: .12em; text-transform: uppercase;
    font-weight: 700; transition: all .3s;
}
.omnie-hero-btn-outline:hover { border-color: #fff; color: #fff; }
.omnie-portrait-wrap { max-width: 420px; margin: 0 auto; }

/* --- SECTION BASE --- */
.omnie-section { padding: 100px 0; }
.omnie-historia { background: var(--warm-white); }
.omnie-pomysl { background: var(--cream); }
.omnie-jak { background: var(--warm-white); }
.omnie-azja { background: var(--cream); }

/* Ryga card */
.omnie-ryga-card {
    display: flex; align-items: center; gap: 18px;
    background: var(--cream); border-left: 4px solid var(--green);
    padding: 18px 22px; margin: 24px 0;
}
.omnie-ryga-icon { font-size: 2.4rem; flex-shrink: 0; line-height: 1; }
.omnie-ryga-label {
    font-size: .63rem; letter-spacing: .15em; text-transform: uppercase;
    color: var(--green); font-weight: 700; margin-bottom: 3px;
}
.omnie-ryga-dest {
    font-family: 'Playfair Display', serif; font-size: 1.1rem;
    font-weight: 700; color: var(--dark);
}
.omnie-ryga-sub { font-size: .8rem; color: var(--text-light); margin-top: 2px; }

/* Side photo */
.omnie-side-photo {
    width: 100%; aspect-ratio: 4/5; object-fit: cover;
    filter: sepia(8%) contrast(1.04);
    clip-path: polygon(0% 2%,2% 0%,98% 1%,100% 3%,99% 97%,97% 100%,3% 99%,0% 97%);
    transition: clip-path .6s;
}
.omnie-side-photo:hover {
    clip-path: polygon(0% 0%,100% 0%,100% 100%,0% 100%);
}

/* Pull quote */
.omnie-pullquote {
    position: relative; background: var(--dark);
    padding: 36px 36px 36px 54px;
    margin: 0; border: none;
}
.omnie-pullquote::before {
    content: '\201C'; position: absolute; left: 14px; top: 8px;
    font-size: 5rem; line-height: 1; color: var(--green);
    font-family: 'Playfair Display', serif; opacity: .7;
}
.omnie-pullquote::after {
    content: ''; position: absolute; left: 0; top: 0; bottom: 0;
    width: 4px; background: var(--green);
}
.omnie-pullquote p {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.25rem; font-style: italic; color: rgba(255,255,255,.88);
    line-height: 1.75; margin: 0;
}

/* Stat highlight */
.omnie-stat-highlight {
    display: flex; align-items: center; gap: 18px;
    border: 1px solid var(--border); border-left: 4px solid var(--green);
    padding: 18px 22px; margin: 24px 0; background: #fff;
}
.omnie-stat-highlight-num {
    font-family: 'Playfair Display', serif; font-size: 2.8rem; font-weight: 900;
    color: var(--green); line-height: 1; flex-shrink: 0;
}
.omnie-stat-highlight-text { font-size: .88rem; color: var(--text-light); line-height: 1.5; }

/* Preferences list */
.omnie-pref-list { list-style: none; padding: 0; margin-top: 14px; }
.omnie-pref-list li {
    display: flex; align-items: center; gap: 14px;
    padding: 10px 0; border-bottom: 1px solid var(--border);
    font-size: .9rem; color: var(--text); font-weight: 700;
    letter-spacing: .02em;
}
.omnie-pref-list li:last-child { border-bottom: none; }
.omnie-pref-icon {
    width: 34px; height: 34px; flex-shrink: 0;
    background: rgba(3,132,92,.08); color: var(--green);
    display: flex; align-items: center; justify-content: center;
    font-size: .88rem;
}

/* Gallery grid */
.omnie-gallery-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    gap: 10px;
}
.omnie-gallery-photo {
    width: 100%; object-fit: cover; display: block;
    filter: sepia(8%) contrast(1.04); transition: transform .5s, filter .5s;
    aspect-ratio: 1;
}
.omnie-gallery-grid > :first-child { grid-column: 1 / -1; }
.omnie-gallery-grid > :first-child .omnie-gallery-photo,
.omnie-gallery-grid > .omnie-gallery-photo:first-child,
.omnie-gallery-grid > .omnie-photo-placeholder:first-child { aspect-ratio: 16/9; }
.omnie-gallery-photo:hover { transform: scale(1.02); filter: sepia(0%) contrast(1.06); }

/* --- CO CENIĘ (dark) --- */
.omnie-cenie {
    background: var(--dark); padding: 100px 0; position: relative; overflow: hidden;
}
.omnie-cenie::before {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(3,132,92,.07), transparent);
    pointer-events: none;
}
.omnie-cenie > .container { position: relative; z-index: 1; }
.omnie-cenie-title { color: #fff; }
.omnie-cenie-title em { color: var(--green); }
.omnie-cenie-text { color: rgba(255,255,255,.6); }
.omnie-cenie-quote {
    position: relative; margin: 36px 0 0;
    padding: 0; border: none; text-align: left;
}
.omnie-cenie-quote p {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.2rem, 2.2vw, 1.8rem); font-weight: 700;
    color: #fff; line-height: 1.45; font-style: italic; margin: 0;
}
.omnie-cenie-quote footer {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.1rem; color: rgba(255,255,255,.45);
    font-style: italic; margin-top: 14px;
    padding-top: 14px; border-top: 1px solid rgba(255,255,255,.1);
}

/* --- AZJA --- */
.omnie-azja-badges {
    display: flex; flex-wrap: wrap; gap: 8px; margin: 20px 0 28px;
}
.omnie-azja-badge {
    background: rgba(3,132,92,.1); border: 1px solid rgba(3,132,92,.3);
    color: var(--green); padding: 6px 16px;
    font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
}
.omnie-kraje-count {
    display: flex; align-items: center; gap: 16px;
    margin-top: 24px; padding: 18px 22px;
    background: var(--dark); border-left: 4px solid var(--green);
}
.omnie-kraje-num {
    font-family: 'Playfair Display', serif; font-size: 2.8rem; font-weight: 900;
    color: var(--green); line-height: 1; flex-shrink: 0;
}
.omnie-kraje-text { font-size: .88rem; color: rgba(255,255,255,.6); line-height: 1.5; }
.omnie-azja-photo {
    width: 100%; aspect-ratio: 4/3; object-fit: cover;
    filter: sepia(8%) contrast(1.04);
}

/* --- CO ZNAJDZIESZ --- */
.omnie-znajdziesz {
    background: var(--cream); padding: 100px 0; position: relative;
}
.omnie-znajdziesz::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0;
    height: 4px; background: linear-gradient(to right, var(--green), transparent);
}
.omnie-znajdziesz-item {
    padding: 28px 22px; background: #fff; border: 1px solid var(--border);
    border-top: 3px solid transparent; height: 100%;
    transition: border-top-color .3s, box-shadow .3s, transform .3s;
}
.omnie-znajdziesz-item:hover {
    border-top-color: var(--green);
    box-shadow: 0 8px 30px rgba(57,54,57,.1);
    transform: translateY(-4px);
}
.omnie-znajdziesz-icon {
    width: 46px; height: 46px; background: rgba(3,132,92,.08);
    color: var(--green); display: flex; align-items: center; justify-content: center;
    font-size: 1.05rem; margin-bottom: 16px;
    transition: background .3s, color .3s;
}
.omnie-znajdziesz-item:hover .omnie-znajdziesz-icon {
    background: var(--green); color: #fff;
}
.omnie-znajdziesz-title {
    font-family: 'Playfair Display', serif; font-size: .95rem;
    font-weight: 700; color: var(--dark); margin-bottom: 8px;
}
.omnie-znajdziesz-text {
    font-size: .8rem; color: var(--text-light); line-height: 1.7;
}

/* --- CTA KONTAKT --- */
.omnie-cta {
    background: var(--dark); padding: 90px 0; position: relative; overflow: hidden;
}
.omnie-cta::before {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(3,132,92,.1), transparent 60%);
    pointer-events: none;
}
.omnie-cta > .container { position: relative; z-index: 1; }
.omnie-cta .section-label { color: var(--green-light); }
.omnie-cta .section-label::before { background: var(--green-light); }
.omnie-cta-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 900;
    color: #fff; line-height: 1.15; margin: 14px 0 18px;
}
.omnie-cta-title em { font-style: italic; color: var(--gold-light); }
.omnie-cta-text { font-family: 'Cormorant Garamond', serif; font-size: 1.15rem; color: rgba(255,255,255,.52); line-height: 1.75; }
.omnie-cta-social { display: flex; gap: 12px; justify-content: flex-end; margin-bottom: 20px; flex-wrap: wrap; }
.omnie-cta-social-link {
    display: inline-flex; align-items: center; gap: 8px;
    border: 1px solid rgba(255,255,255,.2); color: rgba(255,255,255,.7);
    padding: 10px 20px; font-size: .73rem; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase; transition: all .3s;
}
.omnie-cta-social-link:hover { background: var(--green); border-color: var(--green); color: #fff; }
.omnie-cta-btn { display: inline-flex; align-items: center; gap: 10px; }

/* --- RESPONSIVE --- */
@media (max-width: 991px) {
    .omnie-hero { padding: 120px 0 80px; }
    .omnie-cta-social { justify-content: flex-start; }
}
@media (max-width: 768px) {
    .omnie-section { padding: 70px 0; }
    .omnie-hero { padding: 110px 0 70px; }
    .omnie-cenie, .omnie-znajdziesz, .omnie-cta { padding: 70px 0; }
    .omnie-gallery-grid { grid-template-columns: 1fr; }
    .omnie-gallery-grid > *:first-child { grid-column: auto; }
    .omnie-pullquote { padding: 28px 24px 28px 44px; }
    .omnie-hero-stats { gap: 20px; }
}

/* =========================================================
   STRONA KONTAKT (page-kontakt.php)
========================================================= */

/* Hero */
.contact-hero {
    background: var(--dark);
    padding: 160px 0 100px;
    position: relative;
    overflow: hidden;
    text-align: center;
}
.contact-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(3,132,92,.12), transparent 60%);
    pointer-events: none;
}
.contact-hero::after {
    content: 'KONTAKT';
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    font-family: 'Playfair Display', serif;
    font-size: clamp(5rem,18vw,16rem);
    font-weight: 900;
    color: rgba(255,255,255,.03);
    pointer-events: none;
    white-space: nowrap;
    line-height: 1;
    z-index: 0;
}
.contact-hero > * { position: relative; z-index: 1; }
.contact-hero .section-label { color: var(--green-light); }
.contact-hero .section-label::before { background: var(--green-light); }
.contact-hero-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.5rem,5.5vw,5rem);
    font-weight: 900;
    color: #fff;
    line-height: 1.1;
    margin: 14px 0 22px;
}
.contact-hero-title em { font-style: italic; color: var(--gold-light); }
.contact-hero-sub {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.25rem;
    color: rgba(255,255,255,.52);
    max-width: 560px;
    margin: 0 auto;
    line-height: 1.75;
}

/* Contact section */
.contact-section { padding: 100px 0; background: var(--warm-white); }

/* Info cards */
.contact-info-cards { display: flex; flex-direction: column; gap: 12px; margin-top: 2rem; }
.contact-info-card {
    display: flex; align-items: center; gap: 16px;
    background: #fff; border: 1px solid var(--border);
    border-left: 3px solid var(--green);
    padding: 16px 20px; transition: box-shadow .3s;
}
.contact-info-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,.07); }
.contact-info-icon {
    width: 42px; height: 42px; flex-shrink: 0;
    background: rgba(3,132,92,.07); color: var(--green);
    display: flex; align-items: center; justify-content: center; font-size: 1rem;
}
.contact-info-label {
    font-size: .63rem; letter-spacing: .16em; text-transform: uppercase;
    color: var(--text-light); font-weight: 700; margin-bottom: 3px;
}
.contact-info-value { font-size: .88rem; font-weight: 700; color: var(--dark); }
a.contact-info-value:hover { color: var(--green); }

/* Form wrap */
.contact-form-wrap {
    background: #fff;
    border: 1px solid var(--border);
    border-top: 3px solid var(--green);
    padding: 44px;
}
.contact-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.contact-form-group { margin-bottom: 20px; }
.contact-form-group label {
    display: block; font-size: .65rem; letter-spacing: .14em;
    text-transform: uppercase; font-weight: 700; color: var(--dark); margin-bottom: 7px;
}
.contact-form-group label span { color: var(--green); }
.contact-form-group input,
.contact-form-group select,
.contact-form-group textarea {
    width: 100%; background: var(--warm-white);
    border: 1px solid var(--border); border-radius: 0;
    padding: 12px 16px; font-family: 'Lato', sans-serif;
    font-size: .9rem; color: var(--dark);
    transition: border-color .25s, background .25s;
    outline: none; -webkit-appearance: none; appearance: none;
}
.contact-form-group input:focus,
.contact-form-group select:focus,
.contact-form-group textarea:focus {
    border-color: var(--green); background: #fff;
}
.contact-form-group select {
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23393639' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 12px;
    padding-right: 40px;
    background-color: var(--warm-white);
}
.contact-form-group select:focus { background-color: #fff; }
.contact-form-group textarea { resize: vertical; min-height: 148px; }
.contact-form-submit { width: 100%; padding: 15px; font-size: .73rem; letter-spacing: .15em; cursor: pointer; }

/* Messages */
.contact-msg {
    display: flex; align-items: flex-start; gap: 14px;
    padding: 20px 24px; margin-bottom: 28px;
    font-family: 'Lato', sans-serif;
}
.contact-msg i { font-size: 1.3rem; margin-top: 2px; flex-shrink: 0; }
.contact-msg strong { display: block; margin-bottom: 4px; font-size: .9rem; color: var(--dark); }
.contact-msg p { margin: 0; font-size: .84rem; color: var(--text-light); }
.contact-msg--ok { background: linear-gradient(135deg,#f0faf6,#e6f7f0); border-left: 4px solid var(--green); }
.contact-msg--ok i { color: var(--green); }
.contact-msg--err { background: linear-gradient(135deg,#fff8f8,#fdf0f0); border-left: 4px solid #c0392b; }
.contact-msg--err i { color: #c0392b; }

/* Współpraca section */
.wspolpraca-section {
    padding: 100px 0;
    background: var(--dark);
    position: relative;
    overflow: hidden;
}
.wspolpraca-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(3,132,92,.08), transparent);
    pointer-events: none;
}
.wspolpraca-section > .container { position: relative; z-index: 1; }
.wspolpraca-section .section-label { color: var(--green-light); }
.wspolpraca-section .section-label::before { background: var(--green-light); }
.wspolpraca-section .section-title { color: #fff; }
.wspolpraca-section .section-title em { color: var(--green); }
.wspolpraca-section .about-text { color: rgba(255,255,255,.52); }
.wspolpraca-card {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.07);
    border-top: 3px solid var(--green);
    padding: 32px 26px;
    height: 100%;
    transition: background .3s, transform .3s, border-top-color .3s;
}
.wspolpraca-card:hover {
    background: rgba(255,255,255,.08);
    border-top-color: var(--gold);
    transform: translateY(-5px);
}
.wspolpraca-icon {
    width: 52px; height: 52px;
    background: rgba(3,132,92,.15);
    border: 1px solid rgba(3,132,92,.3);
    color: var(--green);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.15rem; margin-bottom: 20px;
    transition: background .3s, border-color .3s, color .3s;
}
.wspolpraca-card:hover .wspolpraca-icon {
    background: rgba(201,168,76,.15);
    border-color: rgba(201,168,76,.35);
    color: var(--gold);
}
.wspolpraca-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.05rem; font-weight: 700;
    color: #fff; margin-bottom: 12px;
}
.wspolpraca-text {
    font-size: .84rem; color: rgba(255,255,255,.44);
    line-height: 1.8; font-family: 'Lato', sans-serif;
}
.contact-wspolpraca-cta-text {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem; color: rgba(255,255,255,.55);
    margin-bottom: 20px;
}
.contact-wspolpraca-btn {
    display: inline-flex; align-items: center; gap: 10px;
    background: none; border: 1px solid rgba(255,255,255,.25);
    color: #fff; padding: 13px 34px;
    font-size: .73rem; font-weight: 700;
    letter-spacing: .12em; text-transform: uppercase;
    transition: all .3s;
}
.contact-wspolpraca-btn:hover {
    background: var(--green); border-color: var(--green); color: #fff;
}

/* Responsive */
@media (max-width: 768px) {
    .contact-hero { padding: 120px 0 70px; }
    .contact-form-wrap { padding: 28px 22px; }
    .contact-form-row { grid-template-columns: 1fr; gap: 0; }
    .contact-info-cards { margin-top: 1.5rem; }
}
@media (max-width: 480px) {
    .contact-hero-title { font-size: 2.2rem; }
}

/* =========================================================
   SHORTCODES – dodatkowe bloki (box-highlight, box-quote, box-faq)
========================================================= */

/* ── BOX-FAQ ── */
.box-faq {
    border: 1px solid var(--border);
    margin: 32px 0;
    overflow: hidden;
}
.box-faq-title {
    background: var(--dark);
    color: #fff;
    padding: 16px 24px;
    font-family: 'Playfair Display', serif;
    font-size: 1rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 10px;
}
.box-faq-title i { color: var(--gold); }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-item:last-child { border-bottom: none; }
.faq-question {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 24px;
    background: #fff;
    border: none;
    cursor: pointer;
    font-family: 'Lato', sans-serif;
    font-size: .92rem;
    font-weight: 700;
    color: var(--dark);
    text-align: left;
    transition: background .15s, color .15s;
}
.faq-question:hover { background: var(--cream); color: var(--green); }
.faq-question[aria-expanded="true"] { background: var(--green-light); color: var(--green); }
.faq-icon {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--cream);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .7rem;
    color: var(--green);
    transition: transform .25s, background .15s;
}
.faq-question[aria-expanded="true"] .faq-icon {
    transform: rotate(180deg);
    background: var(--green);
    color: #fff;
}
.faq-answer {
    overflow: hidden;
    max-height: 0;
    transition: max-height .3s ease;
}
.faq-answer:not([hidden]) { max-height: 600px; }
.faq-answer-inner {
    padding: 4px 24px 20px;
    font-size: .9rem;
    color: var(--text-light);
    line-height: 1.7;
    border-left: 3px solid var(--green);
    margin: 0 24px 0 24px;
}

/* ── BOX-HIGHLIGHT ── */
.box-highlight {
    background: var(--dark);
    color: #fff;
    padding: 22px 26px;
    margin: 32px 0;
    display: flex;
    align-items: flex-start;
    gap: 18px;
}
.box-highlight-icon {
    font-size: 1.8rem;
    opacity: .6;
    flex-shrink: 0;
    padding-top: 3px;
}
.box-highlight-title {
    font-family: 'Playfair Display', serif;
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 6px;
    color: var(--gold);
}
.box-highlight-text {
    font-size: .9rem;
    line-height: 1.65;
    color: rgba(255,255,255,.8);
}

/* ── BOX-QUOTE ── */
.box-quote {
    background: var(--cream);
    border-left: 4px solid var(--green);
    padding: 24px 28px 24px 44px;
    margin: 32px 0;
    position: relative;
}
.box-quote::before {
    content: '\201C';
    font-family: 'Playfair Display', serif;
    font-size: 5rem;
    color: var(--green);
    opacity: .2;
    position: absolute;
    top: -10px;
    left: 12px;
    line-height: 1;
}
.box-quote-text {
    font-family: 'Playfair Display', serif;
    font-style: italic;
    font-size: 1.1rem;
    color: var(--dark);
    line-height: 1.7;
    position: relative;
    z-index: 1;
    margin-bottom: 14px;
}
.box-quote-author {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: .85rem;
}
.box-quote-dot {
    width: 32px;
    height: 3px;
    background: var(--green);
    border-radius: 2px;
    flex-shrink: 0;
}
.box-quote-author-name { font-weight: 700; color: var(--dark); }
.box-quote-author-role { color: var(--text-light); }
