/* =====================================================================
   OBSCURA — Design system « dark mystère » (chrome global + base + cartes)
   Chargé après Blocksy. Tokens, header/footer, listing, typographie.
   ===================================================================== */

:root {
  --ob-ink:        #0E0B0D;
  --ob-ink-2:      #15110F;
  --ob-ink-3:      #1C1714;
  --ob-line:       #2A211F;
  --ob-line-soft:  rgba(201,162,90,.18);
  --ob-cream:      #ECE7E1;
  --ob-cream-dim:  #A9A09A;
  --ob-cream-mut:  #756C66;
  --ob-burgundy:   #8A0E32;
  --ob-burgundy-lt:#B23A55;
  --ob-gold:       #C9A25A;
  --ob-gold-soft:  #E3C98B;

  --ob-font-display: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --ob-font-body:    'EB Garamond', Georgia, 'Times New Roman', serif;

  --ob-maxw: 1240px;
  --ob-gap: clamp(1rem, 2.5vw, 2rem);
  --ob-radius: 4px;
  --ob-shadow: 0 24px 60px -28px rgba(0,0,0,.85);
  --ob-ease: cubic-bezier(.22,.61,.36,1);
}

/* ---- Reset doux + base ---- */
html { scroll-behavior: smooth; }
body.obscura {
  margin: 0;
  background: var(--ob-ink);
  color: var(--ob-cream);
  font-family: var(--ob-font-body);
  font-size: 18px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
body.obscura::before { /* grain / vignette subtile */
  content: "";
  position: fixed; inset: 0;
  pointer-events: none; z-index: 0;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(138,14,50,.10), transparent 60%),
    radial-gradient(100% 60% at 50% 120%, rgba(201,162,90,.05), transparent 60%);
}
.obscura * { box-sizing: border-box; }
.obscura a { color: var(--ob-gold); text-decoration: none; transition: color .25s var(--ob-ease); }
.obscura a:hover { color: var(--ob-gold-soft); }
.obscura img { max-width: 100%; height: auto; display: block; }
.obscura h1,.obscura h2,.obscura h3,.obscura h4 { font-family: var(--ob-font-display); font-weight: 600; line-height: 1.08; color: var(--ob-cream); margin: 0 0 .5em; letter-spacing: -.01em; }

.ob-wrap { width: min(var(--ob-maxw), 92vw); margin-inline: auto; position: relative; z-index: 1; }
.ob-site-main { position: relative; z-index: 1; }

/* ---- Composants signature ---- */
.ob-kicker {
  display: inline-flex; align-items: center; gap: .55em;
  font-family: var(--ob-font-body); font-weight: 600;
  font-size: .72rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--ob-gold);
}
.ob-kicker::before { content: ""; width: 18px; height: 1px; background: currentColor; opacity: .8; }
.ob-kicker.is-plain::before { display: none; }

.ob-star { display:inline-block; width:1em; height:1em; background: var(--ob-gold); -webkit-mask: var(--ob-star-mask) center/contain no-repeat; mask: var(--ob-star-mask) center/contain no-repeat; vertical-align: middle; }
:root { --ob-star-mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><path d="M50 0 C53 35 65 47 100 50 C65 53 53 65 50 100 C47 65 35 53 0 50 C35 47 47 35 50 0 Z"/></svg>'); }

.ob-hairline { height: 1px; border: 0; background: linear-gradient(90deg, var(--ob-gold) 0%, var(--ob-line) 60%, transparent 100%); margin: 0; }

.ob-section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; margin-bottom: clamp(1.2rem, 3vw, 2.2rem); }
.ob-section-head h2 { font-size: clamp(1.5rem, 3.4vw, 2.4rem); margin: 0; }
.ob-section-head .ob-more { font-size: .78rem; letter-spacing: .16em; text-transform: uppercase; white-space: nowrap; }

