:root{
  --bg:#fbf7f2; --card:#ffffff; --ink:#2b2622; --muted:#857b72;
  --teal:#84c3a5; --teal-dark:#2f7a5c; --teal-ink:#1f3b30;
  --orange:#e79641; --orange-dark:#d4842f;
  --red:#da4947; --red-dark:#c23d3b;
  --line:#ece4db; --ok:#3f9a78; --danger:#da4947;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);color:var(--ink);-webkit-tap-highlight-color:transparent}
.wrap{max-width:520px;margin:0 auto;padding:16px;min-height:100vh}
.admin .wrap{max-width:980px}

/* Wordmark mengikuti logo: ice (teal) & (orange) Bean (red) */
.brandmark{text-align:center;margin:22px 0 4px;font-weight:800;font-size:38px;line-height:1;letter-spacing:.3px}
.brandmark .i{color:var(--teal)} .brandmark .a{color:var(--orange)} .brandmark .b{color:var(--red)}
.brand-sub{text-align:center;color:var(--muted);font-size:12px;margin-bottom:20px;letter-spacing:.12em;text-transform:uppercase}

header.app-bar{display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;background:var(--teal);color:var(--teal-ink);border-radius:16px;margin-bottom:16px}
header.app-bar h1{font-size:17px;margin:0;font-weight:800;color:var(--teal-ink)}
header.app-bar small{opacity:.85;font-weight:600;color:var(--teal-ink)}

.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;margin-bottom:14px}
.card h2{font-size:13px;margin:0 0 12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
label{display:block;font-size:13px;color:var(--muted);margin:10px 0 4px}
input,select,button{font:inherit}
input,select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink)}
input:focus,select:focus{outline:none;border-color:var(--orange)}
button{cursor:pointer;border:none;border-radius:10px;padding:12px 16px;font-weight:700}
.btn-primary{background:var(--orange);color:#fff;width:100%}
.btn-primary:active{background:var(--orange-dark)}
.btn-out{background:var(--red);color:#fff;width:100%}
.btn-out:active{background:var(--red-dark)}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn-sm{padding:7px 10px;font-size:13px;width:auto}
.big-action{font-size:18px;padding:18px}
.status{display:flex;align-items:center;gap:12px;padding:14px;border-radius:12px;background:#eef8f2;border:1px solid #cfe9dd}
.status.out{background:#fdeeee;border-color:#f6cfce}
.status .dot{width:12px;height:12px;border-radius:50%;background:var(--teal);flex:0 0 auto}
.status.out .dot{background:var(--red)}
.muted{color:var(--muted);font-size:13px}
.row{display:flex;gap:8px;align-items:center}
.row>*{flex:1}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:8px 6px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-weight:700}
.tag{display:inline-block;font-size:11px;padding:2px 8px;border-radius:20px;background:#f0ece6;color:var(--muted)}
.tag.open{background:#fdeede;color:#9a5a12}
.tag.closed{background:#e7f5ee;color:#246b4f}
.tag.corrected{background:#e9f1fb;color:#1e40af}
.msg{padding:10px 12px;border-radius:10px;margin:10px 0;font-size:14px;display:none}
.msg.show{display:block}
.msg.err{background:#fdeeee;color:var(--red-dark);border:1px solid #f6cfce}
.msg.ok{background:#eef8f2;color:#246b4f;border:1px solid #cfe9dd}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;padding:16px;z-index:50}
.modal.show{display:flex}
.modal .inner{width:100%;max-width:420px;text-align:center}
.modal video,.modal canvas{width:100%;border-radius:14px;background:#000;aspect-ratio:3/4;object-fit:cover}
.tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.tabs button{background:#fff;color:var(--ink);border:1px solid var(--line);padding:9px 14px}
.tabs button.active{background:var(--orange);color:#fff;border-color:var(--orange)}
.tabpane{display:none}.tabpane.active{display:block}
.spin{display:inline-block;width:16px;height:16px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;animation:s .7s linear infinite;vertical-align:-3px}
@keyframes s{to{transform:rotate(360deg)}}
.right{text-align:right}.center{text-align:center}
a.link{color:var(--teal-dark);font-size:12px;font-weight:600}
