:root{
  --teal:#0e7c7b; --teal-d:#0a5a59; --coral:#ff6b5e; --ink:#1c2b2b; --muted:#5d6d6d;
  --sand:#fbf8f3; --line:#e7e1d8; --card:#fff; --radius:14px;
  --shadow:0 6px 24px rgba(20,40,40,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--sand);line-height:1.6}
a{color:var(--teal);text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:0 20px}

/* Header */
.site-head{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:500}
.site-head .wrap{display:flex;align-items:center;gap:28px;height:62px}
.brand{font-weight:800;font-size:1.3rem;letter-spacing:-.5px}
.brand b{color:var(--teal)} .brand span{color:var(--coral)}
.brand img{height:38px;width:auto;display:block}
.nav{display:flex;gap:18px;flex-wrap:wrap}
.nav a{color:var(--muted);font-weight:600;font-size:.95rem}
.nav a:hover,.nav a.active{color:var(--teal)}

/* Hero */
.hero{background:linear-gradient(120deg,var(--teal),var(--teal-d));color:#fff;padding:38px 0 30px}
.hero .crumb{font-size:.82rem;opacity:.8;margin-bottom:8px}
.hero h1{margin:0 0 8px;font-size:2rem;line-height:1.15;letter-spacing:-.5px}
.hero .lede{font-size:1.05rem;max-width:680px;opacity:.95;margin:0 0 16px}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);padding:5px 12px;border-radius:99px;font-size:.85rem;font-weight:600}
.hero .meta{margin-top:14px;font-size:.9rem;opacity:.9}

