/* ============================================================
   ASSUROMIEUX — Offre PER PROPER2026
   Fichier : public/css/offre-proper2026.css
   À inclure dans le <head> de la vue Blade ou via app.css
   ============================================================ */

/* --- Variables locales (héritent du site si déjà défini) --- */
:root {
  --per-navy:        #1B3A6B;
  --per-navy-dark:   #0f2347;
  --per-navy-light:  #2a5298;
  --per-orange:      #E86828;
  --per-orange-dark: #c9561f;
  --per-cream:       #F8F5F0;
  --per-white:       #ffffff;
  --per-grey:        #6b7280;
  --per-grey-light:  #f3f4f6;
  --per-orange-bg:   #FDF0E8;
  --per-navy-bg:     #E8EEF7;
  --per-radius:      12px;
  --per-radius-sm:   8px;
}

/* ---- Section wrapper ---- */
.per-offre-section {
  background: var(--per-cream);
  padding: 0;
  font-family: 'DM Sans', system-ui, sans-serif;
}

/* ============================================================
   BAND INTRO
   ============================================================ */
.per-offre__intro-band {
  background: linear-gradient(135deg, var(--per-navy-dark) 0%, var(--per-navy) 55%, var(--per-navy-light) 100%);
  color: var(--per-white);
  padding: 3.5rem 2rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.per-offre__intro-band::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -15%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(232,104,40,.14) 0%, transparent 70%);
  pointer-events: none;
}

.per-offre__badge {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  background: rgba(232,104,40,.18);
  border: 1px solid rgba(232,104,40,.45);
  color: #ffa570;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .35rem .95rem;
  border-radius: 50px;
  margin-bottom: 1.4rem;
}

.per-offre__badge::before { content: '★'; }

.per-offre__intro-band h2 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 900;
  line-height: 1.1;
  margin: 0 0 1rem;
}

.per-offre__intro-band h2 em {
  font-style: normal;
  color: var(--per-orange);
}

.per-offre__intro-band p {
  font-size: 1rem;
  color: rgba(255,255,255,.72);
  max-width: 540px;
  margin: 0 auto 2rem;
  font-weight: 300;
  line-height: 1.65;
}

.per-offre__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--per-orange);
  color: var(--per-white);
  font-weight: 600;
  font-size: .95rem;
  padding: .85rem 2rem;
  border-radius: var(--per-radius-sm);
  text-decoration: none;
  transition: background .22s ease, transform .2s ease, box-shadow .2s ease;
  box-shadow: 0 4px 18px rgba(232,104,40,.38);
}

.per-offre__cta-btn::after { content: '→'; font-size: 1rem; }

.per-offre__cta-btn:hover {
  background: var(--per-orange-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(232,104,40,.48);
  color: var(--per-white);
  text-decoration: none;
}

.per-offre__validity {
  display: block;
  margin-top: 1.2rem;
  font-size: .73rem;
  color: rgba(255,255,255,.45);
}

/* ============================================================
   PRIMES GRID
   ============================================================ */
.per-offre__primes {
  padding: 3.5rem 2rem;
  max-width: 1100px;
  margin: 0 auto;
}

.per-offre__section-label {
  font-size: .73rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--per-orange);
  margin-bottom: .5rem;
}

.per-offre__primes h3 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 700;
  color: var(--per-navy);
  margin: 0 0 .4rem;
}

.per-offre__primes-intro {
  color: var(--per-grey);
  font-size: .93rem;
  margin-bottom: 2rem;
  max-width: 560px;
  line-height: 1.6;
}

.per-offre__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 1.1rem;
  margin-bottom: 1.8rem;
}

.per-offre__card {
  background: var(--per-white);
  border: 1px solid rgba(27,58,107,.1);
  border-radius: var(--per-radius);
  padding: 1.7rem 1.3rem 1.4rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
}

.per-offre__card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--per-navy), var(--per-orange));
}

.per-offre__card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 36px rgba(27,58,107,.11);
}

.per-offre__card-amount {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 2.2rem;
  font-weight: 900;
  color: var(--per-orange);
  line-height: 1;
  margin-bottom: .35rem;
}

.per-offre__card-range {
  font-size: .8rem;
  color: var(--per-grey);
  line-height: 1.45;
}

.per-offre__card-range strong {
  display: block;
  color: var(--per-navy);
  font-weight: 600;
  font-size: .85rem;
  margin-bottom: .15rem;
}

