
:root{
  --olive:#51634A;
  --olive-dark:#3D4E37;
  --sand:#F6F5F1;
  --ink:#1E1E1E;
  --muted:#6b6b6b;
  --white:#ffffff;
  --gold:#CBBE8F;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family: ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;background:var(--sand);color:var(--ink)}
a{color:inherit;text-decoration:none}
.container{max-width:1120px;margin:0 auto;padding:0 16px}
/* Header */
.header{position:sticky;top:0;z-index:40;background:rgba(246,245,241,.9);backdrop-filter:saturate(180%) blur(6px);
  border-bottom:1px solid rgba(81,99,74,.12)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0;gap:12px}
.logo{display:flex;align-items:center;gap:10px}
.logo-link img{height:40px;width:auto;display:block}
.brand-sub{font-size:12px;color:#8c8c8c}
.nav a{margin:0 12px;font-size:14px;opacity:.92}
.nav a:hover{color:var(--olive)}
.btn{display:inline-block;padding:9px 16px;border-radius:16px;font-size:14px}
.btn-primary{background:var(--olive);color:#fff}
.btn-primary:hover{background:var(--olive-dark)}
.btn-outline{border:1px solid var(--olive);color:var(--olive)}
.btn-outline:hover{background:var(--olive);color:#fff}
/* Premium Airbnb button */
.btn-airbnb{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:14px;border:1px solid var(--gold);
  background:#fff;color:var(--olive-dark);font-weight:500}
.btn-airbnb:hover{background:linear-gradient(180deg, rgba(203,190,143,.16), rgba(203,190,143,.08)); box-shadow:0 3px 10px rgba(0,0,0,.05)}
.btn-airbnb svg{width:16px;height:16px;display:block}
/* Hero */
.hero{padding:56px 0}
.grid-hero{display:grid;grid-template-columns:1fr;gap:24px;align-items:center}
.tag{display:flex;align-items:center;gap:8px;color:var(--olive);letter-spacing:.08em;text-transform:uppercase;font-size:12px}
h1{margin:.2em 0;color:var(--olive-dark);font-size:42px;line-height:1.1}
.lead{color:#686868;font-size:18px;max-width:50ch}
.portrait{position:relative;aspect-ratio:4/5;border-radius:24px;background:linear-gradient(135deg,#fff,#ecebe6);
  overflow:hidden;border:1px solid rgba(81,99,74,.12);box-shadow:0 6px 24px rgba(0,0,0,.06)}
.portrait img{width:100%;height:100%;object-fit:cover}
.badge{position:absolute;left:-12px;bottom:-12px;background:rgba(255,255,255,.85);backdrop-filter:blur(6px);padding:8px 12px;border:1px solid rgba(81,99,74,.2);border-radius:12px;font-size:12px;color:#666;display:none}
/* Sections */
section{padding:32px 0}
h2{color:var(--olive-dark);font-size:28px;margin:0 0 8px}
.muted{color:var(--muted)}
.cards{display:grid;grid-template-columns:1fr;gap:16px;margin-top:16px}
.card{background:#fff;border:1px solid rgba(81,99,74,.12);border-radius:22px;overflow:hidden;box-shadow:0 3px 14px rgba(0,0,0,.03);display:flex;flex-direction:column}
.card .ph{background:linear-gradient(#fafaf7,#efeee8);height:180px;display:grid;place-items:center;color:#8a8a8a;border-bottom:1px dashed rgba(81,99,74,.25)}
.card .body{padding:14px 16px;display:flex;flex-direction:column;gap:6px}
.card h3{margin:0;font-size:18px;color:var(--olive-dark)}
.price{color:var(--olive);font-weight:600;font-size:14px}
/* Images */
.card .service-img{width:100%;height:180px;object-fit:cover;display:block}
.card .product-img{width:100%;height:200px;object-fit:cover;display:block}
/* Band */
.band{background:#fff;border-top:1px solid rgba(81,99,74,.12);border-bottom:1px solid rgba(81,99,74,.12)}
.band-inner{display:grid;gap:10px}
/* Forms */
.two{display:grid;grid-template-columns:1fr;gap:24px}
.panel{background:#fff;border:1px solid rgba(81,99,74,.12);border-radius:22px;padding:20px;box-shadow:0 3px 14px rgba(0,0,0,.03)}
label{font-size:13px;color:#6a6a6a}
input,textarea{width:100%;margin-top:6px;padding:10px 12px;border-radius:12px;border:1px solid rgba(81,99,74,.22);background:#F6F5F1;font-size:14px;outline:none}
input:focus,textarea:focus{border-color:rgba(81,99,74,.6);box-shadow:0 0 0 3px rgba(81,99,74,.13)}
/* Footer */
footer{background:#1E1E1E;color:#fff}
footer .grid3{display:grid;grid-template-columns:1fr;gap:18px}
.copy{border-top:1px solid rgba(255,255,255,.12);color:#bdbdbd;font-size:12px;text-align:center;padding:14px 0;margin-top:8px}
/* Responsive */
@media(min-width:768px){
  .grid-hero{grid-template-columns:1.1fr .9fr}
  .cards{grid-template-columns:repeat(4,1fr)}
  .band-inner{grid-template-columns:repeat(3,1fr)}
  .two{grid-template-columns:1fr 1fr}
  .badge{display:block}
  footer .grid3{grid-template-columns:repeat(3,1fr)}
}

/* ===== Mobile/Tablet Premium (texture + grids + animations) ===== */
@media (max-width: 1024px) {
  /* papier gastronomique subtile */
  body {
    background:
      radial-gradient(rgba(0,0,0,0.015) 1px, transparent 1px) 0 0/6px 6px,
      linear-gradient(transparent 0%, rgba(0,0,0,0.01) 100%),
      var(--sand);
  }
  /* reveal only mobile/tablet */
  .reveal{opacity:0; transform:translateY(12px); transition:opacity .35s ease, transform .35s ease;}
  .reveal.in{opacity:1; transform:translateY(0);}
}

@media (max-width: 640px){
  h1{font-size:34px}
  h2{font-size:22px}
  .lead{font-size:16px}
  .container{padding:0 14px}
  .hero{padding:36px 0}
  .card .service-img{height:200px}
  .card .product-img{height:220px}
}
@media (min-width:641px) and (max-width:1024px){
  .cards{grid-template-columns:repeat(2,1fr)}
}

/* Burger + overlay menu */
.burger{display:none; align-items:center; gap:10px; cursor:pointer}
.burger .bars{display:inline-block; width:22px; height:2px; background:var(--olive-dark); border-radius:2px; position:relative}
.burger .bars::before,.burger .bars::after{content:""; position:absolute; left:0; width:22px; height:2px; background:var(--olive-dark); border-radius:2px}
.burger .bars::before{top:-6px}
.burger .bars::after{top:6px}
@media (max-width:1024px){ .nav{display:none} .burger{display:inline-flex} }

.mobile-menu{position:fixed; inset:0; display:none; align-items:center; justify-content:center;
  background:rgba(255,255,255,.92); backdrop-filter:saturate(160%) blur(8px); z-index:80; opacity:0; transition:opacity .3s ease}
.mobile-menu.open{display:flex; opacity:1}
.mobile-menu .panel{background:#fff; border:1px solid rgba(81,99,74,.15); border-radius:20px; padding:22px; box-shadow:0 10px 30px rgba(0,0,0,.08)}
.mobile-menu a{display:block; margin:10px 0; font-size:18px; text-align:center}
.mobile-menu .btn-airbnb{display:inline-flex; margin-top:10px}

/* Image zoom doux sur mobile/tablette */
@media (max-width:1024px){
  .card .service-img, .card .product-img{
    transition: transform .25s ease, box-shadow .25s ease;
    will-change: transform;
  }
  .img-zoom:hover, .img-zoom.pressed{
    transform: scale(1.03);
    box-shadow: 0 8px 24px rgba(0,0,0,.08);
  }
}
