*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --c-bg:#f0efe9; --c-surface:#fff; --c-border:rgba(0,0,0,.09); --c-border-med:rgba(0,0,0,.16);
  --c-text:#1a1a1a; --c-muted:#6b6b6b; --c-hint:#aaa;
  --c-ok:#2d5a0e; --c-ok-bg:#eaf3de; --c-ok-bd:#b5d87a;
  --c-fail:#8b1f1f; --c-fail-bg:#fceaea; --c-fail-bd:#f0a0a0;
  --c-warn:#7a430a; --c-warn-bg:#fef0d8; --c-warn-bd:#f5c070;
  --c-info:#134e8f; --c-info-bg:#e4f0fb; --c-info-bd:#90c0f0;
  --c-admin:#4a3db0; --c-admin-bg:#eeedfd; --c-admin-bd:#c8c4ef;
  --c-offline:#555; --c-offline-bg:#ebebeb; --c-offline-bd:#ccc;
  --r-sm:6px; --r-md:8px; --r-lg:12px; --r-xl:16px;
  --nav-h:62px; --sb-w:220px;
  font-family:'Sarabun','Noto Sans Thai',sans-serif;
}
html,body{height:100%}
body{background:var(--c-bg);color:var(--c-text);font-size:14px}

/* APP WRAP */
#app-wrap{display:flex;min-height:100vh}
#main-content{flex:1;min-width:0}

/* SIDEBAR */
#sidebar{
  display:none;width:var(--sb-w);background:var(--c-surface);
  border-right:0.5px solid var(--c-border);
  flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:40;overflow-y:auto;
}
#sidebar .sb-logo{
  padding:18px 16px 14px;font-size:15px;font-weight:800;
  border-bottom:0.5px solid var(--c-border);display:flex;align-items:center;gap:8px;
}
#sidebar .sb-section{font-size:10px;color:var(--c-hint);padding:14px 16px 4px;letter-spacing:.08em;text-transform:uppercase}
#sidebar .sb-item{
  display:flex;align-items:center;gap:10px;padding:10px 16px;
  font-size:13px;cursor:pointer;color:var(--c-muted);
  border:none;background:none;width:100%;text-align:left;font-family:inherit;font-weight:500;
  transition:background .12s,color .12s;
}
#sidebar .sb-item:hover{background:var(--c-bg);color:var(--c-text)}
#sidebar .sb-item.active{background:var(--c-bg);color:var(--c-text);font-weight:700}
#sidebar .sb-icon{font-size:16px;width:22px;text-align:center}
#sidebar .sb-user{
  margin-top:auto;padding:12px 16px;border-top:0.5px solid var(--c-border);
  font-size:12px;color:var(--c-muted);display:flex;align-items:center;gap:8px;
}
@media(min-width:900px){
  #sidebar{display:flex}
  #main-content{margin-left:var(--sb-w)}
  .nav-bar{display:none!important}
  .pg{padding-bottom:28px!important}
}

/* SCREENS */
.screen{display:none;min-height:100vh}
.screen.active{display:block}

/* HEADER */
.hdr{
  background:var(--c-surface);border-bottom:0.5px solid var(--c-border);
  padding:13px 20px;display:flex;align-items:center;gap:10px;
  position:sticky;top:0;z-index:30;
}
.hdr h2{font-size:15px;font-weight:700;flex:1}
.back-btn{background:none;border:none;font-size:20px;cursor:pointer;color:var(--c-muted);padding:0;line-height:1}

/* PAGE */
.pg{padding:16px 20px;padding-bottom:calc(var(--nav-h)+32px);max-width:820px}
.pg-wide{max-width:1100px!important}

/* CARD */
.card{background:var(--c-surface);border:0.5px solid var(--c-border);border-radius:var(--r-lg);padding:16px;margin-bottom:12px}
.card-title{font-size:13px;font-weight:700;margin-bottom:12px}

