:root {
  --ink: #07191f;
  --muted: #63777f;
  --line: #d8c999;
  --line-dark: #102b35;
  --gold: #c6a34d;
  --paper: #ffffff;
  --canvas: #edf6f8;
  --green: #075c70;
  --green-2: #087f96;
  --mint: #dceff3;
  --orange: #c6a34d;
  --orange-soft: #f8f1dc;
  --yellow: #f0cf72;
  --danger: #ce594f;
  --shadow: 0 18px 48px rgba(2, 38, 50, .12);
  --radius-lg: 24px;
  --radius-md: 16px;
  --radius-sm: 12px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-width: 320px;
  background: radial-gradient(circle at 82% 0, #ffffff 0, #f3fafb 25%, var(--canvas) 62%, #e4f0f2 100%);
  background-attachment: fixed;
  color: var(--ink);
  font-family: "IBM Plex Sans Thai", sans-serif;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
}
button, input, select, textarea { font: inherit; }
button { color: inherit; }
button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 3px solid rgba(8, 127, 150, .24);
  outline-offset: 1px;
}

.app-shell { display: grid; grid-template-columns: 252px minmax(0, 1fr); min-height: 100vh; }
.sidebar {
  position: fixed; inset: 0 auto 0 0; width: 252px; z-index: 20;
  display: flex; flex-direction: column; padding: 26px 18px 18px;
  background: linear-gradient(165deg, #052f3c 0%, #075f74 55%, #031a22 100%); color: #fff;
  border-right: 1px solid rgba(198,163,77,.72); box-shadow: inset -1px 0 rgba(0,0,0,.42), 9px 0 34px rgba(1,31,41,.11);
}
.brand { display: flex; align-items: center; gap: 12px; padding: 0 10px 30px; }
.brand-mark {
  width: 42px; height: 42px; border-radius: 15px; display: grid; place-items: center;
  background: linear-gradient(145deg, #f6db8b, #b4862e); color: #061b22; box-shadow: inset 0 1px 0 rgba(255,255,255,.75), inset 0 0 0 1px rgba(3,25,33,.45), 0 8px 18px rgba(0,0,0,.2);
}
.brand-mark svg { width: 24px; }
.brand strong { display: block; font: 700 18px/1 "Manrope", sans-serif; letter-spacing: -.4px; }
.brand small { color: rgba(255,255,255,.6); font-size: 11px; }
.nav-label { padding: 0 12px 9px; color: rgba(255,255,255,.43); font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.nav { display: grid; gap: 5px; }
.nav-btn {
  width: 100%; min-height: 46px; border: 0; border-radius: 13px; padding: 0 13px;
  display: flex; align-items: center; gap: 12px; background: transparent; color: rgba(255,255,255,.68);
  cursor: pointer; text-align: left; transition: .18s ease;
}
.nav-btn svg { width: 20px; height: 20px; flex: none; }
.nav-btn:hover { color: #fff; background: rgba(255,255,255,.08); }
.nav-btn.active { color: #fff; background: linear-gradient(90deg,rgba(255,255,255,.16),rgba(255,255,255,.08)); box-shadow: inset 0 1px rgba(255,255,255,.16), inset 0 -1px rgba(0,0,0,.2); font-weight: 600; }
.nav-btn.active::before { content: ""; width: 3px; height: 20px; border-radius: 3px; background: var(--orange); margin-left: -13px; }
.nav-btn.active svg { color: var(--yellow); }
.nav-spacer { flex: 1; }
.sidebar-card { margin: 16px 4px 0; padding: 14px; border: 1px solid rgba(221,186,99,.42); border-radius: 16px; background: linear-gradient(145deg,rgba(255,255,255,.1),rgba(255,255,255,.035)); box-shadow: inset 0 1px rgba(255,255,255,.14); }
.sidebar-card-top { display: flex; align-items: center; justify-content: space-between; }
.live-dot { width: 8px; height: 8px; border-radius: 50%; background: #8ae8f1; box-shadow: 0 0 0 5px rgba(138,232,241,.13), 0 0 10px rgba(255,255,255,.65); }
.sidebar-card b { font-size: 13px; }
.sidebar-card p { margin: 5px 0 0; color: rgba(255,255,255,.55); font-size: 11px; }

.main { grid-column: 2; min-width: 0; }
.topbar {
  height: 82px; padding: 0 38px; display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--line); background: linear-gradient(90deg,rgba(240,248,250,.92),rgba(255,255,255,.88)); backdrop-filter: blur(14px);
  box-shadow: inset 0 -1px rgba(8,30,37,.12), 0 5px 18px rgba(6,58,71,.04);
  position: sticky; top: 0; z-index: 15;
}
.page-title h1 { margin: 0; font-size: 22px; line-height: 1.2; letter-spacing: -.3px; }
.page-title p { margin: 4px 0 0; color: var(--muted); font-size: 12px; }
.top-actions { display: flex; align-items: center; gap: 10px; }
.live-pill { display: inline-flex; align-items: center; gap: 8px; border: 1px solid #a9d4dc; border-radius: 999px; padding: 8px 12px; background: linear-gradient(145deg,#fff,#e9f6f8); color: var(--green-2); box-shadow: inset 0 1px #fff; font-size: 12px; font-weight: 600; }
.live-pill .live-dot { width: 7px; height: 7px; }
.icon-btn { width: 40px; height: 40px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 12px; background: #fff; cursor: pointer; }
.icon-btn svg { width: 19px; }
.profile-switch { position: relative; display: flex; align-items: center; gap: 10px; margin-left: 3px; padding: 5px 6px 5px 7px; border: 1px solid var(--line); border-radius: 14px; background: #fff; cursor: pointer; }
.avatar { width: 32px; height: 32px; display: grid; place-items: center; border-radius: 10px; background: var(--mint); color: var(--green); font-weight: 700; }
.profile-copy { text-align: left; line-height: 1.25; }
.profile-copy b { display: block; font-size: 12px; }
.profile-copy small { color: var(--muted); font-size: 10px; }
.profile-menu { position: absolute; top: 52px; right: 0; width: 220px; padding: 8px; border: 1px solid var(--line); border-radius: 15px; background: #fff; box-shadow: var(--shadow); }
.profile-menu p { margin: 5px 8px 8px; color: var(--muted); font-size: 11px; }
.role-option { width: 100%; display: flex; align-items: center; gap: 10px; border: 0; border-radius: 10px; padding: 10px; background: transparent; cursor: pointer; text-align: left; }
.role-option:hover, .role-option.active { background: var(--canvas); }
.role-option .check { margin-left: auto; color: var(--orange); }

.content { padding: 30px 38px 44px; max-width: 1540px; margin: auto; }
.content-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 22px; }
.content-head h2 { margin: 0; font-size: 19px; }
.content-head p { margin: 4px 0 0; color: var(--muted); font-size: 12px; }
.btn { min-height: 42px; border: 0; border-radius: 12px; padding: 0 16px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; cursor: pointer; font-weight: 600; transition: .18s ease; }
.btn svg { width: 18px; height: 18px; }
.btn-primary { border: 1px solid #041d25; background: linear-gradient(135deg,#06495b,#09849c); color: #fff; box-shadow: inset 0 1px rgba(255,255,255,.28), 0 7px 18px rgba(5,83,101,.2); }
.btn-primary:hover { background: linear-gradient(135deg,#032f3c,#067389); transform: translateY(-1px); }
.btn-orange { border: 1px solid #6e531d; background: linear-gradient(145deg,#e5c96f,#b88d35); color: var(--ink); box-shadow: inset 0 1px rgba(255,255,255,.62), 0 6px 16px rgba(125,92,27,.18); }
.btn-orange:hover { background: linear-gradient(145deg,#f0d886,#ae7e25); }
.btn-soft { border: 1px solid #a9d2da; background: linear-gradient(145deg,#eefafb,#d6eef2); color: var(--green); }
.btn-ghost { border: 1px solid var(--gold); background: linear-gradient(145deg,#fff,#f5f8f7); box-shadow: inset 0 1px #fff; }
.btn-danger { background: #fff1ef; color: var(--danger); }
.btn-sm { min-height: 34px; padding: 0 11px; border-radius: 9px; font-size: 12px; }
.btn-block { width: 100%; }

.stat-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.stat-card { position: relative; overflow: hidden; min-height: 140px; padding: 21px; border: 1px solid var(--line); border-bottom-color: rgba(10,35,43,.45); border-radius: var(--radius-lg); background: linear-gradient(145deg,#ffffff 0%,#fbfeff 52%,#edf7f9 100%); box-shadow: inset 0 1px rgba(255,255,255,.96), 0 10px 28px rgba(4,55,68,.07); }
.stat-card::before { content: ""; position: absolute; left: 16px; right: 16px; top: 0; height: 2px; background: linear-gradient(90deg,transparent,rgba(255,255,255,.95),var(--gold),rgba(255,255,255,.95),transparent); opacity: .72; }
.stat-card::after { content: ""; position: absolute; right: -24px; bottom: -30px; width: 100px; height: 100px; border-radius: 50%; background: var(--stat-soft, var(--mint)); opacity: .65; }
.stat-top { display: flex; align-items: center; justify-content: space-between; color: var(--muted); font-size: 12px; }
.stat-icon { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 12px; color: var(--stat-color, var(--green)); background: var(--stat-soft, var(--mint)); }
.stat-icon svg { width: 19px; }
.stat-value { margin: 15px 0 3px; font: 700 27px/1.1 "Manrope", "IBM Plex Sans Thai", sans-serif; }
.stat-foot { color: var(--muted); font-size: 11px; }
.trend-up { color: var(--green-2); font-weight: 600; }
.dashboard-grid { display: grid; grid-template-columns: minmax(0, 1.65fr) minmax(300px, .8fr); gap: 18px; margin-top: 18px; }
.panel { border: 1px solid var(--line); border-bottom-color: rgba(8,31,39,.38); border-radius: var(--radius-lg); background: linear-gradient(145deg,#fff 0%,#fbfeff 58%,#edf7f9 100%); box-shadow: inset 0 1px rgba(255,255,255,.98), 0 10px 30px rgba(3,47,59,.065); overflow: hidden; }
.panel-pad { padding: 22px; }
.panel-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 18px; }
.panel-head h3 { margin: 0; font-size: 15px; }
.panel-head p { margin: 3px 0 0; color: var(--muted); font-size: 11px; }
.segmented { display: flex; padding: 3px; border-radius: 10px; background: var(--canvas); }
.segment { min-width: 50px; border: 0; border-radius: 8px; padding: 6px 9px; background: transparent; color: var(--muted); font-size: 11px; cursor: pointer; }
.segment.active { background: #fff; color: var(--ink); box-shadow: 0 2px 8px rgba(0,0,0,.05); }
.branch-selector { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; max-width: 100%; }
.branch-selector.compact { justify-content: flex-end; }
.branch-selector button { min-height: 34px; display: inline-flex; align-items: center; gap: 7px; border: 1px solid var(--line); border-radius: 10px; padding: 0 11px; background: #fff; color: var(--muted); cursor: pointer; font-size: 10px; font-weight: 600; box-shadow: inset 0 1px #fff; }
.branch-selector button.active { border-color: var(--green); background: linear-gradient(145deg,#e9f8fa,#fff); color: var(--green); box-shadow: inset 3px 0 var(--gold); }
.branch-selector i { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.branch-select-note { display: inline-flex; align-items: center; gap: 7px; min-height: 34px; padding: 0 11px; border: 1px solid var(--line); border-radius: 10px; background: #fff; color: var(--green); font-size: 10px; font-weight: 700; }
.branch-select-note svg { width: 15px; }
.branch-picker-trigger { min-width: min(285px,100%); min-height: 42px; display: inline-grid; grid-template-columns: 28px minmax(0,1fr) auto; align-items: center; gap: 9px; border: 1px solid var(--line); border-bottom-color: rgba(7,27,34,.35); border-radius: 14px; padding: 6px 8px; background: linear-gradient(145deg,#fff,#eef9fb); color: var(--ink); cursor: pointer; text-align: left; box-shadow: inset 0 1px rgba(255,255,255,.9), 0 7px 18px rgba(3,53,67,.06); }
.branch-picker-trigger:hover { border-color: rgba(198,163,77,.65); box-shadow: inset 0 1px rgba(255,255,255,.9), 0 9px 22px rgba(3,53,67,.1); }
.branch-picker-trigger b { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 11px; }
.branch-picker-trigger small { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--muted); font-size: 9px; }
.branch-picker-trigger em { padding: 5px 8px; border-radius: 999px; background: #fff; color: var(--green); font-size: 9px; font-style: normal; font-weight: 800; border: 1px solid var(--line); }
.branch-picker-mark { width: 24px; height: 24px; display: grid; place-items: center; border-radius: 999px; background: var(--branch-color); color: #fff; box-shadow: 0 0 0 3px rgba(255,255,255,.86), 0 0 0 4px rgba(7,27,34,.08); }
.branch-picker-mark:empty::before { content: ""; width: 9px; height: 9px; border-radius: 50%; background: #fff; opacity: .95; }
.branch-picker-mark svg { width: 14px; }
.field-hint { display: block; margin-top: 5px; color: var(--muted); font-size: 9px; }
.field-hint.danger { color: var(--danger); }
.branch-mini { --branch-color: var(--green-2); display: inline-flex; align-items: center; gap: 4px; width: fit-content; margin-right: 4px; padding: 2px 6px; border-radius: 999px; background: color-mix(in srgb,var(--branch-color) 12%,#fff); color: var(--branch-color); font-size: 9px; font-weight: 700; }
.branch-mini::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--branch-color); }
.chart-wrap { height: 215px; display: flex; align-items: flex-end; gap: 10px; padding-top: 18px; border-bottom: 1px solid var(--line); }
.bar-col { flex: 1; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: flex-end; gap: 8px; }
.bar { width: min(30px, 68%); min-height: 8px; border-radius: 8px 8px 3px 3px; background: var(--mint); position: relative; transition: .2s; }
.bar:hover { background: var(--green-2); }
.bar.today { background: var(--orange); }
.bar-val { opacity: 0; position: absolute; top: -25px; left: 50%; transform: translateX(-50%); white-space: nowrap; color: var(--ink); font-size: 10px; }
.bar:hover .bar-val, .bar.today .bar-val { opacity: 1; }
.bar-day { color: var(--muted); font-size: 10px; }
.activity-list { display: grid; gap: 2px; }
.activity-item { display: grid; grid-template-columns: 35px 1fr auto; align-items: center; gap: 10px; padding: 11px 0; border-bottom: 1px solid #f0eee8; }
.activity-item:last-child { border-bottom: 0; }
.activity-icon { width: 35px; height: 35px; display: grid; place-items: center; border-radius: 11px; background: var(--canvas); color: var(--green); }
.activity-icon svg { width: 17px; }
.activity-item b { display: block; font-size: 12px; }
.activity-item p { margin: 2px 0 0; color: var(--muted); font-size: 10px; }
.activity-time { color: var(--muted); font-size: 10px; white-space: nowrap; }

.order-layout { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 22px; align-items: start; }
.section-kicker { margin: 0 0 12px; color: var(--muted); font-size: 12px; font-weight: 600; }
.service-grid { display: grid; grid-template-columns: repeat(3, minmax(160px, 1fr)); gap: 13px; }
.service-card { min-height: 155px; padding: 18px; border: 1px solid var(--line); border-bottom-color: rgba(7,29,37,.42); border-radius: 19px; background: linear-gradient(145deg,#fff 0%,#f9fdfe 55%,#eaf6f8 100%); box-shadow: inset 0 1px #fff, 0 8px 22px rgba(4,55,68,.055); cursor: pointer; text-align: left; transition: .18s ease; }
.service-card:hover { transform: translateY(-3px); border-color: #d5d2c8; box-shadow: 0 14px 30px rgba(37,52,47,.07); }
.service-card-icon { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 15px; margin-bottom: 17px; background: var(--service-soft); color: var(--service-color); }
.service-card-icon svg { width: 25px; }
.service-card b { display: block; font-size: 14px; }
.service-card p { margin: 5px 0 0; color: var(--muted); font-size: 11px; }
.service-card-bottom { display: flex; justify-content: space-between; align-items: center; margin-top: 13px; color: var(--service-color); font-size: 11px; font-weight: 600; }
.service-card-bottom svg { width: 15px; }
.cart-panel { position: sticky; top: 104px; }
.cart-body { padding: 20px; }
.cart-title { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.cart-title h3 { margin: 0; font-size: 16px; }
.order-number { border-radius: 999px; padding: 5px 9px; background: var(--canvas); color: var(--muted); font: 600 10px "Manrope", sans-serif; }
.field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.field { display: grid; gap: 6px; margin-bottom: 11px; }
.field label { color: var(--muted); font-size: 10px; font-weight: 600; }
.input { width: 100%; min-height: 40px; border: 1px solid var(--line); border-radius: 10px; padding: 0 11px; background: #fff; color: var(--ink); }
textarea.input { min-height: 68px; padding-top: 10px; resize: vertical; }
.input::placeholder { color: #b2bab7; }
.cart-items { margin: 16px 0; border-top: 1px dashed var(--line); border-bottom: 1px dashed var(--line); }
.empty-cart { padding: 27px 10px; text-align: center; color: var(--muted); }
.empty-cart svg { width: 33px; margin-bottom: 8px; opacity: .45; }
.empty-cart b { display: block; color: var(--ink); font-size: 12px; }
.empty-cart p { margin: 3px 0 0; font-size: 10px; }
.cart-item { display: grid; grid-template-columns: 1fr auto; gap: 9px; padding: 12px 0; border-bottom: 1px solid #f0eee8; }
.cart-item:last-child { border: 0; }
.cart-item b { display: block; font-size: 12px; }
.cart-item p { margin: 2px 0 0; color: var(--muted); font-size: 10px; }
.cart-item-price { font: 700 12px "Manrope", sans-serif; }
.cart-item-actions { grid-column: 1 / -1; display: flex; align-items: center; justify-content: space-between; }
.mini-stepper { display: flex; align-items: center; gap: 8px; }
.mini-stepper button { width: 24px; height: 24px; border: 1px solid var(--line); border-radius: 7px; background: #fff; cursor: pointer; }
.link-danger { border: 0; padding: 2px; background: transparent; color: var(--danger); font-size: 10px; cursor: pointer; }
.total-row { display: flex; align-items: center; justify-content: space-between; margin: 9px 0; color: var(--muted); font-size: 11px; }
.total-row.grand { margin: 15px 0; color: var(--ink); font-weight: 700; font-size: 14px; }
.total-row.grand strong { color: var(--orange); font: 700 22px "Manrope", sans-serif; }
.payment-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 7px; margin-bottom: 13px; }
.pay-option { min-height: 43px; border: 1px solid var(--line); border-radius: 10px; background: #fff; color: var(--muted); font-size: 10px; cursor: pointer; }
.pay-option.active { border-color: var(--green); background: var(--mint); color: var(--green); font-weight: 600; }

.filter-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.filter-tabs { display: flex; flex-wrap: wrap; gap: 6px; }
.filter-btn { min-height: 35px; border: 1px solid var(--line); border-radius: 10px; padding: 0 12px; background: #fff; color: var(--muted); cursor: pointer; font-size: 11px; }
.filter-btn.active { border-color: var(--green); background: var(--green); color: #fff; }
.filter-count { min-width: 20px; height: 20px; display: inline-grid; place-items: center; margin-left: 5px; padding: 0 5px; border-radius: 999px; background: var(--canvas); color: var(--ink); font: 700 9px "Manrope",sans-serif; }
.filter-btn.active .filter-count { background: rgba(255,255,255,.16); color: #fff; }
.search { min-width: 250px; position: relative; }
.search svg { position: absolute; left: 12px; top: 50%; width: 16px; transform: translateY(-50%); color: var(--muted); }
.search .input { padding-left: 38px; }
.order-list { display: grid; gap: 10px; }
.order-row { display: grid; grid-template-columns: 90px minmax(170px, 1.2fr) minmax(150px, 1fr) 100px 82px 145px 34px 34px; align-items: center; gap: 12px; padding: 15px 17px; border: 1px solid var(--line); border-bottom-color: rgba(7,27,34,.38); border-radius: 16px; background: linear-gradient(145deg,#fff,#f5fbfc); box-shadow: inset 0 1px #fff, 0 6px 18px rgba(4,52,64,.045); }
.order-row:hover { border-color: #d5d2c9; }
.order-code { font: 700 12px "Manrope", sans-serif; }
.order-main b, .order-service b { display: block; font-size: 12px; }
.order-main small, .order-service small { color: var(--muted); font-size: 10px; }
.order-total { font: 700 13px "Manrope", sans-serif; }
.status { width: fit-content; display: inline-flex; align-items: center; gap: 6px; padding: 6px 9px; border: 0; border-radius: 999px; font-size: 10px; font-weight: 600; white-space: nowrap; cursor: pointer; }
.status::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.status-received { background: #edf0f8; color: #6573a2; }
.status-washing { background: #e6f2f7; color: #3e83a1; }
.status-drying { background: #fff2df; color: #b67419; }
.status-ready { background: #e3f3e9; color: #398256; }
.status-picked_up { background: #f0f0ed; color: #81817b; }
.payment-status { width: fit-content; display: inline-flex; align-items: center; gap: 6px; padding: 7px 10px; border-radius: 999px; font-size: 9px; font-weight: 600; white-space: nowrap; }
.payment-status::before { content: ""; width: 7px; height: 7px; flex: none; border-radius: 50%; background: currentColor; box-shadow: 0 0 0 3px color-mix(in srgb,currentColor 14%,transparent); }
.payment-cash { color: #08778c; background: #ddf2f5; }.payment-transfer { color: #264f60; background: #e3edf1; }.payment-unpaid { color: #927022; background: #f8f0d9; }
.print-row-btn, .more-btn { width: 32px; height: 32px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 9px; background: #fff; cursor: pointer; }
.print-row-btn { border-color: #f2d5c7; background: var(--orange-soft); color: var(--orange); }.print-row-btn:hover { background: #ffe4d7; }.print-row-btn svg, .more-btn svg { width: 16px; }
.workflow-line { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 5px 0 13px; padding: 10px 12px; border-radius: 10px; background: var(--canvas); color: var(--muted); font-size: 10px; }.workflow-line b { color: var(--ink); font-size: 11px; }
.old-debt-alert { grid-column: 1 / -1; display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 2px 12px; margin-top: 2px; padding: 10px 12px; border: 1px solid #f2c8c4; border-left: 4px solid var(--danger); border-radius: 10px; background: #fff5f4; color: var(--danger); }
.old-debt-alert span { font-size: 10px; font-weight: 600; }.old-debt-alert b { font: 700 13px "Manrope","IBM Plex Sans Thai",sans-serif; }.old-debt-alert small { grid-column: 1 / -1; color: #b8645c; font-size: 9px; }
.orders-summary { margin-top: 18px; padding: 20px; border: 1px solid #cbded8; border-radius: 19px; background: linear-gradient(135deg,#f5fbf8,#fff); box-shadow: 0 12px 30px rgba(31,67,57,.05); }
.orders-summary-title { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding-bottom: 15px; border-bottom: 1px solid #dfeae6; }
.orders-summary-title span { display: block; font-size: 13px; font-weight: 700; }.orders-summary-title small { display: block; margin-top: 2px; color: var(--muted); font-size: 9px; }.orders-summary-title .btn:disabled { opacity: .45; cursor: not-allowed; }
.orders-summary-metrics { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; padding-top: 15px; }
.orders-summary-metrics > div { padding: 12px 14px; border-radius: 12px; background: #fff; }.orders-summary-metrics span { display: block; color: var(--muted); font-size: 9px; }.orders-summary-metrics strong { display: block; margin-top: 5px; font: 700 16px "Manrope","IBM Plex Sans Thai",sans-serif; }.summary-paid { color: var(--green-2); }.summary-unpaid { color: var(--danger); }
.summary-print-meta { display: grid; grid-template-columns: auto 1fr; gap: 4px 9px; }.summary-print-meta b { text-align: right; }
.summary-print-list { display: grid; gap: 8px; }.summary-print-list > div { display: grid; grid-template-columns: 1fr auto; gap: 8px; padding-bottom: 7px; border-bottom: 1px dotted #bbb; }.summary-print-list b { display: block; font-size: 9px; }.summary-print-list small { color: #555; font-size: 8px; }.summary-print-list strong { font: 600 9px "Manrope",sans-serif; }

.machine-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.machine-card { padding: 19px; border: 1px solid var(--line); border-radius: 19px; background: #fff; }
.machine-top { display: flex; align-items: flex-start; justify-content: space-between; }
.machine-icon { width: 43px; height: 43px; display: grid; place-items: center; border-radius: 13px; background: var(--canvas); color: var(--green); }
.machine-icon svg { width: 22px; }
.machine-card h3 { margin: 18px 0 2px; font-size: 14px; }
.machine-card > p { margin: 0; color: var(--muted); font-size: 10px; }
.progress { height: 5px; margin: 16px 0 8px; border-radius: 5px; background: var(--canvas); overflow: hidden; }
.progress span { display: block; height: 100%; border-radius: inherit; background: var(--orange); }
.machine-foot { display: flex; align-items: center; justify-content: space-between; color: var(--muted); font-size: 10px; }
.status-idle { background: #e6f3eb; color: #3e865c; }
.status-running { background: #fff2df; color: #b67419; }
.status-maintenance { background: #f9e9e7; color: #b9574e; }

.settings-layout { display: grid; grid-template-columns: 230px minmax(0, 1fr); gap: 18px; align-items: start; }
.settings-menu { padding: 8px; }
.settings-menu button { width: 100%; min-height: 41px; border: 0; border-radius: 10px; padding: 0 11px; background: transparent; color: var(--muted); cursor: pointer; text-align: left; font-size: 12px; }
.settings-menu button.active { background: var(--mint); color: var(--green); font-weight: 600; }
.menu-category { padding: 17px 0; border-bottom: 1px solid var(--line); }
.menu-category:last-child { border-bottom: 0; }
.menu-category-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 11px; }
.category-name { display: flex; align-items: center; gap: 10px; }
.category-dot { width: 9px; height: 9px; border-radius: 50%; }
.category-name b { font-size: 13px; }
.category-name small { display: block; color: var(--muted); font-size: 10px; }
.variant-table { width: 100%; border-collapse: collapse; }
.variant-table td { padding: 9px 8px; border-top: 1px solid #f0eee8; font-size: 11px; }
.variant-table td:nth-child(2) { width: 110px; font-family: "Manrope", sans-serif; font-weight: 600; }
.variant-table td:last-child { width: 120px; text-align: right; }
.text-btn { border: 0; padding: 4px 6px; background: transparent; color: var(--green-2); font-size: 10px; cursor: pointer; }
.text-btn.danger { color: var(--danger); }

.report-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; margin-bottom: 18px; }
.report-card { padding: 20px; border: 1px solid var(--line); border-radius: 19px; background: #fff; }
.report-card p { margin: 0; color: var(--muted); font-size: 11px; }
.report-card strong { display: block; margin: 8px 0 4px; font: 700 25px "Manrope", sans-serif; }
.report-card small { color: var(--green-2); font-size: 10px; }
.popular-list { display: grid; gap: 13px; }
.popular-row { display: grid; grid-template-columns: 26px minmax(120px, 1fr) 2fr 70px; align-items: center; gap: 10px; }
.rank { width: 25px; height: 25px; display: grid; place-items: center; border-radius: 8px; background: var(--canvas); color: var(--muted); font: 700 10px "Manrope", sans-serif; }
.popular-row b { font-size: 11px; }
.popular-track { height: 7px; border-radius: 6px; background: var(--canvas); overflow: hidden; }
.popular-track span { display: block; height: 100%; border-radius: inherit; background: var(--green-2); }
.popular-amount { text-align: right; font: 700 11px "Manrope", sans-serif; }

.period-switch { display: flex; gap: 7px; margin: -4px 0 18px; padding: 5px; width: fit-content; max-width: 100%; overflow-x: auto; scrollbar-width: none; border: 1px solid var(--line); border-radius: 14px; background: #fff; }
.period-switch::-webkit-scrollbar { display: none; }
.report-actions { display: flex; align-items: center; gap: 8px; }
.period-btn { min-width: 76px; height: 36px; border: 0; border-radius: 9px; padding: 0 13px; background: transparent; color: var(--muted); font-size: 11px; cursor: pointer; white-space: nowrap; }
.period-btn:hover { background: var(--canvas); color: var(--ink); }
.period-btn.active { background: var(--green); color: #fff; font-weight: 600; box-shadow: 0 5px 15px rgba(24,79,69,.16); }
.sales-kpi-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 14px; margin-bottom: 17px; }
.sales-kpi { min-height: 132px; display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; padding: 19px; border: 1px solid var(--line); border-bottom-color: rgba(7,27,34,.4); border-radius: 20px; background: linear-gradient(145deg,#fff,#edf8fa); box-shadow: inset 0 1px #fff, 0 8px 22px rgba(3,48,60,.06); overflow: hidden; }
.sales-kpi.primary { background: linear-gradient(145deg,#063b4b,#087f96); color: #fff; border-color: var(--line-dark); box-shadow: inset 0 1px rgba(255,255,255,.28), 0 9px 24px rgba(3,53,67,.2); }
.sales-kpi span { color: var(--muted); font-size: 11px; }.sales-kpi.primary span { color: rgba(255,255,255,.65); }
.sales-kpi strong { display: block; margin: 11px 0 5px; font: 700 24px "Manrope","IBM Plex Sans Thai",sans-serif; }
.sales-kpi small { color: var(--muted); font-size: 9px; }.sales-kpi.primary small { color: rgba(255,255,255,.62); }.sales-kpi small b { color: #78d7ae; }
.sales-kpi-icon { width: 38px; height: 38px; flex: none; display: grid; place-items: center; border-radius: 12px; background: rgba(255,255,255,.12); color: #fff; }
.sales-kpi-icon svg { width: 19px; }.sales-kpi-icon.blue { color: #087f96; background: #e0f3f6; }.sales-kpi-icon.gold { color: #9b7628; background: #f8f1dc; }.sales-kpi-icon.violet { color: #173f4d; background: #e3ecef; }
.sales-main-grid { display: grid; grid-template-columns: minmax(0,1.7fr) minmax(270px,.7fr); gap: 17px; margin-bottom: 17px; }
.sales-chart-panel { min-width: 0; overflow-x: auto; }
.report-live { display: inline-flex; align-items: center; gap: 6px; color: var(--muted); font-size: 9px; white-space: nowrap; }.report-live i { width: 6px; height: 6px; border-radius: 50%; background: #66c59b; }
.sales-chart { min-width: 550px; height: 245px; display: flex; align-items: flex-end; gap: 10px; padding: 30px 4px 0; border-bottom: 1px solid var(--line); }
.sales-bar-col { flex: 1; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: flex-end; gap: 7px; }
.sales-bar { width: min(34px,72%); min-height: 8px; border-radius: 8px 8px 3px 3px; background: linear-gradient(100deg,rgba(255,255,255,.42),transparent 38%),linear-gradient(180deg,#087f96,#9dcbd4); box-shadow: inset 0 0 0 1px rgba(4,29,37,.24); transition: .2s; }.sales-bar.peak { background: linear-gradient(100deg,rgba(255,255,255,.48),transparent 38%),linear-gradient(180deg,#c6a34d,#ead68f); }
.sales-bar-value { color: var(--muted); font: 600 9px "Manrope",sans-serif; white-space: nowrap; }.sales-bar-col small { color: var(--muted); font-size: 9px; white-space: nowrap; }
.branch-chart-legend { display: flex; flex-wrap: wrap; gap: 8px; margin: -4px 0 8px; }
.branch-chart-legend span { display: inline-flex; align-items: center; gap: 6px; color: var(--muted); font-size: 10px; font-weight: 600; }
.branch-chart-legend i { width: 9px; height: 9px; border-radius: 50%; }
.branch-sales-chart { align-items: stretch; gap: 12px; }
.branch-sales-col { flex: 1; min-width: 58px; height: 100%; display: flex; flex-direction: column; justify-content: flex-end; align-items: center; gap: 7px; }
.branch-bars { width: 100%; height: 100%; display: flex; align-items: flex-end; justify-content: center; gap: 4px; }
.branch-color-bar { width: min(18px,32%); background: linear-gradient(100deg,rgba(255,255,255,.45),transparent 38%),linear-gradient(180deg,var(--bar-color),color-mix(in srgb,var(--bar-color) 45%,#fff)); }
.branch-color-bar.peak { outline: 2px solid rgba(198,163,77,.42); }
.branch-bars .bar-val { top: -22px; font-size: 8px; }
.branch-sales-col small { color: var(--muted); font-size: 9px; white-space: nowrap; }
.payment-panel { display: flex; flex-direction: column; }
.payment-donut { width: 148px; height: 148px; display: grid; place-items: center; margin: 3px auto 19px; border-radius: 50%; background: conic-gradient(var(--green) 0 calc(var(--cash)*1%),var(--orange) calc(var(--cash)*1%) calc(var(--transfer)*1%),#ddd9d0 calc(var(--transfer)*1%) 100%); position: relative; }
.payment-donut::after { content: ""; position: absolute; inset: 24px; border-radius: 50%; background: #fff; }.payment-donut > div { position: relative; z-index: 1; text-align: center; }.payment-donut strong { display: block; font: 700 16px "Manrope",sans-serif; }.payment-donut small { color: var(--muted); font-size: 9px; }
.payment-legend { display: grid; gap: 9px; }.payment-legend > div { display: grid; grid-template-columns: 8px 1fr auto; align-items: center; gap: 8px; font-size: 10px; }.payment-legend span { color: var(--muted); }.payment-legend i { width: 7px; height: 7px; border-radius: 50%; }.dot-cash { background: var(--green); }.dot-transfer { background: var(--orange); }.dot-unpaid { background: #ddd9d0; }
.sales-bottom-grid { display: grid; grid-template-columns: minmax(0,1.25fr) minmax(300px,.85fr); gap: 17px; }
.service-sales-list { display: grid; gap: 15px; }.service-sale-row { display: grid; grid-template-columns: 27px minmax(130px,1fr) 75px; align-items: center; gap: 11px; }.service-sale-row b { font-size: 11px; }.service-sale-row > strong { text-align: right; font: 700 11px "Manrope",sans-serif; }
.service-sale-track { height: 6px; margin-top: 6px; border-radius: 6px; background: var(--canvas); overflow: hidden; }.service-sale-track i { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg,var(--green-2),#8cc5b7); }
.other-report-list { display: grid; gap: 4px; }.other-report-list > div { display: grid; grid-template-columns: 38px 1fr auto; align-items: center; gap: 10px; padding: 10px 0; border-bottom: 1px solid #f0eee8; }.other-report-list > div:last-child { border-bottom: 0; }.other-report-list b { display: block; font-size: 10px; }.other-report-list small { color: var(--muted); font-size: 8px; }.other-report-list > div > strong { font: 700 11px "Manrope",sans-serif; white-space: nowrap; }
.other-icon { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 11px; }.other-icon svg { width: 17px; }.other-icon.green { color: var(--green); background: var(--mint); }.other-icon.orange { color: var(--orange); background: var(--orange-soft); }.other-icon.blue { color: #087f96; background: #e0f3f6; }

.sales-print-sheet { width: 190mm; min-height: 270mm; padding: 8mm; background: #fff; color: #17211e; font-family: "IBM Plex Sans Thai",sans-serif; }
.sales-print-sheet > header { display: flex; align-items: center; justify-content: space-between; padding-bottom: 5mm; border-bottom: 1px solid #ccd4d1; }
.sales-print-brand { display: flex; align-items: center; gap: 3mm; }.sales-print-brand > span { width: 12mm; height: 12mm; display: grid; place-items: center; border-radius: 3mm; background: var(--green); color: #fff; }.sales-print-brand svg { width: 8mm; }.sales-print-brand h1 { margin: 0; font: 700 18pt "Manrope",sans-serif; }.sales-print-brand p { margin: 0; color: #64736e; font-size: 8pt; }
.sales-print-date { text-align: right; color: #64736e; font-size: 7.5pt; }.sales-print-date b { color: #17211e; }
.sales-print-heading { padding: 6mm 0 4mm; }.sales-print-heading h2 { margin: 0; font-size: 17pt; }.sales-print-heading p { margin: 1mm 0 0; color: #64736e; font-size: 8pt; }
.sales-print-kpis { display: grid; grid-template-columns: repeat(4,1fr); gap: 3mm; }.sales-print-kpis > div { padding: 4mm; border: 1px solid #dce3e0; border-radius: 3mm; background: #f7faf8; }.sales-print-kpis span { display: block; color: #64736e; font-size: 7.5pt; }.sales-print-kpis strong { display: block; margin-top: 2mm; font-size: 14pt; }
.sales-print-section { margin-top: 5mm; padding: 5mm; border: 1px solid #dce3e0; border-radius: 3mm; }.sales-print-section h3 { margin: 0 0 4mm; font-size: 11pt; }
.sales-print-chart { height: 52mm; display: flex; align-items: flex-end; gap: 2.5mm; padding-top: 7mm; border-bottom: 1px solid #adb8b4; }.sales-print-chart > div { flex: 1; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: flex-end; gap: 1.5mm; }.sales-print-chart span { font-size: 6pt; }.sales-print-chart i { width: 60%; min-height: 2mm; border-radius: 1.5mm 1.5mm 0 0; background: linear-gradient(#2c7364,#a9cec5); }.sales-print-chart small { font-size: 6.5pt; white-space: nowrap; }
.sales-print-columns { display: grid; grid-template-columns: .8fr 1.2fr; gap: 4mm; }.sales-print-columns .sales-print-section { margin-top: 4mm; }
.sales-print-sheet table { width: 100%; border-collapse: collapse; }.sales-print-sheet td { padding: 2mm 0; border-bottom: 1px solid #edf0ef; font-size: 8pt; }.sales-print-sheet td:last-child { text-align: right; font-weight: 600; }
.sales-print-sheet footer { margin-top: 6mm; padding-top: 3mm; border-top: 1px solid #ccd4d1; text-align: center; color: #64736e; font-size: 7pt; }

.customer-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 13px; }
.customer-card { padding: 18px; border: 1px solid var(--line); border-radius: 18px; background: #fff; }
.customer-card-top { display: flex; align-items: center; gap: 11px; }
.customer-card h3 { margin: 0; font-size: 13px; }
.customer-card p { margin: 2px 0 0; color: var(--muted); font-size: 10px; }
.customer-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 15px; }
.customer-stat { padding: 9px; border-radius: 10px; background: var(--canvas); }
.customer-stat small { display: block; color: var(--muted); font-size: 9px; }
.customer-stat b { font: 700 11px "Manrope", "IBM Plex Sans Thai", sans-serif; }

.modal-backdrop { position: fixed; inset: 0; z-index: 100; display: grid; place-items: center; padding: 20px; background: rgba(18,33,29,.48); backdrop-filter: blur(4px); animation: fadeIn .15s ease; }
.modal { width: min(540px, 100%); max-height: min(760px, calc(100vh - 34px)); overflow: auto; border-radius: 24px; background: #fff; box-shadow: 0 24px 80px rgba(0,0,0,.2); animation: modalIn .2s ease; }
.modal-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 22px 22px 15px; }
.modal-head h2 { margin: 0; font-size: 18px; }
.modal-head p { margin: 4px 0 0; color: var(--muted); font-size: 11px; }
.modal-close { width: 35px; height: 35px; border: 1px solid var(--line); border-radius: 10px; background: #fff; cursor: pointer; font-size: 20px; }
.modal-body { padding: 0 22px 22px; }
.variant-option { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 10px; padding: 14px; border: 1px solid var(--line); border-radius: 14px; margin-bottom: 9px; cursor: pointer; transition: .15s; }
.variant-option:hover { border-color: #c9c6bc; }
.variant-option.selected { border-color: var(--green); background: #f5faf8; box-shadow: inset 3px 0 var(--green); }
.variant-option b { display: block; font-size: 13px; }
.variant-option p { margin: 2px 0 0; color: var(--muted); font-size: 10px; }
.variant-price { color: var(--orange); font: 700 16px "Manrope", sans-serif; }
.modal-quantity { display: flex; align-items: center; justify-content: space-between; margin: 17px 0; padding: 14px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.modal-quantity b { display: block; font-size: 12px; }
.modal-quantity small { color: var(--muted); font-size: 10px; }
.stepper { display: flex; align-items: center; gap: 13px; }
.stepper button { width: 34px; height: 34px; border: 1px solid var(--line); border-radius: 10px; background: #fff; cursor: pointer; font-size: 17px; }
.stepper span { min-width: 22px; text-align: center; font: 700 15px "Manrope", sans-serif; }
.modal-total { display: flex; align-items: center; justify-content: space-between; margin-bottom: 15px; }
.modal-total span { color: var(--muted); font-size: 11px; }
.modal-total strong { font: 700 22px "Manrope", sans-serif; color: var(--orange); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; }
.color-options { display: flex; gap: 9px; }
.color-radio { width: 30px; height: 30px; border: 3px solid #fff; border-radius: 50%; box-shadow: 0 0 0 1px var(--line); cursor: pointer; }
.color-radio.selected { box-shadow: 0 0 0 2px var(--ink); }

.toast { position: fixed; right: 24px; bottom: 24px; z-index: 150; min-width: 280px; max-width: 360px; padding: 14px 16px; display: flex; align-items: center; gap: 11px; border-radius: 14px; background: var(--green); color: #fff; box-shadow: 0 18px 40px rgba(18,50,42,.25); animation: toastIn .25s ease; }
.toast svg { width: 21px; color: #8ee0bb; }
.toast b { display: block; font-size: 12px; }
.toast p { margin: 2px 0 0; color: rgba(255,255,255,.65); font-size: 10px; }
.modal-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }

.printer-settings { display: grid; gap: 18px; }
.setting-section { padding: 19px; border: 1px solid var(--line); border-radius: 17px; background: #fff; }
.setting-title { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 15px; }
.setting-title h3, .setting-toggle h3 { margin: 0; font-size: 14px; }
.setting-title p, .setting-toggle p { margin: 3px 0 0; color: var(--muted); font-size: 10px; }
.printer-badge { padding: 5px 8px; border-radius: 7px; background: var(--canvas); color: var(--muted); font: 700 9px "Manrope", sans-serif; }
.paper-options, .connection-options { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.paper-option, .connection-option { min-height: 78px; display: flex; align-items: center; gap: 12px; border: 1px solid var(--line); border-radius: 13px; padding: 12px; background: #fff; cursor: pointer; text-align: left; }
.paper-option:hover, .connection-option:hover { border-color: #c7c4bb; }
.paper-option.selected, .connection-option.selected { border-color: var(--green); background: #f5faf8; box-shadow: inset 3px 0 var(--green); }
.paper-option > svg { width: 18px; margin-left: auto; color: var(--green); }
.paper-option b, .connection-option b { display: block; font-size: 12px; }
.paper-option small, .connection-option small { display: block; margin-top: 2px; color: var(--muted); font-size: 9px; }
.paper-roll { height: 47px; display: grid; place-items: center; border: 1px solid #d8d5cd; border-radius: 5px 5px 10px 10px; background: linear-gradient(90deg,#f0eee8,#fff 50%,#eceae4); color: var(--muted); font: 700 9px "Manrope",sans-serif; box-shadow: 0 5px 9px rgba(0,0,0,.05); }
.paper-58 { width: 35px; }.paper-80 { width: 45px; }
.connection-icon { width: 43px; height: 43px; display: grid; place-items: center; border-radius: 12px; background: var(--mint); color: var(--green); font: 700 10px "Manrope",sans-serif; }
.connection-state { padding: 6px 9px; border-radius: 999px; background: #f1f0ec; color: var(--muted); font-size: 9px; font-weight: 600; }
.connection-state.connected { background: #e3f3e9; color: #398256; }
.device-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 14px; padding: 13px; border-radius: 12px; background: var(--canvas); }
.device-row small { display: block; color: var(--muted); font-size: 9px; }.device-row b { font-size: 11px; }
.setting-note { margin: 12px 0 0; color: var(--muted); font-size: 9px; line-height: 1.6; }
.setting-toggle { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.toggle { width: 48px; height: 27px; flex: none; border: 0; border-radius: 999px; padding: 3px; background: #d8d8d3; cursor: pointer; transition: .2s; }
.toggle span { display: block; width: 21px; height: 21px; border-radius: 50%; background: #fff; box-shadow: 0 2px 5px rgba(0,0,0,.15); transition: .2s; }
.toggle.on { background: var(--green); }.toggle.on span { transform: translateX(21px); }
.receipt-field-checks { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 8px; margin-top: 13px; }
.receipt-field-checks label { display: flex; align-items: center; gap: 7px; padding: 9px 10px; border: 1px solid var(--line); border-radius: 10px; color: var(--muted); font-size: 9px; cursor: pointer; }
.receipt-field-checks input, .settings-checks input { accent-color: var(--green); }
.receipt-field-list { display: grid; gap: 8px; }
.receipt-field-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 11px 12px; border: 1px solid var(--line); border-radius: 11px; background: var(--canvas); }
.receipt-field-row b { display: block; font-size: 11px; }.receipt-field-row small { display: block; margin-top: 2px; color: var(--muted); font-size: 9px; }
.receipt-field-empty { padding: 16px; border: 1px dashed var(--line); border-radius: 11px; color: var(--muted); text-align: center; font-size: 10px; }
.qr-setting-preview { min-height: 132px; display: flex; align-items: center; gap: 18px; margin-top: 14px; padding: 14px; border: 1px solid var(--line); border-radius: 14px; background: linear-gradient(145deg,#fff,var(--canvas)); }
.qr-setting-preview b { display: block; font-size: 12px; }.qr-setting-preview small { display: block; max-width: 390px; margin-top: 4px; color: var(--muted); font-size: 9px; line-height: 1.55; }
.qr-preview-code, .qr-setting-preview .qr-image { width: 104px; height: 104px; flex: none; object-fit: contain; padding: 5px; background: #fff; border: 1px solid var(--line); }
.qr-upload-row { display: flex; align-items: center; gap: 10px; margin-top: 12px; color: var(--muted); font-size: 9px; }
.qr-empty { width: 104px; height: 104px; flex: none; display: grid; place-items: center; padding: 10px; border: 1px dashed var(--line); background: #fff; color: var(--muted); text-align: center; font-size: 8px; }
.receipt-preview-mini { display: flex; align-items: center; justify-content: space-between; min-height: 160px; padding: 20px; border-radius: 17px; background: var(--canvas); overflow: hidden; }
.receipt-preview-mini small { display: block; color: var(--muted); font-size: 9px; }.receipt-preview-mini b { font-size: 13px; }
.mini-paper { min-height: 130px; display: flex; flex-direction: column; align-items: center; gap: 7px; padding: 15px 10px; background: #fff; box-shadow: 0 10px 30px rgba(0,0,0,.09); color: #222; font-family: monospace; font-size: 8px; transition: width .2s; }
.mini-paper strong { font-size: 11px; }.mini-paper i { width: 100%; border-top: 1px dashed #aaa; }
.mini-paper .mini-qr { width: 58px; height: 58px; margin-top: 3px; }

.receipt-modal { width: min(620px,100%); }
.receipt-backdrop { align-items: start; overflow-y: auto; }
.receipt-stage { display: grid; place-items: center; padding: 24px; background: #e9e7e1; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.receipt-paper { width: var(--paper-mm); max-width: 100%; padding: 8mm 5mm 7mm; background: #fff; color: #141414; box-shadow: 0 12px 35px rgba(0,0,0,.14); font-family: "IBM Plex Sans Thai",sans-serif; font-size: 10px; }
.receipt-brand { text-align: center; }.receipt-logo { width: 36px; height: 36px; display: grid; place-items: center; margin: 0 auto 5px; border: 1.5px solid #111; border-radius: 50%; }.receipt-logo svg { width: 23px; }
.receipt-brand h2 { margin: 0; font: 700 18px "Manrope",sans-serif; letter-spacing: .5px; }.receipt-brand p { margin: 2px 0 0; font-size: 9px; }
.receipt-dash { margin: 12px 0; border-top: 1px dashed #777; }
.receipt-meta { display: grid; grid-template-columns: auto 1fr; gap: 4px 10px; }.receipt-meta b { text-align: right; font-weight: 600; }
.receipt-lines { display: grid; gap: 9px; }.receipt-line { display: grid; grid-template-columns: 1fr auto; gap: 8px; }.receipt-line b { display: block; font-size: 10px; }.receipt-line small { display: block; color: #555; }.receipt-line > span { font: 600 10px "Manrope",sans-serif; }
.receipt-sum { display: grid; grid-template-columns: 1fr auto; gap: 5px; }.receipt-sum > :nth-child(even) { text-align: right; }.receipt-sum strong { margin-top: 4px; font-size: 13px; }
.receipt-payment { margin-top: 11px; padding: 7px; border: 1px solid #bbb; text-align: center; font-weight: 600; }
.receipt-qr { display: flex; flex-direction: column; align-items: center; margin-top: 12px; padding-top: 11px; border-top: 1px dashed #777; text-align: center; }
.receipt-qr-code, .receipt-qr .qr-image { width: min(38mm,85%); height: auto; aspect-ratio: 1; object-fit: contain; background: #fff; }
.receipt-qr b { margin-top: 4px; font-size: 10px; }.receipt-qr span { font-weight: 700; font-size: 11px; }.receipt-qr small { margin-top: 2px; color: #555; font-size: 7px; }
.receipt-footer { margin-top: 18px; text-align: center; }.receipt-footer b { font-size: 11px; }.receipt-footer p { margin: 3px 0 7px; font-size: 8px; }.receipt-footer small { color: #666; font-size: 7px; }
.receipt-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; padding: 17px 22px 9px; }.receipt-done { display: block; margin: 0 auto 14px; }
#print-host { display: none; }
.mobile-nav { display: none; }
.empty-state { padding: 55px 20px; text-align: center; color: var(--muted); }
.empty-state svg { width: 42px; opacity: .4; }
.empty-state h3 { margin: 9px 0 2px; color: var(--ink); font-size: 14px; }
.empty-state p { margin: 0; font-size: 11px; }

.login-shell { min-height: 100vh; display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(360px, .8fr); gap: 30px; align-items: center; padding: 42px; background: radial-gradient(circle at top right,#fff 0,#e2f4f7 38%,#062f3c 100%); }
.login-hero { color: #fff; padding: 24px; }
.login-brand { padding: 0 0 26px; color: #fff; }
.login-hero h1 { max-width: 760px; margin: 0; font-size: clamp(30px,5vw,58px); line-height: 1.05; letter-spacing: -.06em; }
.login-hero > p { max-width: 650px; margin: 18px 0 24px; color: rgba(255,255,255,.74); font-size: 15px; line-height: 1.8; }
.login-card { width: min(430px,100%); justify-self: end; padding: 24px; border: 1px solid rgba(198,163,77,.55); border-radius: 26px; background: linear-gradient(145deg,#fff,#edf8fa); box-shadow: 0 28px 80px rgba(0,0,0,.22), inset 0 1px #fff; }
.login-card-head h2 { margin: 0; font-size: 22px; }
.login-card-head p { margin: 4px 0 18px; color: var(--muted); font-size: 12px; }
.demo-logins { display: grid; gap: 7px; margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--line); }
.login-note { margin: 14px 0 0; color: var(--muted); font-size: 10px; line-height: 1.7; }
.profile-account { margin: 0 6px 7px; padding: 10px; border-radius: 11px; background: var(--canvas); }
.profile-account b { display: block; font-size: 11px; }
.profile-account small { color: var(--muted); font-size: 9px; }
.logout-option { color: var(--danger); }

.pricing-grid { display: grid; grid-template-columns: repeat(5,minmax(130px,1fr)); gap: 10px; }
.pricing-grid.compact { grid-template-columns: repeat(5,minmax(120px,1fr)); }
.pricing-card { min-height: 150px; display: flex; flex-direction: column; justify-content: space-between; gap: 9px; padding: 15px; border: 1px solid rgba(216,201,153,.85); border-radius: 17px; background: linear-gradient(145deg,#fff,#eff8fa); color: var(--ink); box-shadow: inset 0 1px #fff; }
.login-hero .pricing-card { background: rgba(255,255,255,.92); }
.pricing-card.selected { border-color: var(--gold); box-shadow: inset 0 0 0 2px rgba(198,163,77,.22), 0 10px 28px rgba(0,0,0,.08); }
.pricing-card span { color: var(--muted); font-size: 10px; font-weight: 700; }
.pricing-card strong { display: block; margin-top: 4px; font: 700 23px "Manrope","IBM Plex Sans Thai",sans-serif; color: var(--green); }
.pricing-card small { display: block; color: var(--muted); font-size: 9px; }
.pricing-card p { margin: 0; color: var(--muted); font-size: 10px; line-height: 1.45; }
.pricing-card em { width: fit-content; padding: 6px 8px; border-radius: 999px; background: var(--mint); color: var(--green); font-size: 9px; font-style: normal; font-weight: 700; }
.pricing-card .trial-rule { margin-top: -3px; color: #5c6f75; line-height: 1.55; }
.trial-plan { background: linear-gradient(145deg,#062f3c,#087f96); color: #fff; border-color: var(--line-dark); }
.trial-plan span, .trial-plan small, .trial-plan p { color: rgba(255,255,255,.7); }
.trial-plan strong { color: #fff; }
.trial-plan .trial-rule { color: rgba(255,255,255,.78); }

.branch-page { max-width: 1680px; }
.branch-grid { display: grid; grid-template-columns: repeat(3,minmax(250px,1fr)); gap: 14px; margin: 18px 0; }
.branch-card { padding: 18px; border: 1px solid var(--line); border-bottom-color: rgba(8,31,39,.38); border-radius: 21px; background: linear-gradient(145deg,#fff,#edf8fa); box-shadow: inset 0 1px #fff,0 10px 24px rgba(3,49,61,.055); }
.branch-card.current { border-color: var(--gold); box-shadow: inset 0 0 0 2px rgba(198,163,77,.18),0 12px 30px rgba(3,49,61,.08); }
.branch-card-head { display: flex; justify-content: space-between; gap: 12px; }
.branch-code { color: var(--gold); font: 700 10px "Manrope",sans-serif; }
.branch-card h3 { margin: 3px 0; font-size: 15px; }
.branch-card p { margin: 0; color: var(--muted); font-size: 10px; }
.branch-live { height: fit-content; padding: 5px 8px; border-radius: 999px; font-size: 9px; font-weight: 700; }
.branch-live.online { color: #08778c; background: #ddf2f5; }
.branch-live.offline { color: var(--danger); background: #fff0ef; }
.branch-money { margin: 20px 0 14px; font: 700 30px "Manrope","IBM Plex Sans Thai",sans-serif; color: var(--green); }
.branch-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.branch-stats div { padding: 9px; border-radius: 11px; background: rgba(255,255,255,.72); border: 1px solid rgba(216,201,153,.55); }
.branch-stats span { display: block; color: var(--muted); font-size: 9px; }
.branch-stats b { display: block; margin-top: 3px; font: 700 11px "Manrope","IBM Plex Sans Thai",sans-serif; }
.license-strip { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 14px; padding: 11px; border-radius: 13px; border: 1px solid #dfe9eb; background: #fff; }
.license-strip b { display: block; font-size: 11px; }
.license-strip small { display: block; color: var(--muted); font-size: 8px; }
.license-strip.trial { border-color: #bedfe5; background: #effbfc; }
.license-strip.warning { border-color: #ead491; background: #fff9e8; }
.license-strip.expired { border-color: #f2c8c4; background: #fff5f4; }
.branch-card-actions { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 4px; }
.branch-summary-list { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 9px; margin-top: 14px; padding-top: 14px; border-top: 1px solid #dfeae6; }
.branch-summary-list > div { padding: 10px; border: 1px solid var(--line); border-radius: 12px; background: #fff; }
.branch-summary-list span { display: flex; align-items: center; gap: 6px; color: var(--muted); font-size: 9px; font-weight: 700; }
.branch-summary-list i { width: 8px; height: 8px; border-radius: 50%; }
.branch-summary-list b { display: block; margin-top: 5px; font: 700 13px "Manrope","IBM Plex Sans Thai",sans-serif; }
.branch-summary-list small { color: var(--muted); font-size: 9px; }
.branch-detail-modal { width: min(720px,100%); }
.branch-detail-top { display: flex; align-items: stretch; justify-content: space-between; gap: 10px; margin-bottom: 13px; }
.branch-detail-top .license-strip { flex: 1; margin: 0; }
.branch-detail-metrics { display: grid; grid-template-columns: repeat(4,1fr); gap: 9px; margin-bottom: 14px; }
.branch-detail-metrics > div { padding: 12px; border: 1px solid var(--line); border-radius: 13px; background: linear-gradient(145deg,#fff,#f2fafb); }
.branch-detail-metrics span { display: block; color: var(--muted); font-size: 9px; }
.branch-detail-metrics b { display: block; margin-top: 5px; font: 700 15px "Manrope","IBM Plex Sans Thai",sans-serif; }
.branch-detail-head { margin-top: 8px; }
.branch-picker-modal { width: min(680px,100%); }
.branch-picker-search { margin-bottom: 12px; }
.branch-picker-list { display: grid; gap: 9px; max-height: min(440px,52vh); overflow: auto; padding-right: 2px; }
.branch-picker-row { width: 100%; display: grid; grid-template-columns: 30px minmax(0,1fr) auto; align-items: center; gap: 11px; padding: 12px; border: 1px solid var(--line); border-radius: 15px; background: linear-gradient(145deg,#fff,#f7fbfc); color: var(--ink); text-align: left; cursor: pointer; transition: .15s ease; }
.branch-picker-row:hover { transform: translateY(-1px); border-color: rgba(198,163,77,.6); box-shadow: 0 8px 22px rgba(3,53,67,.08); }
.branch-picker-row.active { border-color: var(--green); background: linear-gradient(145deg,#eaf8fa,#fff); box-shadow: inset 3px 0 var(--gold); }
.branch-picker-row b { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 13px; }
.branch-picker-row small { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-top: 2px; color: var(--muted); font-size: 10px; }
.branch-picker-row em { justify-self: end; padding: 5px 8px; border-radius: 999px; background: var(--canvas); color: var(--muted); font-size: 9px; font-style: normal; font-weight: 800; white-space: nowrap; }
.branch-picker-row.active em { background: var(--green); color: #fff; }
.branch-dot { width: 16px; height: 16px; border-radius: 999px; background: var(--branch-color,var(--green-2)); box-shadow: 0 0 0 4px color-mix(in srgb,var(--branch-color,var(--green-2)) 14%,#fff); }
.branch-dot.all { width: 28px; height: 28px; display: grid; place-items: center; background: var(--green); color: #fff; box-shadow: 0 0 0 4px rgba(8,127,150,.12); }
.branch-dot.all svg { width: 15px; }

.reports-split, .developer-grid { display: grid; grid-template-columns: minmax(0,1fr) minmax(340px,.9fr); gap: 17px; }
.branch-report-list, .license-list, .recommend-list { display: grid; gap: 10px; }
.branch-report-row { display: grid; grid-template-columns: 32px minmax(0,1fr) 95px 70px; align-items: center; gap: 10px; padding-bottom: 11px; border-bottom: 1px solid #eef1f1; }
.branch-report-row:last-child { border-bottom: 0; }
.branch-report-row b, .license-row b, .recommend-list b { display: block; font-size: 11px; }
.branch-report-row small, .license-row small, .recommend-list span { display: block; color: var(--muted); font-size: 9px; margin-top: 2px; }
.branch-report-row strong { text-align: right; font: 700 12px "Manrope",sans-serif; }

.settings-form { display: grid; gap: 14px; }
.settings-checks { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 14px; }
.settings-checks label { display: inline-flex; align-items: center; gap: 7px; padding: 9px 10px; border: 1px solid var(--line); border-radius: 11px; background: #fff; font-size: 11px; }
.account-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; }
.account-card { padding: 14px; border: 1px solid var(--line); border-radius: 15px; background: linear-gradient(145deg,#fff,#f3fafb); }
.account-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; margin-bottom: 10px; }
.account-card-head b { display: block; font-size: 12px; }
.account-card-head small { color: var(--muted); font-size: 9px; }
.notification-list { display: grid; gap: 9px; margin-bottom: 14px; }
.notification-list label { display: grid; grid-template-columns: 20px 1fr; gap: 10px; align-items: start; padding: 12px; border: 1px solid var(--line); border-radius: 13px; background: #fff; }
.notification-list b { display: block; font-size: 12px; }
.notification-list small { color: var(--muted); font-size: 9px; }
.license-settings { display: grid; gap: 16px; }
.license-branch-list { display: grid; gap: 9px; }
.license-branch-row { display: grid; grid-template-columns: minmax(0,1fr) auto; align-items: center; gap: 12px; padding: 12px; border: 1px solid var(--line); border-radius: 14px; background: #fff; }
.license-branch-row b { display: block; font-size: 12px; }
.license-branch-row small { display: block; color: var(--muted); font-size: 9px; }
.license-actions { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 6px; }
.license-row { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; padding: 12px; border: 1px solid var(--line); border-radius: 14px; background: #fff; }
.license-row code { display: block; width: fit-content; max-width: 100%; margin-top: 7px; padding: 5px 7px; border-radius: 7px; background: var(--canvas); color: var(--green); font: 700 10px "Manrope",monospace; overflow-wrap: anywhere; }
.recommend-list div { padding: 13px; border: 1px solid var(--line); border-radius: 13px; background: linear-gradient(145deg,#fff,#f4fbfc); }

@keyframes fadeIn { from { opacity: 0; } }
@keyframes modalIn { from { opacity: 0; transform: translateY(10px) scale(.98); } }
@keyframes toastIn { from { opacity: 0; transform: translateY(12px); } }

@media (max-width: 1180px) {
  .stat-grid { grid-template-columns: repeat(2, 1fr); }
  .sales-kpi-grid { grid-template-columns: repeat(2,1fr); }
  .pricing-grid, .pricing-grid.compact { grid-template-columns: repeat(3,1fr); }
  .branch-grid { grid-template-columns: repeat(2,1fr); }
  .account-grid, .reports-split, .developer-grid { grid-template-columns: 1fr; }
  .service-grid { grid-template-columns: repeat(2, 1fr); }
  .machine-grid { grid-template-columns: repeat(3, 1fr); }
  .order-row { grid-template-columns: 82px 1.2fr 105px 80px 145px 32px 32px; }
  .order-service { display: none; }
}

@media (max-width: 900px) {
  .login-shell { grid-template-columns: 1fr; padding: 24px; }
  .login-card { justify-self: stretch; width: 100%; }
  .app-shell { display: block; }
  .sidebar { display: none; }
  .main { padding-bottom: 72px; }
  .topbar { height: 72px; padding: 0 20px; }
  .live-pill, .profile-copy { display: none; }
  .content { padding: 22px 20px 32px; }
  .order-layout { grid-template-columns: 1fr; }
  .cart-panel { position: static; }
  .dashboard-grid { grid-template-columns: 1fr; }
  .sales-main-grid, .sales-bottom-grid { grid-template-columns: 1fr; }
  .machine-grid { grid-template-columns: repeat(2, 1fr); }
  .customer-grid { grid-template-columns: repeat(2, 1fr); }
  .settings-layout { grid-template-columns: 1fr; }
  .settings-menu { display: flex; overflow: auto; }
  .settings-menu button { width: auto; white-space: nowrap; }
  .branch-grid { grid-template-columns: 1fr; }
  .mobile-nav { position: fixed; left: 12px; right: 12px; bottom: 10px; z-index: 30; height: 61px; display: flex; justify-content: space-around; padding: 7px; border: 1px solid rgba(255,255,255,.16); border-radius: 18px; background: var(--green); box-shadow: 0 15px 40px rgba(18,50,42,.28); }
  .mobile-nav .nav-btn { width: 58px; min-height: auto; flex-direction: column; justify-content: center; gap: 2px; padding: 0; font-size: 9px; }
  .mobile-nav .nav-btn.active::before { display: none; }
}

@media (max-width: 620px) {
  .login-shell { padding: 14px; align-items: start; }
  .login-hero { padding: 10px 4px; }
  .login-hero h1 { font-size: 30px; }
  .pricing-grid, .pricing-grid.compact { grid-template-columns: 1fr; }
  .page-title p, .icon-btn { display: none; }
  .page-title h1 { font-size: 18px; }
  .topbar { padding: 0 14px; }
  .content { padding: 18px 14px 28px; }
  .content-head { align-items: flex-start; }
  .content-head .report-actions { width: 100%; flex-wrap: wrap; justify-content: flex-start; }
  .branch-selector.compact { justify-content: flex-start; }
  .branch-picker-trigger { width: 100%; }
  .report-actions { width: 100%; align-items: stretch; flex-direction: column; }.report-actions .btn { width: 100%; }
  .stat-grid { grid-template-columns: 1fr 1fr; gap: 9px; }
  .sales-kpi-grid { grid-template-columns: 1fr 1fr; gap: 9px; }
  .sales-kpi { min-height: 118px; padding: 14px; border-radius: 16px; }
  .sales-kpi strong { font-size: 18px; }.sales-kpi-icon { width: 31px; height: 31px; }.sales-kpi-icon svg { width: 16px; }
  .period-switch { width: 100%; }
  .stat-card { min-height: 121px; padding: 15px; border-radius: 17px; }
  .stat-value { font-size: 21px; }
  .stat-top > span:first-child { font-size: 10px; }
  .stat-icon { width: 32px; height: 32px; }
  .service-grid { grid-template-columns: 1fr 1fr; gap: 9px; }
  .service-card { min-height: 145px; padding: 14px; }
  .service-card-icon { width: 42px; height: 42px; }
  .field-grid, .form-row { grid-template-columns: 1fr; }
  .filter-row { align-items: stretch; flex-direction: column; }
  .search { min-width: 0; }
  .order-row { grid-template-columns: 70px 1fr 32px 32px; grid-template-rows: auto auto; gap: 10px 9px; padding: 13px; }
  .order-total { display: none; }
  .order-row > div:first-child { grid-column: 1; grid-row: 1; }
  .order-main { grid-column: 2 / 5; grid-row: 1; }
  .order-status { grid-column: 1 / 3; grid-row: 2; justify-self: start; }
  .print-row-btn { grid-column: 3; grid-row: 2; }
  .more-btn { grid-column: 4; grid-row: 2; }
  .old-debt-alert { grid-column: 1 / 5; grid-row: 3; }
  .order-time { display: none; }
  .orders-summary { padding: 15px; }
  .orders-summary-title { align-items: stretch; flex-direction: column; }
  .orders-summary-title .btn { width: 100%; }
  .orders-summary-metrics { grid-template-columns: 1fr 1fr; }
  .machine-grid, .customer-grid, .report-grid { grid-template-columns: 1fr; }
  .branch-stats { grid-template-columns: 1fr; }
  .branch-summary-list, .branch-detail-metrics { grid-template-columns: 1fr; }
  .branch-detail-top { flex-direction: column; }
  .branch-report-row { grid-template-columns: 28px 1fr; }
  .branch-report-row strong, .branch-report-row .text-btn { grid-column: 2; text-align: left; }
  .license-branch-row, .license-row { grid-template-columns: 1fr; }
  .license-actions { justify-content: flex-start; }
  .popular-row { grid-template-columns: 26px 1.2fr 1fr 58px; }
  .variant-table td:nth-child(3) { width: 90px; }
  .toast { left: 14px; right: 14px; bottom: 83px; min-width: 0; }
  .paper-options, .connection-options, .receipt-actions, .modal-actions { grid-template-columns: 1fr; }
  .receipt-field-checks { grid-template-columns: 1fr 1fr; }
  .qr-setting-preview { align-items: flex-start; flex-direction: column; }
  .qr-upload-row { align-items: flex-start; flex-wrap: wrap; }
  .device-row { align-items: stretch; flex-direction: column; }
  .branch-picker-row { grid-template-columns: 24px minmax(0,1fr); }
  .branch-picker-row em { grid-column: 2; justify-self: start; }
  .receipt-stage { padding: 17px 8px; }
  .receipt-paper { padding-left: 4mm; padding-right: 4mm; }
}

@media print {
  body { margin: 0 !important; background: #fff !important; }
  body > *:not(#print-host) { display: none !important; }
  #print-host { display: block !important; width: var(--paper-mm); margin: 0; }
  #print-host .receipt-paper { width: var(--paper-mm); max-width: none; box-shadow: none; margin: 0; }
}
