/*
Theme Name: Portail Anne-Sophie Pau
Theme URI: https://annesophiepau.com
Author: Anne-Sophie Pau
Description: Thème sur mesure - Hub de contenu spirituel avec portail 3 colonnes
Version: 1.0
*/

/* =============================================
   VARIABLES & RESET
============================================= */
:root {
  --rose:      #D4A5A5;
  --beige:     #F5EBE0;
  --fond:      #EDE5DB;
  --bleu-nuit: #2C3E50;
  --or:        #C5A059;
  --blanc:     #FFFFFF;
  --bordure:   #D8CCBE;
  --texte:     #444444;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Lato', 'Open Sans', sans-serif;
  background: var(--fond);
  color: var(--texte);
  font-size: 14px;
  line-height: 1.6;
}

a { color: var(--bleu-nuit); text-decoration: none; }
a:hover { color: var(--or); }
img { max-width: 100%; height: auto; display: block; }
h1, h2, h3, h4, h5 {
  font-family: 'Georgia', serif;
  color: var(--bleu-nuit);
  line-height: 1.3;
}

/* =============================================
   HEADER
============================================= */
#site-header {
  background: var(--bleu-nuit);
  border-bottom: 3px solid var(--or);
  padding: 0 24px;
}
.header-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 52px;
}
.site-name { font-family: 'Georgia', serif; font-size: 20px; color: #FFF; font-weight: 700; }
.site-tagline { font-size: 11px; color: var(--rose); letter-spacing: 1px; }
#site-nav ul { list-style: none; display: flex; gap: 20px; }
#site-nav ul li a { font-size: 12px; color: #8A9BAB; transition: color 0.2s; }
#site-nav ul li a:hover, #site-nav ul li.current-menu-item a { color: var(--or); }

/* =============================================
   LAYOUT - 3 COLONNES
============================================= */
#page-wrapper {
  max-width: 1100px;
  margin: 0 auto;
  padding: 16px;
  display: grid;
  grid-template-columns: 200px 1fr 260px;
  gap: 14px;
  align-items: start;
}

/* =============================================
   WIDGETS (boîtes communes)
============================================= */
.widget-box {
  background: var(--blanc);
  border-radius: 6px;
  border: 1px solid var(--bordure);
  overflow: hidden;
  margin-bottom: 12px;
}
.widget-title {
  background: var(--bleu-nuit);
  padding: 8px 12px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.5px;
  color: var(--or);
  text-transform: uppercase;
  font-family: 'Lato', sans-serif;
}
.widget-body { padding: 12px; }

/* Nav gauche */
.widget-box ul { list-style: none; }
.widget-box ul li a {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px; font-size: 12px; color: #666;
  border-bottom: 1px solid var(--fond);
  border-left: 3px solid transparent;
  transition: all 0.15s;
}
.widget-box ul li a:hover,
.widget-box ul li.current-menu-item a {
  background: var(--beige); border-left-color: var(--or);
  color: var(--bleu-nuit); font-weight: 700;
}

/* Widget dernière transmission */
.widget-last-transmission {
  background: var(--bleu-nuit);
  border: 1px solid rgba(197,160,89,0.4);
  border-radius: 6px;
  margin-bottom: 12px;
  overflow: hidden;
}
.widget-last-transmission .widget-title {
  background: transparent;
  border-bottom: 1px solid rgba(197,160,89,0.2);
  display: flex; align-items: center; gap: 6px;
}
.live-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #e74c3c; box-shadow: 0 0 5px #e74c3c;
}
.transmission-type-label { font-size: 9px; color: var(--rose); font-weight: 700; margin-bottom: 5px; }
.last-transmission-title {
  font-family: 'Georgia', serif; font-size: 12px;
  color: var(--blanc); line-height: 1.4; margin-bottom: 8px;
}
.btn-listen {
  display: block; text-align: center;
  background: transparent; color: var(--or);
  border: 1px solid rgba(197,160,89,0.4);
  border-radius: 3px; padding: 5px 10px;
  font-size: 10px; font-weight: 700;
}

/* Citation */
.widget-citation {
  background: var(--blanc);
  border-left: 3px solid var(--rose);
  border-radius: 6px;
  padding: 14px;
}
.widget-citation blockquote {
  font-family: 'Georgia', serif; font-size: 12px;
  color: var(--bleu-nuit); line-height: 1.7; font-style: italic; margin-bottom: 8px;
}
.widget-citation cite { font-size: 10px; color: var(--or); font-weight: 700; font-style: normal; }

