*,:before,:after{box-sizing:border-box}html,body,#root{height:100%}body{font-feature-settings:"cv11", "ss01", "ss03";color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Helvetica,Arial,sans-serif;font-size:13px;line-height:1.45}:root{--bg:#f6f7f9;--surface:#fff;--surface-2:#fafbfc;--border:#e2e8f0;--border-strong:#cbd5e1;--text:#111827;--text-2:#64748b;--text-3:#94a3b8;--primary:#2563eb;--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-700:#1d4ed8;--success:#16a34a;--success-50:#f0fdf4;--success-100:#dcfce7;--warning:#f59e0b;--warning-50:#fffbeb;--warning-100:#fef3c7;--danger:#dc2626;--danger-50:#fef2f2;--danger-100:#fee2e2;--info:#0891b2;--info-50:#ecfeff;--info-100:#cffafe;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-700:#334155;--radius:6px;--radius-sm:4px;--radius-lg:8px;--shadow-sm:0 1px 2px #0f172a0a;--shadow:0 1px 3px #0f172a14, 0 1px 2px #0f172a0a;--shadow-lg:0 10px 24px -8px #0f172a2e, 0 4px 8px -4px #0f172a14;--sidebar-w:220px;--topbar-h:52px}.app{grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"sidebar topbar""sidebar main";height:100vh;display:grid}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;grid-area:sidebar;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);grid-area:topbar;align-items:center;gap:12px;padding:0 16px;display:flex}.main{grid-area:main;overflow:auto}.brand{border-bottom:1px solid var(--border);height:var(--topbar-h);align-items:center;gap:10px;padding:14px;display:flex}.brand-mark{color:#fff;border-radius:var(--radius);letter-spacing:-.02em;font-feature-settings:"tnum";background:#111827;place-items:center;width:26px;height:26px;font-size:11px;font-weight:700;display:grid}.brand-mark .dot{background:var(--warning);border-radius:50%;width:4px;height:4px;margin-left:1px}.brand-name{letter-spacing:-.01em;font-size:13.5px;font-weight:600}.brand-sub{color:var(--text-2);margin-top:-1px;font-size:11px}.nav{flex-direction:column;flex:1;gap:1px;padding:8px;display:flex;overflow-y:auto}.nav-section{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);padding:12px 10px 6px;font-size:10.5px;font-weight:600}.nav-item{border-radius:var(--radius);color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:9px;width:100%;padding:6.5px 10px;font-size:13px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--gray-100)}.nav-item.active{color:#fff;background:#111827}.nav-item.active .ico{color:#fff}.nav-item .count{color:var(--text-2);font-variant-numeric:tabular-nums;margin-left:auto;font-size:11px}.nav-item.active .count{color:#ffffffb3}.nav-item .ico{color:var(--text-2);flex:0 0 16px}.sidebar-foot{border-top:1px solid var(--border);align-items:center;gap:8px;padding:10px;display:flex}.avatar{border-radius:var(--radius);background:var(--primary-100);width:28px;height:28px;color:var(--primary-700);place-items:center;font-size:11px;font-weight:600;display:grid}.avatar.lg{width:36px;height:36px;font-size:13px}.user-name{font-size:12.5px;font-weight:600}.user-role{color:var(--text-2);font-size:11px}.search{flex:0 360px;position:relative}.search input{background:var(--gray-100);border-radius:var(--radius);width:100%;color:var(--text);border:1px solid #0000;outline:none;padding:7px 10px 7px 32px;font-family:inherit;font-size:12.5px}.search input:focus{border-color:var(--border-strong);background:#fff}.search .ico{color:var(--text-2);position:absolute;top:50%;left:9px;transform:translateY(-50%)}.kbd{color:var(--text-2);border:1px solid var(--border);background:#fff;border-radius:3px;padding:1px 5px;font-family:inherit;font-size:10.5px;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.topbar-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.icon-btn{border-radius:var(--radius);width:32px;height:32px;color:var(--text-2);cursor:pointer;background:0 0;border:1px solid #0000;place-items:center;display:grid;position:relative}.icon-btn:hover{background:var(--gray-100);color:var(--text)}.icon-btn .badge{background:var(--danger);border:1.5px solid var(--surface);border-radius:50%;width:7px;height:7px;position:absolute;top:4px;right:4px}.btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;padding:6px 11px;font-family:inherit;font-size:12.5px;font-weight:500;line-height:1.2;display:inline-flex}.btn:hover{background:var(--gray-100)}.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn.primary:hover{background:var(--primary-700)}.btn.dark{color:#fff;background:#111827;border-color:#111827}.btn.dark:hover{background:#000}.btn.ghost{background:0 0;border-color:#0000}.btn.ghost:hover{background:var(--gray-100)}.btn.sm{gap:4px;padding:4px 8px;font-size:11.5px}.btn.lg{padding:8px 14px;font-size:13px}.btn.danger{color:var(--danger)}.btn.danger:hover{background:var(--danger-50);border-color:var(--danger-100)}.pill{background:var(--gray-100);color:var(--gray-700);white-space:nowrap;border:1px solid #0000;border-radius:999px;align-items:center;gap:5px;padding:2px 7px;font-size:11px;font-weight:500;line-height:1.4;display:inline-flex}.pill .dot{background:currentColor;border-radius:50%;width:6px;height:6px}.pill.blue{background:var(--primary-50);color:var(--primary-700)}.pill.green{background:var(--success-50);color:var(--success)}.pill.amber{background:var(--warning-50);color:#b45309}.pill.red{background:var(--danger-50);color:var(--danger)}.pill.cyan{background:var(--info-50);color:var(--info)}.pill.gray{background:var(--gray-100);color:var(--gray-700)}.pill.solid-blue{background:var(--primary);color:#fff}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.card-h{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.card-h h3{letter-spacing:-.005em;margin:0;font-size:13px;font-weight:600}.card-h .sub{color:var(--text-2);font-size:11.5px}.card-b{padding:14px}.card-b.flush{padding:0}.tbl{border-collapse:separate;border-spacing:0;width:100%;font-size:12.5px}.tbl th{text-align:left;color:var(--text-2);background:var(--gray-50);border-bottom:1px solid var(--border);padding:8px 12px;font-size:11.5px;font-weight:500;position:sticky;top:0}.tbl td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 12px}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--gray-50)}.tbl tr.selected td{background:var(--primary-50)}.tbl .num{font-variant-numeric:tabular-nums}.page{max-width:1600px;margin:0 auto;padding:18px 22px 28px}.page-h{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:16px;display:flex}.page-h h1{letter-spacing:-.015em;margin:0 0 2px;font-size:20px;font-weight:600}.page-h .sub{color:var(--text-2);font-size:12.5px}.page-actions{align-items:center;gap:8px;display:flex}.kpis{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;display:grid}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 14px 12px;position:relative}.kpi .label{color:var(--text-2);align-items:center;gap:6px;font-size:11.5px;display:flex}.kpi .value{letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-top:6px;font-size:24px;font-weight:600}.kpi .delta{color:var(--text-2);align-items:center;gap:4px;margin-top:4px;font-size:11.5px;display:flex}.kpi .delta.up{color:var(--success)}.kpi .delta.down{color:var(--danger)}.kpi .spark{color:var(--text-3);position:absolute;top:12px;right:12px}.field{flex-direction:column;gap:4px;display:flex}.field label{color:var(--text-2);font-size:11.5px;font-weight:500}.input,.select,textarea.input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;width:100%;padding:6.5px 10px;font-family:inherit;font-size:12.5px}.input:focus,.select:focus,textarea.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}textarea.input{resize:vertical;min-height:80px;line-height:1.5}.checkbox{cursor:pointer;align-items:center;gap:7px;font-size:12.5px;display:inline-flex}.checkbox input{accent-color:var(--primary);width:14px;height:14px}.thumb{border-radius:var(--radius-sm);background:var(--gray-100);border:1px solid var(--border);flex:0 0 56px;width:56px;height:40px;position:relative;overflow:hidden}.thumb.lg{flex-basis:96px;width:96px;height:68px}.thumb svg{width:100%;height:100%;display:block}.thumb img{object-fit:cover;width:100%;height:100%;display:block}.row{align-items:center;gap:10px;display:flex}.col{flex-direction:column;gap:4px;display:flex}.mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.muted{color:var(--text-2)}.hr{background:var(--border);height:1px;margin:12px 0}.divider-v{background:var(--border);align-self:stretch;width:1px}.scroll-y{overflow-y:auto}.tabs{border-bottom:1px solid var(--border);gap:2px;display:flex}.tab{color:var(--text-2);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 12px;font-family:inherit;font-size:12.5px;font-weight:500}.tab:hover{color:var(--text)}.tab.active{color:var(--text);border-bottom-color:#111827}.chip{background:var(--gray-100);border-radius:var(--radius);color:var(--gray-700);cursor:pointer;border:1px solid #0000;align-items:center;gap:5px;padding:3px 8px;font-family:inherit;font-size:11.5px;display:inline-flex}.chip:hover{background:var(--gray-200)}.chip.active{color:#fff;background:#111827}.toast{color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:1000;background:#111827;align-items:center;gap:8px;padding:9px 14px;font-size:12.5px;animation:.18s ease-out toast-in;display:flex;position:fixed;bottom:18px;left:50%;transform:translate(-50%)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.drawer-bg{z-index:900;background:#0f172a52;animation:.15s fade;position:fixed;inset:0}.drawer{background:var(--surface);z-index:901;width:460px;box-shadow:var(--shadow-lg);flex-direction:column;animation:.2s ease-out drawer-in;display:flex;position:fixed;top:0;bottom:0;right:0}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes drawer-in{0%{opacity:.7;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.creative-frame{background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius);position:relative;overflow:hidden}.creative-frame .label-bar{background:var(--surface);border-bottom:1px solid var(--border);color:var(--text-2);justify-content:space-between;align-items:center;padding:6px 10px;font-size:11.5px;display:flex}.ch-badge{border-radius:var(--radius-sm);color:#fff;flex:0 0 24px;place-items:center;width:24px;height:24px;font-size:11px;font-weight:600;display:grid}.bar{background:var(--gray-100);border-radius:999px;height:5px;overflow:hidden}.bar>span{background:var(--primary);border-radius:999px;height:100%;display:block}.bar.green>span{background:var(--success)}.bar.amber>span{background:var(--warning)}.dotline{align-items:center;gap:3px;display:inline-flex}.dotline span{background:var(--gray-200);border-radius:50%;width:5px;height:5px}.dotline span.on{background:var(--primary)}.dotline span.done{background:var(--success)}.cb-tb-btn{color:var(--text);border-radius:var(--radius);cursor:pointer;background:0 0;border:1px solid #0000;align-items:center;gap:5px;height:30px;padding:5px 8px;font-family:inherit;font-size:12px;font-weight:500;display:inline-flex}.cb-tb-btn:hover{background:var(--gray-100)}.cb-tb-btn:disabled{opacity:.35;cursor:not-allowed}.cb-select,.cb-input{background:var(--surface);width:100%;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);outline:none;padding:6px 8px;font-family:inherit;font-size:12px}.cb-input:focus,.cb-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.cb-input.mono{font-variant-numeric:tabular-nums;font-family:ui-monospace,Menlo,monospace}.cb-btn{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;justify-content:center;align-items:center;gap:5px;height:30px;padding:6px 10px;font-family:inherit;font-size:11.5px;font-weight:500;display:inline-flex}.cb-btn:hover{background:var(--gray-50);border-color:var(--border-strong)}.cb-btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.cb-btn.primary:hover{background:var(--primary-700)}.cb-icon-btn{background:var(--surface);border:1px solid var(--border);width:26px;height:26px;color:var(--text-2);border-radius:var(--radius);cursor:pointer;place-items:center;display:grid}.cb-icon-btn:hover{color:var(--text);background:var(--gray-100)}.cb-link{color:var(--primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:0;font-family:inherit;font-size:11px;font-weight:500;display:inline-flex}.cb-link:hover{color:var(--primary-700);text-decoration:underline}.cb-chip{background:var(--gray-100);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:3px;padding:3px 6px;font-family:inherit;font-size:10.5px;display:inline-flex}.cb-chip:hover{background:var(--gray-200);border-color:var(--border-strong)}.cb-check{color:var(--text);cursor:pointer;align-items:center;gap:6px;font-size:11.5px;display:inline-flex}.cb-check input{accent-color:var(--primary)}.cb-add-btn{background:var(--surface);width:100%;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;padding:8px 10px;font-family:inherit;font-size:12px;display:flex}.cb-add-btn:hover{background:var(--gray-50);border-color:var(--border-strong)}.cb-layer{cursor:move}.cb-layer:hover{outline-offset:1px;outline:1px solid #2563eb66}.cb-layer.selected{outline:2px solid var(--primary);outline-offset:1px}.cb-layer.dragging{outline:2px solid var(--primary);cursor:grabbing}.cb-handle{border:1.5px solid var(--primary);z-index:10;background:#fff;border-radius:2px;width:9px;height:9px;position:absolute}.cb-handle.tl{cursor:nwse-resize;top:-5px;left:-5px}.cb-handle.tr{cursor:nesw-resize;top:-5px;right:-5px}.cb-handle.bl{cursor:nesw-resize;bottom:-5px;left:-5px}.cb-handle.br{cursor:nwse-resize;bottom:-5px;right:-5px}.cb-artboard ::selection{background:#2563eb66}.mkt-layout{grid-template-columns:280px 1fr 320px;align-items:start;gap:14px;display:grid}.mkt-section-h{color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;justify-content:space-between;align-items:center;padding:4px 4px 8px;font-size:11px;font-weight:700;display:flex}.mkt-templates{flex-direction:column;display:flex}.mkt-tpl-list{flex-direction:column;gap:4px;display:flex}.mkt-tpl-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;color:var(--text);align-items:flex-start;gap:9px;padding:9px 10px;font-family:inherit;display:flex}.mkt-tpl-card:hover{border-color:var(--border-strong);background:var(--gray-50)}.mkt-tpl-card.active{border-color:var(--primary);background:var(--primary-50);box-shadow:0 0 0 1px var(--primary)}.mkt-tpl-ico{background:var(--gray-100);width:26px;height:26px;color:var(--text-2);border-radius:var(--radius-sm);flex:0 0 26px;place-items:center;display:grid}.mkt-tpl-ico.tone-blue{background:var(--primary-50);color:var(--primary-700)}.mkt-tpl-ico.tone-red{background:var(--danger-50);color:var(--danger)}.mkt-tpl-ico.tone-cyan{background:var(--info-50);color:var(--info)}.mkt-tpl-ico.tone-amber{background:var(--warning-50);color:#b45309}.mkt-tpl-ico.tone-gray{background:var(--gray-100);color:var(--gray-700)}.mkt-tpl-body{flex:1;min-width:0}.mkt-tpl-h{justify-content:space-between;align-items:center;gap:6px;display:flex}.mkt-tpl-name{font-size:12.5px;font-weight:600}.mkt-tpl-preview{color:var(--text-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:3px;font-size:11.5px;line-height:1.4;display:-webkit-box;overflow:hidden}.mkt-channel-toggle{background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius);padding:2px;display:inline-flex}.mkt-channel-toggle button{color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:12.5px;font-weight:500;display:inline-flex}.mkt-channel-toggle button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.mkt-from{background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:8px;margin-bottom:12px;padding:7px 10px;font-size:12px;display:flex}.mkt-tokens{flex-wrap:wrap;align-items:center;gap:4px;margin-top:10px;display:flex}.mkt-tabs{background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius);padding:2px;display:flex}.mkt-tabs button{color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:4px;flex:1;padding:5px 8px;font-family:inherit;font-size:12px;font-weight:500}.mkt-tabs button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.mkt-recip{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;color:var(--text);background:0 0;align-items:center;gap:9px;padding:8px 10px;font-family:inherit;display:flex}.mkt-recip:hover{background:var(--gray-50)}.mkt-recip.active{background:var(--primary-50);border-color:var(--primary)}.mkt-reach{background:var(--primary-50);color:var(--primary-700);border-radius:var(--radius);align-items:center;gap:8px;padding:8px 10px;font-size:12px;display:flex}.mkt-reach strong{font-size:13px;font-weight:700}.mkt-est{background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-2);align-items:center;gap:6px;padding:6px 10px;font-size:11.5px;display:flex}.mkt-phone{border:1px solid var(--border);background:var(--gray-50);max-width:320px;box-shadow:var(--shadow);border-radius:14px;margin:0 auto;overflow:hidden}.mkt-phone-head{background:var(--surface);border-bottom:1px solid var(--border);color:var(--primary);align-items:center;gap:6px;padding:9px 12px;display:flex}.mkt-phone-body{flex-direction:column;gap:4px;min-height:110px;padding:12px;display:flex}.mkt-bubble-time{text-align:center;color:var(--text-3);margin:4px 0 6px;font-size:10.5px}.mkt-bubble{border:1px solid var(--border);white-space:pre-wrap;max-width:84%;color:var(--text);background:#fff;border-radius:14px 14px 14px 4px;align-self:flex-start;padding:8px 11px;font-size:12.5px;line-height:1.4}.mkt-bubble-meta{color:var(--text-3);align-self:flex-start;margin-top:2px;padding-left:6px;font-size:10px}.mkt-email{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.mkt-email-head{background:var(--gray-50);border-bottom:1px solid var(--border);gap:10px;padding:10px 12px;display:flex}.mkt-email-subj{letter-spacing:-.005em;padding:10px 14px 6px;font-size:14px;font-weight:700}.mkt-email-body{white-space:pre-wrap;color:var(--text);padding:0 14px 12px;font-size:12.5px;line-height:1.55}.mkt-email-foot{border-top:1px solid var(--border);background:var(--gray-50);color:var(--text-2);padding:10px 14px;font-size:10.5px;line-height:1.5}@media (max-width:1180px){.mkt-layout{grid-template-columns:1fr}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--gray-200);border:2px solid var(--bg);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}::-webkit-scrollbar-track{background:0 0}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:2000;background:#0f172a73;justify-content:center;align-items:center;animation:.22s cubic-bezier(.16,1,.3,1) forwards modal-fade-in;display:flex;position:fixed;inset:0}.modal-card{-webkit-backdrop-filter:blur(20px);box-sizing:border-box;background:#ffffffe6;border:1px solid #fff9;border-radius:16px;flex-direction:column;max-height:90vh;animation:.28s cubic-bezier(.34,1.56,.64,1) forwards modal-scale-in;display:flex;box-shadow:0 4px 30px #00000008,0 1px 3px #00000005,0 20px 40px -12px #0f172a2e}.modal-h{border-bottom:1px solid #e2e8f0cc;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-b{flex:1;padding:20px;overflow-y:auto}.modal-f{background:#f8fafca6;border-top:1px solid #e2e8f0cc;border-bottom-right-radius:16px;border-bottom-left-radius:16px;flex-wrap:wrap;justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-scale-in{0%{opacity:0;transform:scale(.95)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}
