﻿/* ════════════════════════════════════════════════════════
   HERO
════════════════════════════════════════════════════════ */
.rates-hero {
    width: 100%;
    height: 52vh;
    min-height: 360px;
    background-size: cover;
    background-position: center;
    position: relative;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.rates-hero::before {
    content: "";
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    background: linear-gradient(
        to bottom,
        rgba(6, 10, 22, 0.38) 0%,
        rgba(6, 10, 22, 0.04) 45%,
        rgba(6, 10, 22, 0.62) 100%
    );
}

.rates-hero-label {
    position: relative;
    z-index: 2;
    text-align: center;
    padding-bottom: 56px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.rates-hero-eyebrow {
    font-family: "Jost", sans-serif;
    font-size: 0.60rem;
    letter-spacing: 0.30em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.50);
}

.rates-hero-title {
    font-family: "Playfair Display", serif;
    font-size: clamp(1.9rem, 4vw, 3.2rem);
    font-weight: 400;
    color: #ffffff;
    letter-spacing: 0.03em;
    line-height: 1.15;
    margin: 0;
}

.rates-hero-title em {
    font-family: "Cormorant Garamond", serif;
    font-style: italic;
    font-size: 1.1em;
}

/* ════════════════════════════════════════════════════════
   INTRO
════════════════════════════════════════════════════════ */
.rates-intro {
    background: #FDFAF5;
    padding: 88px max(5vw, 48px) 80px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
    max-width: 1280px;
    margin: 0 auto;
}

.rates-intro-quote {
    font-family: "Cormorant Garamond", serif;
    font-style: italic;
    font-size: clamp(1.4rem, 2.2vw, 1.9rem);
    color: #1B2744;
    line-height: 1.55;
    margin: 0 0 28px;
    letter-spacing: 0.01em;
}

.rates-intro-quote::before {
    content: "«\00a0";
    color: #C5B49A;
}

.rates-intro-quote::after {
    content: "\00a0»";
    color: #C5B49A;
}

/* ════════════════════════════════════════════════════════
   LES DEUX FORMULES
════════════════════════════════════════════════════════ */
.rates-formules-wrap {
    padding: 0 max(4vw, 28px) 80px;
    background: #FDFAF5;
}

.rates-formules {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-radius: 28px;
    overflow: hidden;
    box-shadow:
        0 8px 32px rgba(27, 39, 68, 0.06),
        0 24px 72px rgba(27, 39, 68, 0.08);
}

/* ── Carte privatisation pleine largeur ── */
.rates-formule-full {
    background: #1B2744;
    border-radius: 28px;
    overflow: hidden;
    display: grid;
    grid-template-columns: 5fr 7fr;
    box-shadow:
        0 8px 32px rgba(27, 39, 68, 0.10),
        0 24px 72px rgba(27, 39, 68, 0.14);
    position: relative;
}

.rates-formule-full::after {
    content: "Privatisation";
    position: absolute;
    bottom: -28px;
    right: -12px;
    font-family: "Cormorant Garamond", serif;
    font-style: italic;
    font-size: 96px;
    color: rgba(255, 255, 255, 0.03);
    line-height: 1;
    pointer-events: none;
    white-space: nowrap;
}

.rates-formule-full-left {
    background: #1B2744;
    padding: 64px 52px 60px 56px;
    display: flex;
    flex-direction: column;
    border-right: 1px solid rgba(255, 255, 255, 0.06);
}

.rates-formule-full-right {
    background: #243459;
    padding: 64px 56px 60px 52px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* Stats chiffrées */
.rates-formule-details {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px 32px;
    margin: 28px 0 0;
    padding: 28px 0 0;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.rates-formule-detail-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.rates-formule-detail-value {
    font-family: "Playfair Display", serif;
    font-size: 1.7rem;
    font-weight: 400;
    color: #ffffff;
    letter-spacing: 0.03em;
    line-height: 1;
}

.rates-formule-detail-label {
    font-family: "Jost", sans-serif;
    font-size: 0.58rem;
    letter-spacing: 0.20em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.38);
}

/* ── Ancienne grille 2 colonnes (conservée pour compat) ── */
.rates-formule {
    display: flex;
    flex-direction: column;
    padding: 64px 56px 60px;
    position: relative;
    overflow: hidden;
}

.rates-formule-icon {
    width: 48px;
    height: 48px;
    margin-bottom: 28px;
    flex-shrink: 0;
}

.rates-formule-label {
    font-family: "Jost", sans-serif;
    font-size: 0.58rem;
    letter-spacing: 0.26em;
    text-transform: uppercase;
    color: #C5B49A;
    margin-bottom: 12px;
    display: block;
}

.rates-formule--priv .rates-formule-label,
.rates-formule-full-left .rates-formule-label {
    color: rgba(197, 180, 154, 0.65);
}

.rates-formule-title {
    font-family: "Playfair Display", serif;
    font-size: clamp(1.5rem, 2.2vw, 2rem);
    font-weight: 400;
    color: #1B2744;
    margin: 0 0 8px;
    letter-spacing: 0.02em;
    line-height: 1.2;
}

.rates-formule--priv .rates-formule-title,
.rates-formule-full-left .rates-formule-title {
    color: #ffffff;
}

.rates-formule-title em {
    font-family: "Cormorant Garamond", serif;
    font-style: italic;
    font-size: 1.1em;
}

.rates-formule-price {
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2.2rem, 3.5vw, 3rem);
    font-weight: 400;
    color: #1B2744;
    letter-spacing: 0.02em;
    margin: 20px 0 4px;
    line-height: 1;
}

.rates-formule--priv .rates-formule-price,
.rates-formule-full-left .rates-formule-price {
    color: #ffffff;
}

.rates-formule-price-sub {
    font-family: "Jost", sans-serif;
    font-size: 0.62rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #8A94A6;
    margin-bottom: 28px;
    display: block;
}

.rates-formule--priv .rates-formule-price-sub,
.rates-formule-full-left .rates-formule-price-sub {
    color: rgba(255, 255, 255, 0.40);
}

.rates-formule-divider {
    width: 32px;
    height: 1px;
    background: rgba(197, 180, 154, 0.45);
    margin-bottom: 28px;
}

.rates-formule--priv .rates-formule-divider,
.rates-formule-full-left .rates-formule-divider {
    background: rgba(255, 255, 255, 0.15);
}

.rates-formule-desc {
    font-family: "Inter", sans-serif;
    font-size: 0.95rem;
    font-weight: 300;
    line-height: 1.9;
    color: #6B7A8D;
    margin: 0 0 auto;
    flex: 1;
}

.rates-formule--priv .rates-formule-desc,
.rates-formule-full-right .rates-formule-desc {
    color: rgba(255, 255, 255, 0.62);
}

.rates-formule-cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: "Jost", sans-serif;
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #1B2744;
    border: none;
    background: transparent;
    cursor: pointer;
    padding: 0;
    margin-top: 36px;
    border-bottom: 1px solid rgba(27, 39, 68, 0.28);
    padding-bottom: 3px;
    transition: opacity 0.25s ease;
}

