/* =========================================================
   Chez Pewee — Feuille de style
   Direction : hospitalité alpine, chaleureuse et raffinée.
   Palette de marque (vert) conservée.
   ========================================================= */

:root{
  /* --- Marque (vert d'origine conservé) --- */
  --green:        #1b7420;   /* primaire */
  --green-deep:   #114d16;   /* foncé */
  --green-soft:   #a9d9ad;   /* clair */
  --green-tint:   #eef4ec;   /* fond très clair */

  /* --- Neutres chaleureux --- */
  --paper:    #f7f4ec;       /* fond crème alpin */
  --paper-2:  #fffdf8;
  --ink:      #1c2a1d;       /* texte */
  --ink-soft: #4a574b;
  --line:     rgba(28,42,29,.12);
  --gold:     #c08a2d;       /* accent discret */

  --maxw: 1180px;
  --radius: 18px;
  --radius-sm: 12px;
  --shadow: 0 18px 50px -20px rgba(17,49,17,.35);
  --shadow-soft: 0 10px 30px -16px rgba(17,49,17,.30);

  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body: "Mulish", system-ui, -apple-system, "Segoe UI", sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.1;margin:0;letter-spacing:-.01em}
p{margin:0 0 1rem}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:16px;background:#fff;padding:10px 14px;border-radius:10px;z-index:200}

/* Kicker / eyebrow */
.kicker{
  display:inline-block;font-family:var(--font-body);font-weight:800;
  font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--green);margin-bottom:14px;
}
.kicker::before{content:"";display:inline-block;width:26px;height:2px;background:var(--green);vertical-align:middle;margin-right:10px;transform:translateY(-3px)}

/* =================== Boutons =================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 24px;border-radius:999px;font-weight:800;font-size:.92rem;
  letter-spacing:.01em;cursor:pointer;border:1.5px solid transparent;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
.btn-primary{background:var(--green);color:#fff;box-shadow:var(--shadow-soft)}
.btn-primary:hover{background:var(--green-deep);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-ghost{background:transparent;color:var(--green);border-color:var(--green)}
.btn-ghost:hover{background:var(--green);color:#fff;transform:translateY(-2px)}
.btn-light{background:rgba(255,255,255,.92);color:var(--green-deep)}
.btn-light:hover{background:#fff;transform:translateY(-2px)}

/* =================== Header =================== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(247,244,236,.78);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease, box-shadow .3s ease;
}
.site-header.scrolled{border-color:var(--line);box-shadow:0 8px 30px -22px rgba(17,49,17,.5);background:rgba(247,244,236,.92)}
.header-inner{display:flex;align-items:center;gap:22px;height:74px}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.brand-mark{width:42px;height:42px;border-radius:50%;object-fit:cover;border:2px solid var(--green-soft)}
.brand-name{font-family:var(--font-display);font-weight:700;font-size:1.32rem;color:var(--green-deep)}

.main-nav{display:flex;gap:4px}
.nav-link{
  position:relative;padding:8px 13px;font-weight:700;font-size:.93rem;color:var(--ink-soft);
  border-radius:10px;transition:color .2s ease, background .2s ease;
}
.nav-link:hover{color:var(--green-deep);background:rgba(27,116,32,.07)}
.nav-link.is-active{color:var(--green-deep)}
.nav-link.is-active::after{content:"";position:absolute;left:13px;right:13px;bottom:2px;height:2px;background:var(--green);border-radius:2px}

.header-tools{display:flex;align-items:center;gap:12px}
.header-cta{padding:10px 18px;font-size:.85rem}

/* Sélecteur de langue */
.lang-switch{position:relative}
.lang-current{
  display:flex;align-items:center;gap:7px;background:transparent;border:1px solid var(--line);
  padding:7px 11px;border-radius:999px;font-weight:800;font-size:.8rem;color:var(--ink);cursor:pointer;
  transition:border-color .2s ease, background .2s ease;
}
.lang-current:hover{border-color:var(--green);background:rgba(27,116,32,.06)}
.lang-current img{width:18px;height:13px;border-radius:2px;object-fit:cover}
.lang-menu{
  position:absolute;right:0;top:calc(100% + 8px);min-width:160px;list-style:none;margin:0;padding:6px;
  background:var(--paper-2);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .2s ease;
}
.lang-switch.open .lang-menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang-menu a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;font-weight:600;font-size:.9rem}
.lang-menu a:hover{background:var(--green-tint)}
.lang-menu img{width:20px;height:14px;border-radius:2px;object-fit:cover}

