/* ═══════════════════════════════════════════════════════════
   FACTURATION — Kito Digital  v6 HYBRID
   Cadre : dark brand (#070A12, #7C5CFF, #2EE5FF, Syne)
   Document : light clean (#FFFFFF, DM Sans)
   ═══════════════════════════════════════════════════════════ */

:root{
  /* ── Kito Digital brand ── */
  --kd-primary:#7C5CFF;
  --kd-accent:#2EE5FF;
  --kd-bg:#070A12;
  --kd-bg2:#0B1020;
  --kd-bg3:#111827;
  --kd-text:#EAF0FF;
  --kd-text2:#94A3B8;
  --kd-muted:#64748B;
  --kd-border:rgba(255,255,255,0.08);
  --kd-border-accent:rgba(124,92,255,0.25);
  --kd-glow:rgba(124,92,255,0.25);
  --kd-glow-accent:rgba(46,229,255,0.20);
  --kd-gradient:linear-gradient(135deg,#7C5CFF,#2EE5FF);
  --kd-edge:linear-gradient(90deg,transparent,#7C5CFF,#2EE5FF,transparent);

  /* ── Document (light) ── */
  --doc-bg:#FFFFFF;
  --doc-bg2:#F4F6FA;
  --doc-bg3:#E9ECF2;
  --doc-ink:#111827;
  --doc-ink2:#374151;
  --doc-ink3:#9CA3AF;
  --doc-ink4:#9CA3AF;
  --doc-ink5:#D1D5DB;
  --doc-line:#E5E7EB;
  --doc-line-s:#D1D5DB;
  --doc-hover:#FAFBFD;
  --doc-blue:#2563EB;
  --doc-blue-ring:rgba(37,99,235,0.18);
  --doc-blue-50:#EFF6FF;
  --doc-blue-100:#DBEAFE;
  --doc-cyan:#06B6D4;
  --doc-green:#059669;
  --doc-green-50:#ECFDF5;
  --doc-green-100:#D1FAE5;
  --doc-amber:#D97706;
  --doc-amber-50:#FFFBEB;
  --doc-amber-100:#FEF3C7;
  --doc-red:#EF4444;
  --doc-red-50:#FEF2F2;

  /* ── Shared ── */
  --r-xl:16px;--r-lg:12px;--r-md:8px;--r-sm:6px;--r-full:50px;
  --sh-xs:0 1px 2px rgba(0,0,0,.04);
  --sh-card:0 1px 3px rgba(0,0,0,.04),0 8px 32px rgba(0,0,0,.08);
  --brand:'Syne',system-ui,sans-serif;
  --body:'DM Sans',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{font-family:var(--body);background:var(--kd-bg);color:var(--kd-text);line-height:1.6;min-height:100vh}
::placeholder{color:#9CA3AF !important;font-style:italic;opacity:1}
.mono{font-family:var(--mono);letter-spacing:-.01em}
a{color:var(--kd-accent);text-decoration:none;transition:color .2s}
a:hover{color:#fff}
fieldset{border:none;padding:0;margin:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
:focus-visible{outline:2px solid var(--kd-primary);outline-offset:2px}

/* ═══════════════════════════════════════════════════════════
   BRANDED FRAME — Dark Kito Digital
   ═══════════════════════════════════════════════════════════ */

/* ── TOOLBAR ── */
.toolbar{
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;gap:.75rem;
  padding:.65rem 1.5rem;
  background:rgba(11,16,32,0.85);backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--kd-border);
}
.toolbar__left{display:flex;align-items:center;gap:.75rem}

.toolbar__logo-link{
  display:flex;align-items:center;text-decoration:none;
  transition:opacity .2s;
}
.toolbar__logo-link:hover{opacity:.8}
.toolbar__wordmark{
  font-family:var(--brand);font-weight:800;font-size:1.15rem;
  background:var(--kd-gradient);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  letter-spacing:-.03em;
}

.toolbar__sep{width:1px;height:20px;background:var(--kd-border);margin:0 .1rem}
.toolbar__page-title{font-size:.82rem;font-weight:600;color:var(--kd-text2);letter-spacing:-.01em}

.toolbar__actions{display:flex;gap:.4rem}

.tbtn{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.42rem .75rem;border:1px solid var(--kd-border);border-radius:var(--r-md);
  background:rgba(255,255,255,.04);font-family:var(--body);font-size:.8rem;font-weight:600;
  color:var(--kd-text2);cursor:pointer;transition:all .2s;
}
.tbtn:hover{background:rgba(255,255,255,.08);border-color:var(--kd-border-accent);color:var(--kd-text);transform:translateY(-1px)}
.tbtn:active{transform:translateY(0)}
.tbtn--primary{
  background:var(--kd-primary);border-color:var(--kd-primary);color:#fff;
  box-shadow:0 2px 12px var(--kd-glow);
}
.tbtn--primary:hover{
  background:#8B6FFF;border-color:#8B6FFF;
  box-shadow:0 4px 20px var(--kd-glow);
}

/* ── HERO BANNER ── */
.hero{
  position:relative;overflow:hidden;
  padding:2.5rem 2.5rem 2rem;
  background:var(--kd-bg2);border:1px solid var(--kd-border);border-radius:var(--r-xl);
  max-width:860px;margin:1.5rem auto 0;
}

/* Glows */
.hero__glow{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none}
.hero__glow--purple{top:-80px;right:-80px;width:300px;height:300px;background:radial-gradient(circle,rgba(124,92,255,.18) 0%,transparent 70%)}
.hero__glow--cyan{bottom:-60px;left:-60px;width:250px;height:250px;background:radial-gradient(circle,rgba(46,229,255,.1) 0%,transparent 70%)}

/* Grid pattern */
.hero__grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black 20%,transparent 100%);
}

.hero__content{position:relative;z-index:2;display:flex;flex-direction:column;gap:.85rem}

/* Pill */
.hero__pill{
  display:inline-flex;align-self:flex-start;
  padding:.4rem 1.1rem;border-radius:var(--r-full);
  background:var(--kd-gradient);color:#fff;
  font-family:var(--brand);font-weight:800;font-size:.85rem;
  letter-spacing:.03em;
  box-shadow:0 4px 20px var(--kd-glow);
}

/* Title */
.hero__title{
  font-family:var(--brand);font-weight:800;
  font-size:2rem;line-height:1.1;letter-spacing:-.04em;
  color:var(--kd-text);
}
.hero__title em{
  font-style:normal;
  background:var(--kd-gradient);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
}

/* Sub */
.hero__sub{font-size:.88rem;font-weight:500;color:var(--kd-text2);line-height:1.5}
.hero__sub strong{color:var(--kd-text)}

/* Chips */
.hero__chips{display:flex;gap:.45rem;flex-wrap:wrap;margin-top:.25rem}
.hero__chip{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.35rem .75rem;border-radius:var(--r-full);
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  font-size:.75rem;font-weight:600;color:#CBD5E1;
}
.hero__chip-dot{width:6px;height:6px;border-radius:50%;background:var(--kd-primary)}

/* Bottom */
.hero__bottom{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;flex-wrap:wrap}
.hero__feedback{
  font-size:.78rem;color:var(--kd-muted);font-weight:500;
}
.hero__feedback strong{color:var(--kd-accent);font-weight:700}

/* Edge line */
.hero__edge{
  position:absolute;bottom:0;left:10%;right:10%;height:2px;
  background:var(--kd-edge);border-radius:2px;
}

/* ── DONATE SECTION ── */
.donate-section{
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  max-width:860px;margin:1rem auto;padding:1.5rem 2rem;
  background:var(--kd-bg2);border:1px solid var(--kd-border);border-radius:var(--r-lg);
  position:relative;overflow:hidden;text-align:center;
}
.donate-section::after{
  content:'';position:absolute;left:8%;right:8%;bottom:0;height:1px;
  background:var(--kd-edge);opacity:.4;
}

.donate-section__icon{font-size:1.75rem;line-height:1;margin-bottom:.15rem}

.donate-section__badge{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.25rem .7rem;border-radius:var(--r-full);
  background:rgba(46,229,255,.08);border:1px solid rgba(46,229,255,.15);
  font-size:.68rem;font-weight:700;color:var(--kd-accent);
  text-transform:uppercase;letter-spacing:.04em;
}

.donate-section__title{
  font-family:var(--brand);font-size:1.05rem;font-weight:800;
  color:var(--kd-text);margin:.25rem 0 .15rem;letter-spacing:-.02em;
}

.donate-section__text{
  font-size:.82rem;color:var(--kd-text2);line-height:1.5;margin:0 0 .5rem;
  max-width:380px;
}

.donate-section__paypal{min-height:40px;margin-bottom:.25rem}

.donate-section__fallback{
  display:inline-block;margin-bottom:.25rem;
  transition:transform .25s ease,opacity .25s ease;
}
.donate-section__fallback:hover{transform:translateY(-2px);opacity:.9}
.donate-section__fallback img{display:block;height:47px;width:auto}

.donate-section__secure{
  font-size:.68rem;color:var(--kd-muted);
  display:flex;align-items:center;gap:.3rem;justify-content:center;
}

/* ── SITE FOOTER ── */
.site-footer{max-width:860px;margin:0 auto;padding:2rem 1rem;text-align:center}
.site-footer__inner{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.site-footer__brand{
  font-family:var(--brand);font-weight:800;font-size:1.1rem;
  background:var(--kd-gradient);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  text-decoration:none;letter-spacing:-.02em;
}
.site-footer__links{font-size:.78rem;color:var(--kd-muted);display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}
.site-footer__links a{color:var(--kd-text2);transition:color .2s}
.site-footer__links a:hover{color:var(--kd-accent)}
.site-footer__copy{font-size:.68rem;color:var(--kd-muted)}

/* ═══════════════════════════════════════════════════════════
   DOCUMENT ZONE — Light, clean, professional
   ═══════════════════════════════════════════════════════════ */
.page{max-width:860px;margin:1.5rem auto;padding:0 1rem 1rem}

.doc{
  position:relative;background:var(--doc-bg);color:var(--doc-ink);
  border-radius:var(--r-xl);box-shadow:var(--sh-card),0 0 60px rgba(124,92,255,.08);
  padding:2.5rem 3rem;overflow:hidden;animation:docIn .5s ease;
}
@keyframes docIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* Accent bar — Kito gradient */
.doc__accent{position:absolute;inset:0 0 auto 0;height:4px;background:var(--kd-gradient)}

/* Header */
.doc__header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:.75rem;margin-bottom:1.25rem}
.doc__title-row{display:flex;align-items:center;gap:.75rem}
.doc__title{font-family:var(--body);font-size:1.75rem;font-weight:800;letter-spacing:-.04em;color:var(--doc-ink);line-height:1}

/* Pill switch (doc zone) */
.pill-switch{display:inline-flex;background:var(--doc-bg2);border-radius:var(--r-full);padding:3px;border:1px solid var(--doc-line)}
.pill-switch__btn{
  padding:.28rem .7rem;border:none;border-radius:var(--r-full);
  font-family:var(--body);font-size:.72rem;font-weight:600;
  cursor:pointer;background:transparent;color:var(--doc-ink3);transition:all .2s;white-space:nowrap;
}
.pill-switch__btn.active{background:var(--kd-primary);color:#fff;box-shadow:var(--sh-xs)}
.pill-switch__btn:not(.active):hover{color:var(--doc-ink)}

/* Meta grid */
.doc__meta{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;
  padding:.85rem 1rem;margin-bottom:1.75rem;
  background:var(--doc-bg2);border-radius:var(--r-lg);border:1px solid var(--doc-line);
}
.meta-field{display:flex;flex-direction:column;gap:.2rem}
.meta-field__label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--doc-ink4)}
.meta-field__input{
  font-family:var(--body);font-size:.88rem;font-weight:600;
  color:var(--doc-ink);border:1px solid transparent;border-radius:var(--r-sm);
  padding:.35rem .5rem;background:var(--doc-bg);transition:all .2s;width:100%;
}
.meta-field__input:hover{border-color:var(--doc-line)}
.meta-field__input:focus{outline:none;border-color:var(--kd-primary);box-shadow:0 0 0 3px var(--kd-glow)}

/* Status badge */
.status-badge{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.35rem .85rem;border-radius:var(--r-full);
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;cursor:pointer;user-select:none;transition:all .2s;flex-shrink:0;
}
.status-badge:hover{transform:scale(1.05)}
.status-badge:active{transform:scale(.97)}
.status-badge__dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.status-badge__text{line-height:1}
.status-badge--pending{background:var(--doc-amber-50);border:1px solid var(--doc-amber-100)}
.status-badge--pending,.status-badge--pending .status-badge__text{color:var(--doc-amber)}
.status-badge--pending .status-badge__dot{background:var(--doc-amber);animation:dotPulse 2s ease-in-out infinite}
.status-badge--paid{background:var(--doc-green-50);border:1px solid var(--doc-green-100)}
.status-badge--paid,.status-badge--paid .status-badge__text{color:var(--doc-green)}
.status-badge--paid .status-badge__dot{background:var(--doc-green)}
@keyframes dotPulse{0%,100%{opacity:1}50%{opacity:.4}}

/* Parties */
.doc__parties{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}
.party-card{border:1px solid var(--doc-line);border-radius:var(--r-lg);overflow:hidden;transition:border-color .2s}
.party-card:focus-within{border-color:var(--kd-primary);box-shadow:0 0 0 3px var(--kd-glow)}
.party-card__header{display:flex;align-items:center;gap:.4rem;width:100%;padding:.45rem .75rem;background:var(--doc-bg2);border-bottom:1px solid var(--doc-line)}
.party-card__icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:var(--r-sm);background:rgba(124,92,255,.12);color:var(--kd-primary)}
.party-card__icon--accent{background:rgba(46,229,255,.1);color:var(--kd-accent)}
.party-card__label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--doc-ink3)}
.party-card__fields{padding:.5rem .65rem;display:flex;flex-direction:column;gap:.25rem}

