/* ReactionChain — dark EVE-style theme */
:root{
  --bg:#06090f;
  --bg2:#0b111c;
  --panel:#0e1623;
  --panel2:#121d2e;
  --line:#1d2c42;
  --line2:#26405f;
  --text:#c8d6e5;
  --muted:#6e8199;
  --cyan:#39bdf2;
  --cyan-dim:#1c6f93;
  --amber:#e8b14a;
  --green:#39d98a;
  --red:#ef5d6c;
  --shadow:0 2px 18px rgba(0,0,0,.5);
  --mono:"SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(57,189,242,.07), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(232,177,74,.05), transparent 55%),
    var(--bg);
  color:var(--text);
  font-family:"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:14px;line-height:1.45;
}
h1,h2{margin:0;font-weight:600;letter-spacing:.3px}
.muted{color:var(--muted)}
.small{font-size:12px}
.hidden{display:none !important}
.pos{color:var(--green)}
.neg{color:var(--red)}
.error{color:var(--red);min-height:18px;font-size:12px}

/* top bar */
.topbar{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 22px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,var(--bg2),rgba(11,17,28,.4));
  position:sticky;top:0;z-index:20;backdrop-filter:blur(4px);
}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{font-size:30px;color:var(--cyan);text-shadow:0 0 12px rgba(57,189,242,.6)}
.brand h1{font-size:19px;color:#eaf3fb}
.brand .sub{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}
.account{display:flex;align-items:center;gap:10px}

/* tabs */
.tabs{display:flex;gap:2px;padding:0 16px;border-bottom:1px solid var(--line);
  background:var(--bg2);overflow-x:auto}
.tab{
  background:none;border:none;color:var(--muted);
  padding:13px 18px;font-size:13px;cursor:pointer;
  border-bottom:2px solid transparent;white-space:nowrap;
}
.tab:hover{color:var(--text)}
.tab.active{color:var(--cyan);border-bottom-color:var(--cyan)}

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

/* cards & layout */
.card{
  background:linear-gradient(180deg,var(--panel),var(--bg2));
  border:1px solid var(--line);border-radius:10px;padding:18px 20px;
  box-shadow:var(--shadow);margin-bottom:18px;
}
.card h2{font-size:14px;color:var(--cyan);text-transform:uppercase;
  letter-spacing:1px;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.card.note{border-color:var(--line2)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.grid2,.grid3{grid-template-columns:1fr}}

label{display:block;margin:10px 0;color:var(--muted);font-size:12px}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row > label{flex:1;min-width:120px}
label.check{display:flex;align-items:center;gap:8px;color:var(--text)}
label.inline{display:flex;align-items:center;gap:8px;color:var(--muted)}
input,select{
  width:100%;margin-top:5px;background:var(--bg);color:var(--text);
  border:1px solid var(--line2);border-radius:6px;padding:8px 10px;font-size:13px;
}
label.check input,label.inline input{width:auto;margin-top:0}
input:focus,select:focus{outline:none;border-color:var(--cyan);
  box-shadow:0 0 0 2px rgba(57,189,242,.15)}
input[type=number]{font-family:var(--mono)}

.derived{margin-top:14px;padding-top:12px;border-top:1px dashed var(--line2);
  font-family:var(--mono);font-size:12px;color:var(--muted);display:grid;gap:4px}
.derived b{color:var(--amber);font-weight:600}

/* buttons */
.btn{
  background:linear-gradient(180deg,var(--cyan-dim),#134b63);
  color:#eaf6fd;border:1px solid var(--cyan-dim);border-radius:6px;
  padding:9px 16px;font-size:13px;cursor:pointer;transition:.15s;
}
.btn:hover{filter:brightness(1.18)}
.btn.small{padding:6px 12px;font-size:12px}
.btn.ghost{background:transparent;border-color:var(--line2);color:var(--muted)}
.btn.ghost:hover{color:var(--text);border-color:var(--cyan)}
.btn.danger{background:transparent;border-color:#5a2530;color:var(--red)}

/* stat bar */
.bar{display:flex;gap:26px;align-items:center;flex-wrap:wrap;
  background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:14px 20px;margin-bottom:18px;box-shadow:var(--shadow)}
.bar.wrap{gap:16px}
.stat{display:flex;flex-direction:column}
.stat span{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}
.stat b{font-size:18px;font-family:var(--mono);color:#eaf3fb}

/* tables */
table.data{width:100%;border-collapse:collapse;font-size:13px;
  background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}
table.data th{
  text-align:right;padding:11px 12px;background:var(--panel2);color:var(--muted);
  font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--line2)}
table.data th:first-child{text-align:left}
table.data td{padding:9px 12px;text-align:right;border-bottom:1px solid var(--line);
  font-family:var(--mono)}
table.data td:first-child{text-align:left;font-family:inherit;color:#dce8f5}
table.data tbody tr:hover{background:rgba(57,189,242,.05)}
table.data.compact td,table.data.compact th{padding:6px 10px;font-size:12px}
table.data tr.total td{border-top:2px solid var(--line2);font-weight:700;color:#fff;background:var(--panel2)}
td input{width:90px;text-align:right;padding:5px 7px;font-family:var(--mono)}
td.edit input{width:100px}

.heat-good{color:var(--green)}
.heat-mid{color:var(--amber)}
.heat-bad{color:var(--red)}
.tag{font-size:10px;padding:1px 6px;border-radius:4px;border:1px solid var(--line2);
  color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.tag.build{color:var(--cyan);border-color:var(--cyan-dim)}
.tag.buy{color:var(--amber);border-color:#5c4a20}

/* modal */
.modal{position:fixed;inset:0;background:rgba(3,6,11,.7);display:flex;
  align-items:center;justify-content:center;z-index:50;backdrop-filter:blur(3px)}
.modal-box{width:340px;margin:0}
.modal-box h2{color:var(--cyan)}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:var(--panel2);border:1px solid var(--cyan-dim);color:#eaf3fb;
  padding:11px 20px;border-radius:8px;box-shadow:var(--shadow);z-index:60;font-size:13px}
.toast.err{border-color:#5a2530;color:#ffd9de}

ol{padding-left:18px;margin:6px 0}
ol li{margin:4px 0}
