  :root {
    --charcoal: #1c1f24;          /* primary ink */
    --charcoal-2: #2c3038;
    --charcoal-3: #4a4e57;
    --ink-soft: #5a5d65;
    --gold: #a17a2c;              /* warm muted gold */
    --gold-lt: #c4992c;
    --gold-pale: #d8b677;
    --cream: #faf6ec;             /* warm paper */
    --cream-2: #f1e9d2;
    --cream-3: #e8dfc4;
    --paper: #fdfaf2;
    --line: rgba(28,31,36,0.10);
    --line-soft: rgba(28,31,36,0.06);
    --muted: #8a8675;
  }
  * { margin:0; padding:0; box-sizing:border-box; }
  html { scroll-behavior: smooth; }
  body { background: var(--paper); color: var(--charcoal); font-family: 'Inter', system-ui, sans-serif; font-size: 16px; line-height: 1.6; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
  a { color: inherit; text-decoration: none; }
  img { display: block; max-width: 100%; }

  .serif { font-family: 'DM Serif Display', Georgia, serif; }
  .wrap { max-width: 1240px; margin: 0 auto; padding: 0 32px; }
  @media (max-width: 700px) { .wrap { padding: 0 20px; } }

  h1, h2, h3 { font-family: 'DM Serif Display', Georgia, serif; font-weight: 400; line-height: 1.05; letter-spacing: -0.01em; color: var(--charcoal); }
  h1 em, h2 em, h3 em { font-style: italic; color: var(--gold); }

  .eyebrow { font-size: 11.5px; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); }
  .eyebrow.on-dark { color: var(--gold-pale); }

  .btn { display: inline-flex; align-items: center; gap: 10px; padding: 14px 26px; font-family: 'Inter', sans-serif; font-size: 13.5px; font-weight: 600; letter-spacing: 0.02em; transition: all 0.2s; cursor: pointer; border: 1px solid transparent; border-radius: 1px; }
  .btn-primary { background: var(--charcoal); color: var(--cream); }
  .btn-primary:hover { background: #000; transform: translateY(-1px); }
  .btn-gold { background: var(--gold); color: #fff; }
  .btn-gold:hover { background: #8a6726; transform: translateY(-1px); }
  .btn-ghost { background: transparent; color: var(--charcoal); border-color: rgba(28,31,36,0.35); }
  .btn-ghost:hover { border-color: var(--charcoal); background: rgba(28,31,36,0.04); }
  .btn-ghost.on-dark { color: var(--cream); border-color: rgba(250,246,236,0.25); }
  .btn-ghost.on-dark:hover { border-color: var(--cream); }
  .btn .arr { transition: transform 0.2s; }
  .btn:hover .arr { transform: translateX(3px); }

  /* TOP BAR */
  .topbar { background: var(--charcoal); color: var(--cream); font-size: 12.5px; }
  .topbar .wrap { display: flex; align-items: center; justify-content: space-between; padding-top: 9px; padding-bottom: 9px; }
  .topbar .tb-l { display: flex; gap: 26px; align-items: center; color: rgba(250,246,236,0.78); }
  .topbar .tb-l .dot { width: 5px; height: 5px; background: var(--gold-lt); border-radius: 50%; display: inline-block; margin-right: 8px; vertical-align: middle; }
  .topbar .tb-r { display: flex; gap: 18px; align-items: center; color: rgba(250,246,236,0.7); }
  .topbar a:hover { color: var(--gold-pale); }
  @media (max-width: 760px) { .topbar .tb-l span:not(:first-child), .topbar .tb-r { display: none; } }

  /* NAV */
  header.nav { position: sticky; top: 0; z-index: 50; background: rgba(253,250,242,0.94); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line-soft); }
  header.nav .wrap { display: flex; align-items: center; justify-content: space-between; padding-top: 18px; padding-bottom: 18px; gap: 32px; }
  .brand { display: flex; align-items: baseline; gap: 14px; flex-shrink: 0; }
  .brand .mk { width: 46px; height: 46px; border: 1px solid var(--charcoal); display: flex; align-items: center; justify-content: center; font-family: 'DM Serif Display', serif; font-size: 19px; line-height: 1; color: var(--charcoal); letter-spacing: -0.02em; position: relative; flex-shrink: 0; }
  .brand .mk::after { content: ""; position: absolute; right: -4px; top: -4px; width: 8px; height: 8px; background: var(--gold); border-radius: 50%; }
  .brand .bn { line-height: 1.1; }
  .brand .bn .n1 { font-family: 'DM Serif Display', serif; font-size: 21px; color: var(--charcoal); letter-spacing: -0.01em; }
  .brand .bn .n2 { font-size: 10.5px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-top: 3px; }
  nav.main { display: flex; align-items: center; gap: 32px; }
  nav.main a { font-size: 14.5px; font-weight: 500; color: var(--ink-soft); transition: color 0.15s; position: relative; }
  nav.main a:hover, nav.main a.active { color: var(--charcoal); }
  nav.main a.active::after { content: ""; position: absolute; bottom: -8px; left: 0; right: 0; height: 2px; background: var(--gold); }
  .nav-cta { display: flex; align-items: center; gap: 14px; }
  .nav-phone { font-family: 'DM Serif Display', serif; font-size: 18px; color: var(--charcoal); white-space: nowrap; }
  @media (max-width: 1100px) { nav.main { display: none; } }
  @media (max-width: 620px) { .nav-phone { display: none; } }

  /* HERO — type-led */
  .hero { background: var(--cream); position: relative; overflow: hidden; }
  .hero::before { content: ""; position: absolute; top: 0; right: 0; width: 60%; height: 100%; background: linear-gradient(180deg, var(--cream-2) 0%, var(--cream) 100%); opacity: 0.5; }
  .hero .wrap { padding-top: 100px; padding-bottom: 100px; position: relative; z-index: 2; display: grid; grid-template-columns: 1.5fr 1fr; gap: 80px; align-items: center; }
  .hero-copy { max-width: 720px; }
  .hero-copy h1 { font-size: clamp(2.6rem, 6vw, 5rem); margin: 28px 0 28px; line-height: 1.02; }
  .hero-copy h1 em { font-style: italic; color: var(--gold); }
  .hero-copy .lead { font-size: 19px; color: var(--charcoal-3); line-height: 1.6; max-width: 28em; margin-bottom: 40px; }
  .hero-actions { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
  .hero-side { position: relative; }
  .hero-side .quote-card { background: var(--paper); border-left: 3px solid var(--gold); padding: 32px 30px; position: relative; }
  .hero-side .quote-card .qm { font-family: 'DM Serif Display', serif; font-style: italic; font-size: 60px; line-height: 0.7; color: var(--gold-pale); position: absolute; top: 22px; right: 26px; }
  .hero-side .quote-card p { font-family: 'DM Serif Display', serif; font-size: 21px; line-height: 1.3; color: var(--charcoal); font-style: italic; }
  .hero-side .quote-card .by { font-family: 'Inter', sans-serif; font-style: normal; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin-top: 18px; }
  .hero-side .credentials { margin-top: 20px; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .hero-side .credentials .c { padding: 18px; background: rgba(161,122,44,0.06); border: 1px solid rgba(161,122,44,0.15); }
  .hero-side .credentials .c .num { font-family: 'DM Serif Display', serif; font-size: 26px; color: var(--gold); line-height: 1; }
  .hero-side .credentials .c .lbl { font-size: 11px; color: var(--ink-soft); letter-spacing: 0.04em; margin-top: 6px; line-height: 1.3; }
  @media (max-width: 960px) {
    .hero .wrap { grid-template-columns: 1fr; gap: 48px; padding-top: 64px; padding-bottom: 64px; }
    .hero::before { display: none; }
  }

  /* TRUST STRIP */
  .trust { background: var(--charcoal); color: var(--cream); }
  .trust .wrap { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
  .trust .c { padding: 36px 28px; border-right: 1px solid rgba(250,246,236,0.10); }
  .trust .c:last-child { border-right: none; }
  .trust .c .num { font-family: 'DM Serif Display', serif; font-size: 38px; color: var(--gold-lt); line-height: 1; }
  .trust .c .lbl { font-size: 13.5px; color: rgba(250,246,236,0.78); margin-top: 11px; line-height: 1.45; }
  @media (max-width: 760px) { .trust .wrap { grid-template-columns: 1fr 1fr; } .trust .c:nth-child(2) { border-right: none; } .trust .c:nth-child(-n+2) { border-bottom: 1px solid rgba(250,246,236,0.10); } }

  /* SECTIONS */
  section.block { padding: 110px 0; }
  .sec-head { max-width: 640px; margin-bottom: 60px; }
  .sec-head h2 { font-size: clamp(2.1rem, 4vw, 3.2rem); margin-top: 16px; }
  .sec-head p { font-size: 17.5px; color: var(--charcoal-3); margin-top: 22px; line-height: 1.6; }

  /* SERVICES — editorial list */
  .svc-list { border-top: 1px solid var(--line); }
  .svc-row { display: grid; grid-template-columns: 80px 1.2fr 2fr 1fr; gap: 32px; align-items: baseline; padding: 32px 0; border-bottom: 1px solid var(--line); transition: background 0.15s; }
  .svc-row:hover { background: var(--cream); }
  .svc-row .n { font-family: 'DM Serif Display', serif; font-style: italic; font-size: 24px; color: var(--gold); }
  .svc-row h3 { font-size: 24px; color: var(--charcoal); }
  .svc-row p { font-size: 14.5px; color: var(--ink-soft); line-height: 1.55; max-width: 38em; }
  .svc-row .more { font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 600; color: var(--gold); text-align: right; opacity: 0; transition: opacity 0.2s; }
  .svc-row:hover .more { opacity: 1; }
  @media (max-width: 860px) { .svc-row { grid-template-columns: 60px 1fr; gap: 16px; } .svc-row p, .svc-row .more { grid-column: 1 / -1; padding-left: 76px; } .svc-row .more { display: none; } }

  /* CLIENTS — segment archetypes */
  .clients-band { background: var(--cream); }
  .clients-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: 50px; }
  .cl { background: var(--cream); padding: 36px 28px; transition: background 0.2s; }
  .cl:hover { background: var(--paper); }
  .cl .ci { font-family: 'DM Serif Display', serif; font-style: italic; font-size: 14px; color: var(--gold); }
  .cl h3 { font-size: 22px; margin: 8px 0 12px; line-height: 1.15; }
  .cl p { font-size: 14px; color: var(--ink-soft); line-height: 1.6; }
  @media (max-width: 860px) { .clients-grid { grid-template-columns: 1fr 1fr; } }
  @media (max-width: 520px) { .clients-grid { grid-template-columns: 1fr; } }

  /* ENGAGEMENT — split feature */
  .engage { background: var(--charcoal); color: var(--cream); }
  .engage .wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; padding-top: 100px; padding-bottom: 100px; }
  .engage h2 { color: var(--cream); font-size: clamp(2rem, 3.6vw, 2.9rem); }
  .engage h2 em { color: var(--gold-lt); }
  .engage .lead { color: rgba(250,246,236,0.78); font-size: 17px; line-height: 1.65; margin-top: 22px; }
  .engage .pillars { display: flex; flex-direction: column; gap: 28px; }
  .engage .pillar { padding-left: 24px; border-left: 2px solid var(--gold); }
  .engage .pillar .pn { font-family: 'DM Serif Display', serif; font-style: italic; font-size: 13px; color: var(--gold-lt); }
  .engage .pillar h3 { color: var(--cream); font-size: 19px; margin: 4px 0 8px; line-height: 1.2; }
  .engage .pillar p { color: rgba(250,246,236,0.7); font-size: 14.5px; line-height: 1.6; }
  @media (max-width: 880px) { .engage .wrap { grid-template-columns: 1fr; gap: 40px; padding-top: 64px; padding-bottom: 64px; } }

  /* TARIFS TEASER */
  .tarifs-band { background: var(--cream-2); }
  .tarifs-band .wrap { padding: 80px 32px; display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
  .tarifs-band h2 { font-size: clamp(1.9rem, 3.4vw, 2.6rem); }
  .tarifs-band p { color: var(--charcoal-3); font-size: 16.5px; margin-top: 18px; line-height: 1.6; max-width: 32em; }
  .tarifs-band .price-card { background: var(--paper); border: 1px solid var(--line); padding: 36px 32px; }
  .tarifs-band .price-card .pn { font-family: 'DM Serif Display', serif; font-style: italic; color: var(--gold); font-size: 14px; }
  .tarifs-band .price-card h3 { font-size: 22px; margin: 6px 0 18px; }
  .tarifs-band .price-card .row { display: flex; justify-content: space-between; padding: 10px 0; border-bottom: 1px dashed var(--line); font-size: 14.5px; }
  .tarifs-band .price-card .row:last-child { border-bottom: none; }
  .tarifs-band .price-card .row .v { font-family: 'DM Serif Display', serif; color: var(--charcoal); }
  .tarifs-band .price-card .note { font-size: 12px; color: var(--muted); margin-top: 18px; font-style: italic; }
  @media (max-width: 820px) { .tarifs-band .wrap { grid-template-columns: 1fr; gap: 36px; } }

  /* CTA BAND */
  .cta-band { background: var(--gold); color: var(--charcoal); position: relative; overflow: hidden; }
  .cta-band::before { content: ""; position: absolute; top: -100px; right: -80px; width: 400px; height: 400px; background: radial-gradient(circle, rgba(28,31,36,0.10) 0%, transparent 60%); }
  .cta-band .wrap { padding: 80px 32px; position: relative; z-index: 2; display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; align-items: center; }
  .cta-band h2 { color: var(--charcoal); font-size: clamp(2rem, 3.6vw, 2.8rem); }
  .cta-band h2 em { color: var(--charcoal); font-style: italic; }
  .cta-band p { color: rgba(28,31,36,0.78); font-size: 16.5px; margin-top: 16px; max-width: 30em; line-height: 1.6; }
  .cta-side .ph-lbl { font-size: 12.5px; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(28,31,36,0.7); }
  .cta-side .ph { font-family: 'DM Serif Display', serif; font-size: clamp(2rem, 4vw, 3rem); color: var(--charcoal); margin-top: 6px; line-height: 1; }
  .cta-side .actions { margin-top: 26px; display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
  .cta-band .btn-primary { background: var(--charcoal); color: var(--cream); border-color: var(--charcoal); }
  @media (max-width: 820px) { .cta-band .wrap { grid-template-columns: 1fr; } }

  /* FOOTER */
  footer.ft { background: var(--charcoal); color: rgba(250,246,236,0.7); padding: 70px 0 30px; font-size: 14px; }
  footer.ft .fcols { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.1fr; gap: 44px; padding-bottom: 44px; border-bottom: 1px solid rgba(250,246,236,0.12); }
  footer.ft .fb .mk { width: 42px; height: 42px; border: 1px solid var(--cream); display: flex; align-items: center; justify-content: center; font-family: 'DM Serif Display', serif; font-size: 17px; color: var(--cream); margin-bottom: 16px; position: relative; }
  footer.ft .fb .mk::after { content: ""; position: absolute; right: -4px; top: -4px; width: 7px; height: 7px; background: var(--gold-lt); border-radius: 50%; }
  footer.ft .fb .n1 { font-family: 'DM Serif Display', serif; font-size: 21px; color: var(--cream); }
  footer.ft .fb p { margin-top: 12px; line-height: 1.65; font-size: 13.5px; max-width: 26em; }
  footer.ft h4 { font-size: 11.5px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold-pale); margin-bottom: 16px; }
  footer.ft ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
  footer.ft ul a:hover { color: var(--cream); }
  footer.ft .fbot { display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; padding-top: 22px; font-size: 12.5px; color: rgba(250,246,236,0.5); }
  footer.ft .fbot a:hover { color: var(--gold-pale); }
  @media (max-width: 860px) { footer.ft .fcols { grid-template-columns: 1fr 1fr; gap: 36px; } }
  @media (max-width: 520px) { footer.ft .fcols { grid-template-columns: 1fr; } }

  /* reveal */
  @keyframes rise { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }
  .reveal { opacity: 1; animation: rise 0.7s cubic-bezier(0.2,0.8,0.2,1) both; }
  @media (prefers-reduced-motion: reduce) { .reveal { animation: none; } }

/* ============ Sub-page additions ============ */

/* Page hero (non-homepage) */
.page-hero { background: var(--cream); border-bottom: 1px solid var(--line-soft); padding: 80px 0 60px; }
.page-hero .wrap { max-width: 1100px; }
.page-hero .crumb { font-size: 12.5px; color: var(--muted); letter-spacing: 0.06em; margin-bottom: 28px; }
.page-hero .crumb a { color: var(--charcoal); border-bottom: 1px solid var(--gold-pale); padding-bottom: 1px; }
.page-hero h1 { font-size: clamp(2.4rem, 4.5vw, 4rem); margin-bottom: 22px; }
.page-hero .lead { font-size: 18px; color: var(--charcoal-3); max-width: 720px; line-height: 1.55; }

/* Service detail rows */
.svc-detail { padding: 80px 0; border-bottom: 1px solid var(--line-soft); }
.svc-detail:nth-child(even) { background: var(--cream); }
.svc-detail .wrap { display: grid; grid-template-columns: 180px 1fr; gap: 50px; max-width: 1100px; }
.svc-detail .marker { font-family: 'DM Serif Display', serif; font-style: italic; font-size: 38px; color: var(--gold); line-height: 1; }
.svc-detail .marker .sub { display: block; font-family: 'Inter', sans-serif; font-style: normal; font-size: 11.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-top: 16px; font-weight: 600; }
.svc-detail h2 { font-size: clamp(1.7rem, 2.5vw, 2.4rem); margin-bottom: 18px; }
.svc-detail .body p { color: var(--charcoal-3); font-size: 16.5px; line-height: 1.7; margin-bottom: 18px; }
.svc-detail .body ul { list-style: none; margin-top: 10px; }
.svc-detail .body ul li { padding: 10px 0 10px 24px; position: relative; border-bottom: 1px solid var(--line-soft); font-size: 15.5px; color: var(--charcoal); }
.svc-detail .body ul li::before { content: ""; position: absolute; left: 0; top: 19px; width: 12px; height: 1px; background: var(--gold); }
.svc-detail .body ul li:last-child { border-bottom: none; }
@media (max-width: 760px) { .svc-detail .wrap { grid-template-columns: 1fr; gap: 28px; } }

/* Client archetype block */
.archetype { padding: 80px 0; border-bottom: 1px solid var(--line-soft); }
.archetype:nth-child(even) { background: var(--cream); }
.archetype .wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; max-width: 1100px; align-items: center; }
.archetype.flip .wrap { direction: rtl; }
.archetype.flip .wrap > * { direction: ltr; }
.archetype .meta .num { font-family: 'DM Serif Display', serif; font-style: italic; color: var(--gold); font-size: 32px; }
.archetype .meta h2 { font-size: 2.4rem; margin: 14px 0 18px; }
.archetype .meta p { color: var(--charcoal-3); font-size: 16.5px; line-height: 1.65; margin-bottom: 18px; }
.archetype .points { display: flex; flex-direction: column; gap: 14px; margin-top: 22px; }
.archetype .points .pt { padding: 14px 18px; background: rgba(161,122,44,0.06); border-left: 2px solid var(--gold); font-size: 14.5px; color: var(--charcoal); }
.archetype .visual { background: var(--paper); border: 1px solid var(--line); padding: 32px 30px; }
.archetype .visual h4 { font-size: 12px; color: var(--muted); letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 18px; }
.archetype .visual ul { list-style: none; }
.archetype .visual ul li { padding: 12px 0; border-bottom: 1px solid var(--line-soft); display: flex; justify-content: space-between; font-size: 14.5px; }
.archetype .visual ul li:last-child { border-bottom: none; }
.archetype .visual ul li span:last-child { font-family: 'DM Serif Display', serif; color: var(--gold); font-style: italic; }
@media (max-width: 760px) { .archetype .wrap { grid-template-columns: 1fr; } .archetype.flip .wrap { direction: ltr; } }

/* Tarifs table */
.tarif-block { padding: 70px 0; border-bottom: 1px solid var(--line-soft); }
.tarif-block:nth-child(odd) { background: var(--cream); }
.tarif-block .wrap { max-width: 1000px; }
.tarif-block .th { display: grid; grid-template-columns: 80px 1fr; gap: 36px; margin-bottom: 32px; align-items: end; }
.tarif-block .th .num { font-family: 'DM Serif Display', serif; font-style: italic; font-size: 44px; color: var(--gold); line-height: 1; }
.tarif-block .th h2 { font-size: 2rem; }
.tarif-block .th p { color: var(--muted); font-size: 14.5px; grid-column: 2; margin-top: 8px; }
.tarif-block .grid { background: var(--paper); border: 1px solid var(--line); }
.tarif-block .grid .row { display: grid; grid-template-columns: 1fr 200px; gap: 18px; padding: 18px 24px; border-bottom: 1px solid var(--line-soft); align-items: center; }
.tarif-block .grid .row:last-child { border-bottom: none; }
.tarif-block .grid .row .l { font-size: 15.5px; }
.tarif-block .grid .row .l small { display: block; font-size: 12.5px; color: var(--muted); margin-top: 4px; }
.tarif-block .grid .row .v { font-family: 'DM Serif Display', serif; font-size: 22px; color: var(--charcoal); text-align: right; }
.tarif-block .note { font-size: 13px; color: var(--muted); margin-top: 18px; font-style: italic; }
@media (max-width: 700px) { .tarif-block .grid .row { grid-template-columns: 1fr; gap: 6px; } .tarif-block .grid .row .v { text-align: left; } .tarif-block .th { grid-template-columns: 1fr; gap: 12px; } .tarif-block .th p { grid-column: 1; } }

/* À propos */
.bio { padding: 80px 0; }
.bio .wrap { display: grid; grid-template-columns: 1.4fr 1fr; gap: 80px; max-width: 1100px; }
.bio .copy h2 { font-size: 2.4rem; margin-bottom: 22px; }
.bio .copy p { font-size: 16.5px; color: var(--charcoal-3); line-height: 1.75; margin-bottom: 18px; }
.bio .side { background: var(--cream); padding: 32px 30px; }
.bio .side h4 { font-size: 12px; color: var(--muted); letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 18px; }
.bio .side ul { list-style: none; }
.bio .side ul li { padding: 12px 0; border-bottom: 1px solid var(--line-soft); font-size: 14.5px; }
.bio .side ul li:last-child { border-bottom: none; }
.bio .side ul li strong { color: var(--gold); display: block; font-family: 'DM Serif Display', serif; font-style: italic; font-size: 18px; margin-bottom: 4px; font-weight: normal; }
@media (max-width: 760px) { .bio .wrap { grid-template-columns: 1fr; gap: 32px; } }

/* FAQ */
.faq-block { padding: 70px 0; }
.faq-block .wrap { max-width: 900px; }
.faq-block .faq { border-top: 1px solid var(--line); }
.faq-block .item { border-bottom: 1px solid var(--line); }
.faq-block .item summary { cursor: pointer; padding: 22px 0; font-family: 'DM Serif Display', serif; font-size: 22px; list-style: none; display: flex; justify-content: space-between; align-items: center; }
.faq-block .item summary::-webkit-details-marker { display: none; }
.faq-block .item summary::after { content: "+"; font-family: 'Inter', sans-serif; font-size: 26px; color: var(--gold); font-weight: 300; }
.faq-block .item[open] summary::after { content: "−"; }
.faq-block .item .answer { padding: 0 0 24px; font-size: 15.5px; color: var(--charcoal-3); line-height: 1.7; max-width: 720px; }
.faq-block .item .answer p { margin-bottom: 10px; }

/* Contact / form */
.contact-grid { padding: 80px 0; }
.contact-grid .wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; max-width: 1100px; }
.contact-form { background: var(--paper); padding: 36px 36px; border: 1px solid var(--line); }
.contact-form h3 { font-size: 1.6rem; margin-bottom: 6px; }
.contact-form .h-sub { color: var(--muted); font-size: 13.5px; margin-bottom: 24px; }
.contact-form .field { margin-bottom: 18px; }
.contact-form label { display: block; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); font-weight: 600; margin-bottom: 6px; }
.contact-form input, .contact-form textarea, .contact-form select { width: 100%; padding: 12px 14px; border: 1px solid var(--line); background: var(--cream); font-family: 'Inter', sans-serif; font-size: 15px; color: var(--charcoal); border-radius: 1px; outline: none; transition: border 0.15s; }
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus { border-color: var(--gold); }
.contact-form textarea { min-height: 110px; resize: vertical; }
.contact-form .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.contact-form button { width: 100%; margin-top: 6px; }
.contact-info { padding-top: 12px; }
.contact-info h3 { font-size: 1.6rem; margin-bottom: 18px; }
.contact-info .blk { margin-bottom: 26px; }
.contact-info .blk h4 { font-size: 11.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold); margin-bottom: 8px; font-weight: 600; }
.contact-info .blk p, .contact-info .blk a { font-size: 16px; color: var(--charcoal); line-height: 1.55; }
.contact-info .blk a:hover { color: var(--gold); }
.contact-info .map-frame { aspect-ratio: 16/10; background: var(--cream); border: 1px solid var(--line); overflow: hidden; margin-top: 14px; }
.contact-info .map-frame iframe { width: 100%; height: 100%; border: none; }
@media (max-width: 760px) { .contact-grid .wrap { grid-template-columns: 1fr; gap: 32px; } .contact-form .row2 { grid-template-columns: 1fr; } }

