/* =========================================================
   [FILE] esim-calculator.css
   ========================================================= */

/* TOKENS & BASE */
:root{
  --color-brand:#1F2A37; --color-accent:#2F6BEF;
  --color-cta:#FF4A3B; --color-cta-hover:#E33C2F;
  --color-surface:#FFFFFF; --color-bg:#F6F7F9;
  --color-border:#E5E7EB; --color-header:#DDECFB;
  --color-text:#1F2A37; --color-muted:#6B7280;
  --radius-sm:10px; --radius-md:14px; --radius-lg:18px; --radius-xl:24px;
  --shadow-soft:0 2px 10px rgba(0,0,0,.04); --shadow-card:0 8px 24px rgba(0,0,0,.06);
  --focus:0 0 0 4px rgba(47,107,239,.35);
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.6}
a{color:var(--color-accent);text-decoration:none} a:hover{text-decoration:underline}

/* HERO */
.hero-simple{max-width:840px;margin:24px auto 6px;text-align:center;padding:0 36px}
.h1{font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-weight:800;letter-spacing:-.02em;font-size:clamp(26px,3.6vw,34px);line-height:1.15;margin:0 0 8px}
.highlight{color:var(--color-accent)}
.lead{color:var(--color-muted);margin:0 auto;max-width:720px}

/* GRID */
.container{max-width:1080px;margin:0 auto;padding:20px 22px}
.grid{display:grid;grid-template-columns:3fr 2fr;gap:16px}
@media (max-width:980px){.grid{grid-template-columns:1fr}}
.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}
.card.pad{padding:18px}

/* TITRES */
.section-title{font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-weight:700;font-size:18px;margin:14px 0 10px}
.hint{font-size:13px;color:var(--color-muted)}
.small{font-size:12px}
.muted{color:var(--color-muted)}
.notice{font-size:13px;color:var(--color-muted)}
.total{font-size:28px;font-weight:800;font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}

