*{margin:0;padding:0;box-sizing:border-box}
:root{
  --primary:#2563eb;
  --primary-dark:#1d4ed8;
  --bg:#f8f9fa;
  --surface:#fff;
  --text:#1a1a1a;
  --text-dim:#6b7280;
  --border:#e5e7eb;
  --success:#10b981;
  --danger:#ef4444;
  --sidebar-w:182px;
  --header-h:68px;
}
html,body{height:100%}
body{
  font-family:'Inter','Segoe UI',sans-serif;
  background:var(--bg);
  color:var(--text);
}

/* Header */
.header{
  background:#fff;
  border-bottom:2px solid var(--border);
  height:var(--header-h);
  padding:0 24px;
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;
}
.header-content{
  display:flex;justify-content:space-between;align-items:center;
  width:100%;
}
.logo{
  font-size:26px;font-weight:900;color:var(--primary);
  text-decoration:none;letter-spacing:-0.5px;
}
.header-right{display:flex;align-items:center;gap:20px}
.user-info{text-align:right}
.user-name{font-weight:700;font-size:14px}
.build-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.logout-btn{
  font-size:10px;color:var(--text-dim);
  background:none;border:1px solid var(--border);
  border-radius:6px;padding:3px 8px;cursor:pointer;
  font-weight:600;transition:all .15s;
}
.logout-btn:hover{background:#fee2e2;color:#991b1b;border-color:#ef4444}
.build-line{font-size:10px;color:var(--text-dim)}
.version-line{font-size:9px;color:var(--text-dim);opacity:.7}
.dev-badge{color:#198754;font-weight:700;margin-left:4px}

/* Layout */
.layout{
  display:flex;
  min-height:calc(100vh - var(--header-h));
}

/* Sidebar */
.sidebar{
  width:var(--sidebar-w);
  background:#fff;
  border-right:2px solid var(--border);
  padding:16px 0;
  flex-shrink:0;
  display:flex;flex-direction:column;
}
.config-link{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;text-decoration:none;color:var(--text);
  font-size:15px;font-weight:700;
  border-top:1px solid var(--border);
  transition:background .15s;
  margin-top:auto;
}
.config-link:hover{background:var(--bg)}
.config-link.active{background:#eff6ff;color:var(--primary)}
.config-icon{font-size:22px;line-height:1}
.menu-group{border-bottom:1px solid var(--border)}
.menu-group-title{
  display:flex;align-items:center;gap:10px;
  width:100%;padding:10px 16px;
  background:none;border:none;cursor:pointer;
  font-family:inherit;
  text-align:left;
  transition:background .15s;
}
.menu-group-title:hover{background:var(--bg)}
.menu-logo{
  width:36px;height:36px;border-radius:8px;
  flex-shrink:0;object-fit:contain;background:#008859;padding:4px;
}
.menu-group[data-insurer="gan"] .menu-logo,
.menu-group[data-insurer="spvie"] .menu-logo{
  background:transparent;border:0;padding:0;object-fit:contain;
  width:auto;max-width:60px;
}
.menu-logo-fallback{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--primary);color:#fff;
  font-weight:800;font-size:18px;
}
.menu-group-name{
  flex:1;font-size:18px;font-weight:700;color:var(--text);
}
.menu-chevron{
  font-size:35px;color:var(--text-dim);line-height:1;
  transition:transform .2s;
}
.menu-group.open .menu-chevron{transform:rotate(90deg)}
.menu-group-items{
  overflow:hidden;max-height:0;
  transition:max-height .25s ease;
}
.menu-group.open .menu-group-items{max-height:600px}
.menu-item{
  display:block;padding:10px 12px 10px 44px;
  text-decoration:none;color:var(--text);
  font-size:15px;font-weight:500;
  border-left:3px solid transparent;
  transition:all .15s;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.menu-item:hover{background:var(--bg);color:var(--primary)}
.menu-item.active{
  background:#eff6ff;color:var(--primary);
  border-left-color:var(--primary);font-weight:700;
}

/* Content */
.content{flex:1;padding:24px 32px;overflow-x:auto;min-width:0}

/* Scrap page */
.scrap-header{
  display:flex;justify-content:space-between;align-items:center;
  gap:16px;margin-bottom:20px;flex-wrap:nowrap;min-width:0;
}
.scrap-title{display:flex;align-items:center;gap:12px;flex-shrink:1;min-width:0;overflow:hidden}
.scrap-title h1{font-size:15px}
.scrap-title-logo{
  width:40px;height:40px;border-radius:8px;
  background:#008859;padding:5px;object-fit:contain;
}
/* GAN : logo déjà sur fond blanc dans le JPG, on remplit le conteneur */
.scrap-title-logo[alt="Gan"]{
  background:transparent;padding:0;object-fit:cover;
}
.scrap-creds{
  display:flex;align-items:flex-end;gap:10px;flex-wrap:nowrap;flex-shrink:0;
}
.scrap-creds label{
  display:flex;flex-direction:column;gap:2px;
  font-size:10px;font-weight:700;text-transform:uppercase;color:var(--text-dim);
}
.scrap-creds input{
  padding:7px 10px;border:1.5px solid var(--border);
  border-radius:6px;font-size:13px;font-family:inherit;
  background:#fff;
}
.scrap-creds input:focus{outline:none;border-color:var(--primary)}
.scrap-creds input[type=text]#credUrl{width:160px}
.scrap-creds input#credUser{width:140px}
.scrap-creds input#credPassword{width:120px;padding-right:32px}
.pwd-wrap{position:relative;display:inline-block}
.pwd-eye{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;font-size:16px;
  padding:2px 4px;color:var(--text-dim);
}
.pwd-eye:hover{color:var(--primary)}
.btn-scrap{
  background:var(--primary);color:#fff;border:none;
  padding:10px 22px;border-radius:8px;
  font-size:15px;font-weight:700;cursor:pointer;
  transition:background .15s;
}
.btn-scrap:hover:not(:disabled){background:var(--primary-dark)}
.btn-scrap:disabled{opacity:.6;cursor:not-allowed}
.btn-scrap.scraping .pct{color:#ef4444;font-weight:900}
.btn-scrap.scraping:hover{background:#991b1b}
.btn-scrap.scraping:hover .pct{color:#fff}
.btn-scrap.scraping:hover::after{content:' ✕ annuler';color:#fff;font-weight:700}
.btn-pause-exec{background:#f59e0b;margin-left:8px}
.btn-pause-exec:hover{background:#d97706}
.btn-pause-exec.paused{background:#10b981}
.btn-pause-exec.paused:hover{background:#059669}

.scrap-grid{
  display:flex;align-items:stretch;
  gap:0;height:calc(100vh - var(--header-h) - 110px);
  min-height:500px;
}
.scrap-col{
  background:#fff;border:1px solid var(--border);border-radius:10px;
  padding:14px;display:flex;flex-direction:column;min-width:100px;overflow:hidden;
  flex:1 1 0;
}
.scrap-col-controls{flex:0 0 220px}
.scrap-col-view{flex:2 1 0}
.scrap-col:last-child{flex:0 0 260px}
.col-splitter{
  flex:0 0 8px;
  cursor:col-resize;
  background:transparent;
  position:relative;
  transition:background .15s;
}
.col-splitter::before{
  content:'';position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:2px;height:40px;background:var(--border);border-radius:1px;
  transition:background .15s;
}
.col-splitter:hover::before{background:var(--primary);height:80px}
.col-head{display:flex;justify-content:flex-start;align-items:center;gap:10px;margin-bottom:10px}
.scrap-col h3{
  font-size:13px;font-weight:800;text-transform:uppercase;
  letter-spacing:0.3px;color:var(--text-dim);
}
.btn-copy{
  background:none;border:1px solid var(--border);border-radius:6px;
  padding:3px 8px;cursor:pointer;font-size:14px;
  transition:all .15s;
}
.btn-copy:hover{background:var(--bg);border-color:var(--primary)}
.col-actions{display:flex;gap:6px;align-items:center}
.btn-expand{font-family:'Consolas','Monaco',monospace;font-size:12px;font-weight:700;display:none}
.btn-expand.expanded{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-expand.expanded:hover{background:var(--primary-dark)}

.resp-flags{display:flex;gap:6px;align-items:center}
.flag-btn{
  border:1px solid var(--border);border-radius:6px;
  padding:3px 7px;cursor:pointer;font-size:12px;font-weight:700;
  background:#f3f4f6;color:#9ca3af;
  transition:all .15s;
  display:inline-flex;align-items:center;gap:3px;
}
.flag-btn:disabled{cursor:not-allowed;opacity:.55}
.flag-btn.warn.active{background:#f59e0b;color:#fff;border-color:#f59e0b}
.flag-btn.err.active{background:#ef4444;color:#fff;border-color:#ef4444}
.flag-btn.warn.active:hover{background:#d97706}
.flag-btn.err.active:hover{background:#dc2626}
.scrap-col h4{font-size:12px;font-weight:700;margin:10px 0 4px;color:var(--text-dim)}
.scrap-col-controls{overflow-y:auto}
.scrap-col-controls label{
  display:block;font-size:11px;font-weight:700;text-transform:uppercase;
  color:var(--text-dim);margin:8px 0 3px;
}
.scrap-col-controls input,
.scrap-col-controls select{
  width:100%;padding:7px 10px;border:1.5px solid var(--border);
  border-radius:6px;font-size:13px;font-family:inherit;background:#fff;
}
.scrap-col-controls input:focus,
.scrap-col-controls select:focus{outline:none;border-color:var(--primary)}

.garanties-head{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.garanties-head label{margin:0 !important}
.btn-sm{
  background:var(--primary);color:#fff;border:none;
  width:22px;height:22px;border-radius:4px;
  font-size:14px;font-weight:800;cursor:pointer;line-height:1;
}
.btn-sm:hover{background:var(--primary-dark)}
.garanties-box{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.gar-row{
  background:#f9fafb;border:1px solid var(--border);border-radius:6px;
  padding:6px;display:flex;flex-direction:column;gap:4px;
}
.gar-row input{font-size:12px !important;padding:4px 6px !important}
.gar-row input[data-g="garantie"]{font-weight:700}
.gar-row-bottom{display:flex;gap:4px}
.gar-row-bottom input{flex:1}
.gar-del{
  background:none;border:1px solid var(--border);border-radius:4px;
  width:24px;cursor:pointer;color:var(--danger);font-weight:800;
}
.gar-del:hover{background:#fee2e2;border-color:var(--danger)}

.json-area{
  flex:1;width:100%;resize:none;
  font-family:'Consolas','Monaco',monospace;font-size:12px;
  padding:10px;border:1.5px solid var(--border);border-radius:6px;
  background:#fafbfc;color:var(--text);
}
.json-area:disabled{background:#f3f4f6;color:#4b5563}
.json-area:focus{outline:none;border-color:var(--primary)}

/* CodeMirror wrappers */
.cm-wrap{flex:1;min-height:0;display:flex;border:1.5px solid var(--border);border-radius:6px;overflow:hidden}
.cm-wrap .CodeMirror{flex:1;height:auto;font-size:12px;line-height:1.45}
.cm-wrap .CodeMirror-scroll{min-height:0}
/* Sélection très visible (orange vif) pour le jump sur warnings/errors */
.cm-wrap .CodeMirror-selected,
.cm-wrap .CodeMirror-focused .CodeMirror-selected,
.cm-wrap .CodeMirror-selectedtext{
  background:#f59e0b !important;color:#111 !important;
}

.scrap-col-view{display:flex;flex-direction:column;gap:10px}
.chromium-frame{
  width:100%;aspect-ratio:16/9;flex-shrink:0;position:relative;
  border:1.5px dashed var(--border);border-radius:8px;
  background:#111827;overflow:hidden;
}
.chromium-placeholder{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:20px;font-size:13px;color:#e5e7eb;
}
.chromium-placeholder p{margin:6px 0}
.chromium-placeholder .muted{color:#9ca3af}
.stream-img{
  width:100%;height:100%;object-fit:contain;display:block;
  opacity:0;transition:opacity .15s;
}
.stream-img.active{opacity:1}
.stream-status{
  font-size:10px;font-weight:700;margin-left:8px;
  color:var(--text-dim);text-transform:none;
}
.stream-status.hl-on{color:#f59e0b}
.stream-status.hl-off{color:var(--success)}
.source-head{display:flex;justify-content:space-between;align-items:center}
.source-head h4{font-size:11px;font-weight:800;text-transform:uppercase;color:var(--text-dim);margin:0;display:flex;gap:8px;align-items:baseline}
.source-file{text-transform:none;font-size:12px;font-weight:700;color:var(--primary)}
.btn-pause{font-size:13px}
.btn-pause:disabled{opacity:.4;cursor:not-allowed}
.btn-pause.paused{background:#f59e0b;color:#fff;border-color:#f59e0b}
.btn-pause.paused:hover{background:#d97706}
.paused-view{opacity:.35;filter:grayscale(.8);transition:opacity .2s,filter .2s}

/* Modal agrandir vue chromium */
.chrom-modal{
  position:fixed;inset:0;z-index:1000;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.75);
}
.chrom-modal[hidden]{display:none}
.chrom-modal-inner{
  position:relative;width:75vw;max-width:1400px;aspect-ratio:16/9;
  background:#111827;border-radius:12px;overflow:hidden;
  box-shadow:0 20px 80px rgba(0,0,0,.6);
}
.chrom-modal-img{width:100%;height:100%;object-fit:contain;display:block}
.chrom-modal-close{
  position:absolute;top:10px;right:10px;z-index:2;
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.9);border:none;cursor:pointer;
  font-size:22px;font-weight:700;line-height:1;color:#111827;
}
.chrom-modal-close:hover{background:#fff}

/* Modale Garanties GAN */
.garanties-modal-inner{
  aspect-ratio:auto !important;width:90vw;max-width:1400px;height:85vh;
  background:#fff;padding:0;display:flex;flex-direction:column;overflow:hidden;
}
.garanties-sticky-head{
  background:#fff;flex-shrink:0;border-bottom:1px solid var(--border);
}
.garanties-top-row{
  display:flex;align-items:center;gap:16px;padding:14px 20px;
}
.garanties-top-row .gar-title{flex:1;margin:0;font-size:18px;line-height:1.2}
.garanties-top-row .chrom-modal-close{
  position:static;transform:none;
}
.garanties-cols-row{
  display:table;width:100%;table-layout:fixed;
  background:transparent;color:#fff;
  font-weight:700;font-size:11px;text-transform:uppercase;
}
.garanties-cols-row .gar-col-cell{
  display:table-cell;padding:8px 8px;text-align:center;vertical-align:middle;
  border-right:1px solid #374151;
  box-sizing:border-box;background:#1f2937;
}
.garanties-cols-row .gar-col-cell:last-child{border-right:none}
.garanties-cols-row .gar-col-cell-label{
  background:transparent;border-right:none;color:transparent;
}
/* Largeurs partagées avec le colgroup de la table */
.garanties-cols-row .gar-col-cell:nth-child(1){width:16%}
.garanties-cols-row .gar-col-cell:nth-child(2){width:22%}
.garanties-cols-row .gar-col-cell:nth-child(n+3){width:10.333%}
.garanties-modal-body{flex:1;overflow-y:scroll;overflow-x:auto;padding:0}
.garanties-table{
  width:100%;border-collapse:separate;border-spacing:0;font-size:12px;
  table-layout:fixed;
}
.garanties-table col.gar-c-garantie{width:16%}
.garanties-table col.gar-c-detail{width:22%}
.garanties-table col.gar-c-val{width:10.333%}
.garanties-table td{
  border-right:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:6px 8px;text-align:left;vertical-align:middle;
  word-wrap:break-word;
}
.garanties-table td:first-child{border-left:1px solid var(--border)}
.garanties-table .gar-head-garantie,.garanties-table .gar-head-detail{background:#fff}
.gar-section-row td{
  background:#e0f2fe;font-weight:800;text-transform:uppercase;color:#075985;
  font-size:12px;letter-spacing:.3px;
}
.gar-col-garantie{font-weight:700;background:#f9fafb;vertical-align:middle}
.gar-col-detail{color:var(--text-dim);padding-left:14px !important}
.gar-col-val{text-align:center;font-family:'Consolas','Monaco',monospace;font-size:11px}
.gar-col-val.gar-col-dual{
  display:flex !important;padding:0 !important;
}
.gar-col-val.gar-col-dual > span{
  flex:1;padding:6px 4px;text-align:center;
}
.gar-col-val.gar-col-dual > span:first-child{
  border-right:1px solid var(--border);
}
.garanties-src{font-size:12px;font-weight:400;color:var(--text-dim);margin-left:8px}
.gar-title{margin-bottom:12px}

/* Toolbar de recherche */
.garanties-toolbar{
  display:flex;align-items:center;gap:6px;
  flex-shrink:0;
}
.garanties-toolbar input[type=search]{
  flex:0 0 260px;padding:6px 10px;border:1.5px solid var(--border);border-radius:6px;
  font-family:inherit;font-size:13px;
}
.garanties-toolbar input[type=search]:focus{outline:none;border-color:var(--primary)}
.garanties-toolbar button{
  width:28px;height:28px;border:1px solid var(--border);border-radius:6px;
  background:#fff;cursor:pointer;font-size:11px;
}
.garanties-toolbar button:hover{background:var(--bg)}
.gar-search-count{font-size:12px;color:var(--text-dim);margin-left:4px}

mark.hl{background:#fef08a;color:inherit;padding:0 1px;border-radius:2px}
mark.hl.active{background:#facc15;box-shadow:0 0 0 1px #ca8a04}
.source-view{
  flex:1;min-height:0;overflow:auto;margin:0;
  background:#0d1117;color:#f0f6fc;
  border-radius:6px;padding:10px;
  font-family:'Consolas','Monaco',monospace;font-size:12px;line-height:1.5;
}
.source-view code{display:block;white-space:pre;font-family:inherit;background:transparent !important}
.source-view .hljs-ln-numbers{
  text-align:right;padding-right:10px;color:#6e7681;user-select:none;
  border-right:1px solid #30363d;
}
.source-view .hljs-ln-code{padding-left:10px}
.source-view tr.line-current td{background:#dc2626 !important}
.source-view tr.line-current td.hljs-ln-code,
.source-view tr.line-current td.hljs-ln-code *{color:#fde047 !important}
.source-view tr.line-current td.hljs-ln-numbers{color:#fde047 !important;font-weight:700;background:#991b1b !important}

.resp-controls{overflow-y:auto;font-size:13px}
.resp-kv{margin:4px 0}
.resp-kv .ok{color:var(--success);font-weight:700}
.resp-kv .ko, .ko{color:var(--danger);font-weight:700}
.resp-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:4px}
.resp-table th,.resp-table td{
  border-bottom:1px solid var(--border);padding:4px 6px;text-align:left;
}
.resp-table th{background:#f9fafb;font-weight:700;color:var(--text-dim)}

/* Config page */
.card-h{font-size:12px;font-weight:800;text-transform:uppercase;color:var(--text-dim);margin-bottom:10px}
.switch-row{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer}
.switch-row input{width:18px;height:18px;cursor:pointer}

.insurer-cards{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:16px;margin-bottom:16px;
}
.insurer-card{
  background:#fff;border:1px solid var(--border);border-radius:12px;
  padding:16px;display:flex;flex-direction:column;gap:12px;
  box-shadow:0 1px 3px rgba(0,0,0,.04);
}
.insurer-card-head{
  display:flex;align-items:center;gap:12px;
  padding-bottom:10px;border-bottom:1px solid var(--border);
}
.insurer-card-logo{
  width:40px;height:40px;border-radius:8px;
  background:#008859;padding:5px;object-fit:contain;
}
.insurer-card[data-insurer="gan"] .insurer-card-logo,
.insurer-card[data-insurer="spvie"] .insurer-card-logo{
  background:transparent;border:0;padding:0;object-fit:contain;
  width:auto;max-width:64px;
}
.card-delete{
  position:absolute;top:8px;right:8px;
  background:transparent;border:0;cursor:pointer;
  font-size:24px;color:#dc2626;
  padding:4px 6px;border-radius:6px;line-height:1;
}
.card-delete:hover{background:rgba(220,38,38,.15)}
.insurer-card-head h3{font-size:18px;font-weight:800;text-transform:none;color:var(--text);letter-spacing:0;margin:0}
.insurer-card-body{display:flex;flex-direction:column;gap:10px}
.insurer-card-body label{
  display:flex;flex-direction:column;gap:4px;
  font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-dim);
}
.insurer-card-body input{
  padding:8px 10px;border:1.5px solid var(--border);border-radius:6px;
  font-size:13px;font-family:inherit;background:#fff;
  text-transform:none;font-weight:400;color:var(--text);
}
.insurer-card-body input:focus{outline:none;border-color:var(--primary)}
.insurer-card-body .pwd-wrap input{padding-right:32px;width:100%}
.insurer-docs{
  display:flex;flex-direction:column;gap:4px;
  padding-top:10px;border-top:1px solid var(--border);
}
.insurer-docs-label{
  font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-dim);
}
.doc-entry{display:flex;gap:6px;align-items:stretch}
.doc-btn{
  flex:1;min-width:0;
  display:flex;flex-direction:column;gap:2px;
  padding:6px 10px;
  background:var(--bg);border:1px solid var(--border);border-radius:6px;
  font-size:13px;color:var(--primary);text-decoration:none;font-weight:500;
}
.doc-btn .doc-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.doc-btn .doc-date{font-size:11px;color:var(--text-dim);font-weight:400}
.doc-btn:hover{background:#eff6ff;border-color:var(--primary)}
.doc-change{
  padding:6px 10px;border:1px solid var(--border);border-radius:6px;
  background:#fff;cursor:pointer;font-size:12px;font-weight:600;
  color:var(--text-dim);white-space:nowrap;
  transition:all .15s;
}
.doc-change:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

.accordion{margin-top:10px;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.accordion-head{
  width:100%;display:flex;justify-content:space-between;align-items:center;
  padding:10px 12px;background:var(--bg);border:none;cursor:pointer;
  font-family:inherit;font-size:13px;font-weight:800;color:var(--text);
  text-transform:none;
}
.accordion-head:hover{background:#eff6ff}
.accordion-title{letter-spacing:0}
.accordion-chevron{font-size:14px;color:var(--text-dim);transition:transform .2s}
.accordion.open .accordion-chevron{transform:rotate(90deg)}
.accordion-body{
  display:none;padding:12px;background:#fff;
  flex-direction:column;gap:10px;
}
.accordion.open .accordion-body{display:flex}
.config-table{width:100%;border-collapse:collapse;font-size:14px}
.config-table th,.config-table td{
  padding:10px 12px;border-bottom:1px solid var(--border);text-align:left;
}
.config-table th{background:#f9fafb;font-weight:800;color:var(--text-dim);font-size:12px;text-transform:uppercase}
.config-table .ins-cell{font-weight:700;text-transform:capitalize}
.config-table input{
  width:100%;padding:7px 10px;border:1.5px solid var(--border);
  border-radius:6px;font-size:13px;font-family:inherit;
}
.config-table input:focus{outline:none;border-color:var(--primary)}
.config-table .pwd-wrap{display:block;width:100%}
.config-table .pwd-wrap input{padding-right:32px}
.config-actions{display:flex;align-items:center;gap:16px;margin-top:16px}
.save-status{font-size:13px;font-weight:700}
.save-status.ok{color:var(--success)}
.save-status.ko{color:var(--danger)}

.page-header{margin-bottom:24px}
.page-header h1{font-size:24px;font-weight:800;margin-bottom:4px}
.muted{color:var(--text-dim);font-size:14px}
.card{
  background:#fff;border:1px solid var(--border);
  border-radius:12px;padding:20px;
}
code{
  font-family:'Consolas','Monaco',monospace;
  background:#f3f4f6;padding:2px 6px;border-radius:4px;
  font-size:13px;
}

/* Login */
.login-body{
  display:flex;align-items:center;justify-content:center;
  min-height:100vh;background:linear-gradient(135deg,#2563eb 0%,#1e3a8a 100%);
}
.login-box{
  background:#fff;border-radius:16px;padding:40px;
  width:380px;box-shadow:0 20px 60px rgba(0,0,0,.3);
}
.login-box h1{
  font-size:28px;font-weight:900;color:var(--primary);
  text-align:center;margin-bottom:24px;
}
.login-box label{
  display:block;font-size:12px;font-weight:700;
  text-transform:uppercase;color:var(--text-dim);
  margin-bottom:4px;margin-top:12px;
}
.login-box input{
  width:100%;padding:10px 12px;
  border:1.5px solid var(--border);border-radius:8px;
  font-size:14px;font-family:inherit;
}
.login-box input:focus{outline:none;border-color:var(--primary)}
.login-box button{
  width:100%;margin-top:20px;padding:12px;
  background:var(--primary);color:#fff;border:none;
  border-radius:8px;font-size:14px;font-weight:700;
  cursor:pointer;transition:background .15s;
}
.login-box button:hover{background:var(--primary-dark)}
.login-error{
  margin-top:12px;padding:10px;
  background:#fee2e2;color:#991b1b;border-radius:8px;
  font-size:13px;
}
.login-hint{
  margin-top:16px;text-align:center;
  font-size:12px;color:var(--text-dim);
}

/* ── Mobile bar (hidden on desktop) ───────────────── */
.mobile-bar{display:none}

/* ── Phone toggle button ──────────────────────────── */
.phone-toggle-btn{font-size:16px;padding:3px 8px}
.phone-mode .phone-toggle-btn{background:#eff6ff;color:var(--primary);border-color:var(--primary)}

/* ── Phone frame mode (desktop → rendu téléphone centré) ── */
html.phone-mode{background:#374151}
html.phone-mode body{
  max-width:390px;margin:0 auto;
  background:#fff;
  box-shadow:0 0 60px rgba(0,0,0,.5);
  min-height:100vh;
}
html.phone-mode .header{height:48px;padding:0 12px}
html.phone-mode .header .build-info,
html.phone-mode .header .user-info{display:none}
html.phone-mode .header .logo{font-size:20px}
html.phone-mode .mobile-bar{display:flex}
html.phone-mode .layout{min-height:calc(100vh - 48px)}
html.phone-mode .sidebar{display:none}
html.phone-mode .content{padding:8px}
html.phone-mode .scrap-header{display:none}
html.phone-mode .scrap-grid{
  flex-direction:column;height:auto!important;min-height:0;gap:8px;padding:0;
}
html.phone-mode .col-splitter{display:none}
html.phone-mode .scrap-col{flex:none!important;width:100%;min-height:0;border-radius:8px}
html.phone-mode .mob-hide{display:none!important}
html.phone-mode .mob-stream{display:none}
html.phone-mode .mob-results{display:none}
html.phone-mode #scrapGrid[data-mobile-state="scraping"] .mob-params{display:none}
html.phone-mode #scrapGrid[data-mobile-state="scraping"] .mob-stream{display:flex}
html.phone-mode #scrapGrid[data-mobile-state="done"] .mob-params{display:none}
html.phone-mode #scrapGrid[data-mobile-state="done"] .mob-stream{display:flex}
html.phone-mode #scrapGrid[data-mobile-state="done"] .mob-results{display:flex}
html.phone-mode .chromium-frame{aspect-ratio:4/3}
html.phone-mode .source-view{max-height:220px}
html.phone-mode #headlessStatus{display:none}

/* ── Mobile : ≤ 767px ─────────────────────────────── */
@media(max-width:767px){
  /* Header compact */
  :root{--header-h:48px}
  .header{height:48px;padding:0 12px}
  .build-info,.user-info{display:none}
  .logo{font-size:20px}

  /* Mobile bar */
  .mobile-bar{
    display:flex;align-items:center;gap:6px;
    position:sticky;top:var(--header-h);z-index:99;
    background:#fff;border-bottom:2px solid var(--border);
    padding:8px 12px;
  }
  .mob-sel{
    flex:1;min-width:0;
    padding:8px 6px;border:1.5px solid var(--border);
    border-radius:8px;font-size:14px;font-family:inherit;
    background:#fff;
  }
  .mob-scrap-btn{flex-shrink:0;padding:8px 14px;font-size:14px}

  /* Hide sidebar */
  .sidebar{display:none}
  .content{padding:8px}

  /* Scrap page */
  .scrap-header{display:none}
  .scrap-grid{
    flex-direction:column;height:auto!important;
    min-height:0;gap:8px;padding:0;
  }
  .col-splitter{display:none}
  .scrap-col{
    flex:none!important;width:100%;
    min-height:0;border-radius:8px;
  }

  /* Section visibility par défaut (idle) */
  .mob-hide{display:none!important}
  .mob-stream{display:none}
  .mob-results{display:none}
  #headlessStatus{display:none}

  /* État scraping */
  #scrapGrid[data-mobile-state="scraping"] .mob-params{display:none}
  #scrapGrid[data-mobile-state="scraping"] .mob-stream{display:flex}

  /* État done */
  #scrapGrid[data-mobile-state="done"] .mob-params{display:none}
  #scrapGrid[data-mobile-state="done"] .mob-stream{display:flex}
  #scrapGrid[data-mobile-state="done"] .mob-results{display:flex}

  /* Chromium frame ratio téléphone */
  .chromium-frame{aspect-ratio:4/3}
  .source-view{max-height:220px}
}
