/* ============================================================
   Channel Manager Georgi Invest — Site public de réservation
   Charte alignée sur georgi-invest.com (noir + or, élégant)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Raleway:wght@300;400;500;600;700&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&display=swap');

:root {
  --color-bg-dark:       #0a0a0a;
  --color-bg-section:    #111111;
  --color-bg-card:       #1a1a1a;
  --color-bg-card-hover: #222222;
  --color-bg-input:      #161616;
  --color-gold:          #c6a057;
  --color-gold-light:    #ded594;
  --color-gold-dark:     #9a7a3a;
  --color-white:         #ffffff;
  --color-text:          #d4d4d4;
  --color-text-muted:    #999999;
  --color-border:        #2a2a2a;
  --color-border-gold:   rgba(198, 160, 87, 0.3);
  --color-success:       #4caf50;
  --color-danger:        #e53935;

  --font-heading: 'Playfair Display', Georgia, serif;
  --font-body:    'Raleway', 'Segoe UI', sans-serif;
  --font-accent:  'Cormorant Garamond', Georgia, serif;
  --max-width: 1200px;
  --radius: 3px;
  --transition: all .3s ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; overflow-x: hidden; }
body {
  font-family: var(--font-body);
  background: var(--color-bg-dark);
  color: var(--color-text);
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}
a { color: var(--color-gold); text-decoration: none; transition: var(--transition); }
a:hover { color: var(--color-gold-light); }
img { max-width: 100%; height: auto; display: block; }
ul { list-style: none; }

h1, h2, h3, h4 { font-family: var(--font-heading); color: var(--color-white); line-height: 1.3; font-weight: 600; }
h1 { font-size: clamp(2rem, 5vw, 3.4rem); font-weight: 700; }
h2 { font-size: clamp(1.6rem, 4vw, 2.5rem); }
h3 { font-size: clamp(1.15rem, 2.5vw, 1.5rem); }

.container { max-width: var(--max-width); margin: 0 auto; padding: 0 1.5rem; }

.subtitle {
  font-family: var(--font-accent);
  font-size: 1.1rem; color: var(--color-gold);
  text-transform: uppercase; letter-spacing: 3px; font-weight: 500;
}
.gold-line {
  width: 60px; height: 2px;
  background: linear-gradient(90deg, var(--color-gold-dark), var(--color-gold-light));
  margin: 1rem 0 1.8rem;
}
.gold-line.center { margin-left: auto; margin-right: auto; }

/* ─── Boutons ──────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: 14px 32px;
  border-radius: var(--radius);
  font-family: var(--font-body); font-size: .82rem; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase;
  cursor: pointer; border: 1px solid transparent; transition: var(--transition);
}
.btn-primary {
  background: linear-gradient(135deg, var(--color-gold-dark), var(--color-gold));
  color: var(--color-bg-dark);
}
.btn-primary:hover {
  background: linear-gradient(135deg, var(--color-gold), var(--color-gold-light));
  color: var(--color-bg-dark); transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(198,160,87,.3);
}
.btn-outline { background: transparent; color: var(--color-gold); border-color: var(--color-gold); }
.btn-outline:hover { background: var(--color-gold); color: var(--color-bg-dark); }
.btn-block { width: 100%; }
.btn-lg { padding: 16px 40px; font-size: .9rem; }

/* ─── Header ───────────────────────────────────────────── */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(10,10,10,.95);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--color-border);
}
.site-header .container {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 1rem; padding-bottom: 1rem;
  flex-wrap: wrap; gap: .8rem;
}
.site-logo { display: flex; align-items: center; gap: .7rem; }
.site-logo .mark {
  width: 40px; height: 40px; display: grid; place-items: center;
  background: linear-gradient(135deg, var(--color-gold-dark), var(--color-gold));
  color: var(--color-bg-dark); font-family: var(--font-heading); font-weight: 700;
  font-size: 1.3rem; border-radius: var(--radius);
}
.site-logo .text { font-family: var(--font-heading); color: var(--color-white); font-size: 1.1rem; }
.site-logo .text small {
  display: block; font-family: var(--font-accent); color: var(--color-gold);
  font-size: .72rem; letter-spacing: 2px; text-transform: uppercase;
}
.header-tools { display: flex; align-items: center; gap: 1rem; }

