/* ===========================================================
   Coworking La Rochelle — Le Bastion · feuille de style commune
   Identité « Le Bastion » : palette multicolore, Zilla Slab /
   Newsreader / Hanken Grotesk, cartes arrondies, motif éclair,
   fonds alternés, animations reveal.
   Partagée par index.html et toutes les pages internes.
   =========================================================== */

/* ============ Tokens ============ */
:root{
  /* Palette signature */
  --teal:#1C4E48;
  --teal-deep:#143A35;
  --orange:#E8551F;
  --ambre:#F5A623;
  --nuit:#1A2A52;
  --indigo:#5B6BBF;
  --rouge:#CC2027;
  --jaune:#F2D544;
  --ecru:#FAF5EA;
  --ecru-2:#F3EBD9;
  --ink:#1B1A17;

  /* Variables historiques (utilisées en inline par les pages) — remappées */
  --bg:        var(--ecru);
  --surface:   #FFFFFF;
  --surface-2: var(--ecru-2);
  --fg:        var(--ink);
  --muted:     #5A554B;
  --border:    #E7DDC7;
  --accent:    var(--teal);
  --accent-ink:var(--teal-deep);
  --sand:      var(--jaune);
  --ok:        #2F8F5B;

  --shadow:    0 1px 2px rgba(20,18,12,.06), 0 14px 34px -16px rgba(20,18,12,.30);
  --shadow-lg: 0 30px 70px -30px rgba(20,18,12,.5);

  --font-display:'Zilla Slab', Georgia, 'Times New Roman', serif;
  --font-quote:'Newsreader', Georgia, 'Times New Roman', serif;
  --font-body:'Hanken Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;

  --radius:22px;
  --radius-sm:14px;
  --maxw:1180px;

  /* Motif éclair (W/M) réutilisable — couleur pilotée par currentColor via fill */
  --bolt-ecru:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 60' preserveAspectRatio='none'%3E%3Cpath d='M0 60 V30 L80 8 160 40 240 8 320 40 400 8 480 40 560 8 640 40 720 8 800 40 880 8 960 40 1040 8 1120 40 1200 12 V60 Z' fill='%23FAF5EA'/%3E%3C/svg%3E");
  --bolt-ecru2:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 60' preserveAspectRatio='none'%3E%3Cpath d='M0 60 V30 L80 8 160 40 240 8 320 40 400 8 480 40 560 8 640 40 720 8 800 40 880 8 960 40 1040 8 1120 40 1200 12 V60 Z' fill='%23F3EBD9'/%3E%3C/svg%3E");
  --bolt-line:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='84' height='14' viewBox='0 0 84 14'%3E%3Cpath d='M2 7 L13 2 24 12 35 2 46 12 57 2 68 12 79 4' fill='none' stroke='%23E8551F' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--fg);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  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:700;line-height:1.04;letter-spacing:-.01em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,28px)}

/* Eyebrow façon maquette : tiret + bas-de-casse capitales espacées */
.eyebrow{
  font-family:var(--font-body);font-size:13px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--orange);
  display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:24px;height:2px;background:currentColor;display:inline-block;flex:none}

/* ============ Accessibilité ============ */
:focus-visible{outline:3px solid var(--nuit);outline-offset:3px;border-radius:6px}
.skip{position:absolute;left:-999px;top:0;background:var(--nuit);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 10px 0;z-index:200;font-weight:700}
.skip:focus{left:0}

/* ============ Boutons (pilule) ============ */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-body);font-weight:700;font-size:15px;letter-spacing:.005em;
  padding:13px 24px;border-radius:999px;border:2px solid transparent;
  cursor:pointer;text-align:center;
  transition:transform .16s ease, background .2s ease, color .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 12px 26px -14px rgba(20,18,12,.7)}
