/**
 * Moviaggio — moviaggio-v33-additions.css v3.3.1 (fix grid layout)
 *
 * Da caricare DOPO moviaggio.css.
 * Override della grid destinazioni per evitare sfasamenti causati dalla card featured (span 2).
 */

/* ============================================================
   FIX GRID DESTINAZIONI — colonne fisse invece di auto-fill
   ============================================================ */
.mv-cities-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);  /* desktop: 4 colonne fisse */
    gap: var(--space-5);
    grid-auto-rows: 1fr;  /* righe di altezza uguale */
}
@media (max-width: 1100px) {
    .mv-cities-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 850px) {
    .mv-cities-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
    .mv-cities-grid { grid-template-columns: 1fr; }
}

/* La card featured occupa 2 colonne SOLO su desktop e tablet (>= 850px) */
.mv-city-card--feat { grid-column: span 2; aspect-ratio: 16 / 10; }
@media (max-width: 850px) {
    .mv-city-card--feat { grid-column: span 2; aspect-ratio: 16 / 10; }  /* span 2 su 2 = full width tablet */
}
@media (max-width: 540px) {
    .mv-city-card--feat { grid-column: span 1; aspect-ratio: 4 / 5; }  /* normale su mobile */
}

/* ============================================================
   FIX GRID MAGAZINE/POSTS — analogo
   ============================================================ */
.mv-posts-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);  /* desktop: 3 colonne */
    gap: var(--space-6);
}
@media (max-width: 900px) {
    .mv-posts-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
    .mv-posts-grid { grid-template-columns: 1fr; }
}

/* Lead card (primo articolo magazine) — span 2 su 3 colonne, layout orizzontale */
.mv-post-card--lead {
    grid-column: span 2;
}
.mv-post-card--lead .mv-post-card__img-wrap {
    aspect-ratio: 16 / 9;
}
@media (max-width: 900px) {
    .mv-post-card--lead { grid-column: span 2; }  /* su tablet 2 col, span 2 = full width */
}
@media (max-width: 540px) {
    .mv-post-card--lead { grid-column: span 1; }
}

/* ============================================================
   QUI SOTTO TUTTO IL CONTENUTO ORIGINALE DEL v3.3 ADDITIONS
   ============================================================ */

/* CTA INLINE */
.mv-cta-inline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-5);
    background: var(--mv-deep-sea);
    color: var(--mv-bone);
    padding: var(--space-6);
    border-radius: var(--radius-md);
    margin: var(--space-6) 0;
    position: relative;
    overflow: hidden;
}
.mv-cta-inline::before {
    content: "";
    position: absolute;
    top: -60px; right: -60px;
    width: 200px; height: 200px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--mv-ochre) 0%, transparent 70%);
    opacity: 0.18;
    pointer-events: none;
}
.mv-cta-inline > * { position: relative; z-index: 1; }
.mv-cta-inline__title {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    color: var(--mv-bone);
    line-height: 1.15;
    margin: 0 0 var(--space-2);
    letter-spacing: -0.01em;
}
.mv-cta-inline__title em { color: var(--mv-ochre); font-style: italic; }
.mv-cta-inline__desc {
    font-family: var(--font-editorial);
    color: rgba(251, 248, 243, 0.82);
    font-size: var(--text-md);
    line-height: 1.5;
    margin: 0;
    max-width: 50ch;
}
.mv-cta-inline__btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    background: var(--mv-ochre);
    color: var(--mv-deep-sea);
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: 600;
    text-decoration: none;
    border-radius: var(--radius-pill);
    transition: background var(--t-fast), transform var(--t-fast);
}
.mv-cta-inline__btn:hover { background: #e6b463; transform: translateY(-1px); }
@media (max-width: 700px) {
    .mv-cta-inline { flex-direction: column; align-items: flex-start; padding: var(--space-5); }
    .mv-cta-inline__btn { width: 100%; justify-content: center; }
}

/* MAP CARD */
.mv-map-card {
    background: var(--mv-foam);
    border-radius: var(--radius-md);
    overflow: hidden;
    margin: var(--space-6) 0;
    border: 1px solid var(--mv-pearl);
}
.mv-map-card__embed {
    position: relative;
    aspect-ratio: 16 / 7;
    background: linear-gradient(135deg, var(--mv-foam) 0%, var(--mv-shallow) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--mv-bone);
}
.mv-map-card__embed::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        repeating-linear-gradient(0deg, transparent 0, transparent 39px, rgba(251, 248, 243, .15) 39px, rgba(251, 248, 243, .15) 40px),
        repeating-linear-gradient(90deg, transparent 0, transparent 39px, rgba(251, 248, 243, .15) 39px, rgba(251, 248, 243, .15) 40px);
    pointer-events: none;
}
.mv-map-card__pin {
    width: 32px;
    height: 42px;
    color: var(--mv-terra);
    filter: drop-shadow(0 4px 8px rgba(10, 37, 64, 0.3));
    z-index: 1;
}
.mv-map-card__caption {
    padding: var(--space-4) var(--space-5);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    flex-wrap: wrap;
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: var(--mv-graphite);
}
.mv-map-card__caption a {
    color: var(--mv-deep-sea);
    text-decoration: none;
    font-weight: 600;
    transition: color var(--t-fast);
}
.mv-map-card__caption a:hover { color: var(--mv-terra); }

