*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}[hidden]{display:none!important}:root{--brand-50: #eff6ff;--brand-100: #dbeafe;--brand-200: #bfdbfe;--brand-400: #60a5fa;--brand-500: #3b82f6;--brand-600: #2563eb;--brand-700: #1d4ed8;--brand-800: #1e40af;--brand-900: #1e3a8a;--brand-950: #0b1e3f;--bg: #f5f7fb;--bg-elevated: #ffffff;--bg-muted: #f1f4f9;--surface: #ffffff;--surface-hover: #f8fafc;--border: #e6ebf2;--border-strong: #d6dde7;--text: #0f172a;--text-muted: #475569;--text-faint: #94a3b8;--primary: var(--brand-700);--primary-hover: var(--brand-800);--primary-soft: var(--brand-50);--primary-soft-strong: var(--brand-100);--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow-md: 0 4px 14px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .1), 0 2px 6px rgba(15, 23, 42, .05);--shadow-brand: 0 8px 24px rgba(29, 78, 216, .25);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 24px;--radius-full: 999px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--font-sans: "Sarabun", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans Thai", sans-serif;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1)}[data-theme=dark]{--bg: #0a1020;--bg-elevated: #111a2e;--bg-muted: #0f172a;--surface: #131c34;--surface-hover: #19243f;--border: #1f2a47;--border-strong: #2a3a5c;--text: #e6ebf5;--text-muted: #a7b3c8;--text-faint: #6b7794;--primary: var(--brand-400);--primary-hover: var(--brand-500);--primary-soft: rgba(96, 165, 250, .12);--primary-soft-strong: rgba(96, 165, 250, .22);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 14px rgba(0, 0, 0, .35);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .45);--shadow-brand: 0 10px 30px rgba(59, 130, 246, .3)}body{font-family:var(--font-sans);color:var(--text);background:var(--bg);background-image:radial-gradient(900px 500px at 110% -10%,rgba(59,130,246,.08),transparent 60%),radial-gradient(700px 400px at -20% 0%,rgba(29,78,216,.06),transparent 60%);min-height:100dvh;overflow-x:hidden}[data-theme=dark] body{background-image:radial-gradient(900px 500px at 110% -10%,rgba(59,130,246,.18),transparent 60%),radial-gradient(700px 400px at -20% 0%,rgba(29,78,216,.16),transparent 60%)}.app{max-width:1180px;margin:0 auto;padding:calc(var(--safe-top) + 12px) 16px calc(var(--safe-bottom) + 32px)}.appbar{position:sticky;top:var(--safe-top);z-index:30;margin:-12px -16px 12px;padding:8px 16px 12px;background:linear-gradient(180deg,var(--bg) 70%,transparent);backdrop-filter:saturate(140%) blur(8px);-webkit-backdrop-filter:saturate(140%) blur(8px)}.appbar__inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 4px}.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand__logo{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:var(--surface);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.brand__text{display:flex;flex-direction:column;line-height:1.1;min-width:0}.brand__title{font-weight:700;font-size:17px;letter-spacing:-.01em;color:var(--text)}.brand__subtitle{font-size:11px;font-weight:500;color:var(--text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:.08em}.appbar__actions{display:flex;align-items:center;gap:8px}.icon-btn{width:40px;height:40px;display:grid;place-items:center;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;position:relative;overflow:hidden;transition:transform .2s var(--ease-out),background .2s,border-color .2s,color .2s}.icon-btn:hover{background:var(--surface-hover);border-color:var(--border-strong)}.icon-btn:active{transform:scale(.92)}.theme-icon{position:absolute;transition:transform .45s var(--ease-out),opacity .3s}[data-theme=light] .theme-icon--sun{opacity:1;transform:rotate(0) scale(1)}[data-theme=light] .theme-icon--moon{opacity:0;transform:rotate(-90deg) scale(.6)}[data-theme=dark] .theme-icon--sun{opacity:0;transform:rotate(90deg) scale(.6)}[data-theme=dark] .theme-icon--moon{opacity:1;transform:rotate(0) scale(1)}.search{position:relative;display:flex;align-items:center;gap:10px;padding:0 14px;height:48px;background:var(--surface);border-radius:var(--radius-full);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s,transform .2s var(--ease-out)}.search:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}.search__icon{color:var(--text-faint);flex-shrink:0}.search input{flex:1;height:100%;border:0;outline:0;background:transparent;font-family:inherit;font-size:15px;color:var(--text);min-width:0}.search input::placeholder{color:var(--text-faint)}.search input::-webkit-search-cancel-button{display:none}.search__clear{width:28px;height:28px;border:0;background:var(--bg-muted);color:var(--text-muted);border-radius:var(--radius-full);display:grid;place-items:center;cursor:pointer;transition:background .15s,color .15s,transform .15s}.search__clear:hover{background:var(--border);color:var(--text)}.search__clear:active{transform:scale(.9)}.main{display:flex;flex-direction:column;gap:20px}.hero{padding:6px 4px 4px}.hero__greeting{font-size:24px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.hero__subtitle{margin-top:4px;font-size:14px;color:var(--text-muted)}.section{display:flex;flex-direction:column;gap:12px}.section__header{display:flex;align-items:center;justify-content:space-between;padding:0 4px}.section__title{display:inline-flex;align-items:center;gap:8px;margin:0;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted)}.section__title svg{color:var(--primary)}.section__count{font-size:12px;font-weight:600;color:var(--text-faint);background:var(--surface);border:1px solid var(--border);padding:3px 10px;border-radius:var(--radius-full)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}@media (min-width: 640px){.grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}}@media (min-width: 900px){.grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}}.card{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:14px;padding:18px 16px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-decoration:none;color:var(--text);cursor:pointer;overflow:hidden;transition:transform .3s var(--ease-out),box-shadow .3s,border-color .2s,background .2s;-webkit-user-select:none;user-select:none;animation:cardIn .45s var(--ease-out) both}@keyframes cardIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.card:before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 0% 0%,var(--primary-soft) 0%,transparent 55%);opacity:0;transition:opacity .3s var(--ease-out);pointer-events:none}.card:hover{transform:translateY(-2px);border-color:var(--primary-soft-strong);box-shadow:var(--shadow-lg)}.card:hover:before{opacity:1}.card:active{transform:translateY(0) scale(.985);transition-duration:.1s}.card__icon{position:relative;width:48px;height:48px;display:grid;place-items:center;border-radius:14px;color:#fff;flex-shrink:0;transition:transform .4s var(--ease-out),box-shadow .3s;background:linear-gradient(135deg,var(--icon-color, var(--brand-600)),var(--icon-color-2, var(--brand-800)));box-shadow:0 6px 16px var(--icon-shadow, rgba(29, 78, 216, .28))}.card:hover .card__icon{transform:scale(1.08) rotate(-3deg)}.card:hover .card__icon:after{opacity:1;transform:scale(1)}.card__icon:after{content:"";position:absolute;inset:-4px;border-radius:18px;background:inherit;opacity:0;filter:blur(14px);transform:scale(.85);transition:opacity .4s,transform .4s;z-index:-1}.card__icon svg{width:24px;height:24px;stroke:#fff}.card__body{position:relative;z-index:1}.card__title{font-size:15px;font-weight:600;line-height:1.25;letter-spacing:-.005em;margin:0;color:var(--text)}.card__subtitle{margin-top:4px;font-size:12px;color:var(--text-muted);line-height:1.4}.card__pin{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:var(--radius-full);border:0;background:transparent;color:var(--text-faint);cursor:pointer;display:grid;place-items:center;z-index:2;opacity:0;transform:scale(.8);transition:opacity .2s,transform .2s var(--ease-out),background .15s,color .15s}.card:hover .card__pin,.card__pin.is-pinned,.card:focus-within .card__pin{opacity:1;transform:scale(1)}.card__pin:hover{background:var(--bg-muted);color:var(--text)}.card__pin.is-pinned{color:#f59e0b}.card__pin:active{transform:scale(.85)}.card__pin svg{width:18px;height:18px;transition:transform .3s var(--ease-out)}.card__pin.is-pinned svg{transform:rotate(8deg) scale(1.05)}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);color:var(--text-muted);animation:cardIn .35s var(--ease-out) both}.empty__icon{width:64px;height:64px;border-radius:var(--radius-full);background:var(--bg-muted);display:grid;place-items:center;color:var(--text-faint);margin-bottom:14px}.empty__title{font-weight:600;font-size:16px;color:var(--text)}.empty__subtitle{margin-top:4px;font-size:13px}.footer{margin-top:28px;padding:16px 4px;display:flex;align-items:center;justify-content:space-between;color:var(--text-faint);font-size:12px}.footer__version{font-feature-settings:"tnum"}mark{background:var(--primary-soft-strong);color:var(--primary);padding:0 2px;border-radius:4px;font-weight:600}.ripple{position:absolute;border-radius:50%;transform:scale(0);background:#3b82f640;animation:ripple .6s var(--ease-out);pointer-events:none}@keyframes ripple{to{transform:scale(4);opacity:0}}.login{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:calc(var(--safe-top) + 24px) 20px calc(var(--safe-bottom) + 24px);overflow-y:auto;animation:fadeIn .4s var(--ease-out)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login__bg{position:absolute;inset:0;z-index:-1;background:radial-gradient(900px 600px at 90% -10%,rgba(59,130,246,.22),transparent 60%),radial-gradient(700px 500px at -10% 110%,rgba(29,78,216,.2),transparent 60%),linear-gradient(180deg,var(--bg) 0%,var(--bg-muted) 100%)}[data-theme=dark] .login__bg{background:radial-gradient(900px 600px at 90% -10%,rgba(59,130,246,.3),transparent 60%),radial-gradient(700px 500px at -10% 110%,rgba(29,78,216,.35),transparent 60%),linear-gradient(180deg,var(--bg) 0%,#060a18 100%)}.login__card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px 28px 24px;box-shadow:var(--shadow-lg);text-align:center;animation:cardPop .55s var(--ease-out)}@keyframes cardPop{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login__logo{width:64px;height:64px;display:grid;place-items:center;margin:0 auto 18px;background:var(--surface);border-radius:18px;box-shadow:var(--shadow-brand);border:1px solid var(--border)}.login__title{margin:0;font-size:22px;font-weight:700;letter-spacing:-.01em;color:var(--text)}.login__subtitle{margin:8px 0 24px;font-size:14px;color:var(--text-muted);line-height:1.55}.login__hint{font-size:12px;color:var(--text-faint)}.login__form{display:flex;flex-direction:column;gap:14px;text-align:left}.login__footer{margin-top:22px;font-size:11px;color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase}.field{display:flex;flex-direction:column;gap:6px}.field__label{font-size:13px;font-weight:600;color:var(--text-muted);padding-left:2px}.field__input{position:relative;display:flex;align-items:center;gap:10px;padding:0 14px;height:48px;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color .2s,background .2s,box-shadow .2s}.field__input:focus-within{background:var(--surface);border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}.field__icon{color:var(--text-faint);flex-shrink:0;transition:color .2s}.field__input:focus-within .field__icon{color:var(--primary)}.field__input input{flex:1;height:100%;border:0;outline:0;background:transparent;font-family:inherit;font-size:15px;color:var(--text);min-width:0}.field__input input::placeholder{color:var(--text-faint)}.field--error .field__input{border-color:#ef4444;background:#ef44440a}.field--error .field__input:focus-within{box-shadow:0 0 0 4px #ef44441f}.field__error{min-height:0;font-size:12px;color:#ef4444;padding-left:2px;font-weight:500;opacity:0;transition:opacity .2s}.field--error .field__error{opacity:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:48px;padding:0 22px;border:0;border-radius:var(--radius-md);font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;transition:transform .15s var(--ease-out),background .2s,box-shadow .2s,opacity .2s;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn--primary{background:linear-gradient(135deg,var(--brand-600),var(--brand-800));color:#fff;box-shadow:var(--shadow-brand)}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg,var(--brand-700),var(--brand-900));box-shadow:0 12px 28px #1d4ed859}[data-theme=dark] .btn--primary{background:linear-gradient(135deg,var(--brand-500),var(--brand-700))}.btn--block{width:100%;margin-top:4px}.btn--ghost{background:var(--bg-muted);color:var(--text)}.btn--ghost:hover:not(:disabled){background:var(--border)}.appbar__inner{position:relative}.avatar-btn{width:40px;height:40px;border-radius:var(--radius-full);border:1px solid var(--border);background:linear-gradient(135deg,var(--brand-500),var(--brand-800));color:#fff;font-family:inherit;font-weight:700;font-size:13px;letter-spacing:.02em;cursor:pointer;display:grid;place-items:center;transition:transform .2s var(--ease-out),box-shadow .2s;box-shadow:var(--shadow-sm)}.avatar-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-brand)}.avatar-btn:active{transform:scale(.92)}.popover{position:fixed;top:calc(var(--safe-top) + 64px);right:16px;width:260px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:8px;z-index:60;animation:popIn .22s var(--ease-out);transform-origin:top right}@keyframes popIn{0%{opacity:0;transform:scale(.96) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.popover__user{display:flex;align-items:center;gap:12px;padding:10px 10px 12px}.popover__avatar{width:44px;height:44px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--brand-500),var(--brand-800));color:#fff;font-weight:700;font-size:15px;display:grid;place-items:center;flex-shrink:0}.popover__info{min-width:0;flex:1}.popover__name{font-weight:600;font-size:14px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.popover__emp{font-size:12px;color:var(--text-muted);margin-top:2px;font-feature-settings:"tnum"}.popover__divider{height:1px;background:var(--border);margin:4px 0}.popover__item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:0;background:transparent;border-radius:var(--radius-sm);font-family:inherit;font-size:14px;color:var(--text);cursor:pointer;text-align:left;transition:background .15s,color .15s}.popover__item:hover{background:var(--bg-muted)}.popover__item svg{color:var(--text-muted);flex-shrink:0}.popover__item--danger{color:#ef4444}.popover__item--danger svg{color:#ef4444}.popover__item--danger:hover{background:#ef444414}.popover-backdrop{position:fixed;inset:0;z-index:49}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
