:root{--teal-900: #0b2e2a;--teal-700: #0f766e;--teal-600: #0d9488;--teal-50: #ecfdf9;--amber: #f59e0b;--ink: #1c1917;--muted: #78716c;--line: #e7e5e4;--surface: #ffffff;--bg: #faf9f7;--danger: #b91c1c;--danger-bg:#fef2f2;--radius: 12px;--shadow: 0 1px 2px rgba(12, 46, 42, .06), 0 8px 24px rgba(12, 46, 42, .06);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}.mono{font-variant-numeric:tabular-nums}.muted{color:var(--muted)}.btn{font:inherit;font-weight:600;border:1px solid transparent;border-radius:10px;padding:11px 16px;cursor:pointer;min-height:44px;transition:background .15s,border-color .15s,transform .05s}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--teal-700);color:#fff}.btn-primary:hover{background:var(--teal-600)}.btn-primary:disabled{opacity:.6;cursor:default}.btn-ghost{background:transparent;color:var(--muted);border-color:var(--line)}.btn-ghost:hover{color:var(--ink);border-color:var(--muted)}.btn-block{width:100%}.icon-btn{background:none;border:none;font-size:22px;line-height:1;color:var(--ink);width:44px;height:44px;border-radius:10px;cursor:pointer}.icon-btn:hover{background:var(--teal-50)}.brand{display:flex;align-items:center;gap:10px;padding:18px 16px}.brand-name{font-weight:700;letter-spacing:-.01em;color:#fff}.brand-mark{display:grid;place-items:center;width:32px;height:32px;border-radius:9px;background:var(--amber);color:var(--teal-900);font-weight:800;font-size:18px}.brand-mark--lg{width:52px;height:52px;font-size:28px;border-radius:14px}.shell{display:flex;height:100%}.sidebar{width:248px;flex-shrink:0;background:var(--teal-900);display:flex;flex-direction:column}.nav{display:flex;flex-direction:column;gap:2px;padding:8px;flex:1}.nav-link{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;color:#cdeae5;text-decoration:none;font-weight:600;min-height:46px}.nav-link:hover{background:#ffffff0f;color:#fff}.nav-link.is-active{background:var(--teal-700);color:#fff}.nav-icon{width:20px;text-align:center;opacity:.9}.sidebar-foot{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08)}.badge{font-size:12px;font-weight:700;color:var(--teal-900);background:var(--teal-50);padding:4px 10px;border-radius:999px}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;gap:12px;padding:12px 20px;background:var(--surface);border-bottom:1px solid var(--line)}.topbar-title{font-weight:700;color:var(--muted);letter-spacing:.04em;font-size:13px}.user{margin-left:auto;display:flex;align-items:center;gap:14px}.user-meta{text-align:right;line-height:1.2}.user-name{font-weight:600;font-size:14px}.user-sub{font-size:12px;color:var(--muted)}.content{padding:24px;overflow:auto}.page{max-width:920px;margin:0 auto}.page-head{display:flex;align-items:baseline;gap:12px}.page-title{font-size:22px;font-weight:700;letter-spacing:-.01em;margin:0 0 4px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:20px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.stat-label{font-size:13px;color:var(--muted);font-weight:600}.stat-value{font-size:26px;font-weight:700;margin:6px 0 2px;font-variant-numeric:tabular-nums}.stat-foot{font-size:12px}.search{width:100%;font:inherit;padding:12px 14px;margin:16px 0;border:1px solid var(--line);border-radius:10px;background:var(--surface)}.search:focus{outline:2px solid var(--teal-600);outline-offset:0;border-color:transparent}.table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--line)}.table th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:#fbfaf9}.table tbody tr:last-child td{border-bottom:none}.table .num{text-align:right}.cell-strong{font-weight:600}.cell-sub{font-size:12px}.empty{text-align:center;padding:56px 20px;color:var(--ink)}.empty-mark{font-size:34px;color:var(--teal-600);margin-bottom:10px}.alert{background:var(--danger-bg);color:var(--danger);border:1px solid #fecaca;border-radius:10px;padding:12px 14px;margin-bottom:14px;font-size:14px}.auth{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(1200px 500px at 50% -10%,var(--teal-50),var(--bg))}.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:var(--shadow)}.auth-brand{text-align:center;margin-bottom:22px}.auth-brand h1{font-size:22px;margin:14px 0 2px;letter-spacing:-.01em}.auth-brand .brand-mark{margin:0 auto}.field{display:block;margin-bottom:14px}.field span{display:block;font-size:13px;font-weight:600;margin-bottom:6px}.field input{width:100%;font:inherit;padding:12px 14px;min-height:46px;border:1px solid var(--line);border-radius:10px;background:#fff}.field input:focus{outline:2px solid var(--teal-600);border-color:transparent}.scrim,.only-mobile{display:none}@media (max-width: 760px){.sidebar{position:fixed;inset:0 auto 0 0;z-index:30;transform:translate(-100%);transition:transform .22s ease;box-shadow:var(--shadow)}.sidebar.is-open{transform:translate(0)}.scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0c2e2a66;z-index:20}.only-mobile{display:inline-grid}.content{padding:16px}.user-meta{display:none}}@media (prefers-reduced-motion: reduce){*{transition:none!important}}.kasir{display:grid;grid-template-columns:1fr 360px;gap:18px;height:100%}.kasir-produk{display:flex;flex-direction:column;min-width:0}.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;overflow:auto;align-content:start;padding-bottom:8px}.prod-card{text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px;cursor:pointer;display:flex;flex-direction:column;gap:8px;min-height:78px;transition:border-color .12s,transform .05s}.prod-card:hover{border-color:var(--teal-600)}.prod-card:active{transform:scale(.98)}.prod-nama{font-weight:600;line-height:1.25}.prod-harga{color:var(--teal-700);font-weight:700}.kasir-cart{background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);display:flex;flex-direction:column;padding:16px}.cart-title{margin:0 0 10px;font-size:16px}.cart-lines{flex:1;overflow:auto;min-height:80px}.cart-empty{padding:24px 0;text-align:center}.cart-line{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid var(--line)}.cart-info{min-width:0}.cart-sub{font-weight:600}.stepper{display:inline-flex;align-items:center;gap:10px}.stepper button{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:#fff;font-size:18px;line-height:1;cursor:pointer}.stepper button:hover{border-color:var(--teal-600)}.cart-total{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;margin-top:6px;border-top:2px solid var(--ink)}.total-num{font-size:22px;font-weight:700}.pay{margin:8px 0}.pay-input{margin:6px 0;font-size:18px}.quick{display:flex;flex-wrap:wrap;gap:6px}.quick .btn{padding:7px 10px;min-height:38px;font-size:13px}.kembali-row{display:flex;justify-content:space-between;margin-top:10px;font-weight:600}.kembali-row .minus{color:var(--danger)}.btn-bayar{margin-top:12px;font-size:16px;min-height:52px}.receipt{position:relative;z-index:40;margin:auto;width:320px;max-width:calc(100% - 32px);background:#fff;border-radius:14px;padding:20px;box-shadow:var(--shadow)}.receipt-head{text-align:center;padding-bottom:12px;border-bottom:1px dashed var(--line)}.badge-pending{background:#fff7ed;color:#9a3412;margin-top:8px;display:inline-block}.receipt-lines{padding:12px 0;border-bottom:1px dashed var(--line)}.receipt-line,.receipt-row{display:flex;justify-content:space-between;padding:3px 0}.receipt-foot{padding-top:12px}.receipt-row.strong{font-weight:700;font-size:16px;margin-top:4px}.receipt-actions{display:flex;gap:10px;margin-top:16px}.receipt-actions .btn{flex:1}@media (max-width: 760px){.kasir{grid-template-columns:1fr;height:auto}.kasir-cart{position:sticky;bottom:0}}@media print{.sidebar,.topbar,.kasir-produk,.receipt-actions{display:none!important}.scrim{position:static;background:none}.receipt{box-shadow:none;width:auto}}.sync-badge{display:inline-flex;align-items:center;gap:7px;background:transparent;border:1px solid var(--line);border-radius:999px;padding:5px 11px;cursor:pointer;font:inherit;font-size:13px;font-weight:600;color:var(--muted)}.sync-badge:hover{border-color:var(--muted)}.sync-dot{width:8px;height:8px;border-radius:50%;background:#cbd5e1}.sync-badge.is-online .sync-dot{background:var(--teal-600)}.sync-badge.is-offline .sync-dot{background:#f59e0b}.sync-badge.is-syncing .sync-dot{animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.sync-pending{background:var(--amber);color:var(--teal-900);border-radius:999px;padding:1px 7px;font-size:12px;font-weight:700}@media (max-width: 760px){.sync-label{display:none}}.sub{font-size:15px;font-weight:700;margin:24px 0 10px}.filters{display:flex;gap:14px;flex-wrap:wrap;margin:14px 0}.field-inline{display:flex;align-items:center;gap:8px;font-size:14px}.field-inline span{font-weight:600;color:var(--muted)}.field-inline input{font:inherit;padding:8px 10px;border:1px solid var(--line);border-radius:8px}.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}@media (max-width: 760px){.report-grid{grid-template-columns:1fr}}.chip{display:inline-block;background:var(--teal-50);color:var(--teal-900);font-size:12px;font-weight:600;padding:2px 9px;border-radius:999px;margin:0 4px 2px 0}.chip-ok{background:#ecfdf5;color:#065f46}.btn-sm{padding:6px 10px;min-height:34px;font-size:13px}.modal{position:relative;z-index:40;margin:auto;width:420px;max-width:calc(100% - 32px);background:#fff;border-radius:14px;padding:22px;box-shadow:var(--shadow);max-height:90vh;overflow:auto}.modal h3{margin:0 0 14px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.field select{width:100%;font:inherit;padding:12px 14px;min-height:46px;border:1px solid var(--line);border-radius:10px;background:#fff}.checks{display:flex;flex-wrap:wrap;gap:10px 16px;padding:4px 0}.check{display:inline-flex;align-items:center;gap:6px;font-weight:500}
