/* =========================================
   PAGES INTÉRIEURES — Hero, Contact, Concept
   L'Instant Plaisir · v4.0
   À charger APRÈS global.css et home.css
========================================= */

/* ── MINI HERO (pages intérieures) ── */
.page-hero-luxe {
  position: relative;
  height: 40vh;
  min-height: 280px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(139, 21, 96, 0.35), transparent 60%),
    var(--color-bg2);
}

.page-hero-luxe .hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom,
      rgba(18, 8, 24, 0.55) 0%,
      rgba(92, 10, 62, 0.25) 50%,
      rgba(18, 8, 24, 0.95) 100%);
}

.page-hero-content {
  position: relative;
  z-index: 5;
  padding: 0 20px;
  animation: reveal-up 0.9s ease both;
}

.page-hero-content h1 {
  font-family: var(--font-display) !important;
  font-size: clamp(38px, 6vw, 64px) !important;
  font-weight: 300 !important;
  line-height: 1 !important;
  color: #fff !important;
  text-transform: uppercase;
  margin-bottom: 0 !important;
}

/* Fallback si reveal-up n'existe pas ailleurs */
@keyframes reveal-up {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── TITRE AVEC LIGNE DORÉE ── */
.title-with-line {
  position: relative;
  padding-bottom: 18px;
  margin-bottom: 34px !important;
  font-family: var(--font-display);
  font-weight: 400 !important;
}
.title-with-line::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 70px;
  height: 2px;
  background: linear-gradient(90deg, var(--color-gold), transparent);
}

/* =========================================
   PAGE CONTACT
========================================= */
.contact-section { background: var(--color-bg); }

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 70px;
  align-items: start;
}

.contact-intro p {
  margin-bottom: 18px;
  color: var(--text-soft);
  font-size: 15px;
}

.contact-details-list {
  list-style: none;
  margin-top: 36px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.contact-details-list li,
.contact-details-list a {
  display: flex;
  align-items: center;
  gap: 14px;
  color: var(--text);
  font-family: var(--font-serif);
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
  transition: var(--transition);
}

.contact-details-list a:hover { color: var(--color-gold); }

.contact-details-list i {
  color: var(--color-gold);
  width: 20px;
  text-align: center;
  font-size: 15px;
}

.contact-form-wrap {
  background: var(--color-card);
  border: 0.5px solid rgba(200, 160, 74, 0.12);
  border-radius: var(--radius-soft);
  padding: 44px;
}

.contact-form-luxe .form-group {
  margin-bottom: 24px;
}

.contact-form-luxe label {
  display: block;
  font-family: var(--font-serif);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: 10px;
}

.contact-form-luxe input,
.contact-form-luxe textarea {
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.contact-form-luxe textarea { resize: vertical; }

.contact-form-luxe .btn-gold-full {
  width: 100%;
  text-align: center;
  border: 1px solid var(--color-gold);
  cursor: pointer;
}

.contact-form-success,
.contact-form-error {
  padding: 20px 24px;
  border-radius: var(--radius);
  font-size: 14px;
  margin-bottom: 24px;
}

.contact-form-success {
  background: rgba(200, 160, 74, 0.1);
  border: 1px solid var(--color-gold);
  color: var(--color-gold-light);
}

.contact-form-error {
  background: rgba(139, 21, 96, 0.12);
  border: 1px solid var(--color-primary);
  color: var(--color-accent);
}

/* =========================================
   PAGE LE CONCEPT
========================================= */
.concept-section { background: var(--color-bg); }

.concept-grid { max-width: 900px; margin: 0 auto; }

.concept-text p {
  margin-bottom: 22px;
  color: var(--text-soft);
  font-size: 15px;
}

.concept-subtitle {
  font-family: var(--font-display) !important;
  font-size: 26px !important;
  color: var(--color-gold) !important;
  margin: 40px 0 24px !important;
}

.concept-included-list {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px 30px;
  margin-bottom: 46px;
}

.concept-included-list li {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--text);
  font-size: 14px;
}

.concept-included-list i {
  color: var(--color-gold);
  font-size: 13px;
}

/* ── SUGGESTIONS PRODUITS (WooCommerce) ── */
.concept-shop-section {
  background: var(--color-bg2);
  padding: 20px 0;
}

.concept-shop-title { text-align: center; }
.concept-shop-title::after { left: 50%; transform: translateX(-50%); }

.concept-shop-subtitle {
  text-align: center;
  color: var(--text-soft);
  font-size: 14px;
  font-style: italic;
  margin-bottom: 44px;
}

.concept-shop-section ul.products {
  display: grid;
  gap: 26px;
  list-style: none;
}
.concept-shop-section ul.products.columns-4 { grid-template-columns: repeat(4, 1fr); }
.concept-shop-section ul.products.columns-5 { grid-template-columns: repeat(5, 1fr); }

.concept-shop-section ul.products li.product {
  background: var(--color-card);
  border: 0.5px solid rgba(200, 160, 74, 0.1);
  border-radius: var(--radius);
  padding: 20px;
  text-align: center;
  transition: var(--transition);
}
.concept-shop-section ul.products li.product:hover {
  border-color: rgba(200, 160, 74, 0.35);
  transform: translateY(-3px);
}

.concept-shop-section img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: var(--radius);
  margin-bottom: 14px;
}

.concept-shop-section .woocommerce-loop-product__title {
  font-size: 16px !important;
  color: var(--text) !important;
  margin-bottom: 8px;
}

.concept-shop-section .price {
  color: var(--color-gold);
  font-family: var(--font-serif);
  font-size: 13px;
  display: block;
  margin-bottom: 16px;
}

.concept-cta {
  text-align: center;
  padding: 70px 20px;
}

/* =========================================
   RESPONSIVE
========================================= */
@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr; gap: 44px; }
  .contact-form-wrap { padding: 30px; }
  .concept-included-list { grid-template-columns: 1fr; }
  .concept-shop-section ul.products.columns-4,
  .concept-shop-section ul.products.columns-5 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .concept-shop-section ul.products.columns-4,
  .concept-shop-section ul.products.columns-5 { grid-template-columns: 1fr; }
}