:root{--bg:#071017;--panel:#0d1a24;--panel2:#102432;--line:#24465a;--text:#e8f8ff;--muted:#8fb4c6;--accent:#28e3ff;--accent2:#9b7cff;--ok:#50f0a0;--warn:#ffd166;--bad:#ff6b6b;--info:#75a7ff;--shadow:0 20px 70px rgba(0,0,0,.35)}
*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top left,#173044 0,#071017 45%,#03070a 100%);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;min-height:100vh}.page-shell{width:min(1500px,calc(100% - 28px));margin:0 auto;padding:20px 0 18px}.hero{display:flex;justify-content:space-between;gap:20px;align-items:center;border:1px solid var(--line);background:linear-gradient(135deg,rgba(15,35,49,.92),rgba(8,16,24,.92));box-shadow:var(--shadow);border-radius:24px;padding:18px 20px}.brand-row{display:flex;align-items:center;gap:16px}.logo-link{display:inline-flex;border-radius:18px;line-height:0}.logo-link:focus-visible{outline:3px solid var(--accent);outline-offset:4px}.logo{width:74px;height:74px;object-fit:contain;filter:drop-shadow(0 0 16px rgba(40,227,255,.35))}.eyebrow{margin:0 0 4px;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);font-size:.72rem;font-weight:800}.hero h1{margin:0;font-size:clamp(2rem,4vw,4rem);letter-spacing:.02em}.subtitle{margin:4px 0 0;color:var(--muted);font-size:1rem}.hero-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.small-btn,.mode-btn,.quick-chip,.footer-btn{border:1px solid var(--line);background:rgba(10,22,31,.8);color:var(--text);border-radius:999px;padding:9px 12px;font-weight:800;cursor:pointer}.small-btn:hover,.mode-btn:hover,.quick-chip:hover,.footer-btn:hover{border-color:var(--accent);box-shadow:0 0 0 2px rgba(40,227,255,.12)}.small-btn.active,.mode-btn.active{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#001018;border-color:transparent}.lang-switch,.view-switch{display:flex;gap:6px;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.06);padding:5px;border-radius:999px}.dashboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin:14px 0}.stat-card{border:1px solid var(--line);background:rgba(13,26,36,.85);border-radius:18px;padding:14px 16px}.stat-card strong{display:block;font-size:1.45rem;color:#fff}.stat-card span{color:var(--muted);font-size:.85rem}.layout{display:grid;grid-template-columns:330px 1fr;gap:14px;align-items:start}.filters{position:sticky;top:14px;border:1px solid var(--line);background:rgba(9,21,30,.92);border-radius:22px;padding:14px;max-height:calc(100vh - 28px);overflow:auto}.panel-block{border-bottom:1px solid rgba(255,255,255,.08);padding:0 0 14px;margin:0 0 14px}.panel-block:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}.panel-block label{display:block;font-weight:900;color:#dff8ff;margin-bottom:8px}input,select{width:100%;border:1px solid var(--line);background:#07121b;color:var(--text);border-radius:13px;padding:11px 12px;font-weight:700;outline:none}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(40,227,255,.12)}.hint{margin:8px 0 0;color:var(--muted);font-size:.78rem;line-height:1.4}.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.mode-grid.two{grid-template-columns:1fr 1fr}.mode-btn{border-radius:14px;padding:10px 8px}.toggles{display:grid;gap:8px}.check{display:flex!important;gap:9px;align-items:flex-start;color:var(--muted);font-weight:800!important}.check input{width:auto;margin-top:3px}.quick-block{display:flex;flex-direction:column;gap:7px}.quick-chip{text-align:left;border-radius:13px}.content{min-width:0}.content-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-end;border:1px solid var(--line);background:rgba(13,26,36,.75);border-radius:22px;padding:16px 18px;margin-bottom:12px}.content-head h2{margin:0;font-size:1.55rem}.mode-help{margin:5px 0 0;color:var(--muted)}.result-count{font-weight:900;color:var(--accent);white-space:nowrap}.info-strip{display:none;margin:0 0 12px;border:1px solid rgba(117,167,255,.35);background:rgba(117,167,255,.08);border-radius:16px;padding:10px 14px;color:#cfe1ff}.info-strip.show{display:block}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px}.grid.list{grid-template-columns:1fr}.card{border:1px solid var(--line);background:linear-gradient(180deg,rgba(16,36,50,.86),rgba(8,18,27,.92));border-radius:20px;padding:14px;box-shadow:0 8px 30px rgba(0,0,0,.22);cursor:pointer;transition:.15s ease}.card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 14px 45px rgba(0,0,0,.35),0 0 0 2px rgba(40,227,255,.09)}.card-top{display:flex;gap:12px;align-items:flex-start}.icon{width:44px;height:44px;display:grid;place-items:center;border:1px solid rgba(40,227,255,.35);background:rgba(40,227,255,.1);border-radius:14px;color:var(--accent);font-weight:1000;flex:0 0 auto}.card h3{margin:0 0 4px;font-size:1.04rem;line-height:1.18}.card-sub{color:var(--muted);font-size:.82rem;line-height:1.3}.answer{margin:12px 0;padding:10px 11px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);display:grid;gap:3px}.answer strong{font-size:.92rem}.answer span{color:var(--muted);font-size:.82rem;line-height:1.35}.answer.ok{border-color:rgba(80,240,160,.35);background:rgba(80,240,160,.08)}.answer.warn{border-color:rgba(255,209,102,.35);background:rgba(255,209,102,.08)}.answer.bad{border-color:rgba(255,107,107,.35);background:rgba(255,107,107,.08)}.answer.info{border-color:rgba(117,167,255,.35);background:rgba(117,167,255,.08)}.badges{display:flex;flex-wrap:wrap;gap:6px}.badge{display:inline-flex;align-items:center;gap:5px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.055);color:#d9f6ff;border-radius:999px;padding:5px 8px;font-size:.74rem;font-weight:900;max-width:100%;overflow:hidden;text-overflow:ellipsis}.badge.ok{border-color:rgba(80,240,160,.4);color:var(--ok);background:rgba(80,240,160,.08)}.badge.warn{border-color:rgba(255,209,102,.45);color:var(--warn);background:rgba(255,209,102,.08)}.badge.bad{border-color:rgba(255,107,107,.4);color:var(--bad);background:rgba(255,107,107,.08)}.badge.info{border-color:rgba(117,167,255,.4);color:#bcd0ff;background:rgba(117,167,255,.08)}.badge.accent{border-color:rgba(40,227,255,.45);color:var(--accent);background:rgba(40,227,255,.08)}.tech{display:none}.diag-on .tech{display:inline}.diag-on .section.tech{display:block}.section.tech{display:none}.modal{display:none;position:fixed;inset:0;z-index:30}.modal.open{display:block}.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(5px)}.modal-card{position:relative;width:min(980px,calc(100% - 28px));max-height:calc(100vh - 28px);overflow:auto;margin:14px auto;background:#08131c;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:22px}.modal-close{position:sticky;top:0;float:right;border:1px solid var(--line);background:#102432;color:var(--text);width:36px;height:36px;border-radius:999px;font-size:1.4rem;cursor:pointer;z-index:2}.modal h2{font-size:2rem;margin:0 42px 10px 0}.section{margin-top:18px;border-top:1px solid rgba(255,255,255,.08);padding-top:16px}.section h3{margin:0 0 12px;font-size:1.12rem}.route,.loot-application,.source-row,.why-box{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.035);border-radius:15px;padding:10px 12px;margin-bottom:8px}.route strong,.loot-application strong,.source-row strong{display:block;margin-bottom:3px}.small{color:var(--muted);font-size:.8rem;line-height:1.35}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}.source-row{display:grid;gap:3px}.tableish{display:grid;gap:4px}.limit-note{margin:12px 0;color:var(--muted);font-size:.86rem;text-align:center}.empty{grid-column:1/-1;border:1px dashed var(--line);border-radius:18px;padding:30px;text-align:center;color:var(--muted)}.hidden{display:none!important}.footer{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin-top:18px;color:var(--muted);font-size:.86rem}.footer-btn{padding:7px 10px;font-size:.78rem}.diag-on .footer-btn{border-color:var(--accent);color:var(--accent)}@media (max-width:980px){.layout{grid-template-columns:1fr}.filters{position:relative;top:auto;max-height:none}.dashboard{grid-template-columns:1fr 1fr}.hero,.content-head{align-items:flex-start;flex-direction:column}.result-count{white-space:normal}}@media (max-width:540px){.page-shell{width:min(100% - 16px,1500px)}.dashboard{grid-template-columns:1fr}.grid{grid-template-columns:1fr}.modal-card{padding:16px}.two-col{grid-template-columns:1fr}.logo{width:58px;height:58px}}

.reset-link{display:inline-flex;margin-top:9px;border:0;background:transparent;color:var(--accent);font-weight:900;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:3px}.reset-link:hover{color:#fff}.reset-link:focus-visible{outline:3px solid var(--accent);outline-offset:4px;border-radius:6px}


/* v2.3 global UI readability pass */
.source-summary{display:flex;align-items:baseline;gap:8px;border:1px solid rgba(40,227,255,.25);background:rgba(40,227,255,.06);border-radius:15px;padding:10px 12px;margin-bottom:10px;color:var(--muted)}
.source-summary strong{font-size:1.35rem;color:var(--accent)}
.source-group{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.025);border-radius:16px;margin:0 0 10px;overflow:hidden}.source-group>summary{display:flex;justify-content:space-between;gap:12px;align-items:center;cursor:pointer;padding:11px 13px;font-weight:1000;color:#e8f8ff;background:rgba(255,255,255,.045)}.source-group>summary:hover{background:rgba(40,227,255,.08)}.source-group .loot-application,.source-group .route{margin:9px 10px}.summary-count{color:var(--accent);font-size:.82rem;white-space:nowrap}.route-group>summary{color:#dff8ff}.card .badge.accent,.card .badge.info,.card .badge.warn{white-space:normal;line-height:1.25}.grid.list .card{display:grid;grid-template-columns:minmax(260px,1.25fr) minmax(260px,1fr);gap:12px;align-items:start}.grid.list .card .card-top{min-width:0}.grid.list .card .answer{margin:0}.grid.list .card .badges{grid-column:1/-1}.modal-card{width:min(1080px,calc(100% - 28px))}.hidden.check{display:none!important}@media (max-width:760px){.grid.list .card{grid-template-columns:1fr}.grid.list .card .answer{margin:12px 0}.source-group>summary{align-items:flex-start;flex-direction:column}.summary-count{white-space:normal}}

.quick-chip.active{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#001018;border-color:transparent}
.source-summary span{line-height:1.35}
.card .badges .badge.info{max-width:100%;white-space:normal}


/* v2.4 UX joueur */
.quick-section{margin:9px 0 2px;color:var(--accent);font-size:.72rem;text-transform:uppercase;letter-spacing:.13em;font-weight:1000}.quick-section:first-of-type{margin-top:0}
.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.summary-grid>div{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.035);border-radius:15px;padding:10px 12px}.summary-grid strong{display:block;color:#e8f8ff;margin-bottom:4px}.summary-grid span{color:var(--muted);line-height:1.35}
.card .answer span{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card .badges{margin-top:8px}.grid.list .card .answer span{-webkit-line-clamp:3}.source-group:not([open]){background:rgba(255,255,255,.018)}.source-group:not([open])>summary{border-bottom:0}.modal .source-summary{margin-top:6px}.filters select option{background:#07121b;color:#eaf7ff}.badge.warn{white-space:normal}.why-box{line-height:1.45}
@media (max-width:980px){.quick-block{display:grid;grid-template-columns:1fr 1fr}.quick-block label,.quick-section{grid-column:1/-1}}
@media (max-width:540px){.quick-block{grid-template-columns:1fr}.summary-grid{grid-template-columns:1fr}}

/* OctoLoot v3.1 UX additions */
.badge.info{border-color:rgba(117,167,255,.5)}
.summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.modal-card{max-width:min(1120px,calc(100% - 28px))}
.source-group summary{gap:12px}
.card .answer span{line-height:1.35}
@media(max-width:760px){.filters{position:static}.summary-grid{grid-template-columns:1fr}.card{min-height:auto}}
