/* Styled after the CpEMK Cyberpunk RED sheet: black paper, red frames,
   white category bars. */
:root {
  --red: #c4202e;
  --bright-red: #e62937;
  --dark-red: #6e0e16;
  --bg: #0c0c0c;
  --panel: #151515;
  --line: #3a3a3e;
  --text: #e8e6e3;
  --dim: #9a948c;
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--text);
  font-family: "Segoe UI", system-ui, sans-serif; font-size: 14px;
}
.hidden { display: none !important; }

/* ------------------------------------------------ top bars (unchanged) */
#topbar {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding: 8px 14px; background: var(--red);
  position: sticky; top: 0; z-index: 5;
}
.logo { font-weight: 900; letter-spacing: 2px; font-size: 18px; color: #000; }
.logo span { color: #fff; }
#auth-area { display: flex; align-items: center; gap: 8px; }
#user-chip { display: inline-flex; align-items: center; gap: 6px; }
#user-avatar { width: 24px; height: 24px; border-radius: 50%; }
#quickroll-area { display: flex; gap: 6px; flex: 1; min-width: 260px; }
#roll-input { flex: 1; }

.btn {
  background: #000; color: #fff; border: 1px solid #000; cursor: pointer;
  padding: 5px 12px; font-weight: 700; text-decoration: none;
  font-size: 13px; display: inline-block;
}
.btn:hover { background: #fff; color: #000; }
.btn.small { padding: 2px 8px; font-size: 12px; }
select.btn { appearance: none; -webkit-appearance: none; }

input, select, textarea {
  background: #000; color: var(--text);
  border: 1px solid var(--line); padding: 4px 6px; font: inherit;
}
input:focus, select:focus, textarea:focus { outline: 1px solid var(--red); }
input[type=number] { width: 58px; }
textarea { width: 100%; resize: vertical; }

#char-bar {
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
  padding: 8px 14px; background: var(--panel);
  border-bottom: 2px solid var(--red);
}
#char-bar .spacer { flex: 1; }
#save-state { color: var(--dim); font-size: 12px; }

#toast {
  position: fixed; bottom: 18px; right: 18px; z-index: 10;
  background: #000; border: 1px solid var(--red); padding: 10px 16px;
  max-width: 380px; white-space: pre-wrap;
}
#toast.error { border-color: #ffce00; color: #ffce00; }

/* ------------------------------------------------------------- sheet */
#sheet { max-width: 1280px; margin: 0 auto; padding: 10px 14px 30px;
         position: relative; }

/* number inputs: no spinner buttons, they clutter the dense sheet */
input[type=number] { appearance: textfield; -moz-appearance: textfield; }
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

#sheet-frame {
  display: grid;
  grid-template-columns: 250px 92px 1fr;
  gap: 10px;
  border: 2px solid var(--red);
  border-top-width: 6px;
  padding: 10px;
  background:
    linear-gradient(to right, var(--red) 0 90px, transparent 90px) top left /
    100% 2px no-repeat;
}
#left-col { grid-column: 1; }
#stat-rail { grid-column: 2; }
#skills-grid { grid-column: 3; }
#bottom-section { grid-column: 1 / -1; }

/* --------------------------------------------------------- left column */
#left-col { display: flex; flex-direction: column; gap: 8px; }
/* notes absorbs whatever height the skills columns dictate */
.lfield.notes { flex: 1; }
.lfield.notes textarea { height: 100%; min-height: 56px; }

/* condition block: 2x2 squares like the original */
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.lbox { display: flex; flex-direction: column; overflow: hidden; }
.lbox h3 { flex: none; }
.lbox textarea { border: 0; background: transparent; font-size: 12px;
                 flex: 1; height: auto; min-height: 56px;
                 resize: none; overflow-y: auto; }

.portrait-box {
  border: 2px solid var(--red); min-height: 110px; background: #000;
  display: flex; flex-direction: column; justify-content: flex-end;
}
.portrait-box img { width: 100%; object-fit: cover; max-height: 170px; }
.portrait-box input {
  border: 0; border-top: 1px solid var(--line); font-size: 11px;
  color: var(--dim);
}