/* WEATHER CARD */
.mv-weather-card {
    background: linear-gradient(135deg, var(--mv-deep-sea) 0%, #133355 100%);
    color: var(--mv-bone);
    padding: var(--space-5);
    border-radius: var(--radius-md);
    margin-top: var(--space-4);
    position: relative;
    overflow: hidden;
}
.mv-weather-card::before {
    content: "";
    position: absolute;
    top: -40px; right: -40px;
    width: 140px; height: 140px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--mv-ochre) 0%, transparent 70%);
    opacity: 0.22;
    pointer-events: none;
}
.mv-weather-card > * { position: relative; z-index: 1; }
.mv-weather-card h4 {
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--mv-ochre);
    font-weight: 600;
    margin: 0 0 var(--space-3);
}
.mv-weather-card__temp {
    font-family: var(--font-display);
    font-size: 2.2rem;
    line-height: 1;
    color: var(--mv-bone);
    margin-bottom: var(--space-2);
}
.mv-weather-card__desc {
    font-family: var(--font-editorial);
    font-size: var(--text-sm);
    line-height: 1.5;
    color: rgba(251, 248, 243, 0.85);
    margin-bottom: var(--space-3);
}
.mv-weather-card__seasons {
    font-family: var(--font-ui);
    font-size: 0.8rem;
    color: rgba(251, 248, 243, 0.75);
    line-height: 1.55;
    padding-top: var(--space-3);
    border-top: 1px solid rgba(251, 248, 243, 0.15);
}
.mv-weather-card__seasons strong { color: var(--mv-ochre); font-weight: 600; }

/* ORNAMENT */
.mv-ornament {
    text-align: center;
    margin: var(--space-7) 0;
    color: var(--mv-stone);
    opacity: 0.5;
}
.mv-ornament svg { width: 28px; height: 28px; }

/* LIST HERO */
.mv-list-hero {
    background: var(--mv-deep-sea);
    color: var(--mv-bone);
    padding: var(--space-8) 0 var(--space-7);
    position: relative;
    overflow: hidden;
}
.mv-list-hero::before {
    content: "";
    position: absolute;
    top: -100px; right: -150px;
    width: 400px; height: 400px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--mv-ochre) 0%, transparent 65%);
    opacity: 0.18;
    pointer-events: none;
}
.mv-list-hero__inner { position: relative; z-index: 1; }
.mv-list-hero h1 {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 6vw, 4.2rem);
    color: var(--mv-bone);
    line-height: 1.05;
    margin: 0 0 var(--space-3);
    letter-spacing: -0.02em;
}
.mv-list-hero h1 em { color: var(--mv-ochre); font-style: italic; }
.mv-list-hero p {
    font-family: var(--font-editorial);
    font-size: var(--text-md);
    color: rgba(251, 248, 243, 0.85);
    max-width: 60ch;
    line-height: 1.55;
}