/* ---- Bonus VLP ---- */
.per-offre__vlp-band {
  background: linear-gradient(135deg, var(--per-navy) 0%, var(--per-navy-light) 100%);
  border-radius: var(--per-radius);
  padding: 1.8rem 2rem;
  color: var(--per-white);
  display: flex;
  align-items: center;
  gap: 1.6rem;
  flex-wrap: wrap;
}

.per-offre__vlp-icon {
  font-size: 2.2rem;
  flex-shrink: 0;
  line-height: 1;
}

.per-offre__vlp-content { flex: 1; min-width: 200px; }

.per-offre__vlp-content h4 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.15rem;
  font-weight: 700;
  margin: 0 0 .3rem;
}

.per-offre__vlp-content p {
  font-size: .85rem;
  color: rgba(255,255,255,.72);
  line-height: 1.55;
  margin: 0;
}

.per-offre__vlp-badge {
  background: var(--per-orange);
  color: var(--per-white);
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.8rem;
  font-weight: 700;
  padding: .7rem 1.3rem;
  border-radius: 10px;
  text-align: center;
  flex-shrink: 0;
}

.per-offre__vlp-badge span {
  display: block;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: .68rem;
  font-weight: 400;
  opacity: .85;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-top: .15rem;
}

/* ============================================================
   CODE PROMO BAND
   ============================================================ */
.per-offre__code-band {
  background: linear-gradient(135deg, #f97316 0%, var(--per-orange) 50%, #c9561f 100%);
  color: var(--per-white);
  text-align: center;
  padding: 3rem 2rem;
}

.per-offre__code-band h3 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0 0 .4rem;
}

.per-offre__code-band > p {
  font-size: .88rem;
  opacity: .82;
  margin: 0 0 1.6rem;
}

.per-offre__code-box {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  background: rgba(255,255,255,.14);
  border: 2px dashed rgba(255,255,255,.48);
  border-radius: 10px;
  padding: .9rem 2.5rem;
  font-family: 'Courier New', Courier, monospace;
  font-size: 1.9rem;
  font-weight: 700;
  letter-spacing: .1em;
  margin-bottom: .8rem;
  cursor: default;
  user-select: all;
}

.per-offre__code-note {
  font-size: .76rem;
  opacity: .68;
  margin: 0;
}

/* ============================================================
   ELIGIBILITE
   ============================================================ */
.per-offre__elig {
  padding: 3.5rem 2rem;
  max-width: 900px;
  margin: 0 auto;
}

.per-offre__elig h3 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(1.3rem, 2vw, 1.8rem);
  font-weight: 700;
  color: var(--per-navy);
  margin: 0 0 1.4rem;
}

.per-offre__elig-card {
  background: var(--per-white);
  border-radius: var(--per-radius);
  padding: 2rem 2.2rem;
  box-shadow: 0 4px 28px rgba(27,58,107,.07);
  border: 1px solid rgba(27,58,107,.08);
}

.per-offre__elig-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .9rem;
}

.per-offre__elig-list li {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  font-size: .93rem;
  color: #374151;
  line-height: 1.55;
}

.per-offre__elig-list li::before {
  content: '✓';
  background: var(--per-navy);
  color: var(--per-white);
  width: 20px;
  height: 20px;
  min-width: 20px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .65rem;
  font-weight: 700;
  margin-top: 2px;
}

/* ============================================================
   MENTIONS LÉGALES
   ============================================================ */
.per-offre__mentions {
  background: #111827;
  color: rgba(255,255,255,.42);
  padding: 2.2rem 2rem;
  font-size: .73rem;
  line-height: 1.7;
}

.per-offre__mentions-inner {
  max-width: 900px;
  margin: 0 auto;
}

.per-offre__mentions h4 {
  color: rgba(255,255,255,.58);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  margin: 0 0 .7rem;
}

.per-offre__mentions p { margin: 0 0 .6rem; }

.per-offre__risk-warning {
  border-left: 3px solid var(--per-orange);
  padding-left: .9rem;
  margin: .9rem 0 1rem;
  font-weight: 600;
  color: rgba(255,255,255,.54);
  font-style: italic;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 640px) {
  .per-offre__vlp-band {
    flex-direction: column;
    text-align: center;
  }

  .per-offre__vlp-badge { margin: 0 auto; }

  .per-offre__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .per-offre__code-box {
    font-size: 1.4rem;
    padding: .8rem 1.4rem;
  }

  .per-offre__elig-card {
    padding: 1.4rem 1.2rem;
  }
}

@media (max-width: 380px) {
  .per-offre__grid {
    grid-template-columns: 1fr 1fr;
  }
}
