/* ──────────────────────────────────────────────────────────────
   Ma Belle Vitrine — Design « Marée éditoriale »
   Refonte éditoriale : typographie intentionnelle, filets fins,
   numérotation de sections, texture papier, états d’accessibilité.
   ────────────────────────────────────────────────────────────── */
:root{
  /* Couleurs (palette « Marée », contrastes ajustés) */
  --bg:#e9eeec; --surface:#f6f9f8; --surface-2:#eef3f1;
  --ink:#102e33; --sub:#48626a; --line:#d2dedb; --line-2:#bfd0cc;
  --sea:#0e5e63; --sea-deep:#0a4a4e; --accent:#d99a2b; --accent-deep:#bd831b;
  --on-accent:#1c1a12; --hero-bg:#0c3539;
  /* Formes */
  --radius:18px; --radius-sm:12px; --radius-lg:26px;
  /* Rythme (échelle d’espacement) */
  --s1:6px; --s2:12px; --s3:18px; --s4:26px; --s5:40px; --s6:64px; --s7:92px;
  /* Ombres */
  --sh-card:0 26px 54px -36px rgba(16,46,51,.55);
  --sh-soft:0 18px 44px -30px rgba(0,0,0,.42);
  --sh-lift:0 10px 24px -16px rgba(16,46,51,.4);
  /* Anneau de focus */
  --focus:0 0 0 3px var(--bg), 0 0 0 5.5px var(--sea);
  /* Typo */
  --font-d:'Bricolage Grotesque', system-ui, -apple-system, sans-serif;
  --font-b:'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --font-accent:'Bebas Neue', 'Arial Narrow', var(--font-b);
}

/* Police d'enseigne + chiffres — Bebas Neue (SIL OFL, auto-hébergée) */
@font-face{
  font-family:'Bebas Neue';
  src:url('../fonts/BebasNeue-Regular.woff2') format('woff2'),
      url('../fonts/BebasNeue-Regular.woff') format('woff'),
      url('../fonts/BebasNeue-Regular.ttf') format('truetype');
  font-weight:400;font-style:normal;font-display:swap;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--font-b); background:var(--bg); color:var(--ink); line-height:1.55;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-feature-settings:"kern" 1,"liga" 1; font-variant-numeric:lining-nums;
  position:relative;
}
/* Texture papier : grain très discret, sous le contenu */
body::before{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.045;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:inherit}
::selection{background:rgba(14,94,99,.22)}
h1,h2,h3,h4{margin:0;font-family:var(--font-d);font-weight:700;hyphens:none;text-wrap:balance;font-optical-sizing:auto}
p{text-wrap:pretty}
.serif{font-family:var(--font-d)}
.container{max-width:1220px;margin:0 auto;padding:0 24px}
.muted{color:var(--sub)}
.center{text-align:center}
.measure{max-width:62ch}

/* Accessibilité : focus visible cohérent au clavier */
:focus-visible{outline:none;box-shadow:var(--focus);border-radius:6px}
a:focus-visible,.btn:focus-visible,.chip:focus-visible,.like-btn:focus-visible{box-shadow:var(--focus)}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible,
.searchbar input:focus-visible{box-shadow:0 0 0 3px rgba(14,94,99,.18);border-color:var(--sea)}

/* Utilitaires de mise en page (remplacent les styles en ligne) */
.stack>*+*{margin-top:var(--stack,18px)}
.stack-tight{--stack:10px}.stack-loose{--stack:26px}
.cluster{display:flex;flex-wrap:wrap;align-items:center;gap:var(--gap,12px)}
.btn-row{display:flex;flex-wrap:wrap;gap:12px}
.mt-2{margin-top:12px}.mt-3{margin-top:18px}.mt-4{margin-top:26px}.mt-5{margin-top:40px}

/* Filet pointillé « marée » (séparateur signature) */
.dot-rule,.tide-rule{height:18px;background:radial-gradient(circle at center,var(--accent) 0 2.2px,transparent 2.4px);
  background-size:22px 18px;opacity:.5}
.tide-rule{opacity:.55;margin-top:6px}