/* Sélecteur de langue — boutons texte élégants (style theplacetobe) */
.lang-bar { display: flex; gap: .3rem; flex-wrap: wrap; }
.lang-btn {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-size: .72rem;
  font-weight: 500;
  letter-spacing: .12em;
  padding: .35rem .6rem;
  cursor: pointer;
  transition: var(--transition);
  border-radius: 2px;
  text-transform: uppercase;
  text-decoration: none;
  line-height: 1;
}
.lang-btn:hover { border-color: var(--color-gold); color: var(--color-gold); }
.lang-btn.active {
  background: var(--color-gold);
  color: var(--color-bg-dark);
  border-color: var(--color-gold);
  font-weight: 600;
}

/* Sélecteur de devise — petit toggle assorti */
.currency-toggle { display: flex; gap: .3rem; }
.currency-btn {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-size: .72rem;
  font-weight: 500;
  letter-spacing: .08em;
  padding: .35rem .55rem;
  cursor: pointer;
  transition: var(--transition);
  border-radius: 2px;
  text-decoration: none;
  line-height: 1;
}
.currency-btn:hover { border-color: var(--color-gold); color: var(--color-gold); }
.currency-btn.active {
  background: rgba(198,160,87,.15);
  color: var(--color-gold);
  border-color: var(--color-gold);
}

/* Cadenas admin discret (coin bas-droite) — style theplacetobe */
.admin-lock {
  position: fixed;
  bottom: 18px; right: 18px;
  width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(198,160,87,0.4);
  border: 1px solid transparent;
  border-radius: 50%;
  transition: color .2s, border-color .2s, background .2s;
  z-index: 200;
}
.admin-lock:hover {
  color: var(--color-gold);
  border-color: rgba(198,160,87,0.5);
  background: rgba(198,160,87,0.08);
}
.admin-lock svg { width: 18px; height: 18px; }

/* ─── Hero ─────────────────────────────────────────────── */
.hero {
  min-height: 70vh;
  display: flex; align-items: center;
  background: radial-gradient(ellipse at 50% 0%, #1c1c1c 0%, #0a0a0a 65%);
  text-align: center;
  padding: 4rem 1.5rem;
}
.hero-content { max-width: 760px; margin: 0 auto; }
.hero h1 { margin: .5rem 0 1rem; }
.hero h1 span { color: var(--color-gold); }
.hero p { color: var(--color-text-muted); font-size: 1.1rem; margin-bottom: 2rem; }

/* ─── Sections ─────────────────────────────────────────── */
section { padding: 4rem 0; }
.section-head { text-align: center; margin-bottom: 3rem; }
.bg-section { background: var(--color-bg-section); }

/* ─── Grille d'appartements ────────────────────────────── */
.apartments-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 2rem;
}
.apt-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: var(--transition);
  display: flex; flex-direction: column;
}
.apt-card:hover {
  border-color: var(--color-border-gold);
  transform: translateY(-4px);
  box-shadow: 0 12px 35px rgba(0,0,0,.5);
}
.apt-card .photo {
  aspect-ratio: 4 / 3; overflow: hidden; background: var(--color-bg-section);
  position: relative;
}
.apt-card .photo img { width: 100%; height: 100%; object-fit: cover; transition: var(--transition); }
.apt-card:hover .photo img { transform: scale(1.05); }
.apt-card .photo .no-photo {
  width: 100%; height: 100%; display: grid; place-items: center;
  color: var(--color-border); font-size: 3rem;
}
.apt-card .body { padding: 1.5rem; display: flex; flex-direction: column; flex: 1; }
.apt-card .body h3 { margin-bottom: .4rem; }
.apt-card .location {
  font-family: var(--font-accent); color: var(--color-gold);
  font-size: .95rem; letter-spacing: 1px; margin-bottom: .8rem;
}
.apt-card .excerpt { color: var(--color-text-muted); font-size: .92rem; margin-bottom: 1rem; flex: 1; }
.apt-card .meta {
  display: flex; gap: 1rem; flex-wrap: wrap;
  font-size: .82rem; color: var(--color-text-muted);
  padding-top: 1rem; border-top: 1px solid var(--color-border); margin-bottom: 1rem;
}
.apt-card .price-row { display: flex; align-items: baseline; justify-content: space-between; }
.apt-card .price { font-family: var(--font-heading); color: var(--color-gold); font-size: 1.5rem; font-weight: 600; }
.apt-card .price small { font-size: .8rem; color: var(--color-text-muted); font-weight: 400; }
.apt-card .price .from-label { font-family: var(--font-accent); font-size: .85rem; text-transform: uppercase; letter-spacing: 1px; }