.ob-btn {
  display: inline-flex; align-items: center; gap: .6em;
  font-family: var(--ob-font-body); font-weight: 600; font-size: .82rem;
  letter-spacing: .12em; text-transform: uppercase;
  padding: .85em 1.6em; border-radius: 999px;
  border: 1px solid var(--ob-gold); color: var(--ob-gold);
  background: transparent; cursor: pointer;
  transition: all .3s var(--ob-ease);
}
.ob-btn:hover { background: var(--ob-gold); color: var(--ob-ink); }
.ob-btn--solid { background: var(--ob-burgundy); border-color: var(--ob-burgundy); color: #fff; }
.ob-btn--solid:hover { background: var(--ob-burgundy-lt); border-color: var(--ob-burgundy-lt); color: #fff; }

/* =====================================================================
   SKIN DU HEADER / FOOTER BLOCKSY
   On NE remplace pas la structure : Blocksy garde la main (logo, menu,
   recherche, widgets, copyright restent éditables dans le Customizer).
   On applique seulement l'habillage « Obscura » par-dessus.
   ===================================================================== */

/* ---- Header Blocksy ---- */
.obscura .ct-header { border-bottom: 1px solid var(--ob-line); position: relative; z-index: 50; }
.obscura .ct-header::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 1px; background: linear-gradient(90deg, transparent, var(--ob-gold) 40%, var(--ob-gold) 60%, transparent); opacity: .5; }

/* Logo (version claire sur fond sombre, sans cadre) */
.obscura .site-logo-container { display: inline-flex; align-items: center; line-height: 0; }
.obscura .site-logo-container img,
.obscura .site-branding img.default-logo,
.obscura .ct-header .custom-logo { max-height: 48px; width: auto; }

/* Menu principal */
.obscura .ct-header .menu a,
.obscura .header-menu .ct-menu-link {
  font-family: var(--ob-font-body) !important;
  font-size: .76rem; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--ob-cream);
  position: relative;
}
.obscura .ct-header .menu > li > a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -3px; height: 1px; background: var(--ob-gold); transition: right .3s var(--ob-ease); }
.obscura .ct-header .menu > li > a:hover,
.obscura .ct-header .menu > li.current-menu-item > a,
.obscura .ct-header .menu > li.current-cat > a { color: var(--ob-gold-soft); }
.obscura .ct-header .menu > li > a:hover::after,
.obscura .ct-header .menu > li.current-menu-item > a::after { right: 0; }

/* Sous-menus déroulants */
.obscura .ct-header .sub-menu { background: var(--ob-ink-2); border: 1px solid var(--ob-line); }
.obscura .ct-header .sub-menu a { color: var(--ob-cream-dim); }
.obscura .ct-header .sub-menu a:hover { color: var(--ob-gold); }

/* Icône compte injectée dans l'en-tête (à côté de la recherche) */
.obscura .ct-header .ob-account-link { display: inline-grid; place-items: center; width: 38px; height: 38px; margin-right: .5rem; border: 1px solid var(--ob-line); border-radius: 50%; color: var(--ob-cream); transition: all .25s var(--ob-ease); flex: 0 0 auto; }
.obscura .ct-header .ob-account-link:hover { border-color: var(--ob-gold); color: var(--ob-gold); }

/* Icônes recherche / menu mobile */
.obscura .ct-header-search .ct-icon,
.obscura .ct-header-trigger .ct-icon { color: var(--ob-cream); transition: color .25s var(--ob-ease); }
.obscura .ct-header-search:hover .ct-icon,
.obscura .ct-header-trigger:hover .ct-icon { color: var(--ob-gold); }

/* ---- Footer Blocksy ---- */
.obscura .ct-footer { position: relative; border-top: 1px solid var(--ob-line); }
.obscura .ct-footer::before { content: ""; position: absolute; left: 0; right: 0; top: -1px; height: 1px; background: linear-gradient(90deg, transparent, var(--ob-gold) 50%, transparent); opacity: .4; }
.obscura .ct-footer a { color: var(--ob-cream-dim); transition: color .25s var(--ob-ease); }
.obscura .ct-footer a:hover { color: var(--ob-gold); }
.obscura .ct-footer .menu a, .obscura .ct-footer .ct-menu-link { font-family: var(--ob-font-body); }
.obscura .ct-footer-copyright { color: var(--ob-cream-mut); font-family: var(--ob-font-body); font-size: .85rem; }
.obscura .ct-footer h3, .obscura .ct-footer .widget-title, .obscura .ct-footer .ct-widget-title {
  font-family: var(--ob-font-body); font-size: .74rem; letter-spacing: .2em; text-transform: uppercase; color: var(--ob-gold); margin-bottom: 1.1rem;
}