/* Numéro + intitulé éditorial (« № 01 — … ») */
.kicker{display:flex;align-items:center;gap:12px;margin:0;font-size:12px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--sea)}
.kicker-no{font-family:var(--font-accent);font-weight:400;font-size:22px;letter-spacing:.03em;
  text-transform:none;color:var(--accent-deep);line-height:1}
.kicker::after{content:"";flex:1;height:1px;background:var(--line-2);min-width:24px}
.kicker.solo::after{display:none}

/* ---- Boutons (« plat moderne » : aplats unis, rayon 12px, relief discret au survol) ---- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:9px;border:0;border-radius:12px;
  padding:13px 24px;font-weight:700;font-size:15px;letter-spacing:.005em;font-family:inherit;cursor:pointer;
  text-decoration:none;-webkit-tap-highlight-color:transparent;
  transition:transform .16s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0) scale(.985);transition-duration:.06s}
.btn .arrow{transition:transform .2s ease}
.btn:hover .arrow{transform:translateX(3px)}
.btn-accent{background:var(--accent);color:var(--on-accent)}
.btn-accent:hover{background:var(--accent-deep);box-shadow:0 8px 18px -10px rgba(217,154,43,.7)}
.btn-sea{background:var(--sea);color:#fff}
.btn-sea:hover{background:var(--sea-deep);box-shadow:0 8px 18px -10px rgba(14,94,99,.6)}
.btn-ink{background:var(--ink);color:var(--bg)}
.btn-ink:hover{box-shadow:0 8px 18px -10px rgba(16,46,51,.6)}
.btn-ghost{background:transparent;border:1.5px solid var(--line-2);color:var(--ink)}
.btn-ghost:hover{border-color:var(--sea);color:var(--sea);background:rgba(14,94,99,.06)}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ghost.on-dark:hover{color:#fff;border-color:#fff;background:rgba(255,255,255,.1)}
.btn-block{width:100%}
.btn-sm{padding:9px 16px;font-size:13.5px}

/* ---- En-tête / navigation ---- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(233,238,236,.88);
  backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
  transition:background .25s ease,box-shadow .25s ease,border-color .25s ease}
.site-header.is-scrolled{background:rgba(233,238,236,.96);border-bottom-color:var(--line-2);
  box-shadow:0 12px 32px -20px rgba(16,46,51,.55)}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:13px 0;
  transition:padding .25s ease}
.site-header.is-scrolled .bar{padding:8px 0}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;flex:0 0 auto}
.brand .mark{width:42px;height:42px;border-radius:13px;overflow:hidden;display:block;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08),0 6px 16px -10px var(--sea)}
.brand .mark svg{width:100%;height:100%;display:block}
.brand .name{display:block;font-family:var(--font-accent);font-size:27px;letter-spacing:.045em;text-transform:uppercase;line-height:1;color:var(--ink)}
.brand .tag{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--sub);font-weight:700;margin-top:3px}

.nav{display:flex;align-items:center;gap:2px}
.nav-link,.nav-trigger{position:relative;display:inline-flex;align-items:center;gap:6px;
  padding:9px 14px;font-family:inherit;font-size:14.5px;font-weight:600;color:var(--ink);
  text-decoration:none;background:none;border:0;border-radius:9px;cursor:pointer;opacity:.8;
  transition:opacity .15s ease,background .15s ease,color .15s ease}
.nav-link::after,.nav-trigger::after{content:"";position:absolute;left:14px;right:14px;bottom:5px;height:2px;
  background:var(--sea);border-radius:2px;transform:scaleX(0);transform-origin:left;
  transition:transform .22s cubic-bezier(.2,.7,.2,1)}
.nav-link:hover,.nav-trigger:hover{opacity:1;background:rgba(14,94,99,.06)}
.nav-link:hover::after,.nav-trigger:hover::after{transform:scaleX(1)}
.nav-link.is-active,.nav-trigger.is-active{opacity:1;color:var(--sea)}
.nav-link.is-active::after,.nav-trigger.is-active::after{transform:scaleX(1)}
.nav-caret{flex:0 0 auto;opacity:.55;transition:transform .2s ease}
.nav-group{position:relative}
.nav-group:hover .nav-caret,.nav-group[data-open] .nav-caret{transform:rotate(180deg)}
.nav-menu{position:absolute;top:calc(100% + 10px);left:0;min-width:272px;padding:8px;
  display:grid;gap:2px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);
  box-shadow:0 24px 52px -26px rgba(16,46,51,.6);
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s ease,transform .18s ease,visibility .18s;z-index:60}
.nav-menu::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}
.nav-group:hover .nav-menu,.nav-group[data-open] .nav-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-menu-link{display:grid;gap:2px;padding:10px 12px;border-radius:10px;text-decoration:none;
  transition:background .15s ease}
.nav-menu-link:hover{background:rgba(14,94,99,.08)}
.nav-menu-link.is-active{background:rgba(14,94,99,.1)}
.nav-menu-label{font-size:14.5px;font-weight:600;line-height:1.2;color:var(--ink)}
.nav-menu-link.is-active .nav-menu-label{color:var(--sea)}
.nav-menu-desc{font-size:12.5px;line-height:1.3;color:var(--sub)}

.header-cta{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.header-cta .login{font-size:14px;color:var(--ink);text-decoration:none;font-weight:600;opacity:.72;padding:8px 6px}
.header-cta .login:hover{opacity:1;color:var(--sea)}
.pill-support{font-size:14px;font-weight:700;text-decoration:none;color:var(--sea);
  padding:9px 16px;border-radius:100px;border:1.5px solid var(--line-2);
  transition:border-color .18s ease,color .18s ease,background .18s ease}
.pill-support:hover{border-color:var(--sea);background:rgba(14,94,99,.06)}
.pill-publish{background:linear-gradient(180deg,#1b444a,var(--ink));color:var(--bg);padding:10px 18px;border-radius:100px;
  font-size:14px;font-weight:700;text-decoration:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 8px 18px -12px rgba(16,46,51,.7);
  transition:transform .15s ease,background .2s ease,box-shadow .2s ease}
.pill-publish:hover{transform:translateY(-2px);background:linear-gradient(180deg,#137b80,var(--sea));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 14px 26px -14px rgba(14,94,99,.8)}
.pill-publish:active{transform:translateY(0) scale(.98)}

.burger{display:none;background:var(--surface);border:1px solid var(--line-2);border-radius:12px;width:46px;height:46px;
  flex-direction:column;gap:4px;align-items:center;justify-content:center;cursor:pointer}
.burger span{width:20px;height:2px;background:var(--ink);border-radius:2px;transform-origin:center;
  transition:transform .25s cubic-bezier(.2,.7,.2,1),opacity .2s ease}
.burger.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.mobile-nav{display:none;flex-direction:column;gap:2px;border-top:1px solid var(--line);padding:12px 0 18px}
.mobile-nav.open{display:flex}
.mnav-link{padding:13px 6px;font-size:17px;font-weight:600;color:var(--ink);text-decoration:none;
  border-bottom:1px solid var(--line)}
.mnav-link.is-active{color:var(--sea)}
.mnav-group{display:flex;flex-direction:column}
.mnav-group-label{font-family:var(--font-accent);font-size:16px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--sub);padding:16px 6px 2px}
.mnav-sub{padding-left:18px;font-size:16px}
.mnav-actions{display:flex;flex-direction:column;gap:10px;margin-top:16px;padding-top:8px}
.mnav-support{text-align:center;font-weight:700;color:var(--sea);text-decoration:none;
  border:1.5px solid var(--line-2);border-radius:100px;padding:12px}
.mnav-actions .mnav-link{border-bottom:0;text-align:center}
.mnav-publish{text-align:center;margin-top:2px}

/* Focus clavier visible (a11y) — anneau marque, souris non affectée */
.brand:focus-visible,.nav-link:focus-visible,.nav-trigger:focus-visible,.nav-menu-link:focus-visible,
.header-cta .login:focus-visible,.pill-support:focus-visible,.pill-publish:focus-visible,
.burger:focus-visible,.mnav-link:focus-visible,.mnav-support:focus-visible{
  outline:2.5px solid var(--sea);outline-offset:3px;border-radius:10px}