.rates-formule--priv .rates-formule-cta,
.rates-formule-full-left .rates-formule-cta {
    color: #ffffff;
    border-bottom-color: rgba(255, 255, 255, 0.35);
}

.rates-formule-cta::after {
    content: "→";
    transition: transform 0.25s ease;
}

.rates-formule-cta:hover { opacity: 0.65; }
.rates-formule-cta:hover::after { transform: translateX(5px); }

/* ════════════════════════════════════════════════════════
   CE QUI EST INCLUS
════════════════════════════════════════════════════════ */
.rates-included {
    background: #F6F1EA;
    padding: 96px max(5vw, 48px) 104px;
}

.rates-included-header {
    text-align: center;
    max-width: 560px;
    margin: 0 auto 64px;
}

.rates-included-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    max-width: 1280px;
    margin: 0 auto;
}

.rates-included-item {
    background: #FDFAF5;
    border-radius: 18px;
    padding: 32px 28px 36px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    box-shadow: 0 2px 12px rgba(27, 39, 68, 0.04);
    transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.rates-included-item:hover {
    box-shadow: 0 6px 28px rgba(27, 39, 68, 0.08);
    transform: translateY(-2px);
}

.rates-included-icon {
    width: 40px;
    height: 40px;
    margin-bottom: 4px;
    flex-shrink: 0;
}

.rates-included-name {
    font-family: "Playfair Display", serif;
    font-size: 1rem;
    font-weight: 400;
    color: #1B2744;
    letter-spacing: 0.02em;
}

.rates-included-detail {
    font-family: "Inter", sans-serif;
    font-size: 0.85rem;
    font-weight: 300;
    line-height: 1.75;
    color: #6B7A8D;
    margin: 0;
}

/* ════════════════════════════════════════════════════════
   LES SAISONS
════════════════════════════════════════════════════════ */
.rates-seasons {
    background: #FDFAF5;
    padding: 96px max(5vw, 48px) 104px;
}

.rates-seasons-header {
    text-align: center;
    max-width: 560px;
    margin: 0 auto 64px;
}

.rates-seasons-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    max-width: 1100px;
    margin: 0 auto;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 4px 32px rgba(27, 39, 68, 0.07);
}