/* FILTER BAR */
.mv-filter-bar {
    background: var(--mv-bone);
    border-bottom: 1px solid var(--mv-pearl);
    position: sticky;
    top: 72px;
    z-index: 50;
    padding: var(--space-4) 0;
    backdrop-filter: saturate(180%) blur(8px);
    -webkit-backdrop-filter: saturate(180%) blur(8px);
}
.mv-filter-bar__inner {
    display: flex;
    gap: var(--space-4);
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
}
@media (max-width: 700px) {
    .mv-filter-bar { top: 64px; }
    .mv-filter-bar__inner { gap: var(--space-3); }
}

/* CHIPS */
.mv-chips {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
}
.mv-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: transparent;
    border: 1px solid var(--mv-pearl);
    border-radius: var(--radius-pill);
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: var(--mv-graphite);
    text-decoration: none;
    transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast);
}
.mv-chip:hover { background: var(--mv-foam); border-color: var(--mv-shallow); color: var(--mv-deep-sea); }
.mv-chip.is-active { background: var(--mv-deep-sea); border-color: var(--mv-deep-sea); color: var(--mv-bone); }
.mv-chip__count { font-size: 0.75rem; opacity: 0.7; font-family: var(--font-mono); }
.mv-chip.is-active .mv-chip__count { color: var(--mv-ochre); opacity: 1; }

/* LIST SEARCH */
.mv-list-search {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: 6px 14px;
    background: var(--mv-foam);
    border: 1px solid var(--mv-pearl);
    border-radius: var(--radius-pill);
    max-width: 280px;
    transition: border-color var(--t-fast);
}
.mv-list-search:focus-within { border-color: var(--mv-shallow); }
.mv-list-search svg { flex-shrink: 0; color: var(--mv-stone); }
.mv-list-search input {
    background: transparent;
    border: 0;
    outline: none;
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    flex: 1;
    color: var(--mv-deep-sea);
    min-width: 0;
}
.mv-list-search input::placeholder { color: var(--mv-stone); }

/* PAGINATION */
.mv-pagination {
    display: flex;
    gap: var(--space-2);
    justify-content: center;
    align-items: center;
    margin-top: var(--space-8);
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    flex-wrap: wrap;
}
.mv-pagination a, .mv-pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 10px;
    border: 1px solid var(--mv-pearl);
    border-radius: var(--radius-md);
    color: var(--mv-graphite);
    text-decoration: none;
    transition: background var(--t-fast), border-color var(--t-fast);
}
.mv-pagination a:hover { background: var(--mv-foam); border-color: var(--mv-shallow); color: var(--mv-deep-sea); }
.mv-pagination .is-current { background: var(--mv-deep-sea); border-color: var(--mv-deep-sea); color: var(--mv-bone); font-weight: 600; }
.mv-pagination .is-disabled { opacity: 0.4; cursor: default; }

/* EMPTY STATE */
.mv-empty {
    text-align: center;
    padding: var(--space-9) var(--gutter);
    color: var(--mv-graphite);
}
.mv-empty h2 {
    color: var(--mv-deep-sea);
    font-family: var(--font-display);
    font-size: var(--text-xl);
    margin-bottom: var(--space-3);
}
.mv-empty p {
    font-family: var(--font-editorial);
    font-size: var(--text-md);
    max-width: 50ch;
    margin: 0 auto var(--space-4);
    line-height: 1.55;
}

