/* ============================================================
   FIXEO V4 — PRICING CSS
   ============================================================ */

/* ── PRICING HERO ──────────────────────────────────────────── */
.pricing-hero {
  padding: 120px 24px 60px;
  text-align: center;
  background: linear-gradient(160deg, rgba(13,13,26,0.9) 0%, rgba(26,26,46,0.95) 100%);
  position: relative;
  overflow: hidden;
}
.pricing-hero::before {
  content:'';
  position:absolute;inset:0;
  background: radial-gradient(ellipse 60% 50% at 50% 0%, rgba(225,48,108,0.15) 0%, transparent 70%);
  pointer-events:none;
}
.pricing-hero-inner { position:relative;z-index:2; }
.pricing-hero h1 { font-size: clamp(2rem,4vw,3rem); font-weight:800; margin:12px 0; }
.pricing-hero p { color:var(--text-muted); font-size:1rem; max-width:520px; margin:0 auto 32px; }

/* ── BILLING TOGGLE ────────────────────────────────────────── */
.billing-toggle {
  display:inline-flex; align-items:center; gap:12px;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:50px; padding:8px 20px;
}
.billing-label {
  font-size:.88rem; font-weight:600; color:var(--text-muted);
  cursor:pointer; transition:color .2s; user-select:none;
}
.billing-label.active { color:#fff; }
.toggle-switch-wrap {
  width:44px; height:24px; background:rgba(255,255,255,0.1);
  border-radius:12px; position:relative; cursor:pointer;
  border:1px solid rgba(255,255,255,0.18); transition:background .3s;
}
.toggle-switch-wrap.annual { background:var(--grad-primary); }
.toggle-pill {
  position:absolute; top:3px; left:3px;
  width:16px; height:16px; border-radius:50%;
  background:#fff; transition:transform .3s;
}
.toggle-pill.annual { transform:translateX(20px); }
.save-badge {
  background:var(--grad-success); color:#fff;
  font-size:.68rem; font-weight:700; padding:2px 7px;
  border-radius:20px; margin-left:4px; vertical-align:middle;
}

/* ── PRICING GRID ──────────────────────────────────────────── */
.pricing-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px,1fr));
  gap:24px; margin-bottom:64px; align-items:stretch;
}
.pricing-card {
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:var(--radius-xl);
  padding:32px 28px;
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
}
.pricing-card:hover {
  transform:translateY(-6px);
  box-shadow:0 20px 60px rgba(0,0,0,0.4);
}
.pricing-card.popular {
  border-color:rgba(225,48,108,0.5);
  background:rgba(225,48,108,0.06);
  box-shadow:0 0 40px rgba(225,48,108,0.12);
}
.pricing-card.premium-card {
  border-color:rgba(252,175,69,0.4);
  background:rgba(252,175,69,0.04);
}
.premium-glow {
  position:absolute; inset:0; border-radius:var(--radius-xl);
  background:radial-gradient(ellipse 80% 50% at 50% 0%, rgba(252,175,69,0.08) 0%, transparent 70%);
  pointer-events:none;
}
.popular-badge {
  position:absolute; top:16px; right:16px;
  background:var(--grad-primary); color:#fff;
  font-size:.65rem; font-weight:700; padding:4px 10px;
  border-radius:20px; letter-spacing:.05em;
}