/* ─── Page détail appartement ──────────────────────────── */
/* Galerie : chaque photo avec sa légende sous l'image */
.apt-photos {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.2rem;
  margin-bottom: 2.5rem;
}
.apt-photo {
  margin: 0;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
}
.apt-photo img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}
.apt-photo figcaption {
  padding: .7rem .9rem;
  font-family: var(--font-accent);
  font-size: 1rem;
  color: var(--color-text);
  line-height: 1.4;
  border-top: 1px solid var(--color-border);
}
/* La première photo occupe toute la largeur (visuel d'accroche) */
.apt-photo-hero { grid-column: 1 / -1; }
.apt-photo-hero img { aspect-ratio: 16 / 9; }
.apt-photo-hero figcaption { font-size: 1.1rem; color: var(--color-gold); }

/* Photos cliquables → visionneuse plein écran */
.apt-photo { cursor: zoom-in; }
.apt-photo img { transition: var(--transition); }
.apt-photo:hover img { opacity: .85; }
.apt-photo:focus-visible { outline: 2px solid var(--color-gold); outline-offset: 3px; }

.apt-lightbox {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(8, 8, 8, .96);
  display: flex; align-items: center; justify-content: center;
}
.apt-lightbox[hidden] { display: none; }
.apt-lb-figure {
  margin: 0; display: flex; flex-direction: column;
  align-items: center; gap: .9rem;
}
.apt-lb-figure img {
  max-width: 92vw; max-height: 80vh;
  object-fit: contain;
  border: 1px solid var(--color-border-gold);
  box-shadow: 0 24px 70px rgba(0, 0, 0, .65);
}
.apt-lb-figure figcaption {
  color: var(--color-text); font-family: var(--font-accent);
  font-size: 1.05rem; text-align: center; max-width: 80vw;
}
.apt-lb-close, .apt-lb-nav {
  position: absolute;
  display: flex; align-items: center; justify-content: center;
  background: rgba(20, 20, 20, .75);
  border: 1px solid var(--color-border-gold);
  color: var(--color-gold); cursor: pointer;
  transition: var(--transition); line-height: 1;
}
.apt-lb-close:hover, .apt-lb-nav:hover {
  background: var(--color-gold); color: var(--color-bg-dark);
}
.apt-lb-close {
  top: 1.2rem; right: 1.2rem;
  width: 46px; height: 46px; border-radius: 50%; font-size: 1.6rem;
}
.apt-lb-nav {
  top: 50%; transform: translateY(-50%);
  width: 54px; height: 54px; border-radius: 50%; font-size: 2rem;
}
.apt-lb-prev { left: 1.4rem; }
.apt-lb-next { right: 1.4rem; }
.apt-lb-counter {
  position: absolute; bottom: 1.4rem; left: 50%; transform: translateX(-50%);
  color: var(--color-text-muted); font-family: var(--font-accent);
  letter-spacing: 2px; font-size: .9rem;
}
@media (max-width: 600px) {
  .apt-lb-nav { width: 44px; height: 44px; font-size: 1.6rem; }
  .apt-lb-prev { left: .5rem; }
  .apt-lb-next { right: .5rem; }
  .apt-lb-close { top: .6rem; right: .6rem; }
  .apt-lb-figure img { max-height: 74vh; }
}