/* Menu mobile */
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--green-deep);border-radius:2px;transition:.3s}
.mobile-nav{display:none}

/* =================== Hero =================== */
.hero{
  position:relative;min-height:min(88vh,760px);display:flex;align-items:flex-end;
  color:#fff;overflow:hidden;
  background:linear-gradient(180deg, rgba(11,30,12,.20) 0%, rgba(11,30,12,.20) 35%, rgba(11,30,12,.78) 100%),
             url(IMG/cover_2.jpg) center/cover no-repeat;
}
.hero-inner{position:relative;padding:0 0 70px;max-width:780px}
.hero .kicker{color:#cfe8c8}
.hero .kicker::before{background:#cfe8c8}
.hero h1{font-size:clamp(3rem,8vw,6rem);color:#fff;line-height:.96;text-shadow:0 8px 40px rgba(0,0,0,.4)}
.hero-sub{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:clamp(1.2rem,2.6vw,1.7rem);color:#eef6e8;margin:14px 0 6px}
.hero-lead{font-size:1.06rem;color:rgba(255,255,255,.9);max-width:560px;margin-bottom:26px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-mail{display:inline-flex;align-items:center;gap:9px;font-weight:700;color:#fff;border-bottom:1px solid rgba(255,255,255,.5);padding-bottom:2px}
.hero-mail:hover{border-color:#fff}

/* Bandeau de faits */
.facts{background:var(--green-deep);color:#fff}
.facts .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.fact{padding:26px 18px;text-align:center;border-right:1px solid rgba(255,255,255,.14)}
.fact:last-child{border-right:0}
.fact b{display:block;font-family:var(--font-display);font-size:1.5rem;line-height:1.1}
.fact span{display:block;font-size:.82rem;letter-spacing:.04em;color:rgba(255,255,255,.78);margin-top:4px}

/* =================== Sections =================== */
.section{padding:clamp(56px,9vw,110px) 0}
.section-tint{background:var(--green-tint)}
.section-head{max-width:720px;margin:0 auto clamp(36px,5vw,56px);text-align:center}
.section-head.left{margin-left:0;text-align:left}
.section-head h2{font-size:clamp(2rem,4.4vw,3.1rem);color:var(--green-deep)}
.section-head p{color:var(--ink-soft);font-size:1.08rem;margin-top:10px}

/* À propos : image + texte */
.about-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.about-media{position:relative}
.about-media img{width:100%;height:100%;min-height:340px;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}
.about-media .badge{
  position:absolute;left:-18px;bottom:-18px;background:var(--paper-2);border:1px solid var(--line);
  border-radius:16px;padding:16px 20px;box-shadow:var(--shadow-soft);max-width:200px;
}
.about-media .badge b{font-family:var(--font-display);color:var(--green);font-size:1.3rem;display:block}
.about-media .badge span{font-size:.82rem;color:var(--ink-soft)}
.about-text p{color:var(--ink-soft);font-size:1.04rem}
.about-text p + p{margin-top:1rem}

/* =================== Galerie =================== */
.gallery-cat{margin-bottom:clamp(40px,6vw,68px)}
.gallery-cat h3{font-size:1.6rem;color:var(--green-deep);margin-bottom:18px;display:flex;align-items:center;gap:14px}
.gallery-cat h3::before{content:"";width:30px;height:2px;background:var(--gold)}
.masonry{columns:3;column-gap:16px}
.masonry .tile{break-inside:avoid;margin:0 0 16px;border-radius:var(--radius-sm);overflow:hidden;cursor:zoom-in;box-shadow:var(--shadow-soft);background:#ddd}
.masonry .tile img{width:100%;transition:transform .5s ease, filter .4s ease}
.masonry .tile:hover img{transform:scale(1.05);filter:saturate(1.08)}

.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.gallery-grid .tile{aspect-ratio:4/3;border-radius:var(--radius-sm);overflow:hidden;cursor:zoom-in;box-shadow:var(--shadow-soft)}
.gallery-grid .tile img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery-grid .tile:hover img{transform:scale(1.06)}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(11,20,11,.92);display:none;align-items:center;justify-content:center;z-index:300;padding:24px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-btn{position:absolute;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;width:50px;height:50px;border-radius:50%;font-size:1.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lb-btn:hover{background:rgba(255,255,255,.25)}
.lb-close{top:22px;right:22px}
.lb-prev{left:22px;top:50%;transform:translateY(-50%)}
.lb-next{right:22px;top:50%;transform:translateY(-50%)}

/* =================== Cartes activités =================== */
.act-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.act-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s ease, box-shadow .25s ease}
.act-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.act-card .ph{aspect-ratio:16/11;overflow:hidden}
.act-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.act-card:hover .ph img{transform:scale(1.06)}
.act-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.act-body h3{font-size:1.2rem;color:var(--green-deep);margin-bottom:6px}
.act-body p{font-size:.92rem;color:var(--ink-soft);margin:0 0 14px}
.act-link{margin-top:auto;font-weight:800;font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:6px}
.act-link span{transition:transform .2s ease}
.act-card:hover .act-link span{transform:translateX(4px)}

/* =================== Tarifs =================== */
.price-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(28px,5vw,56px);align-items:start}
.price-card{background:var(--green-deep);color:#fff;border-radius:var(--radius);padding:40px 36px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.price-card::after{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.06)}
.price-amount{font-family:var(--font-display);font-size:3.6rem;line-height:1;margin:6px 0 2px}
.price-amount small{font-size:1rem;font-family:var(--font-body);font-weight:700;opacity:.8}
.price-card .from{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;opacity:.8}
.price-note{font-size:.95rem;color:rgba(255,255,255,.85);margin-top:18px;border-top:1px solid rgba(255,255,255,.18);padding-top:18px}
.price-note .min{display:inline-block;margin-bottom:6px;font-weight:800}
.incl-list{list-style:none;margin:0;padding:0;display:grid;gap:12px}
.incl-list li{display:flex;gap:13px;align-items:flex-start;font-size:1rem;color:var(--ink-soft)}
.incl-list li::before{content:"";flex:none;width:22px;height:22px;border-radius:50%;background:var(--green-tint);border:1.5px solid var(--green);position:relative;margin-top:2px}
.incl-list li::after{content:"✓";position:absolute;color:var(--green);font-weight:900;font-size:.7rem;margin-left:7px;margin-top:5px}

/* =================== Accès =================== */
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px);align-items:start}
.access-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:28px 30px;margin-bottom:22px;box-shadow:var(--shadow-soft)}
.access-card h3{color:var(--green-deep);font-size:1.35rem;margin-bottom:8px}
.access-card p{color:var(--ink-soft);margin-bottom:10px}
.access-card a.inline{color:var(--green);font-weight:700;border-bottom:1px solid var(--green-soft)}
.access-card a.inline:hover{border-color:var(--green)}
.map-frame{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.map-frame img{width:100%}

/* =================== Équipe / contact =================== */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:40px}
.team-card{display:flex;gap:18px;align-items:center;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow-soft)}
.team-card img{width:84px;height:84px;border-radius:50%;object-fit:cover;flex:none;border:2px solid var(--green-soft)}
.team-card h3{color:var(--green-deep);font-size:1.3rem;margin-bottom:4px}
.team-card p{font-size:.94rem;color:var(--ink-soft);margin:0}
.contact-cta{text-align:center;background:var(--green-tint);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(36px,6vw,60px)}
.contact-cta p{max-width:560px;margin:0 auto 22px;color:var(--ink-soft);font-size:1.05rem}
.contact-mail{font-family:var(--font-display);font-size:clamp(1.4rem,3vw,2.1rem);color:var(--green-deep);display:inline-block;margin-bottom:24px}

/* =================== Livre d'or =================== */
.gb-wrap{max-width:760px;margin:0 auto}
.gb-form{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-soft);margin-bottom:36px}
.gb-form input[type=text],.gb-form textarea{
  width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:12px;background:#fff;
  font-family:var(--font-body);font-size:1rem;color:var(--ink);margin-bottom:14px;resize:vertical;
}
.gb-form input:focus,.gb-form textarea:focus{outline:2px solid var(--green-soft);border-color:var(--green)}
.gb-captcha{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.gb-captcha label{font-weight:800;color:var(--ink-soft)}
.gb-captcha input{width:130px;margin:0;padding:10px 12px;border:1px solid var(--line);border-radius:12px}
.gb-alert{padding:13px 16px;border-radius:12px;margin-bottom:16px;font-weight:600}
.gb-ok{background:rgba(27,116,32,.1);border:1px solid rgba(27,116,32,.25);color:var(--green-deep)}
.gb-err{background:rgba(176,38,30,.08);border:1px solid rgba(176,38,30,.25);color:#8a201a}
.gb-list{display:grid;gap:16px}
.gb-msg{background:var(--paper-2);border:1px solid var(--line);border-radius:16px;padding:18px 20px;box-shadow:var(--shadow-soft)}
.gb-msg .top{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.gb-msg .name{font-weight:900;color:var(--green-deep)}
.gb-msg .date{font-size:.82rem;color:var(--ink-soft)}
.gb-msg .body{margin-top:8px;white-space:pre-wrap;color:var(--ink-soft)}
.btn-danger{background:#b3261e;color:#fff;padding:6px 12px;border:0;border-radius:999px;font-weight:800;font-size:.8rem;cursor:pointer}
.honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* =================== Footer =================== */
.site-footer{background:var(--green-deep);color:rgba(255,255,255,.82);padding:56px 0 26px;margin-top:auto}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.14)}
.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.footer-logo img{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.4)}
.footer-logo span{font-family:var(--font-display);font-size:1.4rem;color:#fff}
.footer-col h4{font-family:var(--font-body);font-weight:800;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:14px}
.footer-col a{display:block;padding:4px 0;color:rgba(255,255,255,.85);font-size:.95rem}
.footer-col a:hover{color:#fff}
.footer-addr{font-size:.9rem;line-height:1.6;margin-top:10px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:22px;font-size:.85rem;flex-wrap:wrap;gap:8px}
.heart{color:#ff7b6b}

/* =================== Animations d'apparition =================== */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
[data-reveal].in{opacity:1;transform:none}

/* =================== Responsive =================== */
@media (max-width:1040px){
  .main-nav{display:none}
  .nav-toggle{display:flex}
  .masonry{columns:2}
  .act-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .about-grid,.price-wrap,.access-grid,.team-grid{grid-template-columns:1fr}
  .about-media .badge{left:16px;bottom:16px}
  .facts .wrap{grid-template-columns:repeat(2,1fr)}
  .fact:nth-child(2){border-right:0}
  .fact:nth-child(1),.fact:nth-child(2){border-bottom:1px solid rgba(255,255,255,.14)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .header-cta{display:none}
  /* Menu mobile déroulant */
  .mobile-nav{display:flex;flex-direction:column;gap:4px;padding:0 24px;max-height:0;overflow:hidden;transition:max-height .35s ease, padding .35s ease;background:var(--paper-2);border-bottom:1px solid var(--line)}
  .site-header.menu-open .mobile-nav{max-height:520px;padding:14px 24px 22px}
  .mobile-nav a{padding:11px 6px;font-weight:700;color:var(--ink-soft);border-bottom:1px solid var(--line)}
  .mobile-nav a.is-active{color:var(--green-deep)}
  .mobile-nav .btn{margin-top:12px}
  .site-header.menu-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .site-header.menu-open .nav-toggle span:nth-child(2){opacity:0}
  .site-header.menu-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media (max-width:560px){
  .masonry{columns:1}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .act-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .brand-name{font-size:1.12rem}
  .hero-inner{padding-bottom:48px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  [data-reveal]{opacity:1;transform:none}
}