.lfield {
  display: flex; flex-direction: column; gap: 2px;
  font-size: 11px; font-weight: 700; letter-spacing: 1px; color: #fff;
  border: 2px solid var(--red); padding: 4px 6px 6px; background: #000;
}
.lfield input, .lfield textarea { border: 0; padding: 2px 0; background: transparent; }
.lfield input.big { font-size: 20px; font-weight: 800; color: #fff; }
.pair-row { display: flex; gap: 8px; }
.pair-row .grow { flex: 1; }
.lfield.rank { width: 64px; }
.lfield.rank input { text-align: center; }

.lbox { border: 2px solid var(--red); background: #000; }
.lbox h3 {
  margin: 0; background: var(--red); color: #000; font-size: 12px;
  letter-spacing: 2px; padding: 2px 6px;
}
.lbox .pair-row { padding: 6px; }
.lbox .mini {
  flex: 1; display: flex; flex-direction: column; font-size: 9px;
  color: var(--dim); letter-spacing: 1px; font-weight: 700;
}
.lbox .mini input { width: 100%; text-align: center; font-size: 16px;
                    font-weight: 800; }
.lbox .subnote {
  font-size: 10px; color: var(--dim); padding: 0 6px 4px;
  border-bottom: 1px solid var(--line); margin-bottom: 2px;
}
.lbox .subnote b { color: var(--bright-red); }
.lbox .subnote.wounded {
  color: #fff; background: var(--dark-red); font-weight: 700;
  padding-top: 2px;
}

/* ----------------------------------------------------------- stat rail */
#stat-rail { display: flex; flex-direction: column; gap: 6px;
             justify-content: space-between; }
.stat input[readonly] { color: var(--dim); cursor: default; }
.stat { border: 2px solid var(--red); background: #000; }
.stat h4 {
  margin: 0; background: var(--red); color: #000; font-size: 12px;
  letter-spacing: 2px; padding: 2px 4px; text-align: center;
  cursor: pointer; user-select: none;
}
.stat h4:hover { background: #fff; }
.stat > input {
  width: 100%; border: 0; text-align: center; background: transparent;
  font-size: 22px; font-weight: 800; color: #fff; padding: 2px 0;
}
.stat .sub { display: flex; border-top: 1px solid var(--line); }
.stat .sub label { flex: 1; font-size: 8px; color: var(--dim);
                   text-align: center; letter-spacing: 1px; }
.stat .sub input { width: 100%; border: 0; text-align: center;
                   background: transparent; font-size: 12px; }

/* -------------------------------------------------------------- skills */
#skills-grid { display: grid; grid-template-columns: repeat(3, 1fr);
               gap: 12px; align-items: start; }
.skill-col { display: flex; flex-direction: column; gap: 10px; min-width: 0; }
.skill-cat table { width: 100%; border-collapse: collapse; font-size: 11px;
                   background: #000; table-layout: fixed; }
.skill-cat tr.cat-head th {
  background: #fff; color: #000; font-size: 10px; font-weight: 800;
  letter-spacing: 1px; padding: 2px 3px; text-align: center;
  border: 1px solid #fff; width: 34px;
}
.skill-cat tr.cat-head th.title { text-align: left; font-size: 12px;
                                  width: auto; }
.skill-cat td { padding: 1px 3px; border-bottom: 1px solid var(--dark-red); }
.skill-cat td.name { white-space: nowrap; overflow: hidden;
                     text-overflow: ellipsis; }
.skill-cat td.name .stat-tag { color: var(--bright-red); font-weight: 700;
                               font-size: 10px; }
.skill-cat td.num { text-align: center; width: 34px; }
.skill-cat input.lvl, .skill-cat input.mod {
  width: 100%; text-align: center; padding: 1px 2px; font-size: 12px;
  border: 0; background: transparent;
}
.skill-cat input.mod { color: var(--dim); }
.skill-cat .stat-val { color: var(--dim); font-weight: 700; }
.skill-cat input.label-input {
  width: 76px; font-size: 11px; padding: 0 3px;
  border: 1px solid var(--dark-red); background: #000;
}
.skill-cat .base {
  display: inline-block; min-width: 30px; text-align: center;
  background: var(--red); color: #000; font-weight: 800; cursor: pointer;
  padding: 0 4px; user-select: none;
}
.skill-cat .base:hover { background: #fff; }

/* --------------------------------------------------- weapons and armor */
#bottom-section { margin-top: 6px; }
.banner {
  background: var(--red); color: #000; font-size: 16px;
  letter-spacing: 3px; padding: 4px 10px; margin: 0 0 8px;
  font-weight: 900;
}
.banner span { text-transform: lowercase; font-weight: 400; color: #fff; }
#wa-grid { display: grid; grid-template-columns: 300px 1fr; gap: 12px; }

#armor-table, #weapons-table {
  width: 100%; border-collapse: collapse; background: #000;
  align-self: start;
}
#armor-table th, #weapons-table th {
  background: #fff; color: #000; font-size: 10px; letter-spacing: 1px;
  text-align: left; padding: 3px 6px; border: 1px solid #fff;
}
#armor-table td, #weapons-table td {
  padding: 2px 4px; border-bottom: 1px solid var(--dark-red);
}
#armor-table td:first-child { font-weight: 700; width: 90px; }
#armor-table input { width: 100%; border: 0; background: transparent; }
#armor-table input[type=number] { width: 56px; }
#weapons-table input { width: 100%; border: 0; background: transparent; }
#weapons-table td.w-dmg { width: 80px; }
#weapons-table td.w-ammo, #weapons-table td.w-rof { width: 60px; }
#weapons-table .roll-dmg { cursor: pointer; color: var(--bright-red);
                           font-weight: 800; }
#weapons-table .roll-dmg:hover { color: #fff; }

/* ------------------------------------------- page tabs (in the char bar) */
#page-tabs { display: flex; gap: 4px; flex-wrap: wrap; margin-left: 10px; }
#page-tabs button {
  background: #000; color: var(--dim); border: 1px solid var(--line);
  padding: 2px 10px; font: inherit; font-weight: 700; font-size: 12px;
  letter-spacing: 1px; cursor: pointer;
}
#page-tabs button:hover { background: var(--dark-red); color: #fff; }
#page-tabs button.active { background: var(--red); color: #000;
                           border-color: var(--red); }