/* Plan header */
.plan-header { margin-bottom:24px; }
.plan-icon { font-size:2.5rem; margin-bottom:12px; }
.plan-name { font-size:1.4rem; font-weight:800; margin-bottom:8px; }
.plan-price {
  display:flex; align-items:baseline; gap:4px; margin-bottom:10px;
  flex-wrap:wrap;
}
.price-amount { font-size:2.8rem; font-weight:800; color:#fff; line-height:1; }
.pricing-card.popular .price-amount { color:var(--primary); }
.pricing-card.premium-card .price-amount { color:var(--warning); }
.price-currency { font-size:1rem; color:var(--text-muted); font-weight:600; }
.price-period { font-size:.85rem; color:var(--text-muted); }
.plan-desc { font-size:.85rem; color:var(--text-muted); }

/* Features list */
.plan-features { list-style:none; padding:0; margin:0 0 24px; flex:1; }
.plan-features li {
  display:flex; align-items:center; gap:10px;
  font-size:.87rem; padding:7px 0;
  border-bottom:1px solid rgba(255,255,255,0.05);
}
.plan-features li:last-child { border-bottom:none; }
.feat-ok { color:rgba(255,255,255,0.88); }
.feat-no { color:rgba(255,255,255,0.35); }
.feat-icon { font-size:.9rem; flex-shrink:0; width:20px; }

/* Buttons */
.plan-btn { margin-top:auto; }
.btn-premium {
  background:linear-gradient(135deg,#FCA337,#E1306C) !important;
  color:#fff !important;
}
.btn-premium:hover { opacity:.9; transform:translateY(-1px); }

/* ── COMPARISON TABLE ──────────────────────────────────────── */
.comparison-wrap { margin-bottom:64px; }
.comparison-table-wrap { overflow-x:auto; border-radius:var(--radius-xl); }
.comparison-table {
  width:100%; border-collapse:collapse;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--radius-xl); overflow:hidden;
}
.comparison-table th, .comparison-table td {
  padding:14px 20px; text-align:center; font-size:.85rem;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.comparison-table th { background:rgba(255,255,255,0.06); font-weight:700; font-size:.82rem; }
.comparison-table tr:last-child td { border-bottom:none; }
.comparison-table tr:hover td { background:rgba(255,255,255,0.03); }
.feat-name { text-align:left !important; font-weight:600; color:rgba(255,255,255,.8); }
.th-badge {
  display:inline-block; padding:4px 14px; border-radius:20px; font-size:.78rem; font-weight:700;
}
.th-badge.free { background:rgba(255,255,255,0.1); color:#fff; }
.th-badge.pro { background:rgba(225,48,108,0.2); color:var(--primary); border:1px solid rgba(225,48,108,0.3); }
.th-badge.premium { background:rgba(252,175,69,0.15); color:var(--warning); border:1px solid rgba(252,175,69,0.3); }

/* ── FAQ ───────────────────────────────────────────────────── */
.faq-section { margin-bottom:64px; }
.faq-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(340px,1fr)); gap:16px; }
.faq-item {
  background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--radius-lg); overflow:hidden;
}
.faq-q {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; cursor:pointer; font-weight:600; font-size:.9rem;
  transition:background .2s;
}
.faq-q:hover { background:rgba(255,255,255,0.04); }
.faq-arrow { font-size:.75rem; color:var(--text-muted); transition:transform .3s; flex-shrink:0; }
.faq-item.open .faq-arrow { transform:rotate(180deg); }
.faq-a {
  padding:0 20px; max-height:0; overflow:hidden;
  font-size:.85rem; color:var(--text-muted); transition:all .35s ease;
}
.faq-item.open .faq-a { padding:0 20px 16px; max-height:200px; }

/* ── PAYMENT MODAL ─────────────────────────────────────────── */
.modal { display:none; position:fixed; inset:0; z-index:1000; align-items:center; justify-content:center; }
.modal.open { display:flex; }
.modal-dialog {
  background:var(--surface); border:1px solid rgba(255,255,255,0.1);
  border-radius:var(--radius-xl); width:90%; max-width:520px;
  max-height:90vh; overflow-y:auto; position:relative; z-index:1001;
  animation:modalIn .3s ease;
}
.modal-dialog.modal-lg { max-width:640px; }
.modal-dialog.modal-sm { max-width:420px; }
@keyframes modalIn {
  from { opacity:0; transform:scale(0.92) translateY(20px); }
  to   { opacity:1; transform:scale(1) translateY(0); }
}
.modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 24px; border-bottom:1px solid rgba(255,255,255,0.08);
}
.modal-header h3 { font-size:1.05rem; font-weight:700; }
.modal-close {
  background:none; border:none; color:var(--text-muted);
  cursor:pointer; font-size:1.1rem; padding:4px 8px; border-radius:6px;
  transition:all .2s;
}
.modal-close:hover { background:rgba(255,255,255,0.08); color:#fff; }
.modal-body { padding:24px; }
.modal-footer {
  padding:16px 24px; border-top:1px solid rgba(255,255,255,0.08);
  display:flex; gap:10px; justify-content:flex-end; flex-wrap:wrap;
}
.modal-backdrop-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.65);
  backdrop-filter:blur(4px); z-index:999;
}

