/* ╔══════════════════════════════════════════════════╗
   ║  OUVRAGE WEB — Feuille de styles centrale       ║
   ║  Modifier ici impacte tout le site              ║
   ╚══════════════════════════════════════════════════╝ */

/* ── Design Tokens ── */
:root {
  --t: #c4734f; --th: #a85d3b; --tl: #f2e0d5; --tg: rgba(196,115,79,0.07);
  --o: #d4a853; --ol: #faf0db; --od: #9b7a2e;
  --ink: #2d1f1a; --ink2: #4a372e;
  --bg: #fdfaf6; --surf: #f7f2eb;
  --bd: #e8e0d8; --bds: #d4c9bd;
  --txt: #6b5e53; --muted: #7a6e64;
  --green: #4a8c5c; --green-bg: rgba(74,140,92,0.10);
  --sh: rgba(45,31,26,0.08); --sh2: rgba(45,31,26,0.04);
  --hfont: 'DM Serif Display', Georgia, serif;
  --bfont: 'DM Sans', system-ui, -apple-system, sans-serif;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--bfont);font-weight:300;color:var(--txt);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}

/* ── Typographie ── */
h1,h2,h3,h4{font-family:var(--hfont);font-weight:400;color:var(--ink);line-height:1.15}
.t-hero{font-size:clamp(2rem,4.5vw,3rem)}
.t-h1{font-size:clamp(1.5rem,3vw,1.9rem)}
.t-h2{font-size:1.15rem;font-weight:400;color:var(--ink2)}
.t-body{font-size:.95rem;font-weight:300;line-height:1.6;color:var(--txt)}
.t-lg{font-size:1.05rem;font-weight:300;line-height:1.55}
.t-sm{font-size:.8rem;color:var(--muted)}

/* ── Navigation ── */
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:rgba(253,250,246,0.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--bd);position:sticky;top:0;z-index:100}
.nav-logo{display:flex;align-items:center;text-decoration:none}
.nav-logo img{height:36px;width:auto}
.nav-links{display:flex;align-items:center;gap:24px;list-style:none}
.nav-links a{font-size:.9rem;font-weight:400;color:var(--ink);text-decoration:none;transition:color .15s}
.nav-links a:hover{color:var(--t)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}