/* Footer riche (widgets Obscura) */
.obscura .ct-footer, .obscura #footer > div { background: var(--ob-ink-2) !important; }
.obscura .ct-footer { overflow: hidden; }
/* La rangée de widgets (créée par code) n'a pas reçu le CSS de colonnes de
   Blocksy : on la passe en grille 4 colonnes nous-mêmes. */
.obscura #footer .ct-container:has(.ct-widget) {
  display: grid;
  grid-template-columns: 1.7fr 1fr 1fr 1.2fr;
  gap: clamp(1.6rem, 3.2vw, 3rem);
  align-items: start;
  padding-block: clamp(2.6rem, 6vw, 4.4rem);
}
.obscura #footer .ct-container:has(.ct-widget) > * { min-width: 0; }
@media (max-width: 880px) { .obscura #footer .ct-container:has(.ct-widget) { grid-template-columns: 1fr 1fr; gap: 2rem; } }
@media (max-width: 480px) { .obscura #footer .ct-container:has(.ct-widget) { grid-template-columns: 1fr; } }
.obscura .ct-footer::after { content: "\2726"; position: absolute; right: 2%; bottom: -6%; font-size: clamp(8rem, 20vw, 16rem); line-height: 1; color: rgba(201,162,90,.04); pointer-events: none; z-index: 0; }
.obscura .ct-footer .ct-footer-widgets, .obscura .ct-footer [data-row="middle"] { position: relative; z-index: 1; }
.obscura .ct-footer .widget { margin: 0; }
.obscura .ct-footer .widget ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .55rem; }
.obscura .ct-footer .widget li { margin: 0; }
.obscura .ct-footer .widget li::before { content: none; }
/* Pot de miel anti-spam du formulaire newsletter (semé par le thème dans le
   footer) : caché ici pour ne pas dépendre du CSS du plugin obscura-community. */
.obscura .oc-hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
.obscura .ob-fbrand { display: inline-block; margin-bottom: 1rem; line-height: 0; }
.obscura .ob-fbrand img { width: 160px; max-height: 46px; object-fit: contain; }
.obscura .ob-fabout { color: var(--ob-cream-dim); font-size: .92rem; max-width: 36ch; margin: 0 0 1rem; }
.obscura .ct-footer .ob-fmenu a, .obscura .ct-footer .widget_categories a { color: var(--ob-cream-dim); font-size: .92rem; }
.obscura .ct-footer .ob-fmenu a:hover, .obscura .ct-footer .widget_categories a:hover { color: var(--ob-gold); }
.obscura .ct-footer .widget_categories li { display: flex; justify-content: space-between; gap: .6rem; }

/* Bouton-icône rond (partage d'article, actions) */
.ob-iconbtn { display: grid; place-items: center; width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--ob-line); color: var(--ob-cream); background: transparent; cursor: pointer; transition: all .25s var(--ob-ease); text-decoration: none; }
.ob-iconbtn:hover { border-color: var(--ob-gold); color: var(--ob-gold); }

/* =====================================================================
   CARTE ARTICLE (réutilisée: home, archive, recherche, liés)
   ===================================================================== */
