/* FacturXLab — feuille unique. Base : maquette facturxlab_maquette.html. */

:root{
  --paper:#FBFAF7;
  --ink:#16203B;
  --ink-soft:#4A5470;
  --blue:#1E3FAE;
  --blue-deep:#142B7A;
  --line:#E3E1D9;
  --ok:#0E7A4F;
  --ok-bg:#EAF6EF;
  --err:#B3261E;
  --err-bg:#FBEEED;
  --warn:#8A6100;
  --warn-bg:#FBF4E2;
  --code-bg:#101626;
  --code-text:#D8DEF0;
  --radius:10px;
  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*{transition:none!important;animation:none!important}}
body{font-family:var(--font-body);background:var(--paper);color:var(--ink);line-height:1.6;font-size:16px}
a{color:var(--blue)}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}
:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:4px}
.visually-hidden{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* ---------- header ---------- */
header{border-bottom:1px solid var(--line);background:var(--paper);position:sticky;top:0;z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:var(--ink);text-decoration:none;letter-spacing:-.01em}
.logo .x{color:var(--blue)}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{text-decoration:none;color:var(--ink-soft);font-size:.92rem;font-weight:500}
.nav-links a:hover{color:var(--ink)}
.nav-cta{background:var(--blue);color:#fff!important;padding:9px 18px;border-radius:8px;font-weight:600}
.nav-cta:hover{background:var(--blue-deep)}
@media(max-width:720px){.nav-links a:not(.nav-cta){display:none}}

/* ---------- hero ---------- */
.hero{padding:64px 0 24px;text-align:center}
.eyebrow{display:inline-block;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em;color:var(--blue);border:1px solid var(--blue);border-radius:999px;padding:4px 14px;margin-bottom:20px}
h1{font-family:var(--font-display);font-weight:700;font-size:clamp(1.9rem,4.4vw,3rem);letter-spacing:-.02em;line-height:1.12;max-width:760px;margin:0 auto 14px}
.hero p.sub{color:var(--ink-soft);max-width:620px;margin:0 auto;font-size:1.05rem}

/* ---------- validateur ---------- */
.tool{max-width:760px;margin:36px auto 0;padding:0 24px}
.dropzone{border:2px dashed #B9C2DE;border-radius:var(--radius);background:#fff;padding:46px 24px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}
.dropzone:hover,.dropzone.drag{border-color:var(--blue);background:#F4F6FE}
.dropzone .icon{font-size:2rem;display:block;margin-bottom:10px}
.dropzone strong{font-size:1.05rem}
.dropzone .hint{color:var(--ink-soft);font-size:.88rem;margin-top:6px}
.dropzone.busy{pointer-events:none;border-color:var(--blue);background:#F4F6FE}
.spinner{display:none;width:34px;height:34px;margin:0 auto 10px;border:3px solid #C7CFE9;border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.dropzone.busy .spinner{display:block}
.dropzone.busy .icon{display:none}
.tool-actions{display:flex;justify-content:center;gap:14px;margin-top:14px;flex-wrap:wrap}
.btn{font-family:var(--font-body);font-weight:600;font-size:.92rem;border-radius:8px;padding:11px 20px;cursor:pointer;border:1px solid transparent}
.btn-ghost{background:transparent;color:var(--blue);border-color:#C7CFE9}
.btn-ghost:hover{background:#F0F3FC}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-deep)}
.privacy-note{text-align:center;color:var(--ink-soft);font-size:.83rem;margin-top:14px}
.privacy-note .lock{color:var(--ok)}

/* message d'état (erreurs HTTP, fichiers refusés) */
.tool-status{display:none;margin-top:16px;border:1px solid var(--line);border-left:4px solid var(--warn);border-radius:8px;background:var(--warn-bg);padding:13px 16px;font-size:.93rem}
.tool-status.show{display:block}
.tool-status a{font-weight:600}

/* ---------- rapport ---------- */
.report{margin-top:28px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:none}
.report.show{display:block;animation:rise .35s ease}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.verdict{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 26px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.verdict-left{display:flex;flex-direction:column;gap:3px}
.verdict-title{font-family:var(--font-display);font-weight:700;font-size:1.25rem}
.verdict-title.bad{color:var(--err)}
.verdict-title.good{color:var(--ok)}
.verdict-meta{font-family:var(--font-mono);font-size:.78rem;color:var(--ink-soft)}
.stamp{font-family:var(--font-mono);font-weight:500;font-size:.85rem;letter-spacing:.12em;border:2.5px solid var(--err);color:var(--err);padding:8px 16px;border-radius:6px;transform:rotate(-4deg);text-transform:uppercase;background:var(--err-bg)}
.stamp.ok{border-color:var(--ok);color:var(--ok);background:var(--ok-bg)}
.checks{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--line)}
.check{padding:14px 12px;text-align:center;border-right:1px solid var(--line)}
.check:last-child{border-right:none}
.check .name{font-family:var(--font-mono);font-size:.72rem;color:var(--ink-soft);letter-spacing:.04em;display:block}
.check .state{font-weight:600;font-size:.9rem;margin-top:2px;display:block}
.state.pass{color:var(--ok)} .state.fail{color:var(--err)} .state.skip{color:var(--ink-soft)}
@media(max-width:560px){.checks{grid-template-columns:repeat(2,1fr)}.check:nth-child(2){border-right:none}}
.errors{padding:10px 26px 22px}
.errors h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-soft);margin:16px 0 10px}
.errcard{border:1px solid var(--line);border-left:4px solid var(--err);border-radius:8px;padding:14px 16px;margin-bottom:10px;background:#FFFEFC}
.errcard.warn{border-left-color:var(--warn)}
.errhead{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.errhead .meta{font-size:.8rem;color:var(--ink-soft)}
.badge{font-family:var(--font-mono);font-size:.75rem;font-weight:500;background:var(--err-bg);color:var(--err);padding:3px 9px;border-radius:5px;text-decoration:none}
.errcard.warn .badge{background:var(--warn-bg);color:var(--warn)}
.errmsg{font-size:.93rem;margin-top:7px}
.errhint{margin-top:8px;background:#F2F6F1;border-radius:6px;padding:9px 12px;font-size:.9rem;color:#1F4733}
.errhint b{color:var(--ok)}
.errcard details{margin-top:8px}
.errcard summary{font-size:.8rem;color:var(--ink-soft);cursor:pointer}
.errcard code{font-family:var(--font-mono);font-size:.76rem;color:var(--ink-soft);word-break:break-all}
.report-foot{display:flex;justify-content:space-between;align-items:center;padding:14px 26px;background:#FAFAF6;border-top:1px solid var(--line);flex-wrap:wrap;gap:10px}
.report-foot .api-push{font-size:.9rem;color:var(--ink-soft)}
.report-foot .api-push a{font-weight:600}

/* ---------- sections ---------- */
section{padding:72px 0}
.sec-title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,3vw,2.1rem);letter-spacing:-.015em;margin-bottom:8px}
.sec-sub{color:var(--ink-soft);max-width:600px;margin-bottom:36px}

.deadline{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.dates{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:760px){.dates{grid-template-columns:1fr}}
.date-card{border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.date-card .when{font-family:var(--font-mono);font-size:.95rem;color:var(--blue);font-weight:500}
.date-card h3{font-family:var(--font-display);font-size:1.08rem;margin:8px 0 6px}
.date-card p{font-size:.92rem;color:var(--ink-soft)}

/* ---------- API ---------- */
.api-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
@media(max-width:860px){.api-grid{grid-template-columns:1fr}}
.codeblock{background:var(--code-bg);border-radius:var(--radius);padding:20px 22px;font-family:var(--font-mono);font-size:.8rem;line-height:1.65;color:var(--code-text);overflow-x:auto}
.codeblock .c{color:#7E89A9}.codeblock .g{color:#7BD8A8}.codeblock .y{color:#F0CE7A}.codeblock .r{color:#F08A8A}
.api-args{list-style:none;display:flex;flex-direction:column;gap:16px;margin-top:8px}
.api-args li{display:flex;gap:12px;align-items:flex-start}
.api-args .tick{color:var(--ok);font-weight:700;margin-top:2px}
.api-args b{display:block}
.api-args span{color:var(--ink-soft);font-size:.93rem}

/* ---------- pricing ---------- */
.pricing-band{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.plans{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:980px){.plans{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.plans{grid-template-columns:1fr}}
.plan{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;display:flex;flex-direction:column}
.plan.featured{border-color:var(--blue);box-shadow:0 6px 24px rgba(30,63,174,.10);position:relative}
.plan.featured::before{content:"Le plus choisi";position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;font-size:.7rem;font-weight:600;letter-spacing:.05em;padding:3px 12px;border-radius:999px}
.plan h3{font-family:var(--font-display);font-size:1.05rem}
.price{font-family:var(--font-display);font-size:2rem;font-weight:700;margin:10px 0 2px}
.price small{font-size:.85rem;font-weight:400;color:var(--ink-soft)}
.plan ul{list-style:none;margin:16px 0 22px;display:flex;flex-direction:column;gap:9px;font-size:.9rem;color:var(--ink-soft)}
.plan ul li::before{content:"✓ ";color:var(--ok);font-weight:700}
.plan .btn{margin-top:auto;width:100%;text-align:center;background:var(--ink);color:#fff;text-decoration:none;display:block}
.plan .btn:hover{background:#000}
.plan.featured .btn{background:var(--blue)}
.plan.featured .btn:hover{background:var(--blue-deep)}

/* ---------- FAQ ---------- */
.faq{max-width:720px}
.faq details{border-bottom:1px solid var(--line);padding:16px 4px}
.faq summary{font-weight:600;cursor:pointer;font-size:.98rem}
.faq details p{margin-top:10px;color:var(--ink-soft);font-size:.94rem}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:36px 0 44px;font-size:.85rem;color:var(--ink-soft)}
.foot-grid{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}
footer a{color:var(--ink-soft)}
.disclaimer{margin-top:18px;font-size:.78rem;max-width:560px}

/* ---------- modal clé API ---------- */
dialog.keymodal{border:1px solid var(--line);border-radius:var(--radius);padding:0;max-width:430px;width:calc(100% - 40px)}
dialog.keymodal::backdrop{background:rgba(22,32,59,.45)}
.keymodal-inner{padding:26px}
.keymodal h2{font-family:var(--font-display);font-size:1.25rem;margin-bottom:4px}
.keymodal p.lead{color:var(--ink-soft);font-size:.9rem;margin-bottom:18px}
.field{margin-bottom:14px}
.field label{display:block;font-weight:600;font-size:.88rem;margin-bottom:5px}
.field input,.field select{width:100%;padding:10px 12px;border:1px solid #C7CFE9;border-radius:8px;font-family:var(--font-body);font-size:.95rem;background:#fff;color:var(--ink)}
.field input:focus,.field select:focus{outline:3px solid var(--blue);outline-offset:1px}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.keymodal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}
.form-status{margin-top:12px;font-size:.9rem;display:none}
.form-status.ok{display:block;color:var(--ok)}
.form-status.err{display:block;color:var(--err)}

/* ---------- pages légales ---------- */
.legal{max-width:720px;margin:0 auto;padding:48px 24px 72px}
.legal h1{font-size:1.7rem;text-align:left;margin:0 0 24px}
.legal h2{font-family:var(--font-display);font-size:1.1rem;margin:28px 0 8px}
.legal p,.legal li{color:var(--ink-soft);font-size:.95rem}
.legal ul{padding-left:22px}
.legal .back{display:inline-block;margin-bottom:28px;font-size:.9rem}
