/* Bandeau prévisualisation admin */
.theme-preview-banner {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding: 0.55rem 1rem;
  padding-top: calc(0.55rem + var(--safe-top));
  background: var(--color-accent);
  color: #fff;
  font-size: 0.85rem;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
}

.theme-preview-banner strong {
  font-weight: 600;
}

.theme-preview-banner-exit {
  color: #fff;
  text-decoration: underline;
  font-weight: 500;
  white-space: nowrap;
}

body.has-theme-preview {
  padding-top: calc(2.5rem + var(--safe-top));
}

body.has-theme-preview .site-header {
  top: calc(2.5rem + var(--safe-top));
}

/* Thèmes sombres — lisibilité */
html[data-theme-dark="1"] body,
html[data-theme="ramadan"] body,
html[data-theme="nouvel_an"] body {
  background: var(--color-cream);
  color: var(--color-earth);
}

html[data-theme-dark="1"] .site-header,
html[data-theme="ramadan"] .site-header,
html[data-theme="nouvel_an"] .site-header {
  background: color-mix(in srgb, var(--color-cream) 94%, transparent);
  border-bottom: 1px solid var(--color-border);
}

html[data-theme-dark="1"] .nav a,
html[data-theme="ramadan"] .nav a,
html[data-theme="nouvel_an"] .nav a {
  color: var(--color-earth);
}

html[data-theme-dark="1"] .nav a:hover,
html[data-theme="ramadan"] .nav a:hover,
html[data-theme="nouvel_an"] .nav a:hover {
  color: var(--color-gold);
}

html[data-theme-dark="1"] .logo-main,
html[data-theme="ramadan"] .logo-main,
html[data-theme="nouvel_an"] .logo-main {
  color: var(--color-earth);
}

html[data-theme-dark="1"] .apartment-card,
html[data-theme="ramadan"] .apartment-card,
html[data-theme="nouvel_an"] .apartment-card,
html[data-theme-dark="1"] .review-card,
html[data-theme="ramadan"] .review-card,
html[data-theme="nouvel_an"] .review-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

html[data-theme-dark="1"] .apartment-body,
html[data-theme="ramadan"] .apartment-body,
html[data-theme="nouvel_an"] .apartment-body {
  color: var(--color-earth);
}

html[data-theme-dark="1"] .faq-list details,
html[data-theme="ramadan"] .faq-list details,
html[data-theme="nouvel_an"] .faq-list details {
  background: var(--color-surface);
  border-color: var(--color-border);
}

html[data-theme-dark="1"] .faq-list details p,
html[data-theme="ramadan"] .faq-list details p,
html[data-theme="nouvel_an"] .faq-list details p {
  color: var(--color-earth);
  opacity: 0.92;
}

html[data-theme-dark="1"] .faq-section,
html[data-theme="ramadan"] .faq-section,
html[data-theme="nouvel_an"] .faq-section {
  background: linear-gradient(180deg, var(--color-cream) 0%, var(--color-sand) 100%);
}

html[data-theme-dark="1"] .section-header p,
html[data-theme="ramadan"] .section-header p,
html[data-theme="nouvel_an"] .section-header p {
  color: var(--color-text-muted);
}

html[data-theme-dark="1"] .site-footer,
html[data-theme="ramadan"] .site-footer,
html[data-theme="nouvel_an"] .site-footer {
  background: var(--color-sand);
  color: var(--color-earth);
}

html[data-theme-dark="1"] .btn-primary,
html[data-theme="ramadan"] .btn-primary,
html[data-theme="nouvel_an"] .btn-primary {
  background: var(--color-gold);
  color: #1a1830;
  border-color: var(--color-gold);
}

html[data-theme-dark="1"] .btn-outline,
html[data-theme="ramadan"] .btn-outline,
html[data-theme="nouvel_an"] .btn-outline {
  color: var(--color-earth);
  border-color: var(--color-gold);
}

html[data-theme-dark="1"] .hero .btn-outline,
html[data-theme="ramadan"] .hero .btn-outline,
html[data-theme="nouvel_an"] .hero .btn-outline {
  color: var(--color-earth);
  border-color: rgba(255, 255, 255, 0.5);
}

/* Thèmes publics — décorations par data-theme */

html[data-theme="ete"] .hero-bg::after {
  background: linear-gradient(135deg, rgba(26, 122, 170, 0.25) 0%, rgba(232, 184, 74, 0.2) 100%);
}

html[data-theme="hiver"] .hero-bg::after {
  background: linear-gradient(135deg, rgba(42, 80, 128, 0.3) 0%, rgba(200, 220, 240, 0.15) 100%);
}

html[data-theme="printemps"] .hero-tag {
  color: var(--color-accent);
}

html[data-theme="ramadan"] .hero {
  color: var(--color-earth);
}

html[data-theme="ramadan"] .hero-bg::after {
  background: linear-gradient(160deg, rgba(74, 58, 122, 0.5) 0%, rgba(26, 24, 48, 0.7) 100%);
}

html[data-theme="ramadan"] .site-header {
  background: color-mix(in srgb, var(--color-cream) 92%, transparent);
}

html[data-theme="aid_fitr"] .hero-tag,
html[data-theme="aid_adha"] .hero-tag {
  letter-spacing: 0.08em;
}

html[data-theme="noel"] .btn-primary {
  box-shadow: 0 4px 16px color-mix(in srgb, var(--color-accent) 35%, transparent);
}

html[data-theme="nouvel_an"] .hero h1 em {
  color: var(--color-gold);
}

html[data-theme="fete_trone"] .logo-main,
html[data-theme="independence"] .logo-main {
  background: linear-gradient(90deg, var(--color-sage-dark), var(--color-accent));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme="saint_valentin"] .section-title em {
  color: var(--color-accent);
}

html[data-theme="automne"] .hero-bg::after {
  background: linear-gradient(135deg, rgba(122, 82, 48, 0.35) 0%, rgba(196, 120, 64, 0.2) 100%);
}

html[data-theme="mawlid"] .hero-tag::before {
  content: '✦ ';
  color: var(--color-gold);
}

.theme-serenity .hero-bg,
.theme-ete .hero-bg,
.theme-hiver .hero-bg,
.theme-printemps .hero-bg,
.theme-automne .hero-bg,
.theme-ramadan .hero-bg {
  position: relative;
}

.theme-serenity .hero-bg::after,
.theme-ete .hero-bg::after,
.theme-hiver .hero-bg::after,
.theme-printemps .hero-bg::after,
.theme-automne .hero-bg::after,
.theme-ramadan .hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
}
