:root{--ff-thai: "Sarabun";--ff-latin: "Inter";--ff: var(--ff-thai), var(--ff-latin), system-ui, sans-serif;--ff-mono: "JetBrains Mono", "SF Mono", monospace;--c-primary: #22C55E;--c-accent: #FBBF24;--c-hero: #2C3346;--c-hero-2: #1F2937;--c-primary-50: #22C55E10;--c-primary-100: #22C55E22;--c-primary-200: #22C55E40;--c-accent-50: #FBBF2418;--c-accent-100: #FBBF2430;--c-success: #22C55E;--c-success-100: #22C55E1F;--c-warning: #FBBF24;--c-danger: #EF4444;--c-danger-100: #EF444418;--c-line: #06C755;--c-line-100:#06C75518;--c-bg: #F4F6F8;--c-surface: #FFFFFF;--c-surface-2:#F8FAFB;--c-border: #EEF1F4;--c-border-2: #F4F6F8;--c-text: #1F2937;--c-text-2: #6B7280;--c-text-3: #9CA3AF;--c-muted: #9CA3AF;--c-muted-soft: #F3F4F6;--r-1: 8px;--r-2: 12px;--r-3: 18px;--r-4: 24px;--r-pill: 999px;--sh-1: 0 1px 2px rgba(31,41,55,.04);--sh-2: 0 4px 14px -6px rgba(31,41,55,.1);--sh-3: 0 16px 40px -16px rgba(31,41,55,.18);--sh-card: 0 6px 20px -10px rgba(31,41,55,.1), 0 1px 2px rgba(31,41,55,.04);--pad-page: 32px;--pad-card: 22px;--gap: 18px}:root[data-theme=dark]{--c-bg: #0A0A0A;--c-surface: #111111;--c-surface-2:#161616;--c-border: #1F1F1F;--c-border-2: #1A1A1A;--c-text: #ECECEC;--c-text-2: #A1A1AA;--c-text-3: #71717A;--c-muted: #71717A;--c-muted-soft: #1A1A1A;--sh-1: 0 1px 1px rgba(0,0,0,.4);--sh-2: 0 1px 2px rgba(0,0,0,.4);--sh-3: 0 12px 32px -12px rgba(0,0,0,.7)}:root[data-density=compact]{--pad-page: 20px;--pad-card: 14px;--gap: 12px}:root[data-density=comfy]{--pad-page: 36px;--pad-card: 26px;--gap: 20px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--ff);color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}button{font-family:inherit}input,textarea,select{font-family:inherit;color:inherit}input:focus,textarea:focus,select:focus{outline:none}a{color:var(--c-primary);text-decoration:none}.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.app[data-sidebar=top]{grid-template-columns:1fr}.app-main{display:flex;flex-direction:column;min-width:0;background:var(--c-bg)}.app-content{flex:1;padding:var(--pad-page);overflow-y:auto;animation:fadeUp .26s cubic-bezier(.2,.7,.3,1)}.app-content.is-transitioning{opacity:0;transform:translateY(6px);transition:opacity .12s,transform .12s}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sidebar{background:var(--c-surface);border-right:1px solid var(--c-border);display:flex;flex-direction:column;padding:18px 12px 14px;position:sticky;top:0;height:100vh}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:4px 10px 18px;border-bottom:1px solid var(--c-border-2);margin-bottom:14px}.brand-mark{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,oklch(.82 .15 152),var(--c-primary));color:#fff;display:grid;place-items:center;position:relative;box-shadow:0 6px 14px -6px var(--c-primary)}.brand-mark-lg{width:52px;height:52px;border-radius:16px}.brand-name{font-weight:700;font-size:18px;letter-spacing:-.01em}.brand-name span{color:var(--c-accent);font-weight:400}.brand-name-lg{font-size:24px}.brand-sub{font-size:11px;color:var(--c-text-2);font-weight:500}.sidebar-section{padding:0 4px;margin-bottom:18px}.sidebar-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-text-3);padding:0 10px 6px}.sidebar-item{display:flex;align-items:center;gap:12px;width:100%;background:transparent;border:0;border-radius:var(--r-2);padding:11px 12px;color:var(--c-text-2);font-size:13.5px;font-weight:500;cursor:pointer;text-align:left;position:relative;transition:background .15s,color .15s}.sidebar-item:hover{background:var(--c-surface-2);color:var(--c-text)}.sidebar-item.is-active{background:var(--c-primary-100);color:var(--c-primary);font-weight:600}.sidebar-item.is-accent{color:var(--c-text);font-weight:500}.sidebar-item.is-accent:hover{background:var(--c-muted-soft)}.sidebar-badge{margin-left:auto;background:var(--c-primary);color:#fff;font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:999px;font-family:var(--ff-latin)}.sidebar-foot{margin-top:auto;padding:12px 4px 0;border-top:1px solid var(--c-border-2)}.topnav{display:flex;align-items:center;gap:24px;background:var(--c-surface);border-bottom:1px solid var(--c-border);padding:12px 28px;position:sticky;top:0;z-index:5}.topnav-brand{display:flex;align-items:center;gap:10px;padding-right:24px;border-right:1px solid var(--c-border-2)}.topnav-items{display:flex;gap:4px;flex:1}.topnav-item{display:flex;align-items:center;gap:6px;background:transparent;border:0;border-radius:8px;padding:8px 12px;color:var(--c-text-2);font-size:13px;font-weight:500;cursor:pointer}.topnav-item:hover{background:var(--c-surface-2);color:var(--c-text)}.topnav-item.is-active{background:var(--c-primary-100);color:var(--c-primary);font-weight:600}.topnav-badge{background:var(--c-text);color:var(--c-surface);font-size:10px;font-weight:600;padding:1px 6px;border-radius:999px}.app[data-sidebar=top] .sidebar{display:none}.topbar{display:flex;align-items:center;gap:12px;padding:12px 24px;background:var(--c-surface);border-bottom:1px solid var(--c-border);position:sticky;top:0;z-index:4}.app[data-sidebar=top] .topbar{top:56px}.topbar-search{flex:1;max-width:480px;display:flex;align-items:center;gap:8px;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:10px;padding:8px 12px;color:var(--c-text-3);transition:border-color .12s,background .12s}.topbar-search:focus-within{border-color:var(--c-primary);background:var(--c-surface)}.topbar-search input{flex:1;border:0;background:transparent;font-size:13.5px;color:var(--c-text)}.topbar-search kbd{font-family:var(--ff-latin);font-size:10px;padding:2px 6px;border-radius:4px;background:var(--c-surface);border:1px solid var(--c-border);color:var(--c-text-2)}.topbar-right{display:flex;align-items:center;gap:8px;margin-left:auto;position:relative}.topbar-icon{width:36px;height:36px;border-radius:8px;border:1px solid var(--c-border);background:var(--c-surface);display:grid;place-items:center;color:var(--c-text-2);cursor:pointer;position:relative}.topbar-icon:hover{background:var(--c-surface-2);color:var(--c-text)}.topbar-icon.is-open{background:var(--c-primary-100);color:var(--c-primary);border-color:transparent}.topbar-dot{position:absolute;top:7px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--c-accent);border:2px solid var(--c-surface)}.topbar-divider{width:1px;height:22px;background:var(--c-border)}.topbar-role{display:flex;padding:3px;background:var(--c-surface-2);border-radius:9px}.role-tab{border:0;background:transparent;padding:5px 10px;border-radius:6px;color:var(--c-text-2);font-size:12.5px;font-weight:500;cursor:pointer}.role-tab.is-active{background:var(--c-surface);color:var(--c-text);font-weight:600}.topbar-user{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border-radius:999px;border:1px solid var(--c-border);background:var(--c-surface);cursor:pointer}.topbar-user:hover{background:var(--c-surface-2)}.topbar-user-meta{text-align:left;line-height:1.1}.topbar-user-name{font-size:12.5px;font-weight:600}.topbar-user-role{font-size:11px;color:var(--c-text-3)}.dropdown{position:absolute;right:0;top:48px;min-width:220px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;box-shadow:var(--sh-3);padding:6px;z-index:50}.dropdown-wide{right:80px;width:360px}.dropdown-head{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;font-weight:600;font-size:13px}.dropdown-link{background:transparent;border:0;color:var(--c-primary);cursor:pointer;font-size:12px;font-weight:500}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:0;padding:9px 10px;border-radius:8px;color:var(--c-text);font-size:13px;cursor:pointer;text-align:left}.dropdown-item:hover{background:var(--c-surface-2)}.dropdown-sep{height:1px;background:var(--c-border);margin:4px 6px}.notif-row{display:flex;gap:10px;padding:9px 10px;border-radius:8px;background:transparent;border:0;width:100%;text-align:left;cursor:pointer;position:relative}.notif-row:hover{background:var(--c-surface-2)}.notif-meta{flex:1;min-width:0}.notif-title{font-size:12.5px;font-weight:600}.notif-desc{font-size:12px;color:var(--c-text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-time{font-size:11px;color:var(--c-text-3);margin-top:2px}.notif-unread{width:7px;height:7px;border-radius:50%;background:var(--c-accent);position:absolute;right:10px;top:14px}.crumbs{display:flex;align-items:center;gap:8px;padding:12px 28px 0;font-size:12px;color:var(--c-text-2)}.crumb-link{background:transparent;border:0;color:var(--c-text-2);cursor:pointer;font-size:12px;padding:0}.crumb-link:hover{color:var(--c-primary)}.crumb-current{color:var(--c-text);font-weight:500}.page{display:flex;flex-direction:column;gap:var(--gap);max-width:1400px;margin:0 auto;width:100%}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.page-head h1{margin:0;font-size:24px;font-weight:600;letter-spacing:-.015em}.page-sub{color:var(--c-text-2);margin-top:4px;font-size:13.5px}.page-actions{display:flex;gap:8px;align-items:center}.av{border-radius:50%;display:grid;place-items:center;font-weight:700;font-family:var(--ff-latin);letter-spacing:.02em;flex-shrink:0}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:999px;font-size:11.5px;font-weight:600;white-space:nowrap}.badge-sm{padding:2px 7px;font-size:11px}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge-muted{background:var(--c-muted-soft);color:var(--c-text-2)}.badge-info{background:var(--c-primary-100);color:var(--c-primary)}.badge-success{background:var(--c-success-100);color:var(--c-success)}.badge-warning{background:var(--c-accent-100);color:var(--c-accent)}.badge-danger{background:var(--c-danger-100);color:var(--c-danger)}.chip{display:inline-flex;padding:2px 8px;border-radius:6px;background:var(--c-surface-2);border:1px solid var(--c-border-2);font-size:11.5px;color:var(--c-text-2);font-weight:500}.pill{background:var(--c-surface);border:1px solid var(--c-border);border-radius:999px;padding:6px 12px;color:var(--c-text-2);font-size:12.5px;font-weight:500;cursor:pointer}.pill.is-active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--r-pill);border:1px solid transparent;font-size:13.5px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,transform .08s,box-shadow .15s,filter .15s;white-space:nowrap}.btn:active{transform:translateY(1px)}.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{padding:12px 22px;font-size:14.5px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--c-primary);color:#fff;box-shadow:0 6px 16px -8px var(--c-primary)}.btn-primary:hover{background:#00b65d;background:oklch(.68 .18 152)}.btn-accent{background:var(--c-text);color:#fff;box-shadow:0 6px 16px -8px #1f293773}.btn-accent:hover{background:#000}.btn-secondary{background:var(--c-surface);border-color:var(--c-border);color:var(--c-text)}.btn-secondary:hover{background:var(--c-surface-2)}.btn-ghost{background:transparent;color:var(--c-text);border-color:var(--c-border)}.btn-ghost:hover{background:var(--c-surface-2)}.btn-danger{background:var(--c-danger);color:#fff}.btn-danger:hover{filter:brightness(1.05)}.icon-btn{width:32px;height:32px;border-radius:var(--r-2);background:transparent;border:0;color:var(--c-text-2);display:grid;place-items:center;cursor:pointer}.icon-btn:hover{background:var(--c-surface-2);color:var(--c-text)}.seg{display:inline-flex;padding:3px;background:var(--c-surface-2);border:1px solid var(--c-border-2);border-radius:8px}.seg-item{background:transparent;border:0;padding:5px 11px;border-radius:6px;font-size:12px;color:var(--c-text-2);cursor:pointer;font-weight:500}.seg-item.is-active{background:var(--c-surface);color:var(--c-text);font-weight:600;box-shadow:var(--sh-1)}.seg-full{display:grid;grid-template-columns:repeat(3,1fr)}.seg-full .seg-item{text-align:center;padding:7px}.card{background:var(--c-surface);border:0;border-radius:var(--r-3);overflow:hidden;box-shadow:var(--sh-card)}.card-head{display:flex;align-items:center;justify-content:space-between;padding:14px var(--pad-card) 12px;border-bottom:1px solid var(--c-border-2)}.card-head h3{margin:0;font-size:13px;font-weight:600;color:var(--c-text);letter-spacing:-.005em}.card-body{padding:var(--pad-card)}.card-body-flush{padding:0}.card-link{display:inline-flex;align-items:center;gap:4px;background:transparent;border:0;color:var(--c-primary);font-size:12.5px;font-weight:600;cursor:pointer}.card-toolbar{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--c-border-2);flex-wrap:wrap}.card-tools{display:flex;align-items:center;gap:6px;margin-left:auto}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--c-border);padding:0 4px}.tab{background:transparent;border:0;padding:10px 14px;cursor:pointer;color:var(--c-text-2);font-size:13px;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;display:inline-flex;align-items:center;gap:6px}.tab:hover{color:var(--c-text)}.tab.is-active{color:var(--c-primary);border-color:var(--c-primary);font-weight:600}.tab-count{background:var(--c-surface-2);color:var(--c-text-2);font-size:11px;padding:1px 7px;border-radius:999px;font-weight:600}.tab.is-active .tab-count{background:var(--c-primary);color:#fff}.empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 20px;text-align:center}.empty-icon{width:56px;height:56px;border-radius:14px;background:var(--c-surface-2);display:grid;place-items:center;color:var(--c-text-2)}.empty-title{font-weight:600;font-size:15px}.empty-desc{color:var(--c-text-2);font-size:13px;max-width:340px}.field{display:flex;flex-direction:column;gap:6px}.field-span{grid-column:1 / -1}.field-label{font-size:12.5px;font-weight:500;color:var(--c-text-2)}.field-label em{color:var(--c-danger);font-style:normal}.field-input{width:100%;background:var(--c-surface);border:1px solid var(--c-border);border-radius:8px;padding:9px 12px;font-size:13.5px;color:var(--c-text);transition:border-color .12s,box-shadow .12s}.field-input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-50)}.field-textarea{resize:vertical;min-height:80px;line-height:1.5;font-family:inherit}.field-input::placeholder{color:var(--c-text-3)}select.field-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%2364748B' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.check{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--c-text-2);cursor:pointer}.check input,input[type=checkbox]{accent-color:var(--c-primary)}.form-h{margin:0 0 4px;font-size:16px;font-weight:700}.form-h-span{grid-column:1 / -1}.form-sub{color:var(--c-text-2);font-size:13px;margin:0 0 16px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;gap:8px;padding:14px var(--pad-card);align-items:center}.link{color:var(--c-primary);font-size:12.5px;font-weight:500}.login-wrap{min-height:100vh;display:grid;grid-template-columns:480px 1fr;background:var(--c-surface)}.login-left{padding:60px 56px;display:flex;flex-direction:column;gap:16px}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}.login-h1{font-size:32px;font-weight:700;letter-spacing:-.02em;margin:0}.login-p{color:var(--c-text-2);margin:0 0 12px}.login-form{display:flex;flex-direction:column;gap:14px}.login-row{display:flex;justify-content:space-between;align-items:center}.login-or{display:flex;align-items:center;gap:12px;color:var(--c-text-3);font-size:12px}.login-or:before,.login-or:after{content:"";flex:1;height:1px;background:var(--c-border)}.login-foot{margin-top:auto;font-size:12px;color:var(--c-text-3)}.login-right{background:var(--c-bg);display:grid;place-items:center;padding:40px;position:relative;overflow:hidden;border-left:1px solid var(--c-border)}.login-right:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--c-border-2) 1px,transparent 1px),linear-gradient(90deg,var(--c-border-2) 1px,transparent 1px);background-size:32px 32px;-webkit-mask-image:radial-gradient(ellipse at center,black,transparent 70%);mask-image:radial-gradient(ellipse at center,black,transparent 70%);pointer-events:none}.login-art{position:relative;width:100%;max-width:460px;display:flex;flex-direction:column;gap:16px}.login-art-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:14px;padding:18px;box-shadow:var(--sh-3);display:flex;flex-direction:column;gap:8px}.login-art-card-1{transform:rotate(-1.2deg);margin-right:60px}.login-art-card-2{transform:rotate(1.5deg);margin-left:60px}.art-title{font-size:12px;font-weight:600;font-family:var(--ff-latin);color:var(--c-text-2)}.art-sub{font-size:14px;font-weight:600}.art-bar{height:6px;background:var(--c-surface-2);border-radius:4px;overflow:hidden}.art-bar span{display:block;height:100%;background:var(--c-text)}.art-row{display:flex;align-items:center;gap:4px}.art-row-text{margin-left:8px;font-size:11.5px;color:var(--c-text-2)}.av-stack>*+*{margin-left:-8px}.login-art-stat{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:14px;padding:18px;box-shadow:var(--sh-2)}.art-stat-num{font-size:22px;font-weight:700;font-family:var(--ff-latin)}.art-stat-num span{font-size:12px;color:var(--c-text-2);margin-left:2px}.art-stat-lbl{font-size:11.5px;color:var(--c-text-2)}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}.stat{background:var(--c-surface);border:0;border-radius:var(--r-3);padding:18px 20px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--sh-card)}.stat-head{display:flex;align-items:center;gap:8px}.stat-dot{width:8px;height:8px;border-radius:2px}.stat-label{font-size:12.5px;color:var(--c-text-2);font-weight:500}.stat-row{display:flex;align-items:baseline;justify-content:space-between}.stat-num{font-size:30px;font-weight:600;letter-spacing:-.025em;font-family:var(--ff-latin)}.stat-delta{font-size:12px;color:var(--c-success);font-weight:600;font-family:var(--ff-latin);background:var(--c-success-100);padding:2px 7px;border-radius:6px}.spark{width:100%;height:40px;display:block}.dash-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:var(--gap)}.chart-wrap{width:100%}.chart{width:100%;height:auto}.chart-tick{font-size:10px;fill:var(--c-text-3);font-family:var(--ff-latin)}.legend{display:flex;gap:16px;margin-top:8px}.legend-item{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--c-text-2)}.legend-item i{width:10px;height:10px;border-radius:3px;display:inline-block}.donut-wrap{display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:center}.donut-num{font-size:22px;font-weight:700;fill:var(--c-text);font-family:var(--ff-latin)}.donut-lbl{font-size:10px;fill:var(--c-text-2)}.donut-legend{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:12.5px;color:var(--c-text-2)}.donut-legend li{display:flex;align-items:center;gap:8px}.donut-legend li span{width:10px;height:10px;border-radius:3px}.donut-legend li em{margin-left:auto;font-style:normal;font-weight:700;color:var(--c-text);font-family:var(--ff-latin)}.activity{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.activity li{display:flex;gap:10px}.activity-title{font-size:13px;font-weight:600}.activity-desc{font-size:12.5px;color:var(--c-text-2);margin:2px 0}.activity-time{font-size:11.5px;color:var(--c-text-3)}.deadline{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.deadline li{display:flex;align-items:center;gap:12px;padding:8px;border-radius:10px;cursor:pointer}.deadline li:hover{background:var(--c-surface-2)}.deadline-date{width:48px;text-align:center;padding:6px 0;background:var(--c-primary-100);border-radius:10px}.deadline-day{font-size:18px;font-weight:700;font-family:var(--ff-latin);color:var(--c-primary);line-height:1}.deadline-month{font-size:10px;color:var(--c-primary);font-weight:600;margin-top:2px}.deadline-main{flex:1;min-width:0}.deadline-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deadline-meta{font-size:11.5px;color:var(--c-text-3);display:flex;align-items:center;gap:6px;margin-top:2px}.table-wrap{overflow-x:auto}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl thead th{text-align:left;padding:11px 12px;font-size:11px;font-weight:600;color:var(--c-text-3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--c-border-2);background:var(--c-surface-2)}.tbl tbody td{padding:12px;border-bottom:1px solid var(--c-border-2);vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:0}.tbl tbody tr:hover{background:var(--c-surface-2);cursor:pointer}.tbl-dense tbody td{padding:8px 12px}.tbl-doc{display:flex;align-items:center;gap:10px;min-width:280px}.tbl-doc-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,oklch(.82 .15 152),var(--c-primary));color:#fff;flex-shrink:0;box-shadow:0 4px 10px -4px var(--c-primary)}.tbl-doc-icon[data-type=Travel]{background:linear-gradient(135deg,#ffab9d,#dd503f);background:linear-gradient(135deg,color(xyz 0.684 0.516 0.284),#dd503f);box-shadow:0 4px 10px -4px #dd503f}.tbl-doc-icon[data-type=HR]{background:linear-gradient(135deg,#34dde5,#15d4dd 12.5%,#00d0d8,#00cbd3 25%,#00c1c9,#00b8bf 50%,#009298);background:linear-gradient(135deg,#34dde5,#15d4dd 12.5%,color(xyz 0.348 0.5 0.731),color(xyz 0.328 0.474 0.699) 25%,color(xyz 0.254 0.382 0.581) 50%,color(xyz 0.142 0.234 0.385));box-shadow:0 4px 10px -4px #009298;box-shadow:0 4px 10px -4px oklch(.6 .15 200)}.tbl-doc-icon[data-type=Contract]{background:linear-gradient(135deg,#b8beff,#6f6fe2);background:linear-gradient(135deg,color(xyz 0.591 0.536 1.291),#6f6fe2);box-shadow:0 4px 10px -4px #6f6fe2}.tbl-doc-icon[data-type=Budget]{background:linear-gradient(135deg,#ffc761,#fdb21e,#f0a200,#e09300,#d18500);background:linear-gradient(135deg,color(xyz 0.649 0.626 0.131),#fdb21e,color(xyz 0.492 0.444 0.047),color(xyz 0.424 0.367 0.018),color(xyz 0.363 0.3 -0.003));box-shadow:0 4px 10px -4px #d18500;box-shadow:0 4px 10px -4px oklch(.68 .18 70)}.tbl-doc-icon[data-type=Training]{background:linear-gradient(135deg,#85cdff,#56bdff,#20acf7 50%,#0fa8f4,#00a3ef,#009ee9,#009ae2 75%,#0089c9);background:linear-gradient(135deg,color(xyz 0.494 0.562 1.227),color(xyz 0.401 0.456 1.076),#20acf7 50%,#0fa8f4,color(xyz 0.287 0.324 0.872) 62.5%,color(xyz 0.255 0.287 0.81) 75%,color(xyz 0.198 0.22 0.694));box-shadow:0 4px 10px -4px #0089c9;box-shadow:0 4px 10px -4px oklch(.6 .17 240)}.tbl-doc-title{font-weight:600;font-size:13px}.tbl-doc-id{font-size:11.5px;color:var(--c-text-3);font-family:var(--ff-latin);margin-top:1px}.tbl-amt{font-family:var(--ff-latin);font-weight:600}.tbl-due{font-size:12.5px;color:var(--c-text-2)}.tbl-foot{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-top:1px solid var(--c-border-2);font-size:12.5px;color:var(--c-text-2)}.pager{display:flex;gap:4px}.pager-btn{width:30px;height:30px;border-radius:6px;border:1px solid var(--c-border);background:var(--c-surface);cursor:pointer;font-size:12px;color:var(--c-text-2);display:grid;place-items:center;font-family:var(--ff-latin);font-weight:500}.pager-btn:hover{background:var(--c-surface-2)}.pager-btn.is-active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.search-mini{display:flex;align-items:center;gap:6px;background:var(--c-surface-2);border:1px solid var(--c-border-2);border-radius:8px;padding:6px 10px;min-width:200px}.search-mini input{flex:1;border:0;background:transparent;font-size:12.5px;color:var(--c-text)}.stepper{display:flex;align-items:center;padding:14px 4px}.step{display:flex;align-items:center;gap:10px;position:relative;flex:1;min-width:0}.step-num{width:28px;height:28px;border-radius:50%;background:var(--c-surface);border:2px solid var(--c-border);display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--c-text-3);font-family:var(--ff-latin);flex-shrink:0}.step.is-current .step-num{background:var(--c-primary);color:#fff;border-color:var(--c-primary);box-shadow:0 0 0 5px var(--c-primary-100)}.step.is-done .step-num{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.step-label{font-size:13px;color:var(--c-text-2);font-weight:500;white-space:nowrap}.step.is-current .step-label{color:var(--c-text);font-weight:600}.step.is-done .step-label{color:var(--c-text)}.step-line{flex:1;height:2px;background:var(--c-border);margin:0 6px}.step.is-done .step-line{background:var(--c-primary)}.type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.type-card{background:var(--c-surface);border:2px solid var(--c-border);border-radius:12px;padding:16px;cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:8px;transition:border-color .12s,background .12s}.type-card:hover{border-color:var(--c-text-3)}.type-card.is-active{border-color:var(--c-primary);background:var(--c-primary-50)}.type-icon{width:42px;height:42px;border-radius:12px;background:var(--c-muted-soft);color:var(--c-text);display:grid;place-items:center}.type-card.is-active .type-icon{background:linear-gradient(135deg,oklch(.82 .15 152),var(--c-primary));color:#fff;box-shadow:0 4px 12px -4px var(--c-primary)}.type-label{font-weight:600;font-size:14px}.type-en{font-size:11px;color:var(--c-text-3);font-family:var(--ff-latin)}.approver-preview{background:var(--c-surface-2);border:1px dashed var(--c-border);border-radius:12px;padding:16px}.ap-head{font-size:12.5px;color:var(--c-text-2);font-weight:500;margin-bottom:10px}.ap-flow{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.ap-node{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}.ap-name{font-size:12.5px;font-weight:600}.ap-role{font-size:11px;color:var(--c-text-3)}.drop{display:flex;flex-direction:column;align-items:center;gap:10px;padding:48px 20px;border:2px dashed var(--c-border);border-radius:14px;cursor:pointer;text-align:center;color:var(--c-text-2);transition:background .12s,border-color .12s}.drop:hover,.drop.is-drag{background:var(--c-primary-50);border-color:var(--c-primary);color:var(--c-primary)}.drop-title{font-size:14px;font-weight:500}.drop-title strong{color:var(--c-primary)}.drop-sub{font-size:12px;color:var(--c-text-3)}.files{display:flex;flex-direction:column;gap:6px;margin-top:16px}.files-head{font-size:12.5px;font-weight:600;color:var(--c-text-2);margin-bottom:4px}.file-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--c-surface-2);border-radius:9px}.file-row-clickable{cursor:pointer}.file-row-clickable:hover{background:var(--c-primary-50)}.file-icon{width:32px;height:32px;border-radius:7px;background:var(--c-surface);color:var(--c-text-2);display:grid;place-items:center;border:1px solid var(--c-border)}.file-meta{flex:1;min-width:0}.file-name{font-size:13px;font-weight:600}.file-size{font-size:11.5px;color:var(--c-text-3);font-family:var(--ff-latin)}.review-list{display:flex;flex-direction:column;gap:12px}.review-list>div{display:grid;grid-template-columns:160px 1fr;gap:16px;padding:12px 0;border-bottom:1px solid var(--c-border-2)}.review-list>div:last-child{border:0}.review-list dt{font-size:12.5px;color:var(--c-text-2);margin:0}.review-list dd{margin:0;font-size:13.5px;font-weight:500}.doc-meta{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-text-2);margin-top:6px}.doc-id{font-family:var(--ff-latin);font-weight:600;color:var(--c-text);background:var(--c-surface-2);border:1px solid var(--c-border-2);padding:2px 8px;border-radius:6px;font-size:11.5px}.details-grid{display:grid;grid-template-columns:1fr 320px;gap:var(--gap)}.details-side{display:flex;flex-direction:column;gap:var(--gap)}.kv{display:grid;grid-template-columns:1fr 1fr;gap:16px}.kv>div{display:flex;flex-direction:column;gap:4px}.kv dt{font-size:11.5px;color:var(--c-text-2);margin:0;font-weight:500}.kv dd{font-size:13.5px;font-weight:500;margin:0;display:flex;align-items:center;gap:6px}.kv-amt{font-family:var(--ff-latin);font-weight:700;font-size:16px!important;color:var(--c-text)}.kv-compact{grid-template-columns:1fr;gap:10px}.kv-compact>div{flex-direction:row;justify-content:space-between;align-items:center}.kv-sep{height:1px;background:var(--c-border-2);margin:16px 0}.kv-body h4{margin:0 0 6px;font-size:13.5px;font-weight:600}.kv-body p,.kv-body ul{color:var(--c-text-2);font-size:13px;margin:0 0 14px;line-height:1.6}.kv-body ul{padding-left:20px}.timeline{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px;position:relative}.timeline:before{content:"";position:absolute;left:12px;top:16px;bottom:16px;width:2px;background:var(--c-border-2)}.tl{display:flex;gap:14px;position:relative}.tl-dot{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;z-index:1;background:var(--c-surface);border:2px solid var(--c-border);color:var(--c-text-3)}.tl-approve .tl-dot{background:var(--c-success);color:#fff;border-color:var(--c-success)}.tl-pending .tl-dot{background:var(--c-accent);color:#fff;border-color:var(--c-accent)}.tl-create .tl-dot{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.tl-submit .tl-dot{background:var(--c-surface);color:var(--c-primary);border-color:var(--c-primary)}.tl-card{flex:1;background:var(--c-surface-2);border:1px solid var(--c-border-2);border-radius:10px;padding:10px 14px}.tl-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.tl-title{font-weight:600;font-size:13.5px}.tl-actor{font-size:11.5px;color:var(--c-text-3);display:inline-flex;align-items:center;gap:6px;margin-top:2px}.tl-time{font-size:11px;color:var(--c-text-3);font-family:var(--ff-latin);white-space:nowrap}.tl-note{font-size:12.5px;color:var(--c-text-2);margin-top:6px}.comments{list-style:none;padding:0;margin:0 0 16px;display:flex;flex-direction:column;gap:16px}.comments li{display:flex;gap:10px}.comment-bubble{flex:1;background:var(--c-surface-2);border:1px solid var(--c-border-2);border-radius:12px;padding:12px 14px}.comment-head{font-size:11.5px;color:var(--c-text-3);margin-bottom:4px}.comment-bubble p{margin:0;font-size:13px;line-height:1.55}.comment-input{display:flex;align-items:center;gap:10px;padding-top:14px;border-top:1px solid var(--c-border-2)}.comment-input input{flex:1}.approval-chain{display:flex;flex-direction:column;gap:12px}.chain{display:grid;grid-template-columns:28px 36px 1fr;gap:10px;align-items:center;padding:8px;border-radius:10px}.chain-step{width:22px;height:22px;border-radius:50%;background:var(--c-surface-2);color:var(--c-text-3);display:grid;place-items:center;font-size:11px;font-weight:700;font-family:var(--ff-latin)}.chain.is-done .chain-step,.chain.is-current .chain-step{background:var(--c-primary);color:#fff}.chain-name{font-size:13px;font-weight:600}.chain-status{margin-top:2px}.bulk-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--c-primary-100);color:var(--c-primary);border-radius:var(--r-2);font-size:13px}.inbox{display:flex;flex-direction:column;gap:6px}.inbox-row{display:grid;grid-template-columns:24px 4px 36px 1fr auto auto auto auto;gap:12px;align-items:center;padding:12px 14px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;transition:border-color .12s,box-shadow .12s}.inbox-row:hover{border-color:var(--c-text-3);box-shadow:var(--sh-1)}.inbox-row.is-sel{border-color:var(--c-primary);background:var(--c-primary-50)}.urgency{width:4px;height:32px;border-radius:2px;background:var(--c-text-3)}.urgency-high{background:var(--c-danger)}.urgency-medium{background:var(--c-text)}.urgency-low{background:var(--c-success)}.inbox-main{min-width:0;cursor:pointer}.inbox-title{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inbox-sub{font-size:11.5px;color:var(--c-text-3);display:flex;gap:6px;margin-top:2px}.inbox-amt{font-family:var(--ff-latin);font-weight:700;font-size:14px;white-space:nowrap}.inbox-step{display:flex}.inbox-due{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;color:var(--c-text-2)}.review-grid{display:grid;grid-template-columns:1fr 340px;gap:var(--gap)}.review-side{display:flex;flex-direction:column;gap:var(--gap)}.pdf-preview{background:var(--c-bg);padding:32px;min-height:600px;display:grid;place-items:start center}.pdf-page{background:#fff;color:#0f172a;width:100%;max-width:540px;padding:40px 44px;box-shadow:var(--sh-3);font-size:13px;line-height:1.7;border-radius:4px;min-height:580px}.pdf-h{font-size:13px;font-weight:700}.pdf-sub{font-size:11px;color:#64748b;font-family:var(--ff-latin)}.pdf-sep{height:1px;background:#e5e7eb;margin:16px 0}.pdf-title{font-size:16px;font-weight:700;text-align:center;margin:0 0 16px}.pdf-page p{margin:0 0 10px}.pdf-list{padding-left:20px;margin:0 0 12px}.pdf-list li{margin-bottom:6px}.pdf-sign{margin-top:36px;text-align:center;font-size:12px}.pdf-sign-title{font-size:11px;color:#64748b}.pdf-toolbar{display:flex;align-items:center;gap:6px;padding:10px 14px;border-top:1px solid var(--c-border-2)}.pdf-zoom{font-size:12px;color:var(--c-text-2);font-family:var(--ff-latin)}.decision{display:flex;flex-direction:column;gap:8px}.dec-btn{display:flex;align-items:center;gap:12px;background:var(--c-surface);border:2px solid var(--c-border);border-radius:10px;padding:12px;text-align:left;cursor:pointer;transition:border-color .12s,background .12s}.dec-btn:hover{border-color:var(--c-text-3)}.dec-approve.is-sel{border-color:var(--c-primary);background:var(--c-primary-100);color:var(--c-primary)}.dec-return.is-sel{border-color:var(--c-accent);background:var(--c-accent-100);color:#946900;color:oklch(.55 .16 80)}.dec-reject.is-sel{border-color:var(--c-danger);background:var(--c-danger-100);color:var(--c-danger)}.dec-title{font-size:13.5px;font-weight:600}.dec-sub{font-size:11.5px;color:var(--c-text-2)}.dec-btn.is-sel .dec-sub{color:currentColor;opacity:.7}.page-success{display:grid;place-items:center;min-height:560px}.success-art{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.success-tick{width:84px;height:84px;border-radius:50%;background:var(--c-primary-100);color:var(--c-primary);display:grid;place-items:center;animation:pop .4s cubic-bezier(.2,.7,.3,1.3)}@keyframes pop{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.success-art h2{margin:0;font-size:24px}.success-art p{color:var(--c-text-2);margin:0;max-width:380px}.notif-list{list-style:none;margin:0;padding:0}.notif-list-row{display:grid;grid-template-columns:32px 1fr auto auto;gap:12px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--c-border-2);cursor:pointer;position:relative}.notif-list-row:last-child{border-bottom:0}.notif-list-row:hover{background:var(--c-surface-2)}.notif-list-row.is-unread{background:var(--c-muted-soft)}.notif-list-row.is-unread:hover{background:#eee}.notif-list-icon{width:32px;height:32px;border-radius:8px;display:grid;place-items:center}.notif-list-icon-success{background:var(--c-success-100);color:var(--c-success)}.notif-list-icon-danger{background:var(--c-danger-100);color:var(--c-danger)}.notif-list-icon-warning{background:var(--c-accent-100);color:var(--c-accent)}.notif-list-icon-info{background:var(--c-primary-100);color:var(--c-primary)}.notif-list-icon-muted{background:var(--c-muted-soft);color:var(--c-text-2)}.notif-list-title{font-size:13.5px;font-weight:600}.notif-list-desc{font-size:12.5px;color:var(--c-text-2);margin-top:2px}.notif-list-time{font-size:11.5px;color:var(--c-text-3);white-space:nowrap}.notif-list-row.is-unread .notif-unread{position:relative;top:0;right:0}.profile-grid{max-width:720px}.profile-head{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--c-border-2)}.profile-name{font-size:18px;font-weight:700}.profile-en{font-size:12.5px;color:var(--c-text-2)}.prefs{display:flex;flex-direction:column;gap:4px}.prefs-h{margin:0 0 8px;font-size:12px;font-weight:700;color:var(--c-text-3);text-transform:uppercase;letter-spacing:.08em}.pref-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--c-border-2)}.pref-row:last-child{border-bottom:0}.pref-title{font-size:13.5px;font-weight:600}.pref-sub{font-size:12px;color:var(--c-text-2)}.switch{width:38px;height:22px;border-radius:999px;background:var(--c-muted-soft);border:0;padding:2px;cursor:pointer;position:relative}.switch span{display:block;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .14s;box-shadow:var(--sh-1)}.switch.on{background:var(--c-primary)}.switch.on span{transform:translate(16px)}.flows{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}.flow-meta{display:flex;flex-wrap:wrap;gap:14px;color:var(--c-text-2);font-size:12.5px;margin-bottom:14px}.flow-meta span{display:inline-flex;align-items:center;gap:5px}.flow-diag{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:12px;background:var(--c-surface-2);border-radius:10px}.flow-node{display:flex;align-items:center;gap:8px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:8px;padding:6px 10px}.flow-step{width:22px;height:22px;border-radius:50%;background:var(--c-primary);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center;font-family:var(--ff-latin)}.flow-name{font-size:12.5px;font-weight:600;line-height:1.1}.flow-role{font-size:10.5px;color:var(--c-text-3);font-family:var(--ff-latin)}.flow-actions{display:flex;gap:6px;margin-top:12px}.bars{display:flex;flex-direction:column;gap:10px}.bar-row{display:grid;grid-template-columns:120px 1fr 40px;align-items:center;gap:12px;font-size:12.5px}.bar-label{color:var(--c-text-2)}.bar-track{height:8px;background:var(--c-surface-2);border-radius:4px;overflow:hidden}.bar-fill{height:100%;background:var(--c-text);border-radius:4px;transition:width .4s}.bar-val{text-align:right;font-family:var(--ff-latin);font-weight:600}.toast-stack{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:100}.toast{display:flex;gap:10px;align-items:flex-start;background:var(--c-surface);border:1px solid var(--c-border);border-radius:10px;padding:12px 14px;min-width:280px;max-width:360px;box-shadow:var(--sh-3);animation:toastIn .25s cubic-bezier(.2,.7,.3,1)}.toast-success{border-left:3px solid var(--c-primary)}.toast-danger{border-left:3px solid var(--c-danger)}.toast-info{border-left:3px solid var(--c-primary)}.toast-title{font-size:13px;font-weight:600}.toast-desc{font-size:12px;color:var(--c-text-2);margin-top:2px}@keyframes toastIn{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.channels{display:flex;flex-direction:column;gap:8px}.channel{display:grid;grid-template-columns:40px 1fr auto;gap:14px;align-items:center;padding:12px;background:var(--c-surface);border:1px solid var(--c-border-2);border-radius:10px}.ch-icon{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:var(--c-muted-soft);color:var(--c-text-2)}.ch-icon-lg{width:56px;height:56px;border-radius:14px}.ch-icon-line{background:var(--c-line);color:#fff}.ch-icon-sms{background:#eff1ff;background:oklch(.96 .04 280);color:#4134ab}.ch-icon-email{background:#def7ff;background:oklch(.96 .04 220);color:#00566a;color:oklch(.42 .18 220)}.ch-icon-app{background:#ffeee2;background:oklch(.96 .04 60);color:#733e00;color:oklch(.42 .16 60)}.ch-name{font-size:13.5px;font-weight:600}.ch-sub{font-size:12px;color:var(--c-text-2);margin-top:2px}.line-banner{display:flex;align-items:center;gap:14px;background:var(--c-line-100);border:1px solid var(--c-line);border-radius:12px;padding:14px 16px;margin-bottom:16px}.line-banner-title{font-size:14px;font-weight:600}.line-banner-sub{font-size:12.5px;color:var(--c-text-2);margin-top:2px}.prefs-headrow{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.sms-row{display:flex;gap:12px;align-items:flex-end}.field-hint{font-size:11.5px;color:var(--c-text-3)}.sms-foot{display:flex;align-items:center;gap:6px;padding:10px 12px;margin-top:14px;background:var(--c-muted-soft);border-radius:8px;font-size:11.5px;color:var(--c-text-2)}.pref-row.is-disabled{opacity:.5;pointer-events:none}.switch:disabled{opacity:.4;cursor:not-allowed}.qr-box{position:relative;padding:14px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px}.qr-line-badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:36px;height:36px;background:var(--c-line);border-radius:9px;display:grid;place-items:center;border:4px solid var(--c-surface)}.qr-meta{text-align:center}.qr-title{font-weight:600;font-size:14px}.qr-sub{font-size:12px;color:var(--c-text-2);margin-top:4px}.qr-step{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--c-muted-soft);border-radius:999px;font-size:12px;color:var(--c-text-2)}.qr-step:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--c-line);animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1116;z-index:200;display:grid;place-items:center;padding:20px;animation:bdFade .15s ease}@keyframes bdFade{0%{opacity:0}to{opacity:1}}.modal{background:var(--c-surface);border-radius:14px;width:100%;max-width:520px;box-shadow:var(--sh-3);display:flex;flex-direction:column;animation:modalIn .2s cubic-bezier(.2,.7,.3,1)}.modal-sm{max-width:360px}@keyframes modalIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 12px;border-bottom:1px solid var(--c-border-2)}.modal-head h3{margin:0;font-size:15px;font-weight:600}.modal-body{padding:18px 22px}.modal-foot{display:flex;gap:8px;padding:14px 22px;border-top:1px solid var(--c-border-2);justify-content:flex-end}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#11111159;z-index:200;display:flex;justify-content:flex-end;animation:bdFade .15s ease}.drawer{width:440px;max-width:100%;height:100vh;background:var(--c-surface);display:flex;flex-direction:column;box-shadow:var(--sh-3);animation:drawerIn .22s cubic-bezier(.2,.7,.3,1)}@keyframes drawerIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.drawer-head{display:flex;align-items:center;gap:12px;padding:20px 22px;border-bottom:1px solid var(--c-border-2)}.drawer-title{font-size:16px;font-weight:600}.drawer-sub{font-size:12px;color:var(--c-text-2);margin-top:2px}.drawer-body{flex:1;padding:20px 22px;overflow-y:auto}.drawer-foot{display:flex;gap:8px;padding:14px 22px;border-top:1px solid var(--c-border-2);align-items:center}.user-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}.user-stat{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-3);padding:16px 18px}.user-stat-num{font-size:26px;font-weight:600;letter-spacing:-.02em;font-family:var(--ff-latin);line-height:1.1}.user-stat-lbl{font-size:12px;color:var(--c-text-2);margin-top:4px}.builder-grid{display:grid;grid-template-columns:1fr 320px;gap:var(--gap)}.builder-side{display:flex;flex-direction:column;gap:var(--gap)}.cond-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-text-2);flex-wrap:wrap}.cond-pick{width:140px}.cond-op{width:200px}.cond-val{width:120px}.cond-add{display:flex;gap:12px;margin-top:12px;padding-top:12px;border-top:1px dashed var(--c-border)}.link-add{background:transparent;border:0;color:var(--c-text-2);font-size:12px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;padding:4px 0}.link-add:hover{color:var(--c-text)}.builder-steps{display:flex;flex-direction:column;align-items:stretch}.builder-anchor{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--c-muted-soft);border-radius:8px;font-size:12.5px;color:var(--c-text-2)}.builder-anchor-start,.builder-anchor-end{color:var(--c-text)}.builder-line{width:2px;height:16px;background:var(--c-border);margin-left:18px}.builder-step{display:grid;grid-template-columns:18px 28px 1fr auto;gap:12px;align-items:flex-start;background:var(--c-surface);border:1px solid var(--c-border);border-radius:10px;padding:12px 14px}.bs-handle{color:var(--c-text-3);cursor:grab;padding-top:6px}.bs-num{width:26px;height:26px;border-radius:50%;background:var(--c-primary);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;font-family:var(--ff-latin);margin-top:2px}.bs-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}.bs-input{background:transparent;border:0;padding:0;font-size:13px;font-weight:500;color:var(--c-text);border-bottom:1px dashed transparent}.bs-input:hover,.bs-input:focus{border-bottom-color:var(--c-border)}.bs-input-h{font-size:14px;font-weight:600}.bs-row{display:flex;gap:10px}.bs-field{flex:1;display:flex;flex-direction:column;gap:4px}.bs-field>span{font-size:11px;color:var(--c-text-3)}.bs-field .field-input{padding:6px 10px;font-size:12.5px}.bs-actions{display:flex;flex-direction:column;gap:2px}.bs-actions .icon-btn{width:26px;height:26px}.flow-trigger,.flow-end{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:var(--c-surface);border:1px dashed var(--c-border);border-radius:8px;font-size:11.5px;color:var(--c-text-2)}.flow-end{background:var(--c-muted-soft);border-style:solid}.preview-flow{display:flex;flex-direction:column;gap:6px}.pf-node{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:9px}.pf-start,.pf-end{background:var(--c-muted-soft);border:0;font-size:12px;color:var(--c-text-2);padding:8px 12px}.pf-name{font-size:12.5px;font-weight:600}.pf-sub{font-size:11px;color:var(--c-text-3)}.pf-arrow{color:var(--c-text-3);display:flex;align-items:center;padding-left:14px}.line-preview{background:var(--c-muted-soft);border-radius:12px;padding:14px}.lp-head{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:12.5px}.lp-avatar{width:22px;height:22px;border-radius:50%;background:var(--c-line);display:grid;place-items:center}.lp-bubble{background:var(--c-surface);border-radius:4px 14px 14px;padding:12px 14px;box-shadow:var(--sh-1)}.lp-cta{margin-top:8px;padding:6px 12px;background:var(--c-line);color:#fff;border-radius:6px;font-size:12px;font-weight:600;text-align:center;cursor:pointer}.exp{background:var(--c-surface-2);border-radius:var(--r-3);padding:16px}.exp-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.exp-title{font-size:14px;font-weight:600}.exp-sub{font-size:12px;color:var(--c-text-2);margin-top:2px;max-width:520px}.exp-wrap{overflow-x:auto;background:var(--c-surface);border-radius:var(--r-2);border:1px solid var(--c-border-2)}.exp-tbl{width:100%;border-collapse:collapse;font-size:13px;min-width:720px}.exp-tbl thead th{text-align:left;padding:10px 12px;font-size:11px;font-weight:600;color:var(--c-text-3);text-transform:uppercase;letter-spacing:.04em;background:var(--c-surface-2);border-bottom:1px solid var(--c-border)}.exp-tbl tbody td{padding:8px 10px;border-bottom:1px solid var(--c-border-2);vertical-align:middle}.exp-tbl tbody tr:last-child td{border-bottom:0}.exp-idx{text-align:center;font-family:var(--ff-latin);color:var(--c-text-3);font-weight:600;font-size:12px}.exp-input{width:100%;background:transparent;border:1px solid transparent;border-radius:6px;padding:8px 10px;font-size:13px;color:var(--c-text);font-family:inherit;transition:border-color .12s,background .12s}.exp-input:hover{background:var(--c-surface-2)}.exp-input:focus{outline:none;border-color:var(--c-primary);background:var(--c-surface);box-shadow:0 0 0 3px var(--c-primary-100)}.exp-input[type=number]{font-family:var(--ff-latin)}.exp-input.ta-right,.ta-right{text-align:right}.exp-total{font-family:var(--ff-latin);font-weight:600;color:var(--c-text);padding-right:14px!important}.exp-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:28px 12px;color:var(--c-text-3);font-size:13px}.exp-tbl tfoot td{padding:12px 14px;background:var(--c-surface-2);border-top:2px solid var(--c-border)}.exp-foot-label{color:var(--c-text-2);font-size:12px;display:flex;align-items:center;gap:6px}.exp-grand{padding-right:14px!important}.exp-grand-lbl{font-size:11px;color:var(--c-text-2)}.exp-grand-val{font-family:var(--ff-latin);font-weight:700;font-size:18px;color:var(--c-primary);margin-top:2px}.exp-foot-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;padding:0 4px}.exp-note{font-size:11.5px;color:var(--c-text-3)}.dt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}.dt-card{background:var(--c-surface);border-radius:var(--r-3);padding:20px;box-shadow:var(--sh-card);display:flex;flex-direction:column;gap:12px;transition:transform .12s,box-shadow .12s}.dt-card:hover{transform:translateY(-2px);box-shadow:var(--sh-3)}.dt-card.is-off{opacity:.55}.dt-head{display:flex;align-items:center;gap:12px}.dt-icon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;color:#fff;flex-shrink:0}.dt-label{font-size:15px;font-weight:600}.dt-key{font-size:11.5px;color:var(--c-text-3);font-family:var(--ff-latin);margin-top:2px}.dt-desc{font-size:12.5px;color:var(--c-text-2);line-height:1.55;margin:0;min-height:38px}.dt-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:11.5px;color:var(--c-text-2);padding:10px 12px;background:var(--c-surface-2);border-radius:10px}.dt-meta span{display:inline-flex;align-items:center;gap:5px}.dt-actions{display:flex;gap:4px;border-top:1px solid var(--c-border-2);margin-top:2px;padding-top:12px}.dt-add{border:2px dashed var(--c-border);background:transparent;box-shadow:none;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;cursor:pointer;gap:8px;min-height:220px;color:var(--c-text-2)}.dt-add:hover{border-color:var(--c-primary);background:var(--c-primary-50);color:var(--c-primary);transform:translateY(-2px)}.dt-add-icon{width:52px;height:52px;border-radius:14px;background:var(--c-muted-soft);display:grid;place-items:center}.dt-add:hover .dt-add-icon{background:var(--c-primary);color:#fff}.dt-add-title{font-size:14px;font-weight:600}.dt-add-sub{font-size:12px;color:var(--c-text-3)}.dt-preview{display:flex;align-items:center;gap:14px;padding:14px;background:var(--c-surface-2);border-radius:var(--r-2)}.icon-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:6px}.icon-pick{width:40px;height:40px;border-radius:8px;background:var(--c-surface);border:1px solid var(--c-border);display:grid;place-items:center;cursor:pointer;color:var(--c-text-2)}.icon-pick:hover{background:var(--c-surface-2);color:var(--c-text)}.icon-pick.is-active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.color-picker{display:flex;flex-wrap:wrap;gap:8px}.color-pick{width:32px;height:32px;border-radius:50%;border:0;cursor:pointer;display:grid;place-items:center;color:#fff;position:relative;transition:transform .12s}.color-pick:hover{transform:scale(1.08)}.color-pick.is-active{box-shadow:0 0 0 3px var(--c-surface),0 0 0 5px var(--c-text)}.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--c-hero),var(--c-hero-2));color:#fff;border-radius:var(--r-4);padding:28px 32px;box-shadow:0 12px 32px -16px #1f293766}.hero-shape{position:absolute;border-radius:50%;pointer-events:none;background:radial-gradient(circle,rgba(34,197,94,.4),transparent 70%)}.hero-shape-1{width:280px;height:280px;right:-80px;top:-120px}.hero-shape-2{width:220px;height:220px;right:120px;bottom:-140px;background:radial-gradient(circle,rgba(251,191,36,.2),transparent 70%)}.hero-body{display:flex;align-items:center;justify-content:space-between;gap:20px;position:relative}.hero-left{display:flex;align-items:center;gap:16px}.hero-eyebrow{font-size:13px;opacity:.7}.hero-title{font-size:22px;font-weight:700;letter-spacing:-.01em;margin-top:2px}.hero-sub{font-size:12.5px;opacity:.6;margin-top:2px}.hero-cta{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--c-text);padding:10px 18px;border-radius:var(--r-pill);border:0;font-size:13.5px;font-weight:600;cursor:pointer;box-shadow:0 6px 16px -8px #0000004d;transition:transform .08s,background .15s}.hero-cta:hover{background:#fafafa}.hero-cta:active{transform:translateY(1px)}.hero-stats{display:flex;gap:40px;margin-top:22px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);position:relative}.hero-stat-num{font-size:22px;font-weight:700;font-family:var(--ff-latin);letter-spacing:-.02em}.hero-stat-lbl{font-size:12px;opacity:.65;margin-top:2px}.qa-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.qa-item{background:transparent;border:0;padding:14px 12px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;border-radius:var(--r-2);transition:background .15s,transform .08s}.qa-item:hover{background:var(--c-surface-2)}.qa-item:active{transform:translateY(1px)}.qa-icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;color:#fff}.qa-icon-primary{background:linear-gradient(135deg,oklch(.82 .15 152),var(--c-primary));box-shadow:0 6px 14px -6px var(--c-primary)}.qa-icon-blue{background:linear-gradient(135deg,#4bc6fa,#2fb7f2 25%,#1cafee,#00a7ea,#00a0e1,#0098d9 75%,#0089c9);background:linear-gradient(135deg,#4bc6fa,#2fb7f2 25%,#1cafee,color(xyz 0.287 0.337 0.831),color(xyz 0.262 0.305 0.795),color(xyz 0.239 0.275 0.761) 75%,color(xyz 0.198 0.22 0.694));box-shadow:0 6px 14px -6px #0089c9;box-shadow:0 6px 14px -6px oklch(.6 .17 240)}.qa-icon-amber{background:linear-gradient(135deg,#ffc761,#e68100);background:linear-gradient(135deg,color(xyz 0.649 0.626 0.131),color(xyz 0.416 0.324 0.02));box-shadow:0 6px 14px -6px #e68100;box-shadow:0 6px 14px -6px oklch(.7 .18 60)}.qa-icon-pink{background:linear-gradient(135deg,#ff8cc5,#cf48ab);background:linear-gradient(135deg,color(xyz 0.613 0.438 0.584),#cf48ab);box-shadow:0 6px 14px -6px #cf48ab}.qa-icon-purple{background:linear-gradient(135deg,#b6aaff,#8362ed);background:linear-gradient(135deg,color(xyz 0.546 0.452 1.207),#8362ed);box-shadow:0 6px 14px -6px #8362ed}.qa-label{font-size:12.5px;font-weight:500;color:var(--c-text)}@media (max-width: 1100px){.app{grid-template-columns:64px 1fr}.sidebar-brand>div,.sidebar-label,.sidebar-item span,.sidebar-badge,.brand-sub{display:none}.sidebar{padding:18px 8px 14px}.sidebar-brand{justify-content:center;padding:4px 0 18px}.sidebar-item{justify-content:center;padding:9px}.dash-grid,.details-grid,.review-grid,.flows,.form-grid,.builder-grid{grid-template-columns:1fr}.user-stat-grid,.dt-grid{grid-template-columns:repeat(2,1fr)}.drawer{width:100%}.stat-grid{grid-template-columns:repeat(2,1fr)}}
