/* ============================================================
   GENSHI — Automatisation & IA : modules graphiques animés
   (en plus de genshi-v3.css + genshi-v4.css ; thème clair)
   ============================================================ */

/* ===== Comparaison À la main / Avec Genshi ===== */
.compare{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:clamp(34px,4vw,52px); }
@media (max-width:780px){ .compare{ grid-template-columns:1fr; } }
.cpanel{ border:1px solid var(--line); border-radius:20px; padding:clamp(24px,3vw,34px); background:var(--bg-2); display:flex; flex-direction:column; gap:16px; }
.cpanel--auto{ border-color:color-mix(in srgb,var(--accent) 50%, var(--line)); background:color-mix(in srgb,var(--accent) 6%, var(--bg-2)); position:relative; }
.cp-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.cp-head h3{ font-family:var(--f-display); font-weight:600; font-size:clamp(18px,2vw,22px); }
.cp-tag{ font-family:var(--f-mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; padding:5px 11px; border-radius:100px; }
.cp-tag.man{ color:var(--dim); background:var(--bg-3); }
.cp-tag.auto{ color:var(--accent-ink); background:var(--accent); }
.cp-tasks{ display:flex; flex-direction:column; }
.ctask{ display:flex; align-items:center; gap:13px; padding:13px 0; border-top:1px solid var(--line-2); }
.ctask:first-child{ border-top:0; }
.ctask .box{ width:21px; height:21px; border-radius:6px; border:1.5px solid var(--dim-2); flex:none; display:grid; place-items:center; transition:border-color .35s var(--ease), background .35s var(--ease); }
.ctask .box svg{ width:13px; height:13px; color:#fff; opacity:0; transform:scale(.4); transition:opacity .3s, transform .3s var(--ease-out); }
.ctask .lbl{ font-size:15px; }
.ctask .t{ margin-left:auto; font-family:var(--f-mono); font-size:12px; color:var(--dim-2); white-space:nowrap; }
.cpanel--auto .ctask.done .box{ background:var(--accent); border-color:var(--accent); }
.cpanel--auto .ctask.done .box svg{ opacity:1; transform:none; }
.cpanel--auto .ctask.done .t{ color:var(--accent); }
.cp-foot{ margin-top:auto; padding-top:16px; border-top:1px solid var(--line); display:flex; align-items:baseline; gap:11px; }
.cp-foot .big{ font-family:var(--f-display); font-weight:600; font-size:clamp(26px,3.4vw,40px); letter-spacing:-.02em; }
.cpanel--manual .cp-foot .big{ color:var(--dim); }
.cpanel--auto .cp-foot .big{ color:var(--accent); }
.cp-foot .cap{ font-family:var(--f-mono); font-size:12px; color:var(--dim); }
.no-anim .cpanel--auto .ctask .box{ background:var(--accent); border-color:var(--accent); }
.no-anim .cpanel--auto .ctask .box svg{ opacity:1; transform:none; }

/* ===== Graphe : heures récupérées ===== */
.gain{ margin-top:clamp(34px,4vw,52px); display:flex; flex-direction:column; gap:15px; max-width:880px; }
.gain-row{ display:grid; grid-template-columns:180px 1fr 70px; gap:18px; align-items:center; }
@media (max-width:620px){ .gain-row{ grid-template-columns:120px 1fr 52px; gap:12px; } }
.gain-row .gl{ font-size:14.5px; }
.gbar{ height:15px; border-radius:100px; background:var(--bg-3); overflow:hidden; }
.gbar i{ display:block; height:100%; width:0; border-radius:100px; background:linear-gradient(90deg,var(--accent-deep),var(--accent)); transition:width 1.1s var(--ease-out); }
.gbar i.fill{ width:var(--w); }
.no-anim .gbar i{ width:var(--w) !important; transition:none !important; }
.gain-row .gv{ font-family:var(--f-mono); font-size:13px; color:var(--accent); text-align:right; }
.gain-total{ margin-top:10px; display:flex; align-items:baseline; gap:14px; flex-wrap:wrap; }
.gain-total .gt{ font-family:var(--f-display); font-weight:600; font-size:clamp(30px,4vw,52px); color:var(--accent); letter-spacing:-.02em; }
.gain-total .gtc{ font-size:15px; color:var(--dim); }
.gain-cap{ font-family:var(--f-mono); font-size:11.5px; color:var(--dim-2); margin-top:16px; }

/* ===== Tuiles cas d'usage (graphiques) ===== */
.tiles{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:clamp(30px,4vw,46px); }
@media (max-width:820px){ .tiles{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .tiles{ grid-template-columns:1fr; } }
.tile{ border:1px solid var(--line); border-radius:16px; background:var(--bg-2); padding:24px; display:flex; flex-direction:column; gap:13px; transition:transform .4s var(--ease-out), box-shadow .4s, border-color .3s; }
.tile:hover{ transform:translateY(-4px); box-shadow:0 22px 44px -26px rgba(20,20,20,.4); border-color:color-mix(in srgb,var(--accent) 40%, var(--line)); }
.tile .tic{ width:46px; height:46px; border-radius:12px; background:color-mix(in srgb,var(--accent) 12%, transparent); color:var(--accent); display:grid; place-items:center; }
.tile .tic svg{ width:24px; height:24px; }
.tile h4{ font-family:var(--f-display); font-weight:600; font-size:17px; }
.tile p{ color:var(--dim); font-size:13.5px; line-height:1.5; }

/* ===== Workflow : ligne de progression + token ===== */
.flow{ position:relative; }
.flow-node.active .fn-ic{ box-shadow:0 0 0 6px color-mix(in srgb,var(--accent) 18%, transparent); }

/* ===== Hero : console « automatisation en direct » ===== */
.spec-chips{ display:flex; flex-wrap:wrap; gap:8px; margin-top:24px; }
.schip{ font-family:var(--f-mono); font-size:12px; color:var(--dim); border:1px solid var(--line); border-radius:100px; padding:7px 13px; }
.schip b{ color:var(--fg); font-weight:500; }
.auto-live{ border:1px solid var(--line); border-radius:18px; background:var(--bg-2); overflow:hidden; box-shadow:0 34px 64px -38px rgba(20,20,20,.45); }
.al-top{ display:flex; align-items:center; gap:10px; padding:14px 18px; border-bottom:1px solid var(--line); font-family:var(--f-mono); font-size:12px; color:var(--dim); }
.al-top .dot3{ display:flex; gap:6px; } .al-top .dot3 i{ width:9px; height:9px; border-radius:50%; background:var(--line); }
.al-live{ margin-left:auto; display:inline-flex; align-items:center; gap:7px; color:var(--accent); }
.al-live .pulse{ width:7px; height:7px; border-radius:50%; background:var(--accent); }
@media (prefers-reduced-motion: no-preference){ .al-live .pulse{ animation:alpulse 1.5s ease-in-out infinite; } }
@keyframes alpulse{ 0%,100%{ opacity:1; transform:scale(1); } 50%{ opacity:.35; transform:scale(.7); } }
.al-body{ padding:16px 18px; display:flex; flex-direction:column; }
.al-line{ display:flex; align-items:center; gap:12px; padding:11px 0; font-size:14.5px; opacity:0; transform:translateY(7px); transition:opacity .45s var(--ease-out), transform .45s var(--ease-out); }
.al-line.show{ opacity:1; transform:none; }
.no-anim .al-line{ opacity:1; transform:none; transition:none; }
.al-ic{ width:23px; height:23px; border-radius:7px; display:grid; place-items:center; flex:none; font-family:var(--f-mono); font-size:13px; }
.al-ic.in{ background:var(--bg-3); color:var(--dim); }
.al-ic.ok{ background:var(--accent); color:#fff; }
.al-ic.ok svg{ width:13px; height:13px; }
.al-foot{ padding:15px 18px; border-top:1px solid var(--line); display:flex; align-items:center; gap:10px; font-family:var(--f-mono); font-size:13px; color:var(--dim); background:color-mix(in srgb,var(--accent) 5%, transparent); }
.al-foot svg{ width:16px; height:16px; color:var(--accent); }
.al-foot b{ color:var(--accent); font-size:15px; }
