:root{--ink:#231c16;--ink-soft:#3d352d;--canvas:#fbf8f3;--surface:#fff;--line:#eae2d7;--line-strong:#d6cdbf;--text:#231c16;--muted:#766c60;--faint:#a79e92;--brand:#f0473f;--brand-deep:#d63a32;--brand-wash:#fde7e5;--teal:#f0473f;--teal-deep:#d63a32;--teal-wash:#fde7e5;--ok:#15774d;--ok-wash:#ecfdf5;--warn:#c2410c;--warn-wash:#fbf0e6;--danger:#b91c1c;--danger-wash:#fbe7e3;--radius:12px;--radius-sm:8px;--shadow:0 1px 2px rgba(35,28,22,.05),0 8px 24px rgba(35,28,22,.06);--mono:ui-monospace,"SFMono-Regular",Menlo,monospace}*{box-sizing:border-box}body,html{margin:0;padding:0}body{background:var(--canvas);color:var(--text);font-family:Noto Sans TC,-apple-system,PingFang TC,Microsoft JhengHei,sans-serif;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.side{background:var(--ink);color:#cdbfb0;display:flex;flex-direction:column;padding:18px 14px;gap:6px}.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 14px}.brand .mark{width:30px;height:30px;border-radius:9px;background:var(--brand);display:grid;place-items:center;box-shadow:0 2px 6px rgba(240,71,63,.4)}.brand b{color:#fff;font-size:15px;letter-spacing:.3px;display:block;line-height:1.1}.brand span{font-size:11px;color:#a79e92}.navlbl{font-size:10.5px;letter-spacing:.14em;color:#a79e92;text-transform:uppercase;margin:14px 8px 4px;font-weight:600}.nav{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:9px;color:#c4b6a6;cursor:pointer;border:1px solid transparent;font-size:13.5px}.nav:hover{background:#33291f;color:#f1eae1}.nav.active{background:var(--teal-deep);color:#fff;border-color:#b06b3a}.nav .ic{width:18px;text-align:center}.side .foot{margin-top:auto;font-size:11px;color:#8a7d6e;padding:8px;line-height:1.5}.main{display:flex;flex-direction:column;min-width:0}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:20;background:hsla(38,50%,97%,.86);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:14px 26px}.topbar h1{font-size:19px;margin:0;font-weight:600;letter-spacing:.2px}.today{margin-left:auto;font-size:12px;color:var(--muted);background:var(--surface);border:1px solid var(--line);padding:6px 12px;border-radius:20px}.content{padding:22px 26px;display:flex;flex-direction:column;gap:18px}.kpis{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:14px;gap:14px}.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:15px 16px;box-shadow:var(--shadow)}.kpi .k{font-size:12px;color:var(--muted)}.kpi .v{font-size:27px;font-weight:600;margin-top:7px;letter-spacing:.5px}.kpi .s{font-size:11.5px;color:var(--faint);margin-top:3px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card .hd{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line)}.card .hd h2{font-size:14px;margin:0;font-weight:600}.card .bd{padding:14px 16px}table{width:100%;border-collapse:collapse;font-size:13px}th{font-size:11px;color:var(--muted);text-align:left;font-weight:600;letter-spacing:.04em;background:#fafbfc;text-transform:uppercase;white-space:nowrap}td,th{padding:11px 14px;border-bottom:1px solid var(--line)}tr:last-child td{border-bottom:0}.mono{font-family:var(--mono);font-size:12px}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}.dot.ok{background:var(--ok)}.dot.warn{background:var(--warn)}.dot.danger{background:var(--danger)}.pill{display:inline-block;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;background:var(--teal-wash);color:var(--teal-deep)}.pill.ok{background:var(--ok-wash);color:var(--ok)}.pill.warn{background:var(--warn-wash);color:var(--warn)}.btn{font-family:inherit;font-size:13px;font-weight:600;border-radius:9px;padding:9px 15px;cursor:pointer;border:1px solid transparent}.btn.primary{background:var(--teal);color:#fff}.btn.primary:hover{background:var(--teal-deep)}.btn.ghost{border-color:var(--line-strong)}.btn.ghost,input,select{background:var(--surface);color:var(--text)}input,select{font-family:inherit;font-size:13px;border:1px solid var(--line-strong);border-radius:9px;padding:9px 11px;width:100%}label{font-size:12px;color:var(--muted);display:block;margin-bottom:5px}.field{margin-bottom:12px}.row{display:flex;gap:10px;flex-wrap:wrap}.login{min-height:100vh;display:grid;place-items:center;padding:20px}.login .box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;width:100%;max-width:380px}.login .mark{width:44px;height:44px;border-radius:13px;background:var(--brand);display:grid;place-items:center;margin-bottom:14px;box-shadow:0 3px 10px rgba(240,71,63,.4)}.logobars{display:flex;flex-direction:column;gap:2.5px}.logobars i{display:block;height:3px;border-radius:2px;background:#fff}.logobars i:first-child,.logobars i:nth-child(2),.logobars i:nth-child(3){width:15px}.mark-lg .logobars{gap:3.5px}.mark-lg .logobars i{height:4px;width:22px;border-radius:2.5px}.muted{color:var(--muted)}.err,.muted{font-size:12.5px}.err{color:var(--danger);margin-top:8px}@media (max-width:920px){.app{grid-template-columns:64px 1fr}.brand b,.brand span,.nav span,.navlbl,.side .foot{display:none}.nav{justify-content:center}.kpis{grid-template-columns:repeat(2,1fr)}}