:root{--bg-0: #07081a;--bg-1: #0c0d24;--bg-2: #12132e;--surface: rgba(22, 24, 56, .55);--surface-2: rgba(30, 32, 70, .7);--border: rgba(139, 92, 246, .18);--border-strong: rgba(139, 92, 246, .35);--text-hi: #eef0ff;--text-md: #a4a8cf;--text-lo: #6b6f95;--primary: #8b5cf6;--primary-2: #6366f1;--primary-3: #3b82f6;--accent: #22d3ee;--pink: #f472b6;--success: #10d997;--warning: #fbbf24;--danger: #f43f5e;--grad-primary: linear-gradient(135deg, #8b5cf6 0%, #6366f1 50%, #3b82f6 100%);--grad-pink: linear-gradient(135deg, #ec4899 0%, #8b5cf6 100%);--grad-cyan: linear-gradient(135deg, #06b6d4 0%, #6366f1 100%);--grad-success: linear-gradient(135deg, #10d997 0%, #06b6d4 100%);--grad-warning: linear-gradient(135deg, #fbbf24 0%, #f97316 100%);--grad-danger: linear-gradient(135deg, #f43f5e 0%, #ec4899 100%);--shadow-glow: 0 0 0 1px rgba(139,92,246,.2), 0 20px 60px -20px rgba(139,92,246,.4);--shadow-card: 0 4px 30px rgba(0,0,0,.3);--radius: 14px;--radius-sm: 10px;--radius-lg: 20px;--r-md: 12px;--font-display: "Space Grotesk", "IBM Plex Sans Thai", system-ui, sans-serif;--font-body: "IBM Plex Sans Thai", "Manrope", system-ui, sans-serif;--font-mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, monospace}[data-theme=light]{--bg-0: #f1f3fb;--bg-1: #ffffff;--bg-2: #f7f8fe;--surface: rgba(255, 255, 255, .7);--surface-2: rgba(255, 255, 255, .9);--border: rgba(99, 102, 241, .14);--border-strong: rgba(99, 102, 241, .28);--text-hi: #0e1130;--text-md: #555a7e;--text-lo: #8b8fb1;--shadow-glow: 0 0 0 1px rgba(99,102,241,.15), 0 20px 60px -20px rgba(99,102,241,.35);--shadow-card: 0 4px 24px rgba(15,18,60,.08)}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body{margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg-0);color:var(--text-hi);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;overflow-x:hidden}.app-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(900px 600px at 10% -10%,rgba(139,92,246,.25),transparent 60%),radial-gradient(800px 600px at 100% 0%,rgba(59,130,246,.22),transparent 60%),radial-gradient(700px 500px at 50% 100%,rgba(34,211,238,.14),transparent 60%),var(--bg-0)}[data-theme=light] .app-bg{background:radial-gradient(900px 600px at 10% -10%,rgba(139,92,246,.18),transparent 60%),radial-gradient(800px 600px at 100% 0%,rgba(59,130,246,.15),transparent 60%),var(--bg-0)}#particle-canvas{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.app-shell{position:relative;z-index:2;min-height:100vh;display:flex}.sidebar{width:260px;flex-shrink:0;background:linear-gradient(180deg,#0c0d24eb,#0c0d24d9);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--border);position:sticky;top:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column;z-index:50}[data-theme=light] .sidebar{background:linear-gradient(180deg,#fffffff2,#ffffffd9)}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:#8b5cf666;border-radius:4px}.sb-brand{padding:22px 18px 18px;display:flex;align-items:center;border-bottom:1px solid var(--border)}.sb-logo{width:40px;height:40px;border-radius:11px;flex-shrink:0;background:#ffffffeb;display:grid;place-items:center;box-shadow:0 8px 24px -6px #3b82f661;position:relative;overflow:hidden}.sb-logo img{width:32px;height:32px;object-fit:contain;display:block}.sb-brand-wordmark{width:178px;max-width:100%;height:auto;display:block}.sb-brand-text{display:flex;flex-direction:column;gap:2px}.sb-brand-title{font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:-.01em;color:var(--text-hi)}.sb-brand-sub{font-size:11px;color:var(--text-lo);letter-spacing:.06em;text-transform:uppercase}.sb-section{padding:14px 12px 4px}.sb-section-label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-lo);padding:0 10px 6px;font-weight:600}.sb-item{display:flex;align-items:center;gap:12px;padding:10px 12px;margin:2px 0;border-radius:10px;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-md);font-size:13.5px;font-weight:500;transition:background .2s ease,color .2s ease,transform .15s ease;position:relative}.sb-item:hover{background:#8b5cf614;color:var(--text-hi)}.sb-item.active{background:linear-gradient(90deg,#8b5cf62e,#6366f10f);color:var(--text-hi)}.sb-item.active:before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;background:var(--grad-primary);border-radius:0 4px 4px 0;box-shadow:0 0 12px #8b5cf6cc}.sb-icon{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:#8b5cf614;color:var(--text-md);flex-shrink:0}.sb-item.active .sb-icon{background:var(--grad-primary);color:#fff;box-shadow:0 4px 14px -2px #8b5cf699}.sb-icon svg{width:14px;height:14px}.sb-badge{margin-left:auto;font-size:10px;font-weight:700;background:var(--grad-danger);color:#fff;padding:2px 7px;border-radius:100px;letter-spacing:.04em}.sb-foot{margin-top:auto;padding:14px 14px 18px;border-top:1px solid var(--border)}.sb-user{display:flex;align-items:center;gap:11px;padding:8px;border-radius:12px;background:#8b5cf60f}.sb-avatar{width:36px;height:36px;border-radius:10px;flex-shrink:0;background:var(--grad-pink);display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;position:relative}.sb-avatar:after{content:"";position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-radius:50%;background:var(--success);border:2px solid var(--bg-1)}.sb-user-info{display:flex;flex-direction:column;min-width:0}.sb-user-name{font-size:13px;font-weight:600;color:var(--text-hi)}.sb-user-role{font-size:11px;color:var(--text-lo)}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:68px;padding:0 28px;display:flex;align-items:center;gap:16px;background:#0c0d2480;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:30}[data-theme=light] .topbar{background:#ffffffb3}.tb-title{font-family:var(--font-display);font-weight:700;font-size:19px;letter-spacing:-.01em}.tb-sub{font-size:12px;color:var(--text-lo)}.tb-search{margin-left:auto;min-width:280px;height:40px;background:#8b5cf60f;border:1px solid var(--border);border-radius:10px;padding:0 14px;display:flex;align-items:center;gap:10px;color:var(--text-md)}.tb-search input{background:transparent;border:0;outline:0;color:var(--text-hi);font-family:var(--font-body);font-size:13px;width:100%}.tb-search input::placeholder{color:var(--text-lo)}.tb-icon-btn{width:40px;height:40px;border-radius:10px;background:#8b5cf60f;border:1px solid var(--border);display:grid;place-items:center;cursor:pointer;color:var(--text-md);position:relative;transition:background .2s ease,color .2s ease,transform .15s ease;-webkit-user-select:none;user-select:none}.tb-icon-btn:hover{background:#8b5cf624;color:var(--text-hi)}.tb-icon-btn:active{transform:scale(.92)}.tb-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--danger);box-shadow:0 0 10px var(--danger)}.page{padding:28px;flex:1}.card{background:var(--surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-card)}.card-title{font-family:var(--font-display);font-weight:700;font-size:16px;margin:0 0 4px;letter-spacing:-.01em}.card-sub{font-size:12px;color:var(--text-lo);margin-bottom:14px}.stat{background:var(--surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius);padding:18px;position:relative;overflow:hidden}.stat:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--grad-primary);opacity:.7}.stat .stat-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.stat-icon{width:36px;height:36px;border-radius:10px;background:#8b5cf624;color:var(--primary);display:grid;place-items:center}.stat-icon.cyan{background:#22d3ee24;color:var(--accent)}.stat-icon.green{background:#10d99724;color:var(--success)}.stat-icon.pink{background:#f472b624;color:var(--pink)}.stat-icon.amber{background:#fbbf2424;color:var(--warning)}.stat-label{font-size:12px;color:var(--text-lo);letter-spacing:.04em;text-transform:uppercase;font-weight:600}.stat-value{font-family:var(--font-display);font-weight:700;font-size:28px;letter-spacing:-.02em;margin-top:4px;color:var(--text-hi)}.stat-delta{display:inline-flex;align-items:center;gap:4px;font-size:12px;margin-top:8px;font-weight:600;font-family:var(--font-mono)}.stat-delta.up{color:var(--success)}.stat-delta.down{color:var(--danger)}.btn{height:40px;padding:0 18px;border-radius:10px;border:1px solid var(--border);background:#8b5cf614;color:var(--text-hi);font-family:var(--font-body);font-weight:600;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background 80ms ease,transform 80ms ease,box-shadow 80ms ease}.btn:hover{background:#8b5cf62e;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn.primary{background:var(--grad-primary);border:0;box-shadow:0 8px 24px -8px #8b5cf6b3,inset 0 1px #fff3;color:#fff}.btn.primary:hover{box-shadow:0 12px 30px -8px #8b5cf6e6,inset 0 1px #fff3}.btn.danger{background:var(--grad-danger);border:0;color:#fff;box-shadow:0 8px 20px -6px #f43f5e80}.btn.success{background:var(--grad-success);border:0;color:#fff;box-shadow:0 8px 20px -6px #10d99780}.btn.ghost{background:transparent;border:1px solid var(--border)}.btn.sm{height:32px;padding:0 12px;font-size:12px}.btn.lg{height:48px;padding:0 24px;font-size:14px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:14px;height:14px}.input,.select,.textarea{width:100%;height:42px;background:#0c0d2499;border:1px solid var(--border);border-radius:10px;padding:0 14px;color:var(--text-hi);font-family:var(--font-body);font-size:13.5px;outline:0;transition:border-color 80ms ease,box-shadow 80ms ease}[data-theme=light] .input,[data-theme=light] .select,[data-theme=light] .textarea{background:#ffffffb3}[data-theme=light] .input:focus,[data-theme=light] .select:focus,[data-theme=light] .textarea:focus{background:#fffffff2}.textarea{height:auto;padding:12px 14px;resize:vertical;min-height:80px;font-family:var(--font-body)}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px #8b5cf62e;background:#0c0d24d9}.input::placeholder,.textarea::placeholder{color:var(--text-lo)}.input-label{font-size:12px;color:var(--text-md);margin-bottom:6px;font-weight:600;display:block;letter-spacing:.02em}.input-hint{font-size:11px;color:var(--text-lo);margin-top:4px}.input-group{position:relative}.input-group .input{padding-right:42px}.input-icon-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:30px;height:30px;border:0;background:transparent;color:var(--text-lo);cursor:pointer;border-radius:7px;display:grid;place-items:center}.input-icon-btn:hover{background:#8b5cf61a;color:var(--text-hi)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a4a8cf' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:36px}.tbl-wrap{background:var(--surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.tbl-head{padding:16px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.tbl-head .card-title{margin:0}.tbl-scroll{overflow-x:auto}.tbl{width:100%;border-collapse:collapse;font-size:13px;min-width:700px}.tbl thead th{text-align:left;padding:12px 16px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-lo);background:#8b5cf60d;border-bottom:1px solid var(--border)}.tbl tbody td{padding:14px 16px;border-bottom:1px solid var(--border);color:var(--text-md);vertical-align:middle}.tbl tbody tr:hover{background:#8b5cf60a}.tbl tbody tr:last-child td{border-bottom:0}.tbl .row-strong{color:var(--text-hi);font-weight:600}.tbl .mono{font-family:var(--font-mono);font-size:12px}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:100px;font-size:11px;font-weight:700;letter-spacing:.04em;line-height:1.6}.badge.violet{background:#8b5cf629;color:#c4b5fd}.badge.cyan{background:#22d3ee29;color:#7dd3fc}.badge.green{background:#10d99729;color:#6ee7b7}.badge.amber{background:#fbbf2429;color:#fcd34d}.badge.red{background:#f43f5e29;color:#fda4af}.badge.gray{background:#6b6f9529;color:var(--text-md)}.badge.dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{pointer-events:auto;min-width:280px;max-width:380px;background:var(--surface-2);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--border-strong);border-radius:12px;padding:14px 16px;display:flex;gap:12px;align-items:flex-start;box-shadow:0 16px 50px -10px #00000080;animation:toastIn .3s cubic-bezier(.2,.9,.3,1.2);position:relative;overflow:hidden}.toast.exit{animation:toastOut .25s ease-in forwards}.toast:before{content:"";position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--grad-primary)}.toast.success:before{background:var(--grad-success)}.toast.error:before{background:var(--grad-danger)}.toast.warning:before{background:var(--grad-warning)}.toast.info:before{background:var(--grad-cyan)}.toast.loading:before{background:var(--grad-primary)}.toast-progress{position:absolute;bottom:0;left:0;height:2px;background:linear-gradient(90deg,var(--primary),var(--accent));animation:toastProg linear forwards}.toast-ico{width:32px;height:32px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;color:#fff}.toast.success .toast-ico{background:var(--grad-success)}.toast.error .toast-ico{background:var(--grad-danger)}.toast.warning .toast-ico{background:var(--grad-warning)}.toast.info .toast-ico{background:var(--grad-cyan)}.toast.loading .toast-ico{background:var(--grad-primary)}.toast-body{flex:1;min-width:0}.toast-title{font-size:13px;font-weight:700;color:var(--text-hi)}.toast-msg{font-size:12px;color:var(--text-md);margin-top:2px}.toast-close{background:transparent;border:0;color:var(--text-lo);cursor:pointer;padding:4px}.toast-close:hover{color:var(--text-hi)}.toast-spin{animation:spin .9s linear infinite}@keyframes toastIn{0%{opacity:0;transform:translate(100%) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toastOut{to{opacity:0;transform:translate(120%) scale(.9)}}@keyframes toastProg{0%{width:100%}to{width:0%}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;background:#020418b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;place-items:center;animation:fadeIn .2s ease;padding:20px}.modal{background:var(--bg-1);border:1px solid var(--border-strong);border-radius:18px;padding:24px;width:min(560px,100%);max-height:90vh;overflow-y:auto;box-shadow:0 30px 90px -20px #000c,0 0 0 1px #8b5cf633;animation:modalIn .25s cubic-bezier(.2,.9,.3,1.1)}.modal.wide{width:min(760px,100%)}.modal.x-wide{width:min(960px,100%)}.modal-head{display:flex;align-items:center;gap:12px;margin-bottom:18px}.modal-head .title{font-family:var(--font-display);font-weight:700;font-size:18px;flex:1;letter-spacing:-.01em}.modal-close{width:32px;height:32px;border-radius:8px;border:0;background:#8b5cf614;color:var(--text-md);cursor:pointer;display:grid;place-items:center}.modal-close:hover{background:#f43f5e29;color:var(--danger)}.modal-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;padding-top:18px;border-top:1px solid var(--border)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.login-wrap{min-height:100vh;display:grid;place-items:center;position:relative;z-index:2;padding:24px}.login-card{width:min(420px,100%);padding:40px 32px 32px;background:#1416328c;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--border-strong);border-radius:24px;box-shadow:var(--shadow-glow),0 30px 90px -10px #000000b3;position:relative;overflow:hidden}[data-theme=light] .login-card{background:#ffffffa6}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.8),transparent)}.login-logo{width:132px;height:118px;border-radius:0;margin:0 auto 18px;background:transparent;display:grid;place-items:center;box-shadow:none}.login-logo img{width:132px;height:118px;object-fit:contain;display:block}.login-title{text-align:center;font-family:var(--font-display);font-weight:700;font-size:24px;margin:0 0 6px;letter-spacing:-.02em;background:linear-gradient(135deg,#fff,#c4b5fd);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}[data-theme=light] .login-title{background:linear-gradient(135deg,#1e1b4b,#6366f1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.login-sub{text-align:center;color:var(--text-md);font-size:13px;margin-bottom:28px}.login-field{margin-bottom:14px}.login-error{background:#f43f5e1f;border:1px solid rgba(244,63,94,.3);color:#fda4af;padding:10px 14px;border-radius:10px;font-size:12.5px;display:flex;align-items:center;gap:8px;margin-bottom:14px;animation:shake .4s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.login-help{margin-top:18px;padding-top:16px;border-top:1px solid var(--border);font-size:11.5px;color:var(--text-lo);text-align:center;font-family:var(--font-mono)}.login-help b{color:var(--accent);font-weight:600}.spin{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;animation:spin .7s linear infinite}.spin.lg{width:28px;height:28px;border-width:3px}.grid{display:grid;gap:18px}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:1fr 1fr}.grid-2-3{grid-template-columns:2fr 3fr}.grid-3-1{grid-template-columns:3fr 1fr}.grid-2-1{grid-template-columns:2fr 1fr}.empty{padding:60px 20px;text-align:center}.empty-ico{width:64px;height:64px;border-radius:16px;margin:0 auto 14px;background:#8b5cf61a;color:var(--primary);display:grid;place-items:center}.empty h3{margin:0 0 4px;font-family:var(--font-display);font-size:16px}.empty p{margin:0;color:var(--text-lo);font-size:13px}.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:8px;font-size:12px;font-weight:600;background:#8b5cf614;border:1px solid var(--border);color:var(--text-md);cursor:pointer}.chip:hover{background:#8b5cf629;color:var(--text-hi)}.chip.active{background:var(--grad-primary);color:#fff;border-color:transparent;box-shadow:0 4px 14px -2px #8b5cf680}.tabs{display:inline-flex;gap:4px;padding:4px;background:#8b5cf614;border-radius:12px;border:1px solid var(--border)}.tab{padding:7px 14px;border-radius:8px;font-size:12.5px;font-weight:600;color:var(--text-md);cursor:pointer;background:transparent;border:0;font-family:var(--font-body)}.tab:hover{color:var(--text-hi)}.tab.active{background:var(--grad-primary);color:#fff;box-shadow:0 4px 14px -3px #8b5cf680}.between{justify-content:space-between}.items-center{align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.text-hi{color:var(--text-hi)}.text-md{color:var(--text-md)}.text-lo{color:var(--text-lo)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.mono{font-family:var(--font-mono)}.display{font-family:var(--font-display)}.fw-700{font-weight:700}.fw-600{font-weight:600}.fs-11{font-size:11px}.fs-12{font-size:12px}.fs-13{font-size:13px}.fs-14{font-size:14px}.fs-16{font-size:16px}.fs-18{font-size:18px}.fs-28{font-size:28px}.uppercase{text-transform:uppercase;letter-spacing:.08em}.cart-item{display:flex;gap:12px;padding:12px;background:#8b5cf60f;border:1px solid var(--border);border-radius:12px;align-items:center}.cart-img{width:44px;height:44px;border-radius:10px;background:var(--grad-primary);display:grid;place-items:center;color:#fff;font-weight:700;flex-shrink:0}.cart-body{flex:1;min-width:0}.cart-name{font-size:13.5px;font-weight:600;color:var(--text-hi)}.cart-meta{font-size:11.5px;color:var(--text-lo);margin-top:2px}.drop-zone{border:1.5px dashed var(--border-strong);border-radius:12px;padding:24px;text-align:center;cursor:pointer;transition:all .2s ease;background:#8b5cf60a}.drop-zone:hover{background:#8b5cf61a;border-color:var(--primary)}.drop-zone-ico{width:44px;height:44px;border-radius:12px;margin:0 auto 10px;background:#8b5cf624;color:var(--primary);display:grid;place-items:center}.chart-wrap{position:relative;height:280px}.mobile-toggle,.sidebar-overlay{display:none}@media (max-width: 1100px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.grid-2-3,.grid-3-1,.grid-2-1{grid-template-columns:1fr}}@media (max-width: 860px){.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);transition:transform .25s ease}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:49;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .2s ease}.sidebar-overlay.open{opacity:1;pointer-events:auto}.mobile-toggle{display:grid}.tb-search{display:none}.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.page{padding:18px}.topbar{padding:0 16px;gap:10px}.tb-sub{display:none}.tbl-head{flex-wrap:wrap}.toast-container{left:10px;right:10px;top:10px}.toast{min-width:0;max-width:100%}}@media (max-width: 480px){.stat-value{font-size:22px}.modal{padding:18px;border-radius:14px}}.btn,.sb-item,.modal,.stat-card,.bill-img-thumb{will-change:transform;backface-visibility:hidden}.page{will-change:opacity,transform}.seg{display:inline-flex;gap:4px;padding:4px;background:var(--bg-2, #1a1d2e);border:1px solid var(--border, rgba(255,255,255,.08));border-radius:12px}.seg-btn{padding:6px 14px;border-radius:8px;background:transparent;color:var(--text-lo, #8b8fae);font-size:13px;font-weight:500;border:none;cursor:pointer;transition:background 80ms ease,color 80ms ease,box-shadow 80ms ease,transform 80ms ease;font-family:inherit;will-change:transform}.seg-btn:hover{color:var(--text, #fff)}.seg-btn.active{background:var(--grad-purple, linear-gradient(135deg, #a855f7, #6366f1));color:#fff;box-shadow:0 4px 16px -4px #8b5cf68c}.drp-wrap{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.drp-range-wrap{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:var(--bg-2, #1a1d2e);border:1px solid var(--border, rgba(255,255,255,.08));border-radius:10px;color:var(--text-lo, #8b8fae);transition:border-color .18s}.drp-range-wrap.active{border-color:#a855f7;color:#a855f7}.drp-date-input{background:transparent;border:none;outline:none;color:inherit;font-size:13px;font-family:inherit;cursor:pointer;width:108px}.drp-date-input::-webkit-calendar-picker-indicator{filter:invert(.5);cursor:pointer;opacity:.7}.drp-range-sep{font-size:12px;color:var(--text-lo, #8b8fae);flex-shrink:0}.select-sm{padding:5px 28px 5px 10px;border-radius:8px;border:1px solid var(--border, rgba(0,0,0,.12));color:var(--text, #1e293b);font-size:12px;font-weight:600;font-family:IBM Plex Sans Thai,Space Grotesk,sans-serif;cursor:pointer;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--bg-2, #f1f5f9) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a855f7' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 8px center;transition:border-color .18s}.select-sm:hover,.select-sm:focus{border-color:#a855f7}[data-theme=dark] .select-sm{background-color:#ffffff0f;border-color:#ffffff1a;color:#e2e8f0}select{font-family:IBM Plex Sans Thai,Space Grotesk,sans-serif}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:10px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;border:1px solid var(--border, rgba(255,255,255,.1));background:#ffffff0d;color:var(--text, #e2e8f0);transition:background 80ms ease,transform 80ms ease,box-shadow 80ms ease,border-color 80ms ease}.btn:hover{background:#ffffff17}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:linear-gradient(135deg,#a855f7,#6366f1)!important;border-color:transparent!important;color:#fff!important;box-shadow:0 6px 20px -6px #8b5cf699}.btn-primary:hover{box-shadow:0 8px 24px -6px #8b5cf6cc!important}.btn-ghost{background:transparent!important;border-color:var(--border-strong)!important;color:var(--text-md)!important}.btn-ghost:hover{background:#8b5cf614!important;border-color:var(--primary)!important;color:var(--primary)!important}.btn-add{background:linear-gradient(135deg,#a855f7,#6366f1)!important;border-color:transparent!important;color:#fff!important;font-weight:700!important;box-shadow:0 4px 14px -4px #8b5cf673!important}.btn-add:hover{background:linear-gradient(135deg,#9333ea,#4f46e5)!important;box-shadow:0 6px 20px -4px #8b5cf699!important;transform:translateY(-1px)}.btn-block{width:100%;justify-content:center}.btn-sm{padding:6px 12px!important;font-size:12px!important;gap:6px!important}.login-input{width:100%;padding:11px 14px;border-radius:10px;background:#0000000d;border:1px solid rgba(0,0,0,.14);color:#1e293b;font-size:14px;font-family:inherit;outline:none;box-sizing:border-box;transition:border-color .18s}.login-input::placeholder{color:#94a3b8}.login-input:focus{border-color:#a855f7;box-shadow:0 0 0 3px #a855f726}.login-input-wrap{position:relative}.login-input-wrap .login-input{padding-right:44px}.login-eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#94a3b8;cursor:pointer;padding:4px;display:flex}.login-eye:hover{color:#475569}[data-theme=dark] .login-input{background:#ffffff0f;border-color:#ffffff1f;color:#e2e8f0}[data-theme=dark] .login-input::placeholder{color:#64748b}[data-theme=dark] .login-eye{color:#64748b}[data-theme=dark] .login-eye:hover{color:#e2e8f0}.login-submit{width:100%;padding:13px;border-radius:12px;background:linear-gradient(135deg,#a855f7,#6366f1);border:none;color:#fff;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:6px;box-shadow:0 8px 24px -6px #8b5cf68c;transition:box-shadow 80ms ease,transform 80ms ease;will-change:transform}.login-submit:hover{box-shadow:0 12px 30px -6px #8b5cf6bf;transform:translateY(-1px)}.login-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-spinner{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;animation:spin .7s linear infinite;display:inline-block;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.acc-card{background:linear-gradient(135deg,#8b5cf61a,#6366f10f);border:1px solid rgba(139,92,246,.3);border-radius:16px;overflow:hidden}.acc-card-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#8b5cf614;border-bottom:1px solid rgba(139,92,246,.18)}.acc-card-title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px}.acc-card-body{padding:12px 16px;display:flex;flex-direction:column;gap:4px}.acc-row{display:grid;grid-template-columns:90px 1fr auto;align-items:center;padding:8px 10px;border-radius:8px;gap:12px;transition:background .15s}.acc-row:hover{background:#8b5cf60f}.acc-key{color:var(--text-lo);font-size:12px;font-weight:600}.acc-val{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text-hi)}.acc-copy{background:transparent;color:var(--text-lo);border:none;cursor:pointer;padding:6px;border-radius:6px;display:inline-flex}.acc-copy:hover{color:var(--text-hi);background:#8b5cf633}.acc-block{display:none}.multi-img-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.multi-img-thumb{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;border:1px solid var(--border, rgba(255,255,255,.08))}.multi-img-thumb img{width:100%;height:100%;object-fit:cover}.multi-img-x{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:#000000a6;color:#fff;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.multi-img-add{aspect-ratio:1;border-radius:10px;border:1.5px dashed var(--border, rgba(255,255,255,.1));background:transparent;color:var(--text-lo, #8b8fae);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:border-color 80ms ease,color 80ms ease,background 80ms ease}.multi-img-add:hover{border-color:var(--accent, #a855f7);color:var(--accent, #a855f7);background:#8b5cf60f}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:2000;display:flex;align-items:center;justify-content:center;padding:40px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:lbFadeIn .18s ease}@keyframes lbFadeIn{0%{opacity:0}to{opacity:1}}.lightbox img{max-width:100%;max-height:90vh;border-radius:14px;box-shadow:0 0 80px #a855f740}.lightbox-close{position:absolute;top:20px;right:20px;width:42px;height:42px;border-radius:50%;background:#ffffff1f;border:1px solid rgba(255,255,255,.15);color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s}.lightbox-close:hover{background:#ffffff38}.bill-imgs-header{display:flex;align-items:center;justify-content:space-between}.bill-imgs-count{font-size:11px;padding:2px 8px;border-radius:20px;background:#a855f726;color:var(--primary,#a855f7);font-weight:600}.bill-img-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.bill-img-thumb{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:1.5px solid var(--border, rgba(255,255,255,.08));cursor:zoom-in;transition:transform .18s,border-color .18s}.bill-img-thumb:hover{transform:scale(1.03);border-color:#a855f780}.bill-img-thumb img{width:100%;height:100%;object-fit:cover;display:block}.bill-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity .18s}.bill-img-thumb:hover .bill-img-overlay{opacity:1}.bill-no-imgs{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;border-radius:14px;border:1.5px dashed rgba(168,85,247,.2);background:#a855f70a;text-align:center}.bill-no-imgs-icon{width:54px;height:54px;border-radius:50%;background:#a855f71f;display:flex;align-items:center;justify-content:center;color:var(--primary,#a855f7)}.bill-upload-panel{padding:16px;border-radius:14px;border:1px solid var(--border, rgba(255,255,255,.08));background:#a855f708}.tbl-wrap{overflow-x:auto}.summary-card{border-top:3px solid transparent}.summary-card--purple{border-top-color:#a855f7;background:linear-gradient(160deg,rgba(168,85,247,.06) 0%,transparent 60%)!important}.summary-card--cyan{border-top-color:#22d3ee;background:linear-gradient(160deg,rgba(34,211,238,.06) 0%,transparent 60%)!important}.summary-card--red{border-top-color:#f43f5e;background:linear-gradient(160deg,rgba(244,63,94,.06) 0%,transparent 60%)!important}.summary-list-row{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--border, rgba(255,255,255,.06))}.summary-list-row:last-child{border-bottom:none}.summary-list-row--rich{align-items:center}.sum-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sum-name{flex:1;font-size:14px;font-weight:600;min-width:0}.sum-val{font-size:16px;font-weight:700;flex-shrink:0;color:var(--text-hi)}.sum-unit{font-size:13px;color:var(--text-hi);flex-shrink:0;min-width:32px;text-align:right}.sum-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.sum-info .sum-name{flex:none}.sum-meta{display:flex;gap:10px;flex-wrap:wrap}.sum-meta-item{font-size:12.5px;color:var(--text-md);font-weight:500}.sum-meta-item.profit{color:var(--success);font-weight:600}.flex-1{flex:1}.flex{display:flex}.gap-6{gap:6px}.gap-10{gap:10px}.mt-14{margin-top:14px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.fs-10{font-size:10px}.fs-22{font-size:22px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.stat-card{border:1px solid var(--border, rgba(255,255,255,.08));border-radius:16px;padding:24px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center}.stat-ico{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card .stat-label{font-size:12px;color:var(--text-lo, #8b8fae);font-weight:600;letter-spacing:.03em}.stat-card .stat-value{font-size:24px;font-weight:700;color:var(--text-hi, #fff);margin-top:2px;line-height:1.2}.stat-card .stat-sub{font-size:11px;color:var(--text-lo, #8b8fae);margin-top:2px}@media (max-width: 900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.tbl{width:100%;border-collapse:collapse;min-width:700px}.tbl th{text-align:left;font-size:11.5px;font-weight:600;color:var(--text-lo, #8b8fae);padding:12px;border-bottom:1px solid var(--border, rgba(255,255,255,.08));text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.tbl td{padding:12px;border-bottom:1px solid var(--border, rgba(255,255,255,.04));font-size:13px;vertical-align:middle}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:#ffffff05}.grid-bill{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}.bill-aside{position:sticky;top:20px;display:flex;flex-direction:column;gap:16px}@media (max-width: 1100px){.grid-bill{grid-template-columns:1fr}.bill-aside{position:static}}.bill-success{max-width:720px}.bill-item{border-radius:14px;border:1.5px solid var(--border-strong);background:var(--bg-1);margin-bottom:18px;transition:border-color .15s,box-shadow .15s;box-shadow:var(--shadow-card)}.bill-item:hover{border-color:var(--primary);box-shadow:0 4px 20px -6px #8b5cf62e}.bill-item-top{position:relative;display:flex;align-items:flex-end;gap:10px;padding:10px 12px 10px 20px;background:var(--bg-1);border-radius:12px 12px 0 0;overflow:visible}.bill-item-top:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--bill-accent, var(--primary, #8b5cf6));border-radius:12px 0 0}.bill-item-num{font-size:10px;font-weight:800;color:var(--text-md);padding-bottom:9px;min-width:18px;flex-shrink:0}.bill-item-selects{display:grid;grid-template-columns:1fr 1.7fr;gap:12px;flex:1}.bill-item-selects>div>label{font-size:11px;color:var(--text-md);font-weight:700;margin-bottom:6px;display:block}.bill-item-selects select{width:100%;padding:8px 28px 8px 10px;border-radius:9px;background:var(--bg-0);border:1.5px solid var(--border-strong);color:var(--text-hi);font-size:14px;font-family:inherit;outline:none;box-sizing:border-box;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238b8fb1' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 10px center;background-size:14px}.bill-item-selects select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #8b5cf624}.bill-item-selects select:disabled{opacity:.5;cursor:not-allowed}.bill-item-bot{display:flex;gap:8px;padding:8px 12px 10px 20px;align-items:flex-end;background:var(--bg-2);border-top:1.5px solid var(--border-strong);border-radius:0 0 12px 12px}.bill-ifield{display:flex;flex-direction:column;min-width:0}.bill-ifield.w-sm{flex:0 0 90px}.bill-ifield.w-auto{flex:1}.bill-ifield label{font-size:11px;color:var(--text-md);font-weight:700;margin-bottom:6px;display:block;white-space:nowrap}.bill-ifield input{padding:7px 9px;border-radius:8px;background:var(--bg-1);border:1.5px solid var(--border-strong);color:var(--text-hi);font-size:13.5px;font-family:inherit;outline:none;box-sizing:border-box;transition:border-color .15s;width:100%;font-weight:500}.bill-ifield input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #8b5cf61f}.bill-ifield input:disabled{color:var(--text-md);font-weight:600;cursor:default;background:var(--bg-2)}.bill-row-x{background:#f43f5e1a;border:1.5px solid rgba(244,63,94,.3);color:#f43f5e;width:38px;height:38px;border-radius:9px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;align-self:flex-end;transition:all .15s}.bill-row-x:hover{background:#f43f5e38;border-color:#f43f5e8c}.bill-panel-head{padding:10px 14px;border-bottom:1px solid var(--border)}.bill-panel-row{display:flex;align-items:center;gap:8px}.bill-meta-chip{font-size:11px;color:var(--text-lo);background:var(--bg-2);border:1px solid var(--border);border-radius:6px;padding:2px 8px}.bill-panel-body{padding:12px 14px}.bill-panel-divider{border:none;border-top:1.5px dashed var(--border-strong);margin:0}.bill-2col{display:grid;grid-template-columns:1fr 1fr;gap:8px}.bill-field-label{font-size:10.5px;color:var(--text-md);font-weight:600;margin-bottom:4px}.bill-input{padding:7px 10px!important;font-size:13px!important}.bill-summary{display:flex;flex-direction:column;gap:7px;background:linear-gradient(135deg,#8b5cf60f,#6366f108);border:1px solid rgba(139,92,246,.18);border-radius:10px;padding:12px 14px}.bill-summary-total{padding-top:8px;border-top:1px solid rgba(139,92,246,.18);margin-top:2px}.bill-totals{background:linear-gradient(135deg,#8b5cf612,#6366f10a);border:1px solid rgba(139,92,246,.22);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:10px}.bill-total-line{padding-top:12px;border-top:1px solid rgba(139,92,246,.2);margin-top:2px}.alert-warn{background:#fbbf2414;border:1px solid rgba(251,191,36,.28);border-radius:10px;padding:10px 14px;font-size:12.5px;color:#d97706;display:flex;align-items:center;gap:8px;line-height:1.5}[data-theme=dark] .alert-warn{color:#fbbf24}.pattern-ta{width:100%;min-height:160px;padding:12px 14px;border-radius:10px;background:var(--bg-2);border:1px solid var(--border);color:var(--text-hi);font-family:JetBrains Mono,monospace;font-size:12.5px;line-height:1.7;resize:vertical}.pattern-hint{padding:10px 14px;background:#22d3ee0f;border:1px solid rgba(34,211,238,.2);border-radius:10px;font-family:JetBrains Mono,monospace;font-size:12px;color:var(--text-lo)}.pattern-hint b{color:var(--text-hi)}.perm-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#ffffff0d;border:1px solid var(--border, rgba(255,255,255,.08));font-size:12px;cursor:pointer;transition:background 80ms ease,border-color 80ms ease,color 80ms ease;-webkit-user-select:none;user-select:none}.perm-chip.on{background:#8b5cf626;border-color:#8b5cf666;color:#c4b5fd}.perm-chip.on:before{content:"✓"}.user-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#a855f7,#6366f1);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:15px;flex-shrink:0}.user-row-info{display:flex;align-items:center;gap:10px}.user-row td{vertical-align:middle}.user-perm-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;background:#8b5cf61f;color:var(--primary, #a855f7);border:1px solid rgba(139,92,246,.25);white-space:nowrap}.user-perm-chips{display:flex;flex-wrap:wrap;gap:5px}.user-perm-chip{display:inline-block;padding:2px 9px;border-radius:6px;font-size:11px;background:var(--bg-2, rgba(255,255,255,.04));border:1px solid var(--border);color:var(--text-md);white-space:nowrap}.row-between{display:flex;align-items:center;justify-content:space-between}.row-flex{display:flex;align-items:center}.align-center{align-items:center}.flex-col{display:flex;flex-direction:column}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.card-body{display:flex;flex-direction:column}.csel{position:relative;width:100%}.csel-trigger{width:100%;display:flex;align-items:center;gap:8px;padding:8px 10px 8px 12px;border-radius:9px;background:var(--bg-0);border:1.5px solid var(--border-strong);color:var(--text-hi);font-size:13.5px;font-family:inherit;cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s}.csel-trigger:hover{border-color:var(--primary)}.csel-open .csel-trigger{border-color:var(--primary);box-shadow:0 0 0 3px #8b5cf624}.csel-disabled .csel-trigger{opacity:.45;cursor:not-allowed;pointer-events:none}.csel-value{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.csel-label{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.csel-placeholder{color:var(--text-lo);flex:1;font-size:13px}.csel-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.csel-chevron{color:var(--text-lo);flex-shrink:0;transition:transform .18s}.csel-open .csel-chevron{transform:rotate(180deg)}.csel-star{color:#fbbf24;font-size:11px;flex-shrink:0}.csel-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:300;background:var(--bg-1);border:1.5px solid var(--border-strong);border-radius:12px;box-shadow:0 12px 36px -4px #0000002e,0 4px 12px -2px #0000001a;overflow:hidden;max-height:260px;overflow-y:auto;padding:4px}.csel-menu::-webkit-scrollbar{width:5px}.csel-menu::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.csel-item{width:100%;display:flex;align-items:center;gap:9px;padding:8px 10px;background:transparent;border:none;border-radius:8px;color:var(--text-hi);font-size:13px;font-family:inherit;cursor:pointer;text-align:left;transition:background .1s}.csel-item:hover{background:#8b5cf614}.csel-item-active{background:#8b5cf61a!important;font-weight:600}.csel-item-empty{color:var(--text-lo)!important;font-size:12px}.csel-item-empty:hover{background:#0000000a!important}.edit-log-row{display:flex;flex-direction:column;gap:2px;padding:8px 12px;background:var(--bg-2);border-radius:8px;border-left:3px solid #fbbf24}.vps-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600}.vps-badge.ok{background:#10d9971f;color:#10d997}.vps-badge.warn{background:#fbbf241f;color:#fbbf24}.vps-badge.danger{background:#f43f5e1f;color:#f43f5e}.wd-product-head{display:flex;align-items:center;gap:14px;padding:14px 16px;background:linear-gradient(135deg,#8b5cf61a,#6366f10f);border:1px solid rgba(139,92,246,.22);border-radius:12px}.wd-product-icon{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,#8b5cf640,#6366f126);display:flex;align-items:center;justify-content:center;color:#a855f7;flex-shrink:0}.wd-product-name{font-size:15px;font-weight:700;color:var(--text-hi);margin-bottom:2px}.wd-info-row{display:flex;align-items:center;background:var(--bg-2);border:1px solid var(--border);border-radius:10px;overflow:hidden}.wd-info-item{flex:1;padding:12px 16px;display:flex;flex-direction:column;gap:3px}.wd-info-sep{width:1px;align-self:stretch;background:var(--border)}.wd-info-label{font-size:11px;color:var(--text-lo);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.wd-info-val{font-size:14px;color:var(--text-hi);font-weight:600}.wd-stepper{display:flex;align-items:center;gap:0;border:1.5px solid var(--border-strong);border-radius:12px;overflow:hidden;background:var(--bg-1)}.wd-step-btn{width:48px;height:52px;flex-shrink:0;background:var(--bg-2);border:none;color:var(--text-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;-webkit-user-select:none;user-select:none}.wd-step-btn:hover{background:#8b5cf61f;color:#a855f7}.wd-step-btn:active{background:#8b5cf638;transform:scale(.92)}.wd-step-input{flex:1;height:52px;border:none;background:transparent;text-align:center;font-size:22px;font-weight:700;color:var(--text-hi);font-family:var(--font-display, inherit);outline:none;-moz-appearance:textfield}.wd-step-input::-webkit-inner-spin-button,.wd-step-input::-webkit-outer-spin-button{-webkit-appearance:none}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page{animation:pageIn .15s cubic-bezier(.25,.46,.45,.94) both}@keyframes modalIn{0%{opacity:0;transform:scale(.97) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal{animation:modalIn .16s cubic-bezier(.25,.46,.45,.94) both}.modal-overlay{animation:overlayIn .14s ease both}.btn:active:not(:disabled){transform:scale(.95)!important}.btn-add:active:not(:disabled){transform:scale(.95)!important}.login-submit:active:not(:disabled){transform:scale(.97)!important}.seg-btn:active:not(:disabled){transform:scale(.94)}.sb-item{transition:background 80ms ease,color 80ms ease,transform 80ms ease}.sb-item:active{transform:scale(.96)}.input:focus,.select:focus,.textarea:focus{box-shadow:0 0 0 3px #8b5cf62e!important}@keyframes csel-fadein{0%{opacity:0;transform:translateY(-4px) scaleY(.97)}to{opacity:1;transform:translateY(0) scaleY(1)}}.csel-menu{animation:csel-fadein .12s cubic-bezier(.25,.46,.45,.94);transform-origin:top}.csel-item{transition:background 60ms ease!important}.csel-trigger{transition:border-color 80ms ease,box-shadow 80ms ease!important}.csel-chevron{transition:transform .12s ease}.tbl tr{transition:background 60ms ease}.bill-item{transition:border-color 80ms ease!important}.bill-row-x{transition:background 80ms ease,border-color 80ms ease,transform 80ms ease!important}.bill-row-x:active{transform:scale(.88)!important}.bill-ifield input{transition:border-color 80ms ease,box-shadow 80ms ease!important}button,[role=button],.seg,.seg-btn,.perm-chip,.stat-card,.bill-meta-chip,.vps-badge,.multi-img-add,.bill-item-num,.acc-key,.csel-chevron{-webkit-user-select:none;user-select:none}.stat-card{transition:transform .1s ease}.stat-card:hover{transform:translateY(-2px)}.grid-2-form{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3-form{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.grid-full{grid-column:1 / -1}.phase-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.phase-card-mid{display:flex;align-items:center;justify-content:space-between;gap:10px}.phase-card-num{font-size:28px;font-weight:800;line-height:1;color:var(--text-hi)}.phase-card-num span{font-size:11px;font-weight:500;color:var(--text-lo);margin-left:3px}.cat-card2{padding:0;overflow:hidden;display:flex;flex-direction:column}.cat2-color-bar{height:3px;background:var(--cat-c, #8b5cf6);flex-shrink:0}.cat2-body{padding:12px 14px 10px;display:flex;align-items:center;justify-content:space-between;gap:10px}.cat2-top{display:flex;align-items:center;gap:8px;min-width:0}.cat2-count{font-size:13px;font-weight:700;color:var(--cat-c, #8b5cf6);white-space:nowrap}.cat2-count span{font-size:11px;font-weight:500;color:var(--text-lo);margin-left:2px}.cat2-actions{display:flex;gap:4px;flex-shrink:0}.phase-card-clickable{cursor:pointer;transition:transform 80ms ease,box-shadow 80ms ease,border-color 80ms ease!important}.phase-card-clickable:hover{transform:translateY(-2px);border-color:var(--primary)!important;box-shadow:0 4px 20px -6px #8b5cf640}.phase-card-clickable:active{transform:scale(.98)}.autoclaim-flagged-row td{background:#f43f5e0a!important}.autoclaim-flagged-row td:first-child{border-left:3px solid #f43f5e}.autoclaim-status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700}.autoclaim-status-badge.flagged{background:#f43f5e1f;color:#f43f5e;border:1px solid rgba(244,63,94,.25)}.autoclaim-status-badge.claimed{background:#10d9971a;color:#10d997;border:1px solid rgba(16,217,151,.2)}.spin-icon{animation:spin .9s linear infinite}.sysdata-group-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--text-lo);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}.sysdata-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}@media (max-width: 900px){.sysdata-grid{grid-template-columns:repeat(2,1fr)}}.sysdata-tile{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px 18px;display:flex;flex-direction:column;gap:10px;transition:transform 80ms ease,box-shadow 80ms ease}.sysdata-tile:hover{transform:translateY(-2px);box-shadow:0 4px 20px -6px #00000026,0 0 0 1px rgba(var(--tc-rgb, 168,85,247),.15)}.sysdata-tile--accent{border-color:#a855f74d;background:linear-gradient(135deg,#a855f712,#6366f10a)}.sysdata-ico{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sysdata-num{font-size:28px;font-weight:800;line-height:1;color:var(--text-hi);font-family:var(--font-display)}.sysdata-lbl{font-size:12px;color:var(--text-lo);font-weight:500;line-height:1.4}.copy-cell{display:inline-flex;align-items:center;gap:5px;cursor:pointer;border-radius:6px;padding:2px 6px;transition:background .15s}.copy-cell:hover{background:#a855f71f}.copy-cell:hover svg{opacity:1}.copy-cell svg{opacity:0;transition:opacity .15s;color:#a855f7}.inv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;align-items:start}@media (max-width: 900px){.inv-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.inv-grid{grid-template-columns:1fr}}.inv-card{padding:12px 14px;border-top:3px solid var(--cat-c, #8b5cf6)!important;display:flex;flex-direction:column;gap:8px}.inv-card-head{display:flex;align-items:center;justify-content:space-between;gap:6px}.inv-cat-dot{border-radius:50%;flex-shrink:0}.inv-phase-badge{font-size:10px;font-weight:700;padding:1px 6px;border-radius:20px;background:#a855f726;color:#a855f7}.inv-stock-pill{font-size:11px;font-weight:600}.inv-prod-list{display:flex;flex-direction:column;gap:2px}.inv-prod-row{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:7px;background:var(--bg-2)}.inv-prod-row:hover{background:var(--bg-1)}.inv-prod-name{flex:1;font-size:13px;font-weight:500;color:var(--text-hi);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inv-prod-cost{font-size:12px;color:var(--text-lo);flex-shrink:0}.dpk-wrap{position:relative;display:block;width:100%}.dpk-trigger{display:inline-flex;align-items:center;gap:7px;width:100%;padding:8px 11px;border:1.5px solid var(--border, rgba(0,0,0,.12));border-radius:9px;background:var(--bg-1, #fff);color:var(--text-hi);font-size:13px;font-family:inherit;cursor:pointer;transition:border-color 80ms ease,box-shadow 80ms ease;text-align:left}.dpk-trigger:hover{border-color:var(--primary, #a855f7)}.dpk-trigger:focus{outline:none;border-color:var(--primary, #a855f7);box-shadow:0 0 0 3px #a855f726}.dpk-val{flex:1;font-variant-numeric:tabular-nums;color:var(--text-hi)}.dpk-ph{flex:1;color:var(--text-lo)}.dpk-clr{display:inline-flex;align-items:center;justify-content:center;margin-left:auto;width:18px;height:18px;border-radius:4px;color:var(--text-lo);transition:color 80ms ease,background 80ms ease}.dpk-clr:hover{color:#f43f5e;background:#f43f5e1a}.dpk-panel{width:264px;background:var(--bg-0, #fff);border:1.5px solid var(--border, rgba(0,0,0,.1));border-radius:16px;box-shadow:0 12px 40px #00000038,0 2px 10px #0000001a;overflow:hidden;animation:dpkIn .13s cubic-bezier(.22,.68,0,1.18) both}@keyframes dpkIn{0%{opacity:0;transform:scale(.94) translateY(-6px)}to{opacity:1;transform:none}}.dpk-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 10px;border-bottom:1px solid var(--border, rgba(0,0,0,.08))}.dpk-mlabel{font-size:14px;font-weight:700;color:var(--text-hi)}.dpk-nav{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:7px;border:none;color:var(--text-md);background:transparent;cursor:pointer;transition:background 80ms ease,color 80ms ease,transform 80ms ease}.dpk-nav:hover{background:var(--bg-2);color:var(--text-hi)}.dpk-nav:active{transform:scale(.86)}.dpk-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;padding:10px 10px 6px}.dpk-dow{text-align:center;font-size:10px;font-weight:700;color:var(--text-lo);padding:4px 0;letter-spacing:.03em;text-transform:uppercase}.dpk-day{display:flex;align-items:center;justify-content:center;height:32px;border-radius:8px;font-size:13px;color:var(--text-hi);background:transparent;border:none;cursor:pointer;transition:background 80ms ease,color 80ms ease,transform 80ms ease;position:relative}.dpk-day:hover{background:var(--bg-2)}.dpk-day:active{transform:scale(.84)}.dpk-today{color:var(--primary, #a855f7);font-weight:700}.dpk-today:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--primary, #a855f7)}.dpk-sel{background:var(--primary, #a855f7)!important;color:#fff!important;font-weight:700;box-shadow:0 4px 12px -2px #a855f780}.dpk-sel:after{display:none}.dpk-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 14px 12px;border-top:1px solid var(--border, rgba(0,0,0,.08))}.dpk-ftr-btn{font-size:12px;font-weight:600;color:var(--text-lo);background:transparent;border:none;cursor:pointer;padding:4px 10px;border-radius:7px;transition:background 80ms ease,color 80ms ease;font-family:inherit}.dpk-ftr-btn:hover{background:var(--bg-2);color:var(--text-hi)}.dpk-ftr-today{color:var(--primary, #a855f7)!important}.drp-range-wrap{display:inline-flex;align-items:center;gap:8px;flex-shrink:0;background:transparent!important;border:none!important;padding:0!important}.drp-range-wrap .dpk-wrap{display:inline-flex;width:auto}.drp-range-wrap .dpk-trigger{min-width:130px}.drp-range-sep{font-size:12px;color:var(--text-lo);flex-shrink:0}