.field-row{display:flex;gap:.3rem}
.field-row--duo{display:grid;grid-template-columns:110px 1fr;gap:.3rem}
.field-row--optional{display:grid;grid-template-columns:1fr 1fr;gap:.3rem}

.field-input{
  font-family:var(--body);font-size:.82rem;font-weight:500;
  color:var(--doc-ink);border:1px solid transparent;border-radius:var(--r-sm);
  padding:.28rem .45rem;background:transparent;transition:all .15s;width:100%;
}
.field-input:hover{border-color:var(--doc-line);background:var(--doc-hover)}
.field-input:focus{outline:none;border-color:var(--kd-primary);box-shadow:0 0 0 2px var(--kd-glow);background:#fff}
.field-input--cp{max-width:110px}
.field-input--siret{font-family:var(--mono);font-size:.76rem}

/* TVA controls */
.doc__controls{
  display:flex;align-items:center;gap:1.5rem;
  padding:.75rem 1rem;margin-bottom:.75rem;
  background:var(--doc-bg2);border-radius:var(--r-lg);border:1px solid var(--doc-line);flex-wrap:wrap;
}
.control-group{display:flex;align-items:center;gap:.6rem}
.control-group__label{font-size:.78rem;font-weight:600;color:var(--doc-ink3)}
.stepper{display:inline-flex;align-items:center;background:var(--doc-bg);border:1px solid var(--doc-line);border-radius:var(--r-sm);overflow:hidden;transition:all .2s}
.stepper:focus-within{border-color:var(--kd-primary);box-shadow:0 0 0 3px var(--kd-glow)}
.stepper__input{width:48px;border:none;background:transparent;font-family:var(--mono);font-size:.85rem;font-weight:500;color:var(--doc-ink);text-align:center;padding:.3rem .2rem;outline:none}
.stepper__input::-webkit-inner-spin-button{opacity:0;width:12px}
.stepper__suffix{font-size:.78rem;font-weight:600;color:var(--doc-ink4);padding-right:.5rem}

.tva-notice{
  display:flex;align-items:center;gap:.5rem;
  padding:.6rem .85rem;margin-bottom:.75rem;
  background:rgba(124,92,255,.06);border:1px solid rgba(124,92,255,.15);border-radius:var(--r-md);
  font-size:.8rem;font-weight:600;color:var(--kd-primary);animation:noticeIn .3s ease;
}
.tva-notice span{color:var(--kd-primary)}
.tva-notice svg{color:var(--kd-primary);flex-shrink:0}
@keyframes noticeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* Table */
.doc__table{margin-bottom:1.25rem}
.items-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.88rem}
.items-table thead th{padding:.55rem .6rem;text-align:left;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--doc-ink4);border-bottom:2px solid var(--doc-line)}
.items-table tbody tr{transition:background .12s}
.items-table tbody tr:hover{background:var(--doc-hover)}
.items-table tbody tr:not(:last-child) td{border-bottom:1px solid var(--doc-bg3)}
.items-table tbody td{padding:.35rem .5rem;vertical-align:middle}
.col-num{width:32px;text-align:center}.col-desc{min-width:160px}.col-qty{width:65px;text-align:center}.col-price{width:100px;text-align:right}.col-total{width:100px;text-align:right}.col-action{width:32px;text-align:center}

