/* ================================================================
   CHIMING POS · 共用設計系統
   給 Claude Code：把這份檔案放到 /static/css/chiming-pos.css
   所有頁面 <link rel="stylesheet" href="/static/css/chiming-pos.css">
   ================================================================ */

:root{
  /* Color tokens */
  --bg:           #F5F2EC;
  --paper:        #FBFAF5;
  --card:         #FFFFFF;
  --row-alt:      #F9F7F4;

  --ink:          #2A2A28;
  --muted:        #6B6B66;

  --accent:       #4A5E3A;
  --accent-dark:  #3D4F30;
  --accent-soft:  #7A8C6A;
  --accent-tint:  #EEF2E6;

  --border:       #C4A882;
  --border-soft:  #E8E4DC;

  --ok-bg:        #E2EBD7;
  --ok-text:      #4A7C3A;
  --warn-bg:      #FEF3CD;
  --warn-text:    #856404;
  --danger:       #B65A3F;
  --danger-bg:    #FCDCDC;
  --danger-text:  #842029;

  --radius-card:  8px;
  --radius-btn:   6px;
  --radius-pill:  999px;
  --shadow-soft:  0 2px 8px rgba(74,94,58,.06);
  --shadow-hover: 0 8px 24px rgba(74,94,58,.12), 0 2px 6px rgba(74,94,58,.08);

  --font-sans: 'Noto Sans TC', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html,body{ background:var(--bg); color:var(--ink); font-family:var(--font-sans); font-weight:400; line-height:1.55; -webkit-font-smoothing:antialiased; }
.mono{ font-family:var(--font-mono); letter-spacing:.04em; }
button{ font-family:inherit; cursor:pointer; }
a{ color:inherit; text-decoration:none; }
input,select,textarea{ font-family:inherit; }

/* ─── BUTTONS ─────────────────────────────── */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:10px 18px; font-size:13px; font-weight:500;
  border:1px solid transparent; border-radius:var(--radius-btn);
  transition: background .15s, border-color .15s, color .15s;
}
.btn-primary{ background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-primary:hover{ background:var(--accent-dark); border-color:var(--accent-dark); }
.btn-outline{ background:transparent; color:var(--accent); border-color:var(--accent); }
.btn-outline:hover{ background:var(--accent-tint); }
.btn-ghost{ background:transparent; color:var(--muted); }
.btn-ghost:hover{ background:var(--border-soft); color:var(--accent); }
.btn-danger{ background:transparent; color:var(--danger); border-color:var(--danger); }
.btn-danger:hover{ background:var(--danger); color:#fff; }
.btn-sm{ padding:6px 12px; font-size:12px; }
.btn-lg{ padding:14px 28px; font-size:15px; font-weight:600; }
.btn-xl{ padding:18px 32px; font-size:17px; font-weight:600; }

/* ─── BADGES ──────────────────────────────── */
.badge{ display:inline-block; padding:3px 10px; border-radius:var(--radius-pill); font-size:11px; font-weight:500; }
.badge-ok{ background:var(--ok-bg); color:var(--ok-text); }
.badge-warn{ background:var(--warn-bg); color:var(--warn-text); }
.badge-danger{ background:var(--danger-bg); color:var(--danger-text); }
.badge-muted{ background:#EAE6DD; color:var(--muted); }

/* ─── INPUTS ──────────────────────────────── */
.field{ display:flex; flex-direction:column; gap:5px; }
.field label{ font-size:11px; color:var(--muted); letter-spacing:.08em; font-weight:500; }
.input, .select, .textarea{
  padding:9px 12px; font-size:13px; color:var(--ink);
  background:var(--card); border:1px solid var(--border-soft);
  border-radius:var(--radius-btn);
}
.input:focus, .select:focus, .textarea:focus{ outline:none; border-color:var(--accent); }

/* ─── TABLE ───────────────────────────────── */
.tbl{
  width:100%; border-collapse:collapse;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius-card); overflow:hidden;
  font-size:13px;
}
.tbl thead th{
  background:var(--accent); color:#fff;
  font-size:11px; letter-spacing:.14em; font-weight:500;
  text-align:left; padding:10px 14px; text-transform:uppercase;
}
.tbl thead th.num{ text-align:right; }
.tbl tbody td{ padding:11px 14px; border-bottom:1px solid var(--border-soft); }
.tbl tbody tr:nth-child(even){ background:var(--row-alt); }
.tbl tbody tr:last-child td{ border-bottom:none; }
.tbl tbody tr:hover{ background:var(--paper); }
.tbl td.num{ text-align:right; font-variant-numeric:tabular-nums; font-family:var(--font-mono); }

/* ─── ADMIN SHELL ─────────────────────────── */
.admin-shell{ display:grid; grid-template-columns:240px 1fr; min-height:100vh; }

/* Topbar (above whole layout, with logo) */
.admin-top{
  grid-column: 1 / -1;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px;
  background:var(--accent); color:#fff;
  border-bottom:1px solid var(--accent-dark);
}
.admin-top .brand{ display:flex; align-items:center; gap:14px; }
.admin-top .logo{
  width:40px; height:40px; background:#fff; color:var(--accent);
  font-weight:700; font-size:18px; border-radius:4px;
  display:flex; align-items:center; justify-content:center;
}
.admin-top .brand-name{ font-size:16px; font-weight:600; letter-spacing:.04em; }
.admin-top .top-nav{ display:flex; gap:4px; }
.admin-top .top-nav a{
  padding:8px 14px; font-size:13px; color:rgba(255,255,255,.75);
  border-radius:var(--radius-btn);
}
.admin-top .top-nav a:hover{ background:rgba(255,255,255,.08); color:#fff; }
.admin-top .top-nav a.active{ background:#fff; color:var(--accent); font-weight:500; }
.admin-top .top-actions{ display:flex; align-items:center; gap:10px; }

/* Sidebar */
.admin-side{
  background:var(--paper);
  border-right:1px solid var(--border-soft);
  padding:18px 0;
  overflow-y:auto;
}
.side-group{ margin-bottom:18px; }
.side-group-label{
  font-size:10px; letter-spacing:.22em; color:var(--accent-soft);
  font-weight:600; padding:6px 22px; text-transform:uppercase;
  font-family:var(--font-mono);
}
.side-nav{ list-style:none; }
.side-nav a{
  display:flex; align-items:center; gap:10px;
  padding:9px 22px;
  font-size:13px; color:var(--ink);
  border-left:3px solid transparent;
}
.side-nav a:hover{ background:var(--card); }
.side-nav a.active{
  background:var(--accent-tint);
  color:var(--accent); font-weight:500;
  border-left-color:var(--accent);
}
.side-nav .ic{ font-size:15px; width:20px; text-align:center; }

/* Main */
.admin-main{ padding:28px 32px; min-width:0; }
.page-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-bottom:22px;
}
.page-head .num{
  font-size:11px; letter-spacing:.22em; color:var(--border);
  font-weight:600; font-family:var(--font-mono); margin-bottom:4px;
}
.page-head h1{ font-size:24px; font-weight:700; color:var(--accent); }
.page-head .actions{ display:flex; gap:10px; align-items:center; }

/* Filter bar */
.filter-bar{
  display:flex; gap:12px; align-items:flex-end; flex-wrap:wrap;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius-card); padding:14px 18px;
  margin-bottom:18px;
}
.filter-bar .field input,
.filter-bar .field select{
  padding:7px 10px; font-size:12px; min-width:140px;
  border:1px solid var(--border-soft); border-radius:var(--radius-btn);
  background:var(--card);
}
.chip-group{ display:flex; gap:4px; }
.chip{
  padding:7px 12px; font-size:12px;
  background:var(--card); border:1px solid var(--border-soft);
  border-radius:var(--radius-btn); color:var(--muted);
}
.chip:hover{ border-color:var(--border); color:var(--ink); }
.chip.active{ background:var(--accent); border-color:var(--accent); color:#fff; }

/* KPI cards */
.kpi-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:20px; }
.kpi{
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius-card); padding:18px 20px;
}
.kpi .label{ font-size:11px; color:var(--muted); letter-spacing:.08em; margin-bottom:8px; }
.kpi .value{ font-size:24px; font-weight:700; color:var(--accent); font-family:var(--font-mono); line-height:1.1; }
.kpi .meta{ margin-top:8px; font-size:11px; color:var(--muted); }
.kpi .up{ color:var(--ok-text); font-weight:600; }
.kpi .down{ color:var(--danger-text); font-weight:600; }

/* Section card */
.card-block{
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius-card); padding:20px 22px;
  margin-bottom:18px;
}
.card-head{ margin-bottom:14px; display:flex; justify-content:space-between; align-items:baseline; }
.card-num{ font-size:10px; letter-spacing:.22em; color:var(--border); font-weight:600; font-family:var(--font-mono); }
.card-head h3{ font-size:15px; font-weight:700; color:var(--accent); margin-top:2px; }

/* Toggle switch */
.toggle{ position:relative; display:inline-block; width:38px; height:22px; }
.toggle input{ opacity:0; width:0; height:0; }
.toggle .track{
  position:absolute; inset:0; background:#D6D2C8;
  border-radius:var(--radius-pill); transition:.2s;
}
.toggle .track::before{
  content:""; position:absolute; left:3px; top:3px;
  width:16px; height:16px; background:#fff; border-radius:50%;
  transition:.2s; box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.toggle input:checked + .track{ background:var(--accent); }
.toggle input:checked + .track::before{ transform:translateX(16px); }

/* Footer (admin) */
.admin-foot{
  grid-column: 2 / -1;
  border-top:1px solid var(--border-soft);
  padding:16px 32px;
  font-size:11px; color:var(--muted); letter-spacing:.08em;
  display:flex; justify-content:space-between;
  background:var(--paper);
}

/* Offline banner */
.offline-banner{
  background:var(--warn-bg); color:var(--warn-text);
  padding:8px 16px; font-size:12px; text-align:center;
  border-bottom:1px solid #F0E2A6;
}
