:root{
  --bg1:#fff;
  --bg2:#ffe8ee;
  --card:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --border:#e5e7eb;
  --shadow: 0 12px 30px rgba(17,24,39,0.10);
  --red:#ef4444;
  --red2:#fb7185;
  --green:#16a34a; /* pekat */
  --graypill:#e5e7eb;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background: radial-gradient(1200px 600px at 20% 0%, var(--bg2), transparent 60%),
              radial-gradient(900px 500px at 85% 10%, #ffe1e8, transparent 55%),
              linear-gradient(180deg, var(--bg1), #fff 55%, #fff);
}
a{color:inherit}
.container{max-width:1100px;margin:0 auto;padding:22px}
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:rgba(255,255,255,0.65);
  border:1px solid rgba(229,231,235,0.8);
  backdrop-filter: blur(10px);
  padding:14px 16px;border-radius:18px; box-shadow: var(--shadow);
}
.brand{display:flex;align-items:center;gap:12px}
.dot{width:12px;height:12px;border-radius:99px;background:var(--red); box-shadow:0 0 0 6px rgba(239,68,68,0.14)}
.brand h1{font-size:18px;margin:0;font-weight:800;letter-spacing:0.2px}
.brand p{margin:0;color:var(--muted);font-size:13px}
.pills{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;
  border:1px solid rgba(229,231,235,0.9);
  background:rgba(255,255,255,0.75);
  color:#111827;
  font-size:13px;
}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
@media(max-width:900px){.grid3{grid-template-columns:1fr}}
.card{
  background:rgba(255,255,255,0.85);
  border:1px solid rgba(229,231,235,0.9);
  border-radius:22px;
  padding:18px;
  box-shadow: var(--shadow);
}
.card h2{margin:0 0 8px;font-size:30px;letter-spacing:-0.4px}
.card p{margin:0 0 14px;color:var(--text);line-height:1.35}
.card .sub{color:var(--muted);font-size:14px;margin-top:2px}
.actions{display:flex;gap:10px;flex-wrap:wrap}
.btn{
  border:1px solid rgba(229,231,235,1);
  background:rgba(255,255,255,0.9);
  padding:10px 14px;border-radius:999px;
  cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:8px;
  font-weight:700;font-size:14px;
}
.btn-primary{
  border:none;
  background: linear-gradient(135deg,var(--red),var(--red2));
  color:white;
  box-shadow: 0 10px 24px rgba(239,68,68,0.28);
}
.btn:active{transform: translateY(1px)}
.btn[disabled]{opacity:0.55;cursor:not-allowed}
.sectionTitle{margin-top:18px;font-size:20px;margin-bottom:8px}
.bullets{margin:0;color:#111827}
.bullets li{margin:6px 0}
.footer{margin-top:18px;text-align:center;color:var(--muted);font-size:13px}
/* Lists */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:16px;
}
@media(max-width:900px){.split{grid-template-columns:1fr}}
.panelTitle{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.panelTitle h2{margin:0;font-size:22px}
.panelTitle .hint{color:var(--muted);font-size:13px}
.list{
  display:flex;flex-direction:column;gap:12px;
}
.row{
  background:rgba(255,255,255,0.85);
  border:1px solid rgba(229,231,235,0.9);
  border-radius:18px;
  padding:14px 14px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.seat{font-weight:900;font-size:20px;letter-spacing:0.2px}
.controls{display:flex;align-items:center;gap:10px}
.smallBtn{
  width:38px;height:38px;border-radius:12px;
  border:1px solid rgba(229,231,235,1);
  background:rgba(255,255,255,0.9);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:900;cursor:pointer;
}
.count{
  width:44px;height:38px;border-radius:999px;
  border:1px solid rgba(229,231,235,1);
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:900;
  background: var(--graypill);
  color:#374151;
}
.count.on{
  background: rgba(22,163,74,0.28);
  border:1px solid rgba(22,163,74,0.75);
  color:#065f46;
}
.plus{
  width:44px;height:38px;border-radius:12px;border:none;
  background: linear-gradient(135deg,var(--red),var(--red2));
  color:white;font-size:18px;font-weight:900;cursor:pointer;
}
.plus:active,.smallBtn:active{transform: translateY(1px)}
.homeLink{display:inline-flex;align-items:center;gap:8px;text-decoration:none}
.homeLink .arrow{font-weight:900}
/* Checker */
.checkerHeader{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:rgba(255,255,255,0.65);
  border:1px solid rgba(229,231,235,0.85);
  backdrop-filter: blur(10px);
  padding:14px 16px;border-radius:18px; box-shadow: var(--shadow);
  margin-bottom:16px;
}
.checkerHeader h2{margin:0;font-size:22px}
.checkerHeader .desc{margin:0;color:var(--muted);font-size:13px}
.empty{color:#111827;font-size:18px;margin-top:24px}
.updated{color:var(--muted);font-size:13px;text-align:center;margin-top:10px}
.checkerList{display:flex;flex-direction:column;gap:12px;margin-top:10px}
.checkerRow{
  background:rgba(255,255,255,0.85);
  border:1px solid rgba(229,231,235,0.9);
  border-radius:18px;
  padding:12px 14px;
  display:grid;grid-template-columns:140px 1fr;gap:14px;align-items:center;
}
@media(max-width:700px){.checkerRow{grid-template-columns:1fr}}
.boxes{display:flex;gap:12px;flex-wrap:wrap}
.box{
  min-width:160px;
  border:1px solid rgba(229,231,235,1);
  border-radius:16px;
  padding:10px 12px;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:rgba(255,255,255,0.75);
}
.box .label{font-weight:800}
.box .val{
  width:40px;height:36px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;
  border:1px solid rgba(229,231,235,1);
  background: var(--graypill);
  color:#374151;
}
.box .val.on{
  background: rgba(22,163,74,0.20);
  border:1px solid rgba(22,163,74,0.65);
  color:#065f46;
  cursor:pointer;
}
.box .val.on:hover{filter:brightness(0.98)}
.noteCard{
  margin-top:18px;
  background:rgba(255,255,255,0.75);
  border:1px solid rgba(229,231,235,0.9);
  border-radius:22px;padding:16px;
  box-shadow: var(--shadow);
}
.noteCard h3{margin:0 0 8px;font-size:16px}
.noteCard ol{margin:0;padding-left:18px}
.noteCard li{margin:6px 0;color:#111827}
/* settings */
textarea{
  width:100%;
  min-height:240px;
  border:1px solid rgba(229,231,235,1);
  border-radius:14px;
  padding:12px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size:13px;
}


/* Station horizontal grouped layout (Cipang / Steak) */
.stationReport{margin-top:16px}
.stationReportHeader{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.stationReportTitle{font-weight:800;font-size:18px}
.stationReportSub{color:var(--muted);font-size:13px}
.stationReportStrip{
  display:flex;gap:10px;overflow-x:auto;padding:4px 2px 6px;scrollbar-width:thin;
}
.stationReportStrip.emptyState{display:block;padding:10px 2px;color:var(--muted);font-size:14px}
.reportChip{
  flex:0 0 auto;display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:16px;
  border:1px solid rgba(229,231,235,0.95);background:rgba(255,255,255,0.9);
}
.reportChip .code{font-weight:900;min-width:52px;text-align:center}
.reportChip .qty{
  min-width:42px;height:34px;padding:0 10px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;
  font-weight:900;border:1px solid rgba(22,163,74,0.78);background:rgba(22,163,74,0.28);color:#065f46;
}
.stationBoard{margin-top:14px}
.stationBoardHead{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.stationBoardHead h2{margin:0;font-size:18px}
.stationBoardHead .hint{color:var(--muted);font-size:13px}
.stationGroupsScroll{overflow-x:auto;overflow-y:hidden;padding-bottom:8px}
.stationGroupsTrack{display:flex;gap:14px;align-items:flex-start;min-width:max-content}
.stationGroup{
  width:300px;max-width:calc(100vw - 70px);background:rgba(255,255,255,0.72);
  border:1px solid rgba(229,231,235,0.9);border-radius:18px;padding:12px;
}
.stationGroupTitle{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}
.stationGroupTitle .prefix{font-weight:900;font-size:16px}
.stationGroupTitle .meta{color:var(--muted);font-size:12px}
.stationGroupList{display:flex;flex-direction:column;gap:10px;max-height:66vh;overflow-y:auto;padding-right:4px}
.stationRowCompact{
  background:rgba(255,255,255,0.88);border:1px solid rgba(229,231,235,0.9);border-radius:14px;
  padding:10px 10px;display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.stationRowCompact .seat{font-size:16px}
.stationRowCompact .controls{gap:8px}
.stationRowCompact .smallBtn{width:34px;height:34px;border-radius:10px}
.stationRowCompact .count{width:40px;height:34px}
.stationRowCompact .plus{width:40px;height:34px;border-radius:10px}
@media (max-width:640px){
  .stationGroup{width:270px;max-width:calc(100vw - 46px)}
}
