.crm-layout{display:flex;min-height:100vh;background:#f5f7fa}.crm-main{flex:1;margin-left:256px;padding:24px 28px;min-width:0;min-height:100vh;transition:margin-left .22s cubic-bezier(.4,0,.2,1)}@media(max-width:1024px){.crm-main{margin-left:0!important;padding:16px!important}}.ct-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;flex-wrap:wrap}.ct-topbar h1{margin:0;font-size:1.4rem;color:#111827}.ct-topbar p{margin:4px 0 0;color:#6b7280;font-size:.85rem}.ct-layout{display:grid;grid-template-columns:240px 1fr;gap:20px;align-items:start}@media(max-width:900px){.ct-layout{grid-template-columns:1fr}}.ct-sidebar{background:#fff;border-radius:12px;padding:10px;box-shadow:0 1px 3px #0000000f}.ct-sidebar-head{display:flex;justify-content:space-between;align-items:center;padding:6px 8px 10px;color:#6b7280;font-size:.78rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.ct-cat-list{display:flex;flex-direction:column;gap:2px}.ct-cat-item-wrap{display:flex;align-items:center;gap:2px}.ct-cat-item{flex:1;display:flex;align-items:center;gap:10px;padding:8px 10px;border:none;background:none;border-radius:8px;font-size:.87rem;color:#374151;cursor:pointer;text-align:left}.ct-cat-item:hover{background:#f3f4f6}.ct-cat-item.active{background:#eef2ff;color:#1a56db;font-weight:600}.ct-cat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ct-cat-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ct-cat-count{font-size:.72rem;color:#9ca3af;background:#f3f4f6;padding:2px 7px;border-radius:20px}.ct-cat-item.active .ct-cat-count{background:#fff;color:#1a56db}.ct-cat-edit{padding:6px;border:none;background:none;border-radius:6px;color:#9ca3af;cursor:pointer}.ct-cat-edit:hover{background:#f3f4f6;color:#374151}.ct-tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.ct-tpl-card{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column;transition:transform .1s,box-shadow .1s}.ct-tpl-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.ct-tpl-head{padding:10px 14px}.ct-tpl-cat{font-size:.72rem;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.ct-tpl-name{margin:0 14px;font-size:.98rem;color:#111827;min-height:44px}.ct-tpl-meta{display:flex;justify-content:space-between;padding:8px 14px;font-size:.75rem;color:#9ca3af}.ct-tpl-actions{display:flex;gap:6px;padding:10px 12px;border-top:1px solid #f3f4f6}.ct-tpl-actions button{flex:1}.ct-empty{display:none;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:60px 20px;color:#9ca3af;text-align:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f}.ct-empty h3{margin:6px 0 0;color:#374151}.ct-empty p{margin:0 0 10px}.ct-empty-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.ct-btn-primary,.ct-btn-ghost,.ct-btn-danger{padding:9px 16px;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .15s}.ct-btn-primary{background:#1a56db;color:#fff}.ct-btn-primary:hover{background:#1e429f}.ct-btn-ghost{background:#f3f4f6;color:#374151}.ct-btn-ghost:hover{background:#e5e7eb}.ct-btn-danger{background:#fef2f2;color:#dc2626}.ct-btn-danger:hover{background:#fee2e2}.ct-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:#f3f4f6;color:#374151;cursor:pointer;font-size:1rem}.ct-icon-btn:hover{background:#e5e7eb}.ct-icon-btn--danger:hover{background:#fee2e2;color:#dc2626}.ct-link-btn{background:none;border:none;color:#1a56db;font-size:.8rem;cursor:pointer;padding:4px 8px;border-radius:4px}.ct-link-btn:hover{background:#eef2ff}.ct-modal-overlay{display:none;position:fixed;inset:0;background:#0f172a80;align-items:center;justify-content:center;z-index:500;padding:20px;backdrop-filter:blur(3px)}.ct-modal-overlay.open{display:flex}.ct-modal{background:#fff;border-radius:14px;width:100%;max-width:520px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 50px #00000040}.ct-modal--lg{max-width:1080px}.ct-modal-head{padding:16px 20px;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;align-items:center}.ct-modal-head h2{margin:0;font-size:1.05rem;color:#111827}.ct-modal-body{padding:20px;overflow-y:auto;flex:1}.ct-modal-foot{padding:14px 20px;border-top:1px solid #f3f4f6;display:flex;justify-content:space-between;align-items:center;gap:8px}.ct-foot-right{display:flex;gap:8px;margin-left:auto}.ct-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.ct-field label{font-size:.78rem;font-weight:600;color:#374151}.ct-field input,.ct-field select,.ct-field textarea{padding:9px 11px;border:1px solid #e5e7eb;border-radius:7px;font-size:.87rem;color:#111827;font-family:inherit;background:#fff}.ct-field input:focus,.ct-field select:focus,.ct-field textarea:focus{outline:none;border-color:#1a56db;box-shadow:0 0 0 3px #1a56db1f}.ct-form-row{display:grid;grid-template-columns:2fr 1fr;gap:14px}@media(max-width:700px){.ct-form-row{grid-template-columns:1fr}}.ct-editor-wrap{display:grid;grid-template-columns:1fr 400px;gap:18px}@media(max-width:1000px){.ct-editor-wrap{grid-template-columns:1fr 340px}}@media(max-width:900px){.ct-editor-wrap{grid-template-columns:1fr}}.ct-editor-col label,.ct-fields-head label{font-size:.78rem;font-weight:600;color:#374151;display:block;margin-bottom:6px}.ct-toolbar{display:flex;flex-wrap:wrap;gap:4px;padding:6px;background:#f9fafb;border:1px solid #e5e7eb;border-bottom:none;border-radius:8px 8px 0 0}.ct-toolbar button{padding:6px 10px;border:1px solid transparent;background:#fff;border-radius:6px;font-size:.82rem;color:#374151;cursor:pointer;display:inline-flex;align-items:center;gap:5px}.ct-toolbar button:hover{background:#eef2ff;color:#1a56db;border-color:#c7d2fe}.ct-toolbar-sep{width:1px;background:#e5e7eb;margin:4px 2px}.ct-toolbar-primary{background:#1a56db!important;color:#fff!important;border-color:#1a56db!important}.ct-toolbar-primary:hover{background:#1e429f!important}.ct-editor{min-height:380px;max-height:520px;overflow-y:auto;padding:16px 18px;border:1px solid #e5e7eb;border-top:none;border-radius:0 0 8px 8px;font-size:.92rem;line-height:1.65;color:#111827;background:#fff}.ct-editor:focus{outline:none;border-color:#1a56db;box-shadow:0 0 0 3px #1a56db1a}.ct-editor h2{font-size:1.1rem;margin:14px 0 6px}.ct-editor h3{font-size:.98rem;margin:12px 0 4px}.ct-fields-head{display:flex;justify-content:space-between;align-items:center}.ct-fields-hint{font-size:.75rem;color:#6b7280;margin-bottom:10px;line-height:1.5}.ct-fields-hint code{background:#eef2ff;color:#1a56db;padding:1px 5px;border-radius:3px;font-size:.78rem}.ct-presets{display:flex;flex-wrap:wrap;gap:4px;align-items:center;margin-bottom:10px;font-size:.75rem;color:#6b7280}.ct-preset{padding:4px 10px;border:1px solid #d1d5db;background:#fff;border-radius:20px;font-size:.72rem;color:#374151;cursor:pointer}.ct-preset:hover{border-color:#1a56db;color:#1a56db;background:#eef2ff}.ct-fields-list{display:flex;flex-direction:column;gap:10px;max-height:460px;overflow-y:auto;padding-right:4px}.ct-field-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:6px}.ct-field-row-names{display:grid;grid-template-columns:1fr 1fr;gap:6px}.ct-field-row-controls{display:flex;gap:5px;align-items:center;flex-wrap:wrap}.ct-field-row-insert{display:flex;align-items:center;gap:6px;border-top:1px solid #e5e7eb;padding-top:6px;margin-top:2px}.ct-field-label,.ct-field-key{width:100%;padding:6px 9px;border:1px solid #e5e7eb;border-radius:5px;font-size:.8rem;background:#fff;box-sizing:border-box}.ct-field-key{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.ct-field-type,.ct-field-source{padding:6px 7px;border:1px solid #e5e7eb;border-radius:5px;font-size:.78rem;background:#fff;flex-shrink:0}.ct-field-type{width:90px}.ct-field-source{flex:1;min-width:100px}.ct-field-check{display:flex;align-items:center;gap:4px;font-size:.75rem;color:#6b7280;white-space:nowrap;flex-shrink:0}.ct-field-insert{display:flex;align-items:center;gap:6px;font-size:.78rem;border-top:1px solid #e5e7eb;padding-top:6px}.ct-field-insert code{background:#eef2ff;color:#1a56db;padding:2px 6px;border-radius:3px;font-size:.75rem;font-family:ui-monospace,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px;flex-shrink:0}.ct-field-insert .ct-link-btn{flex-shrink:0;white-space:nowrap}.ct-fields-empty{padding:20px;text-align:center;color:#9ca3af;font-size:.82rem;background:#f9fafb;border:1px dashed #e5e7eb;border-radius:8px}.ct-colors{display:flex;flex-wrap:wrap;gap:6px}.ct-color{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer}.ct-color.active{border-color:#111827;transform:scale(1.1)}.ct-merge-list{display:flex;flex-direction:column;gap:4px}.ct-merge-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:1px solid #e5e7eb;background:#fff;border-radius:7px;cursor:pointer;transition:all .15s}.ct-merge-item:hover{border-color:#1a56db;background:#eef2ff}.ct-merge-label{font-size:.87rem;color:#111827}.ct-merge-item code{color:#1a56db;font-size:.78rem;font-family:ui-monospace,monospace}.ct-topbar-actions{display:flex;gap:8px;flex-wrap:wrap}.ct-modal--xl{max-width:1100px}.ct-modal-sub{margin:4px 0 0;color:#6b7280;font-size:.8rem;max-width:640px;line-height:1.5}.ct-presets-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid #f1f5f9}.ct-preset-tab{padding:7px 14px;border:1px solid #e5e7eb;border-radius:20px;background:#fff;color:#374151;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.ct-preset-tab:hover{border-color:#1a56db;color:#1a56db}.ct-preset-tab.active{background:#1a56db;border-color:#1a56db;color:#fff}.ct-presets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.ct-preset-card{position:relative;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:18px 16px 14px;display:flex;flex-direction:column;gap:10px;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}.ct-preset-card:hover{border-color:#1a56db;box-shadow:0 8px 24px #1a56db1f;transform:translateY(-2px)}.ct-preset-card h3{margin:4px 0 0;font-size:.98rem;color:#111827;line-height:1.35;font-weight:700}.ct-preset-card p{margin:0;font-size:.82rem;color:#6b7280;line-height:1.5;flex:1}.ct-preset-badge{display:inline-block;align-self:flex-start;padding:3px 10px;background:linear-gradient(135deg,#059669,#10b981);color:#fff;border-radius:20px;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;line-height:1.4}.ct-preset-foot{display:flex;justify-content:space-between;align-items:center;font-size:.72rem;color:#9ca3af;padding-top:8px;border-top:1px solid #f3f4f6}.ct-preset-cat{font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.03em}.ct-preset-count{color:#9ca3af}.ct-preset-install{width:100%;justify-content:center;margin-top:6px;padding:9px 14px;border:none;border-radius:8px;background:#1a56db;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .15s;font-family:inherit}.ct-preset-install:hover{background:#1e429f}
