:root{
  --bg:#1b1612; --panel:#251e18; --panel-2:#2c241c;
  --line:#3a3026; --line-soft:#332a21;
  --ink:#f1e8d8; --ink-soft:#b6a890; --ink-faint:#8a7c67;
  --brass:#d2a24c; --brass-bright:#e8bf6a; --danger:#c2654a; --ok:#7fc08a;
  --radius:10px;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.5;
  -webkit-font-smoothing:antialiased;padding:28px 20px 80px;
  -webkit-print-color-adjust:exact;print-color-adjust:exact;
}
.wrap{max-width:1180px;margin:0 auto}

header.top{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;
  border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:26px}
header.top h1{margin:0;font-size:26px;letter-spacing:.5px;font-weight:700}
header.top h1 .accent{color:var(--brass)}
header.top p{margin:0;color:var(--ink-faint);font-size:13px}

.layout{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
@media (max-width:880px){.layout{grid-template-columns:1fr}}

.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 18px 20px;margin-bottom:22px}
.panel h2{margin:0 0 14px;font-size:12px;text-transform:uppercase;letter-spacing:2px;
  color:var(--brass);font-weight:700}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field label{display:block;font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--ink-faint);margin-bottom:5px}
.field .inwrap{position:relative}
.field input[type=number]{width:100%;background:var(--panel-2);border:1px solid var(--line);
  color:var(--ink);border-radius:8px;padding:9px 38px 9px 11px;font-family:var(--mono);font-size:15px}
.field .unit{position:absolute;right:10px;top:50%;transform:translateY(-50%);
  font-family:var(--mono);font-size:12px;color:var(--ink-faint);pointer-events:none}
input:focus,select:focus{outline:2px solid var(--brass);outline-offset:1px}
input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield}

/* strips */
.strip{display:grid;grid-template-columns:18px 1fr 92px auto;gap:8px;align-items:center;
  background:var(--panel-2);border:1px solid var(--line-soft);border-radius:8px;padding:8px;margin-bottom:8px}
.swatch{width:18px;height:30px;border-radius:4px;border:1px solid rgba(0,0,0,.4)}
.strip select{width:100%;background:var(--panel);border:1px solid var(--line);color:var(--ink);
  border-radius:7px;padding:8px 9px;font-size:14px;font-family:var(--sans)}
.strip .winput{position:relative}
.strip .winput input{width:100%;background:var(--panel);border:1px solid var(--line);color:var(--ink);
  border-radius:7px;padding:8px 26px 8px 9px;font-family:var(--mono);font-size:14px}
.strip .winput .u{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--ink-faint);font-family:var(--mono)}
.ctrls{display:flex;gap:4px}
.iconbtn{width:30px;height:30px;border:1px solid var(--line);background:var(--panel);color:var(--ink-soft);
  border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;line-height:1}
.iconbtn:hover{border-color:var(--brass);color:var(--brass-bright)}
.iconbtn.del:hover{border-color:var(--danger);color:var(--danger)}
.iconbtn:disabled{opacity:.3;cursor:default}
.iconbtn:disabled:hover{border-color:var(--line);color:var(--ink-soft)}

.row-actions{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap}
.btn{border:1px solid var(--brass);background:transparent;color:var(--brass-bright);
  padding:9px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.3px}