.btn-primary:hover{background:var(--accent-ink);border-color:var(--accent-ink)}
.btn-ghost{background:transparent;color:var(--fg);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-ink)}
.btn-orange{background:var(--orange);color:#fff;border-color:var(--orange);box-shadow:0 12px 26px -14px rgba(232,85,31,.8)}
.btn-orange:hover{background:#cf4715;border-color:#cf4715;color:#fff}

/* photos */
.pic{overflow:hidden}
.pic img{width:100%;height:100%;object-fit:cover;display:block}

/* ============ Header ============ */
.site-head{
  position:sticky;top:0;z-index:60;
  background:rgba(250,245,234,.82);
  backdrop-filter:saturate(150%) blur(12px);
  -webkit-backdrop-filter:saturate(150%) blur(12px);
  border-bottom:1px solid transparent;transition:border-color .2s ease, box-shadow .2s ease;
}
.site-head.scrolled{border-bottom-color:rgba(27,26,23,.10);box-shadow:0 10px 30px -24px rgba(20,18,12,.6)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:1rem}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-.01em}
.brand-logo{height:36px;width:auto;display:block;flex:0 0 auto}
.nav-links{display:flex;align-items:center;gap:18px}
.nav-links a{white-space:nowrap}
.nav-cta .btn{white-space:nowrap}
.nav-links a{font-size:15px;color:var(--muted);font-weight:600;position:relative;padding-block:.2rem;transition:color .15s ease}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--orange);transition:width .2s ease}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--fg)}
.nav-links a:hover::after,.nav-links a:focus-visible::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:13px}
.burger{display:none;width:46px;height:46px;border:2px solid var(--ink);border-radius:12px;background:transparent;cursor:pointer;align-items:center;justify-content:center}
.burger span{display:block;width:18px;height:2px;background:var(--fg);position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--fg);transition:transform .2s ease}
.burger span::before{top:-6px}.burger span::after{top:6px}
/* Liens secondaires : masqués du menu desktop, conservés dans le burger mobile */
@media(min-width:681px){.nav-links a.nav-sec{display:none}}

/* ============ Hero (générique image fixe) ============ */
.hero{position:relative;overflow:hidden;padding:64px 0 80px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(42px,6.4vw,72px);letter-spacing:-.02em}
.hero p.lead{font-size:19px;color:var(--muted);margin:22px 0 30px;max-width:48ch}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{display:flex;gap:28px;margin-top:34px;flex-wrap:wrap}
.hero-meta div{display:flex;flex-direction:column;gap:2px}
.hero-meta .k{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--fg)}
.hero-meta .v{font-size:13.5px;color:var(--muted)}

/* ============ Hero carousel (accueil) ============ */
.hero-carousel{position:relative;height:clamp(560px,84vh,780px);overflow:hidden;background:var(--teal-deep)}
.hc-stage{position:absolute;inset:0}
.hc-slide{position:absolute;inset:0;margin:0;opacity:0;transition:opacity 1s ease;will-change:opacity}
.hc-slide.active{opacity:1}
.hc-slide img{width:100%;height:100%;object-fit:cover;display:block}
.hc-scrim{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(95deg, rgba(20,32,30,.90), rgba(20,32,30,.58) 42%, rgba(20,32,30,.15) 74%),
             linear-gradient(0deg, rgba(20,32,30,.66), transparent 46%)}
