/* ============================================================
   VIT-301 — Editorial főoldal (2026-05-01)
   REKONSTRUKCIÓ 2026-05-15 (4.4.7) — BoK + asszisztens-memória alapján
   ============================================================ */

.vitano-home { background: var(--vitano-bg, var(--vitano-cream)); }

.vh-section-inner {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 var(--sp-5);
}
@media (min-width: 768px) { .vh-section-inner { padding: 0 var(--sp-7); } }

.vh-section-title {
    font-family: var(--font-display);
    font-size: var(--fs-h2);
    font-weight: 600;
    line-height: var(--lh-tight);
    color: var(--vitano-charcoal);
    margin: 0 0 12px 0;
}

/* ============================================================
   HERO
   ============================================================ */
.vh-hero {
    position: relative;
    width: 100%;
    overflow: hidden;
}
.vh-hero-img {
    position: relative;
    aspect-ratio: 1920 / 500;
    min-height: 320px;
    background: var(--vitano-cream-2);
}
@media (max-width: 768px) {
    .vh-hero-img { aspect-ratio: 4 / 5; max-height: 70vh; }
}
.vh-hero-img img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}
.vh-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(250,246,241,0.78) 0%, rgba(250,246,241,0.32) 60%, rgba(250,246,241,0) 100%);
    display: flex;
    align-items: center;
}
@media (max-width: 768px) {
    .vh-hero-overlay {
        background: linear-gradient(180deg, rgba(250,246,241,0.2) 0%, rgba(250,246,241,0.85) 80%);
        align-items: flex-end;
    }
}
.vh-hero-inner {
    max-width: var(--max-width);
    width: 100%;
    margin: 0 auto;
    padding: var(--sp-8) var(--sp-5);
}
@media (min-width: 768px) { .vh-hero-inner { padding: var(--sp-7) var(--sp-7); } }
.vh-hero-title {
    font-family: var(--font-display);
    font-size: clamp(40px, 6vw, 72px);
    font-weight: 600;
    line-height: var(--lh-tight);
    letter-spacing: var(--tracking-display);
    color: var(--vitano-charcoal);
    margin: 0 0 var(--sp-4) 0;
    max-width: 600px;
}
.vh-hero-sub {
    font-family: var(--font-body);
    font-size: clamp(16px, 1.8vw, 22px);
    line-height: var(--lh-body);
    color: var(--vitano-charcoal-2);
    margin: 0 0 var(--sp-6) 0;
    max-width: 480px;
}
.vh-hero-cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-3);
}
.vh-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 48px;
    padding: 0 var(--sp-6);
    border-radius: var(--radius-pill);
    font-family: var(--font-body);
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: background var(--dur-fast) var(--ease-soft), color var(--dur-fast) var(--ease-soft), transform var(--dur-fast) var(--ease-soft);
}
.vh-btn--primary {
    background: var(--vitano-coral);
    color: var(--vitano-white);
    border: none;
}
.vh-btn--primary:hover { background: var(--vitano-coral-dk); transform: translateY(-1px); }
.vh-btn--ghost {
    background: transparent;
    color: var(--vitano-charcoal);
    border: 2px solid var(--vitano-charcoal);
}
.vh-btn--ghost:hover { background: var(--vitano-charcoal); color: var(--vitano-cream); }

/* ============================================================
   KATEGÓRIÁK (chip-row, 4.1.0+)
   ============================================================ */
.vh-cats {
    padding: var(--sp-7) 0;
    background: var(--vitano-cream);
}
@media (min-width: 768px) { .vh-cats { padding: var(--sp-8) 0; } }