.apt-detail-layout {
  display: grid; grid-template-columns: 1fr 380px; gap: 2.5rem; align-items: start;
}
.apt-info h1 { margin-bottom: .3rem; }
.apt-info .location { font-family: var(--font-accent); color: var(--color-gold); font-size: 1.1rem; letter-spacing: 1px; }
.apt-features {
  display: flex; gap: 1.5rem; flex-wrap: wrap;
  padding: 1.2rem 0; margin: 1.5rem 0;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
.apt-feature { text-align: center; }
.apt-feature .num { font-family: var(--font-heading); color: var(--color-white); font-size: 1.4rem; }
.apt-feature .lbl { font-size: .78rem; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 1px; }
.apt-description { color: var(--color-text); white-space: pre-wrap; line-height: 1.8; margin-bottom: 2rem; }
.apt-section { margin-bottom: 1.5rem; scroll-margin-top: 90px; }
.apt-section h3 { margin-bottom: 0; }

/* Section Localisation : carte OpenStreetMap + adresse */
.apt-location .gold-line { margin-bottom: 1rem; }
.apt-map {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: .9rem;
}
.apt-map iframe {
  display: block;
  width: 100%;
  height: 340px;
  border: 0;
}
.apt-map-foot {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 1rem 1.5rem; flex-wrap: wrap;
  margin-bottom: 1rem;
}
.apt-address {
  display: flex; flex-direction: column; gap: .15rem;
  color: var(--color-text); line-height: 1.55;
}
.apt-address-label {
  font-family: var(--font-accent);
  color: var(--color-gold);
  text-transform: uppercase;
  font-size: .72rem; letter-spacing: 2px;
  margin-bottom: .2rem;
}
.apt-map-link { font-size: .85rem; white-space: nowrap; }
@media (max-width: 600px) {
  .apt-map iframe { height: 260px; }
}

/* Barre de navigation haut de page appartement (Retour + menu sections) */
.apt-topnav {
  display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap;
  padding-bottom: .8rem; margin-bottom: .5rem;
}
.apt-back { font-size: .85rem; white-space: nowrap; }
.apt-section-nav {
  display: flex; gap: .4rem; flex-wrap: wrap;
  padding-left: 1.2rem;
  border-left: 1px solid var(--color-border);
}
.apt-section-nav a {
  font-family: var(--font-body);
  font-size: .75rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  border-radius: 2px;
  padding: .35rem .7rem;
  transition: var(--transition);
}
.apt-section-nav a:hover {
  border-color: var(--color-gold);
  color: var(--color-gold);
}
@media (max-width: 600px) {
  .apt-section-nav { padding-left: 0; border-left: none; }
}

.amenities-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: .6rem; }
.amenity {
  display: flex; align-items: center; gap: .5rem;
  color: var(--color-text); font-size: .92rem;
}
.amenity::before { content: '◆'; color: var(--color-gold); font-size: .7rem; }

/* ─── Widget de réservation ────────────────────────────── */
.booking-widget {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-gold);
  border-radius: var(--radius);
  padding: 1.8rem;
  position: sticky; top: 100px;
}
.booking-widget .price-head {
  display: flex; align-items: baseline; gap: .4rem;
  margin-bottom: 1.2rem; padding-bottom: 1.2rem;
  border-bottom: 1px solid var(--color-border);
}
.booking-widget .price-head .amount { font-family: var(--font-heading); color: var(--color-gold); font-size: 2rem; font-weight: 600; }
.booking-widget .price-head .unit { color: var(--color-text-muted); font-size: .9rem; }

