/* ===========================================================
   Clinique du Pré-Seigneur - Redesign v2 (anti-slop)
   System: Cabinet Grotesk + Satoshi · Forest / Bone / Amber
   =========================================================== */

/* ===== TOKENS ===== */
:root{
  --forest:#1E3A2F;        /* brand dark green */
  --forest-800:#16271F;    /* deepest green (text on amber) */
  --forest-600:#2C4E3E;    /* raised green surface */
  --bone:#F3EFE6;          /* warm paper background */
  --bone-200:#E8E2D4;      /* tinted surface / lines */
  --ink:#1A1F1C;           /* near-black warm */
  --ink-2:#54605A;         /* secondary text on bone */
  --amber:#E58A66;         /* THE single accent (corail) */
  --amber-600:#C25A38;     /* corail for text/links on bone (contrast) */
  --surface:#FFFFFF;
  --line:rgba(26,31,28,.12);
  --line-on-forest:rgba(243,239,230,.16);
  --wrap:1240px;
  --r:18px;                /* base radius */
  --r-lg:28px;
  --arch:120px;            /* signature arch radius */
  --font-display:'Cabinet Grotesk','Satoshi',system-ui,sans-serif;
  --font-body:'Satoshi',system-ui,-apple-system,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);background:var(--bone);color:var(--ink);
  line-height:1.6;font-size:1.0625rem;-webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01";overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.02;letter-spacing:-.02em}
::selection{background:var(--amber);color:var(--forest-800)}

/* ===== LAYOUT ===== */
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:28px}
.section{padding-block:clamp(64px,9vw,128px)}
.eyebrow{
  font-family:var(--font-body);font-weight:700;font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--amber-600);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--amber);display:inline-block}
.lead{font-size:1.18rem;color:var(--ink-2);max-width:54ch}

/* ===== BUTTONS (one accent, one intent) ===== */
.btn{
  display:inline-flex;align-items:center;gap:10px;font-family:var(--font-body);font-weight:700;
  font-size:1rem;padding:16px 28px;border-radius:999px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s;white-space:nowrap;
}
.btn--primary{background:var(--amber);color:var(--forest-800);box-shadow:0 10px 30px rgba(229,138,102,.32)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(229,138,102,.42)}
.btn--primary:active{transform:translateY(-1px) scale(.99)}
.btn--ghost{border-color:currentColor;color:inherit;background:transparent}
.btn--ghost:hover{transform:translateY(-3px)}
.btn--on-dark.btn--ghost{color:var(--bone);border-color:var(--line-on-forest)}
.btn--on-dark.btn--ghost:hover{border-color:var(--bone)}

/* ===== NAV ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s,backdrop-filter .3s,border-color .3s}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav__logo{font-family:var(--font-display);font-weight:800;font-size:1.18rem;color:var(--bone);letter-spacing:-.02em;transition:color .3s}
.nav__logo .dot{color:var(--amber)}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{font-weight:600;font-size:.97rem;color:var(--bone);opacity:.92;transition:color .3s,opacity .2s}
.nav__links a:hover,.nav__links a[aria-current="page"]{opacity:1;color:var(--amber)}
.nav__cta{margin-left:8px}
.nav__burger{display:none;background:none;border:0;color:var(--bone);cursor:pointer;padding:8px;transition:color .3s}
.nav__burger svg{width:28px;height:28px}
/* scrolled / solid state */
.nav.is-solid{background:rgba(244,242,234,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav.is-solid .nav__logo,.nav.is-solid .nav__links a,.nav.is-solid .nav__burger{color:var(--ink)}
.nav.is-solid .nav__links a:hover,.nav.is-solid .nav__links a[aria-current="page"]{color:var(--amber-600)}
/* non-hero pages: nav solid from the start via .nav--solid on body wrapper */
.nav--inner .nav__logo,.nav--inner .nav__links a,.nav--inner .nav__burger{color:var(--ink)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100dvh;display:flex;align-items:flex-end;color:var(--bone);overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(22,39,31,.45) 0%,rgba(22,39,31,.12) 35%,rgba(22,39,31,.65) 78%,rgba(22,39,31,.92) 100%);}
.hero__in{position:relative;z-index:1;padding-bottom:clamp(56px,7vw,104px);padding-top:120px;max-width:840px}
.hero h1{font-size:clamp(2.6rem,6.4vw,5.2rem);margin:18px 0 22px;text-wrap:balance}
.hero h1 em{font-style:normal;color:var(--amber)}
.hero__sub{font-size:clamp(1.05rem,1.6vw,1.3rem);color:rgba(244,242,234,.92);max-width:46ch;margin-bottom:34px}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap}
.hero .eyebrow{color:var(--amber)}
.hero .eyebrow::before{background:var(--amber)}