.btn:hover{background:var(--brass);color:#241b10}
.btn:disabled{opacity:.5;cursor:default}
.btn.add{background:var(--brass);color:#241b10}
.btn.add:hover{background:var(--brass-bright)}
.btn.ghost{border-color:var(--line);color:var(--ink-soft)}
.btn.ghost:hover{background:var(--panel-2);color:var(--ink);border-color:var(--ink-faint)}
.btn.sm{padding:8px 12px;font-size:13px}
.empty-hint{color:var(--ink-faint);font-size:13px;padding:10px 2px;font-style:italic}

/* materials */
.mat-row{display:grid;grid-template-columns:34px 1fr 120px 32px;gap:10px;align-items:center;
  padding:7px 0;border-bottom:1px solid var(--line-soft)}
.mat-row:last-of-type{border-bottom:0}
.mat-row input[type=color]{width:34px;height:30px;padding:0;border:1px solid var(--line);
  border-radius:6px;background:var(--panel-2);cursor:pointer}
.mat-row .mname{width:100%;background:var(--panel-2);border:1px solid var(--line);color:var(--ink);
  border-radius:7px;padding:7px 9px;font-size:14px;font-family:var(--sans)}
.mat-row .pwrap{position:relative}
.mat-row .pwrap input{width:100%;background:var(--panel-2);border:1px solid var(--line);color:var(--ink);
  border-radius:7px;padding:7px 46px 7px 9px;font-family:var(--mono);font-size:14px;text-align:right}
.mat-row .pwrap .u{position:absolute;right:9px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--ink-faint);font-family:var(--mono)}
.mat-row .mdel{width:32px;height:30px}
.mat-row .lockpad{width:32px;height:30px}

/* preview */
.board-stage{background:repeating-linear-gradient(45deg,#15110d 0 9px,#171109 9px 18px);
  border:1px solid var(--line);border-radius:10px;padding:22px}
.board-meta-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:8px}
.board-meta-top .w{font-family:var(--mono);font-size:13px;color:var(--brass)}
.board-meta-top .t{font-family:var(--mono);font-size:12px;color:var(--ink-faint)}
.board{display:flex;height:240px;width:100%;border-radius:5px;overflow:hidden;
  box-shadow:0 10px 26px rgba(0,0,0,.5),inset 0 0 0 1px rgba(0,0,0,.5)}
.board .seg{height:100%;min-width:0;position:relative;
  background-image:repeating-linear-gradient(90deg,rgba(0,0,0,.10) 0 1px,rgba(255,255,255,.03) 1px 2px,transparent 2px 6px)}
.board .seg::after{content:attr(data-w);position:absolute;bottom:4px;left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:10px;color:rgba(0,0,0,.55);white-space:nowrap}
.board-empty{height:240px;display:flex;align-items:center;justify-content:center;color:var(--ink-faint);
  font-style:italic;font-size:14px;border:1px dashed var(--line);border-radius:5px;text-align:center;padding:0 20px}
.board-meta-bottom{text-align:center;font-family:var(--mono);font-size:12px;color:var(--ink-faint);margin-top:8px}

/* save bar */
.savebar{display:grid;grid-template-columns:1fr auto;gap:10px;margin-bottom:6px}
.savebar input[type=text]{background:var(--panel-2);border:1px solid var(--line);color:var(--ink);
  border-radius:8px;padding:9px 11px;font-size:14px;font-family:var(--sans)}
.savebar .loadwrap{display:grid;grid-template-columns:1fr auto;gap:8px;grid-column:1/-1}
.savebar select{background:var(--panel-2);border:1px solid var(--line);color:var(--ink);
  border-radius:8px;padding:9px 11px;font-size:14px;font-family:var(--sans)}

.msg{font-size:13px;min-height:18px;margin:2px 0}
.msg.ok{color:var(--ok)}
.msg.warn{color:var(--danger)}
.sharebox{margin-top:8px}
.sharebox label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--ink-faint);margin-bottom:5px}
.sharerow{display:grid;grid-template-columns:1fr auto;gap:8px}
.sharerow input{background:var(--panel-2);border:1px solid var(--line);color:var(--ink);
  border-radius:8px;padding:8px 10px;font-family:var(--mono);font-size:12px}

/* cards */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:6px 0 18px}
.card{background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:13px 14px}
.card .lab{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--ink-faint);margin-bottom:6px}
.card .val{font-family:var(--mono);font-size:22px;font-weight:600;letter-spacing:.5px}
.card.hero{border-color:var(--brass);background:linear-gradient(160deg,#2c2114,#251c12)}
.card.hero .val{color:var(--brass-bright)}

/* table */
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:right;font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--ink-faint);
  font-weight:600;padding:8px 6px;border-bottom:1px solid var(--line)}
thead th:first-child{text-align:left}
tbody td{padding:9px 6px;border-bottom:1px solid var(--line-soft);font-family:var(--mono);text-align:right}
tbody td:first-child{text-align:left;font-family:var(--sans)}
tbody td .dot{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:7px;vertical-align:middle;border:1px solid rgba(0,0,0,.4)}
tfoot td{padding:11px 6px;font-family:var(--mono);text-align:right;font-weight:700;border-top:2px solid var(--line)}
tfoot td:first-child{text-align:left;font-family:var(--sans);letter-spacing:.5px}
tfoot .grand{color:var(--brass-bright);font-size:15px}
.tbl-empty{color:var(--ink-faint);font-style:italic;font-size:13px;padding:14px 4px}

.note{font-size:12px;color:var(--ink-faint);margin-top:14px;line-height:1.6}
.note b{color:var(--ink-soft);font-weight:600}

/* ---- PRINT / PDF ---- */
.printDoc{display:none}
@media print{
  body{background:#fff;color:#111;padding:0}
  .screen{display:none !important}
  .printDoc{display:block;padding:18mm 16mm;font-family:var(--sans);color:#111}
  .printDoc h1{font-size:22px;margin:0 0 2px}
  .printDoc .sub{color:#666;font-size:12px;margin:0 0 18px}
  .printDoc .pmeta{display:flex;flex-wrap:wrap;gap:10px 26px;font-size:13px;margin-bottom:16px}
  .printDoc .pmeta span b{color:#000}
  .printDoc .pboard{display:flex;height:150px;width:100%;border:1px solid #999;border-radius:4px;overflow:hidden;margin-bottom:6px}
  .printDoc .pboard .pseg{height:100%;position:relative}
  .printDoc .pboard .pseg::after{content:attr(data-w);position:absolute;bottom:3px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:9px;color:rgba(0,0,0,.55)}
  .printDoc .pcap{text-align:center;font-family:var(--mono);font-size:11px;color:#555;margin-bottom:18px}
  .printDoc table{width:100%;border-collapse:collapse;font-size:12px}
  .printDoc th{text-align:right;border-bottom:1px solid #333;padding:6px;font-size:10px;text-transform:uppercase;color:#555}
  .printDoc th:first-child{text-align:left}
  .printDoc td{text-align:right;border-bottom:1px solid #ddd;padding:6px;font-family:var(--mono)}
  .printDoc td:first-child{text-align:left;font-family:var(--sans)}
  .printDoc tfoot td{border-top:2px solid #333;font-weight:700}
  .printDoc .dot{display:inline-block;width:9px;height:9px;border-radius:2px;margin-right:6px;vertical-align:middle;border:1px solid rgba(0,0,0,.4)}
}