/* FORM */
label{font-weight:600}
input[type="number"],select{width:100%;height:42px;padding:0 12px;border:1px solid var(--color-border);border-radius:10px;background:#fff;color:var(--color-text);transition:border-color .15s,box-shadow .15s}
input:focus,select:focus{outline:none;border-color:#8DBCF7;box-shadow:var(--focus)}
.step1-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:4px}
.step1-grid.single .col{max-width:320px}
@media (min-width:720px){.step1-grid{grid-template-columns:1fr}}

/* CHIPS */
.categories{margin:10px 0}
.categories-grid{display:grid;grid-template-columns:1fr;gap:10px}
@media (min-width:640px){.categories-grid{grid-template-columns:repeat(2,1fr)}}
.chip{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;border:1px solid var(--color-border);border-radius:14px;background:#fff;cursor:pointer;box-shadow:var(--shadow-soft);transition:.15s}
.chip svg{width:20px;height:20px;color:var(--color-accent);margin-top:2px}
.chip-text{display:flex;flex-direction:column}
.chip-title{font-weight:700}
.chip-sub{font-size:13px;color:var(--color-muted);margin-top:2px}
.chip[aria-pressed="true"]{background:#EEF4FF;border-color:#D6E6FF}
.chip-xl{padding:12px 14px}
.chip-xl:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.07)}

/* GROUPS & SLIDERS */
.group{margin-top:12px;padding:14px;border:1px dashed var(--color-border);border-radius:var(--radius-md);background:#fff;transition:max-height .25s ease,opacity .15s ease,margin .15s ease,padding .15s ease,border-width .15s ease;max-height:800px;opacity:1}
.group.is-collapsed{display:none !important}
.group legend{font-weight:700;padding:0 6px;margin-bottom:6px}
.group legend svg{width:16px;height:16px;color:var(--color-accent);margin-right:6px;vertical-align:-2px}
.activity{border-top:1px dashed var(--color-border);padding-top:10px;margin-top:10px}
.activity + .activity{margin-top:12px}
.activity-row{display:grid;grid-template-areas:"label" "slider" "num";grid-template-columns:1fr;gap:8px}
.a-label{grid-area:label}
.a-label>.hint{display:block;margin-top:4px}
.slider-col{grid-area:slider}
.num-col{grid-area:num;display:flex;align-items:center;gap:6px;white-space:nowrap;justify-content:flex-end}
@media (min-width:480px){.activity-row{grid-template-areas:"label label" "slider num";grid-template-columns:minmax(180px,1fr) auto;column-gap:12px;align-items:center}}
@media (min-width:720px){.activity-row{grid-template-areas:"label slider num";grid-template-columns:220px minmax(220px,1fr) 110px;column-gap:14px}}
.slider{-webkit-appearance:none;width:100%;height:4px;border-radius:999px;background:#E2E8F0;outline:none}
.slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-accent);border:2px solid #fff;box-shadow:0 0 0 2px rgba(47,107,239,.25);cursor:pointer}
.barline{display:none !important}
.num-input{width:70px;height:32px;padding:0 8px;border:1px solid var(--color-border);border-radius:10px;font-size:14px}
.num-input:focus{outline:none;border-color:#8DBCF7;box-shadow:var(--focus)}
.unit{font-size:13px;color:var(--color-muted);line-height:1}
.alert{margin-top:10px;padding:10px 12px;border-radius:10px;background:rgba(220,38,38,.06);border:1px solid #fecaca;color:#991b1b;font-size:14px}

/* SLIDERS WRAP */
.groups-wrap{min-height:480px;max-height:480px;overflow:auto;padding-right:6px;margin-bottom:6px}
@media (max-width:860px){.groups-wrap{min-height:unset;max-height:unset;overflow:visible}}
.cta-compact{margin-top:6px}
.cta-compact .btn{padding:10px 14px;border-radius:12px}

/* SIDEBAR */
/* [ANCHOR: SIDEBAR] */
.esim-sidebar{background:var(--color-header);border:1px solid #CFE1FB;border-radius:var(--radius-lg);margin:0;width:100%}
.summary{padding:16px}

/* Anti-conflit thème: ignorer la règle globale .sidebar en <1023px */
@media (max-width:1023px){
  .esim-calc .esim-sidebar{width:auto;float:none;display:block}
}

@media (max-width: 860px){
  .summary{display:flex;flex-direction:column;gap:10px}
  .summary canvas#lineChart{order:0}
  .summary .kpis{order:1}
  .summary .total-wrap{order:2}
  .summary .notice{order:3}
  .summary .after-options{order:4}
  .summary .cta-block{order:5;margin-top:14px}
}

.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:8px;align-items:end}
.big{display:flex;gap:6px;align-items:baseline;font-weight:800}
canvas#lineChart{width:100%;min-height:200px;height:220px;display:block;background:#fff;border:1px solid var(--color-border);border-radius:12px;margin-top:6px}

/* Reflow spécifique mobile du panneau droit :
   le CANVAS passe au-dessus de tout le reste */
@media (max-width: 1030px){
  .summary{display:flex;flex-direction:column;gap:10px}
  .summary canvas#lineChart{order:0}
  .summary .kpis{order:1}
  .summary .total-wrap{order:2}
  .summary .notice{order:3}
  .summary .after-options{order:4}
  .summary .cta-block{order:5;margin-top:14px}
}

/* BREAKDOWN BARS */
.mini-bars{display:grid;gap:10px;margin-top:10px}
.bar-row{display:grid;grid-template-columns:1fr;gap:6px}
.bar-meta{display:flex;justify-content:space-between;gap:12px}
.bar-label{color:#334155}
.bar-val{color:#var(--color-muted)}
.bar{height:12px;background:#e5e7eb;border-radius:999px;overflow:hidden}
.bar>span{display:block;height:100%;background:linear-gradient(90deg,#2F6BEF,#8DBCF7)}

/* OPTIONS + CTA */
.after-options{margin-top:16px;padding-top:12px;border-top:1px dashed #BCD0F4}
.opt{min-width:220px}
.opt label{margin-bottom:10px}
.cta-block{margin-top:30px}

/* BOUTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:12px;border:1px solid transparent;cursor:pointer;font-weight:700;font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;transition:.12s}
.btn-cta{background:var(--color-cta);color:#fff;box-shadow:0 8px 18px rgba(255,74,59,.32); text-align: center;}
.btn-cta:hover{background:var(--color-cta-hover)}
.btn.sec{background:transparent;color:var(--color-accent);border:1px solid var(--color-accent)}
.btn.sec:hover{background:rgba(47,107,239,.08)}
.btn-block{width:100%}

/* E-BOOK */
.ebook{margin-top:12px;background:#fff;border:1px solid var(--color-border);border-radius:16px;box-shadow:var(--shadow-card)}
.ebook-badge{display:inline-block;font-size:12px;color:#0f5132;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.35);padding:4px 8px;border-radius:999px;margin-bottom:6px}
.ebook-title{font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-weight:800;font-size:22px;line-height:1.3;margin:4px 0}
.ebook-title span{color:var(--color-accent)}
.ebook-blurb{font-size:14px;color:var(--color-muted);margin:4px 0 10px}
.ebook .btn-cta{width:auto;min-width:260px}

/* MÉTHODO */
.method-detailed{max-width:1080px;margin:26px auto 36px;padding:0 22px}
.method-detailed .h3{font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-weight:800;font-size:22px;margin:0 0 10px;text-align:center}
.method-detailed .lead{max-width:820px;margin:0 auto 14px;text-align:center !important;line-height:1.7}
.method-table{width:100%;border-collapse:separate;border-spacing:0 8px}
.method-table th,.method-table td{background:#fff;border:1px solid var(--color-border);padding:10px 12px}
.method-table th:first-child,.method-table td:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}
.method-table th:last-child,.method-table td:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}
.method-table th{background:#EEF4FF;text-align:left}
/* Masquer la colonne “Exemples” en mobile */
@media (max-width:640px){
  .method-table th:nth-child(3),
  .method-table td:nth-child(3){display:none}
}

/* ACCESSIBILITÉ */
:focus-visible{outline:none;box-shadow:var(--focus)}