/* Payment plan summary */
.payment-plan-summary {
  background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1);
  border-radius:var(--radius-lg); padding:16px 20px; margin-bottom:20px;
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px;
}
.payment-plan-name { font-weight:700; font-size:1rem; }
.payment-plan-price { font-size:1.1rem; font-weight:800; color:var(--primary); }

/* Payment tabs */
.payment-tabs { display:flex; gap:8px; margin-bottom:20px; flex-wrap:wrap; }
.pay-tab {
  flex:1; min-width:100px; padding:10px 8px; border-radius:var(--radius-md);
  background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.12);
  color:rgba(255,255,255,.6); cursor:pointer; font-size:.82rem; font-weight:600;
  transition:all .2s; display:flex; align-items:center; justify-content:center; gap:6px;
}
.pay-tab.active { background:rgba(225,48,108,0.12); border-color:rgba(225,48,108,0.4); color:#fff; }
.pay-tab:hover:not(.active) { background:rgba(255,255,255,0.08); color:#fff; }

/* Payment forms */
.pay-form { animation:fadeIn .3s ease; }
.secure-badge {
  background:rgba(32,201,151,0.1); border:1px solid rgba(32,201,151,0.25);
  color:var(--success); font-size:.78rem; font-weight:600;
  padding:8px 14px; border-radius:var(--radius-md); margin-bottom:20px;
  display:flex; align-items:center; gap:6px;
}

/* Form controls */
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-size:.8rem; font-weight:600; color:rgba(255,255,255,.7); margin-bottom:6px; }
.form-group input {
  width:100%; padding:11px 14px; background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.15); border-radius:var(--radius-md);
  color:#fff; font-size:.9rem; transition:all .2s; box-sizing:border-box;
}
.form-group input:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 3px rgba(225,48,108,0.15); }
.card-input-wrap { position:relative; }
.card-type-icons { position:absolute; right:12px; top:50%; transform:translateY(-50%); font-size:1.2rem; }

/* PayPal */
.paypal-logo { font-size:1.8rem; margin-bottom:12px; }
.paypal-info { text-align:center; padding:20px; }
.btn-paypal { background:linear-gradient(135deg,#0070BA,#003087) !important; color:#fff !important; }

/* CMI */
.cmi-info { margin-bottom:20px; }
.cmi-badges { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }
.cmi-badge {
  background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.15);
  font-size:.72rem; font-weight:700; padding:4px 10px; border-radius:6px;
}

/* Payment messages */
.payment-message {
  margin-top:16px; padding:14px 18px; border-radius:var(--radius-md);
  font-size:.88rem; font-weight:600;
}
.payment-message.success { background:rgba(32,201,151,0.1); border:1px solid rgba(32,201,151,.3); color:var(--success); }
.payment-message.error { background:rgba(225,48,108,0.1); border:1px solid rgba(225,48,108,.3); color:var(--primary); }

/* Success animation */
.success-animation { font-size:4rem; animation:bounceIn .5s ease; }
@keyframes bounceIn {
  0%   { transform:scale(0); opacity:0; }
  60%  { transform:scale(1.2); opacity:1; }
  100% { transform:scale(1); }
}

/* Utility */
.w-100 { width:100% !important; }
@keyframes fadeIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

/* Footer */
.footer { background:rgba(255,255,255,0.02); border-top:1px solid rgba(255,255,255,0.06); padding:40px 0 20px; margin-top:40px; }
.footer-content { display:flex; align-items:flex-start; justify-content:space-between; flex-wrap:wrap; gap:24px; margin-bottom:24px; }
.footer-links { display:flex; gap:20px; flex-wrap:wrap; align-items:center; }
.footer-links a { color:var(--text-muted); text-decoration:none; font-size:.85rem; transition:color .2s; }
.footer-links a:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.06); padding-top:16px; text-align:center; }
.footer-bottom p { color:var(--text-muted); font-size:.8rem; }

