:root{
  --bg:#080b12; --bg2:#0c1018;
  --elev:#141b27; --card:rgba(22,30,43,.72); --card-solid:#161e2b;
  --border:#26324a; --border-soft:rgba(120,150,200,.12);
  --text:#eaf1fb; --dim:#9fb0c9; --accent:#38bdf8; --accent2:#7dd3fc; --indigo:#818cf8;
  --warn:#fbbf24; --good:#34d399; --bad:#fb7185;
  --r:14px; --r-sm:10px; --shadow:0 10px 30px -8px rgba(0,0,0,.55); --glow:0 0 0 1px rgba(56,189,248,.5),0 8px 30px -6px rgba(56,189,248,.35);
  --tr:.18s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:"Inter","Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);min-height:100vh;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background:
    radial-gradient(900px 500px at 12% -8%,rgba(129,140,248,.18),transparent 60%),
    radial-gradient(1000px 600px at 88% -4%,rgba(56,189,248,.18),transparent 55%),
    linear-gradient(180deg,var(--bg2),var(--bg) 40%)}
a{color:var(--accent2);text-decoration:none}
img{max-width:100%}
::selection{background:rgba(56,189,248,.3)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#283448;border-radius:10px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:#34465f;background-clip:content-box}

/* ---------- Topbar ---------- */
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  background:rgba(10,14,22,.72);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--border-soft);padding:calc(11px + env(safe-area-inset-top,0px)) 20px 11px;
  box-shadow:0 1px 0 rgba(255,255,255,.03),0 12px 30px -20px rgba(0,0,0,.8)}
.brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:1.18rem;letter-spacing:.2px;
  color:var(--text);background:linear-gradient(90deg,#fff,#cfe9ff);-webkit-background-clip:text;background-clip:text}
.glyph{color:var(--accent);filter:drop-shadow(0 0 10px rgba(56,189,248,.8));font-size:1.25rem;-webkit-text-fill-color:initial}
.theme,.burger{background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text);
  border-radius:10px;font-size:1.05rem;padding:7px 11px;cursor:pointer;transition:var(--tr)}
