/* =============================================
   KIZA — tiandao.css
   ============================================= */

/* ── HERO ── */
.tiandao-hero {
  padding: 130px 52px 80px;
  position: relative; overflow: hidden;
}
.tiandao-hero .page-hero-bg { position: absolute; inset: 0; z-index: 0; }

.hero-tiandao-wrap {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 56px;
  align-items: center;
  position: relative; z-index: 2;
  max-width: 1100px;
}
.hero-tiandao-text { display: flex; flex-direction: column; }
.hero-logo-col {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.tiandao-logo-hero {
  width: 460px;
  height: auto;
  display: block;
}
.tiandao-hero-actions {
  display: flex; gap: 14px; flex-wrap: wrap; margin-top: 32px;
}

/* ── STATS BAND ── */
.stats-band-num { font-size: 1.9rem; }

/* ── SPONSORING NOTE ── */
.sponso-note {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 12px 14px;
  background: rgba(46,122,80,0.06);
  border-left: 2px solid rgba(46,122,80,0.3);
  margin-top: 4px;
}
.sponso-note svg { width: 16px; height: 16px; flex-shrink: 0; color: var(--accent,#2E7A50); margin-top: 2px; }
.sponso-note p { font-size: 0.82rem; color: var(--muted,#6A9278); line-height: 1.6; font-style: italic; margin: 0; }

/* ── OFFRE GRID ── */
.offre-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2px;
}

/* Sponsoring card: spacer between desc and accordions */
.offre-desc-noflex { flex: 0 !important; }
.offre-spacer { flex: 1; }


.offre-card {
  background: var(--bg);
  padding: 40px 36px 36px;
  display: flex; flex-direction: column;
  border-top: 3px solid transparent;
  transition: border-color 0.25s, background 0.25s;
}
.offre-card:nth-child(even) { background: var(--bg-mid); }
.offre-card:hover { border-top-color: var(--accent, #2E7A50); background: rgba(46,122,80,0.04); }

.offre-card-header {
  display: flex; align-items: flex-start; gap: 16px; margin-bottom: 16px;
}
.offre-icon {
  width: 44px; height: 44px; flex-shrink: 0;
  color: var(--accent, #2E7A50); margin-top: 4px;
  opacity: 0.85;
}
.offre-icon svg {
  width: 100%; height: 100%;
  stroke: var(--accent, #2E7A50);
}
/* Stroke-only icons */
.offre-icon svg path, .offre-icon svg rect, .offre-icon svg circle,
.offre-icon svg line, .offre-icon svg polyline, .offre-icon svg polygon {
  stroke-width: 1.5;
  vector-effect: non-scaling-stroke;
}
/* Fill icons (run) */
.offre-icon svg[fill="currentColor"] path {
  fill: var(--accent, #2E7A50);
  stroke: none;
}

.offre-tag {
  display: block; font-family: 'Space Mono', monospace;
  font-size: 0.59rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--accent, #2E7A50); margin-bottom: 5px;
}
.offre-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.3rem; font-weight: 700;
  color: var(--navy, #152B1E); line-height: 1.2;
}
.badge-nouveau {
  display: inline-block;
  font-family: 'Space Mono', monospace;
  font-size: 0.52rem; letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--accent, #2E7A50); color: #fff;
  padding: 2px 7px; vertical-align: middle;
  margin-left: 8px; position: relative; top: -2px;
}

.offre-desc {
  font-size: 0.88rem; color: var(--slate, #3D6050);
  line-height: 1.7; margin-bottom: 20px;
}

/* ── ACCORDION BUTTONS ── */
.offre-accordion-btn {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; margin-top: 6px;
  background: rgba(46,122,80,0.06); border: 1px solid rgba(46,122,80,0.18);
  cursor: pointer; text-align: left;
  transition: background 0.2s;
  font-family: 'Space Mono', monospace; font-size: 0.7rem;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--navy, #152B1E);
}
.offre-accordion-btn:hover { background: rgba(46,122,80,0.1); }
.offre-accordion-btn.open { background: rgba(46,122,80,0.1); border-bottom: none; }

.offre-acc-chevron {
  width: 11px; height: 11px; color: var(--accent, #2E7A50); flex-shrink: 0;
  transition: transform 0.25s ease;
}
.offre-accordion-btn.open .offre-acc-chevron { transform: rotate(180deg); }

.pack-badge {
  font-size: 0.52rem; color: var(--muted, #6A9278);
  font-style: italic; text-transform: none; letter-spacing: 0;
}

/* ── ACCORDION BODY ── */
.offre-accordion-body {
  overflow: hidden; max-height: 0;
  transition: max-height 0.35s ease;
  background: rgba(46,122,80,0.04);
  border: 1px solid rgba(46,122,80,0.18); border-top: none;
  margin-bottom: 2px;
}
.offre-accordion-body.open { max-height: 800px; }

/* ── PRICE TABLE ── */
.prix-table {
  width: 100%; border-collapse: collapse; padding: 0;
}
.prix-table tbody { display: block; padding: 16px 16px 0; width: 100%; }
.prix-table tbody tr {
  display: grid;
  grid-template-columns: 1fr auto auto;
  border-bottom: 1px solid rgba(46,122,80,0.1);
  align-items: center;
}
.prix-table td {
  padding: 9px 4px; font-size: 0.87rem; color: var(--navy, #152B1E);
}
.prix-duration {
  color: var(--muted, #6A9278);
  font-family: 'Space Mono', monospace; font-size: 0.72rem;
  text-align: center; white-space: nowrap; padding: 0 12px;
}
.prix-price {
  text-align: right; font-weight: 500; white-space: nowrap;
  font-family: 'Space Mono', monospace; font-size: 0.82rem;
  color: var(--accent, #2E7A50);
}
.prix-old {
  text-decoration: line-through;
  color: var(--muted, #6A9278); font-size: 0.72rem;
  margin-left: 4px;
}
.prix-carte td { background: rgba(46,122,80,0.07); }
.prix-rabais td { color: var(--accent, #2E7A50); font-weight: 500; }

/* Carte 3 massages — featured row */
.prix-carte-featured td { padding: 0; background: transparent; }
.carte-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  background: linear-gradient(135deg, rgba(46,122,80,0.12) 0%, rgba(46,122,80,0.06) 100%);
  border-left: 3px solid var(--accent, #2E7A50);
  border-right: 1px solid rgba(46,122,80,0.2);
  width: calc(100% - 32px);
  margin: 6px 0;
}
.carte-label {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 0.92rem; font-weight: 700;
  color: var(--navy, #152B1E); flex: 1;
}
.carte-discount {
  font-family: 'Space Mono', monospace; font-size: 0.7rem;
  font-weight: 700; color: #fff;
  background: var(--accent, #2E7A50);
  padding: 3px 8px; white-space: nowrap;
}
.carte-price {
  font-family: 'Space Mono', monospace; font-size: 0.88rem;
  font-weight: 700; color: var(--accent, #2E7A50);
  white-space: nowrap; text-align: right;
}

/* ── OFFRES SPÉCIALES ── */
.prix-offres { padding: 14px 16px 0; }
.prix-offres-title {
  font-family: 'Space Mono', monospace; font-size: 0.6rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--muted, #6A9278); margin-bottom: 8px;
}
.prix-offre-item {
  display: flex; justify-content: space-between;
  font-size: 0.84rem; color: var(--navy, #152B1E);
  padding: 5px 0; border-bottom: 1px solid rgba(46,122,80,0.08);
}
.prix-offre-item .prix-price { color: var(--accent, #2E7A50); }

/* ── NOTES ── */
.prix-note {
  font-size: 0.72rem; color: var(--muted, #6A9278);
  font-style: italic; padding: 10px 16px 0; line-height: 1.5;
}

/* ── PACK OPTION BLOCK (inside accordion, below main content) ── */
.pack-option-block {
  margin: 0 16px 12px;
  border-top: 2px dashed rgba(46,122,80,0.25);
  padding-top: 16px;
}
.pack-option-header {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: 'Space Mono', monospace;
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent, #2E7A50);
  margin-bottom: 14px;
}
.pack-option-header svg {
  width: 14px; height: 14px; flex-shrink: 0;
}
.pack-tarif-box-option {
  background: rgba(46,122,80,0.04);
  border-color: rgba(46,122,80,0.15);
}

/* ── PACK CONTENT ── */
.pack-content { padding: 16px 16px 0; }

.pack-desc {
  font-size: 0.87rem; color: var(--slate, #3D6050);
  line-height: 1.7; margin-bottom: 16px;
  font-style: italic;
}

.pack-two-col {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: start;
  margin-bottom: 12px;
}

.pack-inclus-title {
  font-family: 'Space Mono', monospace;
  font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--muted, #6A9278); margin-bottom: 10px;
}
.pack-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 6px;
}
.pack-list li {
  font-size: 0.87rem; color: var(--navy, #152B1E);
  line-height: 1.5; padding-left: 16px; position: relative;
}
.pack-list li::before {
  content: '→';
  position: absolute; left: 0;
  color: var(--accent, #2E7A50); font-size: 0.75rem;
}

.pack-note {
  font-size: 0.75rem; color: var(--muted, #6A9278);
  font-style: italic; margin-top: 10px;
}

/* Tarif box inside pack */
.pack-tarif-box {
  background: rgba(46,122,80,0.06);
  border: 1px solid rgba(46,122,80,0.2);
  padding: 16px 20px;
  min-width: 160px;
  text-align: center;
  flex-shrink: 0;
}
.pack-tarif-label {
  font-family: 'Space Mono', monospace;
  font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--muted, #6A9278); margin-bottom: 8px;
}
.pack-tarif-old {
  font-family: 'Space Mono', monospace;
  font-size: 0.85rem; color: var(--muted, #6A9278);
  text-decoration: line-through; margin-bottom: 4px;
}
.pack-tarif-price {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 2rem; font-weight: 700;
  color: var(--accent, #2E7A50); line-height: 1.1;
  margin-bottom: 6px;
}
.pack-tarif-note {
  font-size: 0.7rem; color: var(--muted, #6A9278);
  font-style: italic; line-height: 1.4;
}

/* Lancement badge on button */
.pack-lancement-badge {
  display: inline-block;
  font-family: 'Space Mono', monospace;
  font-size: 0.5rem; letter-spacing: 0.08em; text-transform: uppercase;
  background: #e8883a; color: #fff;
  padding: 2px 6px; vertical-align: middle;
  margin-left: 8px; position: relative; top: -1px;
  font-style: normal;
}

@media (max-width: 600px) {
  .pack-two-col { grid-template-columns: 1fr; }
  .pack-tarif-box { min-width: unset; }
}


/* ── RDV BUTTON (inside accordion) ── */
.offre-rdv-btn {
  display: inline-flex; align-items: center; gap: 8px;
  margin: 14px 16px 16px;
  padding: 10px 20px; background: var(--accent, #2E7A50); color: #fff;
  font-family: 'Space Mono', monospace; font-size: 0.66rem;
  font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  text-decoration: none;
  transition: background 0.2s, transform 0.2s ease; align-self: flex-start;
}
.offre-rdv-btn svg { width: 12px; height: 12px; transition: transform 0.2s ease; }
.offre-rdv-btn:hover { background: var(--accent-light, #3FA066); transform: translateY(-2px); }
.offre-rdv-btn:hover svg { transform: translate(3px,-3px); }

/* ── VISION FUTURE ── */
.vision-future-card {
  background: var(--bg-soft); border: 1px solid var(--border, rgba(21,43,30,0.1));
  padding: 36px;
}
.vf-item { display: flex; gap: 16px; align-items: flex-start; padding: 20px 0; border-bottom: 1px solid var(--border, rgba(21,43,30,0.1)); }
.vf-item:last-child { border-bottom: none; padding-bottom: 0; }
.vf-num { font-family: 'Space Mono', monospace; font-size: 1rem; color: var(--accent, #2E7A50); flex-shrink: 0; margin-top: 2px; }
.vf-item strong { display: block; color: var(--navy, #152B1E); font-weight: 500; margin-bottom: 4px; }
.vf-item p { font-size: 0.86rem; color: var(--muted, #6A9278); line-height: 1.6; }

/* ── CONTACT / QR ── */
.tiandao-contact-section { padding: 96px 52px; background: var(--navy, #152B1E); }
.tiandao-contact-inner { display: grid; grid-template-columns: 1fr auto; gap: 80px; align-items: center; max-width: 1000px; }
.tiandao-contact-section .section-tag  { color: rgba(255,255,255,0.38); }
.tiandao-contact-section .section-title { color: #fff; }
.tiandao-contact-section .section-title em { color: rgba(120,210,150,0.9); }
.tiandao-contact-sub { font-size: 0.96rem; color: rgba(255,255,255,0.52); line-height: 1.8; margin-top: 18px; margin-bottom: 32px; max-width: 460px; }
.tiandao-contact-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 24px; }
.tiandao-contact-section .btn-primary { background: var(--accent, #2E7A50); color: #fff; font-size: 0.7rem; }
.tiandao-contact-section .btn-primary:hover { background: var(--accent-light, #3FA066); }
.btn-tiandao-ghost { display: inline-flex; align-items: center; padding: 13px 22px; background: transparent; color: rgba(255,255,255,0.6); border: 1px solid rgba(255,255,255,0.18); font-family: 'Space Mono', monospace; font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; text-decoration: none; transition: border-color 0.2s, color 0.2s; }
.btn-tiandao-ghost:hover { border-color: rgba(255,255,255,0.5); color: #fff; }
.tiandao-contact-address { display: flex; align-items: center; gap: 10px; font-family: 'Space Mono', monospace; font-size: 0.62rem; letter-spacing: 0.06em; color: rgba(255,255,255,0.3); }
.tiandao-contact-address svg { width: 14px; height: 14px; flex-shrink: 0; color: rgba(120,210,150,0.6); }
.tiandao-qr-card { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 24px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); }
.tiandao-qr-label { font-family: 'Space Mono', monospace; font-size: 0.58rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.35); text-align: center; }
.tiandao-qr-wrap { padding: 10px; background: var(--bg, #F2F7F4); }
.tiandao-qr-img { display: block; width: 140px; height: 140px; image-rendering: pixelated; }

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .tiandao-hero { padding: 110px 24px 60px; }
  .hero-tiandao-wrap { grid-template-columns: 1fr; gap: 32px; }
  .hero-logo-col { justify-content: flex-start; }
  .tiandao-logo-hero { width: 260px; }
  .offre-grid { grid-template-columns: 1fr; }
  .tiandao-contact-section { padding: 72px 24px; }
  .tiandao-contact-inner { grid-template-columns: 1fr; gap: 44px; }
  .tiandao-qr-card { margin: 0 auto; }
}

/* ── KYMA BUTTON ── */
.KYMA-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 28px;
  padding: 13px 24px;
  background: transparent;
  border: 1.5px solid var(--accent, #2E7A50);
  color: var(--accent, #2E7A50);
  font-family: 'Space Mono', monospace;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background 0.2s, color 0.2s, transform 0.2s;
}
.KYMA-btn svg { width: 14px; height: 14px; transition: transform 0.2s; }
.KYMA-btn:hover {
  background: var(--accent, #2E7A50);
  color: #fff;
  transform: translateY(-2px);
}
.KYMA-btn:hover svg { transform: translateX(4px); }
