/* PBF Product Showcase + Quiz — style.css */

/* All interactive elements use div[role=button] to avoid Elementor button inheritance */
.pbf-ps [role="button"] { cursor: pointer; user-select: none; -webkit-tap-highlight-color: transparent; }

.pbf-ps {
  --ps-blue: #1a6ef5;
  --ps-blue-mid: #0d55d4;
  --ps-blue-ghost: #f0f5ff;
  --ps-yellow: #f5c800;
  --ps-yellow-mid: #c9a200;
  --ps-snow: #f7f9fc;
  --ps-g50: #f2f4f8;
  --ps-g100: #e3e8f0;
  --ps-g200: #c5cedd;
  --ps-g300: #9aa5bb;
  --ps-g500: #5e6b82;
  --ps-g700: #2d3547;
  --ps-g900: #111827;
  --ps-sans: 'DM Sans','Montserrat',system-ui,sans-serif;
  --ps-display: 'Syne','Montserrat',system-ui,sans-serif;
  font-family: var(--ps-sans);
  color: var(--ps-g900);
  padding: 60px 24px 52px;
}
.ps-inner { max-width: 1200px; margin: 0 auto; }

/* Scroll reveal */
.ps-reveal { opacity:0; transform:translateY(24px); transition:opacity .55s cubic-bezier(.22,1,.36,1),transform .55s cubic-bezier(.22,1,.36,1); }
.ps-reveal.ps-on { opacity:1; transform:none; }
.ps-d1 { transition-delay:.05s } .ps-d2 { transition-delay:.14s } .ps-d3 { transition-delay:.23s }

/* ── Header ── */
.ps-head { margin-bottom:40px; }
@media(min-width:768px){ .ps-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px} }
.ps-eyebrow { display:inline-flex;align-items:center;gap:6px;font-size:.6875rem;font-weight:700;color:var(--ps-blue);text-transform:uppercase;letter-spacing:.7px;margin-bottom:10px }
.ps-eyebrow-dot { width:6px;height:6px;border-radius:50%;background:var(--ps-blue) }
.ps-title { font-family:var(--ps-display);font-size:clamp(1.5rem,5vw,2.125rem);font-weight:800;color:var(--ps-g900);line-height:1.15;margin-bottom:8px }
.ps-sub { font-size:.9375rem;color:var(--ps-g300);max-width:420px;line-height:1.6 }
.ps-count { display:inline-flex;align-items:center;gap:6px;background:var(--ps-g50);border:1px solid var(--ps-g100);border-radius:50px;padding:6px 14px;font-size:.8125rem;font-weight:600;color:var(--ps-g500);margin-top:16px;white-space:nowrap }
@media(min-width:768px){ .ps-count{margin-top:0} }
.ps-count-num { font-family:var(--ps-display);font-size:.9375rem;font-weight:800;color:var(--ps-blue) }

/* ── Grid ── */
.ps-grid { display:grid;grid-template-columns:1fr;gap:16px }
@media(min-width:600px){ .ps-grid{grid-template-columns:repeat(2,1fr);gap:20px} }
@media(min-width:1024px){ .ps-grid{grid-template-columns:repeat(3,1fr);gap:24px} }
@media(min-width:600px) and (max-width:1023px){ .ps-card:nth-child(3):last-child{grid-column:1/-1} }