.theme:hover,.burger:hover{border-color:var(--accent);color:var(--accent2);background:rgba(56,189,248,.08)}
.burger{display:none}
.topacts{display:flex;align-items:center;gap:8px;margin-left:auto}
/* ---- Nav : liens + menus déroulants groupés ---- */
.nav{display:flex;gap:4px;align-items:center}
.navlink{color:var(--dim);font-weight:600;padding:8px 14px;border-radius:10px;font-size:.92rem;transition:var(--tr);text-decoration:none;white-space:nowrap}
.navlink:hover{color:var(--text);background:rgba(255,255,255,.06)}
.navlink.active{color:#06121d;background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:0 6px 16px -6px rgba(56,189,248,.55)}
.navmenu{position:relative}
.navbtn{display:inline-flex;align-items:center;gap:6px;color:var(--dim);font-weight:600;font-size:.92rem;font-family:inherit;
  background:transparent;border:1px solid transparent;border-radius:10px;padding:8px 14px;cursor:pointer;transition:var(--tr);white-space:nowrap}
.navbtn:hover{color:var(--text);background:rgba(255,255,255,.06)}
.navbtn.has-active{color:var(--accent2)}
.navmenu.open>.navbtn{color:var(--text);background:rgba(255,255,255,.06)}
.navbtn .caret{font-size:.62rem;opacity:.7;transition:transform .18s}
.navmenu.open>.navbtn .caret{transform:rotate(180deg)}
.navpanel{position:absolute;top:calc(100% + 9px);left:0;z-index:60;min-width:236px;display:none;flex-direction:column;gap:2px;
  background:linear-gradient(180deg,#1b2433,#141b27);border:1px solid var(--border);border-radius:14px;padding:8px;
  box-shadow:0 26px 64px -22px rgba(0,0,0,.85),0 1px 0 rgba(255,255,255,.04)}
.navmenu.open>.navpanel{display:flex;animation:fadeUp .16s ease}
.navpanel a{display:flex;align-items:center;gap:10px;color:var(--dim);font-weight:600;font-size:.92rem;padding:9px 12px;border-radius:9px;white-space:nowrap;text-decoration:none;transition:background .12s,color .12s}
.nav-ic{width:20px;text-align:center;flex:none;font-size:.95rem}
/* Menu langue (topbar) */
.langpanel{left:auto;right:0;min-width:148px}
.langopt{display:block;width:100%;text-align:left;background:transparent;border:none;color:var(--dim);font-weight:600;font-size:.92rem;font-family:inherit;padding:9px 12px;border-radius:9px;cursor:pointer;transition:background .12s,color .12s}
.langopt:hover{background:rgba(56,189,248,.12);color:var(--accent2)}
.langopt.on{color:var(--accent2)}
.navpanel a:hover{background:rgba(56,189,248,.12);color:var(--accent2)}
.navpanel a.active{color:#06121d;background:linear-gradient(135deg,var(--accent),var(--accent2))}
body.light .navpanel{background:linear-gradient(180deg,#ffffff,#f2f6fc)}

main{max-width:1100px;margin:0 auto;padding:40px 28px 100px}
#app.fade{animation:fadeUp .3s cubic-bezier(.2,.7,.2,1)}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
h1{font-size:2rem;margin:0 0 10px;font-weight:800;letter-spacing:-.6px;line-height:1.15;
  background:linear-gradient(92deg,#ffffff 20%,#b9dcff);-webkit-background-clip:text;background-clip:text;color:transparent}
.sub{color:var(--dim);margin:0 0 32px;font-size:1.05rem;line-height:1.6;max-width:68ch}
h2{font-size:1.28rem;margin:44px 0 18px;font-weight:700;letter-spacing:-.2px;display:flex;align-items:center;gap:9px;
  padding-bottom:11px;border-bottom:1px solid var(--border-soft)}
h3{font-size:1.04rem;margin:24px 0 11px;color:var(--accent2);font-weight:700;letter-spacing:.1px}
.loading,.empty,.error{color:var(--dim);text-align:center;padding:44px 0}
.loading::before{content:"";display:inline-block;width:26px;height:26px;margin-right:10px;vertical-align:-7px;
  border:3px solid rgba(120,150,200,.25);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.error{color:var(--bad)}.muted{color:var(--dim);font-size:.88rem}

/* ---------- Buttons / inputs ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:rgba(255,255,255,.04);
  border:1px solid var(--border);color:var(--text);border-radius:var(--r-sm);padding:10px 16px;font-weight:600;
  font-size:.94rem;cursor:pointer;transition:var(--tr)}
.btn:hover{border-color:var(--accent);color:var(--accent2);background:rgba(56,189,248,.08);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#06121d;border-color:transparent;
  box-shadow:0 8px 20px -8px rgba(56,189,248,.65)}
.btn.primary:hover{filter:brightness(1.06);color:#06121d}
.input{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);
  padding:11px 14px;font-size:1rem;width:100%;transition:var(--tr)}
.input::placeholder{color:#6f819c}
.input:focus{outline:none;border-color:var(--accent);background:rgba(56,189,248,.05);box-shadow:0 0 0 3px rgba(56,189,248,.18)}
.acwrap{position:relative;max-width:460px}
.acbox{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:25;background:var(--elev);
  border:1px solid var(--accent);border-radius:var(--r-sm);max-height:330px;overflow-y:auto;box-shadow:var(--shadow);overflow:hidden auto}
.acbox.hide{display:none}
.acitem{padding:11px 14px;cursor:pointer;border-bottom:1px solid var(--border-soft);font-size:.95rem;transition:background .12s}
.acitem:last-child{border-bottom:none}
.acitem:hover,.acitem:active{background:rgba(56,189,248,.12);color:var(--accent2)}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:0 0 20px}
.pills{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 18px}
.pill{background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--dim);padding:8px 15px;
  border-radius:999px;cursor:pointer;font-size:.86rem;font-weight:600;transition:var(--tr)}
.pill:hover{color:var(--text);border-color:#3a4a66}
.pill.active{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#06121d;border-color:transparent;
  box-shadow:0 6px 16px -7px rgba(56,189,248,.6)}
.count{color:var(--dim);font-size:.88rem}

/* ---------- Cards / grid ---------- */
.grid{display:grid;gap:20px}
.cols-2{grid-template-columns:repeat(auto-fit,minmax(330px,1fr))}
.cols-auto{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.codex-grid{grid-template-columns:repeat(auto-fill,minmax(168px,1fr))}
.card{background:var(--card);border:1px solid var(--border-soft);border-radius:var(--r);box-shadow:var(--shadow);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:var(--tr)}
.card.pad{padding:22px 24px}
.tile{display:block;padding:20px;position:relative;overflow:hidden}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(56,189,248,.12),transparent 60%);opacity:0;transition:var(--tr)}
.tile:hover{transform:translateY(-4px);border-color:rgba(56,189,248,.4);box-shadow:var(--glow)}
.tile:hover::after{opacity:1}
.tile .t{font-weight:700;font-size:1.12rem;margin-bottom:5px;position:relative}
.tile .d{color:var(--dim);font-size:.9rem;position:relative}

/* ---------- Hero / vedette (accueil) ---------- */
.hero{position:relative;overflow:hidden;border-radius:18px;padding:24px 26px;margin:0 0 24px;
  background:linear-gradient(120deg,rgba(56,189,248,.16),rgba(129,140,248,.14) 60%,transparent);
  border:1px solid rgba(56,189,248,.28);box-shadow:var(--shadow)}
.hero::after{content:"◆";position:absolute;right:-10px;top:-30px;font-size:160px;color:rgba(56,189,248,.10);pointer-events:none}
.hero .ht{font-size:.78rem;text-transform:uppercase;letter-spacing:1px;color:var(--accent2);font-weight:700}
.hero .hn{font-size:1.5rem;font-weight:800;margin:4px 0 2px;letter-spacing:-.3px}
.hero .hd{color:var(--dim);margin-bottom:14px}
.hero .hrow{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.heroimg{position:absolute;right:18px;top:50%;transform:translateY(-50%);width:128px;height:128px;object-fit:contain;
  filter:drop-shadow(0 10px 22px rgba(0,0,0,.5));pointer-events:none;z-index:1;opacity:.96}
.hero .ht,.hero .hn,.hero .hd,.hero .hrow{position:relative;z-index:2}
@media(max-width:560px){.heroimg{display:none}}

/* ---------- Skeleton loaders ---------- */
.skel{position:relative;overflow:hidden;background:rgba(255,255,255,.04);border:1px solid var(--border-soft);border-radius:var(--r)}
.skel::after{content:"";position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.07),transparent);animation:shimmer 1.3s infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}
.skline{height:14px;border-radius:7px;margin:10px 0;background:rgba(255,255,255,.05);position:relative;overflow:hidden}
.skline::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);animation:shimmer 1.3s infinite}

/* ---------- Stagger d'apparition ---------- */
.cols-auto>.tile,.rank .rrow{animation:fadeUp .4s both}
.rank .rrow:nth-child(2){animation-delay:.03s}.rank .rrow:nth-child(3){animation-delay:.06s}
.rank .rrow:nth-child(4){animation-delay:.09s}.rank .rrow:nth-child(5){animation-delay:.12s}
.rank .rrow:nth-child(6){animation-delay:.15s}.rank .rrow:nth-child(7){animation-delay:.18s}
.rank .rrow:nth-child(n+8){animation-delay:.2s}
.cols-auto>.tile:nth-child(2){animation-delay:.04s}.cols-auto>.tile:nth-child(3){animation-delay:.08s}
.cols-auto>.tile:nth-child(4){animation-delay:.12s}.cols-auto>.tile:nth-child(5){animation-delay:.16s}
.cols-auto>.tile:nth-child(n+6){animation-delay:.2s}

/* ---------- Rank list ---------- */
.rank h3{margin:0 0 2px}.rank .meta{color:var(--dim);font-size:.82rem;margin:0 0 10px}
.rrow{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:1px solid var(--border-soft)}
.rrow:last-child{border-bottom:none}
.rnum{width:26px;height:26px;flex:none;display:flex;align-items:center;justify-content:center;border-radius:50%;
  font-weight:800;font-size:.78rem;background:rgba(255,255,255,.05);color:var(--dim)}
.rrow:nth-child(1) .rnum{background:linear-gradient(135deg,#fbbf24,#fcd34d);color:#3a2c05}
.rrow:nth-child(2) .rnum{background:linear-gradient(135deg,#cbd5e1,#e2e8f0);color:#1e2733}
.rrow:nth-child(3) .rnum{background:linear-gradient(135deg,#d2986a,#e0aa7e);color:#3a2410}
.rimg{width:34px;height:34px;flex:none;object-fit:contain;background:radial-gradient(circle at 50% 30%,#16202f,#0c121b);border-radius:8px;padding:3px;border:1px solid var(--border-soft)}
.rname{flex:1;font-size:.92rem}.rval{font-weight:700;color:var(--accent2);white-space:nowrap;text-align:right}
.rlink{color:var(--text);text-decoration:none;transition:color .12s}.rlink:hover{color:var(--accent2);text-decoration:underline}
.rsell{color:var(--good);font-weight:700}.u{font-size:.7rem;color:var(--dim)}
.star{background:none;border:none;color:var(--warn);font-size:1.2rem;cursor:pointer;flex:none;padding:0 2px;line-height:1;transition:transform .12s}
.star:hover{transform:scale(1.2)}.star.on{color:var(--warn)}

/* ---------- Codex ---------- */
.ic{cursor:pointer;overflow:hidden;display:flex;flex-direction:column}
.ic img{width:100%;aspect-ratio:1/1;object-fit:contain;background:radial-gradient(circle at 50% 30%,#16202f,#0c121b);padding:12px;transition:var(--tr)}
.ic:hover{transform:translateY(-4px);border-color:rgba(56,189,248,.4);box-shadow:var(--glow)}
.ic:hover img{transform:scale(1.05)}
.ic .info{padding:11px 13px 14px}
.ic .nm{font-weight:700;margin:0 0 4px;font-size:.95rem}
.ic .mt{font-size:.76rem;color:var(--dim)}
/* Bordures par rareté (mods du Codex) */
.ic-rar-common{border-color:rgba(176,141,87,.55)!important;box-shadow:inset 0 -3px 0 rgba(176,141,87,.5),var(--shadow)}
.ic-rar-uncommon{border-color:rgba(203,213,225,.55)!important;box-shadow:inset 0 -3px 0 rgba(203,213,225,.5),var(--shadow)}
.ic-rar-rare{border-color:rgba(241,196,15,.6)!important;box-shadow:inset 0 -3px 0 rgba(241,196,15,.55),var(--shadow)}
.ic-rar-legendary{border-color:rgba(167,139,250,.7)!important;box-shadow:inset 0 -3px 0 rgba(167,139,250,.6),var(--shadow)}
.mrbadge{display:inline-block;margin-top:6px;font-size:.7rem;font-weight:700;padding:3px 9px;border-radius:7px;
  background:rgba(251,191,36,.16);color:var(--warn)}
.mrbadge.ok{background:rgba(52,211,153,.16);color:var(--good)}
.mrbadge.lock{background:rgba(251,113,133,.16);color:var(--bad)}

/* ---------- World ---------- */
.wc{overflow:hidden}
.wc h3{margin:0;padding:13px 16px;font-size:1rem;background:linear-gradient(90deg,rgba(56,189,248,.12),transparent);
  border-bottom:1px solid var(--border-soft);color:var(--text)}
.wc .body{padding:13px 16px}
.kv{display:flex;justify-content:space-between;gap:12px;padding:7px 0;border-bottom:1px dashed var(--border-soft)}
.kv:last-child{border-bottom:none}.kv .k{color:var(--dim)}.kv .v{font-weight:600;text-align:right}
.cyc{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cy{background:rgba(255,255,255,.03);border:1px solid var(--border-soft);border-radius:var(--r-sm);padding:12px;text-align:center}
.cy .n{font-size:.78rem;color:var(--dim);margin-bottom:7px}
.badge{display:inline-block;padding:3px 11px;border-radius:999px;font-size:.76rem;font-weight:700;
  background:rgba(125,211,252,.15);color:var(--accent2)}

/* ---------- News ---------- */
.news{overflow:hidden;display:flex;flex-direction:column}
.news img{width:100%;aspect-ratio:16/9;object-fit:cover;background:#0d1420}
.news .body{padding:15px 17px}
.tag{display:inline-block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  padding:3px 9px;border-radius:999px;background:rgba(56,189,248,.15);color:var(--accent2)}
.tag.up{background:rgba(251,191,36,.18);color:var(--warn)}

/* ---------- Guide ---------- */
.guide-toc{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px}
.guide-toc a{background:rgba(255,255,255,.04);border:1px solid var(--border);padding:7px 13px;border-radius:999px;font-size:.85rem;transition:var(--tr)}
.guide-toc a:hover{border-color:var(--accent);color:var(--accent2)}
.guide-sec{margin-bottom:16px;padding:18px 22px}
.guide-sec ul{margin:6px 0;padding-left:20px}.guide-sec li{margin-bottom:7px;line-height:1.5}
.guide-sec p{line-height:1.6}
.warnbox{border-left:4px solid var(--warn);background:rgba(251,191,36,.08);padding:11px 15px;border-radius:var(--r-sm);margin:12px 0}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text);padding:7px 13px;border-radius:9px;font-size:.88rem;font-weight:600;transition:var(--tr)}
.chip:hover{border-color:var(--accent)}
.accent-chip{display:inline-flex;align-items:center;gap:7px;cursor:pointer}
.accent-chip.on{border-color:var(--accent);color:var(--accent2);box-shadow:0 0 0 1px rgba(56,189,248,.3) inset}
.accent-dot{width:13px;height:13px;border-radius:50%;flex:none;box-shadow:0 0 6px rgba(0,0,0,.4)}
.fcd{font-weight:700;color:var(--accent2);font-variant-numeric:tabular-nums}
.fcd.ready{color:var(--good)}
.plchip{cursor:pointer}
.plchip.on{border-color:var(--accent);background:rgba(56,189,248,.16);color:var(--accent2);box-shadow:0 0 0 1px rgba(56,189,248,.3) inset}
.plchip[disabled]{opacity:.4;cursor:not-allowed}
.linkbox{border:1px solid rgba(56,189,248,.4)!important;background:linear-gradient(135deg,rgba(56,189,248,.09),transparent)!important;margin-top:16px}
.linkrow{display:flex;gap:10px;flex-wrap:wrap}.linkrow .btn{flex:1;min-width:130px;text-align:center}
select.input{appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='%239fb0c9'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;background-size:11px;padding-right:34px}

/* ---------- Stat grid / chips ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(124px,1fr));gap:12px;margin-top:12px}
.st{background:rgba(255,255,255,.03);border:1px solid var(--border-soft);border-radius:var(--r-sm);padding:13px 15px}
.st .l{font-size:.7rem;text-transform:uppercase;color:var(--dim);letter-spacing:.4px}
.st .vv{font-size:1.08rem;font-weight:800;margin-top:2px}
.chk{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px dashed var(--border-soft);cursor:pointer}
.chk:last-child{border-bottom:none}.chk input{width:20px;height:20px;accent-color:var(--accent);flex:none}
.fav-hit{border-color:var(--good)!important;box-shadow:0 0 0 1px var(--good),0 8px 30px -10px rgba(52,211,153,.5)}
table.cmp{width:100%;border-collapse:collapse}
table.cmp th,table.cmp td{border-bottom:1px solid var(--border-soft);padding:9px 11px;text-align:left;font-size:.92rem}
table.cmp th{color:var(--accent2);font-weight:700}
table.cmp td.win{color:var(--good);font-weight:800}

/* ---------- Fashion / accessoires (Codex) ---------- */
ul.fashion{margin:10px 0 0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:9px}
ul.fashion li{position:relative;padding:12px 14px 12px 40px;border-radius:12px;line-height:1.5;font-size:.93rem;
  background:linear-gradient(135deg,rgba(129,140,248,.13),rgba(56,189,248,.05));
  border:1px solid var(--border-soft);border-left:3px solid var(--indigo);
  box-shadow:0 4px 14px -10px rgba(129,140,248,.5);transition:var(--tr)}
ul.fashion li:hover{transform:translateX(2px);border-left-color:var(--accent);
  box-shadow:0 6px 18px -10px rgba(56,189,248,.55);background:linear-gradient(135deg,rgba(129,140,248,.18),rgba(56,189,248,.08))}
ul.fashion li::before{content:"💅";position:absolute;left:12px;top:12px;font-size:1rem;filter:drop-shadow(0 1px 4px rgba(129,140,248,.6))}
ul.fashion li.muted{background:rgba(255,255,255,.03);border-left-color:var(--border);font-size:.86rem}
ul.fashion li.muted::before{content:"✦";color:var(--accent2)}

/* ---------- Assistant de farm (plan) ---------- */
.farmplan{position:relative;overflow:hidden}
.farmplan::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--indigo))}
.farmplan .fp-head{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.farmplan .fp-ava{width:64px;height:64px;flex:none;object-fit:contain;border-radius:14px;padding:5px;
  background:radial-gradient(circle at 50% 28%,#1a2536,#0b1118);border:1px solid var(--border-soft);
  box-shadow:0 6px 18px -10px rgba(0,0,0,.7)}
.farmplan .fp-ava-res{display:flex;align-items:center;justify-content:center;font-size:1.7rem}
.farmplan h3{counter-increment:fpstep;display:flex;align-items:center;gap:9px;margin:18px 0 9px;
  padding-bottom:7px;border-bottom:1px solid var(--border-soft)}
.farmplan h3::before{content:"";width:4px;height:1.05em;border-radius:3px;background:linear-gradient(180deg,var(--accent),var(--indigo));flex:none}
.farmplan .kv{padding:9px 10px;border-radius:9px;border-bottom:none;margin-bottom:4px;transition:background .14s}
.farmplan .kv:hover{background:rgba(56,189,248,.07)}
.farmplan .kv .k{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text)}
.farmplan .kv .v{color:var(--accent2);font-weight:600}
.farmplan ul.fp-spots{margin:8px 0 0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.farmplan ul.fp-spots li{position:relative;padding:10px 12px 10px 32px;border-radius:9px;line-height:1.45;
  background:rgba(255,255,255,.03);border:1px solid var(--border-soft)}
.farmplan ul.fp-spots li::before{content:"📍";position:absolute;left:10px;top:10px;font-size:.9rem}
@media(max-width:560px){.farmplan .fp-ava{width:52px;height:52px}.farmplan .kv{flex-direction:column;gap:2px}.farmplan .kv .v{text-align:left}}

/* ---------- Fond Warframe aléatoire ---------- */
#wfbg{position:fixed;inset:0;z-index:-1;background-position:center top;background-size:cover;background-repeat:no-repeat;
  opacity:0;transition:opacity .9s ease;pointer-events:none}
#wfbg.on{opacity:.13}
#wfbg::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 50% 0%,transparent,rgba(8,11,18,.65) 70%,rgba(8,11,18,.92))}
body.light #wfbg.on{opacity:.09}
body.light #wfbg::after{background:radial-gradient(120% 90% at 50% 0%,transparent,rgba(238,242,248,.5) 70%,rgba(238,242,248,.85))}

/* ---------- Bons plans (deals) ---------- */
.deal{display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden;transition:var(--tr)}
.deal:hover{transform:translateY(-3px);border-color:rgba(56,189,248,.4);box-shadow:var(--glow)}
.deal-h{display:flex;align-items:center;gap:10px}
.deal-ic{width:38px;height:38px;flex:none;display:flex;align-items:center;justify-content:center;font-size:1.2rem;
  border-radius:11px;background:linear-gradient(135deg,rgba(56,189,248,.18),rgba(129,140,248,.14));border:1px solid var(--border-soft)}
.deal-h h3{margin:0;color:var(--text);font-size:1.02rem}
.deal-d{color:var(--dim);font-size:.9rem;margin:0;flex:1;line-height:1.5}
.deal-sub{color:var(--accent2);font-size:.82rem;font-weight:600;margin:0}
.deal-note{color:var(--dim);font-size:.82rem;font-style:italic}
.deal .btn{align-self:flex-start;margin-top:2px}

/* ---------- Graphique de prix ---------- */
.pchart{display:block;width:100%;height:auto;margin:10px 0 4px;overflow:visible}
.pchart text{font-family:inherit}

/* ---------- Modal ---------- */
.modal{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:16px}
.modal.hide{display:none}
.modal-bd{position:absolute;inset:0;background:rgba(4,7,12,.72);backdrop-filter:blur(4px);animation:fadeIn .2s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-box{position:relative;background:linear-gradient(180deg,#18212f,#121925);border:1px solid var(--border);
  border-radius:18px;max-width:640px;width:100%;max-height:86vh;overflow-y:auto;padding:26px;box-shadow:0 30px 80px -20px rgba(0,0,0,.8);
  animation:popIn .24s cubic-bezier(.2,.8,.2,1)}
@keyframes popIn{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}
.modal-x{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--dim);font-size:1.9rem;cursor:pointer;line-height:1;transition:var(--tr)}
.modal-x:hover{color:var(--text)}
.foot{border-top:1px solid var(--border-soft);padding:22px;text-align:center;color:var(--dim);font-size:.82rem}

/* ---------- Bouton recherche topbar ---------- */
.searchbtn{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.04);
  border:1px solid var(--border);color:var(--dim);border-radius:10px;padding:7px 12px;cursor:pointer;font-size:.9rem;transition:var(--tr)}
.searchbtn:hover{border-color:var(--accent);color:var(--accent2);background:rgba(56,189,248,.07)}
kbd,.kbd{font-family:inherit;font-size:.72rem;background:rgba(255,255,255,.08);border:1px solid var(--border);
  border-radius:6px;padding:1px 6px;color:var(--dim);line-height:1.4}

/* ---------- Palette de recherche ---------- */
.palette{position:fixed;inset:0;z-index:70;display:flex;justify-content:center;align-items:flex-start;padding:12vh 16px 16px}
.palette.hide{display:none}
.palette-bd{position:absolute;inset:0;background:rgba(4,7,12,.7);backdrop-filter:blur(6px);animation:fadeIn .18s}
.palette-box{position:relative;width:100%;max-width:600px;background:linear-gradient(180deg,#1a2433,#121925);
  border:1px solid var(--border);border-radius:16px;box-shadow:0 40px 90px -20px rgba(0,0,0,.85);overflow:hidden;
  animation:popIn .2s cubic-bezier(.2,.8,.2,1)}
.palette-input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--border-soft);
  color:var(--text);font-size:1.1rem;padding:18px 20px;outline:none}
.palette-input::placeholder{color:#6f819c}
.palette-results{max-height:54vh;overflow-y:auto;padding:6px}
.presult{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;cursor:pointer;font-size:.96rem}
.presult .pi{font-size:1.15rem;width:24px;text-align:center;flex:none}
.presult .psub{margin-left:auto;color:var(--dim);font-size:.78rem}
.presult.active,.presult:hover{background:rgba(56,189,248,.14);color:var(--accent2)}
.palette-foot{padding:9px 16px;border-top:1px solid var(--border-soft);color:var(--dim);font-size:.74rem;display:flex;gap:10px;flex-wrap:wrap}

/* ---------- Toasts ---------- */
.toasts{position:fixed;left:0;right:0;bottom:calc(20px + env(safe-area-inset-bottom,0px));z-index:90;
  display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none;padding:0 12px}
.toast{background:linear-gradient(180deg,#1c2736,#151d29);border:1px solid var(--border);border-left:4px solid var(--accent);
  color:var(--text);padding:12px 18px;border-radius:12px;box-shadow:var(--shadow);font-weight:600;font-size:.92rem;
  max-width:440px;animation:toastIn .25s cubic-bezier(.2,.8,.2,1)}
.toast.good{border-left-color:var(--good)} .toast.bad{border-left-color:var(--bad)}
.toast.out{animation:toastOut .3s forwards}
@keyframes toastIn{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateY(10px)}}

/* ---------- Barre de navigation basse (mobile) ---------- */
.botnav{display:none}
@media(max-width:760px){
  .searchbtn{padding:7px 10px}
  main{padding-bottom:90px}
  .foot{margin-bottom:64px}
  .botnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:50;
    background:rgba(10,14,22,.86);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);
    border-top:1px solid var(--border-soft);padding:6px 4px calc(6px + env(safe-area-inset-bottom,0px))}
  .botnav>a,.botnav>button{flex:1;background:none;border:none;color:var(--dim);display:flex;flex-direction:column;
    align-items:center;gap:2px;font-size:.66rem;font-weight:600;padding:6px 2px;cursor:pointer;border-radius:10px;transition:var(--tr)}
  .botnav .bi{font-size:1.25rem;line-height:1}
  .botnav>a.active{color:var(--accent2)}
  .botnav>a.active .bi{filter:drop-shadow(0 0 8px rgba(56,189,248,.7))}
}

/* ---------- Nav repliée (≤900px) : burger + panneau déroulant + sous-menus accordéon ---------- */
@media(max-width:900px){
  .burger{display:inline-flex;align-items:center;justify-content:center}
  .nav{display:none;position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;gap:4px;
    background:linear-gradient(180deg,#141b27,#0d131d);border-bottom:1px solid var(--border);
    padding:12px 18px calc(16px + env(safe-area-inset-bottom,0px));max-height:calc(100vh - 60px);overflow-y:auto;
    box-shadow:0 30px 60px -22px rgba(0,0,0,.85)}
  body.light .nav{background:linear-gradient(180deg,#fff,#eef2f8)}
  .nav.open{display:flex;animation:fadeUp .2s ease}
  .navlink{width:100%;padding:13px 14px}
  /* scopé à .nav : le menu langue (.langmenu) de la topbar garde son dropdown */
  .nav .navmenu{width:100%}
  .nav .navbtn{width:100%;justify-content:space-between;padding:13px 14px}
  .nav .navpanel{position:static;min-width:0;display:none;box-shadow:none;border:none;background:transparent;padding:2px 0 8px 12px;gap:2px;animation:none}
  .nav .navmenu.open>.navpanel{display:flex}
  .nav .navpanel a{padding:12px 14px}
}
/* ---------- Mobile (≤760px) ---------- */
@media(max-width:760px){
  main{padding:26px 18px 92px}
  h1{font-size:1.55rem}
  h2{margin:32px 0 14px}
  .sub{margin-bottom:24px;font-size:1rem}
  .searchbtn .sk,.searchbtn .kbd{display:none}
}

/* ---------- Light theme ---------- */
body.light{--bg:#eef2f8;--bg2:#f6f8fc;--elev:#ffffff;--card:rgba(255,255,255,.85);--card-solid:#fff;
  --border:#d5deec;--border-soft:rgba(40,60,100,.12);--text:#16213a;--dim:#5b6b86;
  --shadow:0 10px 30px -12px rgba(40,60,90,.22);
  background:
    radial-gradient(900px 500px at 12% -8%,rgba(129,140,248,.14),transparent 60%),
    radial-gradient(1000px 600px at 88% -4%,rgba(56,189,248,.16),transparent 55%),
    linear-gradient(180deg,#f6f8fc,#eef2f8 40%)}
body.light .brand{background:linear-gradient(90deg,#0b2540,#0b5cab);-webkit-background-clip:text;background-clip:text}
body.light h1{background:linear-gradient(92deg,#0b2540,#0b5cab);-webkit-background-clip:text;background-clip:text;color:transparent}
body.light .topbar{background:rgba(255,255,255,.78)}
body.light .nav a.active,body.light .pill.active,body.light .btn.primary{color:#06121d}