.ob-card { position: relative; display: flex; flex-direction: column; }
.ob-card__media { position: relative; overflow: hidden; border-radius: var(--ob-radius); aspect-ratio: 16/10; background: var(--ob-ink-3); }
.ob-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ob-ease); }
.ob-card:hover .ob-card__media img { transform: scale(1.06); }
.ob-card__media::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 40%, rgba(14,11,13,.55)); }
.ob-card__noimg { display: grid; place-items: center; width:100%; height:100%; color: rgba(201,162,90,.25); font-family: var(--ob-font-display); font-size: 3rem; }
.ob-card__body { padding: 1rem 0 0; }
.ob-card__cat { --c: var(--ob-gold); color: var(--c); font-size: .68rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; display:inline-flex; align-items:center; gap:.5em; }
.ob-card__cat::before { content:""; width: 8px; height: 8px; background: var(--c); border-radius: 50%; box-shadow: 0 0 0 3px color-mix(in srgb, var(--c) 22%, transparent); }
.ob-card__title { font-family: var(--ob-font-display); font-size: 1.18rem; line-height: 1.2; margin: .55rem 0 .5rem; }
.ob-card__title a { color: var(--ob-cream); background-image: linear-gradient(var(--ob-gold),var(--ob-gold)); background-size: 0 1px; background-repeat: no-repeat; background-position: 0 100%; transition: background-size .35s var(--ob-ease), color .25s; }
.ob-card:hover .ob-card__title a { color: var(--ob-gold-soft); background-size: 100% 1px; }
.ob-card__excerpt { color: var(--ob-cream-dim); font-size: .92rem; margin: 0 0 .7rem; }
.ob-meta { display: flex; align-items: center; gap: .6rem; color: var(--ob-cream-mut); font-size: .76rem; letter-spacing: .02em; }
.ob-meta .ob-star { width: .7em; height: .7em; opacity: .8; }

/* Grille standard */
.ob-grid { display: grid; gap: clamp(1.4rem, 3vw, 2.4rem); grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }

/* Listing archive */
.ob-listing { padding: clamp(2rem, 6vw, 4rem) 0; }
.ob-archive-head { margin-bottom: 2.4rem; }
.ob-archive-head h1 { font-size: clamp(2rem, 5vw, 3.4rem); }
.ob-archive-head p { color: var(--ob-cream-dim); max-width: 60ch; }

/* Chargement infini */
.ob-loadmore { display: flex; flex-direction: column; align-items: center; gap: 1rem; margin-top: 3rem; min-height: 48px; }
.ob-loadmore.is-loading a { opacity: 0; pointer-events: none; }
.ob-loadmore__spin { display: none; width: 28px; height: 28px; border: 2px solid var(--ob-line); border-top-color: var(--ob-gold); border-radius: 50%; animation: ob-spin .7s linear infinite; }
.ob-loadmore.is-loading .ob-loadmore__spin { display: block; position: absolute; }
@keyframes ob-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .ob-loadmore__spin { animation: none; } }

/* Reveal au scroll */
.ob-reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s var(--ob-ease), transform .7s var(--ob-ease); }
.ob-reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){ .ob-reveal{opacity:1;transform:none;transition:none;} html{scroll-behavior:auto;} }

/* Listing vide */
.ob-empty { color: var(--ob-cream-dim); font-family: var(--ob-font-display); font-style: italic; font-size: 1.2rem; padding: 3rem 0; }

/* Corps de page/article — base lisible disponible partout (pas seulement sur single) */
.ob-article__hero.no-img { min-height: auto; }
.ob-article__layout { padding: clamp(2rem, 5vw, 3.4rem) 0; }
.ob-article__body { max-width: 72ch; margin-inline: auto; }
.obscura .entry-content { color: var(--ob-cream); line-height: 1.8; }
.obscura .entry-content a { color: var(--ob-gold); text-decoration: underline; text-underline-offset: 3px; }
.obscura .entry-content h2 { font-size: clamp(1.4rem,3vw,1.9rem); margin: 2rem 0 .8rem; color: var(--ob-cream); }
.obscura .entry-content h3 { color: var(--ob-gold-soft); }
.obscura .entry-content img, .obscura .entry-content figure { border-radius: var(--ob-radius); }
.obscura .entry-content blockquote { border-left: 3px solid var(--ob-gold); padding-left: 1.2rem; font-family: var(--ob-font-display); font-style: italic; color: var(--ob-cream); }

/* =====================================================================
   Pages d'erreur (404) — immersif « dark mystère »
   ===================================================================== */
