@import url("https://fonts.googleapis.com/css2?family=Bai+Jamjuree:wght@500;600;700&family=IBM+Plex+Sans+Thai:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap");:root{--font-display:"Bai Jamjuree","IBM Plex Sans Thai",system-ui,sans-serif;--font-body:"IBM Plex Sans Thai",system-ui,sans-serif;--font-mono:"IBM Plex Mono",ui-monospace,"SFMono-Regular",monospace;--bg:#e9efea;--surface:#fff;--surface-2:#f4f8f5;--surface-3:#eef3ef;--ink:#0b1f16;--ink-soft:#46564d;--muted:#859289;--line:#e1e8e2;--line-strong:#cfd9d1;--brand:#06c755;--brand-deep:#04a648;--brand-darker:#038a3c;--brand-soft:#e3f9ec;--brand-ink:#0a4a29;--danger:#dc2626;--danger-soft:#fef2f2;--danger-line:#f6caca;--warn:#b45309;--warn-soft:#fdf3e3;--info:#1d4ed8;--info-soft:#e7eeff;--radius-lg:22px;--radius:16px;--radius-sm:11px;--shadow-sm:0 1px 2px rgba(11,31,22,.05),0 1px 1px rgba(11,31,22,.04);--shadow:0 8px 24px -10px rgba(11,31,22,.18),0 2px 8px -3px rgba(11,31,22,.08);--shadow-lg:0 34px 64px -22px rgba(11,31,22,.32),0 8px 20px -10px rgba(11,31,22,.16);--ring:0 0 0 4px rgba(6,199,85,.18);--grid-line:rgba(11,31,22,.035);--glow-1:rgba(6,199,85,.16);--glow-2:rgba(6,199,85,.09);--code-bg:#08130d;--code-fg:#c9f5d8;color-scheme:light}:root[data-theme=dark]{--bg:#0a1310;--surface:#111d17;--surface-2:#16261d;--surface-3:#1e3327;--ink:#e8f1ec;--ink-soft:#a6b8ad;--muted:#6e8278;--line:#22362a;--line-strong:#2f4838;--brand:#14d466;--brand-deep:#06c755;--brand-darker:#04a648;--brand-soft:#122c1e;--brand-ink:#74e6a3;--danger:#f87171;--danger-soft:#2a1414;--danger-line:#5a2424;--warn:#fbbf24;--warn-soft:#2a2110;--info:#93b4ff;--info-soft:#15233f;--shadow-sm:0 1px 2px rgba(0,0,0,.4);--shadow:0 10px 28px -12px rgba(0,0,0,.66),0 3px 10px -4px rgba(0,0,0,.5);--shadow-lg:0 40px 70px -24px rgba(0,0,0,.8),0 10px 24px -12px rgba(0,0,0,.6);--ring:0 0 0 4px rgba(20,212,102,.22);--grid-line:rgba(120,200,160,.05);--glow-1:rgba(6,199,85,.18);--glow-2:rgba(6,199,85,.08);--code-bg:#050d09;--code-fg:#b6f2cb;color-scheme:dark}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;min-height:100vh;font-family:var(--font-body);font-weight:400;color:var(--ink);letter-spacing:.1px;background:radial-gradient(1000px 560px at 100% -8%,var(--glow-1),transparent 58%),radial-gradient(760px 620px at -12% 112%,var(--glow-2),transparent 55%),var(--bg);background-attachment:fixed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(circle at 50% 30%,#000 0,transparent 78%);-webkit-mask-image:radial-gradient(circle at 50% 30%,#000 0,transparent 78%)}h1,h2,h3{font-family:var(--font-display);font-weight:600;letter-spacing:-.2px;color:var(--ink)}a{color:var(--brand-deep);text-decoration:none}code,pre{font-family:var(--font-mono)}::selection{background:rgba(6,199,85,.22)}.page{position:relative;z-index:1}.topbar{justify-content:space-between;gap:16px;flex-wrap:wrap}.brand,.topbar{display:flex;align-items:center}.brand{gap:12px}.brand-mark{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;font-size:20px;color:#fff;background:linear-gradient(150deg,var(--brand) 0,var(--brand-darker) 100%);box-shadow:0 8px 18px -6px rgba(6,199,85,.55),inset 0 1px 0 hsla(0,0%,100%,.35);flex-shrink:0}.brand h1{margin:0;font-size:22px;line-height:1.15}.brand .sub{font-size:12.5px;color:var(--muted);margin-top:2px}.userchip{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-soft);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 8px 6px 14px;box-shadow:var(--shadow-sm)}.admin-tag{font-size:11px;font-weight:600;background:var(--brand-soft);color:var(--brand-ink);padding:2px 9px;border-radius:999px;letter-spacing:.2px}.card{position:relative;padding:20px;box-shadow:var(--shadow)}.card,.card-flat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}.card-flat{padding:18px;box-shadow:var(--shadow-sm)}.btn{font-family:var(--font-body);font-size:14px;font-weight:600;border:0;border-radius:var(--radius-sm);padding:10px 18px;cursor:pointer;transition:transform .12s ease,box-shadow .18s ease,background .18s ease,opacity .18s ease;display:inline-flex;align-items:center;gap:7px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:linear-gradient(150deg,var(--brand) 0,var(--brand-deep) 100%);box-shadow:0 10px 22px -10px rgba(6,199,85,.7),inset 0 1px 0 hsla(0,0%,100%,.3)}.btn-primary:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 16px 28px -12px rgba(6,199,85,.8),inset 0 1px 0 hsla(0,0%,100%,.3)}.btn-primary:not(:disabled):active{transform:translateY(0)}.btn-ghost{color:var(--ink-soft);background:var(--surface-2);border:1px solid var(--line)}.btn-ghost:not(:disabled):hover{background:var(--surface-3);border-color:var(--line-strong)}.btn-link{background:none;border:0;padding:0;font-size:13px;color:var(--brand-deep);cursor:pointer;font-weight:500}.btn-link:hover{color:var(--brand-darker);text-decoration:underline}.field-label{font-size:12.5px;font-weight:500;color:var(--ink-soft);margin-bottom:6px;display:block}.input{width:100%;font-family:var(--font-body);font-size:14.5px;color:var(--ink);background:var(--surface);border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);padding:11px 14px;transition:border-color .16s ease,box-shadow .16s ease;outline:none}.input::placeholder{color:var(--muted)}.input:focus{border-color:var(--brand);box-shadow:var(--ring)}textarea.input{resize:vertical;line-height:1.6}.chip{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--brand-ink);background:var(--brand-soft);border:1px solid rgba(6,199,85,.28);border-radius:999px;padding:7px 14px;cursor:pointer;transition:transform .12s ease,background .16s ease,box-shadow .16s ease}.chip:not(:disabled):hover{transform:translateY(-1px);background:#d4f4e0;box-shadow:0 6px 14px -8px rgba(6,199,85,.6)}.chip:disabled{opacity:.5;cursor:not-allowed}.badge{font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:999px;white-space:nowrap;letter-spacing:.1px}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{text-align:left;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-size:11px;padding:8px 10px;border-bottom:1.5px solid var(--line)}.tbl td,.tbl th{white-space:nowrap}.tbl td{padding:9px 10px;border-bottom:1px solid var(--surface-3);color:var(--ink-soft)}.tbl tbody tr{transition:background .12s ease}.tbl tbody tr:hover{background:var(--surface-2)}.codeblock{background:var(--code-bg);color:var(--code-fg);padding:14px 16px;border-radius:var(--radius-sm);overflow-x:auto;font-size:13px;font-family:var(--font-mono);line-height:1.55;margin:6px 0 0;border:1px solid rgba(6,199,85,.18);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.04)}*{scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:999px;border:3px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background:var(--muted);background-clip:content-box}.auth-shell{position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{width:100%;max-width:384px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px 30px;box-shadow:var(--shadow-lg)}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.reveal,.stagger>*{opacity:0;animation:fadeUp .55s cubic-bezier(.22,1,.36,1) forwards}.stagger>:first-child{animation-delay:.04s}.stagger>:nth-child(2){animation-delay:.1s}.stagger>:nth-child(3){animation-delay:.16s}.stagger>:nth-child(4){animation-delay:.22s}.stagger>:nth-child(5){animation-delay:.28s}.stagger>:nth-child(6){animation-delay:.34s}.stagger>:nth-child(7){animation-delay:.4s}.stagger>:nth-child(8){animation-delay:.46s}@media (prefers-reduced-motion:reduce){.reveal,.stagger>*{animation:none;opacity:1}}.btn-ghost,.card,.card-flat,.input,.userchip{transition:background-color .25s ease,border-color .25s ease,color .25s ease,box-shadow .2s ease,transform .12s ease}.shell{position:relative;z-index:1;display:flex;min-height:100vh}.sidebar{position:-webkit-sticky;position:sticky;top:0;align-self:flex-start;width:256px;flex-shrink:0;height:100vh;display:flex;flex-direction:column;padding:22px 16px;gap:6px;background:color-mix(in srgb,var(--surface) 72%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-right:1px solid var(--line)}.sidebar .brand{padding:4px 8px 18px}.sidebar .brand h1{font-size:17px}.nav-group-label{font-size:10.5px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);padding:14px 12px 6px}.nav-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--ink-soft);font-size:14px;font-weight:500;cursor:pointer;text-decoration:none;border:1px solid transparent;transition:background .16s ease,color .16s ease,border-color .16s ease}.nav-link .nav-ico{width:22px;text-align:center;font-size:16px;flex-shrink:0}.nav-link:hover{background:var(--surface-2);color:var(--ink)}.nav-link.active{background:var(--brand-soft);color:var(--brand-ink);border-color:rgba(6,199,85,.28);font-weight:600}.topbar-user{display:flex;align-items:center;gap:10px;flex-shrink:0}.shell-main{flex:1 1;min-width:0;display:flex;flex-direction:column}.shell-topbar{position:-webkit-sticky;position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:14px;padding:16px 26px;background:color-mix(in srgb,var(--bg) 78%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.shell-topbar .title{margin:0;font-size:19px;line-height:1.2}.shell-topbar .sub{font-size:12.5px;color:var(--muted);margin-top:2px}.shell-content{padding:26px;width:100%;max-width:1180px;margin:0 auto}.theme-toggle{display:inline-flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:7px 14px;cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--ink-soft);transition:background .16s ease,border-color .16s ease,color .16s ease}.theme-toggle:hover{background:var(--surface-3);border-color:var(--line-strong);color:var(--ink)}.theme-toggle .ico{font-size:15px}.icon-btn{width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface);cursor:pointer;font-size:18px;color:var(--ink);align-items:center;justify-content:center}.icon-btn,.sidebar-backdrop{display:none}@media (max-width:880px){.icon-btn{display:inline-flex}.sidebar{position:fixed;left:0;top:0;z-index:40;transform:translateX(-100%);transition:transform .28s cubic-bezier(.22,1,.36,1);box-shadow:var(--shadow-lg);background:var(--surface)}.sidebar.open{transform:translateX(0)}.sidebar-backdrop.show{display:block;position:fixed;inset:0;z-index:30;background:rgba(4,10,7,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.shell-content{padding:18px}.shell-topbar{padding:14px 18px}}@media (max-width:600px){.shell-topbar .sub,.topbar-user .userchip{display:none}}