/* Responsive */
@media (max-width:768px) {
  .pricing-grid { grid-template-columns:1fr; }
  .faq-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .payment-tabs { flex-direction:column; }
  .comparison-table th, .comparison-table td { padding:10px 12px; font-size:.78rem; }
}
@media (max-width:480px) {
  .billing-toggle { padding:6px 14px; }
}

/* ══════════════════════════════════════════════════════════
   BUG 4 FIX — Pricing buttons interaction & selection state
   ══════════════════════════════════════════════════════════ */

/* Ensure card overflow doesn't block button clicks */
.pricing-card {
  overflow: visible !important;
  position: relative !important;
}

/* Glow overlay must not intercept pointer events */
.premium-glow {
  pointer-events: none !important;
  z-index: 0 !important;
}

/* All plan content must be above glow */
.plan-header,
.plan-features,
.plan-btn,
.popular-badge {
  position: relative !important;
  z-index: 1 !important;
}

/* Plan buttons — always clickable */
.plan-btn {
  cursor: pointer !important;
  width: 100% !important;
  font-size: .95rem !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
  transition: transform .18s ease, opacity .18s ease, box-shadow .18s ease !important;
}
.plan-btn:hover:not(:disabled) {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(225,48,108,0.25) !important;
}
.plan-btn:active:not(:disabled) {
  transform: translateY(0) !important;
}

/* Selected plan visual state */
.pricing-card.selected {
  border-color: rgba(225,48,108,0.75) !important;
  box-shadow: 0 0 0 3px rgba(225,48,108,0.2), 0 20px 60px rgba(225,48,108,0.2) !important;
  transform: translateY(-4px) !important;
}
.pricing-card.selected .plan-btn {
  background: var(--grad-primary) !important;
  color: #fff !important;
}
.pricing-card.selected::after {
  content: '✓ Sélectionné';
  position: absolute;
  top: 12px;
  left: 12px;
  background: rgba(32,201,151,0.2);
  border: 1px solid rgba(32,201,151,0.4);
  color: #20c997;
  font-size: .65rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  z-index: 2;
}
.pricing-card.popular.selected::after {
  left: auto;
  right: 70px;
}

/* Payment modal form controls */
.pay-form input,
.pay-form select {
  color: #fff !important;
  background: rgba(255,255,255,0.08) !important;
  border: 1px solid rgba(255,255,255,0.15) !important;
  border-radius: 10px !important;
  padding: 11px 14px !important;
  width: 100% !important;
  font-size: .9rem !important;
  font-family: inherit !important;
  transition: border-color .2s ease !important;
  box-sizing: border-box !important;
}
.pay-form input:focus,
.pay-form select:focus {
  outline: none !important;
  border-color: var(--accent-pink) !important;
  box-shadow: 0 0 0 3px rgba(225,48,108,0.15) !important;
}
.pay-form label {
  display: block !important;
  font-size: .82rem !important;
  font-weight: 600 !important;
  color: rgba(255,255,255,.7) !important;
  margin-bottom: 6px !important;
}
.form-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 14px !important;
}
.secure-badge {
  font-size: .78rem !important;
  color: #20c997 !important;
  background: rgba(32,201,151,.08) !important;
  border: 1px solid rgba(32,201,151,.2) !important;
  border-radius: 8px !important;
  padding: 7px 12px !important;
  margin-bottom: 18px !important;
  display: block !important;
}
.payment-message {
  border-radius: 10px !important;
  padding: 12px 16px !important;
  font-size: .88rem !important;
  font-weight: 600 !important;
  margin-top: 14px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.payment-message.error {
  background: rgba(255,71,87,.1) !important;
  border: 1px solid rgba(255,71,87,.25) !important;
  color: #ff4757 !important;
}
