/* ══════════════════════════════════════
   Styles communs — pages intérieures
   Rift Running
══════════════════════════════════════ */
:root {
  --red:   #BB0000;
  --green: #006600;
  --dark:  #111;
  --grey:  #F5F5F5;
  --muted: #666;
  --ff-title: 'Montserrat', sans-serif;
  --ff-body:  'Open Sans', sans-serif;
}

/* ── Banner Kenya ── */
.ip-banner {
  background: linear-gradient(135deg, #000 0%, #BB0000 55%, #006600 100%);
  padding: 156px 0 56px; text-align: center; color: #fff;
}
.ip-banner h1 {
  font-family: var(--ff-title); font-size: clamp(1.8rem,4vw,2.8rem);
  font-weight: 900; color: #fff; margin: 0 0 10px; letter-spacing: -1px;
}
.ip-breadcrumb {
  font-family: var(--ff-title); font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 2px; color: rgba(255,255,255,.6);
}
.ip-breadcrumb a { color: rgba(255,255,255,.6); text-decoration: none; transition: color .2s; }
.ip-breadcrumb a:hover { color: #fff; }
.ip-breadcrumb span { margin: 0 8px; color: rgba(255,255,255,.9); }

/* ── Layout ── */
.ip-wrap { max-width: 1060px; margin: 0 auto; padding: 72px 24px 80px; }
.ip-intro { max-width: 760px; margin: 0 auto 60px; text-align: center; }
.ip-intro h2 {
  font-family: var(--ff-title); font-size: clamp(1.5rem,3vw,2rem);
  font-weight: 900; color: var(--dark); margin-bottom: 16px; letter-spacing: -.5px;
}
.ip-intro p { font-family: var(--ff-body); font-size: 1rem; color: var(--muted); line-height: 1.8; }
.ip-line { display: block; width: 50px; height: 4px; background: var(--red); border-radius: 2px; margin: 18px auto 0; }

/* ── Section title ── */
.ip-sec-title {
  font-family: var(--ff-title); font-size: 13px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 2px; color: var(--red);
  margin-bottom: 24px; display: flex; align-items: center; gap: 10px;
}
.ip-sec-title::before { content: ''; display: block; width: 32px; height: 3px; background: var(--red); }

/* ── Cards grilles ── */
.ip-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-bottom: 48px; }
.ip-grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; margin-bottom: 48px; }
.ip-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-bottom: 48px; }