/* ---- Badges / éligibilité ---- */
.eyebrow{display:inline-flex;align-items:center;gap:9px;padding:7px 14px;border:1px solid var(--line-2);
  border-radius:100px;font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--sea);font-weight:700;
  background:rgba(255,255,255,.4)}
.eyebrow .dot{display:none}

/* ---- Hero (éditorial) ---- */
.hero{position:relative;overflow:hidden;background:var(--bg)}
.hero .grid,.hero-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:clamp(28px,4vw,64px);align-items:center;
  padding-top:clamp(36px,6vw,88px);padding-bottom:clamp(34px,5vw,60px)} /* horizontal hérité de .container (alignement page) */
.hero-grid{grid-template-columns:1.08fr .92fr}
.hero h1{font-family:var(--font-d);font-size:clamp(44px,7vw,88px);line-height:1.04;letter-spacing:-.015em;margin:20px 0 0}
.hero h1 em{color:var(--sea);font-style:normal}
.hero p,.hero-sub{font-size:clamp(16px,1.5vw,19px);line-height:1.6;color:var(--sub);max-width:32em;margin:22px 0 0}
.hero-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:32px}
.hero-stats>div{border:1px solid var(--line);background:var(--surface);border-radius:16px;padding:18px 26px;text-align:center;min-width:128px}
.hero-stats .n{font-family:var(--font-accent);font-size:46px;letter-spacing:.01em;line-height:.86;color:var(--sea);font-variant-numeric:lining-nums}
.hero-stats .l{text-transform:uppercase;letter-spacing:.08em;font-weight:700;font-size:11px;color:var(--sub);margin-top:8px}
.hero-media{position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--sh-card),inset 0 0 0 1px rgba(255,255,255,.06);background:var(--hero-bg)}
.hero-media img,.hero-media .hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0;display:block}
.hero-media .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,40,44,.04) 38%,rgba(11,40,44,.62) 100%)}
.hero-media .tagchip{position:absolute;left:14px;bottom:14px;background:var(--accent);color:var(--on-accent);
  padding:7px 14px;border-radius:100px;font-size:12px;font-weight:700;box-shadow:var(--sh-lift)}