/* ===== FACTS STRIP ===== */
.facts{background:var(--forest);color:var(--bone)}
.facts__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.facts__item{padding:34px 28px;border-left:1px solid var(--line-on-forest)}
.facts__item:first-child{border-left:0;padding-left:0}
.facts__item .k{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--amber);margin-bottom:6px}
.facts__item .v{font-size:.98rem;color:rgba(244,242,234,.82)}

/* ===== SECTION HEAD ===== */
.shead{max-width:60ch}
.shead h2{font-size:clamp(2rem,4vw,3.2rem);margin:16px 0 0;text-wrap:balance}

/* ===== BENTO (services) ===== */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(180px,auto);gap:18px;margin-top:48px}
.tile{position:relative;border-radius:var(--r-lg);padding:30px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:var(--surface);border:1px solid var(--line);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.tile:hover{transform:translateY(-5px);box-shadow:0 22px 48px rgba(26,31,28,.12)}
.tile h3{font-size:1.5rem;margin-bottom:8px}
.tile p{color:var(--ink-2);font-size:.98rem}
.tile--lg{grid-column:span 2;grid-row:span 2;min-height:380px}
.tile--wide{grid-column:span 2}
.tile--img{color:var(--bone);border:0}
.tile--img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.tile--img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(22,39,31,.05),rgba(22,39,31,.82));z-index:1}
.tile--img h3,.tile--img p{position:relative;z-index:2}
.tile--img p{color:rgba(244,242,234,.88)}
.tile--forest{background:var(--forest);color:var(--bone);border:0}
.tile--forest p{color:rgba(244,242,234,.82)}
.tile__n{position:absolute;top:24px;left:30px;font-family:var(--font-display);font-weight:800;color:var(--amber);font-size:1rem;z-index:2}

/* ===== EXPERIENCE FEATURE (arch signature) ===== */
.feature{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.feature__media{position:relative}
.feature__media img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--arch) var(--arch) var(--r-lg) var(--r-lg)}
.feature__media .badge{position:absolute;left:-14px;bottom:34px;background:var(--amber);color:var(--forest-800);font-family:var(--font-display);font-weight:800;
  padding:18px 22px;border-radius:var(--r);line-height:1.1;max-width:200px;box-shadow:0 16px 36px rgba(22,39,31,.22)}
.feature__list{margin-top:28px;display:grid;gap:18px}
.feature__row{display:flex;gap:16px;align-items:flex-start;padding-bottom:18px;border-bottom:1px solid var(--line)}
.feature__row:last-child{border-bottom:0}
.feature__row .ico{flex:0 0 auto;width:42px;height:42px;border-radius:12px;background:var(--bone-200);display:grid;place-items:center;color:var(--forest)}
.feature__row .ico svg{width:22px;height:22px}
.feature__row h4{font-size:1.15rem;margin-bottom:3px}
.feature__row p{color:var(--ink-2);font-size:.97rem}

/* ===== EQUIPE (staggered portraits) ===== */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:48px}
.team figure{margin:0}
.team figure:nth-child(2){margin-top:42px}
.team figure:nth-child(3){margin-top:84px}
.team__ph{position:relative;border-radius:var(--arch) var(--arch) var(--r-lg) var(--r-lg);overflow:hidden;aspect-ratio:4/5}
.team__ph img{width:100%;height:100%;object-fit:cover}
.team figcaption{padding:18px 4px 0}
.team h3{font-size:1.35rem}
.team .role{color:var(--ink-2);font-size:.97rem;margin-top:4px}
.team .illus{font-size:.78rem;color:var(--ink-2);font-style:italic;margin-top:8px;opacity:.8}

/* ===== URGENCE BAND ===== */
.urgence{background:var(--forest);color:var(--bone);border-radius:var(--r-lg);padding:clamp(40px,6vw,72px);display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center}
.urgence h2{font-size:clamp(1.8rem,3vw,2.6rem)}
.urgence p{color:rgba(244,242,234,.84);margin-top:14px;max-width:42ch}
.urgence__phone{text-align:right}
.urgence__phone .lab{font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;color:var(--amber);font-weight:700}
.urgence__phone a{display:block;font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,4.4vw,3.4rem);color:var(--bone);margin:8px 0 18px;letter-spacing:-.02em}
.urgence__phone a:hover{color:var(--amber)}

/* ===== FOOTER ===== */
.foot{background:var(--forest-800);color:rgba(244,242,234,.78);padding-block:64px 40px}
.foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px}
.foot h4{font-family:var(--font-display);color:var(--bone);font-size:1.05rem;margin-bottom:16px;font-weight:800}
.foot__logo{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--bone);margin-bottom:14px}
.foot__logo .dot{color:var(--amber)}
.foot a:hover{color:var(--amber)}
.foot p{margin-bottom:6px;line-height:1.7}
.foot__bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--line-on-forest);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.86rem;color:rgba(244,242,234,.55)}