.rates-season {
    padding: 52px 44px 56px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: relative;
}

.rates-season--low  { background: #ffffff; }
.rates-season--mid  { background: #F6F1EA; }
.rates-season--high { background: #1B2744; }

.rates-season-name {
    font-family: "Jost", sans-serif;
    font-size: 0.60rem;
    letter-spacing: 0.26em;
    text-transform: uppercase;
    color: #C5B49A;
    display: block;
}

.rates-season--high .rates-season-name {
    color: rgba(197, 180, 154, 0.70);
}

.rates-season-period {
    font-family: "Playfair Display", serif;
    font-size: clamp(1.1rem, 1.6vw, 1.4rem);
    font-weight: 400;
    color: #1B2744;
    margin: 0;
    line-height: 1.3;
}

.rates-season--high .rates-season-period {
    color: #ffffff;
}

.rates-season-divider {
    width: 24px;
    height: 1px;
    background: rgba(197, 180, 154, 0.45);
}

.rates-season--high .rates-season-divider {
    background: rgba(255, 255, 255, 0.18);
}

.rates-season-desc {
    font-family: "Inter", sans-serif;
    font-size: 0.87rem;
    font-weight: 300;
    line-height: 1.82;
    color: #6B7A8D;
    margin: 0;
}

.rates-season--high .rates-season-desc {
    color: rgba(255, 255, 255, 0.58);
}

.rates-season-from {
    font-family: "Cormorant Garamond", serif;
    font-size: 1.6rem;
    font-style: italic;
    color: #1B2744;
    margin-top: auto;
    padding-top: 8px;
}

.rates-season--high .rates-season-from {
    color: rgba(255, 255, 255, 0.75);
}

.rates-season-from span {
    font-family: "Jost", sans-serif;
    font-style: normal;
    font-size: 0.60rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #8A94A6;
    display: block;
    margin-top: 4px;
}

.rates-season--high .rates-season-from span {
    color: rgba(255, 255, 255, 0.38);
}

/* ════════════════════════════════════════════════════════
   CONDITIONS
════════════════════════════════════════════════════════ */
.rates-conditions {
    background: #F6F1EA;
    padding: 88px max(5vw, 48px) 96px;
}

.rates-conditions-header {
    text-align: center;
    max-width: 560px;
    margin: 0 auto 56px;
}

.rates-conditions-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    max-width: 1100px;
    margin: 0 auto;
}

.rates-condition {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding-top: 24px;
    border-top: 1px solid rgba(197, 180, 154, 0.35);
}

.rates-condition-title {
    font-family: "Playfair Display", serif;
    font-size: 1.05rem;
    font-weight: 400;
    color: #1B2744;
    margin: 0;
}

.rates-condition-text {
    font-family: "Inter", sans-serif;
    font-size: 0.90rem;
    font-weight: 300;
    line-height: 1.85;
    color: #6B7A8D;
    margin: 0;
}

/* ════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
    .rates-included-grid { grid-template-columns: repeat(2, 1fr); }
    .rates-formule { padding: 52px 44px 48px; }
    .rates-formule-full-left,
    .rates-formule-full-right { padding: 52px 40px 48px; }
}

@media (max-width: 900px) {
    .rates-intro {
        grid-template-columns: 1fr;
        gap: 36px;
        padding: 64px 24px 56px;
    }

    .rates-formules { grid-template-columns: 1fr; border-radius: 20px; }
    .rates-formule-full { grid-template-columns: 1fr; border-radius: 20px; }
    .rates-formule-full-left { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.06); }
    .rates-formule-full-left,
    .rates-formule-full-right { padding: 44px 28px 40px; }
    .rates-formule--suite::after,
    .rates-formule--priv::after,
    .rates-formule-full::after { display: none; }

    .rates-seasons-grid {
        grid-template-columns: 1fr;
        border-radius: 20px;
    }

    .rates-conditions-list { grid-template-columns: 1fr; gap: 24px; }
}

@media (max-width: 768px) {
    .rates-included-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
    .rates-formule { padding: 44px 28px 40px; }
    .rates-season { padding: 40px 28px 44px; }
    .rates-conditions { padding: 64px 20px 72px; }
    .rates-included { padding: 72px 20px 80px; }
    .rates-seasons { padding: 72px 20px 80px; }
}

@media (max-width: 480px) {
    .rates-included-grid { grid-template-columns: 1fr; }
    .rates-hero { height: 48vh; min-height: 300px; }
}