.field { margin-bottom: 1rem; }
.field label {
  display: block; font-family: var(--font-accent); color: var(--color-gold);
  text-transform: uppercase; font-size: .78rem; letter-spacing: 2px;
  margin-bottom: .35rem; font-weight: 500;
}
.field input, .field select {
  width: 100%; padding: .75rem .9rem;
  background: var(--color-bg-input); border: 1px solid var(--color-border);
  border-radius: var(--radius); color: var(--color-white);
  font-family: var(--font-body); font-size: 16px;
}
.field input:focus, .field select:focus { outline: none; border-color: var(--color-gold); box-shadow: 0 0 0 3px rgba(198,160,87,.15); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }

.price-breakdown { margin: 1.2rem 0; padding-top: 1rem; border-top: 1px solid var(--color-border); }
.price-breakdown .line {
  display: flex; justify-content: space-between;
  font-size: .9rem; color: var(--color-text-muted); margin-bottom: .5rem;
}
.price-breakdown .line.total {
  color: var(--color-white); font-weight: 600; font-size: 1.1rem;
  padding-top: .7rem; border-top: 1px solid var(--color-border); margin-top: .7rem;
}
.price-breakdown .line.total .val { color: var(--color-gold); font-family: var(--font-heading); }
.converted-note { font-size: .8rem; color: var(--color-text-muted); font-style: italic; margin-top: .3rem; }

.widget-msg {
  padding: .7rem .9rem; border-radius: var(--radius); font-size: .85rem;
  margin-bottom: 1rem;
}
.widget-msg.error { background: rgba(229,57,53,.1); border: 1px solid var(--color-danger); color: var(--color-danger); }
.widget-msg.ok { background: rgba(76,175,80,.1); border: 1px solid var(--color-success); color: var(--color-success); }

/* ─── Widget réservation : calendrier + voyageurs ─────── */
.bw-dates { display: grid; grid-template-columns: 1fr 1fr; gap: .6rem; margin-bottom: .6rem; }
.bw-datebox {
  width: 100%; text-align: left; cursor: pointer;
  background: var(--color-bg-input); border: 1px solid var(--color-border);
  border-radius: var(--radius); padding: .6rem .8rem;
  display: flex; flex-direction: column; gap: .15rem;
  transition: var(--transition); font-family: var(--font-body);
}
.bw-datebox:hover { border-color: var(--color-gold); }
.bw-datebox-lbl {
  font-family: var(--font-accent); color: var(--color-gold);
  text-transform: uppercase; font-size: .72rem; letter-spacing: 2px; font-weight: 500;
}
.bw-datebox-val { color: var(--color-white); font-size: .98rem; }

.bw-travelers { margin-bottom: .6rem; }

.bw-calendar, .bw-trav-panel {
  background: var(--color-bg-section);
  border: 1px solid var(--color-border-gold);
  border-radius: var(--radius);
  padding: .9rem; margin-bottom: .6rem;
}
.bw-cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .6rem; }
.bw-cal-title { font-family: var(--font-heading); color: var(--color-white); font-size: 1rem; text-transform: capitalize; }
.bw-cal-nav {
  width: 30px; height: 30px; border-radius: 50%;
  background: transparent; border: 1px solid var(--color-border);
  color: var(--color-gold); font-size: 1.1rem; cursor: pointer; line-height: 1;
  transition: var(--transition);
}
.bw-cal-nav:hover:not(:disabled) { border-color: var(--color-gold); background: rgba(198,160,87,.1); }
.bw-cal-nav:disabled { opacity: .25; cursor: default; }
.bw-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.bw-cal-wd {
  text-align: center; font-size: .7rem; color: var(--color-text-muted);
  text-transform: uppercase; padding-bottom: .3rem;
}
.bw-cal-day {
  aspect-ratio: 1 / 1; display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid transparent; border-radius: var(--radius);
  color: var(--color-text); font-family: var(--font-body); font-size: .85rem;
  cursor: pointer; transition: background .15s, color .15s, border-color .15s;
}
.bw-cal-day.is-empty { cursor: default; }
.bw-cal-day:not(.is-disabled):not(.is-empty):hover { border-color: var(--color-gold); }
.bw-cal-day.is-disabled { color: var(--color-border); cursor: not-allowed; text-decoration: line-through; }
.bw-cal-day.is-inrange { background: rgba(198,160,87,.15); border-radius: 0; }
.bw-cal-day.is-selected {
  background: linear-gradient(135deg, var(--color-gold-dark), var(--color-gold));
  color: var(--color-bg-dark); font-weight: 700; border-color: transparent;
}
.bw-cal-foot, .bw-trav-foot {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: .7rem; padding-top: .6rem; border-top: 1px solid var(--color-border);
}
.bw-link-btn {
  background: transparent; border: none; cursor: pointer;
  font-family: var(--font-body); font-size: .76rem; letter-spacing: 1px;
  text-transform: uppercase; color: var(--color-text-muted); padding: .3rem .2rem;
  transition: var(--transition);
}
.bw-link-btn.gold { color: var(--color-gold); font-weight: 600; }
.bw-link-btn:hover { color: var(--color-gold-light); }