.vh-cat-chips {
    list-style: none;
    margin: var(--sp-5) 0 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 12px 12px;
}
.vh-cat-chips > li { margin: 0; }
.vh-cat-chip {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 18px;
    background: var(--vitano-white);
    border: 1px solid var(--vitano-line);
    border-radius: var(--radius-pill);
    font-family: var(--font-body);
    font-size: 15px;
    font-weight: 600;
    color: var(--vitano-charcoal);
    text-decoration: none;
    transition: color var(--dur-fast) var(--ease-soft), background var(--dur-fast) var(--ease-soft), border-color var(--dur-fast) var(--ease-soft), transform var(--dur-fast) var(--ease-soft);
}
.vh-cat-chip svg {
    flex: 0 0 auto;
    color: var(--vitano-charcoal-3);
    transition: color var(--dur-fast) var(--ease-soft);
}
.vh-cat-chip:hover,
.vh-cat-chip:focus-visible {
    background: var(--vitano-terracotta);
    border-color: var(--vitano-terracotta);
    color: var(--vitano-white);
    transform: translateY(-1px);
    outline: none;
}
.vh-cat-chip:hover svg,
.vh-cat-chip:focus-visible svg { color: var(--vitano-white); }
.vh-cat-chip--rose  { border-color: var(--vitano-rose); }
.vh-cat-chip--rose svg { color: var(--vitano-rose-dk); }
.vh-cat-chip--sage  { border-color: var(--vitano-sage); }
.vh-cat-chip--sage svg { color: var(--vitano-sage-dk); }
.vh-cat-chip--stone { border-color: var(--vitano-stone); }
.vh-cat-chip--stone svg { color: var(--vitano-stone-dk); }

/* ============================================================
   HETI KEDVENCEK
   ============================================================ */
.vh-faves {
    padding: var(--sp-7) 0;
    background: var(--vitano-cream-2);
}
@media (min-width: 768px) { .vh-faves { padding: var(--sp-8) 0; } }
.vh-faves-rail .products {
    grid-template-columns: repeat(2, 1fr) !important;
}
@media (min-width: 768px) {
    .vh-faves-rail .products { grid-template-columns: repeat(4, 1fr) !important; }
}
.vh-faves-all {
    display: inline-block;
    margin-top: var(--sp-6);
    color: var(--vitano-terracotta);
    font-weight: 600;
}
.vh-faves-all:hover { color: var(--vitano-terracotta-dk); }

/* ============================================================
   SZTORI-BLOKK
   ============================================================ */
.vh-story {
    position: relative;
    background: var(--vitano-charcoal);
    color: var(--vitano-cream);
    overflow: hidden;
    min-height: auto;
    display: flex;
    align-items: center;
    padding: var(--sp-9) var(--sp-5);
}
@media (min-width: 768px) { .vh-story { padding: var(--sp-8) var(--sp-7); } }
.vh-story-img {
    position: absolute;
    inset: 0;
    z-index: 0;
    opacity: 0.4;
}
.vh-story-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.vh-story-card {
    position: relative;
    z-index: 1;
    max-width: 600px;
    padding: var(--sp-7);
    background: rgba(250, 246, 241, 0.94);
    color: var(--vitano-charcoal);
    border-radius: var(--radius-lg);
}
.vh-story-card .v-eyebrow {
    display: block;
    margin-bottom: var(--sp-2);
    color: var(--vitano-terracotta);
    font-size: var(--fs-tiny);
    font-weight: 600;
    letter-spacing: var(--tracking-eyebrow);
    text-transform: uppercase;
}
.vh-story-title {
    font-family: var(--font-display);
    font-size: clamp(24px, 3vw, 36px);
    font-weight: 600;
    line-height: var(--lh-tight);
    color: var(--vitano-charcoal);
    margin: 0 0 var(--sp-4) 0;
}
.vh-story-card p {
    font-family: var(--font-body);
    font-size: 15px;
    line-height: var(--lh-body);
    color: var(--vitano-charcoal-2);
    margin: 0 0 var(--sp-3) 0;
}
.vh-story-card .vh-btn {
    margin-top: var(--sp-3);
}

/* ============================================================
   ÉRTÉKAJÁNLAT — Az ígéretünk (W1, 4.1.0)
   ============================================================ */
.vh-values { padding: var(--sp-9) 0; }
.vh-values-grid {
    list-style: none;
    margin: var(--sp-6) 0 0 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-5);
}
@media (min-width: 768px) {
    .vh-values-grid { grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); }
}
.vh-value-card {
    background: var(--vitano-white);
    border: 1px solid var(--vitano-line);
    border-radius: var(--radius-lg);
    padding: var(--sp-6) var(--sp-5);
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
}
.vh-value-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: var(--radius-pill);
    background: var(--vitano-cream);
    color: var(--vitano-terracotta);
}
.vh-value-title {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 600;
    line-height: 1.25;
    color: var(--vitano-charcoal);
    margin: 0;
}
.vh-value-desc {
    font-size: var(--fs-body-sm);
    line-height: var(--lh-body);
    color: var(--vitano-charcoal-2);
    margin: 0;
}

/* ============================================================
   MAGAZIN (Blog rail, 4-col 4.2.3+)
   ============================================================ */