#page-2, #page-3, #page-4 {
  border: 2px solid var(--red); border-top-width: 6px; padding: 10px;
}

/* page 2: lifepath & gear */
.p2-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
           margin-top: 10px; }
.pcol { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.lp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }

.rtable { width: 100%; border-collapse: collapse; background: #000; }
.rtable th {
  background: #fff; color: #000; font-size: 10px; letter-spacing: 1px;
  text-align: left; padding: 3px 6px; border: 1px solid #fff;
}
.rtable td { padding: 2px 4px; border-bottom: 1px solid var(--dark-red); }
.rtable input { width: 100%; border: 0; background: transparent; }
#gear-table td.g-cost { width: 76px; }

/* page 3: cyberware boxes */
#cyber-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 10px; margin-top: 8px;
}
.cyber-box { border: 2px solid var(--dark-red); background: #000;
             display: flex; flex-direction: column; }
.cyber-box h3 { margin: 0; background: var(--dark-red); color: #fff;
                font-size: 11px; letter-spacing: 1px; padding: 2px 6px;
                display: flex; justify-content: space-between;
                align-items: center; gap: 6px; }
.cyber-box h3 .inst { display: flex; align-items: center; gap: 3px;
                      font-size: 8px; cursor: pointer; user-select: none; }
.cyber-box h3 .inst input { accent-color: #000; margin: 0;
                            width: 12px; height: 12px; }
.cyber-box.installed { border-color: var(--bright-red); }
.cyber-box.installed h3 { background: var(--red); color: #000; }
.cyber-box textarea { flex: 1; border: 0; background: transparent;
                      min-height: 96px; font-size: 12px; resize: vertical; }
.hint { color: var(--dim); font-size: 11px; margin: 4px 0; }
.hint code { color: var(--bright-red); }

/* page 4: big auto-growing note areas */
.p4-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.bigtext { width: 100%; min-height: 60vh; resize: vertical;
           background: #000; border: 1px solid var(--line);
           padding: 8px; font-size: 13px; line-height: 1.5; }

/* custom rolls (saved macros) */
#custom-rolls td.c-name { width: 24%; }
#custom-rolls td.c-act { width: 34px; text-align: center; }
#custom-rolls .c-del { cursor: pointer; color: var(--dim); font-weight: 700;
                       padding: 0 6px; }
#custom-rolls .c-del:hover { color: #fff; }
#custom-rolls .c-del.armed { color: #000; background: var(--bright-red); }
/* roll button stays quiet until you point at it */
#custom-rolls .roll-dmg.quiet { color: var(--dim); }
#custom-rolls .roll-dmg.quiet:hover { color: var(--bright-red); }

/* progress / money / totals strip (page 2 top) */
#misc-bar {
  border: 2px solid var(--red); background: #000;
  display: flex; gap: 18px; padding: 6px 10px; flex-wrap: wrap;
  align-items: center;
}
#misc-bar .grow { flex: 1; min-width: 160px; }
#misc-bar input.wide { width: 100%; }
#misc-bar label {
  display: flex; align-items: center; gap: 8px;
  font-size: 11px; font-weight: 700; letter-spacing: 1px; color: var(--dim);
}
#misc-bar input { width: 90px; font-size: 14px; font-weight: 700; }
#misc-bar .spacer { flex: 1; }
#misc-bar .total {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; letter-spacing: 1px; color: var(--dim);
}
#misc-bar .total b { color: var(--bright-red); font-size: 15px; }

#intro { max-width: 640px; margin: 60px auto; color: var(--dim);
         text-align: center; line-height: 1.6; }
#intro code { color: var(--bright-red); }

/* ----------------------------------------------------------- responsive */
@media (max-width: 980px) {
  #sheet-frame { grid-template-columns: 1fr; }
  #left-col, #stat-rail, #skills-grid, #bottom-section { grid-column: 1; }
  #stat-rail { flex-direction: row; flex-wrap: wrap; }
  #stat-rail .stat { flex: 1; min-width: 72px; }
  #skills-grid { grid-template-columns: 1fr; }
  #wa-grid { grid-template-columns: 1fr; }
  .p2-grid, .p4-grid, .lp-grid { grid-template-columns: 1fr; }
}

/* print: black on white, hide chrome — browser print = PDF-ish export */
@media print {
  #topbar, #char-bar, #toast { display: none !important; }
  body { background: #fff; color: #000; }
  .stat, .lbox, .lfield, .portrait-box, .skill-cat table,
  #armor-table, #weapons-table { background: #fff; }
  input, select, textarea { background: #fff; color: #000; }
}
