/* ===== Warframe Buddy — thème Vitruvian ===== */
:root{
  --bg:#080704; --bg-2:#0d0c08; --surface:#13120d; --surface-2:#1c1b14;
  --line:#3a2e18; --line-soft:#221d0e; --text:#e8d8a8; --muted:#9a8a68; --faint:#6a5e44;
  --energy:#c8a040; --energy-dim:#7a6020; --prime:#e8c870; --prime-dim:#8a7030;
  --helminth:#8ab060; --helminth-dim:#4e6030; --ok:#78b858; --warn:#d89030; --danger:#c84848;
  --radius:12px; --radius-input:12px;
  --mono:ui-monospace,"SF Mono","Cascadia Code","Roboto Mono",Menlo,Consolas,monospace;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:
    radial-gradient(1000px 500px at 70% 0%, rgba(200,160,64,.05), transparent 55%),
    var(--bg);
  color:var(--text); font-family:var(--sans); font-size:15px; line-height:1.5; -webkit-font-smoothing:antialiased;
}
a{color:var(--energy)}
h1,h2,h3{margin:0;font-weight:650;letter-spacing:.2px}
[hidden]{display:none!important}

/* champs arrondis (global) — couvre aussi les inputs sans attribut type */
input:not([type=checkbox]):not([type=radio]),select,textarea{
  background:var(--surface);border:1px solid var(--line);color:var(--text);
  border-radius:var(--radius-input);padding:10px 13px;font:inherit;outline:none;transition:.15s;
}
input:not([type=checkbox]):not([type=radio]):focus,select:focus,textarea:focus{border-color:var(--energy);box-shadow:0 0 0 3px rgba(200,160,64,.14)}
select{cursor:pointer}

/* ===== Select custom (harmonisé au thème, remplace le rendu natif) ===== */
.csel{position:relative;width:100%}
.csel > select{display:none}
.csel-btn{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:var(--surface);border:1px solid var(--line);color:var(--text);
  border-radius:var(--radius-input);padding:10px 13px;text-align:left;
  font-family:var(--sans);font-size:14px;text-transform:none;letter-spacing:0;
  cursor:pointer;outline:none;transition:.15s;
}
.csel-btn::after{
  content:"";flex:none;width:8px;height:8px;margin-left:auto;
  border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);
  transform:translateY(-2px) rotate(45deg);transition:transform .18s,border-color .18s;
}
.csel-btn:hover{border-color:var(--energy-dim)}
.csel.open .csel-btn,.csel-btn:focus-visible{border-color:var(--energy);box-shadow:0 0 0 3px rgba(200,160,64,.14)}
.csel.open .csel-btn::after{transform:translateY(1px) rotate(225deg);border-color:var(--energy)}
.csel-panel{
  position:absolute;left:0;right:0;top:calc(100% + 5px);z-index:80;
  background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:5px;overflow:hidden auto;max-height:240px;
  box-shadow:0 18px 44px rgba(0,0,0,.55);animation:pop .14s ease;
}
.csel-panel[hidden]{display:none}
.csel-opt{
  display:flex;align-items:center;gap:8px;padding:9px 11px;border-radius:8px;
  color:var(--text);font-family:var(--sans);font-size:14px;text-transform:none;letter-spacing:0;
  cursor:pointer;transition:background .12s,color .12s;
}
.csel-opt:hover,.csel-opt.active{background:rgba(200,160,64,.12);color:var(--prime)}
.csel-opt.sel{color:var(--prime)}
.csel-opt.sel::before{content:"✓";color:var(--energy);font-size:12px;font-weight:700;margin-left:-2px}
.csel-opt:not(.sel)::before{content:"";width:10px}
.csel-opt.disabled{color:var(--faint);cursor:default;background:none}
.csel-btn:disabled{opacity:.5;cursor:not-allowed}
.csel-btn:disabled::after{border-color:var(--faint)}
/* contrôles compacts (pastille de statut) : largeur fixe pour ne pas sauter entre statuts */
.csel-inline{width:auto;display:inline-flex}
.csel-inline .csel-btn{width:auto}
.csel-inline .csel-btn::after{width:6px;height:6px;border-width:1.5px}
/* ajusté au contenu (comme la pastille « up to date ») ; hauteur/padding gérés près de .cfg-top */
.csel-btn.build-status{gap:7px}
/* hauteur des champs dans les cartes de config (hors pastille de statut) */
.cfg .csel-btn:not(.build-status){font-size:13.5px;padding:9px 12px}