/* PROS/CONS */
.mv-prosconz {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
    margin: var(--space-5) 0;
}
@media (max-width: 700px) { .mv-prosconz { grid-template-columns: 1fr; } }
.mv-prosconz__box {
    padding: var(--space-5);
    border-radius: var(--radius-md);
    border: 1px solid var(--mv-pearl);
}
.mv-prosconz__box--pros { background: rgba(107, 122, 61, 0.08); border-color: rgba(107, 122, 61, 0.25); }
.mv-prosconz__box--cons { background: rgba(194, 102, 75, 0.08); border-color: rgba(194, 102, 75, 0.25); }
.mv-prosconz__title {
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    margin-bottom: var(--space-3);
}
.mv-prosconz__box--pros .mv-prosconz__title { color: var(--mv-olive); }
.mv-prosconz__box--cons .mv-prosconz__title { color: var(--mv-terra); }
.mv-prosconz__box ul, .mv-prosconz__box ol {
    margin: 0;
    padding-left: 1.2rem;
    color: var(--mv-graphite);
    font-family: var(--font-editorial);
    font-size: var(--text-sm);
    line-height: 1.55;
}
.mv-prosconz__box li { margin-bottom: 0.4rem; }
.mv-prosconz__box li:last-child { margin-bottom: 0; }
.mv-prosconz__box p {
    color: var(--mv-graphite);
    font-family: var(--font-editorial);
    font-size: var(--text-sm);
    line-height: 1.55;
    margin: 0 0 0.6rem;
}

/* VERDICT */
.mv-verdict {
    background: var(--mv-deep-sea);
    color: var(--mv-bone);
    padding: var(--space-7) var(--space-6);
    border-radius: var(--radius-md);
    margin: var(--space-7) 0;
    position: relative;
    overflow: hidden;
}
.mv-verdict::before {
    content: "";
    position: absolute;
    top: -80px; right: -80px;
    width: 250px; height: 250px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--mv-ochre) 0%, transparent 70%);
    opacity: 0.18;
    pointer-events: none;
}
.mv-verdict__inner { position: relative; z-index: 1; }
.mv-verdict__eyebrow {
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--mv-ochre);
    font-weight: 600;
    margin-bottom: var(--space-3);
    display: block;
}
.mv-verdict h3 {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    color: var(--mv-bone);
    margin-bottom: var(--space-3);
    line-height: 1.2;
}
.mv-verdict p, .mv-verdict div {
    font-family: var(--font-editorial);
    color: rgba(251, 248, 243, 0.88);
    line-height: 1.6;
    margin: 0 0 var(--space-3);
}
.mv-verdict p:last-child, .mv-verdict div:last-child { margin-bottom: 0; }
.mv-verdict strong { color: var(--mv-ochre); }

/* VS HERO */
.mv-vs-row {
    display: flex;
    align-items: baseline;
    gap: var(--space-3);
    margin-bottom: var(--space-3);
    flex-wrap: wrap;
}
.mv-vs-option {
    font-family: var(--font-display);
    font-size: clamp(2rem, 5vw, 3.5rem);
    color: var(--mv-bone);
    line-height: 1;
    letter-spacing: -0.02em;
}
.mv-vs-vs {
    font-family: var(--font-ui);
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.24em;
    color: var(--mv-ochre);
    padding: 4px 10px;
    border: 1px solid var(--mv-ochre);
    border-radius: var(--radius-pill);
}

/* HERO FALLBACK */
.mv-hero__bg--fallback,
.mv-city-hero__bg--fallback {
    background: linear-gradient(135deg, var(--mv-deep-sea) 0%, #133355 50%, #1a2a4a 100%);
}
.mv-hero__bg--fallback::after,
.mv-city-hero__bg--fallback::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 20% 30%, var(--mv-ochre) 0%, transparent 35%),
        radial-gradient(circle at 80% 70%, var(--mv-terra) 0%, transparent 40%);
    opacity: 0.22;
}

/* Gallery credits (Pixabay etc.) */
.mv-gallery__item {
    position: relative;
    overflow: hidden;
}
.mv-gallery__credits {
    position: absolute;
    bottom: 0;
    right: 0;
    padding: 4px 10px;
    background: rgba(10, 37, 64, 0.8);
    color: var(--mv-bone, #fbf8f3);
    font-family: var(--font-ui, system-ui), sans-serif;
    font-size: 0.7rem;
    opacity: 0;
    transition: opacity 200ms ease;
    pointer-events: none;
    border-radius: 2px 0 0 0;
}
.mv-gallery__item:hover .mv-gallery__credits { opacity: 1; }
