/* villes.css — pages locales "acheter un matelas" (conversion / affiliation). DA nocturne dark. */

.v-hero { position: relative; padding: 3.5rem 0 1.5rem; overflow: hidden; }
.v-hero::before { content: ""; position: absolute; top: -120px; left: 50%; transform: translateX(-50%); width: 520px; height: 300px; pointer-events: none; background: radial-gradient(ellipse at center, rgba(201,162,75,.18) 0%, rgba(201,162,75,0) 70%); }
.v-hero > .container { position: relative; z-index: 1; }
.v-breadcrumb { font-size: .82rem; color: var(--text-muted, #9AA3B5); margin-bottom: 1rem; }
.v-breadcrumb a { color: var(--text-light, #9AA3B5); }
.v-breadcrumb a:hover { color: var(--primary, #C9A24B); }
.v-hero h1 { font-size: 2.5rem; line-height: 1.18; max-width: 760px; margin-bottom: .8rem; }
.v-hero .sub { color: var(--text-light, #9AA3B5); font-size: 1.12rem; line-height: 1.6; max-width: 680px; }

.v-wrap { max-width: 880px; margin: 0 auto; padding: 0 20px; }
.v-band { padding: 3.25rem 0; }
.v-band--indigo { background: linear-gradient(180deg, #151A36 0%, #11182E 100%); border-top: 1px solid rgba(201,162,75,.16); border-bottom: 1px solid rgba(201,162,75,.07); }
.v-band--deep { background: #0C1428; border-top: 1px solid rgba(201,162,75,.16); }
.v-band--warm { background: linear-gradient(135deg, #1C2746 0%, #1F1B12 100%); border-top: 1px solid rgba(201,162,75,.16); }

.v-h2 { font-size: 1.8rem; margin-bottom: 1rem; }
.v-h2.center { text-align: center; }
.v-lead { font-size: 1.12rem; color: var(--text, #F4EFE6); line-height: 1.85; margin-bottom: 1.1rem; }
.v-p { line-height: 1.85; margin-bottom: 1.1rem; color: var(--text-secondary, #C8CEDA); }

/* Méthode (étapes numérotées) */
.v-steps { counter-reset: vstep; display: grid; gap: .8rem; margin: 1.5rem 0; }
.v-steps li { list-style: none; counter-increment: vstep; position: relative; padding: 1.1rem 1.3rem 1.1rem 3.6rem; border: 1px solid var(--border, #2E4163); border-radius: 10px; background: var(--surface, #1A2C4E); }
.v-steps li::before { content: counter(vstep); position: absolute; left: 1rem; top: 1.05rem; width: 1.9rem; height: 1.9rem; border-radius: 50%; background: var(--primary, #C9A24B); color: var(--on-primary, #11203F); font-family: var(--font-serif, 'Fraunces', serif); font-weight: 700; display: flex; align-items: center; justify-content: center; }
.v-steps b { display: block; margin-bottom: .15rem; }
.v-steps span { color: var(--text-secondary, #C8CEDA); font-size: .93rem; line-height: 1.5; }
.v-steps a { color: var(--primary, #C9A24B); font-weight: 600; }

/* Comparaison magasin / en ligne */
.v-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin: 1.5rem 0; }
@media (max-width: 620px) { .v-compare { grid-template-columns: 1fr; } }
.v-col { border: 1px solid var(--border, #2E4163); border-radius: var(--radius, 12px); padding: 1.4rem 1.5rem; background: var(--surface, #1A2C4E); }
.v-col h3 { font-size: 1.2rem; margin-bottom: .9rem; display: flex; align-items: center; gap: .5rem; }
.v-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; }
.v-col li { padding-left: 1.5rem; position: relative; line-height: 1.5; font-size: .94rem; color: var(--text-secondary, #C8CEDA); }
.v-col li.pro::before { content: "\2713"; position: absolute; left: 0; color: #7FD18C; font-weight: 700; }
.v-col li.con::before { content: "\2013"; position: absolute; left: 0; color: #E0A06B; font-weight: 700; }

/* Réassurance (check-list) */
.v-reassure { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 1rem; margin-top: 1.25rem; }
.v-reassure .item { border: 1px solid var(--border, #2E4163); border-left: 3px solid var(--primary, #C9A24B); border-radius: 0 8px 8px 0; padding: 1rem 1.2rem; background: rgba(28,39,70,.5); }
.v-reassure .item b { display: block; margin-bottom: .25rem; }
.v-reassure .item span { color: var(--text-secondary, #C8CEDA); font-size: .9rem; line-height: 1.5; }

/* CTA marques (affiliation) */
.v-brands { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 1rem; margin: 1.25rem 0; }
.v-brand { display: flex; flex-direction: column; gap: .5rem; padding: 1.2rem 1.3rem; border: 1px solid var(--border, #2E4163); border-radius: var(--radius, 12px); background: var(--surface, #1A2C4E); transition: all .18s; }
.v-brand:hover { border-color: var(--primary, #C9A24B); transform: translateY(-2px); }
.v-brand .name { font-size: 1.15rem; font-weight: 700; color: var(--text, #F4EFE6); }
.v-brand .badges { display: flex; flex-wrap: wrap; gap: .3rem; }
.v-brand .b { font-size: .68rem; padding: .15rem .5rem; border-radius: 999px; border: 1px solid var(--border, #2E4163); color: var(--text-muted, #9AA3B5); }
.v-brand .b.fr { color: #9FE0AB; border-color: #2F5638; }
.v-brand .b.trial { color: #E8C77A; border-color: #4A3F1C; }
.v-brand .go { margin-top: auto; color: var(--primary, #C9A24B); font-weight: 600; font-size: .9rem; }

.v-disclosure { background: #2A2410; color: #E8C77A; border: 1px solid #4A3F1C; border-radius: 8px; padding: .9rem 1.2rem; font-size: .86rem; line-height: 1.6; margin: 1rem 0; }

.v-cta-box { text-align: center; max-width: 640px; margin: 0 auto; }
.v-cta-box h2 { font-size: 1.9rem; margin-bottom: .7rem; }
.v-cta-box p { color: var(--text-light, #9AA3B5); font-size: 1.08rem; line-height: 1.6; margin-bottom: 1.4rem; }
.v-cta-actions { display: flex; flex-wrap: wrap; gap: .8rem; justify-content: center; }
.btn-ghost { display: inline-flex; align-items: center; padding: .9rem 1.7rem; border: 1px solid rgba(244,239,230,.35); border-radius: 4px; color: var(--white, #fff); font-weight: 600; transition: all .2s; }
.btn-ghost:hover { background: rgba(244,239,230,.1); border-color: var(--white, #fff); }

/* FAQ */
.v-faq details { border-bottom: 1px solid var(--border, #2E4163); padding: .9rem 0; }
.v-faq summary { cursor: pointer; font-weight: 600; font-size: 1.05rem; list-style: none; display: flex; justify-content: space-between; gap: 1rem; }
.v-faq summary::-webkit-details-marker { display: none; }
.v-faq summary::after { content: "+"; color: var(--primary, #C9A24B); font-size: 1.4rem; line-height: 1; }
.v-faq details[open] summary::after { content: "\2013"; }
.v-faq p { margin: .8rem 0 .2rem; color: var(--text-secondary, #C8CEDA); line-height: 1.7; }

/* Annuaire (listing /villes) */
.v-regions { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 1.25rem; }
.v-region { background: var(--surface, #1A2C4E); border: 1px solid var(--border, #2E4163); border-radius: var(--radius, 12px); padding: 1.4rem 1.5rem; }
.v-region h2 { color: var(--primary, #C9A24B); font-size: 1.25rem; padding-bottom: .5rem; margin-bottom: 1rem; border-bottom: 1px solid var(--border, #2E4163); }
.v-dept { margin-bottom: 1.1rem; }
.v-dept h3 { font-size: .95rem; margin-bottom: .4rem; color: var(--text, #F4EFE6); }
.v-dept ul { list-style: none; padding: 0; margin: 0; }
.v-dept li { margin-bottom: .25rem; }
.v-dept a { font-size: .9rem; color: var(--text-light, #9AA3B5); }
.v-dept a:hover { color: var(--primary, #C9A24B); }

@media (max-width: 600px) { .v-hero h1 { font-size: 2rem; } .v-h2 { font-size: 1.5rem; } }