.t-input{font-family:var(--body);font-size:.88rem;color:var(--doc-ink);border:1px solid transparent;border-radius:var(--r-sm);padding:.3rem .45rem;background:transparent;transition:all .12s;width:100%}
.t-input:hover{border-color:var(--doc-line);background:var(--doc-bg2)}
.t-input:focus{outline:none;border-color:var(--kd-primary);box-shadow:0 0 0 3px var(--kd-glow);background:#fff}
.t-input--num{text-align:center;width:50px;font-family:var(--mono)}
.t-input--price{text-align:right;width:85px;font-family:var(--mono)}

.line-num{font-size:.72rem;font-weight:600;color:var(--doc-ink5);font-family:var(--mono)}
.line-total{font-weight:600;color:var(--doc-ink);white-space:nowrap;font-family:var(--mono);font-size:.84rem}

.del-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:var(--r-sm);background:transparent;color:var(--doc-ink5);cursor:pointer;transition:all .12s}
.del-btn:hover{background:var(--doc-red-50);color:var(--doc-red)}

.add-line-btn{
  display:flex;align-items:center;justify-content:center;gap:.4rem;
  width:100%;padding:.55rem;margin-top:.3rem;
  background:transparent;color:var(--kd-primary);
  border:1.5px dashed rgba(124,92,255,.25);border-radius:var(--r-md);
  font-family:var(--body);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;
}
.add-line-btn:hover{background:rgba(124,92,255,.04);border-color:var(--kd-primary)}

