:root{--green-50:#f7fbe9;--green-100:#ecf6cd;--green-200:#d9ed9c;--green-300:#bfdf66;--green-400:#a3cc3d;--green-500:#84b626;--green-600:#65a30d;--green-700:#4d7c0f;--green-800:#3f6212;--blue-50:#ecfeff;--blue-100:#cffafe;--blue-200:#a5f3fc;--blue-300:#67e8f9;--blue-400:#22d3ee;--blue-500:#06b6d4;--blue-600:#0891b2;--blue-700:#0e7490;--blue-800:#155e75;--bg:#f1f4ea;--surface:#ffffff;--surface-2:#f4f6f0;--border:#e6e9e0;--border-strong:#d4d9c8;--border-soft:#f0f2ea;--text:#0f172a;--text-2:#334155;--text-3:#64748b;--text-4:#94a3b8;--text-5:#cbd5e1;--primary:var(--green-600);--primary-hover:var(--green-700);--primary-soft:var(--green-50);--primary-border:var(--green-200);--secondary:var(--blue-700);--secondary-soft:var(--blue-50);--secondary-border:var(--blue-200);--success:#16a34a;--warn:#d97706;--danger:#dc2626;--info:#0284c7;--violet:#7c3aed;--success-soft:#dcfce7;--warn-soft:#fef3c7;--danger-soft:#fee2e2;--info-soft:#e0f2fe;--violet-soft:#ede9fe;--shadow-xs:0 1px 2px rgba(15,23,42,.04);--shadow-sm:0 1px 3px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.04);--shadow-md:0 4px 12px rgba(15,23,42,.06),0 2px 4px rgba(15,23,42,.04);--shadow-lg:0 16px 40px rgba(15,23,42,.1),0 4px 12px rgba(15,23,42,.06);--radius-sm:6px;--radius:8px;--radius-md:10px;--radius-lg:12px;--radius-xl:16px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100vh;width:100vw;overflow:hidden}body{font-family:DM Sans,-apple-system,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased}.mono{font-family:JetBrains Mono,ui-monospace,monospace;font-feature-settings:"ss01" on}::selection{background:var(--green-200);color:var(--green-800)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d4d9c8;border-radius:8px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:#a8b09a}.app{display:flex;height:100vh;width:100vw;position:fixed;top:0;left:0}.sidebar{width:248px;min-width:248px;background:var(--surface);border-right:1px solid var(--border-strong);box-shadow:1px 0 0 var(--border),4px 0 16px #0f172a0a;display:flex;flex-direction:column;position:relative;z-index:2}.sb-head{padding:18px 18px 14px;border-bottom:1px solid var(--border)}.sb-logo{display:flex;align-items:center;gap:10px}.sb-mark{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--green-500),var(--blue-700));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;box-shadow:var(--shadow-sm)}.sb-brand{font-weight:700;font-size:14px;color:var(--text);letter-spacing:-.01em}.sb-brand-sub{font-size:10px;color:var(--text-3);font-weight:500;margin-top:1px;letter-spacing:.02em}.sb-nav{padding:12px 10px;flex:1;overflow-y:auto}.nav-sec{margin-bottom:18px}.nav-lbl{font-size:10px;font-weight:600;color:var(--text-4);text-transform:uppercase;letter-spacing:.08em;padding:0 10px;margin-bottom:6px}.nav-btn{width:100%;display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius);border:none;background:transparent;color:var(--text-2);font-size:13px;font-weight:500;cursor:pointer;transition:background .12s,color .12s;margin-bottom:2px;text-align:left;font-family:inherit}.nav-btn:hover{background:var(--surface-2);color:var(--text)}.nav-btn.active{background:var(--primary-soft);color:var(--primary-hover);font-weight:600}.nav-btn svg{width:16px;height:16px;flex-shrink:0}.nav-badge{margin-left:auto;background:var(--surface-2);color:var(--text-3);font-size:10px;font-weight:600;padding:2px 7px;border-radius:6px;font-family:JetBrains Mono,monospace}.nav-btn.active .nav-badge{background:var(--green-100);color:var(--green-700)}.sb-foot{padding:12px 14px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}.sb-avatar{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--blue-600),var(--blue-800));display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700}.sb-user-name{font-size:13px;font-weight:600;color:var(--text)}.sb-user-role{font-size:10.5px;color:var(--text-3)}.sb-foot-icon{margin-left:auto;width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--text-3);cursor:pointer;transition:background .12s}.sb-foot-icon:hover{background:var(--surface-2);color:var(--text)}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.header{background:var(--surface);border-bottom:1px solid var(--border);padding:14px 24px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;gap:16px}.hd-left{display:flex;flex-direction:column}.hd-crumb{font-size:11px;color:var(--text-3);font-weight:500;display:flex;align-items:center;gap:6px;margin-bottom:3px}.hd-crumb span{color:var(--text-4)}.hd-title{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.02em}.hd-right{display:flex;align-items:center;gap:8px}.search-wrap{position:relative}.search{width:240px;padding:8px 12px 8px 34px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;background:var(--surface);color:var(--text);font-family:inherit;transition:border-color .15s,box-shadow .15s}.search:focus{outline:none;border-color:var(--green-400);box-shadow:0 0 0 3px var(--green-100)}.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-4);pointer-events:none;display:flex;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:var(--radius);font-size:13px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:background .12s,border-color .12s,color .12s,box-shadow .12s;font-family:inherit;white-space:nowrap;line-height:1}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:14px;height:14px}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-2);border:1px solid transparent}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.btn-outline{background:var(--surface);color:var(--primary);border:1px solid var(--primary-border)}.btn-outline:hover{background:var(--primary-soft)}.btn-blue{background:var(--secondary);color:#fff;border-color:var(--secondary)}.btn-blue:hover{background:var(--blue-800)}.btn-danger-ghost{background:transparent;color:var(--danger);border:1px solid transparent}.btn-danger-ghost:hover{background:var(--danger-soft)}.btn-sm{padding:6px 10px;font-size:12px;border-radius:var(--radius-sm)}.btn-icon{padding:7px;width:32px;height:32px}.btn-icon svg{width:15px;height:15px}.content{flex:1;overflow:auto;padding:20px 24px;width:100%}.content-narrow{max-width:1280px;margin:0 auto}.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;cursor:pointer;transition:border-color .15s,box-shadow .15s;position:relative;overflow:hidden}.stat:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.stat-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.stat-icon{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center}.stat-icon svg{width:16px;height:16px}.stat-icon.green{background:var(--green-50);color:var(--green-700)}.stat-icon.blue{background:var(--blue-50);color:var(--blue-700)}.stat-icon.amber{background:var(--warn-soft);color:var(--warn)}.stat-icon.violet{background:var(--violet-soft);color:var(--violet)}.stat-icon.slate{background:var(--surface-2);color:var(--text-2)}.stat-trend{display:flex;align-items:center;gap:3px;font-size:11px;font-weight:600;font-family:JetBrains Mono,monospace}.stat-trend.up{color:var(--success)}.stat-trend.down{color:var(--danger)}.stat-trend.flat{color:var(--text-3)}.stat-num{font-size:26px;font-weight:700;color:var(--text);letter-spacing:-.03em;line-height:1.1}.stat-lbl{font-size:12px;color:var(--text-3);margin-top:3px;font-weight:500}.dcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.dcard-head{padding:14px 16px;border-bottom:1px solid var(--border-soft);display:flex;justify-content:space-between;align-items:center}.dcard-title{font-size:13px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}.dcard-title svg{width:15px;height:15px;color:var(--text-3)}.dcard-link{font-size:11.5px;color:var(--primary);cursor:pointer;font-weight:600;display:inline-flex;align-items:center;gap:3px}.dcard-link:hover{color:var(--primary-hover)}.dcard-body{padding:14px 16px}.dcard-body.flush{padding:0}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.grid3{display:grid;grid-template-columns:2fr 1fr 1fr;gap:12px;margin-bottom:16px}.grid32{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:16px}.dlist{list-style:none}.ditem{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;border-bottom:1px solid var(--border-soft);cursor:pointer;transition:background .1s}.ditem:hover{background:var(--surface-2)}.ditem:last-child{border-bottom:none}.ditem-left{display:flex;align-items:center;gap:10px;min-width:0}.dav{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;flex-shrink:0}.ditem-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.ditem-sub{font-size:11px;color:var(--text-3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:5px;font-size:11px;font-weight:600;letter-spacing:0;border:1px solid transparent;line-height:1.4;white-space:nowrap}.badge.success{background:var(--success-soft);color:#15803d;border-color:#bbf7d0}.badge.warn{background:var(--warn-soft);color:#a16207;border-color:#fde68a}.badge.danger{background:var(--danger-soft);color:#b91c1c;border-color:#fecaca}.badge.info{background:var(--info-soft);color:#0369a1;border-color:#bae6fd}.badge.violet{background:var(--violet-soft);color:#6d28d9;border-color:#ddd6fe}.badge.neutral{background:var(--surface-2);color:var(--text-2);border-color:var(--border)}.badge.green{background:var(--green-50);color:var(--green-700);border-color:var(--green-200)}.badge.blue{background:var(--blue-50);color:var(--blue-700);border-color:var(--blue-200)}.badge.mono{font-family:JetBrains Mono,monospace;font-size:10.5px}.dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.tabs{display:inline-flex;gap:2px;background:var(--surface-2);padding:3px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px}.tab{padding:6px 14px;border-radius:6px;border:none;background:transparent;font-size:12.5px;font-weight:600;color:var(--text-3);cursor:pointer;transition:background .12s,color .12s;font-family:inherit;display:flex;align-items:center;gap:6px}.tab:hover{color:var(--text)}.tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-xs)}.tab .cnt{font-size:10.5px;padding:1px 6px;border-radius:5px;background:var(--surface-2);color:var(--text-3);font-family:JetBrains Mono,monospace}.tab.active .cnt{background:var(--green-100);color:var(--green-700)}.kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:14px;height:calc(100% - 60px)}.kcol{min-width:300px;width:300px;background:var(--surface-2);border-radius:var(--radius-md);border:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;transition:border-color .15s,box-shadow .15s}.kcol.dragover{border-color:var(--primary);background:var(--green-50);box-shadow:0 0 0 3px var(--green-100)}.khead{padding:11px 12px;min-height:52px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--surface);border-radius:var(--radius-md) var(--radius-md) 0 0}.ktitle{font-size:12px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:7px;text-transform:uppercase;letter-spacing:.03em}.kcnt{font-size:10.5px;font-weight:600;color:var(--text-3);background:var(--surface-2);padding:2px 7px;border-radius:5px;font-family:JetBrains Mono,monospace}.kbody{padding:8px;flex:1;overflow-y:auto;min-height:60px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:11px 12px;margin-bottom:7px;cursor:pointer;transition:border-color .12s,box-shadow .12s;box-shadow:var(--shadow-xs)}.card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.card.dragging{opacity:.5;transform:rotate(1deg)}.card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:5px;gap:8px}.card-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.3}.card-email{font-size:10.5px;color:var(--text-3);margin-top:1px;font-family:JetBrains Mono,monospace}.card-test{font-size:12px;color:var(--text-2);margin-top:6px;font-weight:500;display:flex;align-items:center;gap:6px}.card-subj{font-size:12px;color:var(--text-2);margin-top:6px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-meta{display:flex;align-items:center;gap:5px;margin-top:9px;flex-wrap:wrap}.tl{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}.tl.green{background:var(--success);box-shadow:0 0 0 3px var(--success-soft)}.tl.amber{background:var(--warn);box-shadow:0 0 0 3px var(--warn-soft)}.tl.red{background:var(--danger);box-shadow:0 0 0 3px var(--danger-soft)}.empty{text-align:center;padding:32px 12px;color:var(--text-4);font-size:11.5px;border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface);margin:4px}.tbl-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.tbl-toolbar{padding:12px 16px;border-bottom:1px solid var(--border-soft);display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.tbl-tools-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.tbl-tools-right{display:flex;align-items:center;gap:8px}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{text-align:left;padding:10px 16px;color:var(--text-3);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--surface-2);position:sticky;top:0}.tbl td{padding:11px 16px;border-bottom:1px solid var(--border-soft);color:var(--text-2);vertical-align:middle}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--surface-2)}.tbl tr.selected td{background:var(--green-50)}.tbl-cb{width:14px;height:14px;cursor:pointer;accent-color:var(--primary)}.tbl-id{font-family:JetBrains Mono,monospace;color:var(--text-2);font-weight:500;font-size:11.5px}.tbl-name{color:var(--text);font-weight:600}.tbl-date{font-family:JetBrains Mono,monospace;font-size:11.5px;color:var(--text-3)}.cell-row{display:flex;align-items:center;gap:8px}.input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;background:var(--surface);color:var(--text);font-family:inherit;transition:border-color .15s,box-shadow .15s}.input:focus{outline:none;border-color:var(--green-400);box-shadow:0 0 0 3px var(--green-100)}.select{padding:8px 30px 8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;background:var(--surface) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 10px center;color:var(--text);font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.select:focus{outline:none;border-color:var(--green-400);box-shadow:0 0 0 3px var(--green-100)}.textarea{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;background:var(--surface);color:var(--text);font-family:inherit;line-height:1.55;resize:vertical;min-height:120px;transition:border-color .15s,box-shadow .15s}.textarea:focus{outline:none;border-color:var(--green-400);box-shadow:0 0 0 3px var(--green-100)}.label{font-size:11.5px;font-weight:600;color:var(--text-2);display:block;margin-bottom:5px;letter-spacing:.01em}.chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:14px;border:1px solid var(--border);background:var(--surface);font-size:11.5px;font-weight:500;color:var(--text-2);cursor:pointer;transition:background .12s,border-color .12s}.chip:hover{border-color:var(--border-strong);background:var(--surface-2)}.chip.active{background:var(--green-50);border-color:var(--green-300);color:var(--green-700);font-weight:600}.chip svg{width:12px;height:12px}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-start;justify-content:center;padding:32px 20px;overflow-y:auto;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:760px;box-shadow:var(--shadow-lg);border:1px solid var(--border);margin:auto;animation:slideDown .2s ease}@keyframes slideDown{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}.modal.lg{max-width:900px}.modal.xl{max-width:1100px}.m-head{padding:18px 22px;display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--border);gap:12px}.m-head h2{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.01em}.m-head .m-sub{font-size:12px;color:var(--text-3);margin-top:4px;font-family:JetBrains Mono,monospace}.m-badges{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.close{width:30px;height:30px;background:var(--surface);border:1px solid var(--border);border-radius:7px;color:var(--text-3);cursor:pointer;font-size:16px;transition:background .12s,color .12s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.close:hover{background:var(--surface-2);color:var(--text);border-color:var(--border-strong)}.m-body{max-height:74vh;overflow-y:auto}.pnl{border-bottom:1px solid var(--border-soft);padding:18px 22px}.pnl:last-child{border-bottom:none}.pnl-h{display:flex;align-items:center;gap:10px;margin-bottom:14px}.pnl-ico{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pnl-ico svg{width:14px;height:14px}.pnl-ico.i1{background:var(--blue-50);color:var(--blue-700)}.pnl-ico.i2{background:var(--info-soft);color:var(--info)}.pnl-ico.i3{background:var(--violet-soft);color:var(--violet)}.pnl-ico.i4{background:var(--success-soft);color:var(--success)}.pnl-ico.i5{background:var(--green-50);color:var(--green-700)}.pnl-ico.i6{background:var(--warn-soft);color:var(--warn)}.pnl-t{font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.01em}.pnl-sub{font-size:11.5px;color:var(--text-3);margin-top:1px}.pnl-cnt{margin-left:auto;font-size:11px;color:var(--text-3);font-family:JetBrains Mono,monospace;background:var(--surface-2);padding:2px 8px;border-radius:5px}.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.info-grid.cols4{grid-template-columns:repeat(4,1fr)}.info-grid.cols2{grid-template-columns:repeat(2,1fr)}.info-box{background:var(--surface-2);border-radius:var(--radius);padding:10px 12px;border:1px solid var(--border-soft)}.info-box label{font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:3px}.info-box p{font-size:13px;font-weight:600;color:var(--text);line-height:1.3;word-break:break-word}.msg-block{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--radius);overflow:hidden}.msg-subj-bar{padding:11px 14px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;gap:8px;background:var(--surface)}.msg-subj-label{font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;flex-shrink:0}.msg-subj{font-size:13px;font-weight:600;color:var(--text)}.msg-body-wrap{padding:13px 14px}.msg-body{font-size:12.5px;color:var(--text-2);line-height:1.6;white-space:pre-wrap}.msg-meta{font-size:10.5px;color:var(--text-3);padding:8px 14px;border-top:1px solid var(--border-soft);background:var(--surface);font-family:JetBrains Mono,monospace}.thread{display:flex;flex-direction:column;gap:10px}.thread-msg{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--radius);padding:12px 14px}.thread-msg.ai{background:var(--green-50);border-color:var(--green-200)}.thread-msg-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;gap:8px}.thread-from{font-size:11.5px;font-weight:700;color:var(--text)}.thread-from.ai{color:var(--green-700)}.thread-from.cust{color:var(--blue-700)}.thread-date{font-size:10.5px;color:var(--text-3);font-family:JetBrains Mono,monospace}.thread-body{font-size:12.5px;color:var(--text-2);line-height:1.55;white-space:pre-wrap}.ai-box{background:var(--green-50);border:1px solid var(--green-200);border-radius:var(--radius);overflow:hidden}.ai-header{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;background:var(--surface);border-bottom:1px solid var(--green-200)}.ai-label{font-size:10.5px;font-weight:700;color:var(--green-700);letter-spacing:.06em;display:flex;align-items:center;gap:6px;text-transform:uppercase}.ai-label:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green-500);box-shadow:0 0 0 3px var(--green-200)}.ai-body{padding:14px;font-size:12.5px;color:var(--text-2);line-height:1.65;white-space:pre-wrap;max-height:220px;overflow-y:auto}.action-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:12px}.action-row .grow{flex:1}.drawer-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:90;animation:fadeIn .15s ease}.drawer{position:fixed;top:0;right:0;height:100vh;width:520px;max-width:90vw;background:var(--surface);box-shadow:var(--shadow-lg);z-index:100;display:flex;flex-direction:column;animation:slideLeft .2s ease}@keyframes slideLeft{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.drawer-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.drawer-body{flex:1;overflow-y:auto}.drawer-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,var(--green-50) 0%,var(--surface-2) 45%,var(--blue-50) 100%)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:34px 30px;width:100%;max-width:380px;animation:slideDown .25s ease}.login-err{display:flex;align-items:center;gap:7px;background:var(--danger-soft);color:#b91c1c;border:1px solid #fecaca;border-radius:var(--radius);padding:9px 12px;font-size:12.5px;margin-bottom:14px}.toast-wrap{position:fixed;bottom:20px;right:20px;z-index:200;display:flex;flex-direction:column;gap:8px}.toast{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:11px 14px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:10px;animation:slideUp .25s ease;min-width:280px}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.toast-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-icon.success{background:var(--success-soft);color:var(--success)}.toast-icon.info{background:var(--info-soft);color:var(--info)}.toast-icon.warn{background:var(--warn-soft);color:var(--warn)}.toast-icon.error{background:var(--danger-soft);color:var(--danger)}.pulse-dot{animation:pulseDot 2s ease-in-out infinite}@keyframes pulseDot{0%,to{box-shadow:0 0 #16a34a80}50%{box-shadow:0 0 0 4px #16a34a00}}.toast h4{font-size:13px;font-weight:600;color:var(--text)}.toast p{font-size:11.5px;color:var(--text-3);margin-top:1px}.bar{width:100%;height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden}.bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.funnel{display:flex;flex-direction:column;gap:8px;padding:8px}.funnel-row{display:flex;align-items:center;gap:12px}.funnel-label{width:160px;flex-shrink:0;font-size:12px;font-weight:600;color:var(--text-2)}.funnel-bar{flex:1;height:34px;border-radius:6px;display:flex;align-items:center;padding:0 12px;color:#fff;font-weight:700;font-size:13px;font-family:JetBrains Mono,monospace;letter-spacing:-.01em;transition:all .3s ease}.funnel-pct{font-size:11px;font-weight:600;color:var(--text-3);font-family:JetBrains Mono,monospace;width:50px;text-align:right}.tpl-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;transition:border-color .12s,box-shadow .12s}.tpl-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.tpl-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.tpl-name{font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.01em}.tpl-preview{font-size:12px;color:var(--text-3);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;font-family:JetBrains Mono,monospace;background:var(--surface-2);padding:10px 12px;border-radius:6px;border:1px solid var(--border-soft)}.tpl-meta{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.var-chip{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:5px;background:var(--blue-50);color:var(--blue-700);font-size:10.5px;font-weight:600;font-family:JetBrains Mono,monospace;border:1px solid var(--blue-200);cursor:pointer}.var-chip:hover{background:var(--blue-100)}.divider{height:1px;background:var(--border);margin:14px 0}.help-banner{background:var(--blue-50);border:1px solid var(--blue-200);border-radius:var(--radius);padding:10px 14px;font-size:12px;color:var(--blue-800);display:flex;align-items:center;gap:8px;margin-bottom:12px}.help-banner svg{width:14px;height:14px;color:var(--blue-700);flex-shrink:0}.hint{font-size:12px;color:var(--text-3);margin-bottom:10px;display:flex;align-items:center;gap:6px}.hint svg{width:13px;height:13px;color:var(--text-4)}.page-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.page-hd-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.seg-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px}.seg-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border-soft);font-size:12.5px}.seg-row:last-child{border-bottom:none}.seg-conn{font-size:10px;font-weight:700;color:var(--text-3);background:var(--surface-2);padding:2px 7px;border-radius:4px;font-family:JetBrains Mono,monospace}.chart-wrap{padding:16px;height:260px;position:relative}.chart-wrap.tall{height:320px}.av1{background:linear-gradient(135deg,#65a30d,#4d7c0f)}.av2{background:linear-gradient(135deg,#0e7490,#155e75)}.av3{background:linear-gradient(135deg,#d97706,#b45309)}.av4{background:linear-gradient(135deg,#7c3aed,#6d28d9)}.av5{background:linear-gradient(135deg,#dc2626,#b91c1c)}.av6{background:linear-gradient(135deg,#0284c7,#0369a1)}