.ip-card {
  background: #fff; border-radius: 10px; border: 1px solid #eee;
  padding: 28px; box-shadow: 0 2px 12px rgba(0,0,0,.05);
  transition: box-shadow .25s, transform .25s;
  display: flex; flex-direction: column;
}
.ip-card:hover { box-shadow: 0 10px 28px rgba(0,0,0,.09); transform: translateY(-3px); }
.ip-card-icon {
  width: 48px; height: 48px; border-radius: 12px; background: #fff0f0;
  display: flex; align-items: center; justify-content: center;
  color: var(--red); font-size: 20px; margin-bottom: 16px;
}
.ip-card-icon.green { background: #f0fff0; color: var(--green); }
.ip-card h4 {
  font-family: var(--ff-title); font-size: 15px; font-weight: 800;
  color: var(--dark); margin-bottom: 10px; text-transform: none;
}
.ip-card p { font-family: var(--ff-body); font-size: 14px; color: var(--muted); line-height: 1.75; margin: 0; flex: 1; }
.ip-card-link {
  display: inline-flex; align-items: center; gap: 6px; margin-top: 16px;
  font-family: var(--ff-title); font-size: 11px; font-weight: 800;
  text-transform: uppercase; letter-spacing: .8px; color: var(--red);
  text-decoration: none; transition: gap .2s;
}
.ip-card-link:hover { gap: 10px; color: #8B0000; }
.ip-card.featured {
  background: var(--dark); border-color: var(--dark); color: #fff;
}
.ip-card.featured h4 { color: #fff; }
.ip-card.featured p { color: rgba(255,255,255,.7); }
.ip-card.featured .ip-card-icon { background: rgba(187,0,0,.3); color: #ff6666; }

/* ── Plan box ── */
.ip-plan {
  background: var(--grey); border-radius: 10px; padding: 28px 32px;
  border-left: 5px solid var(--red); margin-bottom: 20px;
  transition: box-shadow .2s;
}
.ip-plan:hover { box-shadow: 0 4px 20px rgba(0,0,0,.08); }
.ip-plan.green { border-left-color: var(--green); }
.ip-plan h3 {
  font-family: var(--ff-title); font-size: 16px; font-weight: 800;
  color: var(--dark); margin-bottom: 10px; text-transform: none;
}
.ip-plan p { font-family: var(--ff-body); font-size: 14px; color: var(--muted); line-height: 1.75; margin: 0; }

/* ── Feature list ── */
.ip-features {
  background: #fff; border-radius: 10px; border: 1px solid #eee;
  padding: 28px 32px; margin-bottom: 48px;
}
.ip-features h4 {
  font-family: var(--ff-title); font-size: 13px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 1.5px; color: var(--dark);
  margin-bottom: 18px;
}
.ip-feature-item {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 12px 0; border-bottom: 1px solid #f5f5f5;
  font-family: var(--ff-body); font-size: 14px; color: #444;
}
.ip-feature-item:last-child { border-bottom: none; padding-bottom: 0; }
.ip-feature-item i { color: var(--red); margin-top: 2px; flex-shrink: 0; width: 16px; }
.ip-feature-item i.green { color: var(--green); }

/* ── Steps ── */
.ip-steps { display: flex; flex-direction: column; gap: 0; margin-bottom: 48px; }
.ip-step {
  display: flex; align-items: flex-start; gap: 20px;
  padding: 24px 0; border-bottom: 1px solid #f0f0f0;
}
.ip-step:last-child { border-bottom: none; }
.ip-step-num {
  width: 44px; height: 44px; border-radius: 50%; background: var(--red);
  color: #fff; font-family: var(--ff-title); font-size: 16px; font-weight: 900;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.ip-step h4 {
  font-family: var(--ff-title); font-size: 15px; font-weight: 800;
  color: var(--dark); margin-bottom: 6px; text-transform: none;
}
.ip-step p { font-family: var(--ff-body); font-size: 14px; color: var(--muted); line-height: 1.7; margin: 0; }

/* ── Dark band ── */
.ip-dark-band {
  background: var(--dark); padding: 60px 0; margin: 48px 0;
}
.ip-dark-band .ip-wrap { padding-top: 0; padding-bottom: 0; }

/* ── CTA finale ── */
.ip-cta {
  background: linear-gradient(135deg, #000 0%, #BB0000 55%, #006600 100%);
  border-radius: 12px; padding: 52px 40px; text-align: center; color: #fff;
  margin-top: 60px;
}
.ip-cta h3 {
  font-family: var(--ff-title); font-size: clamp(1.3rem,3vw,1.8rem);
  font-weight: 900; color: #fff; margin-bottom: 12px;
}
.ip-cta p { color: rgba(255,255,255,.78); margin-bottom: 28px; font-size: 1rem; }
.ip-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: #fff; color: var(--red);
  font-family: var(--ff-title); font-size: 12px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 1px;
  padding: 13px 28px; border-radius: 4px; text-decoration: none;
  transition: background .2s, transform .15s;
}
.ip-btn:hover { background: #f0f0f0; color: #8B0000; transform: translateY(-2px); }
.ip-btn-dark {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--red); color: #fff;
  font-family: var(--ff-title); font-size: 12px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 1px;
  padding: 13px 28px; border-radius: 4px; text-decoration: none;
  transition: background .2s, transform .15s; margin-left: 12px;
}
.ip-btn-dark:hover { background: #8B0000; color: #fff; transform: translateY(-2px); }

/* ── Pricing ── */
.ip-pricing-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; margin-bottom: 48px; }
.ip-pricing-card {
  background: #fff; border-radius: 12px; border: 1px solid #e8e8e8;
  overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,.07);
  transition: transform .25s, box-shadow .25s;
  display: flex; flex-direction: column;
}
.ip-pricing-card:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(0,0,0,.12); }
.ip-pricing-card.popular { border-color: var(--red); border-width: 2px; }
.ip-pricing-header { background: var(--dark); padding: 28px 24px; text-align: center; border-bottom: 4px solid var(--red); }
.ip-pricing-header.kenya { background: linear-gradient(135deg, #000, #BB0000, #006600); border-bottom-color: rgba(255,255,255,.3); }
.ip-pricing-badge {
  display: inline-block; background: #fff; color: var(--red);
  font-family: var(--ff-title); font-size: 10px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 1px; padding: 3px 12px;
  border-radius: 99px; margin-bottom: 10px;
}
.ip-pricing-name { font-family: var(--ff-title); font-size: 15px; font-weight: 900; color: #fff; margin-bottom: 4px; }
.ip-pricing-sub { font-size: 12px; color: rgba(255,255,255,.6); margin-bottom: 16px; }
.ip-pricing-price { font-family: var(--ff-title); font-weight: 900; color: #fff; line-height: 1; }
.ip-pricing-price .amount { font-size: 48px; }
.ip-pricing-price .period { font-size: 14px; color: rgba(255,255,255,.6); }
.ip-pricing-alt { font-size: 12px; color: rgba(255,255,255,.5); margin-top: 8px; }
.ip-pricing-body { padding: 28px 24px; flex: 1; display: flex; flex-direction: column; }
.ip-pricing-body ul { list-style: none; margin: 0 0 20px; padding: 0; }
.ip-pricing-body li {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 9px 0; border-bottom: 1px solid #f5f5f5;
  font-family: var(--ff-body); font-size: 14px; color: #444;
}
.ip-pricing-body li:last-child { border-bottom: none; }
.ip-pricing-body li i { color: var(--green); margin-top: 3px; flex-shrink: 0; }
.ip-pricing-ideal { font-size: 13px; color: var(--red); font-weight: 700; font-family: var(--ff-title); margin-bottom: 20px; flex: 1; }
.ip-pricing-cta {
  display: block; text-align: center;
  background: var(--red); color: #fff; padding: 13px;
  border-radius: 6px; font-family: var(--ff-title); font-size: 12px;
  font-weight: 800; text-transform: uppercase; letter-spacing: 1px;
  text-decoration: none; transition: background .2s;
}
.ip-pricing-cta:hover { background: #8B0000; color: #fff; }

/* ── Animations scroll — activées seulement si JS a marqué .anim-ready ── */
.anim-ready .ip-card,
.anim-ready .ip-plan,
.anim-ready .ip-step,
.anim-ready .ip-pricing-card {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .55s ease, transform .55s ease;
}
.anim-ready .ip-card.visible,
.anim-ready .ip-plan.visible,
.anim-ready .ip-step.visible,
.anim-ready .ip-pricing-card.visible {
  opacity: 1;
  transform: translateY(0);
}
.anim-ready .ip-card:nth-child(2), .anim-ready .ip-pricing-card:nth-child(2) { transition-delay: .1s; }
.anim-ready .ip-card:nth-child(3), .anim-ready .ip-pricing-card:nth-child(3) { transition-delay: .2s; }
.anim-ready .ip-card:nth-child(4) { transition-delay: .3s; }
.anim-ready .ip-step:nth-child(2) { transition-delay: .08s; }
.anim-ready .ip-step:nth-child(3) { transition-delay: .16s; }
.anim-ready .ip-step:nth-child(4) { transition-delay: .24s; }

/* ── Boutons CTA mobile — 44px minimum ── */
@media (max-width: 767px) {
  .ip-btn, .ip-btn-dark, .ip-pricing-cta {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
}

/* ── Responsive ── */
@media(max-width:991px){
  .ip-grid-3 { grid-template-columns: repeat(2,1fr); }
  .ip-grid-4 { grid-template-columns: repeat(2,1fr); }
  .ip-pricing-grid { grid-template-columns: 1fr; max-width: 480px; margin-left: auto; margin-right: auto; }
}
@media(max-width:575px){
  .ip-wrap { padding: 48px 16px 60px; }
  .ip-grid-2, .ip-grid-3, .ip-grid-4 { grid-template-columns: 1fr; }
  .ip-cta { padding: 36px 20px; }
  .ip-plan { padding: 20px; }
}
