:root{
  --ink:#0E2A2A; --ink-2:#06161B; --gold:#C8954A; --gold-deep:#9E6E2C;
  --paper:#F7F3EA; --paper-2:#EFEADD; --line:#D5CDB6;
  --grotesk:'Space Grotesk',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --sans:'Inter',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.55}
a{color:inherit}
.skip{position:absolute;left:-9999px}
.skip:focus{left:8px;top:8px;background:var(--ink);color:#fff;padding:8px 14px;z-index:99}
:focus-visible{outline:2.5px solid var(--gold);outline-offset:3px}

/* Sticky left rail */
.rail{position:fixed;top:0;left:0;bottom:0;width:260px;background:var(--ink);color:#E6DDC4;padding:28px 22px;display:flex;flex-direction:column;z-index:50;border-right:1px solid var(--ink-2)}
.rail-brand{display:flex;align-items:center;gap:12px;font-family:var(--grotesk);font-weight:600;font-size:1.05rem;line-height:1.1;letter-spacing:.005em;margin-bottom:42px}
.rail-mark{font-size:1.6rem;color:var(--gold)}
.rail-toc{list-style:none;padding:0;margin:0 0 auto;display:grid;gap:10px}
.rail-toc a{font-family:var(--mono);font-size:.82rem;letter-spacing:.04em;color:#C7BDA0;text-decoration:none;display:block;padding:4px 0;border-bottom:1px solid transparent}
.rail-toc a:hover{color:var(--gold);border-bottom-color:var(--gold-deep)}
.rail-phone{font-family:var(--mono);font-size:.85rem;color:var(--ink);background:var(--gold);text-align:center;padding:11px 8px;border-radius:3px;text-decoration:none;letter-spacing:.04em;margin-bottom:10px;font-weight:500}
.rail-phone:hover{background:#DAA458}
.rail-foot{font-family:var(--mono);font-size:.7rem;color:#988B62;letter-spacing:.1em;text-transform:uppercase;text-align:center}

.body{margin-left:260px}

/* Cover */
.cover{padding:90px 60px 60px;background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%)}
.cover-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}
.badge{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:var(--paper);padding:7px 14px;border-radius:3px}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(200,149,74,.25)}
.ref{color:#6F6648}
.cover-title{font-family:var(--grotesk);font-weight:500;font-size:clamp(2.1rem,5vw,4.2rem);line-height:1.05;color:var(--ink);margin:0 0 26px;letter-spacing:-.015em;max-width:1100px}
.cover-title em{color:var(--gold-deep);font-style:normal;background:linear-gradient(transparent 62%,rgba(200,149,74,.22) 62%);padding:0 4px}
.cover-lead{font-size:1.1rem;color:#3F4441;max-width:720px;margin:0 0 50px}

.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.metrics > div{padding:22px 18px;border-right:1px solid var(--line);position:relative}
.metrics > div:last-child{border-right:0}
.metrics > div::before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:2px;background:var(--gold);opacity:.45}
.m-num{display:block;font-family:var(--mono);font-size:1.95rem;font-weight:500;color:var(--ink);letter-spacing:-.02em}
.m-lbl{display:block;font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:#7B7456;margin-top:6px}

/* Bands */
.band{padding:54px 60px;text-align:center}
.band-dark{background:var(--ink);color:var(--paper)}
.band-light{background:var(--paper-2)}
.band-quote{font-family:var(--grotesk);font-weight:400;font-size:clamp(1.2rem,2.4vw,1.85rem);line-height:1.4;max-width:900px;margin:0 auto;letter-spacing:-.005em}
.signals{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}
.signals span{font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;background:var(--gold);color:var(--ink);padding:8px 14px;border-radius:3px}

/* Section */
.section{padding:80px 60px;max-width:1100px;margin:0 auto}
.sec-h{display:grid;grid-template-columns:auto 1fr;gap:0 22px;align-items:end;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:36px}
.sec-no{font-family:var(--mono);font-size:.95rem;color:var(--gold-deep);letter-spacing:.04em;grid-row:1/3}
.sec-h h2{font-family:var(--grotesk);font-weight:500;font-size:clamp(1.7rem,3.4vw,2.6rem);margin:0;color:var(--ink);letter-spacing:-.015em}
.sec-h p{margin:8px 0 0;color:#5B5A55;max-width:600px;font-size:.95rem}
.section-dark{background:var(--ink);color:var(--paper);max-width:none;margin:0;padding-left:calc((100vw - 260px - 1100px)/2 + 60px);padding-right:calc((100vw - 260px - 1100px)/2 + 60px)}
.sec-h-dark{border-bottom-color:rgba(255,255,255,.15)}
.sec-h-dark h2{color:var(--paper)}
.sec-h-dark p{color:#C7BDA0}

/* List items (services) */
.list-items{list-style:none;padding:0;margin:0;display:grid;gap:0}
.list-items li{display:grid;grid-template-columns:120px 1fr;gap:22px;padding:24px 0;border-top:1px solid var(--line)}
.list-items li:last-child{border-bottom:1px solid var(--line)}
.li-no{font-family:var(--mono);font-size:.85rem;color:var(--gold-deep);letter-spacing:.04em}
.list-items h3{font-family:var(--grotesk);font-weight:500;margin:0 0 8px;color:var(--ink);font-size:1.25rem}
.list-items p{margin:0;color:#3F4441;font-size:.97rem}

/* Creed */
.creed{list-style:none;padding:0;margin:0;display:grid;gap:0}
.creed li{display:grid;grid-template-columns:80px 1fr;gap:22px;padding:24px 0;border-top:1px solid var(--line)}
.creed li:last-child{border-bottom:1px solid var(--line)}
.creed-letter{font-family:var(--grotesk);font-weight:600;font-size:2.6rem;color:var(--gold);line-height:1;letter-spacing:-.02em}
.creed strong{font-family:var(--grotesk);font-weight:500;color:var(--ink)}

/* Fees grid */
.fees-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:8px}
.fee{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);padding:28px 24px}
.fee-featured{background:var(--gold);color:var(--ink);border-color:var(--gold-deep);transform:translateY(-4px)}
.fee h3{font-family:var(--grotesk);font-weight:500;margin:0 0 14px;font-size:1.15rem}
.fee-pct{font-family:var(--grotesk);font-weight:600;font-size:2.6rem;margin:0 0 18px;letter-spacing:-.02em;line-height:1}
.fee-pct span{display:block;font-size:.85rem;font-weight:400;color:#C7BDA0;margin-top:6px;letter-spacing:0}
.fee-featured .fee-pct span{color:#5B4321}
.fee ul{list-style:none;padding:0;margin:0;font-family:var(--mono);font-size:.82rem;display:grid;gap:8px}
.fee ul li::before{content:"·  ";color:var(--gold)}
.fee-featured ul li::before{color:var(--ink)}

/* Rating */
.rating-block{display:flex;align-items:center;gap:30px;padding:22px 0;margin-bottom:28px;border-bottom:1px solid var(--line)}
.rating-huge{font-family:var(--grotesk);font-weight:600;font-size:5.4rem;color:var(--ink);line-height:1;letter-spacing:-.03em}
.rating-huge span{font-family:var(--mono);font-size:1.2rem;color:#7B7456;font-weight:400;letter-spacing:0}
.rating-block p{margin:0;font-size:.95rem;color:#3F4441}
.rating-block a{color:var(--gold-deep);text-decoration:none;border-bottom:1px solid var(--gold-deep)}

.testimonies{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.testimonies figure{margin:0;padding:22px 22px;background:var(--paper-2);border-left:3px solid var(--gold)}
.testimonies blockquote{margin:0 0 12px;font-family:var(--grotesk);font-style:italic;font-weight:400;font-size:1.02rem;color:var(--ink);line-height:1.5}
.testimonies figcaption{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;color:var(--gold-deep)}

/* Contact grid */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.contact-grid > div{padding:22px 18px;border-right:1px solid var(--line)}
.contact-grid > div:last-child{border-right:0}
.contact-grid dt{font-family:var(--mono);font-size:.7rem;color:#7B7456;letter-spacing:.16em;text-transform:uppercase}
.contact-grid dd{margin:8px 0 0;color:var(--ink);font-family:var(--mono);font-size:.92rem}
.contact-grid a{color:var(--gold-deep);text-decoration:none;border-bottom:1.5px solid var(--gold-deep)}

/* Big CTA */
.bigcta{padding:100px 60px;background:var(--ink-2);color:var(--paper);text-align:center}
.cta-kicker{font-family:var(--mono);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin:0 0 18px}
.bigcta-phone{display:inline-block;font-family:var(--grotesk);font-weight:600;font-size:clamp(2.4rem,7vw,5.4rem);color:var(--paper);text-decoration:none;letter-spacing:-.02em;line-height:1;border-bottom:2px solid var(--gold)}
.bigcta-phone:hover{color:var(--gold)}
.cta-sub{font-family:var(--mono);font-size:.82rem;color:#C7BDA0;margin:18px 0 0}

/* Foot */
.foot{padding:36px 60px;background:#03100E;color:#6F6F60;margin-left:260px}
.foot p{margin:0 0 6px;font-size:.82rem;font-family:var(--mono);letter-spacing:.03em}
.foot .craft{color:#C7BDA0;font-size:.76rem}
.foot strong{color:var(--gold)}

@media (max-width:900px){
  .rail{position:static;width:auto;flex-direction:row;justify-content:space-between;align-items:center;padding:14px 20px;gap:14px}
  .rail-toc{display:none}
  .body{margin-left:0}
  .foot{margin-left:0}
  .section-dark{padding-left:30px;padding-right:30px}
  .cover{padding:50px 24px}
  .section{padding:60px 24px}
  .bigcta{padding:60px 24px}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important;scroll-behavior:auto}}

/* ═══════════════════════════════════════════════════════════
   ANIMATION PASS — added by AnimationDesigner
   Fully encapsulé dans prefers-reduced-motion: no-preference
   ═══════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: no-preference) {

  /* --- Scroll-reveal : éléments individuels ---------------------- */
  @keyframes fade-up {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  [data-reveal] {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .55s ease, transform .55s ease;
  }
  [data-reveal].revealed {
    opacity: 1;
    transform: translateY(0);
  }

  /* --- Scroll-reveal : groupes avec stagger ---------------------- */
  [data-reveal-stagger] > * {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .5s ease, transform .5s ease;
  }
  [data-reveal-stagger].revealed > * { opacity: 1; transform: translateY(0); }
  [data-reveal-stagger].revealed > *:nth-child(1) { transition-delay: 0s; }
  [data-reveal-stagger].revealed > *:nth-child(2) { transition-delay: .08s; }
  [data-reveal-stagger].revealed > *:nth-child(3) { transition-delay: .16s; }
  [data-reveal-stagger].revealed > *:nth-child(4) { transition-delay: .24s; }
  [data-reveal-stagger].revealed > *:nth-child(5) { transition-delay: .32s; }
  [data-reveal-stagger].revealed > *:nth-child(6) { transition-delay: .40s; }
  [data-reveal-stagger].revealed > *:nth-child(7) { transition-delay: .48s; }
  [data-reveal-stagger].revealed > *:nth-child(8) { transition-delay: .56s; }

  /* --- Hover cartes génériques ----------------------------------- */
  .card, .service-card, .feature-card, .feat, .prestations-card,
  .menu-item, .offer-card, .avis-card, .tarif-card, .gallery-item,
  .partner, .blog-card, .room-card, .product-card {
    transition: transform .22s ease, box-shadow .22s ease;
  }
  .card:hover, .service-card:hover, .feature-card:hover, .feat:hover,
  .prestations-card:hover, .menu-item:hover, .offer-card:hover,
  .avis-card:hover, .tarif-card:hover, .gallery-item:hover,
  .partner:hover, .blog-card:hover, .room-card:hover, .product-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 28px rgba(0,0,0,.12);
  }

  /* --- Hover liens nav ------------------------------------------- */
  nav a, .nav-link, header a {
    transition: opacity .18s ease, color .18s ease;
  }

  /* --- CTA boutons ---------------------------------------------- */
  .btn, .cta-btn, .cta-link, .button, [class*="btn-"], [class*="-btn"],
  .hero-cta, .bigcta a, .band-cta a {
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  }
  .btn:hover, .cta-btn:hover, .cta-link:hover, .button:hover,
  [class*="btn-"]:hover, [class*="-btn"]:hover,
  .hero-cta:hover, .bigcta a:hover, .band-cta a:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,.15);
  }

  /* --- Focus visible ring élégant ------------------------------- */
  :focus-visible {
    outline: 2px solid currentColor;
    outline-offset: 3px;
    border-radius: 2px;
  }

}
/* End animation pass */

/* ═══════════════════════════════════════════════════════════
   ANIMATION PASS v2 — micro-interactions site-spécifiques
   Template C sticky-rail · jaime-louer · AnimationDesigner
   ═══════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: no-preference) {

  /* 1 · Dot badge — pulse statut ACTIF */
  @keyframes pulse-dot {
    0%, 100% { box-shadow: 0 0 0 3px rgba(200,149,74,.35); }
    55%       { box-shadow: 0 0 0 8px rgba(200,149,74,.0); }
  }
  .dot { animation: pulse-dot 2.6s ease-in-out infinite; }

  /* 2 · Cover — entrée séquentielle au chargement */
  @keyframes cover-in {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
  }
  .cover-meta  { animation: cover-in .5s ease both; animation-delay: .08s; }
  .cover-title { animation: cover-in .6s ease both; animation-delay: .22s; }
  .cover-lead  { animation: cover-in .6s ease both; animation-delay: .38s; }

  /* 3 · Metrics — stagger après cover-lead */
  .metrics > div { animation: cover-in .55s ease both; }
  .metrics > div:nth-child(1) { animation-delay: .52s; }
  .metrics > div:nth-child(2) { animation-delay: .62s; }
  .metrics > div:nth-child(3) { animation-delay: .72s; }
  .metrics > div:nth-child(4) { animation-delay: .82s; }

  /* 4 · Rail TOC — glissement doux au hover */
  .rail-toc a {
    transition: color .2s ease, border-bottom-color .2s ease, padding-left .2s ease;
  }
  .rail-toc a:hover { padding-left: 6px; }

  /* 5 · Fee cards — lift + halo amber */
  .fee {
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  }
  .fee:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 32px rgba(0,0,0,.25);
  }
  .fee-featured:hover {
    transform: translateY(-7px);
    box-shadow: 0 14px 38px rgba(200,149,74,.38);
  }

  /* 6 · List-items services — accent numéro au hover */
  .list-items li { transition: background .2s ease; }
  .list-items .li-no { transition: transform .2s ease, color .2s ease; }
  .list-items li:hover { background: rgba(200,149,74,.05); }
  .list-items li:hover .li-no { transform: translateX(4px); color: var(--gold); }

  /* 7 · Creed steps — même accent sur la lettre */
  .creed li { transition: background .2s ease; }
  .creed-letter { transition: transform .22s ease, color .22s ease; }
  .creed li:hover { background: rgba(200,149,74,.04); }
  .creed li:hover .creed-letter { transform: translateX(4px) scale(1.05); }

  /* 8 · Testimonies — lift + bordure amber profond */
  .testimonies figure {
    transition: transform .22s ease, box-shadow .22s ease, border-left-color .22s ease;
  }
  .testimonies figure:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    border-left-color: var(--gold-deep);
  }

  /* 9 · Big CTA — transition couleur fluide */
  .bigcta-phone { transition: color .22s ease, border-bottom-color .22s ease; }

  /* 10 · Signals — micro-lift au hover */
  .signals span {
    transition: transform .18s ease, box-shadow .18s ease;
    display: inline-block;
  }
  .signals span:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(200,149,74,.32);
  }

  /* 11 · Rail phone — transition subtile */
  .rail-phone { transition: background .18s ease, letter-spacing .18s ease; }
  .rail-phone:hover { letter-spacing: .06em; }

  /* 12 · Contact grid cells — hover discret */
  .contact-grid > div {
    transition: background .2s ease;
  }
  .contact-grid > div:hover { background: rgba(200,149,74,.06); }

}
/* End animation pass v2 */