/* ===== REVEAL MOTION ===== */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
.hero [data-reveal]{transition-delay:.1s}
.hero [data-reveal]:nth-child(2){transition-delay:.22s}
.hero [data-reveal]:nth-child(3){transition-delay:.34s}
.hero [data-reveal]:nth-child(4){transition-delay:.46s}

/* ===== RESPONSIVE ===== */
@media (max-width:1024px){
  .feature{grid-template-columns:1fr;gap:36px}
  .feature__media img{aspect-ratio:16/10;border-radius:var(--r-lg)}
}
@media (max-width:820px){
  .nav__links{position:fixed;inset:72px 0 auto 0;flex-direction:column;align-items:flex-start;gap:4px;
    background:var(--bone);padding:18px 28px 28px;border-bottom:1px solid var(--line);display:none}
  .nav__links.open{display:flex}
  .nav__links a{color:var(--ink);font-size:1.1rem;padding:10px 0;width:100%}
  .nav.is-solid .nav__links a,.nav--inner .nav__links a{color:var(--ink)}
  .nav__cta{margin:8px 0 0}
  .nav__burger{display:block}
  .facts__grid{grid-template-columns:repeat(2,1fr)}
  .facts__item{border-left:0;border-top:1px solid var(--line-on-forest);padding-inline:0}
  .facts__item:nth-child(odd){padding-right:20px}
  .facts__item:nth-child(even){padding-left:20px;border-left:1px solid var(--line-on-forest)}
  .bento{grid-template-columns:repeat(2,1fr)}
  .tile--lg{grid-column:span 2;grid-row:auto;min-height:300px}
  .tile--wide{grid-column:span 2}
  .team{grid-template-columns:1fr;gap:18px}
  .team figure:nth-child(2),.team figure:nth-child(3){margin-top:0}
  .urgence{grid-template-columns:1fr;text-align:left}
  .urgence__phone{text-align:left}
  .foot__grid{grid-template-columns:1fr;gap:32px}
}
@media (max-width:520px){
  .bento{grid-template-columns:1fr}
  .tile--lg,.tile--wide{grid-column:span 1}
  .facts__grid{grid-template-columns:1fr}
  .facts__item:nth-child(even){border-left:0;padding-left:0}
}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ===========================================================
   INNER PAGES (services / equipe / urgences / contact)
   =========================================================== */
.page-hero{background:var(--forest);color:var(--bone);padding:148px 0 clamp(52px,7vw,92px);position:relative}
.page-hero .eyebrow{color:var(--amber)}
.page-hero .eyebrow::before{background:var(--amber)}
.page-hero h1{font-size:clamp(2.4rem,5.4vw,4rem);margin:16px 0 18px;max-width:20ch;text-wrap:balance}
.page-hero p{color:rgba(244,242,234,.88);max-width:56ch;font-size:1.12rem}

/* services list */
.svc-list{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:48px}
.svc{display:flex;gap:18px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.svc:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(26,31,28,.12)}
.svc .ico{flex:0 0 auto;width:48px;height:48px;border-radius:14px;background:var(--bone-200);display:grid;place-items:center;color:var(--forest)}
.svc .ico svg{width:24px;height:24px}
.svc h3{font-size:1.3rem;margin-bottom:6px}
.svc p{color:var(--ink-2);font-size:.98rem}

/* hours table */
.hours{width:100%;border-collapse:collapse;max-width:580px;margin-top:8px}
.hours th,.hours td{padding:16px 2px;border-bottom:1px solid var(--line);text-align:left}
.hours th{font-family:var(--font-body);font-weight:700}
.hours td{text-align:right;font-weight:700;color:var(--forest)}
.hours tr:last-child th,.hours tr:last-child td{border-bottom:0}

/* values (equipe) */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px}
.value{background:var(--forest);color:var(--bone);border-radius:var(--r-lg);padding:32px}
.value h3{color:var(--bone);font-size:1.3rem;margin-bottom:8px}
.value p{color:rgba(244,242,234,.84);font-size:.98rem}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:start;margin-top:8px}
.info{display:grid;gap:22px}
.info .row .lab{font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;color:var(--amber-600);font-weight:700;margin-bottom:4px}
.info .row a:hover{color:var(--amber-600)}
.info .big{font-family:var(--font-display);font-weight:800;font-size:1.5rem}
.form{display:grid;gap:18px}
.form .field{display:grid;gap:8px}
.form label{font-weight:700;font-size:.92rem}
.form input,.form textarea{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:12px;font-family:inherit;font-size:1rem;background:var(--surface);color:var(--ink)}
.form input:focus,.form textarea:focus{outline:2px solid var(--amber);outline-offset:1px;border-color:var(--amber)}
.form .note{font-size:.92rem;color:var(--ink-2)}
.map{width:100%;height:400px;border:0;border-radius:var(--r-lg);margin-top:26px}

@media (max-width:820px){
  .svc-list{grid-template-columns:1fr}
  .values{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}