/* FORM */
label{display:block;font-size:12px;color:var(--c-muted);margin-bottom:4px;margin-top:12px;font-weight:600}
label:first-child{margin-top:0}
input[type=text],input[type=password],input[type=email],input[type=number],input[type=date],select,textarea{
  width:100%;padding:9px 12px;border:0.5px solid var(--c-border-med);
  border-radius:var(--r-md);background:var(--c-surface);color:var(--c-text);
  font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--c-text);box-shadow:0 0 0 3px rgba(26,26,26,.07)}

/* BUTTONS */
.btn{width:100%;padding:11px 16px;border-radius:var(--r-md);font-size:14px;font-weight:600;
  cursor:pointer;border:0.5px solid var(--c-border-med);background:var(--c-surface);
  color:var(--c-text);font-family:inherit;transition:all .12s}
.btn:hover{background:var(--c-bg)}
.btn:active{transform:scale(.985)}
.btn-primary{background:var(--c-text);color:#fff;border-color:var(--c-text)}
.btn-primary:hover{opacity:.88;background:var(--c-text)}
.btn-danger{border-color:var(--c-fail-bd);color:var(--c-fail)}
.btn-danger:hover{background:var(--c-fail-bg)}
.btn-sm{padding:5px 12px;font-size:12px;width:auto;border-radius:var(--r-md);cursor:pointer;
  border:0.5px solid var(--c-border-med);background:var(--c-surface);color:var(--c-text);
  font-family:inherit;font-weight:600;transition:all .12s}
.btn-sm:hover{background:var(--c-bg)}
.btn-go{width:100%;padding:16px;border-radius:var(--r-lg);font-size:17px;font-weight:700;
  cursor:pointer;border:none;background:var(--c-text);color:#fff;font-family:inherit;
  letter-spacing:.01em;transition:opacity .15s}
.btn-go:hover{opacity:.88}
.btn-go:active{opacity:.7;transform:scale(.99)}
.btn-go:disabled{opacity:.35;cursor:not-allowed}

/* BOTTOM NAV */
.nav-bar{
  display:flex;justify-content:center;
  background:var(--c-surface);border-top:0.5px solid var(--c-border);
  position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);z-index:50;
  padding-bottom:env(safe-area-inset-bottom,0);
  box-shadow:0 -2px 12px rgba(0,0,0,.06);
}
.nav-bar-inner{display:flex;width:100%;max-width:480px}
.nav-item{
  flex:1;padding:8px 4px 6px;text-align:center;cursor:pointer;
  font-size:11px;color:var(--c-muted);border:none;background:none;font-family:inherit;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  transition:color .12s;
}
.nav-item.active{color:var(--c-text);font-weight:700}
.nav-icon{font-size:19px}

/* TABS */
.tab-row{display:flex;gap:4px;margin-bottom:12px}
.tab{flex:1;padding:8px;text-align:center;font-size:12px;font-weight:600;
  border:0.5px solid var(--c-border);border-radius:var(--r-md);cursor:pointer;
  color:var(--c-muted);font-family:inherit;background:var(--c-surface);transition:all .12s}
.tab:hover{background:var(--c-bg)}
.tab.active{background:var(--c-text);color:#fff;border-color:transparent}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:3px 9px;
  border-radius:20px;font-weight:700;white-space:nowrap;border:0.5px solid transparent}
