:root{
  --bg:#f4f6f9; --panel:#fff; --ink:#1f2733; --sub:#67707e; --line:#e3e8ef;
  --brand:#2f6df0; --ok:#2e8b57; --okbg:#e7f4ec; --warn:#e08a00; --warnbg:#fdf1dd;
  --pend:#6b7280; --pendbg:#eef0f3; --danger:#c0392b; --dangerbg:#fbe9e7;
  --miss:#7a5bd0; --missbg:#eee9fb;
}
*{box-sizing:border-box}
body{margin:0;font-family:"Hiragino Kaku Gothic ProN","Yu Gothic UI",system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;}
a{color:var(--brand);text-decoration:none}
/* login */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;}
.loginbox{background:#fff;border:1px solid var(--line);border-radius:14px;padding:34px 40px;text-align:center;min-width:320px;}
.loginbox h1{font-size:18px;margin:0 0 20px;}
.gbtn{display:inline-block;background:var(--brand);color:#fff;padding:11px 22px;border-radius:8px;font-weight:600;}
.gbtn:hover{background:#2456c9}
.devbox{margin-top:22px;padding-top:16px;border-top:1px dashed var(--line);font-size:13px;line-height:1.9;}
.muted{color:var(--sub);font-size:12px;margin:0 0 6px}
.err{color:var(--danger);font-size:13px}
/* layout */
.app{display:flex;min-height:100vh;}
.side{width:212px;background:#10182a;color:#c7cfdc;flex-shrink:0;display:flex;flex-direction:column;}
.brand{padding:18px;font-weight:700;color:#fff;font-size:15px;border-bottom:1px solid #1e2740;}
.brand small{display:block;font-weight:400;color:#7c89a3;font-size:11px;margin-top:3px;}
.nav{padding:10px 0;flex:1;}
.nav button{width:100%;text-align:left;background:none;border:0;color:#aeb8ca;padding:11px 18px;font-size:13.5px;cursor:pointer;display:flex;gap:9px;align-items:center;}
.nav button:hover{background:#1a2238;color:#fff;}
.nav button.active{background:#1f2a45;color:#fff;border-left:3px solid var(--brand);padding-left:15px;}
.nav .badge{margin-left:auto;background:var(--danger);color:#fff;border-radius:10px;font-size:11px;padding:1px 7px;}
.sidefoot{padding:14px 18px;border-top:1px solid #1e2740;font-size:12px;display:flex;flex-direction:column;gap:6px;}
.logout{color:#9fb0cc;font-size:12px;}
.main{flex:1;display:flex;flex-direction:column;min-width:0;}
.top{background:var(--panel);border-bottom:1px solid var(--line);padding:12px 22px;display:flex;align-items:center;gap:16px;}
.top h1{font-size:16px;margin:0;}
.top .right{margin-left:auto;}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;}
.content{padding:22px;overflow:auto;}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:15px 17px;}
.kpi .lab{color:var(--sub);font-size:12px;margin-bottom:7px;}
.kpi .val{font-size:25px;font-weight:700;}
.kpi .val small{font-size:13px;font-weight:600;color:var(--sub);}
.kpi.alert .val{color:var(--danger);}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:12px;margin-bottom:20px;overflow:hidden;}
.panel h2{font-size:14px;margin:0;padding:14px 18px;border-bottom:1px solid var(--line);display:flex;gap:10px;}
.panel h2 .hint{font-weight:400;color:var(--sub);font-size:12px;margin-left:auto;}
table{width:100%;border-collapse:collapse;}
th,td{text-align:left;padding:10px 14px;font-size:13px;border-bottom:1px solid #eef1f5;white-space:nowrap;}
th{color:var(--sub);font-weight:600;font-size:12px;background:#fafbfc;}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums;}
.badge2{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11.5px;font-weight:600;}
.s-照合OK{color:var(--ok);background:var(--okbg);}
.s-要確認{color:var(--warn);background:var(--warnbg);}
.s-未照合{color:var(--pend);background:var(--pendbg);}
.s-無断来店{color:var(--danger);background:var(--dangerbg);}
.s-未入室{color:var(--miss);background:var(--missbg);}
.pill{display:inline-block;padding:1px 8px;border-radius:6px;font-size:11px;background:#eef1f5;color:var(--sub);}
.btn{border:0;border-radius:7px;padding:6px 12px;font-size:12.5px;font-weight:600;cursor:pointer;}
.btn-ok{background:var(--ok);color:#fff;} .btn-ok:hover{background:#256e45;}
.filters{display:flex;gap:10px;align-items:center;padding:12px 18px;border-bottom:1px solid var(--line);flex-wrap:wrap;}
select,input{font-family:inherit;font-size:13px;padding:6px 9px;border:1px solid var(--line);border-radius:7px;background:#fff;}
.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--sub);padding:10px 18px;}
.legend span{display:inline-flex;align-items:center;gap:5px;}
.sw{width:11px;height:11px;border-radius:3px;display:inline-block;}
.logitem{display:flex;gap:11px;padding:11px 14px;border-bottom:1px solid #eef1f5;}
.logitem .dot{width:9px;height:9px;border-radius:50%;margin-top:5px;flex-shrink:0;}
.logitem .meta{color:var(--sub);font-size:11.5px;margin-top:2px;}
.note{background:#f0f5ff;border:1px solid #d6e4ff;border-radius:9px;padding:11px 14px;font-size:12.5px;margin-bottom:18px;}
.right-secondary{color:var(--sub);font-size:12px;}
.chip{display:inline-block;background:#eef1f5;border-radius:14px;padding:3px 6px 3px 10px;font-size:12px;margin:2px;}
.chip button{border:0;background:#d6dbe3;color:#444;border-radius:50%;width:16px;height:16px;line-height:14px;margin-left:5px;cursor:pointer;font-size:11px;padding:0;}
.chip button:hover{background:var(--danger);color:#fff;}
.empty{padding:26px;text-align:center;color:var(--sub);}
