:root{
  --paper:#f4f1ea; --ink:#1a2b4a; --line:#33415c; --accent:#1a73e8;
  --green:#2e7d32; --red:#c62828; --house:#c0764a; --grey:#8a93a6;
  --panel:#ffffff; --soft:#e7e3d8;
}
*{box-sizing:border-box;}
body{margin:0;font-family:"Segoe UI",system-ui,Arial,sans-serif;color:var(--ink);background:var(--paper);}
header{padding:12px 22px;border-bottom:1px solid var(--soft);display:flex;align-items:center;gap:14px;background:#fff;position:sticky;top:0;z-index:5;}
header .logo{font-size:19px;font-weight:700;letter-spacing:.3px;}
header .logo b{color:var(--accent);}
header .sub{color:var(--grey);font-size:13px;}
header .spacer{flex:1;}
header .ver{font-size:11px;color:var(--grey);border:1px solid var(--soft);border-radius:20px;padding:3px 9px;}

.wrap{display:grid;grid-template-columns:300px 1fr 330px;height:calc(100vh - 50px);overflow:hidden;}
.panel{padding:16px 18px;}
.left{border-right:1px solid var(--soft);background:#fbfaf6;overflow-y:auto;}
.right{border-left:1px solid var(--soft);background:#fbfaf6;overflow-y:auto;}
.mid{display:flex;align-items:flex-start;justify-content:center;padding:18px;overflow-y:auto;}

h2{font-size:11.5px;text-transform:uppercase;letter-spacing:.8px;color:var(--grey);margin:18px 0 8px;}
h2:first-child{margin-top:0;}
label{display:block;font-size:13px;margin:9px 0 3px;}
input[type=number],input[type=text],textarea{width:100%;padding:7px 8px;border:1px solid #cfd6e2;border-radius:6px;font-size:14px;font-variant-numeric:tabular-nums;font-family:inherit;}
textarea{resize:vertical;min-height:64px;font-size:12.5px;}
.row{display:flex;gap:8px;}
.row>div{flex:1;}
button{cursor:pointer;border:1px solid #cfd6e2;background:#fff;border-radius:7px;padding:8px 10px;font-size:13px;margin-top:8px;width:100%;transition:.15s;}
button:hover{border-color:var(--accent);color:var(--accent);}
button.primary{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;}
button.primary:hover{filter:brightness(1.07);color:#fff;}
.hint{font-size:11.5px;color:var(--grey);line-height:1.5;margin-top:7px;}

/* tabs */
.tabs{display:flex;flex-wrap:wrap;gap:4px;background:#eee9dd;border-radius:9px;padding:4px;margin-bottom:6px;}
.tabs button{flex:1 1 40%;margin:0;border:none;background:transparent;border-radius:6px;padding:7px 4px;font-size:12px;color:var(--ink);white-space:nowrap;}
.tp-mk{background:#1a73e8;color:#fff;border:none;font-size:10px;padding:0 4px;border-radius:8px;}
.tabs button.active{background:#fff;color:var(--accent);font-weight:600;box-shadow:0 1px 3px rgba(0,0,0,.08);}
.tabpane{display:none;}
.tabpane.active{display:block;}

svg#canvas{background:#fff;border:1px solid var(--soft);box-shadow:0 1px 10px rgba(0,0,0,.06);max-width:100%;height:auto;}
.viewbar{display:flex;gap:6px;margin-bottom:10px;}
.viewbar button{width:auto;margin:0;padding:6px 16px;border-radius:7px;font-size:13px;}
.viewbar button.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;}
#view3d canvas{display:block;border-radius:0;}

.tep{width:100%;border-collapse:collapse;font-size:13px;}
.tep td{padding:5px 2px;border-bottom:1px dashed #e2ddcf;}
.tep td.v{text-align:right;font-variant-numeric:tabular-nums;font-weight:600;}
.check{display:flex;align-items:flex-start;gap:8px;font-size:13px;padding:6px 0;border-bottom:1px dashed #e2ddcf;}
.check .ic{font-weight:700;width:16px;flex:none;}
.ok{color:var(--green);} .bad{color:var(--red);} .info{color:var(--grey);}
.check .meta{color:var(--grey);font-size:11.5px;}
.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;}
.badge.ok{background:#e6f4ea;color:var(--green);} .badge.bad{background:#fdecea;color:var(--red);}
.legend{font-size:12px;color:var(--ink);line-height:1.7;margin-top:6px;}
.sw{display:inline-block;width:14px;height:10px;border-radius:2px;vertical-align:middle;margin-right:6px;border:1px solid rgba(0,0,0,.15);}
.note{font-size:11.5px;background:#fff7e6;border:1px solid #f0e0b8;border-radius:7px;padding:8px 10px;margin-top:8px;color:#7a5a00;line-height:1.45;}