.hc-overlay{position:relative;z-index:3;height:100%;display:flex;flex-direction:column;justify-content:center;color:#fff}
.hc-overlay h1{color:#fff;font-size:clamp(28px,4vw,44px);font-weight:700;line-height:1.08;letter-spacing:-.02em;max-width:24ch;margin-top:14px}
.hc-overlay .hc-accent{color:var(--sand);white-space:nowrap}
.hc-overlay .lead{color:rgba(255,255,255,.9);font-size:19px;margin:22px 0 30px;max-width:50ch}
.hc-overlay .hero-meta{margin-top:34px}
.hc-overlay .hero-meta .k{color:#fff}
.hc-overlay .hero-meta .v{color:rgba(255,255,255,.74)}
.hc-overlay .btn-ghost{color:#fff;border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.05)}
.hc-overlay .btn-ghost:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.14)}
/* Hero carrousel des pages internes : un peu plus court + fil d'ariane blanc */
.hero-carousel.subhero{height:clamp(420px,52vh,520px)}
.hc-overlay .breadcrumb,.hc-overlay .breadcrumb a{color:rgba(255,255,255,.82)}
.hc-overlay .breadcrumb a:hover{color:#fff}
.hc-overlay .breadcrumb span{opacity:.6}
.hc-overlay h1{max-width:22ch}
.hc-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:50px;height:50px;border-radius:50%;
  border:1px solid rgba(255,255,255,.4);background:rgba(20,32,30,.34);color:#fff;font-size:24px;line-height:1;
  display:grid;place-items:center;cursor:pointer;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  transition:background .18s ease,border-color .18s ease}
.hc-arrow:hover{background:rgba(20,32,30,.66);border-color:#fff}
.hc-arrow.prev{left:max(20px,calc((100vw - var(--maxw))/2 - 8px))}
.hc-arrow.next{right:max(20px,calc((100vw - var(--maxw))/2 - 8px))}
.hc-dots{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:4;display:flex;gap:9px}
.hc-dots button{width:9px;height:6px;padding:0;border:0;border-radius:999px;background:rgba(255,255,255,.5);
  cursor:pointer;transition:width .25s ease,background .2s ease}
.hc-dots button[aria-current="true"]{background:var(--jaune);width:30px}
/* bande éclair sous le hero accueil */
.hero-carousel::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:42px;z-index:5;pointer-events:none;
  background:var(--bolt-ecru) bottom/100% 42px no-repeat}

/* H1 fixe (SEO) + bandeau de citations défilant (hero accueil) */
.hc-h1{font-family:var(--font-display);font-weight:700;line-height:1.1;letter-spacing:-.02em;
  font-size:clamp(28px,4vw,44px);margin:.06em 0 0;color:#fff;max-width:24ch}
.hc-h1 em{font-style:normal;color:var(--sand)}
.hc-quotes{margin:16px 0 0;max-width:none}
.hc-quotes .vp{display:block;overflow:hidden;height:2.6em}
.hc-quotes .track{display:block;will-change:transform}
.hc-quotes .line{display:flex;align-items:center;flex-wrap:wrap;gap:.5ch;max-width:46ch;
  font-family:var(--font-quote);font-style:italic;
  font-size:clamp(16px,2.1vw,21px);line-height:1.25;color:rgba(255,255,255,.94)}
.hc-quotes .line b{font-style:normal;font-weight:600;color:var(--q,var(--sand))}
@media(max-width:680px){.hc-quotes .line{max-width:32ch}}
.hc-strap{margin:10px 0 0;color:#fff;font-family:var(--font-display);font-weight:700;
  font-size:clamp(17px,2.6vw,24px);line-height:1.2;max-width:32ch}
.hc-strap em{font-style:normal;color:var(--sand)}

/* ============ Page hero (pages internes) ============ */
.page-hero{position:relative;background:var(--ecru-2);padding:60px 0 72px}
/* Zigzag « montagnes » : rempli de la couleur de la section qui suit le hero
   (par défaut le 1er .block = fond --ecru), pour créer une vraie transition.
   Une page au hero coloré redéfinit --page-hero-bolt (cf. carnet-rose). */
.page-hero::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:34px;pointer-events:none;
  background:var(--page-hero-bolt, var(--bolt-ecru)) bottom/100% 34px no-repeat}
.breadcrumb{font-size:13px;color:var(--muted);display:flex;gap:8px;flex-wrap:wrap;align-items:center;font-weight:600}
.breadcrumb a:hover{color:var(--accent-ink)}
.breadcrumb span{opacity:.5}
.page-hero h1{font-size:clamp(36px,5.2vw,58px);letter-spacing:-.02em;margin:16px 0 0;max-width:18ch}
.page-hero .lead{font-size:18px;color:var(--muted);margin-top:16px;max-width:62ch}
.page-hero .hero-actions{margin-top:26px}

/* ============ Réassurance ============ */
.strip{background:var(--ecru)}
.strip .wrap{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding-top:20px;padding-bottom:20px}
.strip p{font-size:13.5px;color:var(--muted);font-weight:600}
.strip .items{display:flex;gap:24px;flex-wrap:wrap;margin-left:auto}
.strip .items span{font-family:var(--font-display);font-weight:600;color:var(--teal);font-size:15px;letter-spacing:.01em}

/* ============ Sections ============ */
section.block{padding:88px 0;position:relative}
.sec-head{max-width:62ch;margin-bottom:46px}
.sec-head h2{font-size:clamp(30px,4.4vw,46px);margin:14px 0 0}
.sec-head h2::after{content:"";display:block;width:84px;height:14px;margin-top:16px;
  background:var(--bolt-line) left center/84px 14px no-repeat}
.sec-head[style*="center"] h2::after,.sec-head.center h2::after{margin-inline:auto}
.sec-head p{color:var(--muted);font-size:17px;margin-top:16px}

/* Prose (articles / textes longs) */
.prose{max-width:68ch}
.prose p{font-size:16.5px;color:var(--muted);margin:0 0 18px}
.prose h2{font-size:clamp(24px,3vw,32px);margin:36px 0 14px;color:var(--fg)}
.prose h3{font-size:20px;margin:26px 0 10px;color:var(--fg)}
.prose ul{margin:0 0 18px;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.prose ul li{display:flex;gap:10px;align-items:flex-start;font-size:16px;color:var(--muted)}
.prose ul li::before{content:"";flex:0 0 auto;width:7px;height:7px;margin-top:9px;border-radius:50%;background:var(--orange)}
.prose strong{color:var(--fg);font-weight:700}
.prose a{color:var(--accent-ink);text-decoration:underline;text-underline-offset:2px}

/* Espaces (cartes) */
.spaces{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.spaces.cols-3{grid-template-columns:repeat(3,1fr)}
.space-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease;display:flex;flex-direction:column;box-shadow:0 1px 2px rgba(20,18,12,.04)}
.space-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.space-card .pic{aspect-ratio:3/2}
.space-card .body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.space-card h3{font-size:20px}
.space-card p{font-size:14px;color:var(--muted);margin:8px 0 14px}
.space-card .feat{display:flex;flex-wrap:wrap;gap:7px;margin-top:auto}
.tag{font-size:12px;color:var(--accent-ink);background:color-mix(in oklab,var(--accent),transparent 90%);
  padding:4px 11px;border-radius:999px;font-weight:600}

/* Offres / tarifs */
.pricing{background:var(--ecru-2)}
.toggle{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:5px;gap:4px;margin-top:8px;box-shadow:0 1px 2px rgba(20,18,12,.05)}
.toggle button{font-family:var(--font-body);font-weight:600;font-size:14px;border:0;background:transparent;color:var(--muted);
  padding:9px 18px;border-radius:999px;cursor:pointer;transition:all .18s ease}
.toggle button[aria-pressed="true"]{background:var(--accent);color:#fff}
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:38px}
.plan{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:30px 26px;display:flex;flex-direction:column;box-shadow:0 1px 2px rgba(20,18,12,.04)}
.plan.feature{border-color:var(--orange);box-shadow:0 22px 48px -26px rgba(232,85,31,.55);position:relative}
.plan.feature::before{content:"Le plus choisi";position:absolute;top:-13px;left:26px;background:var(--orange);color:#fff;
  font-family:var(--font-body);font-size:12px;font-weight:700;letter-spacing:.04em;padding:6px 13px;border-radius:999px}
.plan h3{font-size:22px}
.plan .price{font-family:var(--font-display);font-size:44px;font-weight:700;letter-spacing:-.02em;margin:16px 0 2px;font-variant-numeric:tabular-nums;color:var(--teal)}
.plan .price small{font-size:15px;font-weight:600;color:var(--muted);letter-spacing:0}
.plan .unit{font-size:13.5px;color:var(--muted);min-height:40px}
.plan ul{list-style:none;margin:22px 0 26px;display:flex;flex-direction:column;gap:11px}
.plan li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px}
.plan li svg{flex:0 0 auto;margin-top:3px;color:var(--orange)}
.plan .btn{margin-top:auto;justify-content:center}
.price-note{font-size:13px;color:var(--muted);margin-top:22px;text-align:center}

/* Avantages — pastilles colorées en rotation */
.perks{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.perks.cols-3{grid-template-columns:repeat(3,1fr)}
.perk{padding:4px}
.perk .ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  color:#fff;margin-bottom:14px;box-shadow:var(--shadow)}
.perk:nth-child(4n+1) .ico{background:var(--orange)}
.perk:nth-child(4n+2) .ico{background:var(--indigo)}
.perk:nth-child(4n+3) .ico{background:var(--teal)}
.perk:nth-child(4n+4) .ico{background:var(--ambre);color:var(--ink)}
.perk h3{font-size:18px}
.perk p{font-size:14px;color:var(--muted);margin-top:7px}

/* Communauté / split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center}
.split.rev>.pic{order:2}
.split .pic{aspect-ratio:5/4;border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.split blockquote{font-family:var(--font-quote);font-style:italic;font-weight:400;font-size:clamp(23px,3vw,32px);line-height:1.3;letter-spacing:-.01em;margin:18px 0;color:var(--fg)}
.split cite{font-style:normal;color:var(--muted);font-size:14.5px;display:flex;gap:11px;align-items:center;font-weight:600}
.split cite .av{width:38px;height:38px;border-radius:50%;background:linear-gradient(140deg,var(--orange),var(--ambre));flex:none}

/* Galerie photos */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:240px;grid-auto-flow:dense;gap:14px}
.gallery a{position:relative;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);background:var(--ecru-2)}
.gallery a.tall{grid-row:span 2}
.gallery a.wide{grid-column:span 2}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery a:hover img{transform:scale(1.04)}

/* Contact / info cards */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:46px}
.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:0 1px 2px rgba(20,18,12,.04)}
.info-card .ico{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:var(--teal);color:#fff;margin-bottom:14px;box-shadow:var(--shadow)}
.info-card:nth-child(3n+2) .ico{background:var(--orange)}
.info-card:nth-child(3n+3) .ico{background:var(--indigo)}
.info-card h3{font-size:17px;margin-bottom:6px}
.info-card p,.info-card a{font-size:15px;color:var(--muted);line-height:1.6}
.info-card a{color:var(--accent-ink)}
.map-embed{width:100%;border:0;border-radius:var(--radius);border:1px solid var(--border);min-height:380px;display:block}
.contact-cols{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}

/* FAQ */
.faq{max-width:760px;margin:0 auto}
.q{border-bottom:1px solid var(--border)}
.q button{width:100%;text-align:left;background:none;border:0;cursor:pointer;
  padding:22px 0;display:flex;justify-content:space-between;gap:20px;align-items:center;
  font-family:var(--font-display);font-weight:600;font-size:19px;color:var(--fg)}
.q .a{max-height:0;overflow:hidden;transition:max-height .28s ease;color:var(--muted);font-size:15px}
.q .a p{padding-bottom:22px;max-width:62ch}
.q button .chev{flex:0 0 auto;transition:transform .25s ease;color:var(--orange)}
.q[data-open="true"] button .chev{transform:rotate(45deg)}

/* CTA / réservation */
.cta{background:var(--accent);color:#fff;border-radius:var(--radius);padding:54px;overflow:hidden;position:relative}
.cta::after{content:"";position:absolute;right:-80px;top:-80px;width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle at center, color-mix(in oklab,var(--jaune),transparent 60%), transparent 70%);pointer-events:none}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;position:relative;z-index:1}
.cta.solo .cta-grid{grid-template-columns:1fr;text-align:center;max-width:640px;margin:0 auto}
.cta.solo .hero-actions{justify-content:center}
.cta h2{font-size:clamp(28px,4vw,42px);color:#fff}
.cta p{color:rgba(255,255,255,.84);font-size:17px;margin-top:14px;max-width:44ch}
.cta.solo p{margin-left:auto;margin-right:auto}
.cta .contact-line{display:flex;gap:22px;flex-wrap:wrap;margin-top:22px;font-size:15px;color:#fff}
.cta.solo .contact-line{justify-content:center}
.cta .contact-line a{display:inline-flex;gap:8px;align-items:center;font-weight:600}
.cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.6)}
.cta .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.14)}
.form{background:var(--surface);color:var(--fg);border-radius:var(--radius-sm);padding:26px;display:grid;gap:14px}
.field{display:grid;gap:6px}
.field label{font-size:13px;font-weight:600;color:var(--muted)}
.field input,.field select,.field textarea{font-family:var(--font-body);font-size:15px;padding:12px 14px;border:1.5px solid var(--border);
  border-radius:12px;background:var(--bg);color:var(--fg);width:100%}
