/* ============================================================
   COFINA INTERACTIVE COMPONENTS — Sprint 8
   Composants partagés entre les 11 pages secondaires.
   Charge via : <link rel="stylesheet" href="cofina-interactive.css"/>
   ============================================================ */

/* ===== A. SIMU-CARD-V2 (épargne / crédit / cotisation) ===== */
.simu-v2{background:var(--cof-paper);border:1px solid var(--cof-line);border-radius:var(--r-lg,16px);padding:32px;box-shadow:var(--sh-card);position:relative;max-width:520px;margin:0 auto}
.simu-v2-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:12px}
.simu-v2-title{font:600 11px/1 Inter;letter-spacing:.12em;text-transform:uppercase;color:var(--cof-ash)}
.simu-v2-tag{display:inline-flex;align-items:center;gap:6px;font:500 11px/1 Inter;color:var(--cof-red);padding:4px 10px;background:var(--cof-red-soft,#fdecec);border-radius:var(--r-full,999px)}
.simu-v2-field{margin-bottom:18px}
.simu-v2-label{font:500 12px/1 Inter;letter-spacing:.04em;text-transform:uppercase;color:var(--cof-ash);display:block;margin-bottom:8px}
.simu-v2-row{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--cof-cream);border:1px solid var(--cof-line);border-radius:var(--r-sm,8px);transition:border-color .15s ease}
.simu-v2-row:focus-within{border-color:var(--cof-red)}
.simu-v2-input{flex:1;background:none;border:none;outline:none;font:500 24px/1 'JetBrains Mono',monospace;color:var(--cof-graphite);font-variant-numeric:tabular-nums;width:100%;padding:0;min-width:0}
.simu-v2-input::-webkit-outer-spin-button,.simu-v2-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.simu-v2-input[type=number]{-moz-appearance:textfield}
.simu-v2-suffix{font:500 18px/1 'JetBrains Mono',monospace;color:var(--cof-ash)}
.simu-v2-select{flex:1;background:none;border:none;outline:none;font:500 16px/1.2 Inter;color:var(--cof-graphite);cursor:pointer;-webkit-appearance:none;appearance:none;padding-right:24px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10' fill='none' stroke='%231b1b1f' stroke-width='2'><path d='M2 4L5 7L8 4'/></svg>") no-repeat right center/10px}
.simu-v2-slider{width:100%;-webkit-appearance:none;appearance:none;height:4px;background:var(--cof-line);border-radius:2px;outline:none;margin-top:6px}
.simu-v2-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--cof-red);border-radius:50%;cursor:pointer;border:3px solid #fff;box-shadow:0 2px 8px rgba(211,32,39,.4)}
.simu-v2-slider::-moz-range-thumb{width:20px;height:20px;background:var(--cof-red);border-radius:50%;cursor:pointer;border:3px solid #fff;box-shadow:0 2px 8px rgba(211,32,39,.4)}
.simu-v2-output{background:var(--cof-graphite);color:#fff;padding:24px;border-radius:var(--r-md,12px);margin:24px 0 16px}
.simu-v2-output-lbl{font:500 11px/1 Inter;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.simu-v2-output-val{font:600 clamp(28px,4vw,38px)/1 'JetBrains Mono',monospace;color:#fff;margin-top:6px;font-variant-numeric:tabular-nums}
.simu-v2-output-val em{color:var(--cof-red);font-style:normal}
.simu-v2-output-sub{font:400 13px/1.4 Inter;color:rgba(255,255,255,.65);margin-top:8px}
.simu-v2-output-sub strong{color:#fff;font-weight:600}
.simu-v2-output-sub em{color:var(--cof-red);font-style:normal;font-weight:600}
.simu-v2-meta{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0 0 18px}
.simu-v2-meta-item{padding:12px 14px;background:var(--cof-cream);border-radius:var(--r-sm,8px)}
.simu-v2-meta-lbl{font:500 10px/1 Inter;letter-spacing:.1em;text-transform:uppercase;color:var(--cof-ash)}
.simu-v2-meta-val{font:600 18px/1 'JetBrains Mono',monospace;color:var(--cof-graphite);margin-top:4px;font-variant-numeric:tabular-nums}
.simu-v2-meta-val.green{color:#2e7d32}
.simu-v2-cta{width:100%;padding:14px;background:var(--cof-red);color:#fff;border:none;border-radius:var(--r-full,999px);font:600 14px/1 Inter;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.simu-v2-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(211,32,39,.3)}

/* ===== B. COMPARATOR TABLE ===== */
.cmp-wrap{max-width:1180px;margin:60px auto;padding:0 24px}
.cmp-head{text-align:center;margin-bottom:36px}
.cmp-eyebrow{font:600 11px/1 Inter;letter-spacing:.12em;text-transform:uppercase;color:var(--cof-red);margin-bottom:12px;display:inline-block}
.cmp-title{font:italic 500 clamp(28px,3.4vw,44px)/1.1 var(--font-display,'Fraunces',serif);color:var(--cof-graphite);text-wrap:balance}
.cmp-table{width:100%;border-collapse:collapse;background:var(--cof-paper);border:1px solid var(--cof-line);border-radius:var(--r-md,12px);overflow:hidden;box-shadow:var(--sh-card)}
.cmp-table thead th{padding:20px 16px;text-align:left;font:600 13px/1.2 Inter;color:var(--cof-graphite);background:var(--cof-cream);border-bottom:1px solid var(--cof-line);vertical-align:bottom}
.cmp-table thead th:not(:first-child){text-align:center}
.cmp-table thead th.is-best{background:var(--cof-red-soft,#fdecec);position:relative;color:var(--cof-red)}
.cmp-table thead th.is-best::after{content:'★ Recommandé';position:absolute;top:-8px;left:50%;transform:translateX(-50%);background:var(--cof-red);color:#fff;font:600 9px/1 Inter;letter-spacing:.08em;text-transform:uppercase;padding:4px 8px;border-radius:var(--r-full,999px);white-space:nowrap}
.cmp-table tbody td{padding:16px;font:400 14px/1.4 Inter;color:var(--cof-slate);border-bottom:1px solid var(--cof-line);text-align:center;vertical-align:top}
.cmp-table tbody td:first-child{text-align:left;font:500 14px/1.4 Inter;color:var(--cof-graphite);background:var(--cof-cream-soft,#faf7f2)}
.cmp-table tbody td.is-best{background:rgba(211,32,39,.04);font-weight:600;color:var(--cof-graphite)}
.cmp-table tbody tr:last-child td{border-bottom:none}
.cmp-check{color:#2e7d32;font-weight:700}
.cmp-cross{color:#c62828;opacity:.5}
@media(max-width:768px){
  .cmp-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .cmp-table thead th{padding:14px 10px;font-size:11px;min-width:130px}
  .cmp-table thead th:first-child{position:sticky;left:0;background:var(--cof-cream);z-index:1;min-width:120px}
  .cmp-table tbody td{padding:12px 10px;font-size:13px;min-width:130px}
  .cmp-table tbody td:first-child{position:sticky;left:0;z-index:1;min-width:120px}
}

/* ===== C. MODAL ===== */
.modal-backdrop{position:fixed;inset:0;background:rgba(15,15,18,.62);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9998;opacity:0;pointer-events:none;transition:opacity .25s ease}
.modal-backdrop.is-open{opacity:1;pointer-events:auto}
.modal-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-48%) scale(.96);z-index:9999;width:min(720px,calc(100vw - 32px));max-height:88vh;overflow-y:auto;background:var(--cof-paper);border-radius:var(--r-lg,16px);box-shadow:0 24px 80px rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s cubic-bezier(.16,1,.3,1)}
.modal-dialog.is-open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;padding:28px 32px 16px;gap:16px;position:sticky;top:0;background:var(--cof-paper);border-bottom:1px solid var(--cof-line);z-index:1}
.modal-title{font:italic 500 clamp(22px,2.4vw,30px)/1.15 var(--font-display,'Fraunces',serif);color:var(--cof-graphite);margin:0}
.modal-close{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:var(--cof-cream);border:none;cursor:pointer;display:grid;place-items:center;transition:background .15s ease}
.modal-close:hover{background:var(--cof-red-soft,#fdecec)}
.modal-close svg{width:16px;height:16px;color:var(--cof-graphite)}
.modal-body{padding:24px 32px 32px}
.modal-body p{font:400 15px/1.6 Inter;color:var(--cof-slate);margin:0 0 14px}
.modal-body h3{font:600 14px/1 Inter;letter-spacing:.04em;text-transform:uppercase;color:var(--cof-red);margin:24px 0 10px}
.modal-body ul{margin:0 0 14px;padding-left:20px}
.modal-body li{font:400 14px/1.6 Inter;color:var(--cof-slate);margin-bottom:6px}
@media(max-width:640px){
  .modal-dialog{width:calc(100vw - 16px);max-height:92vh;border-radius:var(--r-md,12px)}
  .modal-head{padding:20px 22px 14px}
  .modal-body{padding:18px 22px 22px}
}

/* ===== D. FILTER PILLS ===== */
.fp-wrap{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 32px;align-items:center}
.fp-pill{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;background:var(--cof-cream);border:1px solid var(--cof-line);color:var(--cof-graphite);font:500 13px/1 Inter;border-radius:var(--r-full,999px);cursor:pointer;transition:all .18s ease;white-space:nowrap}
.fp-pill:hover{border-color:var(--cof-red-soft,#fdecec);background:var(--cof-paper)}
.fp-pill.is-active{background:var(--cof-red);color:#fff;border-color:var(--cof-red)}
.fp-pill-count{font-size:11px;opacity:.7;font-variant-numeric:tabular-nums}
.fp-pill.is-active .fp-pill-count{opacity:.85}
.fp-search{flex:1;min-width:200px;padding:9px 16px;border:1px solid var(--cof-line);background:var(--cof-paper);border-radius:var(--r-full,999px);font:400 13px/1 Inter;color:var(--cof-graphite);outline:none;transition:border-color .15s ease}
.fp-search:focus{border-color:var(--cof-red)}
.fp-search::placeholder{color:var(--cof-ash)}
@media(max-width:640px){
  .fp-wrap{gap:6px}
  .fp-pill{padding:7px 12px;font-size:12px}
  .fp-search{padding:8px 14px;font-size:12px;width:100%}
}

/* ===== E. LOAD-MORE BUTTON ===== */
.load-more{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--cof-paper);border:1.5px solid var(--cof-graphite);color:var(--cof-graphite);font:500 14px/1 Inter;border-radius:var(--r-full,999px);cursor:pointer;transition:all .2s ease;margin:32px auto;display:flex}
.load-more:hover{background:var(--cof-graphite);color:#fff}
.load-more.is-hidden{display:none}

/* ===== F. ITEM FADE-IN (used with filters / load-more) ===== */
.filt-item{transition:opacity .25s ease,transform .25s ease}
.filt-item.is-hidden{display:none}
.filt-item.is-enter{opacity:0;transform:translateY(10px)}

/* ===== G. KPI COUNTERS ===== */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;max-width:1180px;margin:60px auto;padding:0 24px}
.kpi-card{background:var(--cof-paper);border:1px solid var(--cof-line);border-radius:var(--r-md,12px);padding:28px 24px;text-align:left}
.kpi-num{font:600 clamp(36px,5vw,56px)/.96 'JetBrains Mono',monospace;color:var(--cof-red);font-variant-numeric:tabular-nums;letter-spacing:-0.02em;display:block}
.kpi-num .kpi-suffix{font-size:.7em;color:var(--cof-graphite);margin-left:4px}
.kpi-lbl{font:500 12px/1.4 Inter;letter-spacing:.06em;text-transform:uppercase;color:var(--cof-ash);margin-top:12px;display:block}

/* ===== H. CHARTS WRAPPER ===== */
.charts-wrap{max-width:1280px;margin:60px auto;padding:0 24px;display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:24px}
.chart-card{background:var(--cof-paper);border:1px solid var(--cof-line);border-radius:var(--r-md,12px);padding:24px;box-shadow:var(--sh-card)}
.chart-card-title{font:600 13px/1.2 Inter;letter-spacing:.06em;text-transform:uppercase;color:var(--cof-graphite);margin-bottom:6px}
.chart-card-sub{font:400 13px/1.4 Inter;color:var(--cof-ash);margin-bottom:18px}
.chart-canvas-wrap{position:relative;height:300px}
.chart-canvas-wrap canvas{max-width:100%}
@media(max-width:640px){.charts-wrap{grid-template-columns:1fr}.chart-canvas-wrap{height:240px}}

/* ===== I. WEST AFRICA SVG MAP ===== */
.map-wrap{max-width:1180px;margin:60px auto;padding:0 24px;display:grid;grid-template-columns:1fr;gap:24px}
.map-svg{width:100%;height:auto;display:block;background:var(--cof-cream);border:1px solid var(--cof-line);border-radius:var(--r-md,12px)}
.map-svg .country{fill:#e8e2d5;stroke:#c9b894;stroke-width:.5;transition:fill .2s ease,opacity .2s ease;cursor:pointer}
.map-svg .country.is-cofina{fill:#f5d4a8}
.map-svg .country:hover{fill:var(--cof-red-soft,#fdecec)}
.map-svg .pin{fill:var(--cof-red);stroke:#fff;stroke-width:2;cursor:pointer;transition:transform .2s ease,filter .2s ease;transform-origin:center;transform-box:fill-box}
.map-svg .pin:hover{filter:drop-shadow(0 4px 12px rgba(211,32,39,.5));transform:scale(1.4)}
.map-svg .pin-label{font:600 11px/1 Inter;fill:var(--cof-graphite);pointer-events:none;text-anchor:middle}
.map-tooltip{position:absolute;background:var(--cof-graphite);color:#fff;padding:10px 14px;border-radius:var(--r-sm,8px);font:500 12px/1.3 Inter;box-shadow:0 4px 12px rgba(0,0,0,.3);pointer-events:none;opacity:0;transition:opacity .15s ease;z-index:100;white-space:nowrap}
.map-tooltip.show{opacity:1}
.map-tooltip strong{display:block;color:#fff;margin-bottom:2px;font-size:13px}
.map-tooltip span{color:rgba(255,255,255,.7);font-size:11px}

/* ===== J. TIMELINE (vertical desktop, horizontal scroll mobile) ===== */
.timeline{max-width:880px;margin:60px auto;padding:0 24px;position:relative}
.timeline::before{content:'';position:absolute;left:31px;top:8px;bottom:8px;width:2px;background:var(--cof-line)}
.timeline-item{position:relative;padding:0 0 0 78px;margin-bottom:32px;cursor:pointer}
.timeline-item::before{content:'';position:absolute;left:24px;top:6px;width:16px;height:16px;border-radius:50%;background:var(--cof-paper);border:3px solid var(--cof-red);box-shadow:0 0 0 4px var(--cof-paper)}
.timeline-item.is-open::before{background:var(--cof-red)}
.timeline-year{font:600 13px/1 'JetBrains Mono',monospace;letter-spacing:.06em;color:var(--cof-red);text-transform:uppercase}
.timeline-title{font:italic 500 clamp(22px,2.4vw,30px)/1.15 var(--font-display,'Fraunces',serif);color:var(--cof-graphite);margin:4px 0 0;transition:color .2s ease}
.timeline-item:hover .timeline-title{color:var(--cof-red)}
.timeline-body{max-height:0;overflow:hidden;transition:max-height .35s ease,margin-top .35s ease;font:400 15px/1.6 Inter;color:var(--cof-slate)}
.timeline-item.is-open .timeline-body{max-height:300px;margin-top:12px}
.timeline-toggle{display:inline-block;margin-top:4px;font:500 11px/1 Inter;color:var(--cof-ash);letter-spacing:.06em;text-transform:uppercase;transition:color .15s ease}
.timeline-item:hover .timeline-toggle{color:var(--cof-red)}

/* ===== K. CAROUSEL (app screenshots) ===== */
.carousel{max-width:1100px;margin:60px auto;padding:0 24px;position:relative}
.carousel-track-wrap{overflow:hidden;border-radius:var(--r-lg,16px);background:var(--cof-cream)}
.carousel-track{display:flex;transition:transform .45s cubic-bezier(.16,1,.3,1);will-change:transform}
.carousel-slide{flex:0 0 100%;min-width:0;padding:40px 24px;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.carousel-slide-info h3{font:italic 500 clamp(22px,2.6vw,32px)/1.15 var(--font-display,'Fraunces',serif);color:var(--cof-graphite);margin:0 0 12px}
.carousel-slide-info p{font:400 15px/1.6 Inter;color:var(--cof-slate)}
.carousel-slide-img{display:grid;place-items:center}
.carousel-slide-img img{max-width:280px;width:100%;height:auto;border-radius:24px;box-shadow:0 20px 60px rgba(0,0,0,.18)}
.carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:18px}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:var(--cof-line);border:none;cursor:pointer;padding:0;transition:background .15s ease,width .15s ease}
.carousel-dot.is-active{background:var(--cof-red);width:28px;border-radius:4px}
.carousel-arrows{position:absolute;top:50%;left:0;right:0;display:flex;justify-content:space-between;padding:0 8px;transform:translateY(-50%);pointer-events:none}
.carousel-arrow{width:44px;height:44px;border-radius:50%;background:var(--cof-paper);border:1px solid var(--cof-line);display:grid;place-items:center;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,.12);pointer-events:auto;transition:transform .15s ease}
.carousel-arrow:hover{transform:scale(1.08)}
.carousel-arrow svg{width:18px;height:18px}
@media(max-width:640px){
  .carousel-slide{grid-template-columns:1fr;padding:24px 16px}
  .carousel-slide-img{order:-1}
  .carousel-slide-img img{max-width:200px}
  .carousel-arrows{display:none}
}

/* ===== L. ORG CHART (gouvernance) ===== */
.org-chart{max-width:1180px;margin:60px auto;padding:0 24px;display:flex;flex-direction:column;align-items:center;gap:36px}
.org-level{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;width:100%;position:relative}
.org-level::before{content:'';position:absolute;top:-22px;left:50%;width:2px;height:22px;background:var(--cof-line)}
.org-level:first-child::before{display:none}
.org-card{background:var(--cof-paper);border:1px solid var(--cof-line);border-radius:var(--r-md,12px);padding:18px 20px;width:240px;cursor:pointer;text-align:center;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.org-card:hover{transform:translateY(-3px);border-color:var(--cof-red-soft,#fdecec);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.org-avatar{width:64px;height:64px;border-radius:50%;background:var(--cof-cream);display:grid;place-items:center;margin:0 auto 10px;font:italic 500 24px/1 var(--font-display,'Fraunces',serif);color:var(--cof-red);overflow:hidden}
.org-avatar img{width:100%;height:100%;object-fit:cover}
.org-name{font:600 14px/1.2 Inter;color:var(--cof-graphite);margin-bottom:4px}
.org-role{font:400 12px/1.3 Inter;color:var(--cof-slate)}

/* ===== M. PRICE TOGGLE (pack-diaspora) ===== */
.price-tog{max-width:720px;margin:48px auto;padding:36px 32px;background:var(--cof-paper);border:1px solid var(--cof-line);border-radius:var(--r-lg,16px);text-align:center;box-shadow:var(--sh-card)}
.price-tog-switch{display:inline-flex;background:var(--cof-cream);border-radius:var(--r-full,999px);padding:4px;margin-bottom:24px;gap:0}
.price-tog-opt{padding:10px 22px;font:500 13px/1 Inter;color:var(--cof-slate);background:none;border:none;cursor:pointer;border-radius:var(--r-full,999px);transition:all .2s ease;white-space:nowrap}
.price-tog-opt.is-active{background:var(--cof-graphite);color:#fff}
.price-tog-amount{font:600 clamp(48px,6vw,68px)/1 'JetBrains Mono',monospace;color:var(--cof-graphite);font-variant-numeric:tabular-nums;letter-spacing:-0.02em;transition:opacity .2s ease}
.price-tog-amount.is-flip{opacity:.3}
.price-tog-amount sup{font-size:.4em;vertical-align:super;margin-left:2px}
.price-tog-period{font:400 14px/1 Inter;color:var(--cof-ash);margin-top:4px;display:block}
.price-tog-saving{display:inline-block;margin-top:16px;padding:6px 14px;background:rgba(46,125,50,.12);color:#2e7d32;font:600 13px/1 Inter;border-radius:var(--r-full,999px)}
.price-tog-detail{margin-top:16px;font:400 13px/1.6 Inter;color:var(--cof-slate)}