/* Totaux */
.doc__summary{display:flex;justify-content:flex-end;margin-bottom:1.5rem}
.totals-card{width:260px;padding:.85rem 1rem;background:var(--doc-bg2);border-radius:var(--r-lg);border:1px solid var(--doc-line)}
.totals-card__row{display:flex;justify-content:space-between;align-items:center;padding:.3rem 0;font-size:.85rem}
.totals-card__label{color:var(--doc-ink3)}
.totals-card__value{color:var(--doc-ink)}
.totals-card__rate{font-family:var(--mono);font-weight:600}
.totals-card__divider{height:1px;background:var(--doc-line-s);margin:.4rem 0}
.totals-card__row--total{font-size:1.05rem;font-weight:800}
.totals-card__row--total .totals-card__label{color:var(--doc-ink)}
.totals-card__row--total .totals-card__value{color:var(--kd-primary)}

/* Notes */
.doc__notes{margin-bottom:1.5rem}
.section-label{display:block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--doc-ink4);margin-bottom:.35rem}
.notes-area{font-family:var(--body);font-size:.82rem;color:var(--doc-ink2);line-height:1.6;border:1px solid var(--doc-line);border-radius:var(--r-md);padding:.55rem .75rem;background:var(--doc-bg);resize:vertical;width:100%;transition:all .2s}
.notes-area:hover{border-color:var(--doc-line-s)}
.notes-area:focus{outline:none;border-color:var(--kd-primary);box-shadow:0 0 0 3px var(--kd-glow)}

