/* ═══════════════════════════════════════════════════
   SaaS Pro Épuré — Générateur de Code-Barres
   Style: Swiss Minimalism · Light + Dark mode
   Palette: Blue #2563EB · Slate · Grey #F8FAFC
   Fonts: Space Grotesk (display) · Inter (body/ui)
═══════════════════════════════════════════════════ */

:root {
  --bg:            #F8FAFC;
  --surface:       #FFFFFF;
  --surface2:      #F1F5F9;
  --border:        #E2E8F0;
  --border-focus:  #2563EB;
  --primary:       #2563EB;
  --primary-hover: #1D4ED8;
  --primary-light: #EFF6FF;
  --primary-border:#BFDBFE;
  --text:          #1E293B;
  --text-2:        #1A2537;
  --muted:         #94A3B8;
  --error:         #DC2626;
  --error-bg:      #FEF2F2;
  --error-border:  #FECACA;
  --radius-xs:     4px;
  --radius-sm:     6px;
  --radius:        10px;
  --radius-lg:     14px;
  --shadow-xs:     0 1px 2px rgba(0,0,0,0.06);
  --shadow-sm:     0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.04);
  --shadow:        0 4px 12px rgba(0,0,0,0.08),0 2px 4px rgba(0,0,0,0.04);
  --font-ui:       'Inter', system-ui, sans-serif;
  --font-hd:       'Space Grotesk', 'Inter', sans-serif;
}