.btn{appearance:none;border:1px solid var(--line);background:var(--surface-2);color:var(--text);border-radius:var(--radius-input);padding:9px 15px;font:inherit;font-size:13px;cursor:pointer;transition:.15s}
.btn:hover{border-color:var(--energy)}
.btn.primary{background:var(--energy);color:var(--bg);border-color:var(--energy);font-weight:600}
.btn.primary:hover{box-shadow:0 0 18px rgba(200,160,64,.45)}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn:disabled:hover{border-color:var(--line);box-shadow:none}
.btn.ghost{background:transparent}
.btn.danger{color:var(--danger);border-color:#4a2020}
.btn.danger:hover{background:rgba(200,72,72,.1)}
.btn.block{width:100%;justify-content:center;padding:12px}
.btn.small{padding:6px 11px;font-size:12px}

/* ===== AUTH ===== */
.auth{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(800px 500px at 50% 0%,rgba(200,160,64,.07),transparent 55%),var(--bg);z-index:100}
.auth-card{width:100%;max-width:400px;background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.auth-brand{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;text-transform:uppercase;letter-spacing:3px}
.auth-brand .glyph{color:var(--energy);text-shadow:0 0 18px rgba(200,160,64,.6)}
.auth-tag{color:var(--muted);font-size:13px;margin:12px 0 20px}
.auth-tabs{display:flex;gap:6px;margin-bottom:18px;background:var(--bg-2);padding:5px;border-radius:12px;border:1px solid var(--line-soft)}
.auth-tab{flex:1;appearance:none;border:0;background:transparent;color:var(--muted);padding:9px;border-radius:8px;font:inherit;font-size:13px;cursor:pointer;transition:.15s}
.auth-tab.active{background:var(--surface-2);color:var(--energy)}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-form .field{display:flex;flex-direction:column;gap:6px}
.auth-form .field span{font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--faint)}
.auth-err{color:var(--danger);font-size:13px;margin:0;background:rgba(200,72,72,.08);border:1px solid #4a2020;border-radius:10px;padding:9px 12px}
.auth-note{color:var(--faint);font-size:11px;margin:16px 0 0;text-align:center}
.turnstile-box{display:flex;justify-content:center;min-height:65px}

/* ===== Topbar ===== */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:13px 24px;background:linear-gradient(180deg,rgba(8,7,4,.97),rgba(8,7,4,.84));backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:13px;flex:1}
.brand .glyph{font-size:24px;color:var(--energy);text-shadow:0 0 18px rgba(200,160,64,.6)}
.brand h1{font-size:17px;text-transform:uppercase;letter-spacing:3px}
.brand .sub{margin:0;font-size:11px;color:var(--faint);font-family:var(--mono)}
.tabs{display:flex;gap:4px}
.tab{appearance:none;border:0;cursor:pointer;background:transparent;color:var(--muted);padding:9px 16px;border-radius:9px;font:inherit;font-size:13px;text-transform:uppercase;letter-spacing:1.5px;transition:.15s}
.tab:hover{color:var(--text);background:var(--surface)}
.tab.active{color:var(--bg);background:var(--energy);box-shadow:0 0 22px rgba(200,160,64,.4)}
.userchip{display:flex;align-items:center;gap:10px;flex:1;justify-content:flex-end}
.userchip .uname{font-size:13px;color:var(--muted);font-family:var(--mono)}
.userchip .uname::before{content:"◆ ";color:var(--energy)}

main{max-width:1180px;margin:0 auto;padding:24px}
.view{display:none}
.view.active{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ===== Statbar ===== */
.statbar{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.stat{flex:1;min-width:130px;background:linear-gradient(180deg,var(--surface),var(--bg-2));border:1px solid var(--line-soft);border-radius:var(--radius);padding:14px 16px}
.stat .n{font-family:var(--mono);font-size:26px;font-weight:600;color:var(--energy)}
.stat .l{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--faint);margin-top:2px}
.stat.owned .n{color:var(--ok)}.stat.prime .n{color:var(--prime)}.stat.helm .n{color:var(--helminth)}

/* ===== Filtres ===== */
.filters{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:18px}#search,#helminthSearch{flex:1;min-width:220px}
.filter-switches{display:flex;align-items:center;gap:18px;margin-left:auto}
.seg{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-input);overflow:hidden}
.seg button{appearance:none;border:0;background:transparent;color:var(--muted);cursor:pointer;padding:9px 13px;font:inherit;font-size:13px;border-right:1px solid var(--line-soft)}
.seg button:last-child{border-right:0}
.seg button:hover{color:var(--text)}
.seg button.on{background:var(--surface-2);color:var(--energy)}
.check{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-size:13px;cursor:pointer;user-select:none}
.check input{position:absolute;opacity:0;width:0;height:0}
.check span{width:16px;height:16px;border-radius:4px;border:1px solid var(--line);background:var(--surface-2);flex:none;position:relative;transition:.15s}
.check span::after{content:"";position:absolute;top:2px;left:5px;width:4px;height:8px;border:2px solid transparent;border-top:0;border-left:0;transform:rotate(45deg);transition:.15s}
.check input:checked + span{background:var(--energy-dim);border-color:var(--energy)}
.check input:checked + span::after{border-color:var(--energy)}

/* ===== Cartes (arsenal + helminth) ===== */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.card{position:relative;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:.15s}
.card:hover{border-color:var(--energy-dim);transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,0,0,.4)}
.card.owned{border-color:var(--energy-dim)}
.card.owned::before{content:"";position:absolute;inset:0;border-radius:var(--radius);box-shadow:inset 0 0 0 1px rgba(200,160,64,.28);pointer-events:none}
.card-img{position:relative;height:122px;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120px 80px at 50% 30%,rgba(200,160,64,.09),transparent),var(--bg-2);border-bottom:1px solid var(--line-soft);overflow:hidden}
.card-img.prime{background:radial-gradient(120px 80px at 50% 30%,rgba(232,200,112,.12),transparent),var(--bg-2)}
.card-img img{max-height:100%;max-width:100%;object-fit:contain;filter:drop-shadow(0 6px 14px rgba(0,0,0,.5))}
.card-img .img-fb{position:absolute;font-family:var(--mono);font-size:30px;font-weight:700;color:var(--faint);letter-spacing:1px}
.card-img.has-img .img-fb{display:none}
.card-body{padding:12px 13px 13px;display:flex;flex-direction:column;gap:7px;flex:1}
.card-name{font-weight:650;font-size:14px;display:flex;align-items:center;gap:7px;flex-wrap:wrap;line-height:1.25}
.card-item-note{font-size:11px;font-weight:400;font-style:italic;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-name.prime{color:var(--prime)}
.badge-prime{font-family:var(--mono);font-size:9px;letter-spacing:1px;color:var(--prime);border:1px solid var(--prime-dim);border-radius:5px;padding:1px 5px;text-transform:uppercase}
.card-sub{font-size:11px;color:var(--faint);font-family:var(--mono)}
.card-pills{display:flex;gap:6px;flex-wrap:wrap;padding-top:4px}
.card-extra{margin-top:auto;padding-top:6px;display:flex;flex-direction:column;gap:7px}
.card-configs{display:flex;flex-direction:column;gap:3px}
.ccfg{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--muted);background:var(--bg-2);border:1px solid var(--line-soft);border-radius:8px;padding:6px 9px}
.ccfg.none{align-items:center;color:var(--faint);font-style:italic}
/* Ligne 1 : état · statut · titre · rôle · version */
.ccfg-l1{display:flex;align-items:center;gap:7px}
.cdot{width:8px;height:8px;border-radius:50%;flex:none}
.cdot.ok{background:var(--ok);box-shadow:0 0 7px rgba(120,184,88,.5)}
.cdot.out{background:var(--warn);box-shadow:0 0 7px color-mix(in srgb,var(--warn) 45%,transparent)}
.ccfg-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);font-weight:600}
.ccfg-role{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11px;color:var(--muted);font-style:italic}
.ccfg-ver{margin-left:auto;flex:none;font-family:var(--mono);font-size:10.5px;color:var(--faint)}
.ccfg-build{font-size:11px;flex:none}
/* Ligne 2 : helminth (logo + pouvoir subsumé) · 5 shards */
.ccfg-l2{display:flex;align-items:center;gap:8px;padding-top:5px;border-top:1px solid color-mix(in srgb,var(--line-soft) 60%,transparent)}
.ccfg-helm2{display:flex;align-items:center;gap:5px;min-width:0;flex:1;white-space:nowrap;overflow:hidden}
.ccfg-helm2 .hlogo{flex:none;color:var(--helminth);font-size:13px;line-height:1}
.ccfg-helm2.off .hlogo{color:var(--muted)}
.ccfg-helm2 .hab-ic{width:17px;height:17px;flex:none;object-fit:contain;border-radius:3px;filter:drop-shadow(0 0 3px var(--helminth-dim))}
.ccfg-helm2 .hab-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11px;color:var(--helminth)}
.ccfg-helm2 .hab-name.has-desc{cursor:help;text-decoration:underline dotted color-mix(in srgb,var(--helminth) 55%,transparent);text-underline-offset:2px}
.ccfg-helm2 .hnone{font-size:11px;font-style:italic;color:var(--muted)}
.ccfg-shards5{display:flex;align-items:center;gap:3px;flex:none;margin-left:auto}
.cs5{width:15px;height:15px;flex:none;display:inline-flex;align-items:center;justify-content:center;line-height:0}
.cs5 img{width:15px;height:15px;object-fit:contain;display:block}
.cs5.vacant img{opacity:.28;filter:grayscale(1) brightness(.8)}
.cs5.filled img{filter:drop-shadow(0 0 2px color-mix(in srgb,var(--energy) 40%,transparent))}
.cs5.tau img{filter:drop-shadow(0 0 4px #fff) drop-shadow(0 0 2px #fff);transform:scale(1.04)}
.ccfg-build.tbuild{filter:hue-rotate(200deg) saturate(.8)}
.ccfg-build.wip{filter:saturate(.6)}
.pill{font-family:var(--mono);font-size:10.5px;padding:2px 8px;border-radius:20px;border:1px solid var(--line);color:var(--muted);white-space:nowrap}
.pill.ok{color:var(--ok);border-color:var(--energy-dim)}
.pill.out{color:var(--warn);border-color:#5b4422}
.pill.helm{color:var(--helminth);border-color:var(--helminth-dim)}
.pill.muted{color:var(--faint)}
.pill.done{color:var(--ok);border-color:var(--energy-dim)}
.pill.tbuild{color:#7890e0;border-color:#2a3060}
.pill.wip{color:var(--warn);border-color:#5b4422}
.card-footer{display:flex;align-items:stretch;border-top:1px solid var(--line-soft);background:var(--surface-2)}
.card-own{padding:8px 10px;flex:1;min-width:0;display:flex;align-items:center}
.card-own-lbl{font-size:11.5px;color:var(--muted);font-style:normal;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:.15s}
.card-own input:checked ~ .card-own-lbl{color:var(--energy)}
.card-cfgbtn{appearance:none;border:0;border-left:1px solid var(--line-soft);background:var(--surface-2);color:var(--muted);
  padding:9px 11px;font:inherit;font-size:12px;cursor:pointer;transition:.12s;letter-spacing:.5px;flex-shrink:0;display:flex;align-items:center}
.card-cfgbtn:hover{background:rgba(200,160,64,.14);color:var(--energy)}
.card-wiki{border-left:1px solid var(--line-soft);background:var(--surface-2);color:var(--muted);text-decoration:none;
  padding:9px 11px;font-size:12px;cursor:pointer;transition:.12s;letter-spacing:.5px;flex-shrink:0;display:flex;align-items:center}
.card-wiki:hover{background:rgba(200,160,64,.14);color:var(--energy)}

/* chips d'aptitudes (Helminth) */
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.chip{appearance:none;border:1px solid var(--line);background:var(--bg-2);color:var(--muted);border-radius:20px;
  padding:4px 10px;font:inherit;font-size:11.5px;cursor:pointer;transition:.12s}
.chip:hover{border-color:var(--helminth-dim);color:var(--text)}
.chip.on{background:var(--helminth-dim);border-color:var(--helminth);color:#fff;font-weight:600}
.helm-ability{display:flex;flex-direction:column;gap:5px;margin-bottom:4px}
.helm-ab-header{display:flex;align-items:center;gap:7px}
.helm-ab-img{width:28px;height:28px;object-fit:contain;flex:none;filter:drop-shadow(0 0 4px var(--helminth-dim))}
.helm-chosen{font-size:12px;font-weight:600;color:var(--helminth)}
.helm-ab-desc{font-size:11px;color:var(--muted);line-height:1.4}
.hcard.owned{border-color:var(--helminth-dim)}
.hcard.owned::before{box-shadow:inset 0 0 0 1px rgba(138,176,96,.3)}
.hcard .card-img{background:radial-gradient(120px 80px at 50% 30%,rgba(138,176,96,.09),transparent),var(--bg-2)}

/* ===== Switch ===== */
.switch{position:relative;display:inline-flex;align-items:center;gap:9px;cursor:pointer;font-size:13px;color:var(--muted);user-select:none}
.switch input{position:absolute;opacity:0;width:0;height:0}
.switch span{width:40px;height:22px;border-radius:22px;background:var(--surface-2);border:1px solid var(--line);position:relative;transition:.18s;flex:none}
.switch span::after{content:"";position:absolute;top:1px;left:1px;width:18px;height:18px;border-radius:50%;background:var(--faint);transition:.18s}
.switch input:checked + span::after{transform:translateX(18px)}
.switch input:checked + span{background:var(--helminth-dim);border-color:var(--helminth)}
.switch input:checked + span::after{background:var(--helminth)}
.switch.energy input:checked + span{background:var(--energy-dim);border-color:var(--energy)}
.switch.energy input:checked + span::after{background:var(--energy)}
.card-own span{box-shadow:0 2px 8px rgba(0,0,0,.4)}

/* ===== Sections ===== */
.section-intro{margin-bottom:20px;max-width:780px}
.section-intro h2{font-size:20px;text-transform:uppercase;letter-spacing:2px}
.section-intro p{color:var(--muted);font-size:13px;margin:8px 0}
.section-intro .hint{color:var(--faint);font-size:12px}
.section-intro .count,.count{font-family:var(--mono);font-size:12px;color:var(--faint)}
.section-intro input{margin-top:6px;width:100%;max-width:440px}
.hl{color:var(--energy)}
.empty{padding:40px;text-align:center;color:var(--faint)}

/* ===== Versions (mainline / hotfix) ===== */

/* ===== Modal ===== */
.modal-backdrop{position:fixed;inset:0;z-index:60;background:rgba(5,3,1,.75);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.modal-backdrop[hidden]{display:none!important}
.modal{position:relative;width:100%;max-width:700px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:0 30px 80px rgba(0,0,0,.6);animation:pop .2s ease}
@keyframes pop{from{opacity:0;transform:scale(.98) translateY(8px)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:14px;right:14px;appearance:none;border:0;background:transparent;color:var(--faint);font-size:18px;cursor:pointer}
.modal-close:hover{color:var(--text)}
.modal-head{display:flex;align-items:center;gap:16px}
.modal-img{position:relative;width:84px;height:84px;flex:none;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(80px 60px at 50% 30%,rgba(200,160,64,.12),transparent),var(--bg-2);border:1px solid var(--line-soft);overflow:hidden}
.modal-img img{max-width:100%;max-height:100%;object-fit:contain}
.modal-img .img-fb{position:absolute;font-family:var(--mono);font-size:24px;font-weight:700;color:var(--faint)}
.modal-img.has-img .img-fb{display:none}
.modal.modal-narrow{max-width:460px}
.modal-head h2{font-size:22px}
.modal-head .modal-meta{color:var(--faint);font-family:var(--mono);font-size:12px;margin-top:4px}
.modal-wiki{margin-left:auto;margin-right:28px;align-self:center;flex-shrink:0;white-space:nowrap;display:inline-flex;align-items:center;gap:4px;
  padding:7px 12px;border:1px solid var(--line-soft);border-radius:8px;background:var(--surface-2);
  font-family:var(--mono);font-size:12px;letter-spacing:.5px;color:var(--muted);text-decoration:none;transition:.12s}
.modal-wiki:hover{background:rgba(200,160,64,.14);border-color:var(--energy);color:var(--energy)}

/* Formulaire de tâche personnalisée */
.task-form{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.task-form label{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--muted);font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em}
.task-form input,.task-form select{font-family:var(--sans);font-size:14px;text-transform:none;letter-spacing:0;color:var(--text)}
.task-form-hint{font-family:var(--sans);text-transform:none;letter-spacing:0;color:var(--faint);font-size:11px}
.task-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.task-form-actions{display:flex;align-items:center;gap:8px;margin-top:6px}
.task-form-actions .spacer{flex:1}
.own-row{display:flex;gap:14px;align-items:center;margin:18px 0;flex-wrap:wrap}
.own-row #mNotes{flex:1;min-width:200px}
.cfg-head{display:flex;align-items:center;justify-content:space-between;margin:18px 0 12px;border-top:1px solid var(--line-soft);padding-top:16px}
.cfg-head h3{font-family:var(--mono);font-size:14px;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted)}
.cfg-list{display:flex;flex-direction:column;gap:12px}
.cfg{border:1px solid var(--line);border-radius:var(--radius);padding:14px;background:var(--bg-2)}
/* En-tête de config : les 3 « bulles » (statut, à-jour, suppr.) partagent la même hauteur
   et un rayon de pastille cohérent (le ✕ devient un bouton rond de même hauteur). */
.cfg-top{display:flex;align-items:center;gap:10px;margin-bottom:12px;--cfg-pill-h:28px}
.cfg-top input.cname{flex:1;font-weight:600}
.cfg-status{display:inline-flex;align-items:center;height:var(--cfg-pill-h);font-family:var(--mono);font-size:11px;padding:0 11px;border-radius:20px;white-space:nowrap;line-height:1}
.cfg-status.ok{color:var(--ok);border:1px solid var(--energy-dim)}
.cfg-status.out{color:var(--warn);border:1px solid #5b4422}
.csel-btn.build-status{height:var(--cfg-pill-h);padding:0 11px;line-height:1}
.cfg-top .del{flex:none;width:var(--cfg-pill-h);height:var(--cfg-pill-h);padding:0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:13px;line-height:1}
.build-status{font-family:var(--mono);font-size:11px;padding:4px 10px;border-radius:20px;background:var(--surface-2);cursor:pointer}
.build-status.done{color:var(--ok);border:1px solid var(--energy-dim)}
.build-status.tbuild{color:#7890e0;border:1px solid #2a3060}
.build-status.wip{color:var(--warn);border:1px solid #5b4422}
.cfg-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cfg-grid .full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:6px}
.field>span{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--faint)}
.field input,.field select{width:100%}
/* harmonisation : tous les champs de config à la même taille/hauteur */
.cfg input,.cfg select{font-size:13.5px;padding:9px 12px}
.cfg-top input.cname{flex:1;font-weight:600;font-size:14px}
.cver{font-size:13px}
/* Hauteur identique : titre de config = BUILD VERSION (select) = TEMPLATE LINK (input) */
.cfg{--cfg-field-h:40px}
.cfg-top input.cname,
.cfg .field input,
.cfg .field .csel-btn{height:var(--cfg-field-h)}
/* zone Helminth de la config : interrupteur sur sa ligne, libellé collé (plus de césure) */
.helm-field{display:flex;flex-direction:column;align-items:stretch;gap:9px}
.helm-toggle{display:flex;align-items:center;justify-content:flex-start;gap:9px;width:fit-content;cursor:pointer;color:var(--text);font-size:13.5px;user-select:none}
.helm-toggle input{position:absolute;opacity:0;width:0;height:0}
.helm-box{width:17px;height:17px;border-radius:4px;border:1px solid var(--line);background:var(--surface-2);flex:none;position:relative;transition:.15s}
.helm-box::after{content:"";position:absolute;top:2px;left:5px;width:4px;height:9px;border:2px solid transparent;border-top:0;border-left:0;transform:rotate(45deg);transition:.15s}
.helm-toggle input:checked + .helm-box{background:var(--energy-dim);border-color:var(--energy)}
.helm-toggle input:checked + .helm-box::after{border-color:var(--energy)}
.helm-toggle span{white-space:nowrap}
/* ===== Archon Shards : sertissures Orokin encastrées + plateau de cristaux ===== */
/* Marquise (amande pointue) pour la gravure d'alvéole vide + la case Tauforged. */
:root{--xtl:polygon(0% 50%,8% 32%,24% 15%,50% 8%,76% 15%,92% 32%,100% 50%,92% 68%,76% 85%,50% 92%,24% 85%,8% 68%)}
.shard-field{display:flex;flex-direction:column;gap:11px}
.shard-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.shard-head>span:first-child{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--faint)}
.shard-count{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--faint)}
.shard-rail{display:flex;gap:9px;padding:4px 2px 2px;flex-wrap:wrap;align-items:center;justify-content:center}

/* Sertissure = alvéole sombre encastrée à liseré or ; le cristal (PNG officiel) s'y dépose. */
.shard-socket{--xc:#c8a040;position:relative;width:52px;height:52px;flex:none;padding:0;border:0;cursor:pointer;
  border-radius:14px;background:radial-gradient(125% 125% at 50% 32%,#171206,#0a0805 72%);
  box-shadow:inset 0 2px 6px rgba(0,0,0,.7),inset 0 0 0 1px rgba(212,178,106,.16);
  transition:box-shadow .18s ease,transform .18s ease}
/* Lueur de l'alvéole une fois sertie (radial teinté --xc, derrière l'image). */
.shard-socket::before{content:"";position:absolute;inset:6px;border-radius:10px;opacity:0;
  background:radial-gradient(60% 60% at 50% 52%,color-mix(in srgb,var(--xc) 60%,transparent),transparent 75%);
  transition:opacity .18s ease}
.shard-img{position:relative;width:88%;height:88%;margin:6%;object-fit:contain;display:block;
  filter:drop-shadow(0 2px 3px rgba(0,0,0,.6))}
.shard-socket:not(.filled) .shard-img{display:none}
/* Alvéole vide : marquise gravée, en attente (un peu plus présente pour lire « slot »). */
.shard-empty{position:absolute;top:50%;left:50%;width:54%;height:19%;
  transform:translate(-50%,-50%) rotate(-32deg);clip-path:var(--xtl);
  background:rgba(212,178,106,.22);transition:background .18s ease}
.shard-socket.filled .shard-empty{display:none}

/* --- États visuels (couleur) --- */
/* Serti (normal) : alvéole lumineuse + liseré coloré net + le cristal glow doucement dans sa
   couleur → un gemme « allumé », clairement présent (et non éteint à côté d'un Tauforged). */
.shard-socket.filled{box-shadow:inset 0 2px 6px rgba(0,0,0,.55),
  inset 0 0 7px color-mix(in srgb,var(--xc) 28%,transparent),
  inset 0 0 0 1px color-mix(in srgb,var(--xc) 68%,transparent),
  0 0 11px color-mix(in srgb,var(--xc) 34%,transparent)}
.shard-socket.filled::before{opacity:.62}
.shard-socket.filled .shard-img{
  filter:drop-shadow(0 2px 3px rgba(0,0,0,.6)) drop-shadow(0 0 4px color-mix(in srgb,var(--xc) 45%,transparent))}

/* Tauforged : alvéole qui rayonne + anneau lumineux (le « forgé », teinte dominante, blanc en
   rehaut) + cristal avivé. Remplace l'ancien point blanc d'angle qui faisait « badge » répété. */
.shard-socket.tau{box-shadow:inset 0 2px 6px rgba(0,0,0,.5),
  inset 0 0 10px color-mix(in srgb,var(--xc) 60%,transparent),
  0 0 0 2px color-mix(in srgb,var(--xc) 80%,#fff),
  0 0 17px color-mix(in srgb,var(--xc) 58%,transparent)}
.shard-socket.tau::before{opacity:.92}
.shard-socket.tau .shard-img{
  filter:drop-shadow(0 0 4px var(--xc)) drop-shadow(0 0 9px color-mix(in srgb,var(--xc) 75%,transparent)) brightness(1.13)}

/* --- États d'interaction (placés APRÈS la couleur pour gagner, même sur un socle Tauforged) --- */
.shard-socket:hover{transform:translateY(-2px)}
.shard-socket:hover:not(.filled) .shard-empty{background:rgba(212,178,106,.4)}
.shard-socket.editing{transform:translateY(-3px);box-shadow:inset 0 2px 6px rgba(0,0,0,.6),
  inset 0 0 0 1px var(--energy),0 0 12px color-mix(in srgb,var(--energy) 45%,transparent)}
.shard-socket.editing:not(.filled) .shard-empty{background:var(--energy)}
.shard-socket:focus-visible{outline:0;box-shadow:inset 0 2px 6px rgba(0,0,0,.6),inset 0 0 0 2px var(--energy)}

/* Plateau de cristaux (révélé sous le rail) : surface encastrée assortie aux sertissures. */
.shard-picker{margin-top:3px;padding:13px 14px;border:1px solid var(--line-soft);border-radius:13px;
  background:radial-gradient(140% 120% at 50% 0,#14100a,#0a0805 72%);
  box-shadow:inset 0 1px 0 rgba(212,178,106,.1);
  display:flex;flex-direction:column;gap:12px;animation:shardPick .18s ease}
@keyframes shardPick{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:none}}
.pick-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.pick-c{--xc:#c8a040;position:relative;width:46px;height:46px;flex:none;padding:0;border:0;cursor:pointer;
  border-radius:12px;background:radial-gradient(125% 125% at 50% 32%,#171206,#0a0805 72%);
  box-shadow:inset 0 1px 4px rgba(0,0,0,.6),inset 0 0 0 1px rgba(212,178,106,.14);
  transition:box-shadow .14s ease,transform .14s ease}
.pick-img{width:84%;height:84%;margin:8%;object-fit:contain;display:block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}
.pick-c:hover{transform:translateY(-2px)}
.pick-c.on{box-shadow:inset 0 1px 4px rgba(0,0,0,.6),
  inset 0 0 0 1px color-mix(in srgb,var(--xc) 70%,transparent),0 0 9px color-mix(in srgb,var(--xc) 35%,transparent)}
.pick-c.on .pick-img{filter:drop-shadow(0 0 6px var(--xc)) brightness(1.1)}
.pick-c:focus-visible{outline:0;box-shadow:inset 0 1px 4px rgba(0,0,0,.6),inset 0 0 0 2px var(--energy)}
.pick-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.pick-tau{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text);cursor:pointer;user-select:none}
.pick-tau input{position:absolute;opacity:0;width:0;height:0}
.pick-tau-box{width:20px;height:13px;flex:none;clip-path:var(--xtl);background:var(--surface-2);
  border:0;box-shadow:inset 0 0 0 1px var(--line);transition:.15s}
.pick-tau input:checked + .pick-tau-box{background:#fff;box-shadow:0 0 6px 1px rgba(255,255,255,.7)}
.pick-clear{font-family:var(--mono);font-size:10.5px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);
  background:transparent;border:1px solid var(--line-soft);border-radius:8px;padding:6px 11px;cursor:pointer;transition:.15s}
.pick-clear:hover{color:var(--danger);border-color:var(--danger)}

@media(prefers-reduced-motion:reduce){.shard-picker{animation:none}.shard-socket,.pick-c{transition:none}}
.cfg-foot{display:flex;justify-content:flex-end;margin-top:10px}
.linkout{font-size:12px;color:var(--energy);font-family:var(--mono)}

/* ===== Toast ===== */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--surface-2);border:1px solid var(--energy-dim);color:var(--text);padding:10px 18px;border-radius:12px;font-size:13px;z-index:120;box-shadow:0 10px 30px rgba(0,0,0,.5)}

@media(max-width:760px){
  .topbar{flex-wrap:wrap;gap:10px}
  .cfg-grid{grid-template-columns:1fr}
  .goal-form-grid3{grid-template-columns:1fr}
  main{padding:16px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

.hidden { display: none !important; }

/* ============ ADMIN ============ */
.admin-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 20px;margin-bottom:16px;
}
.admin-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}
.admin-card-head h3{font-size:1.05rem}
.admin-output{
  margin:14px 0 0;padding:12px 14px;background:var(--bg-2);border:1px solid var(--line-soft);
  border-radius:var(--radius-input);font-family:var(--mono);font-size:.82rem;line-height:1.45;
  color:var(--muted);white-space:pre-wrap;max-height:300px;overflow:auto;
}
.admin-users{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.auser{
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  background:var(--surface-2);border:1px solid var(--line-soft);border-radius:var(--radius-input);
  padding:11px 14px;
}
.auser.self{border-color:var(--energy-dim)}
.auser-main{display:flex;flex-direction:column;gap:3px;min-width:0}
.auser-name{font-weight:600;display:flex;align-items:center;gap:8px}
.auser-meta{color:var(--faint);font-size:.8rem}
.auser-actions{display:flex;gap:8px;flex-shrink:0}
.badge-admin,.badge-self{
  font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  padding:2px 7px;border-radius:999px;
}
.badge-admin{background:var(--energy-dim);color:#fff8e0}
.badge-self{background:var(--prime-dim);color:#ffeec2}

/* ============ TÂCHES ============ */
/* L'intro des tâches s'étend sur toute la largeur du tableau (pas le 780px global) :
   le paragraphe n'est plus coupé au milieu et le bouton Options se cale tout à droite. */
#view-tasks .section-intro,
#view-alerts .section-intro,
#view-goals .section-intro{max-width:none}
.tasks-filter-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:12px}
.tasks-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:10px}
.tasks-menu{position:relative;margin-left:auto}
.tasks-menu-pop{position:absolute;right:0;top:calc(100% + 6px);z-index:40;min-width:250px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:6px;display:flex;flex-direction:column;gap:2px;box-shadow:0 14px 40px rgba(0,0,0,.55)}
.tasks-menu-pop button{appearance:none;border:0;background:transparent;color:var(--text);
  text-align:left;padding:9px 11px;border-radius:8px;font:inherit;font-size:13px;cursor:pointer}
.tasks-menu-pop button:hover{background:var(--surface-2);color:var(--energy)}
#taskNotifBtn.on{border-color:var(--helminth);color:var(--helminth)}

.task-section{margin-bottom:22px;background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden}
.task-section-head{display:flex;align-items:center;gap:12px;padding:13px 16px;
  background:var(--bg-2);border-bottom:1px solid var(--line-soft);cursor:pointer;user-select:none}
.task-section-head h3{font-size:14px;text-transform:uppercase;letter-spacing:2px;color:var(--energy);display:flex;align-items:center;gap:9px}
.task-section-head .chevron{color:var(--faint);font-size:12px;transition:.2s}
.task-section.collapsed .chevron{transform:rotate(-90deg)}
.task-section.collapsed .task-list{display:none}
.task-reset{font-family:var(--mono);font-size:12px;color:var(--muted);margin-left:auto;text-transform:none;letter-spacing:0}
.task-reset b{color:var(--prime)}
.task-section-sub{font-size:11px;color:var(--faint);font-family:var(--mono)}

.task-list{display:flex;flex-direction:column}
.task-row{display:flex;align-items:flex-start;gap:11px;padding:11px 16px;border-bottom:1px solid var(--line-soft);transition:.12s}
.task-row:last-child{border-bottom:0}
.task-row:hover{background:rgba(200,160,64,.03)}
.task-row.checked{opacity:.55}
.task-row.checked .task-title{text-decoration:line-through;text-decoration-color:var(--energy-dim)}
.task-row.unavailable{opacity:.5}
.task-row.is-hidden{opacity:.4}
.task-row.is-custom{border-left:2px solid var(--energy-dim)}
.task-act.edit:hover{color:var(--energy)}

.task-check{position:relative;flex:none;margin-top:1px;cursor:pointer;width:20px;height:20px}
.task-check input{position:absolute;opacity:0;width:0;height:0}
.task-check span{display:block;width:20px;height:20px;border-radius:6px;border:1px solid var(--line);background:var(--surface-2);position:relative;transition:.15s}
.task-check span::after{content:"";position:absolute;top:3px;left:7px;width:4px;height:9px;border:2px solid transparent;border-top:0;border-left:0;transform:rotate(45deg);transition:.15s}
.task-check input:checked + span{background:var(--energy-dim);border-color:var(--energy)}
.task-check input:checked + span::after{border-color:var(--energy)}

.task-icon{width:30px;height:30px;flex:none;object-fit:contain;border-radius:6px;margin-top:-1px}
.task-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}
.task-line{font-size:13.5px;line-height:1.35;overflow-wrap:anywhere}
.task-title{font-weight:650;color:var(--text)}
.task-desc{color:var(--muted)}
.task-meta{display:flex;flex-wrap:wrap;gap:6px}
.tchip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-family:var(--mono);
  color:var(--muted);background:var(--surface-2);border:1px solid var(--line-soft);border-radius:999px;padding:2px 8px}
.tchip.npc{color:var(--prime);border-color:var(--prime-dim)}
.tchip.loc{color:var(--helminth)}
.tchip.prereq{color:var(--faint)}
.tchip.info{color:var(--muted);font-style:italic;font-family:var(--sans)}
.task-countdown{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:2px}
.task-countdown b{color:var(--prime)}
.task-countdown.soon b{color:var(--warn)}
.task-countdown.unavail{color:var(--faint)}

.task-actions{display:flex;align-items:center;gap:4px;flex:none}
.task-act{appearance:none;border:1px solid transparent;background:transparent;color:var(--faint);
  cursor:pointer;width:30px;height:30px;border-radius:8px;font-size:14px;display:flex;align-items:center;justify-content:center;transition:.12s}
.task-act:hover{background:var(--surface-2);color:var(--text)}
.task-act.bell.on{color:var(--helminth)}
.task-act.eye.on{color:var(--energy)}

/* Groupes (sous-tâches) */
.task-group{border-bottom:1px solid var(--line-soft)}
.task-group:last-child{border-bottom:0}
.task-group-head{display:flex;align-items:center;gap:11px;padding:11px 16px;background:rgba(28,27,20,.4)}
.task-group-title{font-weight:650;font-size:13.5px;display:flex;align-items:center;gap:9px;flex:1;min-width:0}
.task-sub-list{display:flex;flex-direction:column;padding-left:18px}
.task-sub-list .task-row{padding-left:14px}
.task-section-empty{padding:14px 16px;color:var(--faint);font-size:12px}
.task-sub-note{padding:9px 16px 9px 14px;color:var(--faint);font-size:11px;font-family:var(--mono)}
.task-act.group-toggle .chevron{display:inline-block;color:var(--faint);font-size:12px;transition:.2s}
.task-group.collapsed .task-group-toggle .chevron,
.task-group.collapsed .group-toggle .chevron{transform:rotate(-90deg)}
.task-group.collapsed .task-sub-list{display:none}

/* ===== GOALS / TO-DO ===== */
.btn.xsmall{padding:4px 9px;font-size:12px}
.task-form textarea{font-family:var(--sans);font-size:14px;text-transform:none;letter-spacing:0;color:var(--text);resize:vertical;min-height:60px}

/* --- Board Kanban : 3 colonnes (To Do / In Progress / Done) --- */
.goal-board{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:start}
.goal-col{display:flex;flex-direction:column;min-width:0;background:rgba(20,24,30,.35);border:1px solid var(--line-soft);border-radius:var(--radius)}
.goal-col-head{font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);display:flex;align-items:center;gap:9px;margin:0;padding:12px 14px 11px;border-bottom:1px solid var(--line-soft)}
.goal-col-done .goal-col-head{color:var(--faint)}
.goal-col-head .count{font-family:var(--mono);font-size:11px;color:var(--faint);margin-left:auto;background:var(--surface-2);border:1px solid var(--line-soft);border-radius:20px;padding:1px 8px}
.goal-col-body{display:flex;flex-direction:column;gap:12px;padding:12px;min-height:90px;border-radius:0 0 var(--radius) var(--radius);transition:background .15s,box-shadow .15s}
.goal-col-body.drag-over{background:rgba(200,160,64,.07);box-shadow:inset 0 0 0 1px var(--energy-dim)}
.goal-col-empty{font-size:12px;color:var(--faint);text-align:center;padding:14px 8px;border:1px dashed var(--line-soft);border-radius:9px}
.goal-col-body.drag-over .goal-col-empty{border-color:var(--energy-dim);color:var(--muted)}
@media(max-width:880px){.goal-board{grid-template-columns:1fr}}

.goal-card[draggable=true]{cursor:grab}
.goal-card.dragging{opacity:.45;cursor:grabbing}
.goal-card .drag-handle{cursor:grab;color:var(--faint);font-size:13px;line-height:1;user-select:none;padding:0 2px;align-self:flex-start}
.goal-card .drag-handle:hover{color:var(--muted)}

.goal-card{display:flex;flex-direction:column;gap:11px;background:linear-gradient(180deg,var(--surface),var(--bg-2));border:1px solid var(--line-soft);border-left:3px solid var(--line);border-radius:var(--radius);padding:14px}
.goal-card.prio-high{border-left-color:var(--danger)}
.goal-card.prio-med{border-left-color:var(--warn)}
.goal-card.prio-low{border-left-color:#5d7aa0}
.goal-card.status-done{opacity:.62}
.goal-card.status-done .goal-title{text-decoration:line-through;text-decoration-color:var(--faint)}

.goal-head{display:flex;align-items:flex-start;gap:11px}
.goal-thumb{position:relative;width:46px;height:46px;flex:none;border-radius:9px;display:flex;align-items:center;justify-content:center;background:radial-gradient(60px 40px at 50% 30%,rgba(200,160,64,.10),transparent),var(--bg-2);border:1px solid var(--line-soft);overflow:hidden}
.goal-thumb img{max-width:100%;max-height:100%;object-fit:contain}
.goal-thumb .img-fb{position:absolute;font-family:var(--mono);font-size:15px;font-weight:700;color:var(--faint)}
.goal-thumb.has-img .img-fb{display:none}
.goal-head-txt{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}
.goal-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.goal-prio{font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;border-radius:5px;padding:1px 6px;border:1px solid var(--line)}
.goal-prio.prio-high{color:var(--danger);border-color:#4a2020;background:rgba(200,72,72,.08)}
.goal-prio.prio-med{color:var(--warn);border-color:#5a4018;background:rgba(216,144,48,.08)}
.goal-prio.prio-low{color:#86a0c2;border-color:#33414f;background:rgba(93,122,160,.10)}
.goal-horizon{font-family:var(--mono);font-size:9px;letter-spacing:.5px;text-transform:uppercase;border-radius:5px;padding:1px 6px;border:1px solid var(--line)}
.goal-horizon.hz-short{color:var(--ok);border-color:var(--helminth-dim);background:rgba(120,184,88,.08)}
.goal-horizon.hz-mid{color:var(--prime);border-color:var(--prime-dim);background:rgba(232,200,112,.06)}
.goal-horizon.hz-long{color:var(--muted);border-color:var(--line);background:rgba(154,138,104,.06)}
.goal-title{margin:0;font-size:15px;font-weight:650;line-height:1.25}
.goal-item-name{font-size:11px;color:var(--muted);font-family:var(--mono)}
.goal-item-name em{font-style:normal;color:var(--energy)}
.goal-form-grid3{grid-template-columns:1fr 1fr 1fr}
.goal-notes{margin:0;font-size:12.5px;color:var(--muted);white-space:pre-wrap}

.goal-progress{display:flex;align-items:center;gap:9px}
.goal-bar{flex:1;height:8px;background:var(--surface-2);border:1px solid var(--line-soft);border-radius:5px;overflow:hidden}
.goal-bar span{display:block;height:100%;min-width:0;background:linear-gradient(90deg,var(--energy-dim),var(--energy));border-radius:5px;transition:width .25s ease}
.goal-progress.complete .goal-bar span{background:linear-gradient(90deg,var(--helminth-dim),var(--ok))}
.goal-prog-l{font-family:var(--mono);font-size:11px;color:var(--faint);flex:none}
.goal-progress.complete .goal-prog-l{color:var(--ok)}

.goal-steps{display:flex;flex-direction:column;gap:3px}
.goal-step{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);padding:3px 4px;border-radius:7px;cursor:pointer}
.goal-step:hover{background:var(--surface)}
.goal-step input{appearance:none;-webkit-appearance:none;position:relative;width:16px;height:16px;flex:none;border:1px solid var(--line);border-radius:4px;background:var(--surface-2);cursor:pointer;transition:.15s}
.goal-step input:hover{border-color:var(--energy-dim)}
.goal-step input:checked{background:var(--energy-dim);border-color:var(--energy)}
.goal-step input:checked::after{content:"";position:absolute;top:2px;left:5px;width:4px;height:8px;border:2px solid var(--energy);border-top:0;border-left:0;transform:rotate(45deg)}
.goal-step input:focus-visible{outline:none;border-color:var(--energy);box-shadow:0 0 0 3px rgba(200,160,64,.14)}
.goal-step-txt{flex:1;min-width:0}
.goal-step.done .goal-step-txt{text-decoration:line-through;color:var(--faint)}
.goal-step-x{appearance:none;border:0;background:transparent;color:var(--faint);cursor:pointer;font-size:11px;opacity:0;transition:.15s}
.goal-step:hover .goal-step-x{opacity:1}
.goal-step-x:hover{color:var(--danger)}
.goal-step-add input{width:100%;padding:6px 9px;font-size:12.5px;background:var(--bg-2)}

.goal-foot{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:2px;padding-top:9px;border-top:1px solid var(--line-soft)}
.goal-foot .spacer{flex:1}
.goal-del{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;color:var(--muted)}
.goal-del svg{display:block}
.goal-del:hover{color:var(--danger);border-color:#4a2020;background:rgba(200,72,72,.08)}

/* Sélecteur d'item lié dans la modale */
.goal-item-pick{position:relative;text-transform:none;letter-spacing:0}
.goal-item-results{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:5;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;overflow:hidden;max-height:230px;overflow-y:auto;box-shadow:0 16px 40px rgba(0,0,0,.5)}
.goal-item-results[hidden]{display:none}
.goal-item-opt{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;appearance:none;border:0;border-bottom:1px solid var(--line-soft);background:transparent;color:var(--text);cursor:pointer;padding:9px 12px;font:inherit;font-size:14px;text-align:left}
.goal-item-opt:last-child{border-bottom:0}
.goal-item-opt:hover{background:var(--surface)}
.goal-item-opt small{color:var(--faint);font-family:var(--mono);font-size:11px}
.goal-item-chosen{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface-2);border:1px solid var(--energy-dim);border-radius:10px;padding:9px 12px}
.goal-item-chosen[hidden]{display:none}
.goal-chip-name{font-size:14px}
.goal-chip-name small{color:var(--faint);font-family:var(--mono);font-size:11px;margin-left:6px}
.goal-chip-x{appearance:none;border:0;background:transparent;color:var(--faint);cursor:pointer;font-size:13px}
.goal-chip-x:hover{color:var(--danger)}

/* ===== Alerts (carte façon in-game) ===== */
/* Disposition deux colonnes : Open Worlds à gauche, Arbitration à droite, sur la même
   rangée quand l'écran est assez large ; empile en colonne sinon (flex-wrap). */
.alerts-layout{display:flex;flex-wrap:wrap;gap:28px;align-items:flex-start;max-width:1060px}
.alerts-layout .alert-group{margin-bottom:0;display:flex;flex-direction:column}
.ow-group{flex:1 1 440px;min-width:0}
.arb-group{flex:1 1 320px;min-width:0;max-width:440px}
.alert-group{margin-bottom:26px}
.alert-cat{
  font-family:var(--mono);font-size:13px;letter-spacing:2px;text-transform:uppercase;
  color:var(--energy);margin-bottom:12px;padding-left:2px;
}
/* Carte d'alerte : intégrée au thème Vitruvian (cartes dorées). Emblème arbitration à
   gauche, corps au centre, emblème de faction à droite. */
.gcard{
  display:flex;align-items:center;gap:14px;width:100%;
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line-soft);border-left:3px solid var(--energy);
  border-radius:var(--radius);padding:16px 18px;position:relative;overflow:hidden;
}
.gcard::after{ /* liseré or interne, comme les cartes possédées */
  content:"";position:absolute;inset:0;border-radius:var(--radius);
  box-shadow:inset 0 0 0 1px rgba(200,160,64,.16);pointer-events:none;
}
.gcard-emblem{
  flex:none;width:54px;height:54px;display:grid;place-items:center;
  border:1px solid var(--line);border-radius:10px;
  background:radial-gradient(circle at 50% 40%,rgba(200,160,64,.06),transparent 70%);
}
/* Silhouette PNG (alpha) tintée par CSS mask. */
.gcard-emblem i{
  display:block;width:34px;height:34px;background-color:var(--faint);
  -webkit-mask:center/contain no-repeat;mask:center/contain no-repeat;
}
/* Emblème arbitration (gauche) : sigil Arbiters of Hexis, doré (accent du thème). */
.arb-mark i{-webkit-mask-image:url(/icons/arbitration.png);mask-image:url(/icons/arbitration.png);background-color:var(--energy)}
.arb-mark{border-color:var(--energy-dim);background:radial-gradient(circle at 50% 40%,rgba(200,160,64,.14),transparent 70%)}
/* Emblème faction (droite) : tinté à la couleur de la faction. */
.fac-mark i{background-color:var(--faint)}
.gcard.fc-grineer  .fac-mark i{-webkit-mask-image:url(/icons/grineer.png);mask-image:url(/icons/grineer.png);background-color:var(--danger)}
.gcard.fc-corpus   .fac-mark i{-webkit-mask-image:url(/icons/corpus.png);mask-image:url(/icons/corpus.png);background-color:#5aa0d0}
.gcard.fc-infested .fac-mark i{-webkit-mask-image:url(/icons/infested.png);mask-image:url(/icons/infested.png);background-color:var(--helminth)}
.gcard.fc-corrupted .fac-mark i{-webkit-mask-image:url(/icons/corrupted.png);mask-image:url(/icons/corrupted.png);background-color:var(--prime)}
.gcard.fc-grineer  .fac-mark{border-color:rgba(200,72,72,.4)}
.gcard.fc-corpus   .fac-mark{border-color:rgba(90,160,208,.4)}
.gcard.fc-infested .fac-mark{border-color:var(--helminth-dim)}
.gcard.fc-corrupted .fac-mark{border-color:rgba(232,200,112,.4)}
.gcard-body{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}
.gcard-title{
  font-family:var(--mono);font-size:16px;font-weight:700;letter-spacing:.02em;
  color:var(--energy);text-transform:uppercase;
}
.gcard-lvl{color:var(--text);font-weight:600}
.gcard-faction{color:var(--muted);font-weight:600}
.gcard-loc{color:var(--muted);font-size:14px}
.gcard-reward{display:flex;align-items:center;gap:8px;margin-top:6px;color:var(--text);font-size:14px;flex-wrap:wrap}
.gcard-credits,.gcard-vitusrew{display:inline-flex;align-items:center;gap:6px}
.gcard-credits{font-family:var(--mono)}
.gcard-plus{color:var(--faint)}
.gcard-vitus{color:var(--prime)}
/* Icône de récompense (silhouette PNG tintée), alignée au texte. */
.rew-icon{display:inline-block;width:16px;height:16px;background-color:var(--prime);
  -webkit-mask:center/contain no-repeat;mask:center/contain no-repeat}
.rew-icon.credits{-webkit-mask-image:url(/icons/credits.png);mask-image:url(/icons/credits.png);background-color:var(--energy)}
.gcard-timer{
  display:flex;align-items:center;gap:7px;margin-top:8px;
  font-family:var(--mono);font-size:15px;color:var(--prime)}
.gcard-timer .clk{color:var(--energy);opacity:.9}

/* ----- Cartes cycles open world (jour/nuit, chaud/froid, Fass/Vome) ----- */
.cycle-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:14px;
}
.wcard{
  display:flex;flex-direction:column;gap:8px;
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line-soft);border-left:3px solid var(--energy);
  border-radius:var(--radius);padding:14px 16px;position:relative;overflow:hidden;
}
.wcard::after{ /* liseré or interne, comme les cartes d'alerte */
  content:"";position:absolute;inset:0;border-radius:var(--radius);
  box-shadow:inset 0 0 0 1px rgba(200,160,64,.12);pointer-events:none;
}
.wcard-head{display:flex;flex-direction:column;gap:2px}
.wcard-name{
  font-family:var(--mono);font-size:14px;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:var(--energy);
}
.wcard-sub{color:var(--faint);font-size:12px}
.wcard-state{
  display:inline-flex;align-items:center;gap:9px;
  font-size:19px;font-weight:700;color:var(--text);
}
.wcard-state .wsym{font-size:21px;line-height:1}
.wcard-next{
  display:flex;align-items:center;gap:6px;margin-top:auto;
  color:var(--muted);font-size:13px;
}
.wcard-timer{font-family:var(--mono);color:var(--prime);font-size:14px}
/* Accents d'état : liseré gauche + symbole tintés. */
.wcard.st-day   {border-left-color:var(--energy)}      .wcard.st-day   .wsym{color:var(--energy)}
.wcard.st-night {border-left-color:#5a7fb0}            .wcard.st-night .wsym{color:#8fb3e0}
.wcard.st-warm  {border-left-color:#d08a4a}            .wcard.st-warm  .wsym{color:#e6a662}
.wcard.st-cold  {border-left-color:#5aa0d0}            .wcard.st-cold  .wsym{color:#7fc4e8}
.wcard.st-fass  {border-left-color:#d07a3a}            .wcard.st-fass  .wsym{color:#ec9050}
.wcard.st-vome  {border-left-color:#5a7fb0}            .wcard.st-vome  .wsym{color:#8fb3e0}

/* ----- Le Circuit (Duviri) : récompenses hebdo, normal (Warframes) vs Steel Path (armes) ----- */
.circuit-group{max-width:1060px;margin-top:30px}
/* Titre identique aux autres sections (.alert-cat), avec le reset hebdo aligné à droite sur
   LA MÊME ligne (et non sous le titre) : on neutralise le display:flex/margin-top hérités de
   .gcard-timer pour rester cohérent avec « Open Worlds » / « Arbitration ». */
.circuit-group .alert-cat{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.circuit-reset{
  display:inline-flex;align-items:center;gap:6px;margin:0 0 0 auto;
  font-family:var(--mono);font-size:12px;font-weight:400;letter-spacing:0;text-transform:none;
  color:var(--prime);
}
.circuit-reset .clk{color:var(--energy)}
.circuit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
/* Chaque chemin : panneau doré, accent gauche. Steel Path en acier froid (mode « difficile »). */
.circuit-path{
  --cp:var(--energy); --cp-dim:var(--energy-dim);
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line-soft);border-left:3px solid var(--cp);
  border-radius:var(--radius);padding:15px 17px;position:relative;overflow:hidden;
}
.circuit-path::after{
  content:"";position:absolute;inset:0;border-radius:var(--radius);
  box-shadow:inset 0 0 0 1px rgba(200,160,64,.12);pointer-events:none;
}
.cp-steel{--cp:#9fb2c4; --cp-dim:#4a5a6a}
.cp-steel::after{box-shadow:inset 0 0 0 1px rgba(159,178,196,.12)}
.circuit-path-head{display:flex;align-items:baseline;gap:9px;margin-bottom:13px}
.circuit-path-name{
  font-family:var(--mono);font-size:14px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--cp);
}
.circuit-path-sub{color:var(--faint);font-size:12px}
.circuit-rewards{display:flex;flex-wrap:wrap;gap:12px}
.circuit-reward{display:flex;flex-direction:column;align-items:center;gap:6px;width:74px}
.circuit-reward-art{
  width:74px;height:74px;border-radius:10px;display:grid;place-items:center;overflow:hidden;
  background:radial-gradient(circle at 50% 35%,rgba(200,160,64,.07),transparent 70%),var(--bg);
  border:1px solid var(--line-soft);box-shadow:inset 0 0 0 1px rgba(0,0,0,.4);
}
.cp-steel .circuit-reward-art{background:radial-gradient(circle at 50% 35%,rgba(159,178,196,.08),transparent 70%),var(--bg)}
.circuit-reward-art img{width:100%;height:100%;object-fit:contain}
.circuit-noimg{color:var(--cp-dim);font-size:26px}
.circuit-reward-name{
  font-size:11px;color:var(--muted);text-align:center;line-height:1.25;
  width:100%;word-break:break-word;
}

@media(max-width:520px){
  .gcard{flex-direction:column;align-items:flex-start;gap:12px}
  .gcard-emblem{align-self:flex-start}
  .cycle-grid{grid-template-columns:1fr}
  .circuit-grid{grid-template-columns:1fr}
}

/* ===== RAILJACK — console tactique (accent cyan « hologramme », propre à cette page) ===== */
#view-railjack{
  --rj:#5fd0e0; --rj-dim:#2a6b78; --rj-deep:#0c1518; --rj-grid:rgba(95,208,224,.09); --rj-glow:rgba(95,208,224,.5);
}
#view-railjack .section-intro{max-width:none}

.rj-head{display:flex;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:16px}
.rj-export{border-color:var(--rj-dim);color:var(--rj)}
.rj-export:hover{border-color:var(--rj);box-shadow:0 0 12px rgba(95,208,224,.2)}
.rj-export:disabled{opacity:.5}
.rj-eyebrow{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--rj)}
.rj-eyebrow::after{content:"";height:1px;width:46px;background:linear-gradient(90deg,var(--rj-dim),transparent)}
.rj-status{margin-left:auto;font-family:var(--mono);font-size:11px;letter-spacing:1.5px;color:var(--muted);transition:color .2s}
.rj-status.saving{color:var(--rj)} .rj-status.saved{color:var(--ok)} .rj-status.error{color:var(--danger)}

.rj-console{display:grid;grid-template-columns:minmax(0,1.04fr) minmax(300px,.96fr);gap:22px;align-items:start}
/* Colonne de contrôle (éditeur + systèmes) épinglée : reste en vue pendant qu'on parcourt
   le long schéma, et les systèmes sont accessibles tout en haut (plus besoin de scroller). */
.rj-side{display:flex;flex-direction:column;gap:18px;min-width:0;position:sticky;top:14px;align-self:start}

/* ---- Scène : schéma top-down du vaisseau ---- */
.rj-stage{
  position:relative;width:100%;max-width:460px;margin-inline:auto;aspect-ratio:300/460;
  border:1px solid var(--line-soft);border-radius:18px;overflow:hidden;
  background:
    radial-gradient(120% 75% at 50% 16%, rgba(95,208,224,.10), transparent 60%),
    linear-gradient(var(--rj-grid) 1px, transparent 1px) 0 0/100% 30px,
    linear-gradient(90deg, var(--rj-grid) 1px, transparent 1px) 0 0/30px 100%,
    radial-gradient(150% 120% at 50% 45%, #0e1a1f, #06090b);
}
.rj-stage::after{ /* fines scanlines ambiantes */
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:repeating-linear-gradient(rgba(95,208,224,.05) 0 1px, transparent 1px 4px);
}
.rj-ship{position:absolute;inset:0;width:100%;height:100%;filter:drop-shadow(0 0 12px rgba(95,208,224,.22))}
.rj-thruster{filter:drop-shadow(0 0 6px var(--rj))}

.rj-nodes{position:absolute;inset:0}
.rj-node{
  position:absolute;transform:translate(-50%,-50%);
  display:inline-flex;align-items:center;gap:6px;max-width:152px;padding:5px 10px 5px 6px;
  background:rgba(8,15,18,.84);color:var(--text);border:1px solid var(--rj-dim);border-radius:9px;
  font-family:var(--mono);font-size:11px;letter-spacing:.4px;line-height:1;cursor:pointer;white-space:nowrap;
  transition:border-color .16s, box-shadow .16s, color .16s;backdrop-filter:blur(2px);
}
.rj-crew{border-radius:22px;max-width:128px}
.rj-node-ic{flex:none;display:inline-grid;place-items:center;min-width:19px;height:19px;border-radius:50%;font-size:10px;color:var(--rj);border:1px solid var(--rj-dim);background:rgba(95,208,224,.06)}
.rj-node-tx{overflow:hidden;text-overflow:ellipsis;max-width:108px}
.rj-crew .rj-node-tx{max-width:80px}              /* nom (saisie libre) borné + ellipse ; nom complet dans le panneau + l'infobulle */
.rj-node:not(.filled){border-style:dashed;color:var(--muted)}
.rj-node:not(.filled) .rj-node-ic{color:var(--muted);border-color:var(--faint)}
.rj-node.filled{border-color:var(--rj);color:var(--prime);box-shadow:0 0 13px rgba(95,208,224,.26)}
.rj-node.filled .rj-node-ic{color:#06090b;background:var(--rj);border-color:var(--rj)}
.rj-node:hover{border-color:var(--rj);box-shadow:0 0 17px rgba(95,208,224,.42);z-index:5}
.rj-node.active{border-color:var(--prime);color:var(--prime);box-shadow:0 0 0 2px rgba(95,208,224,.32),0 0 22px rgba(95,208,224,.5);z-index:6}

/* Power-on : sweep + allumage séquentiel des stations (désactivés si reduced-motion) */
@keyframes rj-sweep{0%{transform:translateY(-120%);opacity:0}12%{opacity:1}100%{transform:translateY(620%);opacity:0}}
@keyframes rj-ignite{from{opacity:0}to{opacity:1}}
.rj-stage::before{content:"";position:absolute;left:0;right:0;height:16%;pointer-events:none;z-index:7;opacity:0;
  background:linear-gradient(rgba(95,208,224,0),rgba(95,208,224,.14),rgba(95,208,224,0))}
@media (prefers-reduced-motion: no-preference){
  .rj-stage.rj-on::before{animation:rj-sweep 1.15s ease-out .1s 1}
  .rj-stage .rj-node{opacity:0}
  .rj-stage.rj-on .rj-node{animation:rj-ignite .5s ease-out forwards;animation-delay:calc(var(--i) * 95ms + .22s)}
}

/* ---- Systèmes de coque (dans la colonne de droite, sous l'éditeur) ---- */
.rj-systems{min-width:0}
.rj-systems-head{font-family:var(--mono);font-size:10.5px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.rj-systems-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.rj-sys{text-align:left;background:var(--bg-2);border:1px solid var(--line-soft);border-radius:12px;padding:11px 12px;cursor:pointer;transition:.15s;display:flex;flex-direction:column;gap:4px}
.rj-sys:hover{border-color:var(--rj-dim)}
.rj-sys.filled{border-color:var(--rj-dim)}
.rj-sys.active{border-color:var(--rj);box-shadow:0 0 0 1px var(--rj-dim) inset,0 0 16px rgba(95,208,224,.16)}
.rj-sys-name{font-size:13px;color:var(--text)}
.rj-sys.filled .rj-sys-name{color:var(--prime)}
.rj-sys-val{font-family:var(--mono);font-size:11px;color:var(--rj)}
.rj-sys-val.off{color:var(--faint)}

/* ---- Panneau éditeur ---- */
.rj-panel{position:relative;background:linear-gradient(180deg,var(--surface),var(--bg-2));border:1px solid var(--line-soft);border-radius:16px;padding:20px 20px 22px;min-height:320px;overflow:hidden}
.rj-panel::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(var(--rj),transparent 70%);opacity:.7}
.rj-panel-h{font-size:16px;color:var(--prime);letter-spacing:.3px}

.rj-readout{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:14px 0 16px}
.rj-readout-cell{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:12px;padding:13px 8px;text-align:center}
.rj-readout-n{display:block;font-family:var(--mono);font-size:23px;color:var(--rj);line-height:1.1}
.rj-readout-n small{font-size:13px;color:var(--muted)}
.rj-readout-l{font-family:var(--mono);font-size:9.5px;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted)}
.rj-roster{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}
.rj-roster-row{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--bg-2);border:1px solid var(--line-soft);border-radius:10px;font-size:13px}
.rj-roster-row.off{color:var(--faint)}
.rj-roster-slot{font-family:var(--mono);color:var(--rj);min-width:22px}
.rj-roster-row.off .rj-roster-slot{color:var(--faint)}
.rj-roster-name{flex:1;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rj-roster-role{font-family:var(--mono);font-size:11px;color:var(--muted)}
/* Carte d'équipage du résumé : détail des compétences (pips lus seuls), pas la somme */
.rj-roster-card{display:flex;flex-direction:column;gap:9px;padding:11px 12px;background:var(--bg-2);border:1px solid var(--line-soft);border-radius:10px}
.rj-roster-top{display:flex;align-items:center;gap:10px;font-size:13px}
.rj-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px 10px}
.rj-mini-comp{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;color:var(--muted)}
.rj-mini-comp b{color:var(--rj);font-weight:600;min-width:26px}
.rj-mini-pips{display:flex;gap:2px}
.rj-mini-pip{width:9px;height:8px;border:1px solid var(--rj-dim);border-radius:2px;background:var(--bg);transform:skewX(-12deg)}
.rj-mini-pip.on{background:var(--rj);border-color:var(--rj)}
.rj-hint{color:var(--muted);font-size:12.5px;margin:14px 0 0;line-height:1.45}

.rj-edit-head{margin-bottom:16px}
.rj-edit-kicker{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--rj)}
.rj-edit-head .rj-panel-h{margin-top:3px}
.rj-edit-sub{color:var(--muted);font-size:12.5px;margin:3px 0 0}
.rj-field{display:block;margin-bottom:14px}
.rj-field-lab{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.rj-model-desc,.rj-role-desc{color:var(--muted);font-size:12.5px;margin:-4px 0 14px;min-height:1.1em;line-height:1.4}
.rj-role-desc{margin:0 0 14px}

.rj-chips{margin-bottom:14px}
.rj-chips-lab{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.rj-chips-box{display:flex;flex-wrap:wrap;gap:7px}
.rj-chip{appearance:none;background:var(--bg-2);border:1px solid var(--line);color:var(--text);border-radius:9px;padding:7px 12px;font-family:var(--mono);font-size:12px;letter-spacing:.5px;cursor:pointer;transition:.14s}
.rj-chip:hover{border-color:var(--rj-dim)}
.rj-chip.on{background:rgba(95,208,224,.13);border-color:var(--rj);color:var(--rj);box-shadow:0 0 12px rgba(95,208,224,.16)}

.rj-comp-head{display:flex;align-items:baseline;justify-content:space-between;margin:6px 0 9px}
.rj-comp-total{font-family:var(--mono);font-size:12px;color:var(--energy)}
.rj-comp-total.over{color:var(--warn)}
.rj-comp-list{display:flex;flex-direction:column;gap:9px}
.rj-comp-row{display:flex;align-items:center;gap:10px}
.rj-comp-lab{flex:1;font-size:12.5px;color:var(--text)}
.rj-comp-lab b{font-family:var(--mono);color:var(--rj);font-weight:600;margin-right:7px;font-size:11px;letter-spacing:.5px}
.rj-pips{display:flex;gap:5px}
.rj-pip{width:22px;height:15px;padding:0;border:1px solid var(--line);border-radius:3px;background:var(--bg-2);cursor:pointer;transition:.12s;transform:skewX(-12deg)}
.rj-pip:hover{border-color:var(--rj-dim)}
.rj-pip.on{background:var(--rj);border-color:var(--rj);box-shadow:0 0 8px rgba(95,208,224,.4)}

.rj-edit-foot{margin-top:16px;padding-top:14px;border-top:1px solid var(--line-soft)}
.rj-edit-foot .rj-hint{margin:0}

@media(max-width:880px){
  .rj-console{grid-template-columns:1fr}
  .rj-side{position:static}
  .rj-panel{min-height:0}
}
@media(max-width:560px){ .rj-systems-row{grid-template-columns:repeat(2,1fr)} }
