/* styles.css — interface VisionAir Data Analyse */
:root{
  --bg:#eef2f7; --panel:#ffffff; --ink:#1f2a37; --muted:#6b7787;
  --blue:#2f6db0; --blue-d:#1b4f86; --line:#e2e8f0; --accent:#1b3a5b;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:'Segoe UI',system-ui,Arial,sans-serif;color:var(--ink);background:var(--bg)}

/* Topbar */
.topbar{height:58px;background:linear-gradient(120deg,#0f2f51,#1b4f86);color:#fff;
  display:flex;align-items:center;gap:24px;padding:0 20px;box-shadow:0 2px 10px rgba(0,0,0,.12);position:sticky;top:0;z-index:30}
.logo{font-weight:800;letter-spacing:1.5px}
.logo span{font-weight:400;opacity:.8;margin-left:8px;font-size:13px;letter-spacing:0}
.tabs{display:flex;gap:6px;margin-left:10px}
.tab{background:transparent;border:0;color:#cdd9e7;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600}
.tab:hover{background:rgba(255,255,255,.1);color:#fff}
.tab.active{background:rgba(255,255,255,.18);color:#fff}
.token-zone{margin-left:auto;display:flex;align-items:center;gap:8px;font-size:12px}
.token-dot{width:9px;height:9px;border-radius:50%;background:#999}
.token-dot.ok{background:#5fd07a;box-shadow:0 0 0 3px rgba(95,208,122,.25)}
.token-dot.bad{background:#ff6b6b;box-shadow:0 0 0 3px rgba(255,107,107,.25)}
.token-dot.unknown{background:#d9b34a}
.token-label{opacity:.9}
.btn-ghost{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;padding:5px 12px;border-radius:7px;cursor:pointer;font-size:12px}
.btn-ghost:hover{background:rgba(255,255,255,.22)}

/* Layout */
.tab-panel{display:none}
.tab-panel.active{display:flex;min-height:calc(100vh - 58px)}
#tab-about.tab-panel.active{display:block}
.panel{width:330px;flex:none;background:var(--panel);border-right:1px solid var(--line);padding:20px;
  position:sticky;top:58px;height:calc(100vh - 58px);overflow:auto}
.content{flex:1;padding:22px 26px;min-width:0}

.panel-title{font-size:14px;text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin:0 0 16px}
.field-label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin:14px 0 5px}
.search-wrap{position:relative}
#parkSearch,.select,#tokenInput{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-size:13px;background:#fff;color:var(--ink)}
#parkSearch:focus,.select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(47,109,176,.12)}
.dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:8px;margin-top:4px;
  box-shadow:0 8px 24px rgba(20,40,70,.14);max-height:260px;overflow:auto;z-index:20;display:none}
.dropdown.show{display:block}
.dropdown-item{padding:9px 11px;cursor:pointer;border-bottom:1px solid #f1f4f8}
.dropdown-item:hover{background:#f3f7fc}
.dropdown-item b{display:block;font-size:13px}
.dropdown-item small{color:var(--muted);font-size:11px}
.dropdown-empty{padding:10px;color:var(--muted);font-size:12px}

.selected-park{margin-top:10px;background:#f3f7fc;border:1px solid #dbe6f3;border-radius:8px;padding:10px 12px}
.selected-park b{font-size:14px}
.selected-park small{display:block;color:var(--muted);font-size:11px}

.row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tol-label{display:flex;justify-content:space-between;align-items:center}
.tol-val{color:var(--blue);font-weight:700}
.slider{width:100%;margin:4px 0 2px;accent-color:var(--blue)}
.tol-hint{font-size:11px;color:var(--muted);line-height:1.4;margin-bottom:6px}

.btn-primary{background:linear-gradient(120deg,#2f6db0,#1b4f86);color:#fff;border:0;padding:11px 16px;border-radius:9px;
  cursor:pointer;font-size:14px;font-weight:700;width:100%;margin-top:14px;box-shadow:0 3px 10px rgba(27,79,134,.25)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-primary:disabled{opacity:.5;cursor:default}
.btn-ghost.full{width:100%;background:#eef3f9;color:var(--blue);border:1px solid #d6e3f1;margin-top:8px}
.btn-ghost.full:hover{background:#e3edf8}

.turbine-mini{margin-top:16px;border-top:1px solid var(--line);padding-top:12px}
.turbine-mini h4{margin:0 0 8px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.tm-row{display:flex;justify-content:space-between;font-size:12px;padding:4px 0;border-bottom:1px dashed #eef2f6}
.tm-row b{color:var(--accent)}

.panel-foot{margin-top:18px}
.status{font-size:12px;color:var(--muted);min-height:18px}
.status.err{color:#cf4040}
.status.ok{color:#3f8b54}

/* Welcome */
.welcome{display:flex;align-items:flex-start;justify-content:center;padding-top:30px}
.welcome-card{max-width:680px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px 34px;box-shadow:0 6px 24px rgba(20,40,70,.06)}
.welcome-card h1{font-size:24px;margin:0 0 12px;color:var(--accent)}
.welcome-card p{line-height:1.6;color:#3a4654}
.muted{color:var(--muted)}

/* Result toolbar */
.result-toolbar{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:12px 18px;margin-bottom:16px;position:sticky;top:70px;z-index:10;box-shadow:0 2px 8px rgba(20,40,70,.05)}
.result-title{font-weight:700;color:var(--accent);font-size:15px}
.toolbar-actions{display:flex;gap:10px}
.toolbar-actions .btn-primary{width:auto;margin:0;padding:9px 16px}

/* Barre de filtres d'evolution */
.evo-filter{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);
  border-radius:10px;padding:10px 14px;margin-bottom:14px;box-shadow:0 2px 8px rgba(20,40,70,.04)}
.ef-label{font-size:12px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}
.ef-chk{display:inline-flex;align-items:center;gap:6px;cursor:pointer;user-select:none}
.ef-chk input{accent-color:var(--blue);width:15px;height:15px;cursor:pointer}
.ef-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap}
.ef-badge.bad{background:#fbe6e6;color:#cf4040}
.ef-badge.good{background:#e6f3ea;color:#3f8b54}
.ef-badge.neutral{background:#eef2f7;color:#6b7787}
.ef-chk input:not(:checked) + .ef-badge{opacity:.4;filter:grayscale(.5)}
.ef-sep{flex:1}
.ef-mini{background:#eef3f9;border:1px solid #d6e3f1;color:var(--blue);font-size:11px;font-weight:600;
  padding:4px 10px;border-radius:7px;cursor:pointer}
.ef-mini:hover{background:#e3edf8}
.ef-count{font-size:11px;color:var(--muted)}
.report-container.refreshing{opacity:.55;transition:opacity .1s}
/* (compat) lignes masquees cote client si jamais utilise */
.report-container tr.cat-hidden{display:none}
.report-container .turbine.section-hidden{display:none}

/* Report container (utilise le CSS du rapport via /api/report-css) */
.report-container{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 4px 18px rgba(20,40,70,.06)}
.report-container:empty{display:none}
/* On masque la couverture plein-ecran dans l'apercu (elle reste dans le PDF) */
.report-container .cover{height:auto !important;border-radius:0}

/* Loader */
.loader{display:flex;flex-direction:column;align-items:center;gap:14px;padding:60px}
.spinner{width:42px;height:42px;border:4px solid #dfe7f0;border-top-color:var(--blue);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#loaderMsg{color:var(--muted);font-size:14px}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(15,30,55,.55);display:flex;align-items:center;justify-content:center;z-index:50}
.modal-card{background:#fff;border-radius:14px;padding:24px;width:520px;max-width:92vw;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal-card h3{margin:0 0 6px}
#tokenInput{font-family:monospace;font-size:11px;margin-top:8px}
.token-info{font-size:12px;margin-top:8px;min-height:16px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}
.modal-actions .btn-ghost{background:#eef2f7;color:var(--ink);border:1px solid var(--line)}
.modal-actions .btn-primary{width:auto;margin:0}

/* Sous-onglets par turbine (vue Analyse d'inspections) */
.turbine-tabs{display:flex;flex-wrap:wrap;gap:6px;background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:8px;margin-bottom:14px;position:sticky;top:70px;z-index:9;box-shadow:0 2px 8px rgba(20,40,70,.05)}
.tt-btn{background:#eef3f9;border:1px solid #d6e3f1;color:var(--blue);font-weight:700;font-size:13px;
  padding:7px 16px;border-radius:8px;cursor:pointer}
.tt-btn:hover{background:#e3edf8}
.tt-btn.active{background:linear-gradient(120deg,#2f6db0,#1b4f86);color:#fff;border-color:transparent}
.report-container .loc-turbine.tt-hidden{display:none}

/* Visualiseur 3D */
.modal.v3d{padding:24px}
.v3d-card{background:#fff;border-radius:14px;width:min(1100px,94vw);height:min(820px,90vh);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 70px rgba(0,0,0,.4)}
.v3d-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 18px;background:linear-gradient(120deg,#0f2f51,#1b4f86);color:#fff}
.v3d-title{font-weight:700}
.v3d-controls{display:flex;align-items:center;gap:10px}
.v3d-lbl{font-size:12px;opacity:.85}
.v3d-sel{width:auto;min-width:180px;padding:6px 10px}
.v3d-controls .btn-ghost{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3)}
.v3d-stage{position:relative;flex:1;min-height:0}
.v3d-canvas{position:absolute;inset:0}
.v3d-canvas canvas{display:block;width:100%;height:100%}
.v3d-tip{position:absolute;display:none;pointer-events:none;background:rgba(15,30,55,.92);color:#fff;font-size:12px;line-height:1.4;padding:7px 10px;border-radius:8px;max-width:240px;z-index:5;box-shadow:0 6px 18px rgba(0,0,0,.3)}
.v3d-tip b{display:block;margin-bottom:2px}
.v3d-legend{position:absolute;left:14px;bottom:12px;display:flex;flex-direction:column;gap:6px;z-index:4}
.v3d-hint{font-size:11px;color:#5a6675;background:rgba(255,255,255,.8);padding:4px 10px;border-radius:20px}
.v3d-faces{display:flex;gap:12px;font-size:11px;color:#33506e;background:rgba(255,255,255,.85);padding:5px 10px;border-radius:20px;font-weight:700}
.v3d-faces span{display:inline-flex;align-items:center;gap:5px}
.v3d-faces i{width:10px;height:10px;border-radius:3px;display:inline-block}

/* Modales login / partage */
.token-adv{margin-top:14px;border-top:1px solid var(--line);padding-top:10px}
.token-adv summary{cursor:pointer;font-size:12px;color:var(--muted)}
.token-adv textarea{width:100%;font-family:monospace;font-size:11px;margin-top:8px;padding:8px;border:1px solid var(--line);border-radius:8px}
.share-row{display:flex;gap:8px}
.share-row .select{flex:1}
.share-code{font-family:monospace;font-weight:800;font-size:20px;letter-spacing:3px;text-align:center}
.modal-card .field-label{margin-top:12px}

.hidden{display:none !important}
