*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#E8640A;--primary-dk:#C4500A;--primary-lt:#FEF0E6;--dark:#111827;--dark2:#1F2937;--bg:#F3F4F6;--surface:#FFFFFF;--border:#E5E7EB;--text:#111827;--muted:#6B7280;--green:#16A34A;--green-lt:#DCFCE7;--blue:#2563EB;--blue-lt:#DBEAFE;--orange-status:#EA580C;--orange-lt:#FFEDD5;--red:#DC2626;--red-lt:#FEE2E2;--font:"Prompt","Noto Sans Thai",sans-serif;--r-sm:8px;--r-md:12px;--r-lg:16px;--shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);--shadow-md:0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06)}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px}.app{display:grid;grid-template-rows:auto auto 1fr;height:100vh;overflow:hidden}header{background:var(--dark);padding:0 20px;height:56px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,.06)}.hdr-logo{height:30px;object-fit:contain}.hdr-divider{width:1px;height:20px;background:#ffffff1f}.hdr-title{font-size:13px;font-weight:600;color:#fff;flex:1;letter-spacing:.2px}.hdr-user{display:flex;align-items:center;gap:8px}.hdr-role-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;letter-spacing:.5px}.role-admin{background:#e8640a40;color:#fca67a}.role-hr{background:#2563eb40;color:#93c5fd}.hdr-name{font-size:12px;color:#ffffffa6}.hdr-btns{display:flex;gap:2px}.hdr-btn{background:transparent;border:none;color:#ffffff8c;width:34px;height:34px;border-radius:var(--r-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;transition:all .15s}.hdr-btn:hover{background:#ffffff14;color:#fff}.main{display:grid;grid-template-columns:272px 1fr;overflow:hidden}aside{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.aside-top{padding:14px 12px;display:flex;flex-direction:column;gap:10px;border-bottom:1px solid var(--border)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.stat-card{background:var(--bg);border-radius:var(--r-sm);padding:10px 12px;border:1px solid var(--border);display:flex;align-items:center;gap:10px}.stat-card-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.stat-n{font-size:20px;font-weight:700;line-height:1}.stat-l{font-size:10px;color:var(--muted);margin-top:1px}.stat-card.all{grid-column:1/-1;background:linear-gradient(135deg,#fef0e6,#fde8d8);border-color:#f9cba8}.stat-card.all .stat-card-icon{background:#e8640a26}.stat-card.all .stat-card-icon .ti,.stat-card.all .stat-n{color:var(--primary)}.stat-card.s-new .stat-card-icon{background:var(--blue-lt)}.stat-card.s-new .stat-card-icon .ti{color:var(--blue)}.stat-card.s-proc .stat-card-icon{background:var(--orange-lt)}.stat-card.s-proc .stat-card-icon .ti{color:var(--orange-status)}.stat-card.s-done .stat-card-icon{background:var(--green-lt)}.stat-card.s-done .stat-card-icon .ti{color:var(--green)}.search-wrap{position:relative}.search-wrap input{width:100%;padding:8px 10px 8px 32px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:13px;background:var(--bg);color:var(--text);transition:border-color .15s;font-family:var(--font)}.search-wrap input:focus{outline:none;border-color:var(--primary);background:#fff}.search-wrap .ti-search{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:15px;pointer-events:none}.filter-row{display:flex;gap:4px}.flt{flex:1;padding:5px 0;font-size:11px;font-weight:500;border:1px solid var(--border);border-radius:20px;background:transparent;cursor:pointer;color:var(--muted);text-align:center;transition:all .15s;font-family:var(--font)}.flt:hover{border-color:#d1d5db;color:var(--text)}.flt.active{border-color:var(--primary);background:var(--primary-lt);color:var(--primary-dk);font-weight:600}.cdd{position:relative;flex:1}.cdd-btn{width:100%;display:flex;align-items:center;gap:6px;padding:5px 9px;border:1px solid var(--border);border-radius:8px;background:var(--surface);font-size:12px;font-family:var(--font);color:var(--text);cursor:pointer;text-align:left;transition:border-color .15s}.cdd-btn:hover{border-color:#d1d5db}.cdd-btn.open{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-lt)}.cdd-btn svg{flex-shrink:0}.cdd-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cdd-chevron{margin-left:auto;color:var(--muted);transition:transform .15s;flex-shrink:0}.cdd-btn.open .cdd-chevron{transform:rotate(180deg)}.cdd-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px #0000001a;z-index:100;overflow:hidden;display:none}.cdd-menu.open{display:block}.cdd-item{display:flex;align-items:center;gap:8px;padding:7px 10px;font-size:12px;font-family:var(--font);color:var(--text);cursor:pointer;transition:background .1s}.cdd-item:hover{background:var(--bg)}.cdd-item.active{background:var(--primary-lt);color:var(--primary-dk);font-weight:600}.cdd-item svg{flex-shrink:0}.ticket-list{flex:1;overflow-y:auto;padding:8px}.ticket-list-inner{display:flex;flex-direction:column;gap:4px}.tk-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 12px;cursor:pointer;transition:all .15s}.tk-card:hover{border-color:#d1d5db;box-shadow:var(--shadow)}.tk-card.sel{border-color:var(--primary);background:var(--primary-lt);box-shadow:0 0 0 1px var(--primary)}.tk-top{display:flex;align-items:center;gap:4px;margin-bottom:3px;overflow:hidden}.tk-id{font-size:10px;color:var(--muted);font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tk-badges{display:flex;align-items:center;gap:4px;flex-shrink:0}.tk-meta{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}.tk-time{font-size:10px;color:var(--muted)}.pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;white-space:nowrap}.p-new{background:var(--blue-lt);color:var(--blue)}.p-proc{background:var(--orange-lt);color:var(--orange-status)}.p-done{background:var(--green-lt);color:var(--green)}.pill .ti{font-size:10px}.p-proc .ti{animation:blink 1.2s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.pri-high{background:#fee2e2;color:#dc2626}.pri-medium{background:#fef3c7;color:#d97706}.pri-low{background:#f3f4f6;color:#6b7280}.priority-select{display:flex;gap:6px;margin-bottom:14px}.priority-select button{flex:1;padding:6px 4px;border-radius:8px;border:2px solid transparent;font-size:11px;font-weight:600;cursor:pointer;background:var(--bg);color:var(--muted);transition:.15s}.priority-select button.active-high{background:#fee2e2;color:#dc2626;border-color:#dc2626}.priority-select button.active-medium{background:#fef3c7;color:#d97706;border-color:#d97706}.priority-select button.active-low{background:#f3f4f6;color:#6b7280;border-color:#9ca3af}.detail{padding:20px;overflow-y:auto;background:var(--bg)}.detail-card{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;margin-bottom:16px}.detail-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px}.topic-icon{width:42px;height:42px;background:var(--primary-lt);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;color:var(--primary)}.detail-header h2{font-size:15px;font-weight:600;flex:1}.detail-body{padding:20px}.step-track{display:flex;align-items:flex-start;margin:16px 0}.step-item{flex:1;display:flex;flex-direction:column;align-items:center;position:relative}.step-item:not(:last-child):after{content:"";position:absolute;top:13px;left:50%;width:100%;height:2px;background:var(--border);z-index:0}.step-item.done:after{background:var(--primary)}.step-c{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;z-index:1;position:relative;border:2px solid var(--border);background:var(--surface);color:var(--muted);font-weight:700}.step-item.done .step-c{background:var(--primary);border-color:var(--primary);color:#fff}.step-item.active .step-c{background:var(--orange-lt);border-color:var(--primary);color:var(--primary-dk)}.step-lbl{font-size:9px;color:var(--muted);margin-top:5px;text-align:center;line-height:1.3;max-width:56px}.step-item.done .step-lbl{color:var(--primary-dk)}.step-item.active .step-lbl{color:var(--primary)}.prog-wrap{margin:8px 0 12px}.prog-bar{height:6px;background:var(--border);border-radius:10px;overflow:hidden;margin-top:6px}.prog-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-dk));border-radius:10px;transition:width .5s}.prog-row{display:flex;justify-content:space-between;font-size:11px;color:var(--muted)}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.info-item{background:var(--bg);border-radius:var(--r-sm);padding:8px 10px;border:1px solid var(--border)}.info-item label{font-size:10px;color:var(--muted);display:flex;align-items:center;gap:4px;margin-bottom:3px;text-transform:uppercase;letter-spacing:.5px}.info-item label .ti{font-size:12px}.info-item span{font-size:13px;font-weight:500}.assign-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 16px;margin-bottom:14px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow)}.assign-avatar{width:42px;height:42px;border-radius:12px;background:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.assign-avatar .ti{font-size:22px;color:#fff}.assign-avatar.unassigned{background:var(--bg);border:2px dashed var(--border)}.assign-avatar.unassigned .ti{color:var(--muted)}.assign-name{font-size:14px;font-weight:700}.assign-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.step-msg-box{background:#fffbf7;border:1px solid #F9CBA8;border-radius:var(--r-sm);padding:12px;margin-bottom:14px}.step-msg-box label{font-size:11px;color:var(--primary-dk);font-weight:600;display:flex;align-items:center;gap:5px;margin-bottom:6px}.step-msg-box textarea{width:100%;padding:8px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:13px;resize:vertical;min-height:60px;font-family:var(--font);background:#fff;color:var(--text)}.notes-box{background:var(--bg);border-radius:var(--r-sm);padding:10px;font-size:12px;color:var(--text);white-space:pre-wrap;min-height:36px;border:1px solid var(--border);margin-bottom:6px}.note-input{display:flex;gap:6px}.note-input input{flex:1;padding:7px 10px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:13px;background:var(--surface);color:var(--text);font-family:var(--font)}.note-input input:focus{outline:none;border-color:var(--primary)}.section-label{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;display:flex;align-items:center;gap:5px}.section-label .ti{font-size:13px}.actions{display:flex;gap:8px;flex-wrap:wrap;padding-top:14px;border-top:1px solid var(--border);margin-top:14px}.btn{padding:8px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:500;border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s;font-family:var(--font)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dk)}.btn-line{background:#06c755;border-color:#06c755;color:#fff}.btn-line:hover{background:#05a847}.btn-ghost{background:transparent;color:var(--text)}.btn-ghost:hover{background:var(--bg)}.btn-danger{background:var(--red);border-color:var(--red);color:#fff}.btn-danger:hover{background:#b91c1c}.btn:disabled{opacity:.35;cursor:default;pointer-events:none}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a1628;z-index:100;display:flex;align-items:center;justify-content:center}.login-overlay:before{content:"";position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(232,100,10,.13) 0%,transparent 65%);top:-200px;left:-150px;pointer-events:none}.login-card{background:#fff;border-radius:24px;padding:40px 36px 32px;width:380px;box-shadow:0 40px 100px #0000008c;position:relative;z-index:1}.login-logo-wrap{text-align:center;margin-bottom:24px;min-height:52px;display:flex;align-items:center;justify-content:center}.login-logo{height:52px;object-fit:contain}.login-logo-fallback{display:none;flex-direction:column;align-items:center;gap:6px}.login-logo-icon{width:52px;height:52px;background:var(--primary);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;color:#fff}.login-brand-name{font-size:15px;font-weight:800;letter-spacing:2px;color:var(--dark)}.login-title{font-size:20px;font-weight:700;color:var(--dark);text-align:center;margin-bottom:4px}.login-subtitle{font-size:12px;color:var(--muted);text-align:center;margin-bottom:24px;line-height:1.5}.login-rule{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin-bottom:24px}.field-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;display:block}.field-wrap{position:relative;margin-bottom:12px}.field-wrap input{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:14px;background:var(--bg);color:var(--text);transition:border-color .15s;font-family:var(--font)}.field-wrap input:focus{outline:none;border-color:var(--primary);background:#fff}.pw-wrap{position:relative;margin-bottom:12px}.pw-wrap input{width:100%;padding:11px 42px 11px 14px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:14px;background:var(--bg);color:var(--text);transition:border-color .15s;font-family:var(--font)}.pw-wrap input::-ms-reveal,.pw-wrap input::-ms-clear{display:none}.pw-wrap input:focus{outline:none;border-color:var(--primary);background:#fff}.pw-toggle{position:absolute;right:11px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);font-size:18px;padding:0;line-height:1}.login-err{font-size:12px;color:var(--red);margin-bottom:10px;display:flex;align-items:center;gap:4px;min-height:18px}.login-footer{text-align:center;font-size:11px;color:#cbd5e1;margin-top:20px}.page-nav{background:var(--surface);border-bottom:1px solid var(--border);display:flex;gap:0;padding:0 20px}.nav-tab{padding:10px 18px;font-size:13px;font-weight:500;border:none;background:transparent;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;display:flex;align-items:center;gap:6px;transition:all .15s;font-family:var(--font)}.nav-tab .ti{font-size:15px}.nav-tab:hover{color:var(--text)}.nav-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.nav-tab.hidden{display:none}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:50;display:none;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-bg.open{display:flex}.modal{background:var(--surface);border-radius:var(--r-lg);padding:24px;width:400px;box-shadow:0 20px 60px #0003}.modal h3{font-size:15px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:8px}.modal textarea{width:100%;padding:10px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:13px;resize:vertical;min-height:80px;background:var(--bg);color:var(--text);font-family:var(--font);margin-bottom:12px}.modal textarea:focus{outline:none;border-color:var(--primary)}.modal input[type=text],.modal input[type=url],.modal input[type=password]{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:13px;margin-bottom:10px;background:var(--bg);color:var(--text);font-family:var(--font);transition:border-color .15s}.modal input:focus{outline:none;border-color:var(--primary)}.modal label{font-size:11px;color:var(--muted);display:block;margin-bottom:4px;font-weight:500}.modal select{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:13px;margin-bottom:10px;background:var(--bg);color:var(--text);font-family:var(--font)}.modal-actions{display:flex;gap:8px;justify-content:flex-end}#authPopup{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}#authPopup.show{opacity:1;pointer-events:auto}.auth-popup-card{background:#fff;border-radius:20px;padding:36px 32px;min-width:300px;text-align:center;box-shadow:0 24px 64px #0003;transform:scale(.93) translateY(8px);transition:transform .25s}#authPopup.show .auth-popup-card{transform:scale(1) translateY(0)}.auth-popup-icon{width:68px;height:68px;margin:0 auto 18px}.auth-popup-icon svg{width:68px;height:68px}.auth-popup-title{font-size:17px;font-weight:700;margin-bottom:6px}.auth-popup-sub{font-size:13px;color:var(--muted);margin-bottom:24px;line-height:1.7}.auth-popup-btns{display:flex;gap:8px;justify-content:center}.auth-popup-btn{padding:9px 24px;border-radius:10px;border:none;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font)}.auth-popup-btn.ok{background:var(--primary);color:#fff}.auth-popup-btn.neutral{background:var(--bg);color:var(--text);border:1px solid var(--border)}.auth-popup-btn.danger{background:var(--red);color:#fff}#toast{position:fixed;bottom:24px;right:24px;background:var(--dark);color:#fff;padding:10px 16px;border-radius:var(--r-md);font-size:13px;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;z-index:999;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-md);transform:translateY(6px)}#toast.show{opacity:1;transform:translateY(0)}.summary-page{display:none;overflow-y:auto;padding:20px 24px 28px;background:var(--bg)}.summary-page.active{display:block}.main.hidden{display:none}.sum-page-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px 14px;margin-bottom:20px;box-shadow:var(--shadow)}.sum-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}.sum-header-top h2{font-size:16px;font-weight:700;display:flex;align-items:center;gap:7px}.sum-header-top h2 .ti{color:var(--primary);font-size:18px}.sum-date-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--border)}.sum-date-bar .sum-date-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-right:2px;display:flex;align-items:center;gap:4px}.date-preset{padding:5px 12px;font-size:12px;font-weight:500;border:1px solid var(--border);border-radius:20px;background:transparent;cursor:pointer;color:var(--muted);font-family:var(--font)}.date-preset.active{border-color:var(--primary);background:var(--primary-lt);color:var(--primary);font-weight:600}.date-custom{display:flex;align-items:center;gap:6px;margin-left:4px}.date-custom input[type=date]{padding:4px 8px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:12px;font-family:var(--font);color:var(--text);background:var(--bg)}.sum-kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.sum-kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:18px 20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow)}.sum-kpi-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.sum-kpi-body{flex:1}.sum-kpi-val{font-size:28px;font-weight:700;line-height:1}.sum-kpi-label{font-size:11px;color:var(--muted);margin-top:3px;font-weight:500}.sum-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;margin-bottom:16px;box-shadow:var(--shadow)}.sum-section-title{font-size:13px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:6px}.sum-section-title .ti{font-size:16px;color:var(--primary)}.topic-row{display:grid;grid-template-columns:140px 1fr 120px;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.topic-row:last-child{border-bottom:none}.stacked-bar{height:10px;border-radius:6px;overflow:hidden;background:var(--border);display:flex}.stacked-seg{height:100%}.hr-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}.hr-row:last-child{border-bottom:none}.hr-avatar{width:34px;height:34px;border-radius:10px;background:var(--primary-lt);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.hr-bar-wrap{flex:1}.hr-bar-bg{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-top:4px}.hr-bar-fill{height:100%;background:var(--primary);border-radius:4px}.pri-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.pri-row:last-child{border-bottom:none}.pri-bar-wrap{flex:1;height:10px;background:var(--border);border-radius:6px;overflow:hidden}.pri-bar-fill{height:100%;border-radius:6px}.admin-page{display:none;grid-template-columns:210px 1fr;overflow:hidden}.admin-page.active{display:grid}.admin-sidebar{background:var(--surface);border-right:1px solid var(--border);padding:20px 0;overflow-y:auto;display:flex;flex-direction:column}.admin-sidebar-title{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.8px;padding:0 16px 12px;text-transform:uppercase}.admin-nav{display:flex;flex-direction:column;gap:2px;padding:0 8px}.admin-nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-sm);border:none;background:transparent;cursor:pointer;font-size:13px;font-weight:500;color:var(--muted);text-align:left;width:100%;font-family:var(--font);transition:all .15s}.admin-nav-item:hover{background:var(--bg);color:var(--text)}.admin-nav-item.active{background:var(--primary-lt);color:var(--primary-dk);font-weight:600}.admin-nav-item .ti{font-size:17px}.admin-nav-divider{height:1px;background:var(--border);margin:8px 16px}.admin-content{overflow-y:auto;padding:28px;background:var(--bg)}.admin-sec{max-width:720px}.admin-sec-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:4px}.admin-sec-header h3{font-size:15px;font-weight:700;margin-bottom:3px}.admin-sec-header p{font-size:12px;color:var(--muted);line-height:1.5}.conn-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 18px}.conn-card-title{font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:10px}.conn-card-title .ti{font-size:16px;color:var(--primary)}.lc-tab{padding:7px 14px;border:none;background:none;font-size:12px;font-family:var(--font);color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;border-radius:6px 6px 0 0;display:flex;align-items:center;gap:5px;white-space:nowrap}.lc-tab:hover{background:var(--bg);color:var(--text)}.lc-tab-active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600;background:var(--surface)}.lc-panel{display:none}.lc-panel.active{display:flex}.topic-mgr{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.topic-item{background:#fff;border:1px solid var(--border);border-radius:12px;padding:0;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .2s,transform .2s;position:relative}.topic-item:hover{box-shadow:0 4px 20px #00000014;transform:translateY(-2px)}.topic-item-accent{height:4px;background:linear-gradient(90deg,var(--primary),#f97316)}.topic-item-body{padding:14px 16px;flex:1}.topic-item-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:12px;display:flex;align-items:center;gap:8px}.topic-item-name .ti{font-size:16px;color:var(--primary)}.topic-item-flow{display:flex;align-items:center;flex-wrap:wrap;gap:4px}.step-node{display:flex;align-items:center;gap:4px}.step-node-num{width:20px;height:20px;border-radius:50%;background:var(--primary);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.step-node-label{font-size:11px;color:var(--text);font-weight:500}.step-arrow{color:var(--border);font-size:12px;margin:0 2px}.topic-item-actions{display:flex;gap:4px;padding:10px 16px;border-top:1px solid var(--border);background:var(--bg);justify-content:flex-end}.topic-form{background:#fff;border:1.5px solid var(--primary);border-radius:12px;padding:16px;margin-top:4px}.topic-form input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:13px;margin-bottom:8px;font-family:var(--font);background:#fff;color:var(--text)}.topic-form input:focus{outline:none;border-color:var(--primary)}.step-editor{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.step-row{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 10px;display:flex;flex-direction:column;gap:6px}.step-row-header{display:flex;gap:6px;align-items:center}.step-row-num{width:22px;height:22px;border-radius:50%;background:var(--primary);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.step-row input{flex:1;padding:6px 8px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:12px;font-family:var(--font);background:#fff}.step-row input:focus{outline:none;border-color:var(--primary)}.rich-editor{border:1px solid var(--border);border-radius:6px;overflow:hidden;background:#fff}.rich-toolbar{display:flex;align-items:center;gap:2px;padding:4px 6px;background:var(--bg);border-bottom:1px solid var(--border);flex-wrap:wrap}.rich-btn{padding:3px 8px;border:1px solid transparent;border-radius:4px;background:none;cursor:pointer;font-size:12px;color:var(--text);font-family:var(--font);display:flex;align-items:center;gap:3px;line-height:1}.rich-btn:hover{background:var(--border)}.rich-btn.active{background:var(--primary-lt);color:var(--primary-dk);border-color:var(--primary)}.rich-sep{width:1px;height:16px;background:var(--border);margin:0 3px;flex-shrink:0}.rich-text{width:100%;border:none;padding:8px 10px;font-size:12px;font-family:var(--font);resize:vertical;min-height:64px;box-sizing:border-box;color:var(--text);display:block}.rich-text:focus{outline:none}.rich-extra{padding:6px 8px;background:var(--bg);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:5px}.rich-img-row{display:flex;flex-direction:column;gap:3px}.rich-img-inp{width:100%;padding:5px 8px;border:1px solid var(--border);border-radius:4px;font-size:11px;font-family:var(--font);box-sizing:border-box;background:#fff}.rich-links-list{display:flex;flex-direction:column;gap:4px}.rich-link-row{display:flex;gap:4px;align-items:center}.rich-link-row input{flex:1;padding:4px 7px;border:1px solid var(--border);border-radius:4px;font-size:11px;font-family:var(--font);background:#fff}.icon-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:6px;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--muted);flex-shrink:0;transition:.15s}.icon-btn:hover{background:var(--bg);color:var(--text)}.icon-btn.danger:hover{background:var(--red-lt);color:var(--red);border-color:var(--red)}.icon-btn:disabled{opacity:.35;cursor:default;pointer-events:none}.perm-toggle-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid rgba(0,0,0,.05)}.perm-toggle-row:last-child{border-bottom:none}.perm-toggle-label{flex:1;font-size:11px;color:var(--text)}.perm-toggle-label.denied{color:#9ca3af}.toggle-sw{position:relative;display:inline-flex;align-items:center;flex-shrink:0}.toggle-sw input{opacity:0;width:0;height:0;position:absolute}.toggle-sw .track{width:32px;height:18px;border-radius:9px;background:#d1d5db;transition:background .2s;cursor:pointer;display:flex;align-items:center;padding:2px}.toggle-sw input:checked+.track{background:var(--green)}.toggle-sw .track:after{content:"";width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.toggle-sw input:checked+.track:after{transform:translate(14px)}.toggle-sw.locked .track{opacity:.5;cursor:not-allowed}.perm-save-btn{margin-top:10px;padding:6px 14px;font-size:11px;font-weight:600;background:var(--primary);color:#fff;border:none;border-radius:var(--r-sm);cursor:pointer;display:flex;align-items:center;gap:5px;font-family:var(--font);transition:background .15s}.perm-save-btn:hover{background:var(--primary-dk)}.users-table{width:100%;border-collapse:collapse;margin-top:12px}.users-table th{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 12px;border-bottom:2px solid var(--border);text-align:left;background:var(--bg)}.users-table td{padding:10px 12px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover td{background:#fafafa}.user-avatar{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.ua-admin{background:#e8640a26;color:var(--primary)}.ua-hr{background:var(--blue-lt);color:var(--blue)}.role-badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}.rb-admin{background:#e8640a26;color:var(--primary-dk)}.rb-hr{background:var(--blue-lt);color:var(--blue)}.status-badge{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px}.sb-active{background:var(--green)}.sb-inactive{background:var(--muted)}.user-actions{display:flex;gap:4px}.self-badge{font-size:10px;background:var(--green-lt);color:var(--green);padding:2px 6px;border-radius:20px;font-weight:600}.empty{text-align:center;color:var(--muted);padding:32px;font-size:13px}.empty .ti{display:block;font-size:36px;margin-bottom:10px;color:var(--border)}.spin{display:inline-block;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.slide-in{animation:slidein .25s ease}@keyframes slidein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.mob-back{display:none;align-items:center;gap:8px;padding:10px 16px;background:var(--surface);border-bottom:1px solid var(--border);font-size:13px;font-weight:600;cursor:pointer;color:var(--primary)}.mob-back .ti{font-size:18px}@media (max-width:768px){.app{grid-template-rows:auto auto 1fr}header{padding:0 12px;height:50px}.hdr-title,.hdr-divider{display:none}.hdr-logo{height:24px}.main{grid-template-columns:1fr;position:relative}aside{height:100%;overflow:hidden}.detail{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;overflow-y:auto;padding-top:0}.detail.mob-open{display:block}.mob-back{display:flex}.modal{width:calc(100vw - 32px)!important;max-height:90vh;overflow-y:auto}.sum-kpi{grid-template-columns:repeat(2,1fr)}.topic-row{grid-template-columns:1fr 80px;grid-template-rows:auto auto}.page-nav{padding:0 8px;overflow-x:auto}.nav-tab{padding:10px 12px;font-size:12px;white-space:nowrap}}.line-cfg-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-bottom:0}.line-cfg-card-title{padding:12px 16px;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px;background:var(--bg)}.line-cfg-fields{padding:16px;display:flex;flex-direction:column;gap:12px}.line-cfg-field{display:flex;flex-direction:column;gap:4px}.line-cfg-label{font-size:11px;font-weight:600;color:var(--muted)}.line-cfg-field input[type=text]{padding:7px 10px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:13px;font-family:var(--font);background:#fff;color:var(--text);transition:border-color .15s}.line-cfg-field input[type=text]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-lt)}.cfg-color-wrap{display:flex;align-items:center;gap:8px}.cfg-color-wrap input[type=color]{width:36px;height:34px;border:1px solid var(--border);border-radius:6px;padding:2px;cursor:pointer;flex-shrink:0}.cfg-hex-inp{width:80px;padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-size:12px;font-family:monospace;color:var(--text)}.cfg-hex-inp:focus{outline:none;border-color:var(--primary)}.cfg-hint{font-weight:400;color:var(--muted);font-size:10px}