/* ---- Recherche et filtres ---- */
.searchbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:9px;box-shadow:var(--sh-soft)}
.searchbar input{flex:1 1 280px;border:0;background:transparent;font-size:16px;color:var(--ink);padding:13px 14px;outline:none;font-family:inherit}
.searchbar input::placeholder{color:var(--sub);opacity:.85}
.chips{display:flex;gap:9px;margin-top:16px;overflow-x:auto;padding-bottom:6px;scrollbar-width:thin}
.chip{border-radius:100px;padding:9px 17px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;
  text-decoration:none;border:1px solid var(--line-2);background:var(--surface);color:var(--ink);flex:0 0 auto;
  transition:border-color .15s ease,color .15s ease}
.chip:hover{border-color:var(--sea);color:var(--sea)}
.chip.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}

/* ---- Sections ---- */
.section{padding:clamp(34px,5vw,64px) 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;
  margin-bottom:26px;padding-top:22px;border-top:1px solid var(--line-2)}
.section-head h2{font-family:var(--font-d);font-size:clamp(28px,3.6vw,46px);line-height:1.04;letter-spacing:-.01em}
.section-head .link{position:relative;color:var(--sea);font-weight:700;font-size:14.5px;text-decoration:none;white-space:nowrap;
  background-image:linear-gradient(var(--sea),var(--sea));background-size:0% 1.5px;background-position:0 100%;
  background-repeat:no-repeat;transition:background-size .25s ease;padding-bottom:2px}
.section-head .link:hover{background-size:100% 1.5px}