/* Réserver */
.book-grid { padding: 80px 0; }
.book-grid .wrap { max-width: 1000px; display: grid; grid-template-columns: 1fr 1fr; gap: 60px; }
.book-step .num { font-family: 'DM Serif Display', serif; font-style: italic; color: var(--gold); font-size: 32px; line-height: 1; margin-bottom: 14px; }
.book-step h3 { font-size: 1.8rem; margin-bottom: 14px; }
.book-step p { color: var(--charcoal-3); font-size: 15.5px; line-height: 1.65; margin-bottom: 14px; }
.book-step .opt-list { display: flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.book-step .opt-list label { display: flex; gap: 14px; padding: 14px 16px; background: var(--cream); border: 1px solid var(--line); cursor: pointer; transition: border 0.15s; }
.book-step .opt-list label:hover { border-color: var(--gold); }
.book-step .opt-list input { margin-top: 2px; }
.book-step .opt-list .ot { font-weight: 600; font-size: 14.5px; }
.book-step .opt-list .od { color: var(--muted); font-size: 13px; margin-top: 2px; }
@media (max-width: 760px) { .book-grid .wrap { grid-template-columns: 1fr; gap: 32px; } }

/* Portal login gate */
.portal { min-height: 70vh; display: flex; align-items: center; justify-content: center; background: var(--charcoal); color: var(--cream); padding: 80px 32px; }
.portal-card { max-width: 440px; width: 100%; background: rgba(250,246,236,0.04); border: 1px solid rgba(250,246,236,0.12); padding: 44px 40px; }
.portal-card .mk-l { display: inline-flex; align-items: center; justify-content: center; width: 56px; height: 56px; border: 1px solid var(--gold-pale); font-family: 'DM Serif Display', serif; font-size: 22px; color: var(--cream); margin-bottom: 22px; position: relative; }
.portal-card .mk-l::after { content: ""; position: absolute; top: -4px; right: -4px; width: 8px; height: 8px; background: var(--gold); border-radius: 50%; }
.portal-card h1 { font-size: 1.8rem; color: var(--cream); margin-bottom: 8px; }
.portal-card .sub { color: rgba(250,246,236,0.6); font-size: 14px; margin-bottom: 26px; }
.portal-card .field { margin-bottom: 14px; }
.portal-card label { display: block; font-size: 11px; color: var(--gold-pale); letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 6px; font-weight: 600; }
.portal-card input { width: 100%; padding: 12px 14px; background: rgba(250,246,236,0.02); border: 1px solid rgba(250,246,236,0.2); color: var(--cream); font-family: 'Inter', sans-serif; font-size: 14.5px; outline: none; transition: border 0.15s; }
.portal-card input:focus { border-color: var(--gold-pale); }
.portal-card button { width: 100%; margin-top: 8px; }
.portal-card .err { display: none; padding: 12px 14px; background: rgba(204,76,76,0.16); border-left: 2px solid #cc4c4c; color: #f0c0c0; font-size: 13.5px; margin-bottom: 16px; }
.portal-card .err.show { display: block; }
.portal-card .meta { margin-top: 24px; padding-top: 22px; border-top: 1px solid rgba(250,246,236,0.1); font-size: 12.5px; color: rgba(250,246,236,0.5); }
.portal-card .meta a { color: var(--gold-pale); }

/* Dashboard mockup */
.dash-shell { background: var(--cream); padding: 60px 32px; min-height: 70vh; }
.dash-shell .wrap { max-width: 1180px; }
.dash-head { display: flex; justify-content: space-between; align-items: end; gap: 24px; margin-bottom: 36px; padding-bottom: 22px; border-bottom: 1px solid var(--line); }
.dash-head h1 { font-size: 2.2rem; }
.dash-head .who { color: var(--muted); font-size: 13px; margin-top: 4px; }
.dash-head .actions { display: flex; gap: 10px; }
.dash-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 24px; margin-bottom: 32px; }
.dash-card { background: var(--paper); border: 1px solid var(--line); padding: 22px 24px; }
.dash-card .lbl { font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.dash-card .v { font-family: 'DM Serif Display', serif; font-size: 30px; margin-top: 10px; line-height: 1; }
.dash-card .s { font-size: 13px; color: var(--muted); margin-top: 8px; }
.dash-row { background: var(--paper); border: 1px solid var(--line); padding: 28px 28px; margin-bottom: 22px; }
.dash-row h3 { font-size: 1.4rem; margin-bottom: 18px; }
.dash-row .files { display: flex; flex-direction: column; gap: 0; }
.dash-row .files .f { display: grid; grid-template-columns: 1fr 140px 110px 90px; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--line-soft); align-items: center; font-size: 14.5px; }
.dash-row .files .f:last-child { border-bottom: none; }
.dash-row .files .f .pill { display: inline-block; padding: 3px 10px; font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; font-weight: 600; border: 1px solid var(--line); }
.dash-row .files .f .pill.done { background: rgba(95,140,75,0.12); border-color: rgba(95,140,75,0.4); color: #4f7340; }
.dash-row .files .f .pill.wait { background: rgba(196,153,44,0.14); border-color: rgba(196,153,44,0.4); color: #8a6726; }
.dash-row .files .f .pill.brief { background: rgba(28,31,36,0.06); color: var(--charcoal); }
.dash-row .files .f a { color: var(--gold); font-weight: 600; font-size: 13px; }
@media (max-width: 800px) { .dash-grid { grid-template-columns: 1fr; } .dash-row .files .f { grid-template-columns: 1fr; gap: 4px; } }

/* Generic CTA band reused on sub-pages */
.subcta { background: var(--charcoal); color: var(--cream); padding: 70px 0; }
.subcta .wrap { display: grid; grid-template-columns: 1.4fr 1fr; gap: 50px; align-items: center; max-width: 1100px; }
.subcta h2 { color: var(--cream); font-size: 2.2rem; margin-bottom: 14px; }
.subcta h2 em { color: var(--gold-pale); }
.subcta p { color: rgba(250,246,236,0.78); font-size: 15.5px; line-height: 1.6; }
.subcta .side { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
.subcta .side .lbl { font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold-pale); font-weight: 600; }
.subcta .side .ph { font-family: 'DM Serif Display', serif; font-size: 32px; color: var(--cream); }
@media (max-width: 760px) { .subcta .wrap { grid-template-columns: 1fr; gap: 28px; } }
