  :root{
    --ink:#1c1611;
    --slate:#6b6056;
    --mist:#9c9186;
    --line:#e9e2d8;
    --line-soft:#f3eee6;
    --paper:#fdfbf7;
    --wash:#f5f0e8;
    --pine:#2f4a3e;
    --pine-deep:#243a30;
    --pine-wash:#e9f0eb;
    --copper:#b06a3a;
    --copper-deep:#8f5028;
    --gold:#c08a3e;
    --radius:16px;
    --content:1280px;
    --gutter:40px;
    --shadow-sm:0 1px 2px rgba(28,22,17,.05);
    --shadow-md:0 8px 30px -12px rgba(28,22,17,.18);
    --shadow-lg:0 30px 60px -28px rgba(28,22,17,.32);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    font-family:'Geist',-apple-system,sans-serif;
    background:var(--paper);color:var(--ink);
    overflow-x:hidden;-webkit-font-smoothing:antialiased;
  }
  .serif{font-family:'Fraunces',serif;font-weight:400}
  ::selection{background:var(--pine);color:#fff}
  a{color:inherit}

  /* ===== NAV ===== */
  nav{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    background:var(--paper);
    border-bottom:1px solid var(--line);transition:box-shadow .3s,border-color .3s;
  }
  nav.scrolled{box-shadow:0 1px 12px rgba(28,22,17,.06)}
  .nav-inner{max-width:var(--content);margin:0 auto;padding:16px var(--gutter);display:flex;align-items:center;justify-content:space-between;transition:padding .3s}
  nav.scrolled .nav-inner{padding-top:12px;padding-bottom:12px}
  .logo{font-size:22px;font-weight:700;letter-spacing:-1px;display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--ink)}
  .logo .mark{width:24px;height:24px;border-radius:8px;background:linear-gradient(135deg,var(--pine),#4a6b5a);position:relative;box-shadow:0 2px 8px rgba(47,74,62,.4)}
  .logo .mark::after{content:"";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:13px;line-height:24px;text-align:center;content:"▲"}
  .nav-links{display:flex;gap:30px;align-items:center}
  .nav-links a{color:var(--slate);text-decoration:none;font-size:14.5px;font-weight:500;transition:color .2s;position:relative}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;height:2px;width:0;background:var(--ink);transition:width .25s}
  .nav-links a:hover{color:var(--ink)}
  .nav-links a:hover::after{width:100%}
  .nav-r{display:flex;gap:8px;align-items:center}
  .pill-select{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--slate);padding:8px 12px;border-radius:9px;cursor:pointer;transition:background .2s}
  .pill-select:hover{background:var(--wash)}

  /* language selector */
  .lang{position:relative}
  .lang-btn{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--slate);padding:7px 11px;border-radius:9px;cursor:pointer;transition:background .2s;border:none;background:transparent;font-family:'Geist'}
  .lang-btn:hover{background:var(--wash)}
  .lang-btn .flag{width:20px;height:14px;border-radius:3px;overflow:hidden;display:block;box-shadow:0 0 0 1px rgba(28,22,17,.08)}
  .lang-btn .chev{transition:transform .25s}
  .lang.open .lang-btn .chev{transform:rotate(180deg)}
  .lang-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:6px;min-width:188px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .2s,transform .2s,visibility .2s;z-index:50}
  .lang.open .lang-menu{opacity:1;visibility:visible;transform:none}
  .lang-menu .lh{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--mist);padding:8px 12px 6px}
  .lang-opt{display:flex;align-items:center;gap:11px;width:100%;padding:9px 12px;border-radius:9px;border:none;background:transparent;cursor:pointer;font-family:'Geist';font-size:14px;font-weight:500;color:var(--ink);text-align:left;transition:background .15s}
  .lang-opt:hover{background:var(--wash)}
  .lang-opt .flag{width:22px;height:15px;border-radius:3px;overflow:hidden;display:block;flex-shrink:0;box-shadow:0 0 0 1px rgba(28,22,17,.08)}
  .lang-opt .native{color:var(--mist);font-size:12.5px;margin-left:auto;font-weight:400}
  .lang-opt.active{background:var(--pine-wash)}
  .lang-opt.active .native{color:var(--pine)}
  .lang-opt .check{width:15px;height:15px;stroke:var(--pine);fill:none;stroke-width:2.5;margin-left:auto;display:none}
  .lang-opt.active .check{display:block}
  .lang-opt.active .native{display:none}
  .ghost{color:var(--ink);font-size:14.5px;font-weight:600;text-decoration:none;padding:9px 14px;border-radius:10px;transition:background .2s}
  .ghost:hover{background:var(--wash)}
  .solid{background:var(--ink);color:#fff;font-size:14.5px;font-weight:600;text-decoration:none;padding:10px 18px;border-radius:10px;transition:transform .15s,box-shadow .2s}
  .solid:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}

  /* ===== HERO (editorial split) ===== */
  .hero{position:relative;max-width:var(--content);margin:0 auto;padding:130px var(--gutter) 70px;display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:center}
  .hero-left{position:relative;z-index:3}
  .badge{display:inline-flex;align-items:center;gap:8px;background:var(--pine-wash);border:1px solid #d6e2da;padding:7px 15px;border-radius:30px;font-size:13px;font-weight:600;color:var(--pine-deep);margin-bottom:26px;opacity:0;animation:rise .7s .1s forwards}
  .badge .dot{width:7px;height:7px;border-radius:50%;background:var(--pine);box-shadow:0 0 0 3px rgba(47,74,62,.18)}
  .hero h1{font-size:clamp(42px,5vw,76px);line-height:.98;letter-spacing:-3px;font-weight:600;color:var(--ink);opacity:0;animation:rise .8s .2s forwards}
  .hero h1 .serif{font-style:italic;font-weight:400;letter-spacing:-1.5px;color:var(--copper)}
  .hero p.sub{font-size:18px;color:var(--slate);max-width:42ch;margin-top:22px;line-height:1.6;opacity:0;animation:rise .8s .32s forwards}
  .hero-meta{display:flex;gap:30px;margin-top:34px;opacity:0;animation:rise .8s .42s forwards}
  .hero-meta .m .n{font-family:'Fraunces',serif;font-size:30px;font-weight:500;color:var(--ink);letter-spacing:-1px}
  .hero-meta .m .n em{font-style:italic;color:var(--copper)}
  .hero-meta .m .l{font-size:12.5px;color:var(--mist);margin-top:2px}
  .hero-meta .div{width:1px;background:var(--line)}

  /* image cluster on the right */
  .hero-visual{position:relative;height:560px;opacity:0;animation:rise 1s .3s forwards}
  .hv-main{position:absolute;top:0;right:0;width:78%;height:100%;border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg)}
  .hv-main img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:slowzoom 20s ease-out forwards}
  @keyframes slowzoom{to{transform:scale(1)}}
  .hv-sub{position:absolute;bottom:38px;left:0;width:46%;height:42%;border-radius:18px;overflow:hidden;border:5px solid var(--paper);box-shadow:var(--shadow-md);z-index:2}
  .hv-sub img{width:100%;height:100%;object-fit:cover}
  .hv-card{position:absolute;top:34px;left:-14px;z-index:3;background:rgba(253,251,247,.92);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:11px;animation:floaty 5s ease-in-out infinite}
  @keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
  .hv-card .av{display:flex}
  .hv-card .av span{width:30px;height:30px;border-radius:50%;border:2px solid var(--paper);margin-left:-10px;background-size:cover;background-position:center}
  .hv-card .av span:first-child{margin-left:0}
  .hv-card .tx .s{font-size:13px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:4px}
  .hv-card .tx .s b{color:var(--gold)}
  .hv-card .tx .d{font-size:11.5px;color:var(--mist)}
  @keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

  /* ===== SEARCH ===== */
  .search-wrap{max-width:var(--content);margin:8px auto 0;padding:0 var(--gutter);position:relative;z-index:5;opacity:0;animation:rise .8s .5s forwards}
  .search{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:7px;display:flex;align-items:stretch;box-shadow:var(--shadow-lg)}
  .search-fields{display:contents}
  .sf{flex:1;padding:13px 20px;text-align:left;border-radius:12px;cursor:pointer;transition:background .18s;position:relative}
  .sf:hover{background:var(--wash)}
  .sf+.sf::before{content:"";position:absolute;left:0;top:18%;height:64%;width:1px;background:var(--line)}
  .sf label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--mist);letter-spacing:.5px;text-transform:uppercase;margin-bottom:5px}
  .sf label svg{width:13px;height:13px;stroke:var(--mist);fill:none;stroke-width:2}
  .sf .v{font-size:15px;font-weight:500;color:var(--ink)}
  .sf .v.dim{color:var(--mist);font-weight:400}
  /* make real <input>/<select> fields look exactly like the mockup spans */
  .sf input,.sf select{
    appearance:none;-webkit-appearance:none;
    border:none;background:transparent;outline:none;box-shadow:none;
    width:100%;padding:0;margin:0;
    font-family:'Geist',sans-serif;font-size:15px;font-weight:500;color:var(--ink);
    line-height:1.3;cursor:pointer;border-radius:0;
  }
  .sf input::placeholder{color:var(--mist);font-weight:400;opacity:1}
  .sf input:focus,.sf select:focus{outline:none}
  .sf:focus-within{background:var(--wash)}
  .sf select{cursor:pointer}
  /* the whole field is clickable: stack label + control, no input chrome */
  .sf{display:flex;flex-direction:column;justify-content:center}
  .sbtn{background:var(--pine);color:#fff;border:none;border-radius:12px;padding:0 28px;margin-left:4px;font-family:'Geist';font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:9px;transition:background .2s,transform .12s;box-shadow:0 8px 20px -8px rgba(47,74,62,.6)}
  .sbtn:hover{background:var(--pine-deep)}
  .sbtn:active{transform:scale(.97)}
  .sbtn svg{width:18px;height:18px}
  .quick{display:flex;gap:8px;align-items:center;margin-top:16px;flex-wrap:wrap;padding-left:4px}
  .quick span{font-size:13px;color:var(--mist);margin-right:2px}
  .quick a{font-size:13px;color:var(--slate);text-decoration:none;background:var(--wash);padding:6px 13px;border-radius:30px;transition:all .18s}
  .quick a:hover{background:var(--ink);color:#fff}

  /* ===== TRUST ===== */
  .trust{max-width:var(--content);margin:56px auto 0;padding:0 var(--gutter);text-align:center}
  .trust p{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--mist);font-weight:600;margin-bottom:22px}
  .trust-row{display:flex;justify-content:center;gap:44px;flex-wrap:wrap;align-items:center}
  .trust-row span{font-size:17px;font-weight:700;letter-spacing:-.3px;color:var(--mist);opacity:.7;transition:opacity .2s}
  .trust-row span:hover{opacity:1}

  /* ===== SECTIONS ===== */
  section.block{padding:90px var(--gutter);max-width:var(--content);margin:0 auto}
  .head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:34px;gap:24px;flex-wrap:wrap}
  .head h2{font-size:clamp(28px,3.2vw,42px);letter-spacing:-1.5px;font-weight:600;line-height:1.05}
  .head h2 .serif{font-style:italic}
  .head p{color:var(--slate);font-size:15.5px;margin-top:8px;max-width:50ch;line-height:1.5}
  .head .more{color:var(--copper);font-weight:600;font-size:14.5px;text-decoration:none;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;transition:gap .2s}
  .head .more:hover{gap:9px}

  /* destinations */
  .dests{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:200px 200px;gap:14px}
  .dest{display:block;text-decoration:none;color:inherit;position:relative;border-radius:16px;overflow:hidden;cursor:pointer}
  .dest:nth-child(1){grid-row:span 2}
  .dest img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
  .dest:hover img{transform:scale(1.07)}
  .dest::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,16,12,.72),transparent 58%)}
  .dest .meta{position:absolute;left:18px;bottom:15px;z-index:2;color:#fff}
  .dest .meta h3{font-size:20px;font-weight:600;letter-spacing:-.5px}
  .dest .meta span{font-size:12.5px;opacity:.85}
  .dest .arrow{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;opacity:0;transform:translate(-4px,4px);transition:all .3s}
  .dest:hover .arrow{opacity:1;transform:none}
  .dest .arrow svg{width:15px;height:15px;stroke:#fff;fill:none;stroke-width:2.5}

  /* filters */
  .filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
  .filt{padding:9px 18px;border:1px solid var(--line);border-radius:30px;font-size:14px;font-weight:500;cursor:pointer;background:var(--paper);transition:all .2s;color:var(--slate)}
  .filt:hover{border-color:var(--ink);color:var(--ink)}
  .filt.active{background:var(--ink);color:#fff;border-color:var(--ink)}

  /* chalet grid */
  .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .card{display:block;text-decoration:none;color:inherit;cursor:pointer;opacity:0;transform:translateY(24px);transition:opacity .6s,transform .6s}
  .card.in{opacity:1;transform:none}
  .ph{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/3.1;margin-bottom:14px;background:var(--wash)}
  .ph img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
  .card:hover .ph img{transform:scale(1.06)}
  .ph .badge2{position:absolute;top:12px;left:12px;background:rgba(253,251,247,.95);backdrop-filter:blur(4px);padding:5px 12px;border-radius:8px;font-size:11.5px;font-weight:600;color:var(--ink);box-shadow:var(--shadow-sm)}
  .ph .heart{position:absolute;top:10px;right:10px;width:34px;height:34px;padding:0;border:none;border-radius:50%;background:rgba(253,251,247,.92);display:flex;align-items:center;justify-content:center;transition:transform .2s;cursor:pointer}
  .ph .heart:hover{transform:scale(1.14)}
  .ph .heart svg{width:17px;height:17px;fill:none;stroke:var(--ink);stroke-width:2;transition:fill .2s,stroke .2s}
  .ph .heart.liked svg{fill:var(--copper);stroke:var(--copper)}
  .crow{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
  .crow h3{font-size:17px;font-weight:600;letter-spacing:-.3px;line-height:1.2}
  .loc{font-size:13px;color:var(--mist);margin-top:3px;display:flex;align-items:center;gap:4px}
  .loc svg{width:12px;height:12px;stroke:var(--mist);fill:none;stroke-width:2}
  .rate{display:flex;align-items:center;gap:5px;font-size:13.5px;font-weight:700;background:var(--pine-wash);color:var(--pine-deep);padding:4px 9px;border-radius:8px;white-space:nowrap}
  .specs{display:flex;gap:14px;margin-top:11px;font-size:13px;color:var(--slate)}
  .specs span{display:flex;align-items:center;gap:5px}
  .specs svg{width:14px;height:14px;stroke:var(--slate);fill:none;stroke-width:1.8}
  .price{margin-top:12px;font-size:13.5px;color:var(--slate);padding-top:12px;border-top:1px solid var(--line-soft)}
  .price b{color:var(--ink);font-size:17px;font-weight:700;letter-spacing:-.3px}

  /* ===== WHY ===== */
  .why{max-width:var(--content);margin:90px auto;padding:0 var(--gutter)}
  .why-box{background:var(--pine-deep);border-radius:26px;padding:68px 56px;position:relative;overflow:hidden}
  .why-box::before{content:"";position:absolute;top:-120px;right:-60px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(192,138,62,.28),transparent 68%)}
  .why-head{text-align:center;margin-bottom:46px;position:relative}
  .why-head h2{font-size:clamp(28px,3.2vw,42px);letter-spacing:-1.5px;font-weight:600;color:#fff}
  .why-head h2 .serif{font-style:italic;color:var(--gold)}
  .why-head p{color:rgba(255,255,255,.62);font-size:15.5px;margin-top:10px}
  .feats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;position:relative}
  .feat{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:28px;transition:transform .25s,background .25s}
  .feat:hover{transform:translateY(-4px);background:rgba(255,255,255,.08)}
  .feat .ic{width:44px;height:44px;border-radius:12px;background:rgba(192,138,62,.18);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
  .feat .ic svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:2}
  .feat h3{font-size:18px;font-weight:600;letter-spacing:-.4px;margin-bottom:8px;color:#fff}
  .feat p{font-size:14px;color:rgba(255,255,255,.64);line-height:1.55}

  /* ===== CTA ===== */
  .cta{max-width:var(--content);margin:0 auto;padding:0 var(--gutter)}
  .cta-in{background:linear-gradient(120deg,var(--copper),#cc8348);border-radius:24px;padding:64px 60px;display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap;position:relative;overflow:hidden}
  .cta-in::after{content:"";position:absolute;right:-60px;bottom:-100px;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.13)}
  .cta-in h2{color:#fff;font-size:clamp(26px,3.2vw,40px);letter-spacing:-1.5px;font-weight:600;line-height:1.08;max-width:20ch;position:relative}
  .cta-in h2 .serif{font-style:italic}
  .cta-in p{color:rgba(255,255,255,.88);margin-top:12px;font-size:15.5px;position:relative}
  .cta-btn{background:#fff;color:var(--copper-deep);text-decoration:none;font-weight:600;font-size:15px;padding:15px 28px;border-radius:12px;white-space:nowrap;position:relative;transition:transform .2s,box-shadow .2s}
  .cta-btn:hover{transform:translateY(-2px);box-shadow:0 12px 30px -10px rgba(0,0,0,.3)}

  /* ===== FOOTER ===== */
  footer{background:var(--pine);color:#e8e2d6;margin-top:90px}
  .foot-top{max-width:var(--content);margin:0 auto;padding:60px var(--gutter) 40px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr;gap:40px}
  .foot-brand .logo{display:flex;align-items:center;gap:9px;font-size:24px;font-weight:700;color:#fff;text-decoration:none;letter-spacing:-1px;margin-bottom:14px}
  .foot-brand .logo .mark{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--copper),var(--gold));display:inline-block}
  .foot-brand p{color:#b9c4bb;font-size:14px;line-height:1.6;max-width:34ch;margin-bottom:20px}
  .foot-news{margin-bottom:20px}
  .foot-news label{display:block;font-size:12.5px;font-weight:600;color:#fff;margin-bottom:8px}
  .foot-news-row{display:flex;gap:8px;max-width:320px}
  .foot-news input{flex:1;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);border-radius:11px;padding:11px 14px;font:inherit;font-size:14px;color:#fff;outline:none}
  .foot-news input::placeholder{color:#9aa79e}
  .foot-news input:focus{border-color:var(--gold)}
  .foot-news button{width:44px;border:none;border-radius:11px;background:var(--copper);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .foot-news button:hover{background:var(--gold)}
  .foot-news button svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2}
  .foot-news-msg{font-size:12.5px;margin-top:8px}
  .foot-news-msg.ok{color:#8fd6a8}.foot-news-msg.err{color:#e6a88f}
  .socials{display:flex;gap:10px}
  .socials a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:background .2s}
  .socials a:hover{background:rgba(255,255,255,.18)}
  .socials svg{width:18px;height:18px;fill:#e8e2d6}
  .foot-col h4{font-size:13px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px}
  .foot-col a{display:block;color:#b9c4bb;text-decoration:none;font-size:14px;margin-bottom:10px;transition:color .15s}
  .foot-col a:hover{color:#fff}
  .foot-contact a,.foot-contact span{display:flex;align-items:center;gap:8px;color:#e8e2d6;font-size:14px;text-decoration:none;margin-bottom:10px}
  .foot-contact svg{width:15px;height:15px;stroke:var(--gold);fill:none;stroke-width:2;flex-shrink:0}
  .foot-bot{border-top:1px solid rgba(255,255,255,.1)}
  .foot-bot-in{max-width:var(--content);margin:0 auto;padding:22px var(--gutter);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
  .foot-bot-in p{font-size:13px;color:#9aa79e}
  .foot-right{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
  .foot-legal a{color:#9aa79e;text-decoration:none;font-size:13px}
  .foot-legal a:hover{color:#fff}
  .lang-switch{display:flex;gap:4px;background:rgba(255,255,255,.08);border-radius:20px;padding:3px}
  .lang-switch a{font-size:12.5px;font-weight:600;color:#b9c4bb;text-decoration:none;padding:5px 13px;border-radius:16px}
  .lang-switch a.on{background:#fff;color:var(--pine)}
  @media(max-width:860px){.foot-top{grid-template-columns:1fr 1fr;gap:32px}.foot-bot-in{flex-direction:column;align-items:flex-start}}
  @media(max-width:520px){.foot-top{grid-template-columns:1fr}}

  @media(max-width:1100px){
    .hero{grid-template-columns:1fr;gap:40px;padding-top:120px}
    .hero p.sub{max-width:54ch}
    .hero-visual{height:440px}
    .grid{grid-template-columns:repeat(2,1fr)}
    .feats{grid-template-columns:1fr}
    .dests{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,170px)}
    .dest:nth-child(1){grid-row:span 1;grid-column:span 2}
    .foot-top{grid-template-columns:1fr 1fr}
  }
  @media(max-width:680px){
    :root{--gutter:18px}
    .hero{padding:96px var(--gutter) 24px;grid-template-columns:1fr;gap:36px}
    .hero-visual{height:380px;order:2}
    .hv-main{width:82%}
    .hv-sub{width:44%;bottom:24px}
    .hv-card{left:0;top:18px;padding:10px 13px}
    .hv-card .tx .d{display:none}
    .nav-links,.pill-select{display:none}
    .search{flex-direction:column;padding:0;background:transparent;border:none;box-shadow:none}
    .search-fields{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:7px;box-shadow:var(--shadow-lg)}
    .sf+.sf::before{display:none}.sf{border-bottom:1px solid var(--line)}
    .search-fields .sf:last-child{border-bottom:none}
    .sf-dates{flex-direction:row !important}
    .sbtn{margin:14px 0 0;padding:17px;justify-content:center;border-radius:16px;width:100%;box-shadow:0 10px 24px -10px rgba(47,74,62,.7)}
    .grid{grid-template-columns:1fr}
    .dests{grid-template-columns:1fr;grid-template-rows:none}
    .dest{aspect-ratio:16/10}
    .dest:nth-child(1){grid-column:auto}
    .why-box,.cta-in{padding:40px 24px}.cta-in{flex-direction:column;align-items:flex-start}
    .foot-top{grid-template-columns:1fr}
    /* nav: keep logo + language + one CTA only */
    .nav-inner{gap:10px}
    .ghost{display:none}
    .lang-menu{right:auto;left:0}
  }
  @media(max-width:480px){
    .hero-visual{height:320px}
    .hv-main{width:100%}
    .hv-sub{width:48%;height:38%;bottom:-14px;left:8px;border-width:4px}
    .hv-card{top:12px;left:8px}
    .hv-card .av span{width:26px;height:26px}
  }
  @media(max-width:420px){
    .hero-meta{flex-wrap:wrap;gap:18px}
    .hero-meta .div{display:none}
    .trust-row{gap:20px}
    .head{flex-direction:column;align-items:flex-start}
  }

/* ===== WordPress / theme additions ===== */
/* language switcher in nav */
.lang-switch{position:relative}
.lang-btn{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--slate);padding:7px 11px;border-radius:9px;cursor:pointer;border:none;background:transparent;font-family:'Geist'}
.lang-btn:hover{background:var(--wash)}
.lang-btn .flag{width:20px;height:14px;border-radius:3px;overflow:hidden;display:block;box-shadow:0 0 0 1px rgba(28,22,17,.08)}
.lang-btn .chev{transition:transform .25s}
.lang-switch.open .lang-btn .chev{transform:rotate(180deg)}
.lang-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:6px;min-width:190px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .2s,transform .2s,visibility .2s;z-index:1100;list-style:none}
.lang-switch.open .lang-menu{opacity:1;visibility:visible;transform:none}
.lang-menu .lh{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--mist);padding:8px 12px 6px}
.lang-opt{display:flex;align-items:center;gap:11px;width:100%;padding:9px 12px;border-radius:9px;border:none;background:transparent;cursor:pointer;font-family:'Geist';font-size:14px;font-weight:500;color:var(--ink);text-align:left;transition:background .15s;text-decoration:none}
.lang-opt:hover{background:var(--wash)}
.lang-opt .flag{width:22px;height:15px;border-radius:3px;overflow:hidden;display:block;flex-shrink:0;box-shadow:0 0 0 1px rgba(28,22,17,.08)}
.lang-opt .native{color:var(--mist);font-size:12.5px;margin-left:auto;font-weight:400}
.lang-opt.active{background:var(--pine-wash)}
.lang-opt.active .native{color:var(--pine);font-weight:600}

/* generic page content (for WP pages) */
.page-hero{padding:130px var(--gutter) 40px;max-width:var(--content);margin:0 auto}
.page-hero .kicker{font-size:13px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--copper);margin-bottom:14px}
.page-hero h1{font-size:clamp(34px,5vw,60px);letter-spacing:-2px;font-weight:600;line-height:1.02}
.page-hero h1 .serif,.page-hero h1 em{font-family:'Fraunces',serif;font-style:italic;font-weight:400;color:var(--copper)}
.page-body{max-width:760px;margin:0 auto;padding:20px var(--gutter) 90px;font-size:16.5px;line-height:1.75;color:var(--slate)}
.page-body h2{font-family:'Geist';font-size:24px;font-weight:600;letter-spacing:-.5px;color:var(--ink);margin:36px 0 14px}
.page-body h3{font-size:19px;font-weight:600;color:var(--ink);margin:26px 0 10px}
.page-body p{margin-bottom:16px}
.page-body ul,.page-body ol{margin:0 0 16px 22px}
.page-body li{margin-bottom:8px}
.page-body a{color:var(--copper-deep);text-decoration:underline}
.page-body img{border-radius:14px;margin:20px 0}

/* steps (how it works) */
.steps3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:var(--content);margin:0 auto;padding:0 var(--gutter) 90px}
.step{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:30px}
.step .num{font-family:'Fraunces',serif;font-size:34px;font-weight:500;color:var(--copper);letter-spacing:-1px}
.step h3{font-size:19px;font-weight:600;margin:12px 0 8px;letter-spacing:-.4px;color:var(--ink)}
.step p{font-size:14.5px;color:var(--slate);line-height:1.6}
@media(max-width:820px){.steps3{grid-template-columns:1fr}}

/* skip link a11y */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:2000}
.skip-link:focus{left:0}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}

  /* Conteneur largeur de site, partagé par toutes les pages. */
  .wrap{max-width:var(--content);margin:0 auto;padding:0 var(--gutter)}

  /* ===== COMPTES (connexion / inscription / espace) ===== */
  .auth-wrap{max-width:520px;margin:0 auto;padding:120px var(--gutter) 80px}
  .auth-wrap.wide{max-width:var(--content)}
  .auth-card{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:38px 34px;box-shadow:0 12px 40px rgba(28,22,17,.05)}
  .auth-title{font-size:30px;letter-spacing:-1px;margin:0}
  .auth-sub{color:var(--slate);margin:8px 0 24px}
  .auth-form{display:flex;flex-direction:column;gap:16px}
  .auth-form label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:14px;color:var(--ink)}
  .auth-form input[type=text],.auth-form input[type=email],.auth-form input[type=password],.auth-form input[type=url],.auth-form input[type=number],.auth-form textarea{
    border:1px solid var(--line);border-radius:10px;padding:12px 14px;font:inherit;font-weight:400;background:#fff;color:var(--ink);width:100%}
  .auth-form input:focus,.auth-form textarea:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 3px rgba(47,74,62,.1)}
  .auth-form textarea#kfDesc{min-height:180px;resize:vertical;line-height:1.6}
  .auth-hint{font-weight:400;color:var(--mist);font-size:12.5px}
  .auth-check{flex-direction:row;align-items:center;gap:8px;font-weight:400;color:var(--slate)}
  .auth-btn{background:var(--ink);color:#fff;border:none;border-radius:11px;padding:14px;font:inherit;font-weight:600;cursor:pointer;transition:opacity .2s;margin-top:4px}
  .auth-btn:hover{opacity:.9}
  .auth-alt{text-align:center;margin-top:20px;color:var(--slate);font-size:14px}
  .auth-alt a{color:var(--pine);font-weight:600}
  .auth-msg{padding:12px 14px;border-radius:10px;font-size:14px;margin-bottom:18px}
  .auth-msg.err{background:#fbeae5;color:#9c3a1e;border:1px solid #f1c9bb}
  .auth-msg.ok{background:#e7f2ec;color:#1f5840;border:1px solid #bfe0cf}
  /* choix de rôle */
  .auth-roles{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:6px}
  .role-opt{cursor:pointer}
  .role-opt input{position:absolute;opacity:0}
  .role-box{display:block;border:1.5px solid var(--line);border-radius:12px;padding:14px;transition:border-color .2s,background .2s}
  .role-box b{display:block;font-size:15px}
  .role-box small{color:var(--slate);font-size:12.5px}
  .role-opt input:checked + .role-box{border-color:var(--pine);background:var(--wash)}
  /* espace proprio */
  .acct-head{margin-bottom:22px}
  .acct-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px}
  .acct-card{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:30px 28px}
  .acct-h2{font-size:20px;margin:0 0 6px}
  .acct-note{color:var(--slate);font-size:13.5px;margin:0 0 18px}
  .acct-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
  .acct-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
  .acct-list li{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border:1px solid var(--line);border-radius:10px}
  .al-name{font-weight:600}
  .al-state{font-size:12px;font-weight:600;padding:3px 10px;border-radius:20px}
  .s-publish{background:#e7f2ec;color:#1f5840}
  .s-pending{background:#fdf3e3;color:#9a6a1e}
  .s-draft{background:var(--wash);color:var(--slate)}
  @media(max-width:820px){.acct-grid{grid-template-columns:1fr}}
  @media(max-width:560px){.auth-wrap{padding-top:96px}.auth-card{padding:28px 22px}.acct-row{grid-template-columns:1fr}.auth-roles{grid-template-columns:1fr}}

  /* ===== LOUER MA MAISON (page propriétaires) ===== */
  .lmm-hero{background:var(--wash);border-bottom:1px solid var(--line);padding:130px var(--gutter) 70px;text-align:center}
  .lmm-hero-in{max-width:760px;margin:0 auto}
  .lmm-eyebrow{display:inline-block;background:var(--paper);border:1px solid var(--line);border-radius:30px;padding:6px 16px;font-size:13px;font-weight:600;color:var(--pine);margin-bottom:20px}
  .lmm-hero h1{font-size:clamp(34px,5vw,56px);letter-spacing:-1.5px;line-height:1.05;margin:0 0 18px}
  .lmm-sub{font-size:18px;color:var(--slate);line-height:1.6;max-width:600px;margin:0 auto 28px}
  .lmm-cta{display:inline-block;background:var(--ink);color:#fff;text-decoration:none;border-radius:12px;padding:15px 30px;font-weight:600;transition:opacity .2s}
  .lmm-cta:hover{opacity:.9}
  .lmm-stats{display:flex;justify-content:center;gap:48px;margin-top:46px;flex-wrap:wrap}
  .lmm-stats div{display:flex;flex-direction:column}
  .lmm-stats b{font-family:var(--serif,Fraunces,serif);font-size:32px;color:var(--ink)}
  .lmm-stats span{color:var(--mist);font-size:13.5px}
  .lmm-steps,.lmm-why{padding:70px 0}
  .lmm-h2{font-size:28px;letter-spacing:-.5px;margin:0 0 36px;text-align:center}
  .lmm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .lmm-why .lmm-grid{grid-template-columns:repeat(2,1fr)}
  .lmm-step,.lmm-feat{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:28px}
  .lmm-num{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:var(--pine);color:#fff;font-weight:700;margin-bottom:14px}
  .lmm-step h3,.lmm-feat h4{font-size:18px;margin:0 0 8px}
  .lmm-step p,.lmm-feat p{color:var(--slate);line-height:1.6;margin:0;font-size:14.5px}
  .lmm-final{text-align:center;padding:80px var(--gutter);background:var(--wash);border-top:1px solid var(--line)}
  .lmm-final h2{font-size:30px;letter-spacing:-.5px;margin:0 0 24px}
  @media(max-width:820px){.lmm-grid,.lmm-why .lmm-grid{grid-template-columns:1fr}.lmm-stats{gap:30px}}

  /* ===== AUTH SPLIT (connexion / inscription / mot de passe) ===== */
  .asplit-wrap{max-width:var(--content);margin:0 auto;padding:104px var(--gutter) 70px}
  .asplit{display:grid;grid-template-columns:1fr 1fr;min-height:620px;background:var(--paper);border:1px solid var(--line);border-radius:26px;overflow:hidden;box-shadow:0 28px 70px rgba(28,22,17,.10)}
  .asplit-visual{position:relative;padding:42px;display:flex;flex-direction:column;justify-content:space-between;color:#fff;isolation:isolate}
  .asplit-visual img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
  .asplit-visual::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(28,22,17,.18) 0%,rgba(28,22,17,.05) 35%,rgba(28,22,17,.62) 100%)}
  .av-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:21px;color:#fff;text-decoration:none}
  .av-mark{width:30px;height:30px;border-radius:9px;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center}
  .av-mark svg{width:17px;height:17px;stroke:#fff;fill:none;stroke-width:2}
  .av-quote h3{font-family:'Fraunces',serif;font-size:26px;font-weight:500;line-height:1.3;margin-bottom:14px;max-width:18ch}
  .av-author{display:flex;align-items:center;gap:12px}
  .av-author .av{width:44px;height:44px;border-radius:50%;background-size:cover;background-position:center;border:2px solid rgba(255,255,255,.5)}
  .av-author b{display:block;font-size:14.5px}
  .av-author span{font-size:12.5px;opacity:.82}
  .aform{padding:56px 56px;display:flex;flex-direction:column;justify-content:center;width:100%;max-width:460px;margin:0 auto}
  .aform h1{font-size:29px;letter-spacing:-1px;margin-bottom:8px}
  .aform .sub{color:var(--slate);margin-bottom:28px;font-size:15px}
  .afield{position:relative;margin-bottom:14px}
  .afield input{width:100%;border:1px solid var(--line);border-radius:13px;padding:22px 16px 9px;font:inherit;background:#fff;transition:border-color .2s,box-shadow .2s}
  .afield input:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 3px rgba(47,74,62,.12)}
  .afield label{position:absolute;top:8px;left:16px;font-size:11px;font-weight:600;color:var(--mist);letter-spacing:.3px;text-transform:uppercase}
  .aforgot{display:inline-block;margin:2px 0 18px;color:var(--pine);font-weight:600;font-size:13.5px;text-decoration:none}
  .arow{display:flex;align-items:center;gap:10px;margin-bottom:22px;font-size:14px;color:var(--slate)}
  .abtn{background:var(--ink);color:#fff;border:none;border-radius:40px;padding:16px;font:inherit;font-weight:600;cursor:pointer;width:100%;transition:opacity .2s,transform .1s}
  .abtn:hover{opacity:.92}.abtn:active{transform:translateY(1px)}
  .aalt{text-align:center;margin-top:22px;color:var(--slate);font-size:14px}
  .aalt a{color:var(--pine);font-weight:600;text-decoration:none}
  .ahint{display:block;margin-top:6px;font-size:12px;color:var(--mist)}
  .amsg{padding:12px 14px;border-radius:11px;font-size:14px;margin-bottom:18px}
  .amsg.err{background:#fbeae5;color:#9c3a1e;border:1px solid #f1c9bb}
  .amsg.ok{background:#e7f2ec;color:#1f5840;border:1px solid #bfe0cf}
  .aroles{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
  .arole{cursor:pointer;display:block;position:relative;overflow:hidden;border-radius:14px}
  .arole input{position:absolute !important;width:1px !important;height:1px !important;padding:0 !important;margin:-1px !important;border:0 !important;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;opacity:0 !important;pointer-events:none}
  .arole .box{display:block;border:1.5px solid var(--line);border-radius:14px;padding:15px;transition:.2s;height:100%;background:#fff}
  .arole .box .ic{width:32px;height:32px;border-radius:9px;background:var(--wash);display:flex;align-items:center;justify-content:center;margin-bottom:9px}
  .arole .box .ic svg{width:17px;height:17px;stroke:var(--pine);fill:none;stroke-width:1.8}
  .arole .box b{display:block;font-size:14px;color:var(--ink)}.arole .box small{display:block;color:var(--slate);font-size:11.5px}
  .arole input:checked + .box{border-color:var(--pine);background:var(--wash)}
  @media(max-width:820px){.asplit{grid-template-columns:1fr}.asplit-visual{min-height:210px;padding:28px}.av-quote h3{font-size:20px}.aform{padding:40px 28px}.aroles{grid-template-columns:1fr}}

  /* ===== Menu compte connecté (avatar + dropdown) ===== */
  .acct{position:relative}
  .acct-btn{display:flex;align-items:center;gap:8px;cursor:pointer;padding:5px 9px 5px 5px;border:1px solid var(--line);border-radius:30px;background:var(--paper);transition:border-color .15s}
  .acct-btn:hover{border-color:var(--ink)}
  .ava{width:32px;height:32px;border-radius:50%;background:var(--pine);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}
  .ava-owner{background:var(--copper)}
  .acct-btn .chev{width:14px;height:14px;stroke:var(--slate);fill:none;stroke-width:2;transition:transform .2s}
  .acct.open .acct-btn .chev{transform:rotate(180deg)}
  .acct-menu{position:absolute;top:calc(100% + 10px);right:0;width:236px;background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 50px rgba(28,22,17,.16);padding:8px;z-index:1100;display:none}
  .acct.open .acct-menu{display:block;animation:popin .16s ease}
  .acct-menu .head{padding:11px 12px 10px;border-bottom:1px solid var(--line);margin-bottom:6px}
  .acct-menu .head b{display:block;font-size:14.5px;color:var(--ink)}
  .acct-menu .head span{font-size:12.5px;color:var(--mist)}
  .acct-menu a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;text-decoration:none;color:var(--ink);font-size:14px;font-weight:500}
  .acct-badge{margin-left:auto;background:var(--copper);color:#fff;font-size:11px;font-weight:700;min-width:18px;height:18px;border-radius:20px;display:flex;align-items:center;justify-content:center;padding:0 5px}
  .acct-help{margin:10px 6px 2px;padding:12px 13px;background:var(--wash);border-radius:12px;font-size:12.5px;color:var(--slate);line-height:1.45}
  .acct-help b{display:block;color:var(--ink);margin-bottom:3px;font-size:13px}
  .acct-menu a:hover{background:var(--wash)}
  .acct-menu a svg{width:17px;height:17px;stroke:var(--slate);fill:none;stroke-width:1.8}
  .acct-menu .sep{height:1px;background:var(--line);margin:6px 0}
  .acct-menu a.out{color:var(--copper)}
  .acct-menu a.out svg{stroke:var(--copper)}
  @keyframes popin{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

  /* ===== Formulaire "Proposer une maison" (kf-) ===== */
  .kf-import{background:linear-gradient(135deg,var(--wash),#efe7da);border:1px solid var(--line);border-radius:16px;padding:18px;margin-bottom:22px}
  .kf-import-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:13px}
  .kf-import-ic{width:38px;height:38px;border-radius:11px;background:var(--pine);display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .kf-import-ic svg{width:19px;height:19px;stroke:#fff;fill:none;stroke-width:1.9}
  .kf-import-head b{display:block;font-size:14.5px}
  .kf-import-head small{color:var(--slate);font-size:12.5px}
  .kf-import-row{display:flex;gap:10px}
  .kf-import-row input{flex:1;border:1px solid var(--line);border-radius:10px;padding:11px 14px;font:inherit;background:#fff}
  .kf-import-row input:focus{outline:none;border-color:var(--pine)}
  .kf-import-row button{background:var(--pine);color:#fff;border:none;border-radius:10px;padding:11px 20px;font:inherit;font-weight:600;cursor:pointer;white-space:nowrap}
  .kf-import-row button:disabled{opacity:.6;cursor:default}
  .kf-import-status{font-size:13px;margin-top:10px;display:none}
  .kf-import-status.show{display:block}
  .kf-import-status.load{color:var(--slate)}.kf-import-status.ok{color:#1f5840}.kf-import-status.err{color:#9c3a1e}
  .kf-spin{display:inline-block;width:13px;height:13px;border:2px solid var(--line);border-top-color:var(--pine);border-radius:50%;animation:sp .7s linear infinite;vertical-align:-2px;margin-right:6px}
  @keyframes sp{to{transform:rotate(360deg)}}
  /* autocomplete lieu */
  .kf-loc-wrap{position:relative}
  .kf-ac{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 16px 40px rgba(28,22,17,.14);z-index:30;overflow:hidden;display:none;font-weight:400}
  .kf-ac.open{display:block}
  .kf-ac .it{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer;font-size:14px}
  .kf-ac .it:hover,.kf-ac .it.sel{background:var(--wash)}
  .kf-ac .it svg{width:16px;height:16px;stroke:var(--pine);fill:none;stroke-width:1.8;flex-shrink:0}
  .kf-ac .it .sub{color:var(--mist);font-size:12.5px}
  /* dropzone */
  .kf-photos-block{margin:6px 0 4px}
  .kf-lbl{display:block;font-size:13px;font-weight:600;margin-bottom:7px}
  .kf-dz{border:2px dashed var(--line);border-radius:16px;padding:30px 20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:#fff}
  .kf-dz:hover,.kf-dz.drag{border-color:var(--pine);background:var(--wash)}
  .kf-dz-ic{width:48px;height:48px;border-radius:14px;background:var(--wash);display:inline-flex;align-items:center;justify-content:center;margin-bottom:12px}
  .kf-dz-ic svg{width:23px;height:23px;stroke:var(--pine);fill:none;stroke-width:1.8}
  .kf-dz b{display:block;font-size:15px}.kf-dz .kf-browse{color:var(--pine);text-decoration:underline}
  .kf-dz p{color:var(--mist);font-size:12.5px;margin-top:6px}
  .kf-previews{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px}
  .kf-pv{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:var(--wash);cursor:grab}
  .kf-pv.dragging{opacity:.4}
  .kf-pv img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
  .kf-pv .del{position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;background:rgba(28,22,17,.62);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}
  .kf-pv .del svg{width:13px;height:13px;stroke:#fff;fill:none;stroke-width:2.5}
  .kf-pv .main{position:absolute;bottom:6px;left:6px;background:var(--pine);color:#fff;font-size:10px;font-weight:600;padding:3px 8px;border-radius:20px}

  /* ===== Calendrier de la barre de recherche (home) ===== */
  .sf-dates{position:relative;display:flex !important;flex-direction:row !important;gap:0;cursor:pointer;flex:2;padding:0 !important}
  .sf-dates .sf-half{flex:1;display:flex;flex-direction:column;justify-content:center;padding:13px 20px;text-align:left}
  .sf-dates #ariaOutHalf{border-left:1px solid var(--line)}
  .sf-dates .sf-half label{display:flex;align-items:center;gap:7px;margin-bottom:5px}
  @media(max-width:680px){.sf-dates{flex:1}.sf-dates #ariaOutHalf{border-left:none;border-top:1px solid var(--line)}}
  .search-wrap .pop{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%);width:340px;max-width:92vw;z-index:80;background:var(--paper);border:1px solid var(--line);border-radius:18px;box-shadow:0 24px 60px rgba(28,22,17,.18);padding:18px;display:none}
  .search-wrap .pop.open{display:block;animation:popinCenter .18s ease}
  @keyframes popinCenter{from{opacity:0;transform:translateX(-50%) translateY(-6px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
  .search-wrap .pop-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
  .search-wrap .pop-head .mn{font-size:15px;font-weight:600;text-transform:capitalize}
  .search-wrap .pop-head button{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:var(--paper);display:flex;align-items:center;justify-content:center;cursor:pointer}
  .search-wrap .pop-head svg{width:14px;height:14px;stroke:var(--ink);fill:none;stroke-width:2.4}
  .search-wrap .cg{display:grid;grid-template-columns:repeat(7,1fr)}
  .search-wrap .cg-dw{margin-bottom:6px}
  .search-wrap .dw{font-family:'Geist Mono',monospace;font-size:11px;color:var(--mist);text-align:center;padding:3px 0}
  .search-wrap .cd{position:relative;height:38px;display:flex;align-items:center;justify-content:center;font-size:13.5px;cursor:pointer;z-index:1}
  .search-wrap .cd.empty{cursor:default}
  .search-wrap .cd.past{color:#d9d0c4;pointer-events:none}
  .search-wrap .cd.avail:hover{background:var(--wash);border-radius:50%}
  .search-wrap .cd.inrange{background:var(--wash)}
  .search-wrap .cd.sel{font-weight:700;color:#fff}
  .search-wrap .cd.sel::before{content:"";position:absolute;inset:3px;background:var(--pine);border-radius:50%;z-index:-1}
  .search-wrap .cd.sel-in{background:linear-gradient(to right,transparent 50%,var(--wash) 50%)}
  .search-wrap .cd.sel-out{background:linear-gradient(to left,transparent 50%,var(--wash) 50%)}
  .search-wrap .pop-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:12px;border-top:1px solid var(--line)}
  .search-wrap .pop-foot .hint{font-size:12.5px;color:var(--slate)}
  .search-wrap .pop-foot button{background:var(--ink);color:#fff;border:none;border-radius:9px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer}
  .aria-tag.active{background:var(--pine);color:#fff;border-color:var(--pine)}

  /* ===== Dashboard propriétaire v2 ===== */
  .auth-wrap.wide.is-dashboard{max-width:none;padding:0;background:#efe9df}
  .dash-shell{display:block;max-width:var(--content);margin:0 auto;padding:110px var(--gutter) 40px}
  .dash-main{min-width:0}
  .dash-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:26px;flex-wrap:wrap;gap:16px}
  .dash-head .auth-title{margin:0}
  .dash-head .auth-sub{margin-top:4px}
  .dash-add-btn{background:var(--ink);color:#fff;border:none;border-radius:40px;padding:13px 24px;font:inherit;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px}
  .dash-add-btn svg{width:17px;height:17px;stroke:#fff;fill:none;stroke-width:2.2}
  .dash-add-btn:hover{opacity:.92}
  /* stats */
  .dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:32px}
  .dash-stat{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:17px 18px}
  .ds-ic{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
  .i-slate{background:var(--slate)}
  .ds-ic svg{width:17px;height:17px;stroke:#fff;fill:none;stroke-width:2}
  .i-green{background:var(--pine)}.i-copper{background:var(--copper)}.i-gold{background:var(--gold)}
  .dash-stat b{font-family:'Fraunces',serif;font-size:26px;display:block;line-height:1}
  .dash-stat span{color:var(--mist);font-size:12.5px}
  /* section + filtres */
  .dash-sec{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-size:13px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--mist)}
  .dash-seg{display:flex;gap:4px;background:var(--wash);border-radius:30px;padding:3px}
  .dash-seg button{border:none;background:transparent;font:inherit;font-size:12px;font-weight:600;color:var(--slate);padding:5px 13px;border-radius:30px;cursor:pointer;text-transform:none;letter-spacing:0}
  .dash-seg button.on{background:var(--paper);color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.06)}
  /* cartes */
  .dash-listings{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:30px}
  .dcard{background:var(--paper);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,box-shadow .2s}
  .dcard:hover{transform:translateY(-3px);box-shadow:0 18px 40px -20px rgba(28,22,17,.3)}
  .dcard.hide{display:none}
  .dcard-ph{aspect-ratio:1;background-size:cover;background-position:center;background-color:var(--wash);position:relative}
  .dcard-st{position:absolute;top:11px;left:11px;display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;font-size:11px;font-weight:600;backdrop-filter:blur(6px)}
  .dcard-st::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
  .dcard-st.s-publish{background:rgba(231,242,236,.92);color:#1f5840}
  .dcard-st.s-pending{background:rgba(251,234,229,.92);color:#9c3a1e}
  .dcard-st.s-draft{background:rgba(239,236,231,.92);color:#7a7066}
  .dcard-body{padding:15px 16px;flex:1;display:flex;flex-direction:column}
  .dcard-body h3{font-size:15.5px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .dcard-loc{color:var(--mist);font-size:13px;margin-bottom:13px;display:flex;align-items:center;gap:4px}
  .dcard-loc svg{width:13px;height:13px;stroke:var(--mist);fill:none;stroke-width:1.8;flex-shrink:0}
  .dcard-meta{font-size:13px;color:var(--slate);padding-bottom:13px;margin-bottom:13px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:baseline;gap:10px}
  .dcard-views{white-space:nowrap}
  .dcard-meta b{color:var(--ink);font-family:'Fraunces',serif;font-size:17px}
  .dcard-acts{margin-top:auto;display:flex;gap:8px}
  .dcard-acts a{flex:1;text-align:center;padding:9px;border-radius:10px;font-size:13px;font-weight:600;text-decoration:none}
  .d-edit{background:var(--ink);color:#fff}
  .d-view{border:1px solid var(--line);color:var(--ink)}
  /* carte ajouter */
  .dcard-add{border:2px dashed var(--line);background:transparent;border-radius:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;color:var(--slate);min-height:240px;transition:border-color .2s,background .2s;font:inherit}
  .dcard-add:hover{border-color:var(--pine);background:var(--paper)}
  .dcard-add .plus{width:46px;height:46px;border-radius:50%;background:var(--wash);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
  .dcard-add .plus svg{width:21px;height:21px;stroke:var(--pine);fill:none;stroke-width:2}
  .dcard-add b{font-size:14.5px;color:var(--ink)}
  /* sidebar droite — démarre au niveau des stats (sous le bouton Ajouter) */
  .dash-side{grid-column:2;align-self:start;background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:20px 15px;margin-top:96px}
  .ds-who{display:flex;align-items:center;gap:11px;padding:4px 6px 16px;border-bottom:1px solid var(--line);margin-bottom:12px}
  .ds-av{width:42px;height:42px;border-radius:50%;background:var(--copper);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:17px;flex-shrink:0}
  .ds-who b{font-size:14.5px;display:block}.ds-who span{font-size:12px;color:var(--mist)}
  .ds-nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:var(--slate);text-decoration:none;font-size:14.5px;font-weight:500;margin-bottom:3px}
  .ds-nav a svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8}
  .ds-nav a.on{background:var(--pine);color:#fff}
  .ds-nav a:not(.on):hover{background:var(--wash);color:var(--ink)}
  .ds-nav a.out{color:var(--copper-deep)}
  .ds-help{margin-top:16px;padding:14px;background:var(--wash);border-radius:14px;font-size:12.5px;color:var(--slate)}
  .ds-help b{display:block;color:var(--ink);margin-bottom:4px;font-size:13px}
  .dash-form-panel{display:none;animation:popin .2s ease;max-width:var(--content);margin:0 auto;padding:0 var(--gutter) 70px}
  .dash-form-panel.open{display:block}
  /* responsive */
  @media(max-width:1000px){
    .dash-shell{grid-template-columns:1fr}
    .dash-main{grid-column:1}
    .dash-side{grid-column:1;margin-top:0;order:-1;margin-bottom:24px}
    .ds-nav{display:flex;flex-wrap:wrap;gap:6px}
    .ds-nav a{margin-bottom:0}
    .ds-help{display:none}
    .dash-stats{grid-template-columns:repeat(2,1fr)}
    .dash-listings{grid-template-columns:repeat(2,1fr)}
  }
  @media(max-width:560px){
    .dash-listings{grid-template-columns:1fr}
    .dash-head{flex-direction:column;align-items:stretch}
    .dash-add-btn{justify-content:center}
    .dash-sec{flex-direction:column;align-items:flex-start;gap:10px}
    .dash-stats{grid-template-columns:1fr}
  }

  /* ===== Messagerie (dashboard) ===== */
  .inbox{display:grid;grid-template-columns:300px 1fr;background:var(--paper);border:1px solid var(--line);border-radius:18px;overflow:hidden;min-height:440px;margin-bottom:30px}
  .inbox-list{border-right:1px solid var(--line);max-height:520px;overflow-y:auto}
  .conv{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);cursor:pointer;position:relative}
  .conv:hover,.conv.active{background:var(--wash)}
  .conv.active::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--pine)}
  .conv.unread::before{content:"";position:absolute;left:6px;top:50%;width:7px;height:7px;border-radius:50%;background:var(--copper);transform:translateY(-50%)}
  .conv .cav{width:42px;height:42px;border-radius:50%;background:var(--pine);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}
  .conv .cmain{min-width:0;flex:1}
  .conv .crow1{display:flex;justify-content:space-between;gap:8px}
  .conv .cname{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .conv .ctime{font-size:11px;color:var(--mist);flex-shrink:0}
  .conv .chouse{font-size:12px;color:var(--copper);margin:1px 0 3px}
  .conv .cprev{font-size:12.5px;color:var(--slate);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .conv.unread .cprev{color:var(--ink);font-weight:500}
  .inbox-list .search-row{padding:0 14px;height:72px;display:flex;align-items:center;border-bottom:1px solid var(--line)}
  .inbox-list .search-row .sbox{width:100%}
  .inbox-list .sbox{display:flex;align-items:center;gap:8px;background:var(--wash);border-radius:11px;padding:9px 13px}
  .inbox-list .sbox svg{width:16px;height:16px;stroke:var(--mist);fill:none;stroke-width:2;flex-shrink:0}
  .inbox-list .sbox input{border:none;background:transparent;font:inherit;font-size:13.5px;width:100%;outline:none}
  .conv .badge{background:var(--copper);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:20px;display:flex;align-items:center;justify-content:center;padding:0 5px;flex-shrink:0;align-self:center}
  .thread{display:flex;flex-direction:column;min-width:0}
  .thread-empty{margin:auto;color:var(--mist);font-size:14px;padding:40px;text-align:center}
  .thread-head{padding:0 18px;height:72px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:13px}
  .thread-head .th-ph{width:46px;height:46px;border-radius:13px;object-fit:cover;flex-shrink:0}
  .thread-head .th-av{width:46px;height:46px;border-radius:13px;background:var(--pine);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}
  .thread-head .thi{min-width:0;flex:1}
  .thread-head b{font-size:15px;display:block}
  .thread-head .th-house{font-size:12.5px;color:var(--copper);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
  .thread-head .th-view{margin-left:auto;font-size:12.5px;font-weight:600;color:var(--pine);text-decoration:none;border:1px solid var(--line);padding:8px 14px;border-radius:30px;white-space:nowrap}
  .thread-head .th-view:hover{background:var(--wash)}
  .thread-body{flex:1;padding:22px 20px;display:flex;flex-direction:column;gap:5px;background:linear-gradient(var(--paper),var(--wash));overflow-y:auto}
  .day-sep{align-self:center;background:rgba(28,22,17,.06);color:var(--slate);font-size:11px;font-weight:600;padding:4px 13px;border-radius:20px;margin:10px 0}
  .trow{display:flex;flex-direction:column;max-width:72%}
  .trow.me{align-self:flex-end;align-items:flex-end}
  .trow.them{align-self:flex-start}
  .trow .bubble{padding:10px 15px;border-radius:18px;font-size:14px;line-height:1.45}
  .trow .bubble p{margin:0}
  .trow.them .bubble{background:#fff;border:1px solid var(--line);border-bottom-left-radius:5px}
  .trow.me .bubble{background:var(--pine);color:#fff;border-bottom-right-radius:5px}
  .trow .bmeta{font-size:10.5px;color:var(--mist);margin:3px 6px 0}
  .trow.stack{margin-top:-3px}
  .trow.stack .bmeta{display:none}
  .thread-foot{padding:14px 16px;border-top:1px solid var(--line);display:flex;gap:10px;align-items:flex-end}
  .thread-foot .tf-field{flex:1;background:var(--wash);border-radius:22px;padding:4px 8px 4px 18px;display:flex;align-items:flex-end}
  .thread-foot textarea{flex:1;border:none;background:transparent;font:inherit;font-size:14px;resize:none;outline:none;padding:9px 0;max-height:110px;line-height:1.4}
  .thread-foot .send{width:42px;height:42px;border-radius:50%;background:var(--pine);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .thread-foot .send svg{width:17px;height:17px;stroke:#fff;fill:none;stroke-width:2}
  @media(max-width:760px){.inbox{grid-template-columns:1fr}.inbox-list{max-height:260px}}

  /* ===== Page Messagerie dédiée ===== */
  .auth-wrap.wide.is-dashboard .msg-page{max-width:var(--content);margin:0 auto;padding:110px var(--gutter) 70px}
  .msg-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}
  .msg-head .auth-title{margin:0}
  .msg-back{display:inline-flex;align-items:center;gap:6px;color:var(--slate);text-decoration:none;font-size:14px;font-weight:600}
  .msg-back svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}
  .msg-back:hover{color:var(--ink)}
  .inbox-page{min-height:560px}
  .inbox-page .inbox-list{max-height:620px}
  .inbox-page .thread-body{max-height:520px}
  .msg-empty-full{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:60px 30px;text-align:center}
  .msg-empty-full .ic{width:64px;height:64px;border-radius:18px;background:var(--wash);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
  .msg-empty-full .ic svg{width:30px;height:30px;stroke:var(--pine);fill:none;stroke-width:1.7}
  .msg-empty-full h3{font-size:20px;margin-bottom:8px}
  .msg-empty-full p{color:var(--slate);max-width:420px;margin:0 auto}
  .ds-badge{margin-left:auto;background:var(--copper);color:#fff;font-size:11px;font-weight:600;padding:1px 8px;border-radius:20px}

  /* ===== Carte "Demande de séjour" dans le fil ===== */
  .req-card{align-self:flex-start;background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;max-width:320px;margin-bottom:8px;box-shadow:0 6px 16px -12px rgba(28,22,17,.25)}
  .req-card .rc-head{background:var(--wash);padding:9px 14px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--copper);display:flex;align-items:center;gap:7px}
  .req-card .rc-head svg{width:14px;height:14px;stroke:var(--copper);fill:none;stroke-width:2}
  .req-card .rc-body{display:flex;padding:13px 15px;gap:14px;align-items:center}
  .req-card .seg{text-align:left}
  .req-card .seg .lab{font-size:9.5px;letter-spacing:.5px;text-transform:uppercase;color:var(--mist);font-weight:600}
  .req-card .seg .val{font-size:14.5px;font-weight:600;font-family:'Fraunces',serif}
  .req-card .arrow{color:var(--mist)}
  .req-card .rc-foot{border-top:1px solid var(--line);padding:8px 15px;font-size:12px;color:var(--slate)}
  .req-card .rc-foot b{color:var(--ink)}

  /* ===== Autocomplétion Destination ===== */
  .dest-ac{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:0 20px 50px rgba(28,22,17,.16);z-index:90;overflow:hidden;display:none;max-height:300px;overflow-y:auto}
  .dest-ac.open{display:block}
  .ac-item{display:flex;align-items:center;gap:10px;padding:11px 15px;cursor:pointer;border-bottom:1px solid var(--line)}
  .ac-item:last-child{border-bottom:none}
  .ac-item:hover{background:var(--wash)}
  .ac-item svg{width:16px;height:16px;stroke:var(--mist);fill:none;stroke-width:1.8;flex-shrink:0}
  .ac-item .ac-name{font-size:14px;font-weight:500;color:var(--ink);flex:1}
  .ac-item .ac-type{font-size:11px;color:var(--mist);text-transform:uppercase;letter-spacing:.4px}

  /* ===== Calendrier de disponibilités (carte dashboard) ===== */
  .d-avail-btn{margin-top:10px;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:10px;font:inherit;font-size:13px;font-weight:600;color:var(--slate);cursor:pointer;transition:background .15s,color .15s}
  .d-avail-btn:hover{background:var(--wash);color:var(--ink)}
  .d-avail-btn.on{background:var(--pine);color:#fff;border-color:var(--pine)}
  .d-avail-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2}
  .d-avail{margin-top:12px;border-top:1px solid var(--line);padding-top:12px}
  .av-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;min-height:20px}
  .av-count{font-size:12.5px;color:var(--slate)}.av-count b{color:var(--ink)}
  .av-status{font-size:11.5px;font-weight:600;color:var(--pine);opacity:0;transition:opacity .2s}
  .av-status.on{opacity:1}
  .av-tools{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
  .av-tools button{flex:1;min-width:84px;background:var(--wash);border:1px solid var(--line);border-radius:9px;padding:7px 6px;font:inherit;font-size:11.5px;font-weight:600;color:var(--slate);cursor:pointer}
  .av-tools button:hover{background:var(--line)}
  .av-month{margin-bottom:16px}
  .av-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
  .av-nav{width:30px;height:30px;border-radius:9px;border:1px solid var(--line);background:var(--paper);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .av-nav:hover{background:var(--wash)}
  .av-nav svg{width:16px;height:16px;stroke:var(--ink);fill:none;stroke-width:2}
  .av-nav-dis{opacity:.3;cursor:default;pointer-events:none}
  .av-mn{font-size:13px;font-weight:600;text-align:center;font-family:'Fraunces',serif;flex:1}
  .av-legend{display:flex;gap:18px;font-size:12px;color:var(--slate);margin-top:6px}
  .av-legend span{display:flex;align-items:center;gap:6px}
  .av-legend i{width:13px;height:13px;border-radius:4px;display:inline-block}
  .av-legend .ok{background:#eaf3ee;border:1px solid var(--line)}
  .av-legend .no{background:#f7e7e0;border:1px solid #e8cdbf}
  .av-dows{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:4px}
  .av-dows span{text-align:center;font-size:10px;color:var(--mist);font-weight:600}
  .av-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
  .av-empty{aspect-ratio:1}
  .av-day{aspect-ratio:1;border:1px solid var(--line);background:#eaf3ee;color:var(--pine);border-radius:7px;font:inherit;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .08s}
  .av-day:hover{transform:scale(1.08)}
  .av-day.av-off{background:#f7e7e0;color:#955530;border-color:#e8cdbf}
  .av-day.av-disabled{background:transparent;border-color:transparent;color:var(--mist);opacity:.4;cursor:default}
  .av-day.av-disabled:hover{transform:none}

  /* ===== Page Statistiques (front, admin) ===== */
  .auth-wrap.wide.is-dashboard .stats-page{max-width:var(--content);margin:0 auto;padding:110px var(--gutter) 70px}
  .stats-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:14px}
  .stats-head .auth-title{margin:0}
  .stats-period{display:flex;gap:6px;background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:4px}
  .stats-period a{text-decoration:none;font-size:13px;font-weight:600;color:var(--slate);padding:7px 14px;border-radius:8px}
  .stats-period a.on{background:var(--pine);color:#fff}
  .stats-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}
  .stats-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:18px}
  .stats-card .lab{font-size:12.5px;color:var(--slate);margin-bottom:8px}
  .stats-card .val{font-size:28px;font-weight:600;font-family:'Fraunces',serif}
  .stats-card .delta{font-size:12px;font-weight:600;color:#2b9348;margin-top:5px}
  .stats-row{display:grid;grid-template-columns:1.6fr 1fr;gap:14px;margin-bottom:14px}
  .stats-panel{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:18px 20px}
  .stats-panel h2{font-size:14px;font-weight:600;margin-bottom:16px}
  .stats-chart{display:flex;align-items:flex-end;gap:4px;height:170px;padding-top:10px}
  .stats-bar{flex:1;background:linear-gradient(var(--pine),#3c5e4e);border-radius:5px 5px 0 0;min-height:3px}
  .stats-bar:hover{opacity:.8}
  .stats-lst{list-style:none}
  .stats-lst li{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line);font-size:13.5px}
  .stats-lst li:last-child{border-bottom:none}
  .stats-lst .nm{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .stats-lst .ct{font-weight:600;color:var(--slate);margin-left:10px;flex-shrink:0}
  .stats-mini{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .stats-seg{display:flex;justify-content:space-between;font-size:13px;padding:6px 0}
  .stats-seg .pc{font-weight:600;color:var(--slate)}
  .stats-note{font-size:12.5px;color:var(--mist);margin-top:18px;max-width:780px}
  @media(max-width:820px){.stats-cards{grid-template-columns:1fr 1fr}.stats-row{grid-template-columns:1fr}.stats-mini{grid-template-columns:1fr}}

  /* Barre de recherche sur l'archive des maisons */
  .archive-search{margin:0 0 34px}
  .archive-search .search-wrap{max-width:none;padding:0;margin:0;opacity:1;animation:none}

  /* ===== Équipements dans le formulaire d'annonce ===== */
  .kf-am-block{margin:6px 0 4px}
  .kf-am-block .kf-lbl{display:block;font-size:13px;font-weight:600;margin-bottom:10px;color:var(--ink)}
  .kf-amenities{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
  .auth-form label.kf-am{flex-direction:row;align-items:center;text-align:left;font-weight:500}
  .kf-am{display:flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:12px;padding:11px 13px;cursor:pointer;transition:border-color .15s,background .15s;user-select:none}
  .kf-am:hover{background:var(--wash)}
  .kf-am input{display:none}
  .kf-am-box{width:18px;height:18px;border:1.5px solid var(--mist);border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
  .kf-am-box svg{width:11px;height:11px;stroke:#fff;fill:none;stroke-width:3;opacity:0}
  .kf-am-ic{width:17px;height:17px;stroke:var(--slate);fill:none;stroke-width:1.8;flex-shrink:0}
  .kf-am-lbl{font-size:13.5px}
  .kf-am input:checked ~ .kf-am-box{background:var(--pine);border-color:var(--pine)}
  .kf-am input:checked ~ .kf-am-box svg{opacity:1}
  .kf-am input:checked ~ .kf-am-ic{stroke:var(--pine)}
  .kf-am:has(input:checked){border-color:var(--pine);background:var(--pine-wash,#eaf1ec)}
  @media(max-width:560px){.kf-amenities{grid-template-columns:repeat(2,1fr)}}

  /* ===== Frais de ménage (formulaire d'annonce) ===== */
  .kf-cleaning{margin:4px 0 2px}
  .auth-form label.kf-check{display:flex;flex-direction:row;align-items:center;gap:10px;cursor:pointer;user-select:none;font-size:14px;font-weight:500;text-align:left;justify-content:flex-start}
  .kf-check{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none;font-size:14px;font-weight:500}
  .kf-check input{display:none}
  .kf-check-box{width:20px;height:20px;border:1.5px solid var(--mist);border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
  .kf-check-box svg{width:12px;height:12px;stroke:#fff;fill:none;stroke-width:3;opacity:0}
  .kf-check input:checked ~ .kf-check-box{background:var(--pine);border-color:var(--pine)}
  .kf-check input:checked ~ .kf-check-box svg{opacity:1}
  .kf-cleaning-amt{margin-top:12px}
  .kf-cleaning-amt[hidden]{display:none}

  /* ===== Formulaire d'annonce en sections + complétude ===== */
  .kf-progress{margin:4px 0 8px}
  .kf-progress-top{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:6px;color:var(--slate)}
  .kf-progress-top b{color:var(--pine)}
  .kf-progress-track{height:7px;background:var(--wash);border-radius:6px;overflow:hidden}
  .kf-progress-fill{height:100%;width:0;background:linear-gradient(90deg,var(--copper),var(--gold));border-radius:6px;transition:width .35s}
  .kf-sec{border-top:1px solid var(--line);padding-top:20px;margin-top:22px}
  .kf-progress + .kf-sec{border-top:none;padding-top:0;margin-top:10px}
  .kf-sec-h{display:flex;align-items:center;gap:9px;font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--slate);margin-bottom:16px}
  .kf-sec-h svg{width:16px;height:16px;stroke:var(--copper);fill:none;stroke-width:2;flex-shrink:0}
  .kf-sectioned select{width:100%;border:1px solid var(--line);border-radius:11px;padding:11px 13px;font:inherit;font-size:14px;background:#fff;outline:none}
  .kf-sectioned select:focus{border-color:var(--pine)}

  /* ===== Génération IA : zone "coller le texte" ===== */
  .kf-import-paste{margin-top:10px}
  .kf-paste-toggle{background:none;border:none;color:var(--pine);font:inherit;font-size:13px;font-weight:600;cursor:pointer;padding:0;text-decoration:underline}
  .kf-paste-box{margin-top:10px;display:flex;flex-direction:column;gap:10px}
  .kf-paste-box[hidden]{display:none}
  .kf-paste-box textarea{width:100%;border:1px solid var(--line);border-radius:11px;padding:11px 13px;font:inherit;font-size:14px;background:#fff;outline:none;resize:vertical}
  .kf-paste-box textarea:focus{border-color:var(--pine)}
  .kf-paste-box button{align-self:flex-start;background:var(--pine);color:#fff;border:none;border-radius:10px;padding:10px 16px;font:inherit;font-size:13.5px;font-weight:600;cursor:pointer}
  .kf-paste-box button:hover{background:var(--pine-deep,#22382e)}

  /* ===== Import IA : onglets méthode ===== */
  .kf-import-ai .kf-imp-tabs{display:flex;gap:8px;margin:14px 0 14px}
  .kf-imp-tab{flex:1;background:#fff;border:1px solid var(--line);border-radius:11px;padding:10px;font:inherit;font-size:13.5px;font-weight:600;cursor:pointer;color:var(--slate);display:flex;align-items:center;justify-content:center;gap:7px;transition:all .15s}
  .kf-imp-tab.on{border-color:var(--pine);background:var(--pine-wash,#eaf1ec);color:var(--pine)}
  .kf-imp-reco{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;background:var(--copper);color:#fff;border-radius:5px;padding:1px 6px}
  .kf-imp-pane[hidden]{display:none}
  .kf-imp-steps{margin:0 0 12px;padding-left:20px;color:var(--slate);font-size:13px;line-height:1.7}
  .kf-imp-steps li{margin-bottom:2px}
  .kf-imp-note{font-size:12.5px;color:var(--mist);margin:0 0 10px}
  .kf-imp-pane textarea{width:100%;border:1px solid var(--line);border-radius:11px;padding:11px 13px;font:inherit;font-size:14px;background:#fff;outline:none;resize:vertical;margin-bottom:10px}
  .kf-imp-pane textarea:focus{border-color:var(--pine)}
  .kf-imp-go{background:var(--pine);color:#fff;border:none;border-radius:10px;padding:11px 18px;font:inherit;font-size:14px;font-weight:600;cursor:pointer}
  .kf-imp-go:hover{background:var(--pine-deep,#22382e)}

  /* ===== Overlay de progression à la soumission ===== */
  .kf-submit-overlay{position:fixed;inset:0;z-index:9999;background:rgba(28,22,17,.55);display:flex;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(2px)}
  .kf-submit-overlay[hidden]{display:none}
  .kf-submit-card{background:var(--paper);border-radius:18px;padding:30px 28px;max-width:380px;width:100%;text-align:center;box-shadow:0 24px 60px rgba(28,22,17,.3)}
  .kf-submit-card b{display:block;font-size:16px;margin:16px 0 14px;color:var(--ink)}
  .kf-submit-spin{width:38px;height:38px;border:3px solid var(--line);border-top-color:var(--pine);border-radius:50%;margin:0 auto;animation:kfspin .8s linear infinite}
  @keyframes kfspin{to{transform:rotate(360deg)}}
  .kf-submit-track{height:8px;background:var(--wash);border-radius:6px;overflow:hidden;margin-bottom:12px}
  .kf-submit-fill{height:100%;width:4%;background:linear-gradient(90deg,var(--copper),var(--gold));border-radius:6px;transition:width .3s}
  .kf-submit-card small{color:var(--slate);font-size:13px;line-height:1.5}

  /* ===== Accroche import IA (page Louer ma maison) ===== */
  .lmm-import{margin:40px auto}
  .lmm > .lmm-import:first-child{margin-top:96px}
  .ih{background:linear-gradient(135deg,var(--pine),var(--pine-deep,#22382e));border-radius:24px;padding:44px;color:#e8e2d6;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;position:relative;overflow:hidden}
  .ih::after{content:"";position:absolute;right:-80px;top:-80px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(192,138,62,.22),transparent 70%)}
  .ih-left{position:relative;z-index:1}
  .ih-pill{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:30px;padding:6px 14px;font-size:12.5px;font-weight:600;margin-bottom:18px}
  .ih-pill svg{width:14px;height:14px;stroke:var(--gold);fill:none;stroke-width:2}
  .ih h2{font-family:'Fraunces',serif;font-size:32px;font-weight:600;color:#fff;line-height:1.13;margin-bottom:14px}
  .ih h2 em{font-style:italic;color:var(--gold)}
  .ih>.ih-left>p{font-size:16px;color:#c2ccc3;margin-bottom:24px;max-width:440px}
  .ih-steps{display:flex;gap:20px;margin-bottom:28px}
  .ih-step{flex:1}
  .ih-step .n{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff;margin-bottom:9px}
  .ih-step b{display:block;font-size:13.5px;color:#fff;margin-bottom:2px}
  .ih-step span{font-size:12.5px;color:#a9b4aa}
  .ih-cta{display:inline-flex;align-items:center;gap:9px;background:var(--copper);color:#fff;text-decoration:none;border-radius:12px;padding:14px 24px;font-size:15px;font-weight:600;transition:background .2s}
  .ih-cta:hover{background:var(--gold)}
  .ih-cta svg{width:17px;height:17px;stroke:#fff;fill:none;stroke-width:2.2}
  .ih-right{position:relative;z-index:1}
  .ih-mock{background:var(--paper);border-radius:16px;padding:18px;box-shadow:0 20px 50px rgba(0,0,0,.28)}
  .ih-mock-head{display:flex;align-items:center;gap:9px;margin-bottom:14px;color:var(--ink)}
  .ih-mock-head .star{width:32px;height:32px;border-radius:9px;background:var(--pine);display:flex;align-items:center;justify-content:center}
  .ih-mock-head .star svg{width:17px;height:17px;stroke:#fff;fill:none;stroke-width:2}
  .ih-mock-head b{font-size:14px}
  .ih-mock-field{display:flex;gap:8px;margin-bottom:12px}
  .ih-mock-field input{flex:1;border:1px solid var(--line);border-radius:10px;padding:11px 13px;font:inherit;font-size:13px;color:var(--mist);background:#fff}
  .ih-mock-field button{background:var(--pine);color:#fff;border:none;border-radius:10px;padding:0 16px;font:inherit;font-size:13px;font-weight:600;white-space:nowrap;cursor:default}
  .ih-mock-prog{height:6px;background:var(--wash);border-radius:6px;overflow:hidden;margin-bottom:12px}
  .ih-mock-prog i{display:block;height:100%;width:72%;background:linear-gradient(90deg,var(--copper),var(--gold))}
  .ih-mock-lines>div{height:9px;background:var(--wash);border-radius:5px;margin-bottom:7px}
  .ih-mock-lines>div:nth-child(1){width:90%}.ih-mock-lines>div:nth-child(2){width:80%}.ih-mock-lines>div:nth-child(3){width:60%}
  .ih-mock-imgs{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:12px}
  .ih-mock-imgs span{aspect-ratio:1;border-radius:8px;background:linear-gradient(135deg,var(--pine-wash,#eaf1ec),#dfe8e0)}
  @media(max-width:820px){.ih{grid-template-columns:1fr;padding:30px}.ih-right{display:none}.ih h2{font-size:26px}}

  /* ===== Bandeau import compact (home, sous le hero) ===== */
  .import-strip{max-width:var(--content);margin:0 auto 10px;padding:0 var(--gutter)}
  .import-strip-in{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:22px 26px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
  .import-strip .is-ic{width:50px;height:50px;border-radius:14px;background:linear-gradient(135deg,var(--copper),var(--gold));display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .import-strip .is-ic svg{width:25px;height:25px;stroke:#fff;fill:none;stroke-width:2}
  .import-strip .is-txt{flex:1;min-width:240px}
  .import-strip .is-txt b{font-family:'Fraunces',serif;font-size:19px;display:block;margin-bottom:3px;color:var(--ink)}
  .import-strip .is-txt span{font-size:14px;color:var(--slate)}
  .import-strip .is-cta{background:var(--pine);color:#fff;text-decoration:none;border-radius:11px;padding:12px 20px;font-size:14px;font-weight:600;white-space:nowrap;transition:background .2s}
  .import-strip .is-cta:hover{background:var(--pine-deep,#22382e)}

  /* ===== Section propriétaires sur la home (import IA, 2 colonnes) ===== */
  .owner-cta{padding:20px 0 60px}
  .owner-cta .oc{display:grid;grid-template-columns:1fr 1fr;border-radius:22px;overflow:hidden;border:1px solid var(--line)}
  .oc-l{padding:44px;background:var(--paper)}
  .oc-pill{display:inline-flex;align-items:center;gap:7px;background:var(--pine-wash,#eaf1ec);color:var(--pine);border-radius:30px;padding:6px 13px;font-size:12px;font-weight:600;margin-bottom:16px}
  .oc-pill svg{width:14px;height:14px;stroke:var(--copper);fill:none;stroke-width:2}
  .oc-l h2{font-family:'Fraunces',serif;font-size:30px;line-height:1.13;margin-bottom:13px;color:var(--ink)}
  .oc-l p{font-size:16px;color:var(--slate);margin-bottom:24px;max-width:430px}
  .oc-cta{display:inline-flex;align-items:center;gap:9px;background:var(--pine);color:#fff;text-decoration:none;border-radius:12px;padding:14px 24px;font-size:15px;font-weight:600;transition:background .2s}
  .oc-cta:hover{background:var(--pine-deep,#22382e)}
  .oc-cta svg{width:17px;height:17px;stroke:#fff;fill:none;stroke-width:2.2}
  .oc-r{background:linear-gradient(135deg,var(--pine),var(--pine-deep,#22382e));display:flex;align-items:center;justify-content:center;padding:36px;position:relative}
  .oc-r::after{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(192,138,62,.22),transparent 70%)}
  .oc-mock{position:relative;z-index:1;background:var(--paper);border-radius:14px;padding:16px;width:100%;max-width:320px;box-shadow:0 18px 44px rgba(0,0,0,.26)}
  .oc-mh{display:flex;align-items:center;gap:8px;margin-bottom:13px;color:var(--ink)}
  .oc-mh .s{width:30px;height:30px;border-radius:8px;background:var(--pine);display:flex;align-items:center;justify-content:center}
  .oc-mh .s svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2}
  .oc-mh b{font-size:13px}
  .oc-mf{display:flex;gap:7px;margin-bottom:11px}
  .oc-mf input{flex:1;border:1px solid var(--line);border-radius:9px;padding:10px;font:inherit;font-size:11.5px;color:var(--mist);background:#fff}
  .oc-mf button{background:var(--pine);color:#fff;border:none;border-radius:9px;padding:0 13px;font-size:12px;cursor:default}
  .oc-mp{height:6px;background:var(--wash);border-radius:5px;overflow:hidden;margin-bottom:11px}
  .oc-mp i{display:block;height:100%;width:70%;background:linear-gradient(90deg,var(--copper),var(--gold))}
  .oc-ml>div{height:9px;background:var(--wash);border-radius:5px;margin-bottom:7px}
  .oc-ml>div:nth-child(1){width:88%}.oc-ml>div:nth-child(2){width:66%}
  .oc-mi{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:11px}
  .oc-mi span{aspect-ratio:1;border-radius:7px;background:linear-gradient(135deg,var(--pine-wash,#eaf1ec),#dfe8e0)}
  @media(max-width:820px){.owner-cta .oc{grid-template-columns:1fr}.oc-r{display:none}.oc-l{padding:32px}.oc-l h2{font-size:25px}}

  /* ===== Bloc propriétaires flottant (home) ===== */
  .owner-ribbon{max-width:var(--content);margin:20px auto 60px;padding:0 var(--gutter)}
  .owner-ribbon .or-card{background:linear-gradient(135deg,var(--pine),var(--pine-deep,#22382e));border-radius:22px;padding:30px 36px;display:flex;align-items:center;gap:26px;flex-wrap:wrap;position:relative;overflow:hidden}
  .owner-ribbon .or-card::after{content:"";position:absolute;right:-60px;top:-80px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(192,138,62,.18),transparent 70%);pointer-events:none}
  .owner-ribbon .or-t{flex:1;min-width:280px;position:relative;z-index:1}
  .owner-ribbon .or-t b{font-family:'Fraunces',serif;font-size:23px;color:#fff;display:block;margin-bottom:4px}
  .owner-ribbon .or-t span{font-size:14.5px;color:#bcc6bd;line-height:1.5}
  .owner-ribbon .or-cta{position:relative;z-index:1;background:var(--gold);color:#3a2a12;text-decoration:none;border-radius:12px;padding:14px 24px;font-size:14.5px;font-weight:600;white-space:nowrap;transition:background .2s}
  .owner-ribbon .or-cta:hover{background:#d49a4e}
  @media(max-width:680px){.owner-ribbon .or-card{padding:26px}.owner-ribbon .or-t b{font-size:20px}}

  /* ===== Page Notre histoire ===== */
  .story{max-width:var(--content);margin:0 auto;padding:0 var(--gutter) 80px}
  .story-lead{max-width:760px;margin:0 auto 50px;text-align:center}
  .story-lead p{font-size:21px;line-height:1.5;color:var(--ink);font-family:'Fraunces',serif}
  .story-cols{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-bottom:60px}
  .story-block h2{font-family:'Fraunces',serif;font-size:24px;margin-bottom:12px;color:var(--ink)}
  .story-block p{font-size:16px;line-height:1.7;color:var(--slate)}
  .story-values{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .story-values .sv{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:26px}
  .story-values .sv-ic{width:46px;height:46px;border-radius:12px;background:var(--pine-wash,#eaf1ec);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
  .story-values .sv-ic svg{width:23px;height:23px;stroke:var(--pine)}
  .story-values .sv h3{font-size:16px;margin-bottom:7px;color:var(--ink)}
  .story-values .sv p{font-size:14px;line-height:1.6;color:var(--slate)}
  @media(max-width:820px){.story-cols{grid-template-columns:1fr;gap:28px}.story-values{grid-template-columns:1fr}}

  /* ===== Page Nos régions ===== */
  .regions{max-width:var(--content);margin:0 auto;padding:0 var(--gutter) 80px;display:grid;grid-template-columns:1fr 1fr;gap:26px}
  .region{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:18px;overflow:hidden;text-decoration:none;background:var(--paper);transition:transform .25s,box-shadow .25s}
  .region:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(28,22,17,.1)}
  .region-img{aspect-ratio:16/10;overflow:hidden}
  .region-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
  .region:hover .region-img img{transform:scale(1.05)}
  .region-body{padding:24px}
  .region-body h2{font-family:'Fraunces',serif;font-size:23px;margin-bottom:8px;color:var(--ink)}
  .region-body p{font-size:14.5px;line-height:1.6;color:var(--slate);margin-bottom:14px}
  .region-link{font-size:14px;font-weight:600;color:var(--pine)}
  @media(max-width:820px){.regions{grid-template-columns:1fr}}

  /* ===== Carte des maisons (Leaflet) ===== */
  .kabin-map-wrap{max-width:var(--content);margin:0 auto 50px;padding:0 var(--gutter)}
  .kabin-map{height:440px;border-radius:18px;overflow:hidden;border:1px solid var(--line);z-index:1;background:var(--pine-wash,#eaf1ec)}
  .aria-pin .aria-pin-dot{display:block;width:18px;height:18px;border-radius:50%;background:var(--copper);border:3px solid #fff;box-shadow:0 2px 6px rgba(28,22,17,.35)}
  .leaflet-popup-content-wrapper{border-radius:14px;padding:0;overflow:hidden}
  .leaflet-popup-content{margin:0;width:auto!important}
  .aria-pop{display:block;text-decoration:none;color:var(--ink);width:220px}
  .aria-pop-img{height:120px;overflow:hidden}
  .aria-pop-img img{width:100%;height:100%;object-fit:cover}
  .aria-pop-body{padding:11px 13px}
  .aria-pop-body b{display:block;font-size:14px;line-height:1.3;margin-bottom:3px}
  .aria-pop-loc{display:block;font-size:12.5px;color:var(--mist);margin-bottom:5px}
  .aria-pop-price{font-size:13px;color:var(--slate)}
  .aria-pop-price b{display:inline;font-size:14px;color:var(--ink)}