/* ---- Cartes (annonces / grille) ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(266px,1fr));gap:clamp(16px,2vw,24px)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;text-decoration:none;color:inherit;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh-card);border-color:var(--line-2)}
.card .media{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--line)}
.card .media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.2,.6,.2,1)}
.card:hover .media img{transform:scale(1.05)}
.card .featured{position:absolute;top:12px;left:12px;background:var(--accent);color:var(--on-accent);
  padding:5px 12px;border-radius:100px;font-size:11.5px;font-weight:700;letter-spacing:.02em;box-shadow:var(--sh-lift)}
.card .body{padding:16px 17px 18px;display:flex;flex-direction:column;gap:7px;flex:1}
.card .cat{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--sea);font-weight:700}
.card .cat::before{content:"";width:16px;height:1.5px;background:var(--accent);flex:0 0 auto}
.card .title{font-size:17.5px;font-weight:700;line-height:1.25;color:var(--ink);letter-spacing:-.005em}
.card .meta{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13.5px;color:var(--sub)}
.card .meta>span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.card .price{font-weight:800;color:var(--ink);white-space:nowrap;flex:0 0 auto;font-variant-numeric:tabular-nums}

/* Carte « à la une » sur l’accueil (mise en avant éditoriale) */
.card--feature{grid-column:span 2}
@media (min-width:760px){
  .card--feature{flex-direction:row;align-items:stretch}
  .card--feature .media{flex:1 1 52%;aspect-ratio:auto;min-height:280px}
  .card--feature .body{flex:1 1 48%;justify-content:center;padding:clamp(22px,3vw,34px)}
  .card--feature .title{font-size:clamp(22px,2.4vw,30px);font-family:var(--font-d);font-weight:700;line-height:1.1}
}
@media (max-width:560px){.card--feature{grid-column:span 1}}
.card .body p{margin:0;font-size:14px;line-height:1.5;color:var(--sub)}
.hero-media.wide{aspect-ratio:4/3}

/* ---- Annuaire de liens utiles ---- */
.liens-h1{font-family:var(--font-d);font-size:clamp(34px,5vw,54px);line-height:1.04;letter-spacing:-.01em;margin:0}
.liens-form-wrap{max-width:720px}
.links-group{margin-top:6px}
.links-cat{font-family:var(--font-d);font-size:clamp(20px,2.6vw,28px);line-height:1.1;margin:34px 0 16px;display:flex;align-items:baseline;gap:10px}
.links-count{font-family:var(--font-b);font-size:13px;font-weight:700;color:var(--sub)}
.link-card .body{gap:7px}
.link-go{margin-top:6px;color:var(--sea);font-weight:700;font-size:13.5px;display:inline-flex;align-items:center;gap:6px}
.link-card:hover .link-go{color:var(--sea-deep)}
/* admin : lignes de catégories */
.liencat-row{grid-template-columns:1fr auto;align-items:center}
.liencat-rename{gap:8px;min-width:0;flex:1 1 auto}
.liencat-count{font-size:13px;white-space:nowrap}
@media (max-width:680px){ .liencat-row{grid-template-columns:1fr} }

/* ---- Badge soutien (palier membre) ---- */
.tier-badge{display:inline-block;padding:3px 11px;border-radius:100px;font-size:11px;font-weight:800;
  letter-spacing:.02em;line-height:1.3}
.tier-badge.donor{background:rgba(14,94,99,.12);color:var(--sea)}
.tier-badge.mecene{background:var(--accent);color:var(--on-accent)}