.vh-blog { padding: var(--sp-7) 0; }
@media (min-width: 768px) { .vh-blog { padding: var(--sp-8) 0; } }

.vh-blog-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-5);
    margin: var(--sp-4) 0 0 0;
}
@media (min-width: 600px) {
    .vh-blog-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
    .vh-blog-grid { grid-template-columns: repeat(4, 1fr); gap: 16px; }
}

.vh-blog-card {
    background: var(--vitano-white);
    border: 1px solid var(--vitano-line);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: box-shadow var(--dur) var(--ease-soft), transform var(--dur) var(--ease-soft);
}
.vh-blog-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.vh-blog-card-link { display: block; text-decoration: none; color: inherit; }

.vh-blog-card-img {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--vitano-cream-2);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.vh-blog-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.vh-blog-card-img--fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--vitano-cream) 0%, var(--vitano-cream-2) 100%);
}
.vh-blog-card-img-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 84px;
    height: 84px;
    border-radius: 50%;
    background: var(--vitano-white);
    box-shadow: var(--shadow-sm);
}
.vh-blog-card-img-mark img {
    width: 64px;
    height: 64px;
    object-fit: cover;
    border-radius: 50%;
    opacity: 0.92;
}

.vh-blog-card-body { padding: 12px 14px 16px; }
.vh-blog-card-date {
    display: block;
    margin: 0 0 6px 0;
    font-family: var(--font-body);
    font-size: var(--fs-tiny);
    color: var(--vitano-charcoal-3);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.vh-blog-card-title {
    font-family: var(--font-display);
    font-size: 15px;
    font-weight: 600;
    color: var(--vitano-charcoal);
    line-height: 1.3;
    margin: 4px 0 6px 0;
}
.vh-blog-card p {
    font-size: 13px;
    line-height: 1.4;
    color: var(--vitano-charcoal-2);
    margin: 0 0 8px 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.vh-blog-card-cta {
    font-size: 13px;
    color: var(--vitano-terracotta);
    font-weight: 600;
}
.vh-blog-empty {
    text-align: center;
    color: var(--vitano-charcoal-2);
    padding: var(--sp-5) 0;
}

/* ============================================================
   HÍRLEVÉL
   ============================================================ */
.vh-newsletter {
    background: var(--vitano-coral);
    color: var(--vitano-white);
    padding: var(--sp-8) var(--sp-5);
    text-align: center;
}
@media (min-width: 768px) { .vh-newsletter { padding: var(--sp-8) var(--sp-7); } }

.vh-newsletter .vh-section-inner { text-align: center; }
.vh-newsletter .v-eyebrow {
    display: block;
    margin-bottom: var(--sp-2);
    color: var(--vitano-white);
    opacity: 0.85;
    font-size: var(--fs-tiny);
    font-weight: 600;
    letter-spacing: var(--tracking-eyebrow);
    text-transform: uppercase;
}
.vh-newsletter .vh-section-title {
    color: var(--vitano-white);
    margin: 0 0 var(--sp-3) 0;
}
.vh-newsletter-form {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-2);
    max-width: 480px;
    margin: var(--sp-4) auto 0;
}
@media (min-width: 600px) {
    .vh-newsletter-form { flex-wrap: nowrap; }
}
.vh-newsletter-form input[type="email"] {
    flex: 1 1 auto;
    height: 48px;
    padding: 0 var(--sp-5);
    background: var(--vitano-white);
    border: none;
    border-radius: var(--radius-pill);
    font-family: var(--font-body);
    font-size: 15px;
    color: var(--vitano-charcoal);
    outline: none;
}
.vh-newsletter-form button[type="submit"] {
    flex: 0 0 auto;
    height: 48px;
    padding: 0 var(--sp-6);
    background: var(--vitano-charcoal);
    color: var(--vitano-cream);
    font-family: var(--font-body);
    font-size: 15px;
    font-weight: 700;
    border: none;
    border-radius: var(--radius-pill);
    cursor: pointer;
    transition: background var(--dur-fast) var(--ease-soft);
}
.vh-newsletter-form button:hover { background: #1d1814; }
.vh-newsletter-note {
    font-size: var(--fs-tiny);
    color: var(--vitano-cream);
    opacity: 0.85;
    margin: var(--sp-3) 0 0 0;
}
.vh-newsletter-note a { color: var(--vitano-cream); text-decoration: underline; }

/* ============================================================
   VIT-FINETUNE-W3 (4.2.2) — White-space audit -15-20% vertikális
   ============================================================ */

/* Hero kompaktabb */
.vh-hero-img { aspect-ratio: 1920 / 420 !important; min-height: 280px !important; }
@media (max-width: 768px) {
    .vh-hero-img { aspect-ratio: 3 / 4 !important; max-height: 60vh !important; }
}
.vh-hero-inner { padding: var(--sp-6) var(--sp-5) !important; }
@media (min-width: 768px) {
    .vh-hero-inner { padding: var(--sp-7) var(--sp-7) !important; }
}

/* Section-padding -36% */
.vh-cats   { padding: 16px 0 !important; }
.vh-faves  { padding: 32px 0 !important; background: var(--vitano-bg) !important; }
.vh-values { padding: 32px 0 !important; }
.vh-blog   { padding: 32px 0 !important; }
.vh-story  { padding: 32px var(--sp-5) !important; }
.vh-newsletter { padding: 32px var(--sp-5) !important; }

@media (min-width: 768px) {
    .vh-story      { padding: 32px var(--sp-7) !important; }
    .vh-newsletter { padding: 32px var(--sp-7) !important; }
}

@media (max-width: 767px) {
    .vh-cats   { padding: 12px 0 !important; }
    .vh-faves  { padding: 24px 0 !important; }
    .vh-values { padding: 24px 0 !important; }
    .vh-blog   { padding: 24px 0 !important; }
    .vh-story      { padding: 24px var(--sp-5) !important; }
    .vh-newsletter { padding: 24px var(--sp-5) !important; }
}

/* Cím alatti spacing kompaktabb */
.vh-section-title { margin-bottom: 14px !important; }

/* "Összes termék →" link feljebb */
.vh-faves-all { margin-top: var(--sp-4) !important; }

/* ============================================================
   W4 patch-3 — Astra parent #primary {margin:4em 0} felülírás
   + minden section direkt-szülő-margin force-zárása
   ============================================================ */
body.home #primary,
body.home main#primary,
body.home main.vitano-home {
    margin: 0 !important;
    padding: 0 !important;
}
body.home main.vitano-home > section,
body.home main#primary > section {
    margin: 0 !important;
}
body.home .vh-faves .vh-section-title,
body.home .vh-cats .vh-section-title,
body.home .vh-blog .vh-section-title,
body.home .vh-values .vh-section-title,
body.home main h2.vh-section-title {
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
}
body.home main .vh-cats { padding: 0 !important; }
body.home main .vh-faves { padding: 0 0 24px 0 !important; }
body.home main .vh-faves > .vh-section-inner { padding-top: 0 !important; }
body.home main .vh-faves .vh-faves-rail { margin-top: 0 !important; padding-top: 0 !important; }
@media (max-width: 767px) {
    body.home main .vh-faves { padding: 0 0 20px 0 !important; }
}

/* ============================================================
   W4 patch-4 — chip-row (kategória menü) centrálása a hero alatt
   ============================================================ */
.vh-cat-chips,
body.home .vh-cats .vh-cat-chips {
    justify-content: center !important;
    margin: 0 !important;
}

/* ============================================================
   W4 patch-5 (4.3.0) — chip-row körüli esztétikus levegő (28 px)
   ============================================================ */
body.home main .vh-cats { padding: 28px 0 !important; }
body.home main .vh-faves { padding: 12px 0 28px 0 !important; }

@media (max-width: 767px) {
    body.home main .vh-cats { padding: 20px 0 !important; }
    body.home main .vh-faves { padding: 8px 0 20px 0 !important; }
}

/* ============================================================
   4.4.5 — Heti kedvenceink empty-state
   ============================================================ */
.vh-faves-empty {
    padding: 32px 16px;
    text-align: center;
    max-width: 600px;
    margin: 0 auto;
    background: var(--vitano-cream);
    border-radius: var(--radius-lg);
    border: 1px solid var(--vitano-line);
}
.vh-faves-empty-msg {
    font-size: 14px;
    line-height: 1.5;
    color: var(--vitano-charcoal-2);
    margin: 0 0 12px 0;
}
.vh-faves-empty-cta {
    display: inline-block;
    padding: 8px 20px;
    background: var(--vitano-coral);
    color: var(--vitano-white) !important;
    border-radius: var(--radius-pill);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: background 120ms;
}
.vh-faves-empty-cta:hover {
    background: var(--vitano-coral-dk);
}