/* ── DARK MODE ── */
[data-theme="dark"] {
  --bg:            #0F172A;
  --surface:       #1E293B;
  --surface2:      #263548;
  --border:        #334155;
  --border-focus:  #60A5FA;
  --primary:       #3B82F6;
  --primary-hover: #2563EB;
  --primary-light: #1E3A5F;
  --primary-border:#1D4ED8;
  --text:          #F1F5F9;
  --text-2:        #B9C8DD;
  --muted:         #64748B;
  --error:         #FCA5A5;
  --error-bg:      #450A0A;
  --error-border:  #7F1D1D;
  --shadow-xs:     0 1px 2px rgba(0,0,0,0.4);
  --shadow-sm:     0 1px 3px rgba(0,0,0,0.5),0 1px 2px rgba(0,0,0,0.3);
  --shadow:        0 4px 12px rgba(0,0,0,0.5),0 2px 4px rgba(0,0,0,0.3);
}
[data-theme="dark"] body { background: var(--bg); }
[data-theme="dark"] ::-webkit-scrollbar-track { background: #0F172A; }
[data-theme="dark"] ::-webkit-scrollbar-thumb { background: #334155; }
[data-theme="dark"] .input-select,
[data-theme="dark"] .input-text,
[data-theme="dark"] .batch-textarea { background: #1A2A3F; color: var(--text); border-color: var(--border); }
[data-theme="dark"] .input-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23B9C8DD' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
}
[data-theme="dark"] .hero-label  { background: var(--primary-light); border-color: var(--primary-border); color: #93C5FD; }
[data-theme="dark"] .preview-wrap { background: #1A2537; border-color: #334155; }
[data-theme="dark"] .preview-wrap.is-transparent { background: repeating-conic-gradient(#263548 0% 25%, #1E293B 0% 50%) 0 0 / 16px 16px; }
[data-theme="dark"] .preview-empty svg { color: #334155; }
[data-theme="dark"] .ad-zone { background: #1A2537; border-color: #334155; color: #334155; }
[data-theme="dark"] .color-divider { background: #334155; }
[data-theme="dark"] .site-footer { background: var(--surface); }
[data-theme="dark"] .format-group-label { color: #64748B; }
[data-theme="dark"] .batch-card { background: #1A2537; border-color: #334155; }
[data-theme="dark"] .batch-results { border-color: #334155; }

/* ── RESET ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { background:var(--bg); color:var(--text); font-family:var(--font-ui); font-size:15px; line-height:1.6; min-height:100vh; -webkit-font-smoothing:antialiased; }
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--primary); }

/* ── LAYOUT ── */
.page-wrap { max-width:1200px; margin:0 auto; padding:0 20px; }
.hidden    { display:none !important; }

/* ── TOP BAR ── */
.top-bar { background:var(--surface); border-bottom:1px solid var(--border); padding:8px 0; }

/* ── AD ZONES ── */
.ad-zone { border:1.5px dashed #CBD5E1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px; background:#FAFBFD; color:#CBD5E1; font-family:var(--font-ui); font-size:0.68rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; border-radius:var(--radius-sm); overflow:hidden; }
.ad-banner-top { width:100%; height:80px; }
.ad-square     { width:100%; max-width:300px; height:250px; }

/* ── HEADER ── */
.site-header { padding:24px 0 8px; }
.breadcrumb { display:flex; align-items:center; gap:6px; font-size:0.75rem; color:var(--muted); margin-bottom:16px; }
.breadcrumb a { color:var(--muted); text-decoration:none; transition:color .15s; }
.breadcrumb a:hover { color:var(--primary); }
.breadcrumb-sep { color:#CBD5E1; }
.hero-label { display:inline-flex; align-items:center; gap:6px; padding:3px 10px; background:var(--primary-light); border:1px solid var(--primary-border); border-radius:999px; font-size:0.7rem; font-weight:600; color:var(--primary); letter-spacing:0.06em; text-transform:uppercase; margin-bottom:12px; }
h1.page-title { font-family:var(--font-hd); font-size:clamp(1.6rem,3.5vw,2.4rem); font-weight:700; color:var(--text); line-height:1.2; letter-spacing:-0.02em; margin-bottom:8px; }
.page-sub { font-size:0.92rem; color:var(--text-2); max-width:580px; line-height:1.65; }

/* ── DASHBOARD ── */
.dashboard { display:grid; grid-template-columns:360px 1fr; gap:20px; align-items:start; margin:24px 0; }
@media(max-width:860px) { .dashboard { grid-template-columns:1fr; } }

/* ── PANEL ── */
.panel { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); overflow:hidden; }
.panel-header { padding:14px 18px; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:8px; }
.panel-title { font-family:var(--font-hd); font-size:0.9rem; font-weight:700; color:var(--text); }
.panel-icon { width:28px; height:28px; background:var(--primary-light); border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; color:var(--primary); flex-shrink:0; }
.panel-body { padding:18px; }

/* ── FIELDS ── */
.field { margin-bottom:18px; }
.field:last-child { margin-bottom:0; }
.field-label { display:block; font-size:0.78rem; font-weight:600; color:var(--text); letter-spacing:0.02em; margin-bottom:7px; }
.field-label-row { display:flex; align-items:center; justify-content:space-between; margin-bottom:7px; }
.char-count { font-size:0.68rem; color:var(--muted); font-weight:500; }
.field-divider { height:1px; background:var(--border); margin:16px 0; }
.format-hint { font-size:0.72rem; color:var(--muted); margin-top:5px; line-height:1.4; }

/* ── INPUT + BTN ── */
.input-text, .input-select, .batch-textarea {
  width:100%; padding:9px 12px; border:1px solid var(--border); border-radius:var(--radius-sm);
  background:var(--surface); color:var(--text); font-family:var(--font-ui); font-size:0.88rem;
  transition:border-color .15s, box-shadow .15s;
}
.input-text:focus, .input-select:focus, .batch-textarea:focus { outline:none; border-color:var(--border-focus); box-shadow:0 0 0 3px rgba(37,99,235,.12); }
.input-text::placeholder, .batch-textarea::placeholder { color:var(--muted); }
.input-select { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 10px center; padding-right:36px; cursor:pointer; }
.input-with-btn { display:flex; gap:8px; align-items:stretch; }
.input-with-btn .input-text { flex:1; }
.input-gen-btn { display:flex; align-items:center; gap:6px; padding:0 12px; background:var(--primary-light); border:1px solid var(--primary-border); border-radius:var(--radius-sm); color:var(--primary); font-family:var(--font-ui); font-size:0.78rem; font-weight:700; cursor:pointer; white-space:nowrap; flex-shrink:0; transition:background .15s, color .15s; }
.input-gen-btn:hover { background:var(--primary); color:#fff; border-color:var(--primary); }
@media(max-width:420px) { .input-gen-btn .gen-label { display:none; } .input-gen-btn { padding:0 10px; } }

/* ── BLACKLIST WARN ── */
.blacklist-warn { display:flex; align-items:center; gap:6px; font-size:0.73rem; color:#B45309; background:#FFFBEB; border:1px solid #FDE68A; border-radius:var(--radius-sm); padding:6px 10px; margin-top:6px; }
[data-theme="dark"] .blacklist-warn { color:#FCD34D; background:#1C1500; border-color:#713F12; }

/* ── FORMAT ZONE — tout visible, pas de scroll ── */
.format-scroll-zone {
  display: block;
}

/* ── FORMAT GROUP LABEL ── */
.format-group-label { font-size:0.68rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; display:block; }

/* ── FORMAT CARDS — compact 2-col ── */
.format-cards { display:flex; flex-direction:column; gap:5px; }
.format-card { display:flex; align-items:center; gap:8px; padding:8px 10px; border:1.5px solid var(--border); border-radius:var(--radius-sm); background:var(--surface2); cursor:pointer; transition:border-color .15s, background .15s; user-select:none; }
.format-card:hover { border-color:var(--primary); background:var(--primary-light); }
.format-card input[type="radio"] { position:absolute; opacity:0; width:0; height:0; }
.format-card:has(input:checked) { border-color:var(--primary); background:var(--primary-light); box-shadow:0 0 0 3px rgba(37,99,235,.08); }
.format-card-body { flex:1; min-width:0; }
.format-card-name { display:block; font-size:0.78rem; font-weight:700; color:var(--text); }
.format-card:has(input:checked) .format-card-name { color:var(--primary); }
.format-card-desc { display:block; font-size:0.65rem; color:var(--text-2); line-height:1.3; }
.format-card-check { color:var(--border); flex-shrink:0; transition:color .15s; }
.format-card:has(input:checked) .format-card-check { color:var(--primary); }

/* ── COLOR ── */
.color-info { display:flex; align-items:flex-start; gap:7px; font-size:0.75rem; color:var(--text-2); background:var(--surface2); border:1px solid var(--border); border-radius:var(--radius-sm); padding:8px 10px; margin-bottom:10px; line-height:1.45; }
.color-info svg { flex-shrink:0; margin-top:1px; color:var(--muted); }
.color-info strong { color:var(--text); font-weight:600; }
.color-row { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.color-chip { width:28px; height:28px; border-radius:var(--radius-sm); border:2px solid transparent; cursor:pointer; transition:transform .15s, box-shadow .15s; flex-shrink:0; }
.color-chip:hover { transform:scale(1.1); }
.color-chip[data-active] { border-color:var(--primary); box-shadow:0 0 0 3px rgba(37,99,235,.2); transform:scale(1.1); }
.color-divider { width:1px; height:22px; background:var(--border); }
.color-picker-wrap { position:relative; width:28px; height:28px; }
.color-picker-btn { width:28px; height:28px; border-radius:var(--radius-sm); border:1.5px solid var(--border); background:conic-gradient(red,yellow,lime,cyan,blue,magenta,red); cursor:pointer; overflow:hidden; }
.color-picker-btn input[type="color"] { position:absolute; opacity:0; width:100%; height:100%; cursor:pointer; }

/* ── CHECKBOX ── */
.check-row { display:flex; align-items:center; gap:9px; cursor:pointer; user-select:none; }
.check-row input[type="checkbox"] { width:16px; height:16px; appearance:none; border:1.5px solid #CBD5E1; border-radius:4px; background:var(--surface); cursor:pointer; flex-shrink:0; transition:background .15s, border-color .15s; position:relative; }
.check-row input[type="checkbox"]:checked { background:var(--primary); border-color:var(--primary); }
.check-row input[type="checkbox"]:checked::after { content:''; position:absolute; top:1px; left:4px; width:5px; height:9px; border:2px solid #fff; border-top:none; border-left:none; transform:rotate(45deg); }
.check-label-text { font-size:0.85rem; color:var(--text); font-weight:500; }

/* ── PREVIEW ── */
.preview-wrap { min-height:180px; display:flex; align-items:center; justify-content:center; background:#FAFBFD; border:1px dashed #CBD5E1; border-radius:var(--radius); margin-bottom:14px; padding:20px; }
.preview-wrap.is-transparent { background:repeating-conic-gradient(#E2E8F0 0% 25%, #fff 0% 50%) 0 0 / 16px 16px; }
.preview-empty { display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--muted); text-align:center; }
.preview-empty svg { color:#CBD5E1; }
.preview-empty p { font-size:0.82rem; line-height:1.5; max-width:200px; }
.preview-content { display:flex; justify-content:center; align-items:center; width:100%; }
.preview-content svg, .preview-content canvas { max-width:100%; height:auto; border-radius:var(--radius-xs); }

/* ── EXPORT CHIPS ── */
.export-section { margin-bottom:12px; }
.export-format-label { font-size:0.72rem; font-weight:700; color:var(--text-2); display:block; margin-bottom:6px; letter-spacing:0.03em; }
.fmt-chips-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; padding-bottom:4px; }
.fmt-chips { display:flex; gap:6px; width:max-content; }
.fmt-btn { display:flex; align-items:center; gap:4px; padding:4px 11px; font-family:var(--font-ui); font-size:0.72rem; font-weight:700; letter-spacing:0.05em; color:var(--text-2); background:var(--surface2); border:1px solid var(--border); border-radius:999px; cursor:pointer; white-space:nowrap; transition:background .15s, color .15s, border-color .15s; }
.fmt-btn:hover { background:var(--primary-light); color:var(--primary); border-color:var(--primary-border); }
.fmt-btn[data-active] { background:var(--primary); color:#fff; border-color:var(--primary); }

/* ── BUTTONS ── */
.btn { display:flex; align-items:center; justify-content:center; gap:7px; padding:10px 16px; border-radius:var(--radius-sm); font-family:var(--font-ui); font-size:0.84rem; font-weight:600; cursor:pointer; transition:background .15s, color .15s, box-shadow .15s, opacity .15s, transform .1s; border:1px solid transparent; letter-spacing:0.01em; }
.btn:active:not(:disabled) { transform:scale(0.98); }
.btn:disabled { opacity:.45; cursor:not-allowed; }
.btn-primary { background:var(--primary); color:#fff; border-color:var(--primary); box-shadow:var(--shadow-xs); }
.btn-primary:hover:not(:disabled) { background:var(--primary-hover); box-shadow:var(--shadow-sm); }
.btn-secondary { background:var(--surface); color:var(--text-2); border-color:var(--border); box-shadow:var(--shadow-xs); }
.btn-secondary:hover:not(:disabled) { background:var(--surface2); color:var(--text); }
.action-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:12px; }
@media(max-width:400px) { .action-row { grid-template-columns:1fr; } }

/* ── ERROR ── */
.error-msg { display:flex; align-items:flex-start; gap:8px; padding:10px 12px; background:var(--error-bg); border:1px solid var(--error-border); border-radius:var(--radius-sm); margin-bottom:14px; font-size:0.8rem; color:var(--error); line-height:1.45; }
.error-msg svg { flex-shrink:0; margin-top:1px; }

/* ── BLACKLIST BAR ── */
.blacklist-bar { display:flex; align-items:center; gap:8px; font-size:0.75rem; color:var(--text-2); background:var(--surface2); border:1px solid var(--border); border-radius:var(--radius-sm); padding:8px 12px; margin-bottom:10px; }
.blacklist-bar svg { color:var(--muted); flex-shrink:0; }
.blacklist-bar span { flex:1; }
.blacklist-clear-btn { font-size:0.72rem; font-weight:700; color:var(--primary); background:none; border:none; cursor:pointer; padding:0; text-decoration:underline; white-space:nowrap; }
.blacklist-clear-btn:hover { color:var(--primary-hover); }

/* ── BATCH ── */
.batch-toggle { width:100%; margin-bottom:12px; justify-content:flex-start; gap:8px; }
.batch-panel { background:var(--surface2); border:1px solid var(--border); border-radius:var(--radius); padding:14px; margin-bottom:12px; }
.batch-textarea { resize:vertical; min-height:100px; font-family:var(--font-ui); font-size:0.85rem; display:block; margin-bottom:8px; }
.batch-results { display:grid; grid-template-columns:repeat(auto-fill, minmax(160px, 1fr)); gap:12px; padding-top:12px; border-top:1px solid var(--border); margin-top:12px; }
@media(max-width:480px) { .batch-results { grid-template-columns:1fr 1fr; } }
@media(max-width:340px) { .batch-results { grid-template-columns:1fr; } }
.batch-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:12px; display:flex; flex-direction:column; gap:8px; }
.batch-card-header { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.batch-num { font-size:0.65rem; font-weight:700; color:var(--muted); background:var(--surface2); padding:1px 6px; border-radius:999px; }
.batch-val { font-size:0.75rem; font-weight:600; color:var(--text); flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.batch-dupl-badge { font-size:0.65rem; font-weight:700; color:#92400E; background:#FEF3C7; border:1px solid #FDE68A; padding:1px 6px; border-radius:999px; white-space:nowrap; }
[data-theme="dark"] .batch-dupl-badge { color:#FCD34D; background:#1C1500; border-color:#713F12; }
.batch-err-badge { font-size:0.65rem; font-weight:700; color:var(--error); background:var(--error-bg); border:1px solid var(--error-border); padding:1px 6px; border-radius:999px; }
.batch-card-error { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.batch-preview-zone { display:flex; justify-content:center; align-items:center; min-height:80px; background:#FAFBFD; border:1px dashed #CBD5E1; border-radius:var(--radius-sm); padding:8px; overflow:hidden; }
[data-theme="dark"] .batch-preview-zone { background:#1A2537; border-color:#334155; }
.batch-preview-svg, .batch-preview-qr { max-width:100%; height:auto; }
.batch-dl-btn { font-size:0.72rem; padding:6px 10px; }

/* ── BATCH CONFIG (nouveau UI format + quantité) ── */
.batch-config-rows { display:flex; flex-direction:column; gap:6px; margin-bottom:10px; }

.batch-row { display:flex; align-items:center; gap:8px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm); padding:8px 10px; }
.batch-row-format { flex:1; font-size:0.82rem; font-weight:600; color:var(--text); }
.batch-row-count { width:64px; flex-shrink:0; padding:5px 8px; border:1px solid var(--border); border-radius:var(--radius-xs); background:var(--surface2); color:var(--text); font-family:var(--font-ui); font-size:0.82rem; text-align:center; }
.batch-row-count:focus { outline:none; border-color:var(--border-focus); }
.batch-row-remove { width:26px; height:26px; flex-shrink:0; display:flex; align-items:center; justify-content:center; background:none; border:1px solid var(--border); border-radius:var(--radius-xs); color:var(--muted); cursor:pointer; transition:color .15s, border-color .15s; }
.batch-row-remove:hover { color:var(--error); border-color:var(--error); }

.batch-add-row { display:flex; align-items:center; gap:8px; }
.batch-add-row .input-select { flex:1; font-size:0.82rem; padding:7px 32px 7px 10px; }
.batch-add-btn { display:flex; align-items:center; gap:5px; padding:7px 12px; background:var(--primary-light); border:1px solid var(--primary-border); border-radius:var(--radius-sm); color:var(--primary); font-size:0.78rem; font-weight:700; cursor:pointer; white-space:nowrap; flex-shrink:0; transition:background .15s, color .15s; }
.batch-add-btn:hover { background:var(--primary); color:#fff; border-color:var(--primary); }

.batch-total-bar { display:flex; align-items:center; justify-content:space-between; font-size:0.75rem; color:var(--text-2); padding:8px 0 10px; border-bottom:1px solid var(--border); margin-bottom:10px; }
.batch-total-num { font-weight:700; color:var(--primary); }
.batch-total-num.over-limit { color:var(--error); }

[data-theme="dark"] .batch-row { background:var(--surface2); }
[data-theme="dark"] .batch-row-count { background:#1A2537; border-color:var(--border); color:var(--text); }

@media(max-width:420px) {
  .batch-add-row { flex-wrap:wrap; }
  .batch-add-row .input-select { width:100%; }
}

/* ── THEME TOGGLE ── */
.theme-toggle-btn { display:inline-flex; align-items:center; gap:6px; padding:5px 12px; background:var(--surface2); border:1px solid var(--border); border-radius:var(--radius-sm); color:var(--text-2); font-family:var(--font-ui); font-size:0.72rem; font-weight:600; letter-spacing:0.05em; text-transform:uppercase; cursor:pointer; transition:border-color .15s, color .15s; white-space:nowrap; }
.theme-toggle-btn:hover { border-color:var(--primary); color:var(--primary); }

/* ── HOW-TO ── */
.howto-strip { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:8px 0 32px; }
@media(max-width:680px) { .howto-strip { grid-template-columns:1fr 1fr; } }
@media(max-width:420px) { .howto-strip { grid-template-columns:1fr; } }
.howto-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:16px; box-shadow:var(--shadow-xs); }
.howto-card-num { font-family:var(--font-hd); font-size:0.65rem; font-weight:700; color:var(--primary); letter-spacing:0.1em; text-transform:uppercase; margin-bottom:6px; }
.howto-card-title { font-size:0.82rem; font-weight:700; color:var(--text); margin-bottom:4px; }
.howto-card-desc { font-size:0.75rem; color:var(--text-2); line-height:1.55; }

/* ── SEO ARTICLE ── */
.seo-article { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:36px 40px; box-shadow:var(--shadow-xs); margin-bottom:40px; }
@media(max-width:640px) { .seo-article { padding:24px 20px; } }
.seo-article-header { border-bottom:1px solid var(--border); padding-bottom:20px; margin-bottom:28px; }
.seo-grid { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
@media(max-width:700px) { .seo-grid { grid-template-columns:1fr; } }
.seo-article h2 { font-family:var(--font-hd); font-size:1.05rem; font-weight:700; color:var(--text); margin-bottom:10px; display:flex; align-items:center; gap:8px; }
.seo-article h2::before { content:''; display:inline-block; width:3px; height:16px; background:var(--primary); border-radius:2px; flex-shrink:0; }
.seo-article p { font-size:0.88rem; color:var(--text-2); line-height:1.75; margin-bottom:14px; }
.seo-article p:last-child { margin-bottom:0; }
.seo-article strong { color:var(--text); font-weight:600; }
.seo-faq { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media(max-width:700px) { .seo-faq { grid-template-columns:1fr; } }
.faq-card { background:var(--surface2); border:1px solid var(--border); border-radius:var(--radius); padding:16px; }
.faq-card h3 { font-size:0.82rem; font-weight:700; color:var(--text); margin-bottom:6px; }
.faq-card p { font-size:0.78rem; color:var(--text-2); line-height:1.6; }

/* ── FOOTER ── */
.site-footer { background:var(--surface); border-top:1px solid var(--border); padding:20px 0; }
.footer-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.footer-copy { font-size:0.75rem; color:var(--muted); }
.footer-links { display:flex; gap:16px; }
.footer-links a { font-size:0.72rem; color:var(--muted); text-decoration:none; transition:color .15s; }
.footer-links a:hover { color:var(--primary); }

/* ── GLOBAL MOBILE ── */
@media(max-width:860px) {
  .page-wrap { padding:0 16px; }
  .site-header { padding:16px 0 6px; }
}

@media(max-width:480px) {
  .page-wrap { padding:0 12px; }
  /* Breadcrumb : texte court + toggle icône seulement */
  .breadcrumb { font-size:0.7rem; gap:4px; }
  .toggle-label { display:none; }
  .theme-toggle-btn { padding:5px 8px; }
  /* H1 */
  h1.page-title { font-size:1.5rem; }
  .page-sub { font-size:0.85rem; }
  /* Panel */
  .panel-body { padding:14px; }
  /* Export chips : permettre wrap sur mobile */
  .fmt-chips { flex-wrap:wrap; width:auto; }
  .fmt-chips-wrap { overflow-x:visible; }
  /* Buttons */
  .btn { font-size:0.8rem; padding:9px 12px; }
  /* Hero label */
  .hero-label { font-size:0.65rem; }
  /* Footer */
  .footer-inner { flex-direction:column; align-items:flex-start; gap:8px; }
}

@media(max-width:360px) {
  .page-wrap { padding:0 8px; }
  h1.page-title { font-size:1.3rem; }
}

/* ── RANGE INPUT (font size slider) ── */
.range-input {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 4px;
  background: var(--border);
  border-radius: 2px;
  cursor: pointer;
  outline: none;
  transition: background .15s;
}
.range-input:hover { background: var(--primary-border); }
.range-input::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--primary);
  cursor: pointer;
  border: 2px solid var(--surface);
  box-shadow: var(--shadow-xs);
  transition: transform .15s;
}
.range-input::-webkit-slider-thumb:hover { transform: scale(1.15); }
.range-input::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--primary);
  cursor: pointer;
  border: 2px solid var(--surface);
}

/* ── FONT SIZE ROW ── */
.font-size-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
}
.font-size-label {
  font-size: 0.72rem;
  color: var(--text-2);
  white-space: nowrap;
  min-width: 72px;
}

/* ── IMPORT FICHIER ── */
.import-drop-zone {
  border: 2px dashed var(--border);
  border-radius: var(--radius);
  padding: 20px 16px;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
  color: var(--muted);
  margin-bottom: 10px;
}
.import-drop-zone:hover,
.import-drop-zone.drag-over {
  border-color: var(--primary);
  background: var(--primary-light);
  color: var(--primary);
}
.import-drop-zone svg { color: var(--border); transition: color .2s; }
.import-drop-zone:hover svg,
.import-drop-zone.drag-over svg { color: var(--primary); }

.import-browse-btn {
  display: inline-flex;
  align-items: center;
  padding: 5px 14px;
  background: var(--primary-light);
  border: 1px solid var(--primary-border);
  border-radius: var(--radius-sm);
  color: var(--primary);
  font-family: var(--font-ui);
  font-size: 0.78rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.import-browse-btn:hover { background: var(--primary); color: #fff; border-color: var(--primary); }

.import-hint {
  font-size: 0.68rem;
  color: var(--muted);
  margin-top: 2px;
  line-height: 1.4;
}

.import-summary-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.78rem;
  color: var(--text-2);
  padding: 6px 0 8px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 8px;
}

.import-items-list {
  max-height: 220px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.import-item-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  align-items: center;
  padding: 6px 8px;
  background: var(--surface2);
  border-radius: var(--radius-xs);
}
[data-theme="dark"] .import-item-row { background: #1A2537; }

.import-item-value {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.import-fmt-select {
  font-size: 0.7rem;
  padding: 3px 22px 3px 7px;
  border: 1px solid var(--border);
  border-radius: var(--radius-xs);
  background: var(--surface);
  color: var(--text);
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 4px center;
  font-family: var(--font-ui);
}
.import-fmt-select:focus { outline: none; border-color: var(--border-focus); }

.import-fmt-badge {
  font-size: 0.62rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 999px;
  background: var(--primary-light);
  color: var(--primary);
  border: 1px solid var(--primary-border);
  white-space: nowrap;
}
.import-fmt-badge.unknown {
  background: var(--error-bg);
  color: var(--error);
  border-color: var(--error-border);
}

/* ── DATA MATRIX canvas sizing ── */
#datamatrixCanvas {
  max-width: 100%;
  height: auto;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}

/* ═══ PRINT ═══ */
@media print {
  .top-bar, header, .howto-strip, .seo-article, .site-footer,
  .dashboard > aside, .panel-header, .export-section, .action-row,
  #adAfterPreview, #errorMsg, #previewEmpty, .blacklist-bar,
  #batchToggleBtn, #batchPanel, #batchResults, .blacklist-warn { display:none !important; }
  body, main, .page-wrap, .dashboard, .dashboard > div, .panel, .panel-body {
    display:block !important; padding:0 !important; margin:0 !important;
    border:none !important; box-shadow:none !important; background:#fff !important; width:100% !important;
  }
  #printZone { display:flex !important; align-items:center; justify-content:center; border:none !important; background:#fff !important; padding:15mm 15mm 25mm !important; min-height:auto !important; }
  #printZone svg, #printZone canvas { display:block; overflow:visible; max-width:100%; height:auto; }
  @page { margin:0; size:auto; }
}
