/* MILF Rencontre — Théme "Bordeaux Allure" (sophistiqué mature) */
:root {
    --fc-burgundy: #7a1f2a;          /* bordeaux profond */
    --fc-burgundy-dk: #4a0f18;       /* bordeaux nuit */
    --fc-gold: #b8843b;              /* bronze cuivre */
    --fc-gold-dk: #8a5e25;
    --fc-bronze: #a06934;
    --fc-cream: #f6efe3;             /* cream ivoire */
    --fc-paper: #fbf7ee;             /* ivoire warm */
    --fc-ink: #1f1410;               /* espresso */
    --fc-ink-soft: #6b4e3e;
    --fc-line: #e2cfb1;              /* bronze fade ligne */
    --fc-shadow: 0 6px 24px rgba(74, 15, 24, .12);
    --fc-grad: linear-gradient(135deg, #7a1f2a 0%, #b8843b 100%);
}
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,600;0,700;1,500;1,600&family=Lora:wght@400;500;600&display=swap');
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: 'Lora', Georgia, 'Iowan Old Style', 'Palatino Linotype', serif;
    color: var(--fc-ink);
    background: var(--fc-paper);
    line-height: 1.7;
    font-size: 17px;
}
h1, h2, h3 { font-family: 'Playfair Display', Georgia, serif; font-weight: 600; }
h1 { letter-spacing: -0.5px; }
img { max-width: 100%; height: auto; }
a { color: var(--fc-burgundy-dk); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(184, 132, 59, 0.4); }
a:hover { color: var(--fc-burgundy); text-decoration-color: var(--fc-gold); }
/* Bronze accent CTAs */
.fc-hero-cta { background: var(--fc-gold) !important; color: var(--fc-paper) !important; box-shadow: 0 4px 16px rgba(184, 132, 59, 0.3); }
.fc-hero-cta:hover { background: var(--fc-gold-dk) !important; color: var(--fc-paper) !important; }
.fc-nav { background: var(--fc-cream) !important; border-bottom: 2px solid var(--fc-gold) !important; }
.fc-logo-mark { background: var(--fc-burgundy) !important; color: var(--fc-gold) !important; }