/* Doc footer */
.doc__footer{text-align:center;padding-top:1rem;border-top:1px solid var(--doc-line);font-size:.72rem;color:var(--doc-ink4)}
.doc__footer a{font-weight:700;color:var(--kd-primary)}
.doc__footer a:hover{color:var(--kd-accent);text-decoration:underline}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media(max-width:720px){
  .page{margin:.75rem auto;padding:0 .5rem 1rem}
  .doc{padding:1.25rem 1rem;border-radius:var(--r-lg)}
  .toolbar{padding:.5rem .75rem}
  .toolbar__actions{gap:.25rem}
  .tbtn span{display:none}
  .tbtn{padding:.42rem .5rem}
  .doc__header{flex-direction:column;align-items:flex-start;gap:.6rem}
  .doc__title{font-size:1.35rem}
  .doc__title-row{flex-wrap:wrap;gap:.5rem}
  .doc__meta{grid-template-columns:1fr;gap:.5rem;padding:.65rem .75rem}
  .doc__parties{grid-template-columns:1fr;gap:.75rem}
  .field-row--duo{grid-template-columns:90px 1fr}
  .field-row--optional{grid-template-columns:1fr}
  .doc__controls{flex-direction:column;align-items:flex-start;gap:.6rem;padding:.65rem .75rem}
  .doc__table{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .items-table{min-width:480px}
  .col-desc{min-width:120px}
  .doc__summary{justify-content:stretch}
  .totals-card{width:100%}
  .hero{margin:1rem .5rem 0;padding:1.25rem 1rem .85rem}
  .hero__title{font-size:1.4rem}
  .hero__sub{font-size:.8rem}
  .hero__chips{gap:.35rem}
  .hero__chip{font-size:.68rem;padding:.28rem .6rem}
  .donate-section{padding:1rem;margin:.75rem .5rem}
  .site-footer{padding:1.5rem .5rem}
}
@media(max-width:400px){
  .doc{padding:1rem .75rem}
  .doc__title{font-size:1.15rem}
  .pill-switch__btn{padding:.22rem .5rem;font-size:.65rem}
  .status-badge{padding:.25rem .6rem;font-size:.65rem}
  .field-input{font-size:.78rem;padding:.25rem .4rem}
  .toolbar__page-title{display:none}
  .toolbar__sep{display:none}
}

/* ═══════════════════════════════════════════════════════════
   PRINT A4
   ═══════════════════════════════════════════════════════════ */
@media print{
  .no-print{display:none !important}
  body{background:#fff !important;-webkit-print-color-adjust:exact;print-color-adjust:exact;font-size:11pt;color:#111827}
  .page{margin:0;padding:0;max-width:none}
  .doc{box-shadow:none !important;border-radius:0;padding:12mm 15mm 10mm 15mm;animation:none !important;overflow:visible}
  .doc__accent{height:2px}
  .doc__header{margin-bottom:.6rem;padding-top:.3rem}
  .doc__title{font-size:1.4rem}
  .doc__meta{padding:.5rem .7rem;margin-bottom:1rem;background:#F4F6FA !important;border-color:#E5E7EB !important;page-break-inside:avoid}
  .status-badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .status-badge--pending{background:#FFFBEB !important;border-color:#FEF3C7 !important}
  .status-badge--pending,.status-badge--pending .status-badge__text{color:#D97706 !important;-webkit-text-fill-color:#D97706 !important}
  .status-badge--pending .status-badge__dot{background:#D97706 !important;animation:none}
  .status-badge--paid{background:#ECFDF5 !important;border-color:#D1FAE5 !important}
  .status-badge--paid,.status-badge--paid .status-badge__text{color:#059669 !important;-webkit-text-fill-color:#059669 !important}
  .status-badge--paid .status-badge__dot{background:#059669 !important}
  .field-input,.meta-field__input,.t-input,.notes-area{color:#111827 !important;-webkit-text-fill-color:#111827 !important;border:none !important;box-shadow:none !important;background:transparent !important;padding-left:0 !important}
  .doc__parties{gap:.6rem;margin-bottom:1rem}
  .party-card{border-color:#E5E7EB;box-shadow:none !important;page-break-inside:avoid}
  .party-card:focus-within{box-shadow:none !important}
  .party-card__icon{background:rgba(124,92,255,.12) !important}
  .party-card__icon--accent{background:rgba(46,229,255,.1) !important}
  .party-card__fields{padding:.4rem .65rem;gap:.15rem}
  .field-input{padding:.15rem 0}
  .tva-notice{background:rgba(124,92,255,.06) !important;border-color:rgba(124,92,255,.15) !important;margin-bottom:.6rem;padding:.45rem .7rem}
  .tva-notice,.tva-notice span,.tva-notice svg{color:#7C5CFF !important;-webkit-text-fill-color:#7C5CFF !important}
  .doc__table{margin-bottom:.8rem}
  .items-table thead th{padding:.4rem .5rem;font-size:.6rem}
  .items-table tbody td{padding:.3rem .5rem}
  .items-table tbody tr:hover{background:transparent}
  .col-action{display:none}
  .doc__summary{margin-bottom:1rem}
  .totals-card{background:#F4F6FA !important;border-color:#E5E7EB !important;padding:.6rem .85rem}
  .totals-card__label{color:#9CA3AF !important;-webkit-text-fill-color:#9CA3AF !important}
  .totals-card__value{color:#111827 !important;-webkit-text-fill-color:#111827 !important}
  .totals-card__row--total .totals-card__label{color:#111827 !important;-webkit-text-fill-color:#111827 !important}
  .totals-card__row--total .totals-card__value{color:#7C5CFF !important;-webkit-text-fill-color:#7C5CFF !important}
  .doc__notes{margin-bottom:.8rem}
  .notes-area{padding:.35rem 0;border:none !important;background:transparent !important}
  .doc__footer{padding-top:.6rem;font-size:.65rem}
  .doc__footer a{color:#7C5CFF !important;-webkit-text-fill-color:#7C5CFF !important}
  .doc__parties,.doc__table,.doc__summary,.doc__notes{page-break-inside:avoid}
}

/* ═══════════════════════════════════════════════════════════
   PDF MODE
   ═══════════════════════════════════════════════════════════ */
.pdf-mode{box-shadow:none !important;animation:none !important}
.pdf-mode *{animation:none !important;transition:none !important;backdrop-filter:none !important;-webkit-backdrop-filter:none !important}
.pdf-mode .field-input,.pdf-mode .meta-field__input,.pdf-mode .t-input,.pdf-mode .notes-area{color:#111827 !important;-webkit-text-fill-color:#111827 !important;opacity:1 !important;border:none !important;box-shadow:none !important;background:transparent !important}
.pdf-mode .doc__title{color:#111827 !important;-webkit-text-fill-color:#111827 !important}
.pdf-mode .meta-field__label,.pdf-mode .section-label{color:#9CA3AF !important;-webkit-text-fill-color:#9CA3AF !important}
.pdf-mode .party-card__label{color:#9CA3AF !important;-webkit-text-fill-color:#9CA3AF !important}
.pdf-mode .items-table thead th{color:#9CA3AF !important;-webkit-text-fill-color:#9CA3AF !important}
.pdf-mode .line-num{color:#D1D5DB !important;-webkit-text-fill-color:#D1D5DB !important}
.pdf-mode .line-total{color:#111827 !important;-webkit-text-fill-color:#111827 !important}
.pdf-mode .totals-card{background:#F4F6FA !important;border-color:#E5E7EB !important;box-shadow:none !important}
.pdf-mode .totals-card__label{color:#9CA3AF !important;-webkit-text-fill-color:#9CA3AF !important}
.pdf-mode .totals-card__value{color:#111827 !important;-webkit-text-fill-color:#111827 !important}
.pdf-mode .totals-card__row--total .totals-card__label{color:#111827 !important;-webkit-text-fill-color:#111827 !important}
.pdf-mode .totals-card__row--total .totals-card__value{color:#7C5CFF !important;-webkit-text-fill-color:#7C5CFF !important}
.pdf-mode .status-badge--pending{background:#FFFBEB !important;border-color:#FEF3C7 !important}
.pdf-mode .status-badge--pending,.pdf-mode .status-badge--pending .status-badge__text{color:#D97706 !important;-webkit-text-fill-color:#D97706 !important}
.pdf-mode .status-badge--pending .status-badge__dot{background:#D97706 !important}
.pdf-mode .status-badge--paid{background:#ECFDF5 !important;border-color:#D1FAE5 !important}
.pdf-mode .status-badge--paid,.pdf-mode .status-badge--paid .status-badge__text{color:#059669 !important;-webkit-text-fill-color:#059669 !important}
.pdf-mode .status-badge--paid .status-badge__dot{background:#059669 !important}
.pdf-mode .tva-notice{background:rgba(124,92,255,.06) !important;border-color:rgba(124,92,255,.15) !important}
.pdf-mode .tva-notice,.pdf-mode .tva-notice span,.pdf-mode .tva-notice svg{color:#7C5CFF !important;-webkit-text-fill-color:#7C5CFF !important}
.pdf-mode .doc__footer,.pdf-mode .doc__footer p{color:#9CA3AF !important;-webkit-text-fill-color:#9CA3AF !important}
.pdf-mode .doc__footer a{color:#7C5CFF !important;-webkit-text-fill-color:#7C5CFF !important}
.pdf-mode .party-card{border-color:#E5E7EB !important;box-shadow:none !important}
.pdf-mode .party-card__header{background:#F4F6FA !important}
.pdf-mode .party-card__icon{background:rgba(124,92,255,.12) !important;color:#7C5CFF !important}
.pdf-mode .party-card__icon--accent{background:rgba(46,229,255,.1) !important;color:#06B6D4 !important}
.pdf-mode .doc__accent{background:linear-gradient(135deg,#7C5CFF,#2EE5FF) !important;height:4px}
.pdf-mode .doc__meta{background:#F4F6FA !important;border-color:#E5E7EB !important}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms !important;transition-duration:.001ms !important}}