/* ── Card ── */
.ps-card { background:#fff;border-radius:20px;border:1.5px solid var(--ps-g100);box-shadow:0 2px 8px rgba(0,0,0,.06);display:flex;flex-direction:column;overflow:hidden;position:relative;transition:box-shadow .3s,transform .3s,border-color .3s }
.ps-card:hover { box-shadow:0 20px 56px rgba(0,0,0,.13);transform:translateY(-4px);border-color:rgba(26,110,245,.18) }
.ps-card--featured { border-color:var(--ps-blue);box-shadow:0 10px 36px rgba(26,110,245,.26) }
.ps-card--featured:hover { box-shadow:0 24px 64px rgba(26,110,245,.22);transform:translateY(-6px) }
.ps-card--featured::before { content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--ps-blue);z-index:2 }
.ps-card--hidden { opacity:.45;border-style:dashed }
.ps-card--hidden::after { content:'MASQU\00c9';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(239,68,68,.9);color:#fff;padding:6px 16px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.5px;z-index:10 }

/* Ribbon */
.ps-ribbon { position:absolute;top:14px;right:0;z-index:5;font-size:.625rem;font-weight:800;padding:4px 12px 4px 10px;border-radius:4px 0 0 4px;text-transform:uppercase;letter-spacing:.5px;box-shadow:-2px 2px 8px rgba(0,0,0,.12);background:var(--ps-yellow);color:var(--ps-g900) }
.ps-card--featured .ps-ribbon { background:var(--ps-blue);color:#fff }

/* Image */
.ps-card-img { position:relative;overflow:hidden;width:100%;height:190px;background:linear-gradient(150deg,#f4f7ff,#e8eeff);flex-shrink:0 }
@media(min-width:480px){ .ps-card-img{height:200px} }
@media(min-width:600px){ .ps-card-img{height:210px} }
@media(min-width:1024px){ .ps-card-img{height:240px} }
.ps-card--featured .ps-card-img { background:linear-gradient(150deg,#d8e8ff,#c2d7ff) }
.ps-card-img img { position:absolute;inset:20px 0;width:100%;height:calc(100% - 40px);object-fit:contain;object-position:center }
.ps-img-ph { width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px }
.ps-iph-icon { font-size:3rem;opacity:.5 } .ps-iph-label { font-size:.6875rem;color:var(--ps-g300) }
.ps-img-badge { position:absolute;top:10px;left:10px;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.6);border-radius:50px;padding:4px 10px;font-size:.625rem;font-weight:700;color:var(--ps-g700);display:flex;align-items:center;gap:4px;white-space:nowrap;z-index:3 }
.ps-img-bd { width:5px;height:5px;border-radius:50%;background:var(--ps-blue) }
.ps-img-price { position:absolute;bottom:10px;right:10px;background:rgba(10,14,24,.84);backdrop-filter:blur(8px);color:#fff;border-radius:10px;padding:7px 12px;text-align:center;box-shadow:0 4px 14px rgba(0,0,0,.28);z-index:3 }
.ps-ip-from { font-size:.5rem;color:rgba(255,255,255,.45);display:block }
.ps-ip-amount { font-family:var(--ps-display);font-size:1.125rem;font-weight:800;color:var(--ps-yellow);display:block;line-height:1.1 }
.ps-ip-unit { font-size:.5rem;color:rgba(255,255,255,.4);display:block }

/* Body */
.ps-card-body { padding:16px 18px 14px;flex:1;display:flex;flex-direction:column }
@media(min-width:600px){ .ps-card-body{padding:20px 22px 16px} }
.ps-featured-pill { display:none;align-items:center;gap:5px;font-size:.625rem;font-weight:700;color:var(--ps-blue);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px }
.ps-card--featured .ps-featured-pill { display:flex }
.ps-card-name { font-family:var(--ps-display);font-size:1.25rem;font-weight:800;color:var(--ps-g900);line-height:1.1;margin-bottom:7px }
.ps-card--featured .ps-card-name { color:var(--ps-blue) }
.ps-mobile-price { display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--ps-g300);margin-bottom:10px }
.ps-mobile-price strong { font-family:var(--ps-display);font-size:1rem;font-weight:800;color:var(--ps-blue) }
@media(min-width:480px){ .ps-mobile-price{display:none} }
.ps-card-desc { font-size:.875rem;color:var(--ps-g500);line-height:1.6;margin-bottom:14px;flex:1 }
.ps-card-feats { display:flex;flex-direction:column;gap:6px;margin-bottom:14px }
.ps-feat { display:flex;align-items:flex-start;gap:8px;font-size:.8125rem;color:var(--ps-g700);line-height:1.4 }
.ps-feat-check { width:17px;height:17px;border-radius:50%;background:var(--ps-blue-ghost);color:var(--ps-blue);display:flex;align-items:center;justify-content:center;font-size:.5625rem;font-weight:800;flex-shrink:0;margin-top:1px }
.ps-card--featured .ps-feat-check { background:var(--ps-blue);color:#fff }

/* Footer */
.ps-card-footer { padding:12px 18px 16px;border-top:1px solid var(--ps-g100);display:flex;align-items:center;gap:10px }
@media(min-width:600px){ .ps-card-footer{padding:13px 22px 18px} }
.ps-rating { display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--ps-g500) }
.ps-stars { color:var(--ps-yellow);font-size:.75rem;letter-spacing:-1px }
.ps-rating strong { color:var(--ps-g900);font-weight:700;font-size:.8125rem }
.ps-cnt { color:var(--ps-g300) }
.ps-btn-discover { margin-left:auto;background:var(--ps-blue);color:#fff;padding:10px 18px;border-radius:8px;font-size:.875rem;font-weight:700;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all .18s;white-space:nowrap;text-decoration:none;font-family:var(--ps-sans) }
.ps-btn-discover:hover { background:var(--ps-blue-mid);box-shadow:0 8px 24px rgba(26,110,245,.3) }

/* ── Aide banner ── */
.ps-aide { margin-top:20px;background:var(--ps-blue-ghost);border:1.5px solid rgba(26,110,245,.14);border-radius:16px;padding:16px 18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap }
@media(min-width:600px){ .ps-aide{padding:18px 24px;gap:18px} }
@media(min-width:1024px){ .ps-aide{flex-wrap:nowrap;padding:20px 28px} }
.ps-aide-icon { font-size:1.5rem;flex-shrink:0 }
.ps-aide-text { flex:1;min-width:0 }
.ps-aide-title { font-size:.9375rem;font-weight:700;color:var(--ps-g900);margin-bottom:2px }
.ps-aide-sub { font-size:.8125rem;color:var(--ps-g500) }
.ps-btn-aide { flex-shrink:0;background:var(--ps-blue);color:#fff;padding:11px 20px;border-radius:8px;font-size:.875rem;font-weight:700;border:none;cursor:pointer;font-family:var(--ps-sans);transition:all .2s;white-space:nowrap;display:flex;align-items:center;gap:6px;width:100%;justify-content:center }
@media(min-width:480px){ .ps-btn-aide{width:auto} }
.ps-btn-aide:hover { background:var(--ps-blue-mid);box-shadow:0 10px 36px rgba(26,110,245,.26) }
a.ps-btn-aide { text-decoration:none;color:#fff }
a.ps-btn-aide:hover { text-decoration:none;color:#fff }

/* ═══════════════════════════════
   QUIZ MODAL
═══════════════════════════════ */
.ps-overlay { position:fixed;inset:0;z-index:99999;background:rgba(8,14,32,.75);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease }
.ps-overlay.ps-open { opacity:1;pointer-events:all }

.ps-quiz-modal { background:#fff;width:100%;max-width:100%;max-height:96vh;display:flex;flex-direction:column;border-radius:22px 22px 0 0;box-shadow:0 24px 80px rgba(0,0,0,.2);overflow:hidden;transform:translateY(60px);transition:transform .38s cubic-bezier(.22,1,.36,1);position:relative }
.ps-overlay.ps-open .ps-quiz-modal { transform:translateY(0) }
@media(min-width:600px){ .ps-overlay{align-items:center;padding:20px} .ps-quiz-modal{max-width:720px;border-radius:22px;max-height:94vh;transform:scale(.92) translateY(24px)} .ps-overlay.ps-open .ps-quiz-modal{transform:scale(1) translateY(0)} .ps-drag-handle{display:none} }

.ps-drag-handle { flex-shrink:0;display:flex;justify-content:center;padding:10px 0 2px }
.ps-drag-handle span { width:36px;height:4px;background:var(--ps-g100);border-radius:2px }

.ps-modal-close { position:absolute;top:12px;right:12px;width:30px;height:30px;border-radius:50%;background:var(--ps-g50);border:1px solid var(--ps-g100);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.85rem;color:var(--ps-g500);z-index:20;transition:background .15s }
.ps-modal-close:hover { background:var(--ps-g100);color:var(--ps-g900) }

.ps-modal-header { flex-shrink:0;padding:14px 20px 0 }
@media(min-width:600px){ .ps-modal-header{padding:18px 26px 0} }
.ps-qz-eyebrow { display:inline-flex;align-items:center;gap:5px;font-size:.6875rem;font-weight:600;color:var(--ps-blue);text-transform:uppercase;letter-spacing:.6px;background:var(--ps-blue-ghost);border:1px solid rgba(26,110,245,.15);padding:3px 10px;border-radius:50px;margin-bottom:7px }
.ps-modal-title { font-family:var(--ps-display);font-size:1.0625rem;font-weight:800;color:var(--ps-g900);line-height:1.2;margin-bottom:2px }
@media(min-width:600px){ .ps-modal-title{font-size:1.125rem} }
.ps-modal-sub { font-size:.75rem;color:var(--ps-g300);margin-bottom:12px;line-height:1.4 }
.ps-progress { display:flex;gap:5px;margin-bottom:0 }
.ps-prog-track { flex:1;height:3px;background:var(--ps-g100);border-radius:2px;overflow:hidden }
.ps-prog-fill { height:100%;width:0%;background:var(--ps-blue);border-radius:2px;transition:width .45s cubic-bezier(.22,1,.36,1) }
.ps-modal-header::after { content:'';display:block;height:1px;background:var(--ps-g100);margin-top:14px }

.ps-modal-scroll { flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain }
.ps-modal-body { padding:14px 20px 0 }
@media(min-width:600px){ .ps-modal-body{padding:16px 26px 0} }

/* Panels */
.ps-panel { display:none }
.ps-panel--active { display:block;animation:psIn .28s cubic-bezier(.22,1,.36,1) both }
.ps-panel--back { animation:psBack .28s cubic-bezier(.22,1,.36,1) both }
@keyframes psIn { from{opacity:0;transform:translateX(16px)} to{opacity:1;transform:none} }
@keyframes psBack { from{opacity:0;transform:translateX(-16px)} to{opacity:1;transform:none} }

.ps-step-label { display:flex;align-items:center;gap:6px;font-size:.6875rem;font-weight:700;color:var(--ps-g300);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px }
.ps-step-num { width:18px;height:18px;border-radius:50%;background:var(--ps-blue);color:#fff;font-size:.5625rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0 }
.ps-q-text { font-family:var(--ps-display);font-size:.9375rem;font-weight:700;color:var(--ps-g900);margin-bottom:12px;line-height:1.3 }
@media(min-width:600px){ .ps-q-text{font-size:1rem} }

.ps-q-opts { display:flex;flex-direction:column;gap:6px }
@media(min-width:600px){ .ps-q-opts{display:grid;grid-template-columns:1fr 1fr;gap:6px} }
.ps-q-opt { display:flex;align-items:center;gap:10px;padding:9px 36px 9px 11px;border:1.5px solid var(--ps-g100);border-radius:12px;background:var(--ps-snow);cursor:pointer;position:relative;transition:border-color .15s,background .15s;user-select:none }
.ps-q-opt:hover { border-color:rgba(26,110,245,.3);background:var(--ps-blue-ghost) }
.ps-q-opt.ps-selected { border-color:var(--ps-blue);background:var(--ps-blue-ghost);box-shadow:0 0 0 3px rgba(26,110,245,.07) }
.ps-opt-icon { font-size:1.25rem;flex-shrink:0;line-height:1 }
.ps-opt-label { font-size:.875rem;font-weight:600;color:var(--ps-g700) }
.ps-opt-sub { font-size:.75rem;color:var(--ps-g300);margin-top:1px }
.ps-opt-check { position:absolute;right:11px;top:50%;transform:translateY(-50%) scale(0);width:20px;height:20px;background:var(--ps-blue);color:#fff;border-radius:50%;font-size:.6rem;font-weight:800;display:flex;align-items:center;justify-content:center;transition:transform .2s cubic-bezier(.22,1,.36,1);pointer-events:none }
.ps-q-opt.ps-selected .ps-opt-check { transform:translateY(-50%) scale(1) }

/* Result */
.ps-result { display:none }
.ps-result.ps-panel--active { display:block;animation:psIn .3s cubic-bezier(.22,1,.36,1) both }
.ps-res-card { border-radius:20px;padding:16px 15px;display:flex;align-items:flex-start;gap:13px;margin-bottom:11px;border:2px solid var(--ps-blue);background:var(--ps-blue-ghost) }
.ps-res-icon { font-size:1.875rem;flex-shrink:0;line-height:1;margin-top:2px }
.ps-res-body { flex:1;min-width:0 }
.ps-res-tag { display:inline-flex;font-size:.625rem;font-weight:700;padding:2px 8px;border-radius:50px;text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;background:var(--ps-blue);color:#fff }
.ps-res-name { font-family:var(--ps-display);font-size:1.0625rem;font-weight:800;line-height:1.1;margin-bottom:5px;color:var(--ps-blue) }
.ps-res-desc { font-size:.8rem;color:var(--ps-g500);line-height:1.55 }
.ps-res-feats { list-style:none;display:flex;flex-direction:column;gap:5px;margin-top:11px;padding-top:11px;border-top:1px solid rgba(0,0,0,.07) }
.ps-res-feats li { display:flex;align-items:center;gap:7px;font-size:.78rem;color:var(--ps-g700);font-weight:500 }
.ps-res-feat-dot { width:15px;height:15px;border-radius:50%;background:var(--ps-blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.5rem;font-weight:900;flex-shrink:0 }
.ps-res-price { margin-top:11px;display:flex;align-items:baseline;gap:5px;font-size:.78rem;color:var(--ps-g300) }
.ps-res-price strong { font-family:var(--ps-display);font-size:1.25rem;font-weight:800;color:var(--ps-blue) }
.ps-res-note { display:flex;align-items:flex-start;gap:8px;background:var(--ps-g50);border:1px solid var(--ps-g100);border-radius:14px;padding:10px 12px;font-size:.78rem;color:var(--ps-g500);line-height:1.5;margin-bottom:4px }
.ps-note-icon { font-size:.9rem;flex-shrink:0;margin-top:1px }

/* Footer */
.ps-modal-footer { flex-shrink:0;background:#fff;border-top:1px solid var(--ps-g100);padding:12px 20px 16px }
@media(min-width:600px){ .ps-modal-footer{padding:14px 26px 18px} }
.ps-foot-nav { display:flex;align-items:center;gap:9px }
.ps-foot-result { display:none;flex-direction:row;gap:10px;align-items:center }
.ps-btn-back { background:transparent;color:var(--ps-g300);padding:11px 13px;border-radius:8px;font-size:.875rem;font-weight:500;border:1.5px solid var(--ps-g100);cursor:pointer;font-family:var(--ps-sans);transition:all .15s;flex-shrink:0;display:none;align-items:center;gap:4px }
.ps-btn-back.ps-show { display:inline-flex }
.ps-btn-back:hover { border-color:var(--ps-g200);color:var(--ps-g700) }
.ps-btn-next { flex:1;background:var(--ps-blue);color:#fff;padding:13px 18px;border-radius:8px;font-size:.9375rem;font-weight:700;border:none;cursor:pointer;font-family:var(--ps-sans);display:flex;align-items:center;justify-content:center;gap:6px;box-shadow:0 8px 32px rgba(26,110,245,.28);transition:background .15s,box-shadow .15s,transform .15s,opacity .2s }
.ps-btn-next:not(.ps-disabled):hover { background:var(--ps-blue-mid);transform:translateY(-1px) }
.ps-btn-next.ps-disabled { opacity:.32;cursor:not-allowed;box-shadow:none;pointer-events:none }
.ps-btn-devis { flex:1;padding:14px 18px;border-radius:14px;font-size:.9375rem;font-weight:700;border:none;cursor:pointer;font-family:var(--ps-sans);display:flex;align-items:center;justify-content:center;gap:7px;text-decoration:none;transition:all .2s;background:var(--ps-blue);color:#fff;box-shadow:0 8px 32px rgba(26,110,245,.28) }
.ps-btn-devis:hover { background:var(--ps-blue-mid);transform:translateY(-1px) }
.ps-btn-restart { flex-shrink:0;padding:10px 18px;border-radius:8px;font-size:.84375rem;font-weight:500;border:1.5px solid var(--ps-g100);background:transparent;color:var(--ps-g500);cursor:pointer;font-family:var(--ps-sans);transition:all .15s;display:flex;align-items:center;justify-content:center;gap:5px }
.ps-btn-restart:hover { border-color:var(--ps-g200);color:var(--ps-g700) }
