:root{--font-sans: "Segoe UI", "Helvetica Neue", sans-serif;--color-bg: #f3f6fb;--color-bg-gradient: radial-gradient(circle at 12% 0%, #dbeafe 0%, #f3f6fb 42%, #eef2ff 100%);--color-surface: #ffffff;--color-surface-soft: #f8fafc;--color-border: #dbe2ec;--color-border-strong: #c9d4e3;--color-text: #132337;--color-text-muted: #5a6b82;--color-primary: #0f6bff;--color-primary-strong: #0a52c7;--color-primary-soft: #e8f1ff;--color-success: #0f9f6e;--color-warning: #b98320;--color-danger: #cf3b42;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow-sm: 0 8px 20px rgba(23, 44, 78, .06);--shadow-md: 0 16px 38px rgba(13, 36, 70, .08)}*{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg-gradient)}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;color:var(--color-text)}p{margin:0}.layout-shell{min-height:100vh;display:grid;grid-template-columns:280px minmax(0,1fr);background:transparent}.sidebar{background:linear-gradient(180deg,#0d2445,#11315b);color:#d8e6ff;border-right:1px solid #21406f;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:20}.sidebar-header{height:72px;display:flex;align-items:center;padding:0 20px;border-bottom:1px solid rgba(174,201,239,.2)}.app-logo{width:36px;height:36px;border-radius:10px;background:linear-gradient(145deg,#50a7ff,#0f6bff);display:grid;place-items:center;color:#fff;font-size:13px;font-weight:700;margin-right:12px}.app-title{font-size:17px;font-weight:600;letter-spacing:.01em;color:#f0f6ff}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:6px}.nav-item{display:flex;align-items:center;min-height:42px;padding:0 14px;border-radius:10px;border:1px solid transparent;color:#b9ceef;text-decoration:none;font-size:14px;font-weight:500;transition:all .2s ease}.nav-item-label{line-height:1}.nav-item:hover{color:#f8fbff;background:#c8dfff1f}.nav-item.active{color:#fff;background:linear-gradient(90deg,#0f6bff59,#0f6bff2e);border-color:#84bcff80}.sidebar-footer{border-top:1px solid rgba(174,201,239,.2);padding:16px}.status-indicator{display:flex;align-items:center;gap:8px;font-size:13px;color:#bdd3f3}.status-dot{width:8px;height:8px;border-radius:999px}.status-dot.online{background:#21d398;box-shadow:0 0 0 4px #21d39824}.logout-button{margin-top:12px;width:100%;background:#cf3b421f;border:1px solid rgba(207,59,66,.22);color:#ffc4c8;border-radius:10px;padding:10px 12px;text-align:left;cursor:pointer}.logout-button:hover{background:#cf3b4233}.main-wrapper{min-width:0;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:10;height:72px;padding:0 24px;border-bottom:1px solid var(--color-border);background:#ffffffe0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:space-between}.page-title{font-size:20px;font-weight:700}.content-area{flex:1;overflow:auto;padding:24px}.page-content{max-width:1240px;margin:0 auto}.page-content>h1{margin-bottom:16px;font-size:28px;font-weight:700}.card{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-sm);padding:22px}.muted{color:var(--color-text-muted)}.error{margin-bottom:16px;padding:12px 14px;border-radius:var(--radius-md);border:1px solid rgba(207,59,66,.26);color:#aa2a31;background:#fdeff0}.notice{margin-bottom:16px;padding:12px 14px;border-radius:var(--radius-md);border:1px solid rgba(15,159,110,.24);color:#0d6c4c;background:#ecfaf4}.row,.stack{display:grid;gap:12px}.row{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-items:center}.form-section{display:grid;gap:14px}.section-title{font-size:18px;font-weight:700}.form-label{display:block;margin-bottom:6px;font-size:13px;font-weight:600;color:var(--color-text-muted)}.form-inline{display:flex;flex-wrap:wrap;gap:10px}.form-inline>*{min-width:180px}.form-inline-grow input{flex:1}.form-stack,.form-grid-2,.form-grid-3,.form-grid-4{display:grid;gap:12px}.form-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.form-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.form-actions{display:flex;justify-content:flex-end;align-items:center;gap:10px}.form-actions.between{justify-content:space-between}.inline-actions{display:inline-flex;gap:8px;align-items:center}.compact-top{margin-top:8px}.mono-input,.mono-cell{font-family:Consolas,Courier New,monospace}.button-secondary{background:#fff;color:var(--color-text);border:1px solid var(--color-border-strong)}.button-secondary:hover{background:var(--color-surface-soft)}.button-danger,.btn-danger-sm{background:#fdeff0;color:var(--color-danger);border:1px solid rgba(207,59,66,.2)}.button-danger:hover,.btn-danger-sm:hover{background:#f9dfe1}.btn-danger-sm{padding:6px 10px;font-size:12px}.settings-grid{display:grid;gap:20px}.table-section{padding:0;overflow:hidden}.table-wrap{width:100%;overflow-x:auto}.data-table{width:100%;border-collapse:collapse;min-width:740px}.data-table th,.data-table td{border-bottom:1px solid var(--color-border);text-align:left;padding:11px 12px;vertical-align:top}.data-table th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);background:#f7fafe}.data-table td{font-size:14px}.table-empty{text-align:center;color:var(--color-text-muted);padding:22px}.empty-state-card{border:1px dashed var(--color-border-strong);border-radius:var(--radius-lg);background:#fff;box-shadow:var(--shadow-sm);padding:26px;display:grid;gap:10px;justify-items:start}.empty-state-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:var(--color-primary-soft);color:var(--color-primary);font-size:14px;font-weight:700}.empty-state-title{font-size:18px;font-weight:700}.empty-state-description{max-width:62ch;color:var(--color-text-muted);line-height:1.45;margin-bottom:4px}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:3px 8px;font-size:11px;text-transform:uppercase;font-weight:700}.badge.supervisor{background:#e7f0ff;color:#245fcf}.badge.kasir{background:#e8f8f0;color:#0f8b62}.badge.number{background:#fff5e4;color:#a87014}.badge.group{background:#f1ecff;color:#6f47c7}.snippet-box{margin:0;background:#0f1d31;color:#deebff;border-radius:var(--radius-sm);border:1px solid #28456e;padding:14px;overflow-x:auto;font-family:Consolas,Courier New,monospace;font-size:13px;line-height:1.45}.skeleton-card{min-height:140px;background:linear-gradient(90deg,#f4f7fb 25%,#e8eef8,#f4f7fb 75%);background-size:280% 100%;animation:skeletonPulse 1.3s ease-in-out infinite}@keyframes skeletonPulse{0%{background-position:100% 0}to{background-position:-100% 0}}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;background:#07162973;display:grid;place-items:center;padding:16px}.confirm-dialog{width:min(420px,100%);border-radius:var(--radius-lg);border:1px solid var(--color-border-strong);background:#fff;box-shadow:var(--shadow-md);padding:18px;display:grid;gap:12px}.toast-stack{position:fixed;top:18px;right:18px;z-index:140;display:grid;gap:8px;width:min(360px,calc(100vw - 36px))}.toast-item{border-radius:12px;border:1px solid var(--color-border-strong);background:#fff;box-shadow:var(--shadow-sm);padding:10px 12px;font-size:14px;display:flex;align-items:center;justify-content:space-between;gap:10px}.toast-success{border-color:#0f9f6e42;background:#ecfaf4;color:#0d6c4c}.toast-error{border-color:#cf3b4242;background:#fdeff0;color:#aa2a31}.toast-close{border:0;background:transparent;padding:2px 4px;color:currentColor;font-size:12px}.toast-close:hover{background:transparent;text-decoration:underline}.sessions-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:20px 0}.session-card{display:grid;gap:12px}.session-meta-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.auto-connect-chip{padding:6px 10px;font-size:12px}.auto-connect-chip.active{background:#e8f8f0;border-color:#0f8b624d;color:#0f8b62}.session-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.session-card-title{font-size:18px}.session-card-id{margin-top:3px;font-size:12px;color:var(--color-text-muted);font-family:Consolas,Courier New,monospace}.status-pill{padding:4px 9px;border-radius:999px;font-size:11px;text-transform:uppercase;font-weight:700}.status-created,.status-disconnected{background:#edf3fb;color:#4c6586}.status-connecting,.status-qr{background:#fff6e8;color:#a6731c}.status-connected{background:#e8f8f0;color:#0f8b62}.status-error{background:#fdeff0;color:#b5353b}.session-qr-wrap{text-align:center;border:1px dashed var(--color-border-strong);border-radius:var(--radius-md);padding:12px}.session-qr{width:180px;max-width:100%}.session-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.pagination-text{font-size:13px;color:var(--color-text-muted)}.direction-pill{display:inline-flex;border-radius:999px;padding:3px 8px;font-size:11px;font-weight:700;text-transform:uppercase}.direction-pill.incoming{background:#e7f0ff;color:#245fcf}.direction-pill.outgoing{background:#e8f8f0;color:#0f8b62}.message-cell{max-width:340px;white-space:pre-wrap;word-break:break-word}.command-pill,.status-chip{display:inline-flex;border-radius:999px;padding:2px 8px;font-size:11px;background:#edf3fb;color:#4c6586}.stack{grid-template-columns:1fr}input,select,textarea,button{font:inherit}input,select,textarea{width:100%;border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);padding:10px 12px;color:var(--color-text);background:#fff;outline:none;transition:border-color .2s,box-shadow .2s}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0f6bff26}button{border:0;border-radius:var(--radius-sm);padding:10px 14px;cursor:pointer;color:#fff;background:var(--color-primary);font-weight:600;transition:transform .16s ease,background-color .16s ease,opacity .16s ease}button:hover{background:var(--color-primary-strong)}button:active{transform:translateY(1px)}button:disabled{opacity:.6;cursor:not-allowed}.stats-grid{display:grid;gap:16px;margin:18px 0 26px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.stats-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:linear-gradient(180deg,#fff,#f7fbff);box-shadow:var(--shadow-sm);padding:18px;display:flex;align-items:center;gap:14px}.stats-icon{width:44px;height:44px;border-radius:12px;background:var(--color-primary-soft);display:grid;place-items:center;font-size:20px}.stats-label{font-size:13px;color:var(--color-text-muted);margin-bottom:2px}.stats-value{font-size:22px;font-weight:700;line-height:1.2}.stats-subtitle{margin-top:4px;color:var(--color-text-muted);font-size:12px}.page-section-title{margin:6px 0 14px;font-size:18px;font-weight:700}.action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.action-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fff;box-shadow:var(--shadow-sm);text-decoration:none;color:inherit;display:flex;align-items:center;gap:12px;padding:16px;transition:border-color .2s,transform .2s}.action-card:hover{border-color:#9fc6ff;transform:translateY(-2px)}.infra-grid{margin-top:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.infra-card{display:grid;gap:4px}.infra-label{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.infra-value{font-size:18px;font-weight:700}.infra-meta{font-size:12px;color:var(--color-text-muted)}.infra-status.up{color:var(--color-success);font-weight:600}.infra-status.down{color:var(--color-danger);font-weight:600}.action-icon{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:#eef5ff}.action-title{font-size:15px;font-weight:600;margin-bottom:2px}.action-desc{color:var(--color-text-muted);font-size:12px}.login-shell{min-height:100vh;display:grid;place-items:center;padding:20px;background:linear-gradient(160deg,#dbeafe,#eef2ff 40%,#f8fafc)}.login-card{width:min(420px,100%);border-radius:18px;border:1px solid var(--color-border);background:#fff;padding:28px;box-shadow:var(--shadow-md)}.login-title{margin-bottom:16px;text-align:center;font-size:24px;font-weight:700}.login-error{margin-bottom:12px;border-radius:var(--radius-sm);border:1px solid rgba(207,59,66,.24);background:#fdeff0;color:#aa2a31;padding:10px 12px;font-size:14px}.login-field{margin-bottom:14px}.login-label{display:block;margin-bottom:6px;color:var(--color-text-muted);font-size:13px;font-weight:600}.login-input,.login-submit{width:100%}.bot-command-head{margin-bottom:16px;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.bot-guide{margin-bottom:16px;display:grid;gap:14px}.bot-guide-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.bot-guide-block{background:#f7fafe;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px 14px}.bot-guide-block h3{margin:0 0 8px;font-size:14px}.bot-guide-block ol,.bot-guide-block ul{margin:0;padding-left:18px;color:var(--color-text-muted);display:grid;gap:6px;font-size:13px}.bot-example-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.bot-example-item{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff;padding:10px;display:grid;gap:6px}.bot-example-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:13px;font-weight:600}.bot-example-item code{background:#0f1d31;color:#deebff;border-radius:6px;padding:7px 8px;font-family:Consolas,Courier New,monospace;font-size:12px}.bot-schedule-card{margin-bottom:16px;display:grid;gap:12px}.bot-schedule-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.bot-timezone-row{display:grid;gap:6px;max-width:320px}.bot-schedule-item{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#f8fbff;padding:12px;display:grid;gap:10px}.bot-schedule-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.bot-schedule-head h3{margin:0;font-size:15px}.bot-switch{background:#eef3fb;color:var(--color-text-muted);border:1px solid var(--color-border-strong);font-size:12px;padding:6px 10px}.bot-switch:hover{background:#e3ebf9}.bot-switch.active{background:#e8f8f0;color:#0f8b62;border-color:#0f8b6259}.bot-schedule-note{font-size:12px}.bot-schedule-test-btn{justify-self:start;background:#0f8b62;border-color:#0f8b6273;color:#fff}.bot-schedule-test-btn:hover:not(:disabled){background:#0d7955}.bot-command-title-row{display:flex;align-items:center;gap:10px;margin-bottom:4px}.bot-command-title{font-size:18px;font-weight:700}.bot-role-badge{display:inline-flex;border-radius:999px;padding:3px 9px;font-size:12px;font-weight:700;border:1px solid transparent}.bot-command-description{font-size:14px}.bot-toggle-button{border:none;background:transparent;color:inherit;padding:0;display:inline-flex;align-items:center;gap:8px}.bot-toggle-button:hover{background:transparent}.bot-toggle-text{font-size:14px}.bot-toggle-track{width:48px;height:24px;border-radius:999px;background:#96a6bc;padding:2px;transition:background-color .2s ease}.bot-toggle-track.enabled{background:var(--color-primary)}.bot-toggle-thumb{display:block;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 4px #07172e47;transform:translate(0);transition:transform .2s ease}.bot-toggle-track.enabled .bot-toggle-thumb{transform:translate(24px)}.bot-command-body{border-top:1px solid var(--color-border);padding-top:16px}.bot-command-label{display:block;margin-bottom:8px;font-size:14px;font-weight:600}.bot-input-row{display:flex;gap:8px}.bot-command-input{flex:1}.bot-reset-button{border:1px solid var(--color-border-strong);color:var(--color-text-muted);background:#fff}.bot-reset-button:hover{background:var(--color-surface-soft)}.bot-help-text{margin-top:8px;font-size:12px}.mobile-nav-toggle,.sidebar-backdrop{display:none}@media (max-width: 1024px){.layout-shell{grid-template-columns:1fr}.mobile-nav-toggle{display:inline-flex;position:fixed;left:12px;top:14px;z-index:31;border-radius:999px;padding:8px 14px;font-size:13px;box-shadow:0 10px 24px #081d3a33}.sidebar{position:fixed;left:0;top:0;transform:translate(-100%);transition:transform .24s ease;width:min(82vw,320px)}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#07132473;z-index:19}.topbar{padding-left:84px}.content-area{padding:16px}.bot-command-head{flex-direction:column;align-items:stretch}.bot-guide-grid,.bot-schedule-grid{grid-template-columns:1fr}.bot-input-row{flex-direction:column}.form-grid-2,.form-grid-3,.form-grid-4{grid-template-columns:1fr}.form-actions.between{flex-direction:column;align-items:stretch}.session-actions{grid-template-columns:1fr}.toast-stack{left:12px;right:12px;width:auto}}