/* Intro */
.intro{padding:26px 0 6px}
.intro p{font-size:1.05rem;max-width:760px;color:#33403f}

/* Map */
#map{height:340px;border-radius:var(--radius);margin:18px 0 6px;box-shadow:var(--shadow);border:1px solid var(--line)}
.note-src{font-size:.8rem;color:var(--muted);margin:0 0 22px}

/* Section title */
.sec-h{display:flex;align-items:baseline;justify-content:space-between;margin:26px 0 14px;gap:12px;flex-wrap:wrap}
.sec-h h2{margin:0;font-size:1.5rem;letter-spacing:-.4px}
.sec-h .count{color:var(--muted);font-size:.95rem}

/* Filters */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 18px}
.filters button{background:#fff;border:1.5px solid var(--line);color:var(--muted);padding:8px 15px;border-radius:99px;font-weight:600;font-size:.9rem;cursor:pointer;transition:.15s}
.filters button:hover{border-color:var(--teal);color:var(--teal)}
.filters button.active{background:var(--teal);border-color:var(--teal);color:#fff}

/* Cards grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}
.hotel-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.18s}
.hotel-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(20,40,40,.13)}
.hc-media{height:172px;position:relative;background:linear-gradient(120deg,#13908e,#0a5a59);display:flex;align-items:center;justify-content:center;overflow:hidden}
.hc-media img{width:100%;height:100%;object-fit:cover;display:block}
.hc-media .initial{font-size:2.4rem;font-weight:800;color:rgba(255,255,255,.85)}
.hc-badge{position:absolute;top:12px;right:12px;background:#fff;border-radius:10px;padding:4px 9px;font-weight:800;font-size:.95rem;box-shadow:0 2px 8px rgba(0,0,0,.15);display:flex;align-items:center;gap:4px}
.hc-badge.is-top{color:#0a8a3f} .hc-badge.is-good{color:var(--teal)} .hc-badge.is-ok{color:#b06a00}
.hc-body{padding:14px 16px;display:flex;flex-direction:column;gap:8px;flex:1}
.hc-name{font-weight:700;font-size:1.02rem;line-height:1.25}
.hc-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.85rem;color:var(--muted)}
.tag{background:#eef5f4;color:var(--teal-d);padding:2px 9px;border-radius:99px;font-weight:600;font-size:.78rem}
.hc-avis{font-size:.85rem;color:var(--muted)}
.hc-cta{margin-top:auto;display:block;text-align:center;background:var(--coral);color:#fff;font-weight:700;padding:10px;border-radius:10px;font-size:.92rem}
.hc-cta:hover{filter:brightness(.95)}

/* Table */
.cmp{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin:6px 0}
.cmp th,.cmp td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line);font-size:.93rem}
.cmp th{background:#f3efe8;font-weight:700;color:var(--teal-d)}
.cmp tr:last-child td{border-bottom:0}
.cmp .star{color:#0a8a3f;font-weight:800}
.cmp a{font-weight:700;color:var(--coral)}

/* FAQ */
.faq{margin:8px 0}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin-bottom:10px}
.faq summary{font-weight:700;cursor:pointer}
.faq p{margin:10px 0 0;color:#33403f}

/* Footer */
.site-foot{margin-top:46px;background:#11302f;color:#cfe0df;padding:30px 0;font-size:.9rem}
.site-foot a{color:#9fe0dd}
.disclosure{font-size:.8rem;opacity:.75;margin-top:10px}

section{padding:2px 0}
@media(max-width:640px){ .hero h1{font-size:1.6rem} #map{height:260px} }

/* ---- Pages guides ---- */
.hero-guide{padding:30px 0 24px}
.guide{max-width:760px;margin:24px auto 0;font-size:1.06rem;line-height:1.7}
.guide h2{font-size:1.5rem;margin:36px 0 10px;letter-spacing:-.3px;color:var(--ink)}
.guide h3{font-size:1.15rem;margin:22px 0 6px}
.guide p{margin:0 0 14px;color:#27302f}
.guide a{color:var(--teal);font-weight:600;text-decoration:underline;text-decoration-color:rgba(14,124,123,.4)}
.tldr{background:#eef5f4;border-left:4px solid var(--teal);padding:16px 20px;border-radius:8px;margin:0 0 22px}
.toc{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 20px;margin:22px 0}
.toc ol{margin:8px 0 0;padding-left:20px}.toc li{margin:3px 0}
.guide-table{overflow-x:auto;margin:18px 0}
.guide-table table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.guide-table th,.guide-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line);font-size:.95rem}
.guide-table th{background:#f3efe8;color:var(--teal-d);font-weight:700}
.cta-activite{margin:14px 0 22px}
.cta-activite a{display:inline-block;background:var(--coral);color:#fff!important;font-weight:700;padding:11px 20px;border-radius:10px;text-decoration:none!important}
.callout{background:#fff7e6;border-left:4px solid #f0a500;padding:14px 18px;border-radius:8px;margin:18px 0}

/* images & vidéo dans les guides */
.guide figure{margin:18px auto}
.guide figure img{width:100%;height:auto;border-radius:10px;display:block}
.guide figcaption{font-size:.78rem;color:var(--muted);margin-top:5px}
.video-wrap{position:relative;padding-bottom:56.25%;height:0;border-radius:12px;overflow:hidden}
.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.guide blockquote{border-left:4px solid var(--coral);background:#fff;margin:20px 0;padding:14px 20px;font-size:1.1rem;font-style:italic;color:var(--teal-d);border-radius:0 8px 8px 0}

/* ---- Home enrichie ---- */
a.hotel-card{text-decoration:none;color:inherit}
.home-hero{padding:56px 0 48px}
.home-hero h1{font-size:2.4rem}
.hero .stats{display:flex;gap:28px;margin-top:20px;flex-wrap:wrap}
.hero .stats span{font-size:.9rem;opacity:.95}
.hero .stats strong{font-size:1.4rem;display:block;line-height:1.1}
.home-intro{padding:30px 0 8px}
.home-intro h2{font-size:1.6rem;margin:0 0 12px}
.home-intro p{max-width:790px;font-size:1.05rem;color:#33403f;margin:0 0 14px}
.guide-promo{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 22px;box-shadow:var(--shadow);text-decoration:none;color:var(--ink);transition:.16s}
.guide-promo:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(20,40,40,.13)}
.gp-tag{background:var(--coral);color:#fff;padding:4px 11px;border-radius:99px;font-size:.76rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px}
.gp-title{font-weight:700;flex:1;font-size:1.08rem}
.gp-arrow{color:var(--teal);font-weight:700;white-space:nowrap}
.guide-table td a{color:var(--teal);font-weight:700}
@media(max-width:640px){.home-hero h1{font-size:1.8rem}.guide-promo{flex-direction:column;align-items:flex-start;gap:8px}}

/* ---- Nav déroulante ---- */
.nav{display:flex;gap:4px;align-items:center}
.nav-dd{position:relative}
.nav-toggle{background:none;border:0;cursor:pointer;font:inherit;color:var(--muted);font-weight:600;font-size:.95rem;padding:8px 12px;border-radius:8px;display:inline-flex;align-items:center;gap:6px}
.nav-toggle span{font-size:.6rem;opacity:.65}
.nav-dd:hover .nav-toggle,.nav-dd:focus-within .nav-toggle{color:var(--teal)}
.dd-menu{display:none;position:absolute;top:calc(100% - 4px);left:0;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);padding:6px;min-width:225px;z-index:600;flex-direction:column}
.nav-dd:hover .dd-menu,.nav-dd:focus-within .dd-menu{display:flex}
.dd-menu a{padding:9px 12px;border-radius:7px;color:var(--ink);font-size:.92rem;font-weight:500;white-space:nowrap}
.dd-menu a:hover{background:#eef5f4;color:var(--teal-d)}
@media(max-width:640px){.site-head .wrap{height:auto;padding:10px 20px;flex-wrap:wrap;gap:6px}.dd-menu{position:static;box-shadow:none;border:0;border-left:2px solid var(--line);border-radius:0;padding:2px 0 2px 10px;min-width:0}}

/* ---- Bouton Contact + footer + pages fixes ---- */
.nav-contact{background:var(--coral);color:#fff!important;padding:8px 16px;border-radius:8px;font-weight:700;font-size:.92rem;margin-left:8px}
.nav-contact:hover{filter:brightness(.95)}
.site-foot .wrap{display:flex;flex-direction:column;gap:10px}
.foot-links{display:flex;gap:18px;flex-wrap:wrap}
.foot-links a{color:#9fe0dd;font-weight:600;font-size:.9rem}
.contact-form{display:flex;flex-direction:column;gap:14px;max-width:560px;margin:10px 0 6px}
.contact-form label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:.95rem}
.contact-form input,.contact-form textarea{font:inherit;padding:11px 13px;border:1.5px solid var(--line);border-radius:9px;background:#fff;color:var(--ink)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--teal)}
.contact-form button{align-self:flex-start;background:var(--coral);color:#fff;border:0;font-weight:700;padding:12px 26px;border-radius:10px;cursor:pointer;font-size:1rem}
.contact-form button:hover{filter:brightness(.95)}
.guide.page ul{margin:0 0 14px;padding-left:22px}.guide.page li{margin:5px 0}