.field textarea{min-height:104px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form .btn{justify-content:center;margin-top:4px}
.form .ok-msg{display:none;align-items:center;gap:9px;color:var(--ok);font-size:14.5px;font-weight:600}
.form.sent .ok-msg{display:flex}
.form-mini{font-size:12.5px;color:var(--muted)}
.form .err-msg{color:#c0392b;font-size:14px}
.form.sending .btn{opacity:.6;pointer-events:none}

/* ============ Footer (sombre, branding Bastion) ============ */
.foot{background:var(--teal-deep);color:rgba(255,255,255,.78);padding:60px 0 30px;margin-top:0;position:relative}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.1fr;gap:32px}
@media(max-width:980px){.foot-grid{grid-template-columns:1fr 1fr}}
.foot h4{font-family:var(--font-body);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--jaune);margin-bottom:14px;font-weight:700}
.foot a{display:block;color:rgba(255,255,255,.74);font-size:14.5px;padding:5px 0;transition:color .15s ease}
.foot a:hover{color:#fff}
.foot a.cr-link::before{content:"";display:inline-block;width:12px;height:12px;margin-right:7px;vertical-align:-1px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23F08AB0'%3E%3Cpath d='M12 21s-7.5-4.7-10-9.3C.3 8.4 1.7 5 5 5c2 0 3.2 1.2 4 2.3C9.8 6.2 11 5 13 5c3.3 0 4.7 3.4 3 6.7C15.5 16.3 12 21 12 21z'/%3E%3C/svg%3E") center/contain no-repeat;transition:transform .15s ease}
.foot a.cr-link:hover::before{transform:scale(1.18)}
.foot .brand{margin-bottom:14px}
.foot .brand-logo{height:60px;width:auto}
.foot .about{font-size:14px;color:rgba(255,255,255,.66);max-width:32ch}
.foot address{font-style:normal;font-size:14.5px;color:rgba(255,255,255,.74);line-height:1.7}
.foot address a{display:inline}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.12);
  margin-top:40px;padding-top:22px;font-size:13px;color:rgba(255,255,255,.55)}