.badge-ok     {background:var(--c-ok-bg);   color:var(--c-ok);    border-color:var(--c-ok-bd)}
.badge-fail   {background:var(--c-fail-bg); color:var(--c-fail);  border-color:var(--c-fail-bd)}
.badge-warn   {background:var(--c-warn-bg); color:var(--c-warn);  border-color:var(--c-warn-bd)}
.badge-info   {background:var(--c-info-bg); color:var(--c-info);  border-color:var(--c-info-bd)}
.badge-admin  {background:var(--c-admin-bg);color:var(--c-admin); border-color:var(--c-admin-bd)}
.badge-offline{background:var(--c-offline-bg);color:var(--c-offline);border-color:var(--c-offline-bd)}
.badge-viewer {background:var(--c-bg);color:var(--c-muted);border-color:var(--c-border-med)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.dot-ok{background:var(--c-ok)} .dot-fail{background:var(--c-fail)}
.dot-warn{background:var(--c-warn)} .dot-off{background:#bbb}

/* ALERT BOXES */
.box-warn{background:var(--c-warn-bg);border:0.5px solid var(--c-warn-bd);border-radius:var(--r-md);padding:10px 14px;font-size:13px;color:var(--c-warn)}
.box-ok  {background:var(--c-ok-bg);  border:0.5px solid var(--c-ok-bd);  border-radius:var(--r-md);padding:10px 14px;font-size:13px;color:var(--c-ok)}
.box-err {background:var(--c-fail-bg);border:0.5px solid var(--c-fail-bd);border-radius:var(--r-md);padding:10px 14px;font-size:13px;color:var(--c-fail)}
.box-info{background:var(--c-info-bg);border:0.5px solid var(--c-info-bd);border-radius:var(--r-md);padding:10px 14px;font-size:13px;color:var(--c-info)}

/* METRICS */
.metric-row{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.metric{background:var(--c-bg);border-radius:var(--r-md);padding:12px 8px;text-align:center;
  flex:1;min-width:68px;border:0.5px solid var(--c-border)}
.metric-val{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums}
.metric-lbl{font-size:10px;color:var(--c-muted);margin-top:2px}

/* DET ROWS */
.row-item{display:flex;justify-content:space-between;align-items:center;
  padding:10px 0;border-bottom:0.5px solid var(--c-border);gap:8px}
.row-item:last-child{border-bottom:none}
.det-row{display:flex;justify-content:space-between;align-items:flex-start;
  padding:7px 0;font-size:13px;border-bottom:0.5px solid var(--c-border);gap:12px}
.det-row:last-child{border-bottom:none}
.det-key{color:var(--c-muted);font-size:12px;flex-shrink:0;font-weight:500}
.det-val{text-align:right;word-break:break-all}

/* CHIPS */
.chip{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;
  border:0.5px solid var(--c-border-med);border-radius:20px;font-size:12px;
  cursor:pointer;margin:3px;background:var(--c-surface);color:var(--c-text);
  transition:all .12s;font-weight:600}
.chip:hover{background:var(--c-bg)}
.chip.sel{background:var(--c-text);color:#fff;border-color:var(--c-text)}
.chip .x{font-size:15px;color:var(--c-muted);line-height:1;cursor:pointer}
.chip.sel .x{color:rgba(255,255,255,.7)}
.filter-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;
  border:0.5px solid var(--c-border-med);border-radius:20px;font-size:12px;
  cursor:pointer;margin:3px;color:var(--c-muted);background:var(--c-surface);font-weight:600;transition:all .12s}
.filter-chip:hover{background:var(--c-bg)}
.filter-chip.on{border-color:var(--c-text);color:var(--c-text);background:var(--c-bg)}

/* TOGGLE */
.toggle{width:42px;height:24px;background:var(--c-border-med);border-radius:12px;
  cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}
.toggle.on{background:#52a825}
.toggle::after{content:'';position:absolute;width:20px;height:20px;background:#fff;
  border-radius:50%;top:2px;left:2px;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.toggle.on::after{left:20px}

/* PHOTOS */
.upload-zone{border:1.5px dashed var(--c-border-med);border-radius:var(--r-lg);
  padding:20px;text-align:center;cursor:pointer;color:var(--c-muted);
  font-size:13px;position:relative;transition:all .15s}
.upload-zone:hover{background:var(--c-bg);border-color:var(--c-text)}
.photo-strip{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.photo-item{position:relative;width:76px;height:76px;border-radius:var(--r-md);
  overflow:hidden;flex-shrink:0;border:0.5px solid var(--c-border)}
.photo-item img{width:100%;height:100%;object-fit:cover;cursor:pointer;transition:opacity .15s}
.photo-item:hover img{opacity:.85}
.photo-del{position:absolute;top:3px;right:3px;background:rgba(0,0,0,.6);color:#fff;
  border:none;border-radius:50%;width:20px;height:20px;font-size:13px;cursor:pointer;
  display:flex;align-items:center;justify-content:center}
.photo-thumb{width:48px;height:48px;border-radius:var(--r-md);object-fit:cover;
  border:0.5px solid var(--c-border);cursor:pointer;flex-shrink:0;transition:opacity .15s}
.photo-thumb:hover{opacity:.8}

/* SPEED SLIDER */
.speed-row{display:flex;align-items:center;gap:10px}
.speed-row input[type=range]{flex:1;accent-color:var(--c-text)}

/* PROGRESS / STEPS */
.progress-wrap{height:6px;background:var(--c-bg);border-radius:6px;overflow:hidden;margin:10px 0}
.progress-fill{height:100%;background:var(--c-text);border-radius:6px;transition:width .5s ease}
.step-row{display:flex;align-items:center;gap:10px;padding:7px 0;font-size:13px}
.step-icon{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;transition:all .2s}
.step-done  {background:var(--c-ok-bg);  color:var(--c-ok); border:0.5px solid var(--c-ok-bd)}
.step-active{background:var(--c-text);   color:#fff}
.step-wait  {background:var(--c-bg);     color:var(--c-muted);border:0.5px solid var(--c-border)}
.step-val{font-size:11px;color:var(--c-muted);margin-left:auto}

/* PING BARS */
.bar-wrap{height:96px;display:flex;align-items:flex-end;gap:5px;padding:0 2px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}
.bar-rect{width:100%;border-radius:3px 3px 0 0;min-height:4px;transition:height .3s ease}
.bar-rect.good{background:#52a825}.bar-rect.warn{background:#ef9f27}.bar-rect.bad{background:#e24b4a}
.bar-lbl{font-size:8px;color:var(--c-muted);text-align:center}

/* STAT BARS */
.stat-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:13px}
.stat-bar-bg{flex:1;height:10px;background:var(--c-bg);border-radius:5px;overflow:hidden}
.stat-bar-fill{height:100%;border-radius:5px;transition:width .4s ease}
.stat-bar-lbl{min-width:95px;color:var(--c-muted);font-size:12px;font-weight:500}
.stat-bar-num{min-width:30px;text-align:right;font-weight:700;font-size:13px}

/* REPORT SUMMARY CARDS */
.rpt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
@media(min-width:600px){.rpt-grid{grid-template-columns:repeat(4,1fr)}}
.rpt-card{border-radius:var(--r-lg);padding:16px 14px;border:0.5px solid transparent;cursor:default}
.rpt-card .rpt-val{font-size:32px;font-weight:800;margin-bottom:2px;font-variant-numeric:tabular-nums}
.rpt-card .rpt-lbl{font-size:12px;font-weight:600}
.rpt-card .rpt-pct{font-size:12px;margin-top:5px;opacity:.65}
.rpt-card .rpt-bar{height:4px;border-radius:2px;margin-top:8px;opacity:.4}
.rpt-total{background:var(--c-bg);       border-color:var(--c-border-med);color:var(--c-text)}
.rpt-ok   {background:var(--c-ok-bg);    border-color:var(--c-ok-bd);     color:var(--c-ok)}
.rpt-fail {background:var(--c-fail-bg);  border-color:var(--c-fail-bd);   color:var(--c-fail)}
.rpt-off  {background:var(--c-warn-bg);  border-color:var(--c-warn-bd);   color:var(--c-warn)}

/* TIMELINE */
.tl-item{display:flex;gap:12px;padding:10px 6px;border-bottom:0.5px solid var(--c-border);
  cursor:pointer;transition:background .1s;border-radius:var(--r-sm)}
.tl-item:last-child{border-bottom:none}
.tl-item:hover{background:var(--c-bg)}
.tl-dot{width:10px;height:10px;border-radius:50%;margin-top:4px;flex-shrink:0}

/* ONLINE */
.online-ind{display:inline-flex;align-items:center;gap:5px;font-size:12px;padding:4px 10px;border-radius:20px;font-weight:600}
.online-ind.on {background:var(--c-ok-bg); color:var(--c-ok)}
.online-ind.off{background:var(--c-warn-bg);color:var(--c-warn)}
.pulse{width:7px;height:7px;border-radius:50%;background:currentColor;animation:pulse 1.5s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

/* TIME BADGE */
.time-badge{background:var(--c-bg);border:0.5px solid var(--c-border);border-radius:var(--r-md);
  padding:3px 10px;font-size:12px;color:var(--c-muted);font-variant-numeric:tabular-nums}

/* AVATAR */
.avatar{width:38px;height:38px;border-radius:50%;background:var(--c-bg);border:0.5px solid var(--c-border);
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.user-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:0.5px solid var(--c-border)}
.user-row:last-child{border-bottom:none}
.sync-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:0.5px solid var(--c-border)}
.sync-item:last-child{border-bottom:none}

/* RESULT */
.result-big{font-size:56px;font-weight:300;text-align:center;padding:14px 0 4px;font-variant-numeric:tabular-nums}
.result-sub{font-size:12px;color:var(--c-muted);text-align:center;margin-bottom:14px}

/* LOGIN */
.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:var(--c-bg)}
.login-logo{font-size:36px;margin-bottom:8px}
.login-title{font-size:22px;font-weight:800;margin-bottom:4px}
.login-sub{font-size:13px;color:var(--c-muted);margin-bottom:28px}
.login-card{width:100%;max-width:380px;background:var(--c-surface);border:0.5px solid var(--c-border);border-radius:var(--r-xl);padding:28px;box-shadow:0 4px 24px rgba(0,0,0,.06)}

/* MODAL */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:200;align-items:center;justify-content:center}
.modal-bg.show{display:flex}
.modal-img{max-width:94%;max-height:86vh;border-radius:var(--r-lg);box-shadow:0 8px 40px rgba(0,0,0,.5)}

/* PASS */
#pass-strength,#pass-match,#eu-strength,#eu-match{font-size:11px;margin-top:4px;font-weight:600;min-height:16px}

/* TOAST */
.toast{position:fixed;bottom:72px;left:50%;transform:translateX(-50%);z-index:300;
  white-space:nowrap;padding:10px 20px;font-size:13px;border-radius:24px;font-weight:600;
  pointer-events:none;animation:fadeup .25s ease;box-shadow:0 4px 16px rgba(0,0,0,.15)}
@keyframes fadeup{from{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* GRIDS */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media(max-width:480px){.grid-3{grid-template-columns:1fr 1fr}.metric-val{font-size:18px}.result-big{font-size:44px}}

/* BUILDING EDITOR */
.bld-block{background:var(--c-bg);border:0.5px solid var(--c-border);border-radius:var(--r-md);padding:12px;margin-bottom:8px}

/* DESKTOP */
@media(min-width:900px){
  .hdr{padding:14px 24px}
  .pg{padding:20px 28px 32px;max-width:900px}
  .pg-wide{max-width:1100px}
}
@media(max-width:480px){
  .pg{padding:12px 14px;padding-bottom:calc(var(--nav-h)+40px)}
}

/* ─── LAYOUT FIX: full-width balanced ─── */
#main-content { width: 100%; }
.pg { max-width: 100% !important; }
@media(min-width:900px) {
  .pg { padding: 24px 40px 32px; }
  .pg-inner { max-width: 960px; }
}
@media(min-width:1200px) {
  .pg { padding: 28px 60px 36px; }
}

/* ─── COMPACT REPORT ROWS ─── */
.rpt-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 6px;
  border-bottom: 0.5px solid var(--c-border);
  border-radius: var(--r-sm);
  transition: background 0.1s;
}
.rpt-row:last-child { border-bottom: none; }
.rpt-row:hover { background: var(--c-bg); }
.rpt-row-dot {
  width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; margin-top: 1px;
}
.rpt-row-main {
  flex: 1; min-width: 0; cursor: pointer;
  display: flex; flex-wrap: wrap; align-items: baseline; gap: 0 10px;
}
.rpt-row-point {
  font-size: 14px; font-weight: 800; color: var(--c-text); white-space: nowrap;
}
.rpt-row-site {
  font-size: 13px; color: var(--c-muted); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis; max-width: 220px;
}
.rpt-row-speed {
  font-size: 13px; font-weight: 600; color: var(--c-info); white-space: nowrap;
}
.rpt-row-conn {
  font-size: 12px; color: var(--c-muted); white-space: nowrap;
}
.rpt-row-time {
  font-size: 12px; color: var(--c-admin); white-space: nowrap;
}
.rpt-row-note {
  font-size: 11px; color: var(--c-warn); width: 100%;
}
.rpt-row-end {
  display: flex; align-items: center; gap: 5px; flex-shrink: 0;
}

/* ─── REPORT ROW: user field ─── */
.rpt-row-user {
  font-size: 11px;
  color: var(--c-admin);
  white-space: nowrap;
}

/* ─── PRINT REPORT PAGE ─── */
#print-report-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: #fff;
  z-index: 500;
  overflow-y: auto;
}
#print-report-modal.show { display: block; }

.pr-wrap {
  width: 100%;
  padding: 28px 40px 48px;
  font-family: 'Sarabun', sans-serif;
}
.pr-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 28px;
  gap: 12px;
  flex-wrap: wrap;
}
.pr-title { font-size: 22px; font-weight: 800; }
.pr-subtitle { font-size: 13px; color: #666; margin-top: 2px; }
.pr-actions { display: flex; gap: 8px; }

.pr-summary {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 12px;
  margin-bottom: 28px;
}
@media(max-width:640px){ .pr-summary { grid-template-columns: repeat(2,1fr); } }
.pr-card {
  border-radius: 12px;
  padding: 18px 16px;
  border: 1px solid;
}
.pr-card .pr-val { font-size: 36px; font-weight: 800; margin-bottom: 2px; }
.pr-card .pr-lbl { font-size: 12px; font-weight: 700; }
.pr-card .pr-pct { font-size: 12px; margin-top: 6px; opacity: 0.65; }
.pr-c-total { background:#f5f4f0; border-color:#ddd; color:#1a1a1a; }
.pr-c-ok    { background:#eaf3de; border-color:#b5d87a; color:#2d5a0e; }
.pr-c-fail  { background:#fceaea; border-color:#f0a0a0; color:#8b1f1f; }
.pr-c-off   { background:#fef0d8; border-color:#f5c070; color:#7a430a; }

.pr-section { margin-bottom: 32px; }
.pr-section-title {
  font-size: 15px; font-weight: 800; margin-bottom: 12px;
  padding-bottom: 6px; border-bottom: 2px solid #1a1a1a;
  display: flex; justify-content: space-between; align-items: center;
}
.pr-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
}
.pr-table th {
  background: #1a1a1a; color: #fff;
  padding: 9px 12px; text-align: left;
  font-weight: 700; font-size: 12px;
  white-space: nowrap;
}
.pr-table td {
  padding: 8px 12px;
  border-bottom: 0.5px solid #e5e5e5;
  vertical-align: middle;
}
.pr-table tr:nth-child(even) td { background: #fafaf8; }
.pr-table tr:hover td { background: #f0efe9; }
.pr-status {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; padding: 3px 8px; border-radius: 20px; font-weight: 700; white-space: nowrap;
}
.pr-ok   { background:#eaf3de; color:#2d5a0e; }
.pr-fail { background:#fceaea; color:#8b1f1f; }
.pr-off  { background:#fef0d8; color:#7a430a; }

.pr-sort-btn {
  background: none; border: none; cursor: pointer;
  font-size: 11px; color: #888; padding: 0 3px;
  font-family: inherit;
}
.pr-sort-btn.active { color: #1a1a1a; font-weight: 700; }

.pr-bar-mini {
  display: inline-block; height: 6px; border-radius: 3px; min-width: 4px;
  vertical-align: middle; margin-right: 5px;
}

@media print {
  #print-report-modal .pr-actions { display: none !important; }
  #print-report-modal { position: static !important; }
  body > *:not(#print-report-modal) { display: none !important; }
}

/* ─── LAYOUT: full bleed, balanced ─── */
#app-wrap { min-height: 100vh; }

/* Survey screen: cap width for mobile feel */
#s-survey .pg,
#s-result .pg,
#s-testing .pg,
#s-offline .pg,
#s-add-user .pg,
#s-edit-user .pg,
#s-edit-site .pg,
#s-detail .pg {
  max-width: 640px;
}

/* Admin screens: use full width minus sidebar */
#s-admin .pg { max-width: 100%; padding-left: 28px; padding-right: 28px; }

@media(min-width:900px) {
  #s-admin .pg { padding-left: 36px; padding-right: 36px; }
  #s-admin .card { margin-bottom: 14px; }

  /* Report list: stretch full width */
  .rpt-row { padding: 9px 8px; }
  .rpt-row-site { max-width: 280px; }

  /* Summary cards 4-up always on desktop */
  .rpt-grid { grid-template-columns: repeat(4,1fr) !important; }

  /* Stat bars wider */
  .stat-bar-lbl { min-width: 140px; }
}

@media(min-width:1400px) {
  #s-admin .pg { padding-left: 52px; padding-right: 52px; }
}

/* rpt-row-user visible */
.rpt-row-user { font-size: 11px; color: var(--c-muted); white-space: nowrap; }

/* ═══════════════════════════════════════
   ADMIN REPORT - FULL WIDTH FIX
═══════════════════════════════════════ */

/* หน้า admin ใช้พื้นที่เต็มหน้าจอ */
#s-admin { width: 100%; }
#s-admin .pg { 
  max-width: 100% !important; 
  width: 100%;
  padding-left: 24px !important;
  padding-right: 24px !important;
}
@media(min-width:900px) {
  #s-admin .pg {
    padding-left: 32px !important;
    padding-right: 32px !important;
  }
}

/* Summary cards: เต็มแถวเสมอ */
.rpt-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 10px;
  margin-bottom: 14px;
}
@media(max-width:600px) {
  .rpt-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

/* รายการจุดทดสอบ: ใช้พื้นที่เต็ม card */
#rpt-list { width: 100%; }
.rpt-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 8px;
  border-bottom: 0.5px solid var(--c-border);
  border-radius: var(--r-sm);
  width: 100%;
  min-width: 0;
}
.rpt-row:hover { background: var(--c-bg); }
.rpt-row-main {
  flex: 1;
  min-width: 0;
  cursor: pointer;
  display: grid;
  grid-template-columns: 70px 1fr 1fr 1fr 140px 80px;
  gap: 0 10px;
  align-items: center;
}
@media(max-width:1200px) {
  .rpt-row-main {
    grid-template-columns: 60px 1fr 1fr;
    flex-wrap: wrap;
  }
}
.rpt-row-point  { font-size:14px; font-weight:800; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.rpt-row-site   { font-size:12px; color:var(--c-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.rpt-row-speed  { font-size:12px; font-weight:600; color:var(--c-info); white-space:nowrap; }
.rpt-row-conn   { font-size:12px; color:var(--c-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.rpt-row-time   { font-size:11px; color:var(--c-admin); white-space:nowrap; }
.rpt-row-user   { font-size:11px; color:var(--c-muted); white-space:nowrap; }
.rpt-row-note   { font-size:11px; color:var(--c-warn); grid-column:1/-1; padding-top:2px; }
.rpt-row-end    { display:flex; align-items:center; gap:5px; flex-shrink:0; }
.rpt-row-dot    { width:9px; height:9px; border-radius:50%; flex-shrink:0; }

/* stat bars ใช้ full width */
#rpt-stat-bars, #rpt-speed-bars, #rpt-lat-bars { width: 100%; }
.stat-bar-row { width: 100%; }
.stat-bar-bg { flex: 1; min-width: 0; }

/* ═══════════════════════════════════════
   REPORT TABLE - CLEAN TABLE LAYOUT
═══════════════════════════════════════ */
.rpt-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  table-layout: auto;
}
.rpt-table thead tr {
  background: var(--c-text);
  color: #fff;
}
.rpt-table th {
  padding: 10px 12px;
  text-align: left;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
  letter-spacing: 0.03em;
}
/* col widths */
.th-point  { width: 80px; }
.th-site   { width: 160px; }
.th-dl     { width: 140px; }
.th-lat    { width: 70px; }
.th-jit    { width: 65px; }
.th-conn   { width: 150px; }
.th-time   { width: 145px; }
.th-user   { width: 100px; }
.th-photo  { width: 70px; }
.th-status { width: 80px; }

.rt-row {
  border-bottom: 0.5px solid var(--c-border);
  cursor: pointer;
  transition: background 0.1s;
}
.rt-row:last-child { border-bottom: none; }
.rt-row:hover td { background: var(--c-bg) !important; }

.rpt-table td {
  padding: 9px 12px;
  vertical-align: middle;
  font-size: 13px;
  line-height: 1.4;
}
.rt-dot-cell { padding: 9px 6px 9px 12px; }

/* alternating rows */
.rt-row:nth-child(even) td { background: #fafaf8; }

/* text styles per column */
.rt-point { font-size: 14px; font-weight: 800; white-space: nowrap; }
.rt-site  { font-size: 13px; }
.rt-speed { font-size: 13px; white-space: nowrap; }
.rt-lat   { font-size: 13px; font-weight: 600; text-align: center; white-space: nowrap; }
.rt-conn  { font-size: 12px; }
.rt-time  { font-size: 12px; white-space: nowrap; }
.rt-user  { font-size: 12px; color: var(--c-admin); font-weight: 600; }
.rt-photo { white-space: nowrap; }
.rt-status { white-space: nowrap; }
.rt-action { padding: 4px 8px; }
.rt-sub   { font-size: 11px; color: var(--c-muted); }

/* note row if exists */
.rt-note-row td {
  padding: 2px 12px 8px;
  font-size: 11px;
  color: var(--c-warn);
}

/* ═══════════════════════════════════════
   PAGINATION
═══════════════════════════════════════ */
.pg-btn {
  min-width: 32px; height: 32px;
  padding: 0 8px;
  border: 0.5px solid var(--c-border-med);
  border-radius: var(--r-md);
  background: var(--c-surface);
  color: var(--c-text);
  font-size: 13px;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.12s;
  font-weight: 500;
}
.pg-btn:hover:not(:disabled) { background: var(--c-bg); border-color: var(--c-text); }
.pg-btn:disabled { opacity: 0.35; cursor: not-allowed; }
.pg-btn.pg-active {
  background: var(--c-text);
  color: #fff;
  border-color: var(--c-text);
  font-weight: 700;
}
