@import url("https://fonts.googleapis.com/css2?family=Sarabun:wght@300;400;500;600;700;800&family=Manrope:wght@200..800&display=swap");@import url("https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200&display=swap");:root{--primary:#2f7dae;--primary-dark:#1a5c85;--primary-container:#d1e8f7;--accent-green:#0bbf55;--accent-mid:#1a8a5e;--bg:#f4f6f8;--surface:#eef1f4;--card:#ffffff;--header:#f8f9fb;--text:#1b1c1a;--text-secondary:#617a8f;--text-muted:#74777b;--ghost:rgba(190,200,203,0.12);--ghost-strong:rgba(190,200,203,0.15);--input-border:rgba(190,200,203,0.4);--success:#0bbf55;--success-bg:rgba(11,191,85,0.08);--success-text:#15803d;--error:#ba1a1a;--error-bg:rgba(186,26,26,0.08);--error-text:#991b1b;--warning:#d97706;--warning-bg:rgba(217,119,6,0.08);--warning-text:#92400e;--shadow-card:0 2px 40px rgba(27,28,26,0.04);--shadow-hover:0 6px 20px rgba(47,125,174,0.1);--shadow-modal:0 16px 64px rgba(27,28,26,0.12);--shadow-btn:0 4px 16px rgba(47,125,174,0.2);--grad-primary:linear-gradient(135deg,#2f7dae,#1a8a5e);--grad-full:linear-gradient(135deg,#2f7dae,#1a8a5e 50%,#0bbf55);--grad-bar:linear-gradient(90deg,#2f7dae,#1a8a5e,#0bbf55)}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:Sarabun,Manrope,sans-serif;background:var(--bg);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body,h1,h2,h3,h4{color:var(--text)}h1,h2,h3,h4{font-family:Manrope,Sarabun,sans-serif;letter-spacing:.02em;margin:0}h1{font-size:26px;font-weight:800;line-height:1.2}h2{font-size:20px;line-height:1.3}h2,h3{font-weight:700}h3{font-size:16px;line-height:1.4}a{color:var(--primary);text-decoration:none;transition:color .15s ease}a:hover{color:var(--primary-dark)}code{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.92em;background:var(--surface);padding:1px 6px;border-radius:6px;color:var(--text-secondary)}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 24;font-size:20px;line-height:1;-webkit-user-select:none;-moz-user-select:none;user-select:none}.material-symbols-outlined.filled{font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24}.app-shell{display:flex;min-height:100vh}.sidebar{width:230px;flex:0 0 230px;background:var(--card);box-shadow:1px 0 0 var(--ghost-strong);display:flex;flex-direction:column;padding:18px 14px 14px;position:-webkit-sticky;position:sticky;top:0;max-height:100vh}.sidebar__brand{display:flex;align-items:center;gap:10px;padding:4px 6px 16px}.sidebar__brand-icon{width:38px;height:38px;border-radius:10px;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-btn);flex-shrink:0}.sidebar__brand-title{font-family:Manrope,sans-serif;font-size:15px;font-weight:700;letter-spacing:.02em;line-height:1.15}.sidebar__brand-sub{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-top:2px}.sidebar__nav{display:flex;flex-direction:column;gap:3px;margin-top:4px;flex:1 1;overflow-y:auto}.sidebar__link{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;font-size:13px;color:var(--text-secondary);font-weight:500;transition:all .15s ease;border-left:3px solid transparent;margin-left:-3px}.sidebar__link:hover{background:rgba(47,125,174,.04);color:var(--primary)}.sidebar__link--active{background:rgba(47,125,174,.08);color:var(--primary);font-weight:700;border-left-color:var(--primary)}.sidebar__link .material-symbols-outlined{font-size:18px}.sidebar__user{margin-top:12px;padding:10px 10px 4px;border-top:1px solid var(--ghost);display:flex;align-items:center;gap:10px}.sidebar__user-avatar{width:28px;height:28px;border-radius:50%;background:var(--grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.sidebar__user-info{flex:1 1;min-width:0}.sidebar__user-name{font-size:12px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__user-role{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.main{flex:1 1;min-width:0;display:flex;flex-direction:column}.topbar{height:44px;padding:0 22px;background:rgba(255,255,255,.8);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--ghost-strong);display:flex;align-items:center;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:10}.topbar__title{font-size:13px;font-weight:700;letter-spacing:.02em}.topbar__brand{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary)}.content{padding:18px 22px 48px;max-width:1400px;width:100%}.page-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}.page-header__icon{width:42px;height:42px;border-radius:12px;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-btn);flex-shrink:0}.page-header__title{font-size:22px;font-weight:700;letter-spacing:.02em;line-height:1.2}.page-header__sub{font-size:12px;color:var(--text-muted);margin-top:2px}.page-header__actions{margin-left:auto;display:flex;gap:8px;align-items:center}.card{background:var(--card);border-radius:14px;box-shadow:var(--shadow-card);padding:18px 20px}.card--padded-lg{padding:24px}.card--flush{padding:0;overflow:hidden}.card__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.card__title{font-size:15px;font-weight:700;letter-spacing:.02em}.metric{background:var(--grad-primary);color:#fff;border-radius:14px;padding:18px 20px;position:relative;overflow:hidden;min-height:120px;display:flex;flex-direction:column;justify-content:space-between}.metric--error{background:linear-gradient(135deg,#ba1a1a,#7f1d1d)}.metric--warning{background:linear-gradient(135deg,#d97706,#92400e)}.metric--neutral{background:var(--card);color:var(--text)}.metric__icon{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;flex-shrink:0}.metric--neutral .metric__icon{background:rgba(47,125,174,.08);color:var(--primary)}.metric__value{font-size:30px;font-weight:800;line-height:1;letter-spacing:.01em}.metric__label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.85;margin-top:4px}.metric__sub{font-size:11px;opacity:.75;margin-top:4px}.metric--neutral .metric__label,.metric--neutral .metric__sub{color:var(--text-muted);opacity:1}.metric__watermark{position:absolute;right:-8px;bottom:-14px;opacity:.08;pointer-events:none}.metric__watermark .material-symbols-outlined{font-size:100px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;border-radius:10px;border:none;cursor:pointer;font-family:inherit;transition:all .15s ease;text-decoration:none;line-height:1.2;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--grad-primary);color:#fff;box-shadow:var(--shadow-btn)}.btn--primary:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 6px 28px rgba(47,125,174,.3);color:#fff}.btn--secondary{background:var(--surface);color:var(--text)}.btn--secondary:not(:disabled):hover{background:#e2e7ec;color:var(--text)}.btn--ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--input-border)}.btn--ghost:not(:disabled):hover{background:var(--surface);color:var(--text)}.btn--danger{background:var(--error-bg);color:var(--error)}.btn--danger:not(:disabled):hover{background:rgba(186,26,26,.15);color:var(--error)}.btn--sm{padding:5px 10px;font-size:12px;border-radius:8px}.btn--pill{border-radius:999px;padding:8px 20px}.btn .material-symbols-outlined{font-size:16px}.icon-btn{width:32px;height:32px;border:none;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-family:inherit;transition:all .15s ease;background:rgba(47,125,174,.08);color:var(--primary)}.icon-btn:hover{background:rgba(47,125,174,.15)}.icon-btn--danger{background:var(--error-bg);color:var(--error)}.icon-btn--danger:hover{background:rgba(186,26,26,.15)}.badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.06em;line-height:1.4;white-space:nowrap}.badge--success{background:var(--success-bg);color:var(--success-text)}.badge--error{background:var(--error-bg);color:var(--error-text)}.badge--warning{background:var(--warning-bg);color:var(--warning-text)}.badge--info{background:rgba(47,125,174,.08);color:var(--primary)}.badge--neutral{background:var(--surface);color:var(--text-muted)}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--success);display:inline-block}.status-dot--off{background:#d1d5db}.table-wrap{background:var(--card);border-radius:14px;box-shadow:var(--shadow-card);overflow:hidden}.table{width:100%;border-collapse:collapse;font-size:13px}.table thead th{background:var(--header);text-align:left;padding:11px 16px;font-size:10px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.table tbody td{padding:12px 16px;border-bottom:1px solid var(--ghost);vertical-align:top}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:rgba(47,125,174,.02)}.table--compact tbody td,.table--compact thead th{padding:8px 12px}.muted{color:var(--text-muted)}.mono{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:11.5px}.right{text-align:right}.label{display:block;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}.input,.select,.textarea{width:100%;font-family:inherit;font-size:14px;padding:10px 14px;border-radius:10px;border:1px solid var(--input-border);background:var(--card);color:var(--text);transition:all .15s ease}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(47,125,174,.1)}.textarea{min-height:120px;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:13px;resize:vertical}.field{margin-bottom:14px}.field-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:12px;gap:12px}.alert{border-radius:12px;padding:12px 16px;display:flex;align-items:flex-start;gap:10px;font-size:13px}.alert--critical{background:var(--error-bg);color:var(--error-text)}.alert--warn{background:var(--warning-bg);color:var(--warning-text)}.alert--info{background:rgba(47,125,174,.08);color:var(--primary)}.alert__title{font-weight:700}.alert__detail{font-size:12px;opacity:.8;margin-top:2px}.chip{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:600;color:var(--text-secondary);background:var(--card);border:1px solid var(--ghost-strong);text-decoration:none;transition:all .15s ease}.chip:hover{border-color:var(--input-border);color:var(--text)}.chip--active{background:var(--primary);color:#fff;border-color:var(--primary)}.chip--active:hover{color:#fff}.empty{text-align:center;padding:48px 24px}.empty__icon{display:inline-flex;width:72px;height:72px;border-radius:18px;background:rgba(47,125,174,.06);color:rgba(47,125,174,.5);align-items:center;justify-content:center;margin-bottom:12px}.empty__icon .material-symbols-outlined{font-size:36px}.empty__title{font-size:15px;font-weight:700;margin-bottom:4px}.empty__text{font-size:13px;color:var(--text-secondary);margin-bottom:16px}.modal-backdrop{position:fixed;inset:0;background:rgba(27,28,26,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:var(--card);border-radius:16px;box-shadow:var(--shadow-modal);padding:24px;width:min(560px,92vw);max-height:92vh;overflow-y:auto}.modal__title{font-size:18px;font-weight:700;letter-spacing:.02em;margin-bottom:4px}.modal__sub{font-size:13px;color:var(--text-muted);margin-bottom:18px}.modal__footer{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--ghost)}.grid-4{grid-template-columns:repeat(4,1fr);grid-gap:12px}.grid-3,.grid-4{display:grid;gap:12px}.grid-3{grid-template-columns:repeat(3,1fr);grid-gap:12px}.grid-2{grid-template-columns:repeat(2,1fr);grid-gap:12px}.grid-2,.grid-auto{display:grid;gap:12px}.grid-auto{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:12px}.stack{flex-direction:column;gap:18px}.row,.stack{display:flex}.row{align-items:center;gap:8px;flex-wrap:wrap}.row--between{justify-content:space-between}@media (max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.sidebar{display:none}.content{padding:14px 16px 32px}}.md-preview h1,.md-preview h2,.md-preview h3{margin:12px 0 8px}.md-preview h2{font-size:17px}.md-preview p{margin:0 0 10px}.md-preview ol,.md-preview ul{margin:0 0 10px 18px}.md-preview code{background:var(--surface)}.cm-editor{border-radius:10px;background:var(--card);border:1px solid var(--input-border)}.cm-editor.cm-focused{border-color:var(--primary);outline:3px solid rgba(47,125,174,.1)}.cm-gutters{background:var(--header)!important;border-right:1px solid var(--ghost)!important;color:var(--text-muted)!important}