/* ---- Bandeaux CTA ---- */
.band{background:var(--hero-bg);color:#fff;position:relative;overflow:hidden}
.band::before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(circle at center,rgba(217,154,43,.5) 0 2px,transparent 2.2px);background-size:26px 26px;
  -webkit-mask-image:linear-gradient(90deg,#000,transparent 60%);mask-image:linear-gradient(90deg,#000,transparent 60%)}
.band .inner{position:relative;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px;
  align-items:center;padding:clamp(40px,5vw,68px) 0}
.band h2{font-family:var(--font-d);font-size:clamp(30px,3.8vw,48px);line-height:1.04;color:#fff;letter-spacing:-.01em}
.band p{color:rgba(255,255,255,.84);font-size:16px;line-height:1.6;margin:16px 0 0;max-width:34em}

/* ---- Pied de page ---- */
.site-footer{background:var(--ink);color:#cfe0dd;margin-top:48px;border-top:3px solid var(--accent)}
.site-footer .grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:32px;padding:clamp(44px,5vw,68px) 0 30px}
.site-footer h4{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#8fb0ab;font-weight:700;margin:0 0 14px}
.site-footer a{color:#cfe0dd;text-decoration:none;display:block;padding:5px 0;font-size:14.5px;opacity:.85;transition:opacity .15s,color .15s}
.site-footer a:hover{opacity:1;color:#fff}
.site-footer .brand .name{color:#fff}
.site-footer .legal{border-top:1px solid rgba(255,255,255,.12);padding:18px 0;display:flex;justify-content:space-between;
  gap:14px;flex-wrap:wrap;font-size:13px;color:#8fb0ab}
.site-footer .legal a{display:inline;padding:0}

/* ---- Barre de partage ---- */
.share{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-top:20px}
.share .label{font:700 12px/1 var(--font-b);letter-spacing:.12em;text-transform:uppercase;color:inherit;opacity:.65;margin-right:4px}
.share-net{--c:var(--sea);display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;
  border-radius:12px;border:1px solid var(--line-2);background:var(--surface);color:var(--c);text-decoration:none;cursor:pointer;
  transition:background .18s ease,border-color .18s ease,color .18s ease,transform .15s ease}
.share-net:hover{background:var(--c);border-color:var(--c);color:#fff;transform:translateY(-2px)}
.share-net svg{width:18px;height:18px;fill:currentColor}
.share-fb{--c:#1877f2}.share-x{--c:#0a0a0a}.share-li{--c:#0a66c2}.share-wa{--c:#1ebe57}.share-mail{--c:var(--sea)}
.share-copy{display:inline-flex;align-items:center;gap:8px;height:42px;padding:0 16px;border-radius:12px;
  border:1px solid var(--line-2);background:var(--surface);color:var(--ink);font:700 14px/1 var(--font-b);cursor:pointer;
  transition:border-color .18s ease,color .18s ease,background .18s ease}
.share-copy:hover{border-color:var(--sea);color:var(--sea);background:rgba(14,94,99,.06)}
.share-copy svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}

/* ---- Formulaires ---- */
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--sub);font-weight:700;margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line-2);border-radius:11px;background:var(--surface);
  color:var(--ink);padding:13px 14px;font-size:16px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--sea);box-shadow:0 0 0 3px rgba(14,94,99,.14)}
.field textarea{min-height:120px;resize:vertical}
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,3vw,32px);box-shadow:var(--sh-soft)}

/* ---- Alertes / flash ---- */
.alert{border-radius:12px;padding:13px 16px;font-size:14.5px;font-weight:600;margin-bottom:18px}
.alert-success{background:#e3f1e8;color:#15603a;border:1px solid #bcdcc7}
.alert-error{background:#fbe6e3;color:#8a2b1f;border:1px solid #f0c4bd}

/* ---- Prose (pages légales) ---- */
.prose{max-width:46em}
.prose h1{font-family:var(--font-d);font-size:clamp(36px,5vw,56px);line-height:1.06;margin:0 0 10px;letter-spacing:-.01em}
.prose h2{font-family:var(--font-d);font-size:clamp(23px,2.6vw,31px);margin:38px 0 12px}
.prose p,.prose li{font-size:16.5px;line-height:1.7;color:#243a40}
.prose ul{padding-left:20px}
.prose li{margin-bottom:6px}
.prose a{color:var(--sea);font-weight:600;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}
.lead{font-size:18.5px;line-height:1.55;color:var(--sub);margin-top:0}

/* ---- Bandeau cookies ---- */
.cookie{position:fixed;left:18px;right:18px;bottom:18px;z-index:100;max-width:620px;margin:0 auto;
  background:var(--ink);color:#dfeae8;border-radius:16px;padding:18px 20px;box-shadow:0 24px 60px -20px rgba(0,0,0,.5);
  display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.cookie p{margin:0;font-size:14px;line-height:1.55;flex:1 1 280px}
.cookie a{color:var(--accent);font-weight:600}
.cookie .actions{display:flex;gap:9px;flex:0 0 auto}
.cookie .actions button{border:0;border-radius:100px;padding:11px 18px;font-weight:700;font-size:14px;cursor:pointer;font-family:inherit}
.cookie .accept{background:var(--accent);color:var(--on-accent)}
.cookie .refuse{background:transparent;border:1px solid rgba(255,255,255,.3);color:#dfeae8}
.cookie[hidden]{display:none}

/* ---- Galerie ---- */
.masonry{columns:4 240px;column-gap:16px}
.masonry .ph{break-inside:avoid;margin-bottom:16px;border-radius:14px;overflow:hidden;border:1px solid var(--line);
  background:var(--surface);position:relative;transition:box-shadow .2s ease}
.masonry .ph:hover{box-shadow:var(--sh-lift)}
.masonry .ph img{width:100%;display:block}
.masonry .ph .cap{padding:11px 13px}
.masonry .ph .cap .t{font-weight:700;font-size:14.5px}
.masonry .ph .cap .a{font-size:12.5px;color:var(--sub);margin-top:3px}
.masonry .ph .ph-badge{position:absolute;top:10px;left:10px;z-index:2;background:var(--accent);color:var(--on-accent);
  padding:4px 10px;border-radius:100px;font-size:11px;font-weight:800;letter-spacing:.02em;white-space:nowrap}

/* ---- Galerie : « J’aime » ---- */
.like-form{position:absolute;top:8px;right:8px;z-index:2;margin:0}
.like-btn{display:inline-flex;align-items:center;gap:6px;border:0;cursor:pointer;font-family:inherit;
  background:rgba(13,56,61,.62);color:#fff;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  padding:7px 12px;border-radius:100px;font-size:13px;font-weight:700;line-height:1;
  transition:transform .12s ease, background .15s ease}
.like-btn:hover{transform:scale(1.05)}
.like-btn .like-heart{font-size:15px;line-height:1}
.like-btn.liked{background:var(--accent);color:var(--on-accent)}
.like-btn.bump{animation:likeBump .32s ease}
@keyframes likeBump{0%{transform:scale(1)}40%{transform:scale(1.28)}100%{transform:scale(1)}}

/* ---- Galerie : concours du mois ---- */
.contest-banner{display:grid;grid-template-columns:1.6fr 1fr;gap:0;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;background:var(--hero-bg);color:#fff}
.contest-main{padding:clamp(22px,3vw,34px)}
.contest-eyebrow{display:inline-block;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:800}
.contest-main h2{font-family:var(--font-d);font-weight:700;font-size:clamp(24px,3vw,34px);line-height:1.08;margin:10px 0 0}
.contest-desc{font-size:14.5px;line-height:1.6;color:rgba(255,255,255,.82);margin:12px 0 0;max-width:34em}
.contest-reward{display:flex;align-items:flex-start;gap:10px;margin-top:16px;font-size:14px;line-height:1.5;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:13px;padding:12px 14px}
.contest-reward strong{color:var(--accent)}
.contest-gift{font-size:18px;flex:0 0 auto}
.contest-board{background:rgba(255,255,255,.06);border-left:1px solid rgba(255,255,255,.14);
  padding:clamp(18px,2.4vw,24px);display:flex;flex-direction:column;gap:11px}
.contest-board-h{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6);font-weight:800}
.lb-row{display:flex;align-items:center;gap:11px}
.lb-rank{width:24px;height:24px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-accent);font-size:15px;font-weight:400;color:#0d383d}
.lb-thumb{width:42px;height:42px;border-radius:10px;object-fit:cover;flex:0 0 auto}
.lb-meta{min-width:0;flex:1}
.lb-title{font-size:13.5px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lb-author{font-size:12px;color:rgba(255,255,255,.6)}
.lb-likes{font-size:13px;font-weight:800;color:var(--accent);flex:0 0 auto;font-variant-numeric:tabular-nums}

/* ---- Galerie : lauréat précédent ---- */
.winner-card{display:flex;gap:18px;align-items:center;flex-wrap:wrap;background:var(--surface);
  border:1.5px solid var(--accent);border-radius:var(--radius);padding:16px;box-shadow:0 0 0 4px rgba(217,154,43,.08)}
.winner-img{width:96px;height:96px;border-radius:14px;object-fit:cover;flex:0 0 auto}
.winner-eyebrow{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:800}
.winner-title{font-size:22px;margin-top:5px;font-family:var(--font-d)}
.winner-author{font-size:13px;color:var(--sub);margin-top:2px}
.winner-reward{font-size:13.5px;color:var(--ink);margin-top:8px}

/* ---- Galerie : participation au concours ---- */
.contest-optin{display:flex;align-items:flex-start;gap:10px;background:rgba(217,154,43,.1);border:1px solid var(--accent);
  border-radius:12px;padding:12px 14px;margin-bottom:15px;font-size:13.5px;line-height:1.5;color:var(--ink);cursor:pointer}
.contest-optin input{width:18px;height:18px;margin-top:1px;flex:0 0 auto;accent-color:var(--accent)}
@media (max-width:680px){ .contest-banner{grid-template-columns:1fr} .contest-board{border-left:0;border-top:1px solid rgba(255,255,255,.14)} }

/* ---- Liste marchés / associations ---- */
.rows{display:grid;gap:14px}
.row-item{display:grid;grid-template-columns:120px 1fr auto;gap:18px;align-items:center;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px;transition:border-color .15s,box-shadow .15s}
.row-item:hover{border-color:var(--line-2);box-shadow:var(--sh-lift)}
.row-item .town{font-family:var(--font-d);font-size:23px}
.row-item .days{font-size:13px;color:var(--sea);font-weight:700}
.row-item .desc{font-size:14px;color:var(--sub);line-height:1.5}

/* ---- Carte interactive (Découvrir) ---- */
.map-filters{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.map-filter{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line-2);background:var(--surface);
  color:var(--ink);border-radius:100px;padding:8px 15px;font-weight:700;font-size:13.5px;cursor:pointer;font-family:inherit;opacity:.5;transition:opacity .15s,border-color .15s}
.map-filter:hover{opacity:.85}
.map-filter.active{opacity:1;border-color:var(--sea)}
.map-filter .swatch{width:11px;height:11px;border-radius:50%;display:inline-block}
.map-layout{display:grid;grid-template-columns:1fr 340px;gap:18px}
.map-canvas{position:relative;z-index:1;height:520px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:#dfe7e5}
.map-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;align-self:start}
.map-panel-empty{padding:26px}
.map-count{margin-top:16px;font-size:14px;color:var(--sub);background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 14px}
.map-panel-media{aspect-ratio:16/10;background:var(--line)}
.map-panel-media img{width:100%;height:100%;object-fit:cover}
.map-panel-body{padding:18px}
.map-panel-body .cat{font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--sea);font-weight:700}
.leaflet-container{font-family:var(--font-b)}
@media (max-width:880px){.map-layout{grid-template-columns:1fr}.map-canvas{height:400px}}

/* ---- Grille 2 colonnes (formulaires) ---- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:560px){ .grid-2{grid-template-columns:1fr} }

/* ---- Responsive ---- */
@media (max-width:1040px){
  .hero .grid,.hero-grid{grid-template-columns:1fr}
  .nav,.header-cta .login,.header-cta .pill-support{display:none}
  .burger{display:flex}
  .site-footer .grid{grid-template-columns:1fr 1fr}
  .row-item{grid-template-columns:1fr;gap:8px}
}
@media (max-width:560px){
  .container{padding:0 18px}
  .site-footer .grid{grid-template-columns:1fr}
  .masonry{columns:2 150px}
  .hero .grid{grid-template-columns:1fr}
  .header-cta .pill-publish{padding:9px 14px;font-size:13.5px}
  .searchbar{flex-direction:column;align-items:stretch}
  .searchbar input{flex:1 1 auto;width:100%}
  .searchbar .btn{width:100%;justify-content:center}
  .hero-stats{gap:12px}
  .hero-stats>div{padding:14px 20px}
  .section-head{gap:10px}
  .section-head .link{font-size:13.5px}
}

/* Téléphones : compacter l'en-tête pour éviter tout débordement horizontal */
@media (max-width:430px){
  .brand .name{font-size:22px}
  .brand .tag{font-size:9px}
  .site-header .bar{gap:10px}
  .header-cta{gap:8px}
}
@media (max-width:340px){
  .header-cta .pill-publish{display:none} /* écrans minuscules : Publier reste dans le menu burger */
}

/* Cibles tactiles confortables sur appareils tactiles (>=44px, recommandation WCAG/Apple) */
@media (pointer:coarse){
  .pill-publish,.pill-support,.header-cta .login{
    display:inline-flex;align-items:center;justify-content:center;min-height:44px}
  .chip,.map-filter,.share a,.share button{min-height:44px}
}

/* ---- Mouvement réduit (accessibilité) ---- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .card:hover{transform:none}.card:hover .media img{transform:none}.btn:hover{transform:none}
}