.foot-bottom a{color:rgba(255,255,255,.7)}
.foot-bottom a:hover{color:#fff}

/* Teaser carnet rose (page communauté) */
.crose-teaser{display:flex;align-items:center;gap:20px;padding:22px 26px;border-radius:22px;
  background:linear-gradient(160deg,#FCE9F0 0%,#FBDCE8 55%,#F6C9D9 100%);
  border:1px solid #fff;box-shadow:0 10px 30px rgba(178,62,99,.12);transition:transform .18s ease,box-shadow .18s ease}
.crose-teaser:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(178,62,99,.18)}
.crose-teaser-ic{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.7)}
.crose-teaser-ic svg{transition:transform .18s ease}
.crose-teaser:hover .crose-teaser-ic svg{transform:scale(1.15)}
.crose-teaser-txt{display:flex;flex-direction:column;gap:3px;flex:1 1 auto}
.crose-teaser-txt strong{font-family:var(--font-display);font-size:19px;color:#6b2840}
.crose-teaser-txt span:last-child{font-size:14.5px;color:#8a4a61}
.crose-teaser-go{flex:0 0 auto;font-weight:700;font-size:14.5px;color:#B23E63;white-space:nowrap}
@media(max-width:640px){.crose-teaser{flex-wrap:wrap;text-align:left}.crose-teaser-go{width:100%}}

/* Section « Citations inspirantes » — cartes couleur façon flyer */
.quotes-block .qcards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:28px}
.qcard{background:var(--qc,var(--teal));color:#fff;border-radius:var(--radius);padding:30px 28px;
  display:flex;flex-direction:column;justify-content:space-between;min-height:230px;
  position:relative;overflow:hidden;box-shadow:var(--shadow)}
.qcard::after{content:"";position:absolute;right:-30px;bottom:-30px;width:120px;height:120px;border-radius:32px;
  background:rgba(255,255,255,.10);transform:rotate(18deg);pointer-events:none}
.qcard blockquote{margin:0;position:relative;z-index:1;
  font-family:var(--font-quote);font-style:italic;
  font-size:clamp(16px,1.35vw,19px);line-height:1.45}
.qcard figcaption{margin-top:20px;position:relative;z-index:1;
  font-family:var(--font-display);font-weight:700;letter-spacing:.01em;color:rgba(255,255,255,.9)}
@media(max-width:880px){.quotes-block .qcards{grid-template-columns:1fr}}

/* Citations — carrousel horizontal (3 visibles, défilement pour le reste) */
.qrail{position:relative;margin-top:28px}
.qtrack{list-style:none;margin:0;padding:4px 2px 14px;display:flex;gap:18px;
  overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}
.qtrack:focus-visible{outline:3px solid var(--nuit);outline-offset:3px;border-radius:12px}
.qtrack::-webkit-scrollbar{height:8px}
.qtrack::-webkit-scrollbar-thumb{background:rgba(20,18,12,.22);border-radius:8px}
.qtrack .qcard{flex:0 0 calc((100% - 36px)/3);scroll-snap-align:start;margin:0}
.qnav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:48px;height:48px;border-radius:50%;
  border:0;background:#fff;color:var(--nuit);box-shadow:var(--shadow);
  font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.qprev{left:-14px}.qnext{right:-14px}
.qnav:disabled{opacity:.3;cursor:default;box-shadow:none}
@media(max-width:880px){.qtrack .qcard{flex-basis:84%}.qnav{display:none}}

/* ============ Reveal au scroll (classe posée par le JS) ============ */
.reveal{opacity:0;transform:translateY(24px);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============ Responsive ============ */
@media(max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .spaces,.spaces.cols-3{grid-template-columns:1fr 1fr}
  .plans{grid-template-columns:1fr}
  .perks,.perks.cols-3{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:30px}
  .split.rev>.pic{order:0}
  .cta-grid{grid-template-columns:1fr;gap:30px}
  .cta{padding:38px}
  .contact-cols{grid-template-columns:1fr;gap:28px}
  .info-grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links,.nav-cta .btn-ghost{display:none}
  .burger{display:flex}
  .nav-links.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--ecru);border-bottom:1px solid var(--border);padding:8px 24px 18px;box-shadow:var(--shadow)}
  .nav-links.open a{padding:14px 0;border-bottom:1px solid var(--border);font-size:16px;color:var(--fg)}
  .nav-links.open a::after{display:none}
  section.block{padding:60px 0}
  .spaces,.spaces.cols-3{grid-template-columns:1fr}
  .perks,.perks.cols-3{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .strip .items{margin-left:0;gap:18px}
  .info-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr;grid-auto-rows:220px}
  .gallery a.wide{grid-column:span 1}
  .foot-grid{grid-template-columns:1fr 1fr;gap:26px}
  .hero-meta{gap:20px}
  .hero-carousel{height:clamp(500px,86vh,640px)}
  .hc-arrow{display:none}
  .hc-overlay .hero-meta{display:none}
  .hc-overlay .lead{font-size:17px}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .hc-slide{transition:none}
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .btn:hover,.space-card:hover,.perk:hover,.qcard:hover,.gallery a:hover img{transform:none}
}

.items a{font-family:var(--font-display);font-weight:600;color:var(--teal);font-size:15px;letter-spacing:.01em;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s ease,opacity .15s ease}
.items a:hover{border-bottom-color:currentColor;opacity:.85}

/* Blog — article + index */
.blogpost h2{font-size:clamp(22px,2.6vw,30px);margin:34px 0 12px}
.blogpost h3{font-size:clamp(18px,2vw,22px);margin:24px 0 10px}
.blogpost p{margin:0 0 16px}
.blogpost figure{margin:22px 0}
.blogpost img{max-width:100%;height:auto;border-radius:16px;display:block}
.blogpost blockquote{margin:22px 0;padding:14px 22px;border-left:4px solid var(--orange);background:var(--surface-2);border-radius:0 12px 12px 0;font-family:Georgia,"Times New Roman",serif;font-style:italic;font-size:1.1em}
.blogpost blockquote p{margin:0}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:30px}
.tag{font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--teal);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:5px 12px}
.bloglist{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blogcard{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;text-decoration:none;color:inherit;transition:transform .18s ease,box-shadow .18s ease}
.blogcard:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(20,20,40,.12)}
.blogcard-img{aspect-ratio:3/2;overflow:hidden}
.blogcard-img img{width:100%;height:100%;object-fit:cover}
.blogcard-body{padding:20px 22px;display:flex;flex-direction:column;gap:8px}
.blogcard-body h2{font-size:19px;line-height:1.25;margin:0}
.blogcard-body p{font-size:14px;color:var(--muted);margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blogcard-more{margin-top:auto;font-family:var(--font-display);font-weight:600;color:var(--orange);font-size:14px}
@media(max-width:880px){.bloglist{grid-template-columns:1fr}}

/* Partenaires */
.partner-logos{display:flex;flex-wrap:wrap;gap:50px;align-items:center;justify-content:center;margin-top:30px}
.partner-logos img{max-height:78px;width:auto}
.partner-logos a{display:inline-flex}
.partner-note{text-align:center;color:var(--muted);font-size:14px;margin-top:24px;max-width:60ch;margin-left:auto;margin-right:auto}

.photo-credit{display:flex;flex-direction:column;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.6);text-align:center;margin:0 0 34px;font-family:Georgia,"Times New Roman",serif}
.credit-mark{height:22px;width:auto;opacity:.6;flex:0 0 auto}

.credit-montage{height:86px;width:auto;filter:drop-shadow(0 6px 14px rgba(0,0,0,.25))}

.credit-montage-link{display:inline-block;cursor:pointer;transition:transform .18s ease}
.credit-montage-link:hover{transform:translateY(-2px)}