/* =============================================
   CONTENU CENTRAL
============================================= */
.content-main { min-width: 0; }
.content-box {
  background: var(--blanc);
  border-radius: 6px;
  border: 1px solid var(--bordure);
  overflow: hidden;
  margin-bottom: 14px;
}
.content-box-header {
  background: linear-gradient(90deg, var(--bleu-nuit), #3d5166);
  padding: 10px 16px;
  display: flex; align-items: center; justify-content: space-between;
}
.content-box-header .section-title { font-size: 13px; font-weight: 700; color: #FFF; font-family: 'Georgia', serif; }
.content-box-header .section-subtitle { font-size: 10px; color: #8A9BAB; }
.content-box-body { padding: 16px; }

/* Transmissions */
.transmission-item {
  display: flex; gap: 12px; align-items: flex-start;
  padding-bottom: 16px; margin-bottom: 16px;
  border-bottom: 1px solid var(--fond);
}
.transmission-item:last-child { border-bottom: none; padding-bottom: 0; margin-bottom: 0; }
.transmission-icon {
  width: 34px; height: 34px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 16px;
}
.transmission-icon.audio { background: rgba(212,165,165,0.2); }
.transmission-icon.video { background: rgba(44,62,80,0.12); }
.transmission-icon.texte { background: rgba(197,160,89,0.15); }
.transmission-icon.photo { background: rgba(100,150,120,0.15); }

.badge-new {
  background: var(--or); color: #FFF;
  font-size: 8px; font-weight: 800; letter-spacing: 1.5px;
  padding: 2px 6px; border-radius: 3px; text-transform: uppercase;
}
.transmission-date { font-size: 11px; color: #AAA; }
.transmission-duration { font-size: 11px; color: var(--rose); }
.transmission-title {
  font-family: 'Georgia', serif; font-size: 14px;
  font-weight: 600; color: var(--bleu-nuit);
  margin-bottom: 4px; line-height: 1.4;
}
.transmission-excerpt { font-size: 12px; color: #888; margin-bottom: 8px; line-height: 1.5; }

.btn-play {
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--beige); color: var(--bleu-nuit);
  border-radius: 14px; padding: 5px 12px;
  font-size: 11px; font-weight: 600; cursor: pointer;
}
.btn-play:hover { background: var(--bleu-nuit); color: #FFF; }

/* Instants - grille photos */
.instants-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.instant-item { aspect-ratio: 1; border-radius: 6px; overflow: hidden; position: relative; }
.instant-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.instant-item:hover img { transform: scale(1.04); }
.instant-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(44,62,80,0.75) 0%, transparent 50%);
  display: flex; flex-direction: column; justify-content: flex-end; padding: 8px;
}
.instant-lieu { font-size: 8px; color: var(--or); font-weight: 700; margin-bottom: 2px; }
.instant-date-label { font-size: 9px; color: rgba(255,255,255,0.8); }

/* Articles (single) */
.article-content { font-size: 15px; line-height: 1.8; color: var(--texte); }
.article-content h2 { font-size: 20px; margin: 28px 0 12px; }
.article-content p { margin-bottom: 16px; }
.article-content blockquote {
  border-left: 3px solid var(--rose);
  padding: 12px 18px; margin: 20px 0;
  background: var(--beige); border-radius: 0 6px 6px 0;
  font-family: 'Georgia', serif; font-style: italic; color: var(--bleu-nuit);
}
.article-cat {
  display: inline-block; font-size: 9px; font-weight: 800;
  letter-spacing: 1.5px; text-transform: uppercase;
  padding: 3px 10px; border-radius: 3px; margin-bottom: 10px;
  background: rgba(212,165,165,0.2); color: var(--rose);
  border: 1px solid rgba(212,165,165,0.4);
}
.article-title-single { font-size: 26px; margin-bottom: 10px; }
.article-meta { font-size: 11px; color: #AAA; display: flex; gap: 12px; }

/* Lead magnet */
.widget-leadmagnet {
  background: linear-gradient(150deg, var(--bleu-nuit), #1a252f);
  border: 1px solid rgba(197,160,89,0.35);
  border-radius: 6px; padding: 16px; margin-bottom: 12px;
}
.widget-leadmagnet .eyebrow {
  font-size: 9px; font-weight: 800; letter-spacing: 2px;
  text-transform: uppercase; color: var(--or); margin-bottom: 6px;
}
.widget-leadmagnet h3 { font-size: 15px; color: #FFF; margin-bottom: 8px; line-height: 1.4; }
.widget-leadmagnet p { font-size: 11px; color: #BDB0A8; margin-bottom: 12px; line-height: 1.6; }

.btn-primary {
  display: block; width: 100%; text-align: center;
  background: var(--or); color: #FFF;
  border: none; border-radius: 4px;
  padding: 9px; font-size: 12px; font-weight: 700; cursor: pointer;
}
.btn-primary:hover { background: #b8904f; color: #FFF; }
.no-spam { font-size: 9px; color: #7A6A60; text-align: center; margin-top: 6px; }

/* Newsletter */
.widget-newsletter input[type="email"] {
  width: 100%; padding: 7px 10px; border-radius: 4px;
  border: 1px solid var(--bordure); font-size: 11px; margin-bottom: 6px;
  outline: none; font-family: inherit;
}
.widget-newsletter input[type="email"]:focus { border-color: var(--or); }

/* Stats */
.stats-list { list-style: none; padding: 12px; }
.stats-list li {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 7px; margin-bottom: 7px;
  border-bottom: 1px solid var(--fond);
  font-size: 11px; color: #666;
}
.stats-list li:last-child { border-bottom: none; padding-bottom: 0; margin-bottom: 0; }
.stats-list li strong { font-size: 13px; color: var(--bleu-nuit); }

/* Footer */
#site-footer {
  background: var(--bleu-nuit); color: #5A6A7A;
  text-align: center; padding: 14px; font-size: 10px;
  border-top: 2px solid rgba(197,160,89,0.35); margin-top: 8px;
}

/* Responsive */
@media (max-width: 900px) {
  #page-wrapper { grid-template-columns: 1fr; }
  .sidebar-left { display: none; }
}
@media (max-width: 600px) {
  .instants-grid { grid-template-columns: repeat(2, 1fr); }
}

/* =============================================
   AJOUT À COLLER À LA FIN DE style.css
   Correction header : nom + tagline sur une ligne
   + "Auteure · Catéchumène" à droite
============================================= */

/* Header - branding sur une ligne */
.site-branding-link {
  display: flex;
  align-items: baseline;
  gap: 8px;
  text-decoration: none;
}

.site-name {
  font-family: 'Georgia', serif;
  font-size: 20px;
  color: var(--blanc);
  font-weight: 700;
}

.site-separator {
  color: var(--rose);
  font-size: 16px;
}

.site-tagline {
  font-size: 12px;
  color: var(--rose);
  letter-spacing: 0.5px;
}

/* Header droite : statut + nav */
.header-right {
  display: flex;
  align-items: center;
  gap: 20px;
}

.site-statut {
  font-size: 11px;
  color: #8A9BAB;
  letter-spacing: 0.5px;
  white-space: nowrap;
}

/* Responsive header */
@media (max-width: 768px) {
  .site-statut { display: none; }
  .site-tagline { display: none; }
  .site-separator { display: none; }
}


/* =============================================
   STYLE DES WIDGETS NATIFS WORDPRESS
   À coller à la fin de style.css
============================================= */

/* Boîte widget */
.sidebar-left .widget,
.sidebar-right .widget {
  background: var(--blanc);
  border-radius: 6px;
  border: 1px solid var(--bordure);
  overflow: hidden;
  margin-bottom: 12px;
}

/* Titre du widget */
.sidebar-left .widget .widget-title,
.sidebar-left .widget .widgettitle,
.sidebar-right .widget .widgettitle {
  background: var(--bleu-nuit);
  padding: 8px 12px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.5px;
  color: var(--or);
  text-transform: uppercase;
  font-family: 'Lato', sans-serif;
  margin: 0;
  display: block;
}

/* Listes dans les widgets (catégories, navigation, etc.) */
.sidebar-left .widget ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.sidebar-left .widget ul li {
  list-style: none;
  border-bottom: 1px solid var(--fond);
}

.sidebar-left .widget ul li:last-child {
  border-bottom: none;
}

.sidebar-left .widget ul li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 12px;
  font-size: 12px;
  color: #666;
  border-left: 3px solid transparent;
  transition: all 0.15s;
  font-family: 'Lato', sans-serif;
}

.sidebar-left .widget ul li a:hover,
.sidebar-left .widget ul li.current-menu-item > a,
.sidebar-left .widget ul li.current-cat > a {
  background: var(--beige);
  border-left-color: var(--or);
  color: var(--bleu-nuit);
  font-weight: 700;
}

/* Barre de recherche */
.sidebar-left .widget_search .search-form {
  padding: 10px 12px;
  display: flex;
  gap: 6px;
}

.sidebar-left .widget_search input[type="search"] {
  flex: 1;
  padding: 6px 10px;
  border: 1px solid var(--bordure);
  border-radius: 4px;
  font-size: 11px;
  outline: none;
}

.sidebar-left .widget_search input[type="submit"] {
  padding: 6px 12px;
  background: var(--bleu-nuit);
  color: var(--blanc);
  border: none;
  border-radius: 4px;
  font-size: 11px;
  cursor: pointer;
}

/* Widget texte / HTML personnalisé (pour la citation) */
.sidebar-left .widget_text .textwidget,
.sidebar-left .widget_custom_html .custom-html-widget {
  padding: 14px;
}

/* Colonne droite : titre des widgets */
.sidebar-right .widget .widgettitle {
  background: var(--bleu-nuit);
  padding: 8px 12px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.5px;
  color: var(--or);
  text-transform: uppercase;
  font-family: 'Lato', sans-serif;
  margin: 0;
  display: block;
}

.sidebar-right .widget .textwidget,
.sidebar-right .widget .custom-html-widget {
  padding: 12px;
  font-size: 11px;
  color: #666;
  line-height: 1.6;
}