.bw-stepper-row { display: flex; align-items: center; justify-content: space-between; padding: .55rem 0; }
.bw-stepper-row + .bw-stepper-row { border-top: 1px solid var(--color-border); }
.bw-st-name { color: var(--color-white); font-size: .95rem; }
.bw-st-hint { color: var(--color-text-muted); font-size: .78rem; }
.bw-stepper { display: flex; align-items: center; gap: .7rem; }
.bw-st-btn {
  width: 32px; height: 32px; border-radius: 50%;
  background: transparent; border: 1px solid var(--color-gold);
  color: var(--color-gold); font-size: 1.15rem; line-height: 1; cursor: pointer;
  transition: var(--transition);
}
.bw-st-btn:hover:not(:disabled) { background: var(--color-gold); color: var(--color-bg-dark); }
.bw-st-btn:disabled { opacity: .3; cursor: default; border-color: var(--color-border); color: var(--color-text-muted); }
.bw-st-num { min-width: 1.5rem; text-align: center; color: var(--color-white); font-size: 1rem; }

.bw-child-ages { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; }
.bw-child-ages:not(:empty) { margin-top: .6rem; padding-top: .6rem; border-top: 1px solid var(--color-border); }
.bw-child-age label {
  display: block; font-size: .72rem; color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: 1px; margin-bottom: .2rem;
}
.bw-child-age select {
  width: 100%; padding: .5rem .5rem;
  background: var(--color-bg-input); border: 1px solid var(--color-border);
  border-radius: var(--radius); color: var(--color-white); font-family: var(--font-body); font-size: 16px;
}
.bw-child-age select:focus { outline: none; border-color: var(--color-gold); }

/* ─── Pages paiement / confirmation ───────────────────── */
.center-card {
  max-width: 560px; margin: 4rem auto;
  background: var(--color-bg-card); border: 1px solid var(--color-border);
  border-top: 3px solid var(--color-gold);
  border-radius: var(--radius); padding: 2.5rem; text-align: center;
}
.center-card .big-icon {
  width: 70px; height: 70px; margin: 0 auto 1.2rem;
  display: grid; place-items: center; border-radius: 50%;
  background: linear-gradient(135deg, var(--color-gold-dark), var(--color-gold));
  color: var(--color-bg-dark); font-size: 2rem;
}
.ref-box {
  display: inline-block; margin: 1rem 0;
  font-family: monospace; font-size: 1.2rem; color: var(--color-gold);
  background: var(--color-bg-section); border: 1px dashed var(--color-border-gold);
  padding: .6rem 1.2rem; border-radius: var(--radius);
}
.summary-table { width: 100%; margin: 1.5rem 0; text-align: left; }
.summary-table td { padding: .5rem 0; border-bottom: 1px solid var(--color-border); font-size: .92rem; }
.summary-table td:first-child { color: var(--color-text-muted); }
.summary-table td:last-child { color: var(--color-white); text-align: right; }

