/* theme-junot.css — style premium, inspiré de junot.fr */
:root{
    --bg:#f1eae5;
    --paper:#ffffff;
    --ink:#1d1d1f;
    --muted:#6e6e73;
    --accent:#2b2b2b;
    --brand:#0f0f10;
    --radius:14px;
    --shadow:0 20px 60px rgba(0,0,0,.08);
  }
  
  *{box-sizing:border-box}
  html,body{height:100%}
  body{
    margin:0;
    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    color:var(--ink);
    background:var(--bg);
    line-height:1.5;
  }
  
  /* Header */
  .site-header{
    position:sticky; top:0; z-index:50;
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 24px; background:rgba(241,234,229,.85); backdrop-filter:saturate(180%) blur(8px);
    border-bottom:1px solid rgba(0,0,0,.05);
  }
  .brand{
    font-family:'Playfair Display', serif;
    font-weight:600; letter-spacing:.08em; text-decoration:none; color:var(--brand);
    font-size:28px;
  }
  .menu-btn{background:transparent;border:0;font-size:22px;cursor:pointer}
  .nav-links a{margin-left:18px; color:var(--ink); text-decoration:none}
  .nav-links a:hover{opacity:.7}
  
  /* Hero */
  .hero{position:relative; height:72vh; min-height:520px; display:grid;}
  .hero-media{
    position:absolute; inset:0; background-size:cover; background-position:center;
    filter:contrast(1) saturate(1.05);
  }
  .hero-search{
    align-self:end; margin:0 auto 36px; width:min(1120px, 94%);
    background:transparent;
  }
  .search-tabs{
    display:flex; gap:2px; width:max-content; background:rgba(255,255,255,.92);
    padding:6px; border-radius:999px; box-shadow:var(--shadow);
  }
  .tab{
    border:0; background:transparent; padding:10px 18px; border-radius:999px; cursor:pointer;
    font-weight:600; letter-spacing:.05em;
  }
  .tab.active{background:var(--ink); color:white}
  
  /* --- BARRE DE RECHERCHE MODIFIÉE --- */
  .search-bar{
    margin-top:12px;
    display:grid;
    grid-auto-flow: column; /* force une seule ligne */
    grid-auto-columns: max-content; /* chaque champ garde sa largeur naturelle */
    gap:8px;
    padding:12px;
    background:rgba(255,255,255,.95);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    overflow-x:auto; /* scroll horizontal si besoin */
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
  }
  .search-bar > *{min-width:0; white-space:nowrap;}

  .field{position:relative}
  .icon-left{display:flex; align-items:center; gap:8px; background:var(--paper); padding:0 12px; border-radius:10px; border:1px solid #ddd;}
  .icon{opacity:.7}
  .field input{border:0; outline:0; height:44px; width:100%; background:transparent; font-size:16px}
  .select{display:block; height:44px; background:var(--paper); border:1px solid #ddd; border-radius:10px; overflow:hidden}
  .select select{height:100%; width:100%; border:0; background:transparent; padding:0 12px; font-size:16px}
  .cta{height:44px; border:0; padding:0 18px; border-radius:10px; background:#2e2e2e; color:#fff; font-weight:700; letter-spacing:.06em; cursor:pointer; flex-shrink:0;}
  .cta:hover{opacity:.9}
  
  /* Intro */
  .intro{max-width:960px; margin:64px auto 28px; padding:0 20px; text-align:center}
  .intro h1{font-family:'Playfair Display', serif; font-size:44px; margin:0 0 10px}
  .intro p{color:var(--muted); font-size:18px}
  
  /* Listing */
  .listing{max-width:1200px; margin:18px auto 80px; padding:0 20px}
  .listing h2{font-family:'Playfair Display', serif; font-weight:600; margin:14px 0 20px}
  .cards{display:grid; grid-template-columns: repeat(3, 1fr); gap:18px}
  .card{
    background:var(--paper); border-radius:16px; overflow:hidden; box-shadow:var(--shadow);
    display:flex; flex-direction:column;
  }
  .card .media{padding-top:62%; background-size:cover; background-position:center}
  .card .body{padding:14px 14px 16px}
  .badge{display:inline-block; font-size:12px; color:#555; background:#f3f3f3; padding:4px 8px; border-radius:999px; margin-bottom:6px}
  .card h3{margin:4px 0 6px; font-size:18px}
  .muted{color:var(--muted)}
  .meta{margin-top:10px; display:flex; align-items:center; justify-content:space-between}
  .btn-outline{background:transparent; border:1px solid #ddd; border-radius:8px; padding:8px 10px; cursor:pointer}
  .btn-outline:hover{border-color:#999}
  
  /* Footer */
  .site-footer{padding:24px; text-align:center; color:var(--muted)}
  
  /* Responsive */
  @media (max-width: 980px){
    .cards{grid-template-columns: repeat(2,1fr)}
  }
  @media (max-width: 720px){
    .hero{height:64vh; min-height:460px}
    .nav-links{display:none}
    .brand{font-size:24px}
    .cards{grid-template-columns:1fr}
  }

  .maison-intro{
    background: var(--bg);
    padding: 70px 16px 90px;
  }
  .maison-inner{
    max-width: 980px;
    margin: 0 auto;
    text-align: center;
  }
  .maison-intro h2{
    font-family: 'Playfair Display', serif;
    font-weight: 600;
    font-size: clamp(28px, 4vw, 48px);
    margin: 0 0 16px;
  }
  .maison-intro p{
    color: var(--ink);
    opacity: .85;
    line-height: 1.75;
    margin: 8px auto;
    max-width: 860px;
  }
  .maison-divider{
    width: 2px;
    height: 48px;
    background: rgba(0,0,0,.2);
    margin: 28px auto 22px;
    border-radius: 2px;
  }
  .maison-cta{
    display: inline-block;
    padding: 12px 22px;
    border-radius: 10px;
    background: #2e2e2e;
    color: #fff;
    text-decoration: none;
    font-weight: 700;
    letter-spacing: .04em;
  }
  .maison-cta:hover{ opacity: .9; }

  /* ===========================
   CONTACT — Carte cliquable
   =========================== */
.map-wrapper{
    position: relative;
    border-radius: 12px;
    overflow: hidden;            /* arrondis propres sur la carte */
  }
  
  /* Conteneur Leaflet : DOIT avoir une hauteur explicite */
  #map-contact{
    width: 100%;
    height: 360px;               /* hauteur par défaut */
    display: block;
    border-radius: 12px;
  }
  
  /* Lien transparent qui couvre toute la carte
     -> n'importe où on clique, ça ouvre Google Maps */
  .map-overlay{
    position: absolute;
    inset: 0;                    /* top/right/bottom/left: 0 */
    z-index: 5;                  /* au-dessus des tuiles Leaflet */
    cursor: pointer;
  }
  
  /* Responsives : ajuste la hauteur selon l'écran */
  @media (max-width: 600px){
    #map-contact{ height: 280px; }
  }
  @media (min-width: 1200px){
    #map-contact{ height: 420px; }
  }
  
  