.ob-error {
  position: relative;
  overflow: hidden;
  min-height: 78vh;
  display: grid;
  place-items: center;
  text-align: center;
  padding: clamp(3rem, 9vw, 7rem) 0;
}
.ob-error__inner { max-width: 640px; }
.ob-error__orb {
  position: absolute; border-radius: 50%; filter: blur(60px); opacity: .5; pointer-events: none; z-index: 0;
  animation: ob-orb 14s var(--ob-ease) infinite alternate;
}
.ob-error__orb--1 { width: 38vw; height: 38vw; top: -8vw; left: -6vw; background: radial-gradient(circle, rgba(138,14,50,.45), transparent 70%); }
.ob-error__orb--2 { width: 32vw; height: 32vw; bottom: -10vw; right: -6vw; background: radial-gradient(circle, rgba(201,162,90,.30), transparent 70%); animation-delay: -7s; }

.ob-error__star {
  display: block; font-size: 2.2rem; color: var(--ob-gold); margin-bottom: .5rem;
  filter: drop-shadow(0 0 16px rgba(201,162,90,.55));
  animation: ob-error-float 6s ease-in-out infinite;
}
.ob-error__code {
  font-family: var(--ob-font-display); font-weight: 700; line-height: .88;
  font-size: clamp(6rem, 26vw, 17rem); letter-spacing: -.03em; margin: .04em 0;
  background: linear-gradient(180deg, var(--ob-cream) 0%, var(--ob-gold) 52%, var(--ob-burgundy) 120%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent;
  filter: drop-shadow(0 10px 48px rgba(201,162,90,.20));
  animation: ob-error-flicker 7s linear infinite;
}
.ob-error__title { font-size: clamp(1.7rem, 4.5vw, 2.6rem); margin: 0 0 .5rem; }
.ob-error__msg { color: var(--ob-cream-dim); font-style: italic; font-size: 1.15rem; margin: 0 auto 2rem; max-width: 32em; }

.ob-error__search {
  display: flex; align-items: center; gap: .4rem;
  width: min(440px, 90%); margin: 0 auto 1.6rem;
  background: var(--ob-ink-2); border: 1px solid var(--ob-line);
  border-radius: 999px; padding: .35rem .35rem .35rem 1.2rem;
  transition: border-color .25s var(--ob-ease), box-shadow .25s var(--ob-ease);
}
.ob-error__search:focus-within { border-color: var(--ob-gold); box-shadow: 0 0 0 4px rgba(201,162,90,.12); }
.ob-error__search input {
  flex: 1; background: none; border: 0; outline: none;
  color: var(--ob-cream); font-family: var(--ob-font-body); font-size: 1rem; padding: .5rem 0;
}
.ob-error__search input::placeholder { color: var(--ob-cream-mut); }
.ob-error__search button {
  display: grid; place-items: center; width: 42px; height: 42px; flex: 0 0 auto;
  border: 0; border-radius: 50%; cursor: pointer; color: var(--ob-ink);
  background: linear-gradient(180deg, var(--ob-gold), #b88f45);
  transition: transform .2s var(--ob-ease);
}
.ob-error__search button:hover { transform: scale(1.06); }

.ob-error__actions { margin-bottom: 2.4rem; }

.ob-error__cats-label {
  display: block; font-size: .72rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--ob-cream-mut); margin-bottom: .9rem;
}
.ob-error__chips { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; }
.ob-error__chip {
  font-size: .85rem; color: var(--ob-cream-dim); text-decoration: none;
  padding: .4em 1em; border: 1px solid var(--ob-line); border-radius: 999px;
  transition: color .2s var(--ob-ease), border-color .2s var(--ob-ease), background .2s var(--ob-ease);
}
.ob-error__chip:hover { color: var(--ob-gold-soft); border-color: var(--ob-line-soft); background: rgba(201,162,90,.06); }

@keyframes ob-orb { from { transform: translate(0,0) scale(1); } to { transform: translate(2vw,3vw) scale(1.08); } }
@keyframes ob-error-float { 0%,100% { transform: translateY(0) rotate(0); } 50% { transform: translateY(-9px) rotate(10deg); } }
@keyframes ob-error-flicker { 0%,100%{opacity:1;} 48%{opacity:1;} 50%{opacity:.8;} 52%{opacity:1;} 92%{opacity:1;} 94%{opacity:.86;} }
@media (prefers-reduced-motion: reduce) {
  .ob-error__orb, .ob-error__star, .ob-error__code { animation: none; }
}