/* ─── Footer ───────────────────────────────────────────── */
.site-footer {
  background: var(--color-bg-section);
  border-top: 1px solid var(--color-border);
  padding: 2.5rem 0; text-align: center;
}
.site-footer .container { display: flex; flex-direction: column; gap: .5rem; align-items: center; }
.site-footer .muted { color: var(--color-text-muted); font-size: .85rem; }

/* ─── Empty / messages ─────────────────────────────────── */
.empty {
  text-align: center; padding: 4rem 1rem;
  color: var(--color-text-muted); font-family: var(--font-accent); font-size: 1.2rem;
}

/* ─── Badges ───────────────────────────────────────────── */
.tag {
  display: inline-block; padding: .2rem .7rem; font-size: .72rem;
  text-transform: uppercase; letter-spacing: 1.5px; border-radius: 999px;
  border: 1px solid var(--color-gold); color: var(--color-gold);
  background: rgba(198,160,87,.1);
}

/* ─── Responsive ───────────────────────────────────────── */
@media (max-width: 900px) {
  .apt-detail-layout { grid-template-columns: minmax(0, 1fr); }
  .booking-widget { position: static; }
  .apt-gallery { grid-template-columns: 1fr 1fr; grid-auto-rows: 160px; }
  .apt-gallery .main { grid-row: span 2; grid-column: span 2; }
}
@media (max-width: 600px) {
  html { font-size: 15px; }
  section { padding: 2.5rem 0; }
  .container { padding: 0 1rem; }
  .hero { min-height: 55vh; padding: 3rem 1rem; }
  .apartments-grid { grid-template-columns: 1fr; gap: 1.2rem; }
  .apt-gallery { grid-template-columns: 1fr; grid-auto-rows: 220px; }
  .apt-gallery .main { grid-column: span 1; }
  .field-row { grid-template-columns: 1fr; }

  /* Header : éviter le débordement, sélecteurs lang/devise compacts */
  .site-header .container {
    flex-wrap: wrap;
    gap: .5rem .8rem;
    padding-top: .8rem; padding-bottom: .8rem;
  }
  .site-logo .mark { width: 34px; height: 34px; font-size: 1.05rem; }
  .site-logo .text { font-size: .95rem; }
  .site-logo .text small { font-size: .62rem; letter-spacing: 1.5px; }
  .header-tools { gap: .4rem; flex-wrap: wrap; justify-content: flex-end; }
  .lang-bar, .currency-toggle { flex-wrap: nowrap; }
  .lang-btn, .currency-btn { padding: .3rem .5rem; font-size: .68rem; }

  .center-card { margin: 2rem 1rem; padding: 1.8rem; }
  .apt-features { gap: 1rem; }
  .apt-feature { flex: 1 0 28%; min-width: 0; }
  .apt-photo-hero img { aspect-ratio: 4 / 3; }

  /* Boutons confortables au doigt */
  .btn { padding: 12px 22px; font-size: .78rem; min-height: 44px; letter-spacing: 1.5px; }
  .btn-lg { padding: 14px 28px; font-size: .82rem; }

  /* Inputs : pas de zoom auto iOS */
  .field input, .field select,
  .bw-child-age select { font-size: 16px; }

  /* Carte de réservation : pas de débordement */
  .booking-widget { padding: 1.2rem; }
  .booking-widget .price-head .amount { font-size: 1.6rem; }
}

/* Smartphones étroits (iPhone SE etc.) */
@media (max-width: 380px) {
  .container { padding: 0 .8rem; }
  .site-logo .text small { display: none; }
  .lang-btn, .currency-btn { padding: .28rem .4rem; font-size: .64rem; }
  .center-card { margin: 1.5rem .6rem; padding: 1.4rem; }
}