/* ── Boutons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;font-family:var(--bfont);font-size:.9rem;font-weight:400;border-radius:4px;cursor:pointer;text-decoration:none;border:none;transition:all .15s;white-space:nowrap}
.btn-p{background:var(--t);color:#fff}.btn-p:hover{background:var(--th);transform:translateY(-1px);box-shadow:0 4px 12px rgba(45,31,26,0.15)}
.btn-g{background:transparent;color:var(--t);border:1px solid var(--bds)}.btn-g:hover{background:var(--tg);border-color:var(--t)}
.btn-lg{padding:14px 28px;font-size:1rem}

/* ── Layout ── */
.sec{padding:clamp(40px,7vw,72px) 28px}
.sec-alt{background:var(--surf)}
.sec-dark{background:var(--ink);color:#fff}
.wrap{max-width:960px;margin:0 auto}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* ── Cards ── */
.card{background:#fff;border:1px solid var(--bd);border-radius:6px;padding:24px;box-shadow:0 2px 6px -2px var(--sh);transition:all .25s}
.card:hover{box-shadow:0 4px 16px rgba(45,31,26,0.12)}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;padding:2px 10px;font-size:.7rem;font-weight:500;border-radius:4px;letter-spacing:.02em}
.badge-t{background:var(--tl);color:var(--th)}
.badge-o{background:var(--ol);color:var(--od)}
.badge-g{background:var(--green-bg);color:var(--green)}

/* ── Hero ── */
.hero{padding:clamp(48px,8vw,88px) 28px clamp(32px,6vw,56px);text-align:center}
.hero h1{margin-bottom:12px}
.hero .line{width:50px;height:2px;background:var(--o);margin:0 auto 16px}
.hero p{font-size:1.05rem;max-width:540px;margin:0 auto 24px;color:var(--muted)}

/* ── Footer ── */
.ft{background:var(--ink);color:rgba(255,255,255,0.5);padding:44px 28px;font-size:.82rem}
.ft a{color:rgba(255,255,255,0.7);text-decoration:none}.ft a:hover{color:#fff}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:28px}
.ft h4{font-family:var(--hfont);color:#fff;margin-bottom:10px;font-size:.9rem}
.ft ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.ft-bottom{border-top:1px solid rgba(255,255,255,0.07);margin-top:28px;padding-top:16px;text-align:center;font-size:.7rem}

/* ── Accordéon ── */
.acc{border:1px solid var(--bd);border-radius:6px;margin-bottom:16px;background:#fff;overflow:hidden}
.acc-summary{display:flex;align-items:center;gap:16px;padding:20px 24px;cursor:pointer;list-style:none;user-select:none;transition:background .15s}
.acc-summary::-webkit-details-marker{display:none}
.acc-summary:hover{background:var(--surf)}
.acc-summary::after{content:'▼';margin-left:auto;font-size:.65rem;color:var(--muted);transition:transform .25s;flex-shrink:0}
.acc[open]>.acc-summary::after{transform:rotate(180deg)}
.acc-summary h3{font-size:1.15rem;margin:0;flex:1}
.acc-content{padding:0 24px 24px;color:var(--txt);line-height:1.6}

/* ── Formulaires ── */
.f-group{margin-bottom:14px}
.f-group label{display:block;font-size:.82rem;font-weight:500;color:var(--ink2);margin-bottom:4px}
.f-group input,.f-group textarea{width:100%;padding:10px 12px;font-family:var(--bfont);font-size:.9rem;font-weight:300;color:var(--ink);background:#fff;border:1px solid var(--bd);border-radius:4px;transition:border-color .15s}
.f-group input:focus,.f-group textarea:focus{outline:none;border-color:var(--t);box-shadow:0 0 0 3px rgba(196,115,79,0.08)}

/* ── Rendez-vous ── */
.booking{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}
.date-nav{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.date-nav button{background:var(--surf);border:1px solid var(--bd);padding:8px 16px;border-radius:4px;cursor:pointer;font-family:var(--bfont);font-size:.85rem;color:var(--ink)}
.date-nav button:hover{background:var(--tl);border-color:var(--t)}
.slots{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.slot{background:#fff;border:1px solid var(--bd);padding:10px;border-radius:4px;text-align:center;cursor:pointer;font-family:var(--bfont);font-size:.82rem;font-weight:400;color:var(--ink);transition:all .15s}
.slot:hover{border-color:var(--t);background:var(--tl)}
.slot.selected{background:var(--t);color:#fff;border-color:var(--t)}
.slot.past{opacity:.3;pointer-events:none;background:var(--surf)}
.confirm-box{display:none;background:var(--green-bg);border:1px solid rgba(74,140,92,0.25);border-radius:8px;padding:28px;text-align:center}
.confirm-box.show{display:block}

/* ── Utilitaires ── */
.center{text-align:center}
.mt2{margin-top:8px}.mt4{margin-top:16px}.mt6{margin-top:24px}.mt8{margin-top:32px}
.mb2{margin-bottom:8px}.mb4{margin-bottom:16px}
.skip-link{position:absolute;top:-100px;left:16px;background:var(--ink);color:#fff;padding:8px 16px;z-index:200;border-radius:4px;text-decoration:none;font-size:.85rem}.skip-link:focus{top:16px}
:focus-visible{outline:2px solid var(--t);outline-offset:2px}

/* ── Responsive ── */
@media(max-width:768px){
  .grid2,.grid3{grid-template-columns:1fr}
  .booking{grid-template-columns:1fr}
  .sec{padding:36px 16px}
  .nav{padding:10px 16px}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--bg);border-bottom:1px solid var(--bd);padding:16px;gap:14px;box-shadow:0 6px 20px rgba(45,31,26,0.15)}
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
  .hero{padding:40px 16px 32px}
  .ft-grid{grid-template-columns:1fr}.ft{padding:32px 16px}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