/* Nav */
.fc-nav { background: #fff; border-bottom: 1px solid var(--fc-line); position: sticky; top: 0; z-index: 100; }
.fc-nav-inner { max-width: 1100px; margin: 0 auto; padding: 14px 20px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.fc-logo { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; color: var(--fc-ink); font-weight: 700; font-size: 1.1rem; }
.fc-logo-mark { display: inline-grid; place-items: center; width: 34px; height: 34px; border-radius: 50%; background: var(--fc-burgundy); color: var(--fc-cream); font-family: Georgia, serif; font-weight: 700; }
.fc-nav nav { display: flex; gap: 18px; }
.fc-nav nav a { font-family: system-ui, sans-serif; font-size: .95rem; text-decoration: none; color: var(--fc-ink-soft); }
.fc-nav nav a:hover { color: var(--fc-burgundy); }

/* Hero */
.fc-hero { position: relative; min-height: 56vh; max-height: 620px; display: grid; place-items: center; overflow: hidden; }
.fc-hero::before {
    content: ''; position: absolute; inset: 0;
    background-image: var(--fc-hero-bg, url('/assets/img/cities/france_home_hero.jpg'));
    background-size: cover; background-position: center;
    filter: brightness(.55);
}
.fc-hero-content { position: relative; max-width: 880px; padding: 64px 22px; color: #fff; text-align: center; }
.fc-hero h1 { font-size: clamp(1.9rem, 5vw, 3.2rem); margin: 0 0 14px; line-height: 1.15; text-shadow: 0 2px 12px rgba(0,0,0,.55); }
.fc-hero p.lede { font-size: clamp(1.05rem, 2vw, 1.25rem); margin: 0 0 24px; opacity: .95; text-shadow: 0 1px 6px rgba(0,0,0,.5); }
.fc-hero-cta { display: inline-block; background: var(--fc-gold); color: var(--fc-ink); padding: 14px 28px; border-radius: 6px; font-weight: 700; text-decoration: none; font-family: system-ui, sans-serif; transition: transform .15s; }
.fc-hero-cta:hover { transform: translateY(-2px); color: var(--fc-ink); }

/* Containers */
.fc-wrap { max-width: 1080px; margin: 0 auto; padding: 0 22px; }
.fc-section { padding: 56px 0; }
.fc-section h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); margin: 0 0 12px; color: var(--fc-burgundy-dk); }
.fc-section h2::after { content: ''; display: block; width: 60px; height: 3px; background: var(--fc-gold); margin: 10px 0 22px; }
.fc-section h3 { color: var(--fc-burgundy-dk); margin-top: 1.8em; }
.fc-section p, .fc-section li { font-size: 1.05rem; }

/* Offer cards */
.fc-offers { background: var(--fc-cream); padding: 56px 0; }
.fc-offers-head { max-width: 1080px; margin: 0 auto 32px; padding: 0 22px; text-align: center; }
.fc-offers-head h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); margin: 0 0 12px; color: var(--fc-burgundy-dk); }
.fc-offers-intro { color: var(--fc-ink-soft); max-width: 680px; margin: 0 auto; }
.fc-offers-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: 22px; max-width: 1080px; margin: 0 auto; padding: 0 22px; }
.fc-offer-card { position: relative; background: #fff; border: 1px solid var(--fc-line); border-radius: 10px; padding: 24px 22px 22px; box-shadow: var(--fc-shadow); display: flex; flex-direction: column; }
.fc-offer-rank { position: absolute; top: -14px; left: 22px; background: var(--fc-burgundy); color: #fff; padding: 6px 12px; border-radius: 20px; font-family: system-ui, sans-serif; font-weight: 700; font-size: .85rem; }
.fc-offer-badge { font-family: system-ui, sans-serif; font-size: .8rem; color: var(--fc-gold); font-weight: 700; margin-bottom: 8px; letter-spacing: .02em; }
.fc-offer-card h3 { margin: 6px 0 6px; font-size: 1.35rem; color: var(--fc-ink); }
.fc-offer-tagline { font-style: italic; color: var(--fc-ink-soft); margin: 0 0 14px; min-height: 3em; }
.fc-offer-rating { display: flex; align-items: center; gap: 8px; margin: 6px 0 14px; font-family: system-ui, sans-serif; }
.fc-stars { color: var(--fc-gold); font-size: 1.05rem; letter-spacing: 1px; }
.fc-rating-num { color: var(--fc-ink-soft); font-size: .9rem; font-weight: 600; }
.fc-offer-why { font-size: .98rem; margin: 0 0 12px; }
.fc-offer-feat { list-style: none; padding: 0; margin: 0 0 14px; font-family: system-ui, sans-serif; font-size: .92rem; color: var(--fc-ink-soft); }
.fc-offer-feat li { padding: 3px 0; }
.fc-offer-price { font-size: .92rem; color: var(--fc-ink-soft); margin: 0 0 16px; font-family: system-ui, sans-serif; }
.fc-offer-cta { display: block; text-align: center; background: var(--fc-burgundy); color: #fff !important; padding: 12px 18px; border-radius: 6px; font-weight: 700; text-decoration: none; font-family: system-ui, sans-serif; margin-top: auto; transition: background .15s; }
.fc-offer-cta:hover { background: var(--fc-burgundy-dk); }
.fc-offers-disclaimer { max-width: 760px; margin: 28px auto 0; padding: 0 22px; font-size: .85rem; color: var(--fc-ink-soft); text-align: center; font-family: system-ui, sans-serif; }

/* FAQ */
.fc-faq details { background: #fff; border: 1px solid var(--fc-line); border-radius: 8px; padding: 14px 18px; margin-bottom: 10px; }
.fc-faq summary { cursor: pointer; font-weight: 700; color: var(--fc-burgundy-dk); }
.fc-faq details[open] summary { margin-bottom: 10px; }

/* Internal links grid */
.fc-link-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; margin: 18px 0 0; font-family: system-ui, sans-serif; font-size: .95rem; }
.fc-link-grid a { background: #fff; border: 1px solid var(--fc-line); border-radius: 6px; padding: 10px 14px; text-decoration: none; color: var(--fc-ink); }
.fc-link-grid a:hover { border-color: var(--fc-burgundy); color: var(--fc-burgundy-dk); }

/* Footer */
.fc-foot { background: var(--fc-ink); color: var(--fc-cream); padding: 48px 0 24px; margin-top: 48px; }
.fc-foot-inner { max-width: 1080px; margin: 0 auto; padding: 0 22px; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 32px; }
.fc-foot h4 { color: var(--fc-gold); font-size: 1rem; margin: 0 0 14px; letter-spacing: .04em; text-transform: uppercase; font-family: system-ui, sans-serif; }
.fc-foot ul { list-style: none; padding: 0; margin: 0; font-family: system-ui, sans-serif; font-size: .92rem; }
.fc-foot li { padding: 4px 0; }
.fc-foot a { color: var(--fc-cream); text-decoration: none; opacity: .85; }
.fc-foot a:hover { opacity: 1; color: var(--fc-gold); }
.fc-foot-mini { font-size: .82rem; opacity: .65; margin-top: 12px; font-family: system-ui, sans-serif; }
.fc-foot p { font-family: system-ui, sans-serif; font-size: .92rem; }

@media (max-width: 640px) {
    .fc-hero { min-height: 48vh; }
    .fc-section { padding: 40px 0; }
    .fc-nav nav { font-size: .88rem; gap: 14px; }
}
