*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #ffffff;--bg-soft: #fafafa;--bg-subtle: #f4f4f5;--bg-muted: #e4e4e7;--border: #e4e4e7;--border-strong: #d4d4d8;--text: #18181b;--text-muted: #71717a;--text-subtle: #a1a1aa;--text-invert: #fafafa;--accent: #4f46e5;--accent-hover: #4338ca;--accent-soft: #eef2ff;--accent-fg: #ffffff;--danger: #dc2626;--danger-soft: #fef2f2;--success: #16a34a;--success-soft: #f0fdf4;--warning: #d97706;--warning-soft: #fffbeb;--sidebar-bg: #0a0a0a;--sidebar-border: #27272a;--sidebar-text: #fafafa;--sidebar-muted: #a1a1aa;--preview-bg: #f4f4f5;--input-bg: #ffffff;--input-border: #d4d4d8;--input-text: #18181b;--tag-bg: #f4f4f5;--radius-xs: 4px;--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;--text-xs: 12px;--text-sm: 13px;--text-md: 14px;--text-lg: 16px;--text-xl: 20px;--text-2xl: 24px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-lg: 0 10px 30px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.04);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv11","ss01","ss02"}html,body,#root{height:100%;background:var(--sidebar-bg)}body{overflow:auto;color:var(--text)}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{display:flex;align-items:center;gap:12px;padding:0 20px;height:50px;background:#13151a;border-bottom:1px solid var(--sidebar-border);flex-shrink:0}.app-header .logo{font-size:17px;font-weight:700;color:#fff;letter-spacing:-.3px}.app-header .logo span{color:var(--accent)}.header-spacer{flex:1}.header-actions{display:flex;gap:8px;align-items:center}.app-body{display:flex;flex:1;overflow:hidden}.sidebar{width:340px;min-width:260px;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.sidebar-section{padding:14px 16px;border-bottom:1px solid var(--sidebar-border)}.sidebar-section.grow{flex:1;display:flex;flex-direction:column;overflow:hidden}.section-label{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--sidebar-muted);margin-bottom:8px}.upload-zone{border:2px dashed var(--input-border);border-radius:var(--radius);padding:18px 14px;text-align:center;cursor:pointer;transition:all .15s;background:var(--input-bg);color:var(--sidebar-muted);font-size:13px}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent);background:#4f8ef714;color:var(--accent)}.upload-icon{font-size:22px;display:block;margin-bottom:5px}.upload-hint{font-size:11px;color:var(--sidebar-muted);margin-top:3px}.template-active{background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius);padding:10px 12px;display:flex;align-items:center;gap:10px}.t-icon{font-size:20px;flex-shrink:0}.t-info{flex:1;min-width:0}.t-name{font-size:13px;font-weight:600;color:var(--sidebar-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.t-meta{font-size:11px;color:var(--sidebar-muted);margin-top:2px}.t-clear{background:none;border:none;color:var(--sidebar-muted);cursor:pointer;font-size:15px;padding:2px 5px;border-radius:var(--radius-sm)}.t-clear:hover{color:var(--danger);background:#ef44441a}.builtin-label{font-size:11px;color:var(--sidebar-muted);margin:10px 0 6px}.builtin-list{display:flex;flex-wrap:wrap;gap:6px}.builtin-btn{background:var(--tag-bg);border:1px solid var(--input-border);border-radius:20px;padding:4px 10px;font-size:12px;color:var(--sidebar-text);cursor:pointer;transition:all .12s}.builtin-btn:hover,.builtin-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.syntax-hint{margin-top:10px;background:#4f8ef70f;border:1px solid rgba(79,142,247,.2);border-radius:var(--radius-sm);padding:8px 10px;font-size:11px;color:var(--sidebar-muted);line-height:1.65}.syntax-hint code{background:#4f8ef726;color:var(--accent);padding:1px 4px;border-radius:3px;font-family:SF Mono,Fira Code,monospace;font-size:10px}.data-textarea{width:100%;flex:1;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius);color:var(--input-text);font-family:SF Mono,Fira Code,Consolas,monospace;font-size:12px;line-height:1.65;padding:10px 12px;resize:none;outline:none;transition:border-color .15s}.data-textarea:focus{border-color:var(--accent)}.data-textarea.invalid{border-color:var(--danger)}.data-status{font-size:11px;margin-top:5px;display:flex;align-items:center;gap:5px}.data-status.ok{color:var(--success)}.data-status.err{color:var(--danger)}.data-status.empty{color:var(--sidebar-muted)}.var-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:7px}.var-chip{background:var(--tag-bg);border:1px solid var(--input-border);border-radius:4px;padding:2px 7px;font-size:10px;font-family:SF Mono,monospace;color:var(--accent)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .12s;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--sidebar-text);border:1px solid var(--input-border)}.btn-ghost:hover:not(:disabled){background:var(--input-bg)}.btn-ghost:disabled{opacity:.4;cursor:not-allowed}.btn-sm{padding:5px 10px;font-size:12px}.output-panel{flex:1;display:flex;flex-direction:column;background:var(--preview-bg);overflow:hidden}.output-toolbar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border-bottom:1px solid #dde1e8;flex-shrink:0}.output-toolbar .spacer{flex:1}.status-badge{font-size:11px;padding:3px 8px;border-radius:20px;font-weight:500}.status-badge.generating{background:#fef3c7;color:#92400e}.status-badge.ready{background:#dcfce7;color:#166534}.status-badge.error{background:#fee2e2;color:#991b1b}.status-badge.waiting{background:#f1f5f9;color:#64748b}.preview-frame-wrapper{flex:1;padding:20px;display:flex;flex-direction:column;align-items:center;overflow:auto}.preview-frame-wrapper iframe{width:100%;max-width:860px;flex:1;border:none;border-radius:var(--radius);box-shadow:0 4px 24px #0000001f;background:#fff}.preview-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#94a3b8}.preview-placeholder .ph-icon{font-size:48px}.preview-placeholder .ph-title{font-size:16px;font-weight:600;color:#64748b}.preview-placeholder .ph-sub{font-size:13px;text-align:center;max-width:300px}.preview-loading{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;color:#64748b;font-size:14px}.spinner{width:18px;height:18px;border:2px solid rgba(79,142,247,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.preview-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px}.preview-error .err-title{font-size:15px;font-weight:600;color:var(--danger)}.preview-error .err-msg{font-size:11px;color:#64748b;max-width:500px;text-align:center;font-family:monospace;background:#fee2e2;padding:8px 12px;border-radius:var(--radius-sm)}.app.mode-editor,.app.mode-editor .app-body{background:#f3f4f6}.app.mode-editor .app-header{background:#217346;border-bottom-color:#1a5c38}.app.mode-editor .app-header .logo{color:#fff}.app.mode-editor .app-header .logo span{color:#c8f0d8}.view-toggle,.header-data-btn{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid transparent;color:#ffffffd9;font-size:13px;font-weight:500;padding:6px 12px;border-radius:4px;cursor:pointer;transition:all .12s}.view-toggle:hover,.header-data-btn:hover{background:#ffffff1f;color:#fff}.view-toggle.active{background:#ffffff2e;color:#fff;border-color:#ffffff4d}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#f3f4f6;min-width:0}.app.mode-editor .sidebar{width:220px;min-width:220px;padding:0;background:#fff;border-right:1px solid #e5e7eb}.editor-toolbar{background:#f3f4f6;border-bottom:1px solid #d1d5db;padding:4px 8px;flex-shrink:0;overflow-x:auto}.tb-row{display:flex;align-items:stretch;gap:0;min-width:max-content}.tb-group-wrap{display:flex;flex-direction:column;min-width:max-content}.tb-group-content{display:flex;align-items:center;gap:2px;padding:2px 6px;min-height:60px;flex:1}.tb-group-content.tb-font-row{min-height:32px}.tb-group-sep{width:1px;background:#d1d5db;margin:4px}.tb-group-label{font-size:10px;color:#6b7280;text-align:center;text-transform:capitalize;padding:2px 0;min-width:max-content}.tb-btn{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 4px;background:transparent;border:1px solid transparent;border-radius:3px;color:#1f2937;font-size:12px;font-weight:500;cursor:pointer;transition:all .1s}.tb-btn:hover{background:#fff;border-color:#d1d5db}.tb-btn.active{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.tb-btn:disabled{opacity:.4;cursor:not-allowed}.tb-btn-wide{min-width:36px;padding:0 8px}.tb-btn-tall{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-width:56px;min-height:60px;padding:4px 6px;background:#fff;border:1px solid #d1d5db;border-radius:4px;cursor:pointer}.tb-btn-tall:hover{background:#f9fafb;border-color:#93c5fd}.tb-icon-big{font-size:22px;line-height:1;color:#217346}.tb-icon-label{font-size:10px;color:#4b5563}.tb-btn b,.tb-btn i,.tb-btn u,.tb-btn s{font-size:13px}.tb-grow{flex:1}.tb-select{height:24px;padding:0 6px;border:1px solid #d1d5db;border-radius:3px;background:#fff;color:#1f2937;font-size:12px;cursor:pointer}.tb-font-size-select{width:52px}.tb-vsep{width:1px;background:#d1d5db;margin:0 4px;align-self:stretch}.tb-color-group{display:flex;gap:1px;padding:0 2px}.tb-color-swatch{width:14px;height:14px;border-radius:2px;cursor:pointer;border:1px solid rgba(0,0,0,.1)}.tb-color-swatch.active{box-shadow:0 0 0 2px #4f8ef7}.tb-group{display:flex;gap:1px}.editor-canvas-wrap{flex:1;overflow:auto;padding:24px;display:flex;flex-direction:column;align-items:center;gap:8px;background:#e5e7eb}.editor-canvas-page{background:#fff;box-shadow:0 2px 8px #0000001a,0 0 0 1px #0000000a;padding:72px;min-height:100%;display:flex;flex-direction:column;gap:4px;margin-bottom:32px;position:relative}.editor-canvas-pages{display:flex;flex-direction:column;gap:0}.editor-canvas-page-wrap{position:relative;margin-bottom:28px}.editor-canvas-page-wrap:last-child{margin-bottom:0}.editor-canvas-page-badge{position:absolute;top:50%;right:-56px;transform:translateY(-50%);font-size:10px;color:#9ca3af;font-variant-numeric:tabular-nums;pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap}.editor-canvas-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#9ca3af;min-height:400px}.empty-title{font-size:18px;font-weight:600;color:#4b5563}.empty-sub{font-size:13px;color:#9ca3af}.doc-block{position:relative;padding:4px 8px;transition:background .1s,opacity .1s}.doc-block[draggable=true]{cursor:grab}.doc-block[draggable=true]:active{cursor:grabbing}.doc-block.dragging{opacity:.4}.doc-paragraph{font-family:Calibri,Helvetica,Arial,sans-serif;font-size:11pt;line-height:1.5;color:#1f2937;outline:none;min-height:1.5em}.doc-paragraph.doc-empty:before{content:"Type something…";color:#9ca3af;pointer-events:none}.doc-paragraph.bold{font-weight:700}.doc-heading{font-family:Calibri,Helvetica,Arial,sans-serif;color:#1f2937;outline:none;line-height:1.25;font-weight:700}.doc-heading-1{font-size:22pt}.doc-heading-2{font-size:16pt}.doc-heading-3{font-size:13pt}.doc-heading.doc-empty:before{content:"Heading";color:#9ca3af;pointer-events:none}.doc-list{padding-left:4px}.doc-list-row{display:flex;align-items:baseline;gap:6px;margin-bottom:2px}.doc-list-marker{color:#4b5563;min-width:18px;font-size:11pt}.doc-list-input{flex:1;outline:none;font-size:11pt;line-height:1.5;color:#1f2937}.doc-list-input:empty:before{content:"List item";color:#9ca3af;pointer-events:none}.doc-table-wrap{margin:8px 0}.doc-table{width:100%;border-collapse:collapse;font-size:10pt}.doc-table th,.doc-table td{border:1px solid #d1d5db;padding:4px 6px;text-align:left;vertical-align:top}.doc-table th{background:#f3f4f6;font-weight:600}.doc-table-header{width:100%;border:none;background:transparent;font-weight:600;outline:none;padding:0}.doc-table-cell{width:100%;border:none;background:transparent;outline:none;padding:0}.doc-table-actions{margin-top:6px;display:flex;gap:4px}.doc-hr{padding:8px 0}.doc-hr hr{border:none;border-top:1px solid #d1d5db}.doc-pagebreak{border-top:1px dashed #9ca3af;margin:18px 0;height:0;position:relative}.doc-pagebreak:after{content:"Page break";position:absolute;top:-7px;left:50%;transform:translate(-50%);background:#fff;padding:0 6px;color:#6b7280;font-size:9px;font-style:italic;letter-spacing:.04em}.doc-spacer{background:#f9fafb;border:1px dashed #d1d5db;border-radius:4px;padding:4px 8px;display:flex;align-items:center;gap:6px;font-size:11px;color:#6b7280}.doc-spacer input{width:50px;padding:2px 4px;border:1px solid #d1d5db;border-radius:3px}.doc-spacer-label{color:#9ca3af}.doc-image{border:1px solid #e5e7eb;border-radius:4px;padding:8px;display:flex;flex-direction:column;gap:8px;align-items:center;background:#f9fafb}.doc-image-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px;color:#9ca3af;cursor:pointer;width:100%;border:1px dashed #d1d5db;border-radius:4px}.doc-image-controls{display:flex;gap:6px;align-items:center}.doc-footer-region{position:relative;margin-top:auto;padding-top:8px;border-top:1px solid #e5e7eb;min-height:28px}.editor-canvas-page{background:#fff;box-shadow:0 1px 3px #00000014;overflow:hidden;display:flex;flex-direction:column}.editor-canvas-page-margin{display:flex;align-items:flex-end;flex-shrink:0}.editor-canvas-page-margin-top{padding:0 96px;border-bottom:1px solid transparent}.editor-canvas-page-margin-bottom{padding:0 96px;border-top:1px solid transparent;margin-top:auto}.editor-canvas-page-text-area{flex:1 1 auto;display:flex;flex-direction:column}.doc-footer-input{outline:none;font-family:Calibri,Helvetica,Arial,sans-serif;font-size:10pt;color:#1f2937;text-align:center;min-height:1.4em;line-height:1.4}.doc-footer-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:10px;color:#9ca3af;pointer-events:none;font-style:italic}.doc-header-region{position:relative;padding-bottom:8px;border-bottom:1px solid #e5e7eb;min-height:28px;margin-bottom:8px}.doc-header-input{outline:none;font-family:Calibri,Helvetica,Arial,sans-serif;font-size:10pt;color:#1f2937;text-align:center;min-height:1.4em;line-height:1.4}.doc-header-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:10px;color:#9ca3af;pointer-events:none;font-style:italic}.ruler-svg{display:block;background:#fff}.editor-canvas-rulers{display:flex}.editor-canvas-ruler-corner{width:22px;height:22px;background:#f8fafc;border-bottom:1px solid #e5e7eb;border-right:1px solid #e5e7eb}.editor-canvas-page-row{display:flex;align-items:flex-start}.v-ruler{background:#f8fafc;border-right:1px solid #e5e7eb;flex-shrink:0}.live-preview{flex:1;display:flex;flex-direction:column;background:#e5e7eb;overflow:hidden}.live-preview-toolbar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border-bottom:1px solid #d1d5db;flex-shrink:0}.live-preview-toolbar .spacer{flex:1}.live-preview .preview-frame-wrapper{flex:1;padding:24px;display:flex;justify-content:center;overflow:auto}.live-preview .preview-frame-wrapper iframe{width:100%;max-width:860px;min-height:1000px;height:100%;border:none;border-radius:4px;box-shadow:0 4px 24px #00000026;background:#fff}.live-preview .preview-placeholder,.live-preview .preview-loading,.live-preview .preview-error{flex:1;background:#e5e7eb}.ribbon{background:#f3f4f6;border-bottom:1px solid #d1d5db;flex-shrink:0}.ribbon-tabs{display:flex;align-items:stretch;gap:0;background:#217346;padding:0 8px;border-bottom:1px solid #1a5c38}.ribbon-quick-access{display:flex;align-items:center;gap:2px;padding:4px 8px 4px 0;border-right:1px solid rgba(255,255,255,.2);margin-right:4px}.qa-btn{background:transparent;border:none;color:#fff;cursor:pointer;width:26px;height:26px;border-radius:3px;font-size:13px;display:inline-flex;align-items:center;justify-content:center}.qa-btn:hover{background:#ffffff26}.qa-btn:disabled{opacity:.4;cursor:not-allowed}.qa-sep{width:1px;background:#ffffff4d;height:16px;margin:0 4px}.ribbon-tab{background:transparent;border:none;color:#ffffffd9;padding:0 14px;font-size:12px;font-weight:500;cursor:pointer;border-bottom:3px solid transparent;transition:all .1s}.ribbon-tab:hover{background:#ffffff1a;color:#fff}.ribbon-tab.active{background:#f3f4f6;color:#1f2937;border-bottom-color:#f3f4f6}.ribbon-tabs-spacer{flex:1}.ribbon-collapse{color:#fff}.ribbon-content{background:#f3f4f6}.ribbon-placeholder{display:flex;align-items:center;gap:12px;padding:20px 24px;color:#6b7280;font-size:13px;min-height:88px}.rp-icon{font-size:28px}.rp-title{font-size:14px;font-weight:600;color:#1f2937}.rp-hint{color:#6b7280}.ribbon-layout-tab{padding:4px 8px}.layout-section{display:flex;flex-direction:column;gap:2px;padding:0 6px;min-width:110px}.layout-section label{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:#6b7280}.layout-section select{min-width:130px}.status-bar{display:flex;align-items:center;gap:12px;background:#f3f4f6;border-top:1px solid #d1d5db;padding:4px 12px;font-size:11px;color:#4b5563;flex-shrink:0}.sb-item{padding:0 4px;cursor:default}.sb-sep{width:1px;background:#d1d5db;height:14px}.sb-spacer{flex:1}.sb-view-icons{display:flex;gap:2px}.sb-view-icons button{background:transparent;border:1px solid transparent;border-radius:3px;width:24px;height:22px;font-size:12px;color:#4b5563;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.sb-view-icons button:hover{background:#fff;border-color:#d1d5db}.sb-view-icons button.active{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.sb-zoom-group{display:flex;align-items:center;gap:4px}.sb-btn{background:transparent;border:1px solid transparent;border-radius:3px;width:22px;height:22px;color:#4b5563;cursor:pointer;font-size:12px;display:inline-flex;align-items:center;justify-content:center}.sb-btn:hover{background:#fff;border-color:#d1d5db}.sb-zoom-level{width:auto;padding:0 6px;font-size:11px}.sb-zoom-slider{width:100px;height:4px;cursor:pointer}.find-bar{position:sticky;top:0;z-index:10;align-self:flex-end;margin:-16px -16px 12px auto;background:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 4px 16px #0000001f;padding:6px 8px;display:flex;flex-direction:column;gap:4px;min-width:360px}.find-row{display:flex;align-items:center;gap:6px}.find-icon{font-size:12px;color:#6b7280;width:16px;text-align:center}.find-input{flex:1;min-width:0;height:24px;padding:0 8px;border:1px solid #d1d5db;border-radius:3px;font-size:12px;color:#1f2937;background:#fff;outline:none}.find-input:focus{border-color:var(--accent)}.find-counter{font-size:11px;color:#6b7280;min-width:60px;text-align:right}.find-counter.none{color:#9ca3af;font-style:italic}.find-nav{background:transparent;border:1px solid transparent;border-radius:3px;width:24px;height:24px;font-size:12px;color:#4b5563;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.find-nav:hover:not(:disabled){background:#f3f4f6;border-color:#d1d5db}.find-nav:disabled{opacity:.4;cursor:not-allowed}.find-case{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:#4b5563;cursor:pointer;-webkit-user-select:none;user-select:none}.find-case input{margin:0}.find-close{background:transparent;border:1px solid transparent;border-radius:3px;width:24px;height:24px;font-size:14px;color:#4b5563;cursor:pointer;line-height:1}.find-close:hover{background:#fee2e2;color:#991b1b}.find-replace{background:#fff;border:1px solid #d1d5db;border-radius:3px;height:24px;padding:0 10px;font-size:11px;color:#1f2937;cursor:pointer}.find-replace:hover:not(:disabled){background:#f3f4f6;border-color:#93c5fd}.find-replace:disabled{opacity:.4;cursor:not-allowed}.header-portal-link{font-size:12px;color:#4f8ef7;text-decoration:none;margin-right:8px}.header-portal-link:hover{text-decoration:underline}.portal{display:grid;grid-template-columns:240px 1fr;min-height:100vh;background:#f9fafb}.portal-side{background:#1a1d23;color:#e2e8f0;display:flex;flex-direction:column;padding:20px 0}.portal-brand{font-size:18px;font-weight:700;padding:0 20px 16px;color:#fff}.portal-brand span{color:#4f8ef7}.portal-user{padding:12px 20px;border-bottom:1px solid #2e3240;margin-bottom:12px}.portal-user-email{font-size:13px;color:#fff;word-break:break-all}.portal-user-meta{font-size:11px;color:#8892a4;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.portal-nav{display:flex;flex-direction:column;flex:1}.portal-nav-item,.portal-nav a{background:none;border:none;color:#cbd5e1;text-align:left;padding:10px 20px;font-size:14px;cursor:pointer;text-decoration:none;display:block}.portal-nav-item:hover,.portal-nav a:hover{background:#2e3240;color:#fff}.portal-nav-item.active{background:#4f8ef7;color:#fff}.portal-logout{margin:16px 20px;padding:8px 12px;background:#2e3240;color:#e2e8f0;border:1px solid #3a3f50;border-radius:6px;cursor:pointer;font-size:13px}.portal-logout:hover{background:#3a3f50}.portal-main{padding:32px 40px;overflow-y:auto}.portal-page{max-width:900px}.portal-page h1{font-size:24px;margin-bottom:20px;color:#1f2937}.portal-page h2{font-size:18px;margin:24px 0 12px;color:#1f2937}.portal-page h3{font-size:14px;margin:16px 0 8px;color:#1f2937}.portal-page p{color:#4b5563;line-height:1.5;margin-bottom:12px}.portal-loading,.portal-error,.portal-empty{padding:40px;text-align:center;color:#6b7280}.portal-error{color:#b91c1c}.portal-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;margin-bottom:20px}.portal-section.danger-zone{border-color:#fecaca;background:#fef2f2}.portal-section.danger-zone h2{color:#b91c1c}.portal-tabs{display:flex;gap:4px;border-bottom:1px solid #e5e7eb;margin-bottom:20px}.portal-tab{background:none;border:none;padding:10px 14px;font:500 14px inherit;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s,border-color .12s}.portal-tab:hover{color:#1f2937}.portal-tab.active{color:#4f8ef7;border-bottom-color:#4f8ef7}.portal-tab:focus-visible{outline:2px solid #4f8ef7;outline-offset:2px;border-radius:4px}.portal-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}.portal-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.portal-card-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#6b7280}.portal-card-value{font-size:22px;font-weight:600;color:#1f2937;margin-top:4px}.portal-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.portal-table th,.portal-table td{padding:10px 14px;text-align:left;font-size:13px;border-bottom:1px solid #f3f4f6}.portal-table th{background:#f9fafb;font-weight:600;color:#374151}.portal-table tr.revoked{opacity:.5}.portal-table .outcome.success{color:#16a34a}.portal-table .outcome.failure{color:#b91c1c}.portal-table td code{font-family:ui-monospace,monospace;font-size:12px}.portal-table td.prefix{white-space:nowrap}.portal-table td.actions{text-align:right;width:1px}.portal-table button{padding:6px 12px;background:#4f8ef7;color:#fff;border:1px solid transparent;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;font-family:inherit;line-height:1.2}.apikeys-create{display:flex;flex-direction:row;align-items:end;gap:12px;flex-wrap:wrap}.apikeys-create label{flex:1;min-width:220px}.apikeys-create-btn{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.apikeys-empty{padding:24px;text-align:center;color:#6b7280;background:#fff;border:1px dashed #e5e7eb;border-radius:8px}.apikeys-reveal-overlay{position:fixed;inset:0;background:#0f172a8c;display:grid;place-items:center;padding:16px;z-index:100}.apikeys-reveal{position:relative;background:#fff;border-radius:12px;padding:28px;width:100%;max-width:540px;box-shadow:0 20px 60px #00000040}.apikeys-reveal h3{margin:0 0 6px;font-size:18px;color:#1f2937}.apikeys-reveal-sub{margin:0 0 16px;color:#6b7280;font-size:13px;line-height:1.5}.apikeys-reveal-close{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;color:#6b7280;padding:6px;border-radius:6px}.apikeys-reveal-close:hover{background:#f3f4f6;color:#1f2937}.apikeys-reveal-key{display:flex;gap:8px;align-items:stretch;margin-bottom:16px}.apikeys-reveal-key code{flex:1;background:#1f2937;color:#f3f4f6;padding:12px;border-radius:6px;font-family:ui-monospace,monospace;font-size:12px;word-break:break-all}.apikeys-reveal-key button{display:inline-flex;align-items:center;gap:4px;padding:0 12px;background:#4f8ef7;color:#fff;border:none;border-radius:6px;cursor:pointer;font:500 12px inherit}.apikeys-reveal-key button:hover{background:#3a7be0}.apikeys-reveal-confirm{display:flex;align-items:center;gap:8px;padding:12px;background:#fef3c7;border:1px solid #fbbf24;border-radius:6px;margin-bottom:16px;cursor:pointer;font-size:13px;color:#78350f}.apikeys-reveal-confirm input{width:16px;height:16px;margin:0}.apikeys-reveal-actions{display:flex;justify-content:flex-end}.apikeys-reveal-done{padding:8px 20px;background:#4f8ef7;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit}.apikeys-reveal-done:hover:not(:disabled){background:#3a7be0}.apikeys-reveal-done:disabled{opacity:.5;cursor:not-allowed}.twofa-status{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:8px;margin-bottom:16px}.twofa-status svg{flex-shrink:0}.twofa-status-title{font:600 14px var(--font-sans)}.twofa-status-sub{font:12px var(--font-sans);margin-top:2px}.twofa-status>div{flex:1}.twofa-status-off{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.twofa-status-on{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}.twofa-status button{margin-left:auto}.twofa-flow .portal-form{margin-top:16px}.twofa-uri-row{display:flex;gap:8px;align-items:stretch;margin-bottom:12px}.twofa-uri-row .twofa-uri{flex:1;background:#1f2937;color:#f3f4f6;padding:10px 12px;border-radius:6px;font-family:ui-monospace,monospace;font-size:12px;word-break:break-all}.twofa-uri-row button{display:inline-flex;align-items:center;gap:4px;padding:0 12px;background:#4f8ef7;color:#fff;border:none;border-radius:6px;cursor:pointer;font:500 12px inherit}.twofa-secret-details{margin-bottom:16px}.twofa-secret-details summary{cursor:pointer;font-size:13px;color:#4f8ef7;margin-bottom:8px}.twofa-backup{background:#fffbeb;border:1px solid #fbbf24;border-radius:8px;padding:20px}.twofa-backup h3{margin:0 0 4px;color:#78350f;font-size:16px}.twofa-backup p{color:#78350f;font-size:13px;margin:0 0 16px;line-height:1.5}.twofa-codes{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-bottom:12px}.twofa-codes code{background:#fff;border:1px solid #fbbf24;padding:8px 10px;border-radius:4px;font-family:ui-monospace,monospace;font-size:13px;color:#1f2937;text-align:center}.twofa-backup-actions{margin-bottom:16px}.twofa-copy-all{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;color:#78350f;border:1px solid #fbbf24;border-radius:6px;cursor:pointer;font:500 12px inherit}.twofa-copy-all:hover{background:#fef3c7}.twofa-confirm{display:flex;align-items:center;gap:8px;padding:12px;background:#fff;border:1px solid #fbbf24;border-radius:6px;margin-bottom:16px;cursor:pointer;font-size:13px;color:#78350f}.twofa-confirm input{width:16px;height:16px;margin:0}.twofa-backup-continue{display:flex;justify-content:flex-end}.twofa-backup-continue button{padding:8px 20px;background:#4f8ef7;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit}.twofa-backup-continue button:hover:not(:disabled){background:#3a7be0}.twofa-backup-continue button:disabled{opacity:.5;cursor:not-allowed}.pw-strength{display:flex;gap:3px;margin-top:6px}.pw-strength-bar{height:4px;flex:1;background:#f3f4f6;border-radius:2px;transition:background .2s}.pw-strength-bar.active-weak{background:#ef4444}.pw-strength-bar.active-fair{background:#f59e0b}.pw-strength-bar.active-good{background:#10b981}.pw-strength-bar.active-strong{background:#059669}.pw-strength-label{font:11px var(--font-sans);color:#6b7280;margin-top:4px}.profile-2fa-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:8px;margin-bottom:20px;background:#fff;border:1px solid #e5e7eb}.profile-2fa-card.enabled{border-color:#a7f3d0;background:#ecfdf5}.profile-2fa-card.disabled{border-color:#fecaca;background:#fef2f2}.profile-2fa-card svg{flex-shrink:0}.profile-2fa-card-title{font:600 14px var(--font-sans);color:#1f2937}.profile-2fa-card-sub{font:12px var(--font-sans);color:#6b7280;margin-top:2px}.profile-2fa-card>div{flex:1}.profile-2fa-card a,.profile-2fa-card button{padding:6px 14px;background:#4f8ef7;color:#fff;border:none;border-radius:6px;cursor:pointer;font:500 12px inherit;text-decoration:none}.portal-table button:hover:not(:disabled){background:#3a7be0}.portal-table button:disabled{opacity:.5;cursor:not-allowed}.portal-table button.danger{background:#ef4444;color:#fff;border-color:transparent}.portal-table button.danger:hover:not(:disabled){background:#dc2626}.portal-form{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.portal-form label,.portal-section label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:#374151;font-weight:500}.portal-form input,.portal-section input{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit}.portal-form input:focus,.portal-section input:focus{outline:none;border-color:#4f8ef7;box-shadow:0 0 0 3px #4f8ef726}.portal-form button,.portal-section button{padding:8px 16px;background:#4f8ef7;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;align-self:flex-start}.portal-form button:hover:not(:disabled),.portal-section button:hover:not(:disabled){background:#3a7be0}.portal-form button:disabled,.portal-section button:disabled{opacity:.5;cursor:not-allowed}.portal-form button.danger,.portal-section button.danger{background:#ef4444}.portal-form button.danger:hover:not(:disabled),.portal-section button.danger:hover:not(:disabled){background:#dc2626}.billing-warning{display:flex;align-items:center;gap:12px;background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;padding:14px 16px;margin-bottom:20px;color:#78350f}.billing-warning svg{flex-shrink:0;color:#b45309}.billing-warning-title{font:600 14px var(--font-sans);color:#78350f}.billing-warning-sub{font:13px var(--font-sans);color:#78350f;margin-top:2px;line-height:1.5}.billing-warning>div{flex:1}.billing-warning button{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;color:#78350f;border:1px solid #fbbf24;border-radius:6px;cursor:pointer;font:500 13px inherit;white-space:nowrap}.billing-warning button:hover{background:#fef9c3}.billing-status{padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.billing-status-active{background:#dcfce7;color:#166534}.billing-status-past_due{background:#fee2e2;color:#b91c1c}.billing-status-canceled,.billing-status-trialing{background:#f3f4f6;color:#6b7280}.portal-plan{position:relative}.portal-plan-badge{position:absolute;top:-10px;right:12px;background:#4f8ef7;color:#fff;padding:3px 10px;border-radius:999px;font:600 11px var(--font-sans)}.usage-bar-wrap{display:flex;align-items:center;gap:12px}.usage-bar{flex:1;height:10px;background:#f3f4f6;border-radius:999px;overflow:hidden}.usage-bar-fill{height:100%;background:#4f8ef7;transition:width .3s;border-radius:999px}.usage-bar.warn .usage-bar-fill{background:#f59e0b}.usage-bar.danger .usage-bar-fill{background:#ef4444}.usage-bar-label{font:12px var(--font-mono);color:#6b7280;min-width:140px;text-align:right}.usage-spark{width:100%;height:80px;display:block}.usage-overage{background:#fef3c7;border-color:#fbbf24}.portal-row,.auth-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.portal-callout{background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;padding:16px;margin-bottom:20px}.portal-callout strong{display:block;margin-bottom:8px;color:#78350f}.portal-secret{background:#1f2937;color:#f3f4f6;padding:12px;border-radius:6px;font-family:ui-monospace,monospace;font-size:12px;word-break:break-all;white-space:pre-wrap;margin:8px 0}.portal-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.portal-plan{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.portal-plan.current{border-color:#4f8ef7;background:#eff6ff}.portal-plan h3{margin:0 0 6px;color:#1f2937}.portal-plan p{font-size:13px;color:#6b7280;margin:0 0 12px}.muted{color:#9ca3af;font-size:12px}code{background:#f3f4f6;padding:1px 4px;border-radius:3px;font-size:12px}.auth-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#1e293b,#4f8ef7);padding:20px}.auth-card{background:#fff;border-radius:12px;padding:32px;width:100%;max-width:400px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;gap:12px}.auth-brand{font-size:22px;font-weight:700;color:#1a1d23;text-align:center;margin-bottom:8px}.auth-brand span{color:#4f8ef7}.auth-card h1{font-size:18px;color:#374151;margin-bottom:4px;text-align:center;font-weight:600}.auth-card label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:#374151;font-weight:500}.auth-card input{padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.auth-card input:focus{outline:none;border-color:#4f8ef7;box-shadow:0 0 0 3px #4f8ef726}.auth-card button[type=submit]{padding:10px;background:#4f8ef7;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;margin-top:4px}.auth-card button[type=submit]:hover:not(:disabled){background:#3a7be0}.auth-card button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.auth-error{background:#fef2f2;color:#b91c1c;padding:8px 12px;border-radius:6px;font-size:13px;border:1px solid #fecaca}.auth-foot{text-align:center;margin-top:8px}.auth-foot a{color:#4f8ef7;font-size:14px;text-decoration:none;display:inline-block;padding:10px 4px;min-height:32px}.auth-foot a:hover{text-decoration:underline}.mk{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;color:#0f172a;line-height:1.55;background:#fff}.mk-main{min-height:60vh}.mk-brand{font-weight:800;color:#0f172a;text-decoration:none;letter-spacing:-.02em}.mk-brand span{color:#4f8ef7}.mk-header{position:sticky;top:0;z-index:50;background:#ffffffd9;-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid #e2e8f0}.mk-header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:24px;padding:14px 24px}.mk-nav-desktop{display:flex;gap:4px;flex:1;margin-left:16px}.mk-nav-link{padding:8px 12px;border-radius:6px;color:#475569;text-decoration:none;font-size:14px;font-weight:500}.mk-nav-link:hover{background:#f1f5f9;color:#0f172a}.mk-nav-link.active{color:#0f172a;background:#e2e8f0}.mk-cta-desktop{display:flex;align-items:center;gap:8px}.mk-burger{display:none;background:none;border:none;padding:8px;cursor:pointer}.mk-burger span{display:block;width:22px;height:2px;background:#0f172a;margin:4px 0;border-radius:2px}.mk-nav-mobile{display:none;flex-direction:column;gap:4px;padding:8px 24px 16px;border-top:1px solid #e2e8f0;background:#fff}.mk-nav-mobile hr{border:none;border-top:1px solid #e2e8f0;margin:8px 0}.mk-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:background .15s,transform .05s}.mk-btn:active{transform:translateY(1px)}.mk-btn-primary{background:#4f8ef7;color:#fff;border-color:#4f8ef7}.mk-btn-primary:hover{background:#3a7be0;border-color:#3a7be0}.mk-btn-ghost{background:transparent;color:#0f172a;border-color:#cbd5e1}.mk-btn-ghost:hover{background:#f1f5f9}.mk-btn-lg{padding:12px 22px;font-size:15px}.mk-btn-block{width:100%}.mk-hero{background:linear-gradient(180deg,#f8fafc,#fff);padding:64px 24px 80px;border-bottom:1px solid #e2e8f0}.mk-hero-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center}.mk-h1{font-size:56px;line-height:1.05;font-weight:800;letter-spacing:-.03em;margin:12px 0 20px;color:#0f172a}.mk-accent{background:linear-gradient(90deg,#4f8ef7,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:transparent}.mk-lede{font-size:19px;color:#475569;max-width:580px;margin:0 0 28px}.mk-pill{display:inline-block;padding:4px 12px;background:#eef2ff;color:#4338ca;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.02em}.mk-hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}.mk-hero-bullets{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;color:#475569;font-size:14px;max-width:480px}.mk-hero-bullets li{display:flex;align-items:center;gap:8px}.mk-hero-bullets svg{color:#10b981;flex:0 0 auto}.mk-code-window{background:#0f172a;border-radius:12px;overflow:hidden;box-shadow:0 30px 60px -20px #0f172a66,0 0 0 1px #1e293b}.mk-code-window-lg{max-width:100%}.mk-code-bar{display:flex;align-items:center;gap:6px;padding:12px 16px;background:#1e293b;border-bottom:1px solid #334155}.mk-code-bar span{width:12px;height:12px;border-radius:50%;background:#475569}.mk-code-bar span:nth-child(1){background:#ef4444}.mk-code-bar span:nth-child(2){background:#f59e0b}.mk-code-bar span:nth-child(3){background:#10b981}.mk-code-bar em{margin-left:12px;color:#94a3b8;font-size:12px;font-style:normal;font-family:ui-monospace,monospace}.mk-copy{margin-left:auto;display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;background:#ffffff0f;color:#cbd5e1;border:1px solid rgba(255,255,255,.1);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.mk-copy:hover{background:#ffffff1f;color:#fff}.mk-copy:focus-visible{outline:2px solid #4f8ef7;outline-offset:2px}.mk-window{max-width:720px}.mk-window pre{font-size:12.5px}.mk-code-window pre{margin:0;padding:18px 20px;color:#e2e8f0;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:13px;line-height:1.6;overflow-x:auto;white-space:pre}.mk-code-window pre code{background:transparent;padding:0;font-size:inherit;color:inherit;border-radius:0}.mk-code-window code{background:transparent;padding:0;font-size:13px;color:#e2e8f0}.mk-trust{background:#0f172a;color:#cbd5e1;padding:36px 24px}.mk-trust-label{text-align:center;color:#94a3b8;font-size:13px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:20px}.mk-trust-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:16px;text-align:center}.mk-trust-grid>div{display:flex;flex-direction:column;gap:4px}.mk-trust-grid strong{font-size:22px;color:#fff;font-weight:700;letter-spacing:-.01em}.mk-trust-grid span{font-size:12px;color:#94a3b8}.mk-section{max-width:1200px;margin:0 auto;padding:72px 24px}.mk-section-alt{background:#f8fafc;max-width:none}.mk-section-alt>*{max-width:1200px;margin-left:auto;margin-right:auto}.mk-section-head{max-width:720px;margin:0 auto 48px;text-align:center}.mk-section-head h2{font-size:36px;font-weight:800;letter-spacing:-.02em;margin:0 0 12px;color:#0f172a}.mk-section-head p{font-size:17px;color:#475569;margin:0}.mk-section-title{font-size:28px;font-weight:800;letter-spacing:-.02em;margin:0 0 28px;color:#0f172a}.mk-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.mk-feature{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;transition:transform .15s,box-shadow .15s,border-color .15s}.mk-feature:hover{transform:translateY(-2px);box-shadow:0 10px 30px -10px #0f172a1f;border-color:#cbd5e1}.mk-section-alt .mk-feature{background:#fff}.mk-feature h3{font-size:17px;font-weight:700;margin:0 0 8px;color:#0f172a}.mk-feature p{font-size:14px;color:#475569;margin:0;line-height:1.55}.mk p a,.mk li a{display:inline-block;padding:4px 0;line-height:1.4}.mk-steps{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.mk-steps li{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;display:flex;gap:16px}.mk-step-num{flex:0 0 32px;height:32px;border-radius:50%;background:#4f8ef7;color:#fff;font-weight:700;display:grid;place-items:center;font-size:14px}.mk-steps h4{font-size:16px;font-weight:700;margin:0 0 4px;color:#0f172a}.mk-steps p{font-size:14px;color:#475569;margin:0}.mk-cta-band{background:linear-gradient(135deg,#1e293b,#312e81);color:#fff;padding:64px 24px;text-align:center}.mk-cta-band h2{font-size:32px;font-weight:800;letter-spacing:-.02em;margin:0 0 8px}.mk-cta-band p{color:#cbd5e1;margin:0 0 24px}.mk-cta-row{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center}.mk-cta-band .mk-btn-ghost{color:#fff;border-color:#475569}.mk-cta-band .mk-btn-ghost:hover{background:#1e293b}.mk-table-wrap{overflow-x:auto}.mk-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px #e2e8f0}.mk-table th,.mk-table td{padding:14px 18px;text-align:left;font-size:14px;border-bottom:1px solid #e2e8f0;vertical-align:top}.mk-table thead th{background:#f1f5f9;font-weight:600;color:#0f172a}.mk-table tbody tr:last-child th,.mk-table tbody tr:last-child td{border-bottom:none}.mk-table tbody th{font-weight:600;color:#0f172a;white-space:nowrap;width:220px}.mk-table td{color:#475569}.mk-cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.mk-cert{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.mk-cert-name{font-weight:700;color:#0f172a;font-size:15px}.mk-cert-status{margin-top:4px;font-size:13px;color:#10b981;font-weight:600}.mk-cert-target{font-size:12px;color:#94a3b8;margin-top:4px}.mk-plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.mk-plan{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:28px 24px;display:flex;flex-direction:column;gap:12px;position:relative}.mk-plan.featured{border-color:#4f8ef7;box-shadow:0 10px 30px -10px #4f8ef74d}.mk-plan-badge{position:absolute;top:-12px;right:16px;background:#4f8ef7;color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:.04em;text-transform:uppercase}.mk-plan h3{font-size:18px;margin:0}.mk-plan-price{font-size:32px;font-weight:800;color:#0f172a;letter-spacing:-.02em}.mk-plan-price span{font-size:14px;color:#94a3b8;font-weight:500;margin-left:4px}.mk-plan-blurb{font-size:13px;color:#475569;min-height:36px;margin:0}.mk-plan-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px;font-size:14px;color:#475569;flex:1}.mk-plan-features li{padding-left:22px;position:relative}.mk-plan-features li:before{content:"✓";position:absolute;left:0;top:0;color:#10b981;font-weight:700}.mk-faq{display:flex;flex-direction:column;gap:8px;max-width:800px;margin:0 auto}.mk-faq details{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px 20px}.mk-faq summary{font-weight:600;cursor:pointer;color:#0f172a;list-style:none}.mk-faq summary::-webkit-details-marker{display:none}.mk-faq summary:after{content:"+";float:right;font-weight:400;color:#94a3b8}.mk-faq details[open] summary:after{content:"−"}.mk-faq p{margin:12px 0 0;color:#475569;font-size:14px}.mk-changelog{list-style:none;padding:0;max-width:800px;margin:0 auto}.mk-release{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;margin-bottom:16px}.mk-release-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}.mk-release-tag{background:#eef2ff;color:#4338ca;font-size:11px;font-weight:700;padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em}.mk-release-version{font-size:22px;font-weight:800;margin:0;color:#0f172a}.mk-release-date{margin-left:auto;font-size:13px;color:#94a3b8}.mk-release-section h3{font-size:13px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.05em;margin:12px 0 6px}.mk-release-section ul{margin:0;padding-left:20px}.mk-release-section li{font-size:14px;color:#1e293b;margin:2px 0}.mk-page-hero{max-width:800px;margin:0 auto;padding:80px 24px 40px;text-align:center}.mk-page-hero .mk-pill{margin-bottom:16px}.mk-page-hero h1{font-size:44px;font-weight:800;letter-spacing:-.02em;margin:0 0 12px;color:#0f172a}.mk-page-hero p{font-size:17px;color:#475569;margin:0}.mk-footer{background:#0f172a;color:#cbd5e1;padding:56px 24px 24px}.mk-footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}.mk-footer h4{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px}.mk-footer a{display:block;color:#cbd5e1;text-decoration:none;font-size:14px;padding:4px 0}.mk-footer a:hover{color:#fff}.mk-footer-tag{color:#94a3b8;font-size:13px;max-width:280px;margin:8px 0 0}.mk-footer-bottom{max-width:1200px;margin:40px auto 0;padding-top:20px;border-top:1px solid #1e293b;color:#94a3b8;font-size:13px;text-align:center}.mk-skip{position:absolute;left:8px;top:8px;z-index:100;padding:8px 14px;background:#0f172a;color:#fff;border-radius:6px;text-decoration:none;font-weight:600;font-size:13px;transform:translateY(-200%);transition:transform .15s}.mk-skip:focus{transform:translateY(0);outline:2px solid #4f8ef7;outline-offset:2px}.portal-skip{position:absolute;left:8px;top:8px;z-index:100;padding:8px 14px;background:#0f172a;color:#fff;border-radius:6px;text-decoration:none;font-weight:600;font-size:13px;transform:translateY(-200%);transition:transform .15s}.portal-skip:focus{transform:translateY(0);outline:2px solid #4f8ef7;outline-offset:2px}.mk-billing-toggle{display:inline-flex;background:#f1f5f9;border-radius:999px;padding:4px;gap:4px;margin:0 auto 32px}.mk-billing-toggle button{border:none;background:transparent;padding:8px 18px;border-radius:999px;font-size:13px;font-weight:600;color:#475569;cursor:pointer}.mk-billing-toggle button.active{background:#fff;color:#0f172a;box-shadow:0 1px 3px #00000014}.mk-billing-toggle .mk-billing-save{margin-left:6px;font-size:11px;color:#10b981;font-weight:700}.mk-matrix-wrap{overflow-x:auto;margin-top:32px}.mk-matrix{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px #e2e8f0}.mk-matrix th,.mk-matrix td{padding:12px 16px;text-align:center;font-size:14px;border-bottom:1px solid #e2e8f0}.mk-matrix thead th{background:#f1f5f9;font-weight:700;color:#0f172a}.mk-matrix tbody th{text-align:left;font-weight:500;color:#475569}.mk-matrix td.yes{color:#10b981;font-weight:700}.mk-matrix td.no{color:#cbd5e1}.mk-matrix tbody tr:last-child th,.mk-matrix tbody tr:last-child td{border-bottom:none}.mk-cert-badge{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px 18px}.mk-cert-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}.mk-cert-name{font-weight:700;color:#0f172a;font-size:14px}.mk-cert-status{font-size:12px;color:#475569;margin-top:2px}.mk-cert-crosswalk{margin-top:24px}.mk-cert-crosswalk .mk-cert-dot{margin-right:8px;display:inline-block;vertical-align:middle}.mk-trust-logos{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:16px;align-items:center}.mk-trust-logo{display:flex;align-items:center;justify-content:center;gap:8px;height:44px;padding:0 12px;border:1px dashed #475569;border-radius:8px;color:#94a3b8;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.mk-trust-logo svg{color:#64748b}.mk-hero-doc{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 30px 60px -20px #0f172a59,0 0 0 1px #1e293b}.mk-hero-doc-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#1e293b}.mk-hero-doc-bar span{width:10px;height:10px;border-radius:50%;background:#475569}.mk-hero-doc-bar span:nth-child(1){background:#ef4444}.mk-hero-doc-bar span:nth-child(2){background:#f59e0b}.mk-hero-doc-bar span:nth-child(3){background:#10b981}.mk-hero-doc-bar em{margin-left:10px;color:#94a3b8;font-size:12px;font-style:normal;font-family:ui-monospace,monospace}.mk-hero-doc-body{aspect-ratio:8.5 / 11;display:grid;place-items:center;background:#f8fafc}.mk-hero-doc-body img{max-width:100%;max-height:100%;display:block}.mk-hero-doc-fallback{color:#94a3b8;font-size:14px;padding:24px;text-align:center}.mk-mcp-key-card{background:#0f172a;color:#cbd5e1;border-radius:12px;padding:20px;margin-top:16px;font-family:ui-monospace,monospace;font-size:13px}.mk-mcp-key-card code{color:#e2e8f0;word-break:break-all}.mk-mcp-key-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:12px}.mk-mcp-key-err{color:#fca5a5;font-size:13px;margin-top:8px}.mk-mcp-callout{display:grid;grid-template-columns:1.1fr 1fr;gap:32px;align-items:center;background:linear-gradient(135deg,#1e293b,#312e81);color:#fff;border-radius:16px;padding:32px;margin:0 0 48px}.mk-mcp-callout h2{font-size:26px;font-weight:800;margin:0 0 8px}.mk-mcp-callout p{color:#cbd5e1;margin:0 0 16px;font-size:15px;line-height:1.6}@media(max-width:768px){.mk-nav-desktop,.mk-cta-desktop{display:none}.mk-burger{display:block}.mk-header-inner.open~.mk-nav-mobile{display:flex}.mk-hero{padding:40px 20px 56px}.mk-hero-grid{grid-template-columns:1fr;gap:32px}.mk-h1{font-size:36px}.mk-lede{font-size:16px}.mk-hero-bullets{grid-template-columns:1fr}.mk-page-hero h1{font-size:30px}.mk-trust-grid{grid-template-columns:repeat(2,1fr);gap:24px 12px}.mk-steps{grid-template-columns:1fr}.mk-section-head h2{font-size:26px}.mk-footer-grid{grid-template-columns:1fr 1fr;gap:24px}.mk-nav-mobile{display:flex}.mk-code-window pre{font-size:11px;padding:14px 16px}.mk-trust-logos{grid-template-columns:repeat(2,1fr)}.mk-mcp-callout{grid-template-columns:1fr;padding:24px}.mk-hero-doc{display:none}}.mk{overflow-x:hidden}.mk-header,.mk-main,.mk-footer{max-width:100vw}.ad-page{padding-bottom:40px}.ad-intro{color:#475569;max-width:720px;margin:0 0 24px}.ad-layout{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start}.ad-side{position:sticky;top:12px;display:flex;flex-direction:column;gap:4px}.ad-side-group{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:6px;color:#475569;cursor:pointer;font-size:14px;font-weight:500}.ad-side-group:hover{background:#f1f5f9;color:#0f172a}.ad-side-group.active{background:#4f8ef7;color:#fff}.ad-side-count{font-size:11px;background:#00000014;padding:1px 6px;border-radius:999px}.ad-side-group.active .ad-side-count{background:#fff3}.ad-side-link{display:block;margin-top:12px;font-size:13px;color:#4f8ef7;text-decoration:none;padding:8px 12px}.ad-side-link:hover{text-decoration:underline}.ad-main{min-width:0}.ad-section{font-size:20px;font-weight:700;margin:0 0 12px;color:#1f2937}.ad-endpoints{display:flex;flex-direction:column;gap:8px}.ad-endpoint{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.ad-endpoint-head{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;-webkit-user-select:none;user-select:none}.ad-endpoint-head:hover{background:#f9fafb}.ad-method{color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em;min-width:50px;text-align:center}.ad-path{font-family:ui-monospace,monospace;font-size:13px;color:#0f172a;font-weight:600}.ad-summary{color:#6b7280;font-size:13px;margin-left:8px;flex:1}.ad-toggle{color:#9ca3af;font-size:12px}.ad-endpoint-body{padding:16px 20px 20px;border-top:1px solid #e5e7eb;background:#fafbfc}.ad-endpoint-body h4{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#475569;margin:16px 0 8px}.ad-desc-block{color:#475569;font-size:14px;white-space:pre-line;margin:0 0 8px}.ad-schema{width:100%;border-collapse:collapse;font-size:13px}.ad-schema th,.ad-schema td{padding:8px 10px;border-bottom:1px solid #e5e7eb;text-align:left;vertical-align:top}.ad-schema tbody tr:last-child th,.ad-schema tbody tr:last-child td{border-bottom:none}.ad-schema th{font-weight:600;color:#1f2937;width:200px}.ad-type{display:inline-block;font-size:11px;background:#eef2ff;color:#4338ca;padding:1px 6px;border-radius:4px;font-family:ui-monospace,monospace}.ad-req{color:#ef4444;font-weight:700;margin-left:4px}.ad-muted{color:#9ca3af;font-size:12px}.ad-ref{background:#fef3c7;color:#92400e;padding:1px 6px;border-radius:4px;font-size:12px}.ad-desc{color:#6b7280;font-size:12px;margin-top:4px}.ad-nested{margin-top:6px;padding-left:10px;border-left:2px solid #e5e7eb}.ad-try{margin-top:14px;border-top:1px solid #e5e7eb;padding-top:10px}.ad-try-toggle{background:none;border:none;color:#4f8ef7;font-weight:600;font-size:13px;cursor:pointer;padding:0}.ad-try-toggle:hover{color:#3a7be0}.ad-try-body{display:grid;grid-template-columns:1fr 1fr;gap:8px 10px;margin-top:8px;align-items:end}.ad-try-body>.ad-try-submit-row,.ad-try-body>.ad-try-binary,.ad-try-body>.ad-try-err,.ad-try-body>.ad-try-resp{grid-column:1 / -1}.ad-try-body label{display:flex;flex-direction:column;gap:3px;font-size:11px;color:#475569;font-weight:600;letter-spacing:.01em}.ad-try-body label>span{display:block}.ad-try-body input,.ad-try-body textarea,.ad-try-body select{padding:5px 8px;border:1px solid #d1d5db;border-radius:5px;font-family:ui-monospace,monospace;font-size:12px;background:#fff;color:#0f172a;width:100%;box-sizing:border-box}.ad-try-body input:focus,.ad-try-body textarea:focus,.ad-try-body select:focus{outline:none;border-color:#4f8ef7;box-shadow:0 0 0 2px #4f8ef726}.ad-try-body input[type=file]{padding:3px;font-family:inherit;font-size:11px}.ad-try-body input[type=file]::file-selector-button{margin-right:8px;padding:4px 10px;background:#f1f5f9;color:#0f172a;border:1px solid #cbd5e1;border-radius:4px;font:500 12px ui-sans-serif,system-ui,sans-serif;cursor:pointer}.ad-try-body input[type=file]::file-selector-button:hover{background:#e2e8f0}.ad-try-submit-row{display:flex;align-items:center;gap:10px;padding-top:4px}.ad-try-submit-row .mk-btn{padding:6px 14px;font-size:13px;font-weight:600;border-radius:5px;width:auto;align-self:auto}.ad-try-binary{padding:8px 12px;background:#ecfdf5;color:#065f46;border-radius:5px;font-size:12px}.ad-try-binary a{color:#065f46;font-weight:600;text-decoration:underline}.ad-try-err{background:#fef2f2;color:#b91c1c;padding:8px 12px;border-radius:6px;font-size:13px}.ad-try-resp{background:#0f172a;border-radius:6px;overflow:hidden}.ad-try-status{padding:6px 12px;font-size:12px;font-weight:700;color:#fff}.ad-try-status.ok{background:#10b981}.ad-try-status.fail{background:#ef4444}.ad-try-url{padding:4px 12px;background:#1e293b;color:#94a3b8;font-family:ui-monospace,monospace;font-size:11px;word-break:break-all}.ad-try-resp pre{margin:0;padding:12px;color:#e2e8f0;font-family:ui-monospace,monospace;font-size:12px;max-height:320px;overflow:auto;white-space:pre-wrap}@media(max-width:720px){.ad-try-body{grid-template-columns:1fr}}@media(max-width:768px){.ad-layout{grid-template-columns:1fr}.ad-side{position:static;flex-direction:row;flex-wrap:wrap;gap:6px}.ad-side-group{font-size:12px}}.portal-nav-external{color:#94a3b8!important;font-size:12px!important;margin-top:8px;border-top:1px solid #e5e7eb;padding-top:8px!important}.pab{margin-top:8px}.pab-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px}.pab-title{font-size:22px;font-weight:700;color:#0f172a;margin:0}.pab-sub{color:#64748b;font-size:14px;margin:4px 0 0}.pab-search{margin-bottom:16px}.pab-search input{width:100%;padding:10px 14px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff;color:#0f172a}.pab-search input:focus{outline:none;border-color:#4f8ef7;box-shadow:0 0 0 3px #4f8ef726}.pab-loading,.pab-error,.pab-empty{padding:24px;text-align:center;color:#64748b;font-size:14px;background:#f8fafc;border-radius:8px}.pab-error{color:#b91c1c;background:#fef2f2}.pab-layout{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start}.pab-side{position:sticky;top:80px;display:flex;flex-direction:column;gap:4px}.pab-side-group{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:6px;color:#475569;cursor:pointer;font-size:14px;font-weight:500}.pab-side-group:hover{background:#f1f5f9;color:#0f172a}.pab-side-group.active{background:#4f8ef7;color:#fff}.pab-side-count{font-size:11px;background:#00000014;padding:1px 6px;border-radius:999px}.pab-side-group.active .pab-side-count{background:#ffffff40}.pab-main{min-width:0}.pab-section{font-size:18px;font-weight:700;margin:0 0 12px;color:#1f2937}.pab-endpoints{display:flex;flex-direction:column;gap:8px}.pab-endpoint{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.pab-endpoint-head{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;-webkit-user-select:none;user-select:none}.pab-endpoint-head:hover{background:#f8fafc}.pab-method{color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em;min-width:50px;text-align:center}.pab-path{font-family:ui-monospace,monospace;font-size:13px;color:#0f172a;font-weight:600}.pab-summary{color:#64748b;font-size:13px;margin-left:8px;flex:1}.pab-toggle{color:#94a3b8;font-size:12px}.pab-endpoint-body{padding:16px 20px 20px;border-top:1px solid #e2e8f0;background:#f8fafc}.pab-endpoint-body h4{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#475569;margin:16px 0 8px}.pab-endpoint-body h4:first-child{margin-top:0}.pab-desc-block{color:#475569;font-size:14px;white-space:pre-line;margin:0 0 8px}.pab-schema{width:100%;border-collapse:collapse;font-size:13px}.pab-schema th,.pab-schema td{padding:8px 10px;border-bottom:1px solid #e2e8f0;text-align:left;vertical-align:top}.pab-schema tbody tr:last-child th,.pab-schema tbody tr:last-child td{border-bottom:none}.pab-schema th{font-weight:600;color:#1f2937;width:200px}.pab-type{display:inline-block;font-size:11px;background:#eef2ff;color:#4338ca;padding:1px 6px;border-radius:4px;font-family:ui-monospace,monospace}.pab-req{color:#ef4444;font-weight:700;margin-left:4px}.pab-muted{color:#94a3b8;font-size:12px}.pab-ref{background:#fef3c7;color:#92400e;padding:1px 6px;border-radius:4px;font-size:12px}.pab-desc{color:#64748b;font-size:12px;margin-top:4px}.pab-nested{margin-top:6px;padding-left:10px;border-left:2px solid #e2e8f0}.pab-cta-inline{margin-top:16px;padding-top:12px;border-top:1px solid #e2e8f0}.pab-link{color:#4f8ef7;font-size:13px;font-weight:600;text-decoration:none}.pab-link:hover{text-decoration:underline}@media(max-width:768px){.pab-layout{grid-template-columns:1fr}.pab-side{position:static;flex-direction:row;flex-wrap:wrap;gap:6px}.pab-side-group{font-size:12px}.pab-summary{display:none}}@media(max-width:480px){.auth-page{padding:12px}.auth-card{max-width:100%;min-width:0;padding:24px 20px}.auth-row,.auth-row label{min-width:0}.auth-row input{min-width:0;width:100%}}.sandbox-designer{display:grid;grid-template-columns:320px 1fr;height:calc(100vh + -0px);background:#fff;color:#1f2937}.sandbox-sidebar{background:#f9fafb;border-right:1px solid #e5e7eb;overflow-y:auto;display:flex;flex-direction:column}.sandbox-sidebar .sidebar-section:last-of-type{flex:1;min-height:0;overflow:hidden}.sandbox-empty{font-size:12px;color:#6b7280;padding:6px 0;font-style:italic}.builtin-row{display:flex;align-items:stretch;gap:4px;flex:1 1 100%}.builtin-row .builtin-btn{flex:1;min-width:0}.builtin-row.active .builtin-btn{background:var(--accent);border-color:var(--accent);color:#fff}.builtin-del{background:#fff;border:1px solid #e5e7eb;color:#9ca3af;border-radius:6px;padding:0 8px;cursor:pointer;font-size:12px}.builtin-del:hover{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.sandbox-main{display:flex;flex-direction:column;min-width:0;overflow:hidden}.sandbox-toolbar{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid #e5e7eb;background:#fff;flex-shrink:0}.sandbox-save{display:flex;align-items:center;gap:8px;flex:0 1 420px}.sandbox-name-input{flex:1;padding:6px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-family:inherit;background:#fff;min-width:0}.sandbox-name-input:focus{outline:none;border-color:#4f8ef7}.sandbox-name-input:disabled{background:#f3f4f6;color:#9ca3af}.sandbox-info{font-size:12px;color:#6b7280;min-width:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sandbox-err{color:#b91c1c}.sandbox-ok{color:#047857}.sandbox-canvas{flex:1;min-height:0;overflow:hidden}.sandbox-canvas .live-preview{height:100%}.sandbox-canvas .preview-frame-wrapper{height:calc(100vh - 110px)}.sandbox-canvas iframe{height:100%}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;font:500 13px/1 var(--font-sans);border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:all .12s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:5px 9px;font-size:12px}.btn-primary{background:var(--accent);color:var(--accent-fg)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-subtle);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:var(--bg-subtle);color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.input{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font:13px var(--font-sans);background:var(--bg);color:var(--text);transition:border-color .12s}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #4f46e51f}.input:disabled{background:var(--bg-subtle);color:var(--text-subtle);cursor:not-allowed}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sandbox-designer{display:flex;flex-direction:column;height:100%;background:var(--bg);color:var(--text);font-family:var(--font-sans)}.sandbox-body{display:flex;flex:1;min-height:0;overflow:hidden}.sandbox-sidebar{width:380px;min-width:320px;max-width:480px;background:var(--bg-soft);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.sandbox-main{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--bg)}.sandbox-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0;height:52px}.sandbox-topbar-left,.sandbox-topbar-right{display:flex;align-items:center;gap:10px;min-width:0}.sandbox-brand{display:flex;align-items:center;gap:6px;font-weight:600;font-size:14px;color:var(--text);padding-right:12px;border-right:1px solid var(--border)}.sandbox-brand svg{color:var(--accent)}.sandbox-active-name{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);min-width:0}.sandbox-active-name svg{flex-shrink:0}.sandbox-active-name>span:nth-child(2){overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:240px}.sandbox-active-name.muted{color:var(--text-subtle);font-style:italic}.sandbox-active-tag{font-size:10px;font-weight:600;padding:2px 6px;background:var(--success-soft);color:var(--success);border-radius:var(--radius-xs);text-transform:uppercase;letter-spacing:.5px}.sandbox-save-form{display:flex;gap:6px;align-items:center}.sandbox-save-form .input{width:200px}.sandbox-more-menu{min-width:220px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:4px;box-shadow:var(--shadow-lg);font:13px var(--font-sans);color:var(--text);z-index:60}.sandbox-more-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius-xs);cursor:pointer;outline:none;-webkit-user-select:none;user-select:none}.sandbox-more-item[data-highlighted]{background:var(--bg-subtle)}.sandbox-more-item[data-disabled]{color:var(--text-subtle);pointer-events:none}.sandbox-more-label{padding:6px 10px 4px;font:600 10px var(--font-sans);text-transform:uppercase;letter-spacing:.6px;color:var(--text-subtle)}.sandbox-more-sep{height:1px;background:var(--border);margin:4px 6px}.sandbox-more-hint{margin-left:auto;font:11px var(--font-mono);color:var(--text-subtle)}.sandbox-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 12px;gap:2px;background:var(--bg-soft);flex-shrink:0}.sandbox-tab{background:none;border:none;padding:10px 12px;font:500 12px var(--font-sans);color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;display:inline-flex;align-items:center;gap:6px;transition:color .12s,border-color .12s}.sandbox-tab:hover{color:var(--text)}.sandbox-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.sandbox-tab-count{font-size:11px;background:var(--bg-muted);color:var(--text-muted);padding:2px 6px;border-radius:999px}.sandbox-tab.active .sandbox-tab-count{background:var(--accent-soft);color:var(--accent)}.sandbox-tab-body{flex:1;overflow-y:auto;min-height:0}.tpl-grid-wrap{padding:16px}.tpl-grid-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.tpl-search{position:relative;flex:1;min-width:160px}.tpl-search svg{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--text-subtle);pointer-events:none}.tpl-search input{width:100%;padding:7px 10px 7px 30px;border:1px solid var(--border);border-radius:var(--radius-sm);font:13px var(--font-sans);background:var(--bg);color:var(--text)}.tpl-search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #4f46e51f}.tpl-sort{position:relative}.tpl-sort select{appearance:none;padding:7px 26px 7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font:13px var(--font-sans);background:var(--bg);color:var(--text);cursor:pointer}.tpl-sort select:focus{outline:none;border-color:var(--accent)}.tpl-sort svg{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:var(--text-subtle);pointer-events:none}.tpl-section{margin-bottom:24px}.tpl-section-label{font:600 10px/1 var(--font-sans);letter-spacing:1px;text-transform:uppercase;color:var(--text-subtle);margin-bottom:10px}.tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.tpl-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .15s;display:flex;flex-direction:column}.tpl-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-1px)}.tpl-card.active{border-color:var(--accent);box-shadow:0 0 0 3px #4f46e51f}.tpl-card.builtin .tpl-card-cover{background:linear-gradient(135deg,#f5f3ff,#ede9fe)}.tpl-card-cover{position:relative;aspect-ratio:5/7;background:var(--bg-soft);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;overflow:hidden}.doc-preview{width:90%;height:90%;max-width:180px}.doc-preview-empty{font-size:12px;color:var(--text-subtle)}.tpl-card-active-badge,.tpl-card-builtin-badge{position:absolute;top:6px;left:6px;display:inline-flex;align-items:center;gap:3px;font:600 10px var(--font-sans);padding:3px 6px;border-radius:var(--radius-xs)}.tpl-card-active-badge{background:var(--accent);color:#fff}.tpl-card-builtin-badge{background:#ffffffe6;color:var(--accent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tpl-card-menu{position:absolute;top:6px;right:6px;width:24px;height:24px;border:none;background:#ffffffe6;border-radius:var(--radius-xs);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .12s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tpl-card:hover .tpl-card-menu{opacity:1}.tpl-card-menu:hover{color:var(--text);background:#fff}.tpl-card-menu-pop{position:absolute;top:32px;right:6px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:140px;padding:4px;z-index:10}.tpl-card-menu-pop button{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:none;background:none;color:var(--text);font:13px var(--font-sans);text-align:left;cursor:pointer;border-radius:var(--radius-xs)}.tpl-card-menu-pop button:hover{background:var(--bg-subtle)}.tpl-card-menu-pop button.danger{color:var(--danger)}.tpl-card-menu-pop button.danger:hover{background:var(--danger-soft)}.tpl-card-meta{padding:8px 10px}.tpl-card-name{font:600 12px var(--font-sans);color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.tpl-card-sub{font:11px var(--font-sans);color:var(--text-subtle);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tpl-empty{padding:32px 16px;text-align:center;color:var(--text-subtle);display:flex;flex-direction:column;align-items:center;gap:6px}.tpl-empty-title{font:600 13px var(--font-sans);color:var(--text-muted)}.tpl-empty-sub{font:12px var(--font-sans)}.sandbox-data-pane{display:flex;flex-direction:column;height:100%;padding:12px;gap:12px}.sandbox-data-toolbar{display:flex;gap:8px;align-items:center}.sandbox-data-context{flex:1}.code-editor{flex:1;min-height:200px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.code-editor .cm-editor{height:100%}.code-editor .cm-editor.cm-focused{outline:none}.path-inspector{padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg)}.path-inspector-label{font:600 10px/1 var(--font-sans);letter-spacing:1px;text-transform:uppercase;color:var(--text-subtle);margin-bottom:8px;display:flex;align-items:center;gap:6px}.path-inspector-count{font-size:10px;background:var(--bg-muted);color:var(--text-muted);padding:1px 6px;border-radius:999px}.path-inspector-empty{font:12px var(--font-sans);color:var(--text-subtle);padding:4px 0}.path-chips{display:flex;flex-wrap:wrap;gap:4px}.path-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 7px 3px 5px;border:1px solid var(--border);background:var(--bg);border-radius:var(--radius-xs);font:500 11px var(--font-mono);color:var(--text-muted);cursor:pointer;transition:all .12s}.path-chip:hover{border-color:var(--border-strong);color:var(--text)}.path-chip.bound{color:var(--success);border-color:var(--success-soft);background:var(--success-soft)}.path-chip.bound:hover{background:#dcfce7}.path-chip.unbound{color:var(--text-muted)}.path-chip-text{white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis}.preview-pane{flex:1;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.preview-toolbar{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg-soft);flex-shrink:0}.preview-toolbar .spacer{flex:1}.status-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font:600 11px/1 var(--font-sans);text-transform:uppercase;letter-spacing:.5px}.status-pill.idle{background:var(--bg-muted);color:var(--text-subtle)}.status-pill.generating{background:var(--warning-soft);color:var(--warning)}.status-pill.ready{background:var(--success-soft);color:var(--success)}.status-pill.error{background:var(--danger-soft);color:var(--danger)}.preview-stat{font:11px var(--font-mono);color:var(--text-subtle)}.preview-stage{flex:1;overflow:auto;background:var(--bg-subtle);display:flex;align-items:center;justify-content:center;padding:24px}.preview-iframe{width:100%;height:100%;max-width:900px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.preview-empty,.preview-loading,.preview-error{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--text-subtle);padding:32px;text-align:center}.preview-empty svg,.preview-error svg{color:var(--text-subtle)}.preview-empty-title,.preview-error-title{font:600 15px var(--font-sans);color:var(--text-muted)}.preview-empty-sub{font:13px var(--font-sans);max-width:320px}.preview-error-msg{font:11px var(--font-mono);color:var(--danger);background:var(--danger-soft);padding:8px 12px;border-radius:var(--radius-xs);max-width:500px;overflow-x:auto;text-align:left}.status-bar{display:flex;align-items:center;gap:10px;padding:6px 12px;border-top:1px solid var(--border);background:var(--bg-soft);font:11px var(--font-sans);color:var(--text-muted);flex-shrink:0;height:28px}.status-bar .spacer{flex:1}.status-bar-dot{width:6px;height:6px;border-radius:50%;background:var(--text-subtle)}.status-bar.saving .status-bar-dot{background:var(--warning);animation:pulse 1.2s ease-in-out infinite}.status-bar.saved .status-bar-dot{background:var(--success)}.status-bar.error .status-bar-dot{background:var(--danger)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.status-bar-text{color:var(--text);font-weight:500}.status-bar-stat{color:var(--text-subtle);font-family:var(--font-mono)}.status-bar-dirty{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;background:var(--warning-soft);color:var(--warning);border-radius:999px;font:600 10px var(--font-sans);text-transform:uppercase;letter-spacing:.4px}[data-sonner-toast]{font-family:var(--font-sans)!important}.mmd-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100}.mmd-content{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(560px,calc(100vw - 32px));max-height:calc(100vh - 32px);background:var(--bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;z-index:101;overflow:hidden}.mmd-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.mmd-title{display:inline-flex;align-items:center;gap:8px;font:600 15px var(--font-sans);color:var(--text)}.mmd-title svg{color:var(--accent)}.mmd-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-xs);display:inline-flex}.mmd-close:hover{background:var(--bg-subtle);color:var(--text)}.mmd-stepper{display:flex;align-items:center;gap:0;padding:16px 18px 4px}.mmd-step{display:flex;align-items:center;gap:6px;flex:1}.mmd-step:last-child{flex:0}.mmd-step-dot{width:22px;height:22px;border-radius:50%;background:var(--bg-muted);color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;font:600 11px var(--font-sans);flex-shrink:0}.mmd-step.active .mmd-step-dot{background:var(--accent);color:#fff}.mmd-step.done .mmd-step-dot{background:var(--success);color:#fff}.mmd-step-label{font:500 12px var(--font-sans);color:var(--text-muted)}.mmd-step.active .mmd-step-label{color:var(--text);font-weight:600}.mmd-step-bar{flex:1;height:1px;background:var(--border);margin:0 8px}.mmd-step.done+.mmd-step .mmd-step-bar,.mmd-step.active+.mmd-step .mmd-step-bar{background:var(--accent)}.mmd-body{padding:16px 18px 20px;overflow-y:auto;flex:1;min-height:200px}.mmd-step-panel{display:flex;flex-direction:column;gap:12px}.mmd-label{font:600 13px var(--font-sans);color:var(--text)}.mmd-file-input{display:none}.mmd-file-picked{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background:var(--success-soft);border:1px solid var(--success);border-radius:var(--radius-sm);color:var(--text);font:13px var(--font-sans);align-self:flex-start}.mmd-file-picked svg{color:var(--success)}.mmd-detect{display:inline-flex;align-items:center;gap:6px;font:12px var(--font-sans);color:var(--text-muted)}.mmd-field-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px;max-height:240px;overflow-y:auto}.mmd-field{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg)}.mmd-field.bound{border-color:var(--success);background:var(--success-soft)}.mmd-field-name{font:500 12px var(--font-mono);color:var(--text)}.mmd-badge{display:inline-flex;align-items:center;gap:4px;font:600 10px var(--font-sans);padding:3px 7px;border-radius:999px;text-transform:uppercase;letter-spacing:.4px}.mmd-badge.ok{background:var(--success);color:#fff}.mmd-badge.miss{background:var(--danger-soft);color:var(--danger)}.mmd-empty{padding:16px;text-align:center;color:var(--text-subtle);font:13px var(--font-sans);background:var(--bg-subtle);border-radius:var(--radius-sm)}.mmd-summary{font:13px var(--font-sans);color:var(--text-muted)}.mmd-foot{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-top:1px solid var(--border);background:var(--bg-soft)}.mmd-foot-right{display:flex;align-items:center;gap:8px}.audit-filters{display:flex;align-items:center;gap:16px;padding:14px 0;flex-wrap:wrap}.audit-filter-group{display:flex;align-items:center;gap:6px}.audit-filter-label{font:600 12px/1 var(--font-sans);text-transform:uppercase;letter-spacing:.6px;color:var(--text-subtle)}.filter-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border:1px solid var(--border);background:var(--bg);border-radius:999px;font:500 12px var(--font-sans);color:var(--text-muted);cursor:pointer;transition:all .12s}.filter-chip:hover{color:var(--text);border-color:var(--border-strong)}.filter-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.batch-map-list{display:flex;flex-direction:column;gap:8px;max-height:280px;overflow-y:auto}.batch-map-row{display:grid;grid-template-columns:1fr auto 1.4fr;align-items:center;gap:10px;padding:8px 10px;background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-sm)}.batch-map-src{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);font:12px var(--font-mono);min-width:0}.batch-map-src code{color:var(--text);background:var(--bg);padding:2px 6px;border-radius:3px;border:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.batch-map-arrow{color:var(--text-subtle);font:600 14px var(--font-sans)}.epp{display:flex;flex-direction:column;gap:24px;padding:40px 48px;height:100%;overflow-y:auto;background:var(--bg)}.epp-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.epp-title{margin:0 0 4px;font:600 22px var(--font-sans);color:var(--text);letter-spacing:-.2px}.epp-sub{margin:0;font:14px var(--font-sans);color:var(--text-muted)}.epp-steps{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.epp-step{display:flex;gap:12px;padding:16px;background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-md)}.epp-step-num{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;font:600 13px var(--font-sans)}.epp-step-title{font:600 13px var(--font-sans);color:var(--text);margin-bottom:4px}.epp-step-body{font:13px var(--font-sans);color:var(--text-muted);line-height:1.5}.epp-section-label{display:inline-flex;align-items:center;gap:6px;font:600 11px var(--font-sans);text-transform:uppercase;letter-spacing:.5px;color:var(--text-subtle)}.epp-section-label svg{color:var(--accent)}.epp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media(max-width:900px){.epp-grid,.epp-steps{grid-template-columns:1fr}}.epp-card{display:flex;flex-direction:column;gap:10px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all .12s ease;font:inherit;color:inherit}.epp-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.epp-card.builtin{background:linear-gradient(180deg,var(--bg) 0%,var(--bg-soft) 100%)}.epp-card-cover{background:var(--bg-subtle);border-radius:var(--radius-sm);aspect-ratio:200/283;overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative}.epp-card-cover svg{width:100%;height:100%}.epp-card-iframe{width:100%;height:100%;border:0;background:#fff;pointer-events:none}.epp-card-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(110deg,var(--bg-subtle) 30%,var(--bg-muted) 50%,var(--bg-subtle) 70%);background-size:200% 100%;animation:shimmer 1.2s ease-in-out infinite;color:var(--text-subtle)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.epp-card-error{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg-subtle);color:var(--text-subtle);font:12px var(--font-sans);padding:12px;text-align:center}.epp-card-name{font:600 13px var(--font-sans);color:var(--text)}.epp-card-sub{font:12px var(--font-sans);color:var(--text-muted);margin-top:2px}.epp-foot{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--bg-soft);border:1px dashed var(--border);border-radius:var(--radius-sm);font:13px var(--font-sans);color:var(--text-muted)}.epp-foot code{font:12px var(--font-mono);color:var(--text);background:var(--bg);padding:1px 5px;border-radius:3px;border:1px solid var(--border)}.epp-foot svg{color:var(--text-subtle);flex-shrink:0}.mmd-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.mmd-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-top:1px solid var(--border);background:var(--bg-soft);font:12px var(--font-sans)}.ei-format-row{display:flex;gap:8px}.ei-format-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border:1px solid var(--border);background:var(--bg-soft);color:var(--text);border-radius:6px;font:500 13px var(--font-sans);cursor:pointer}.ei-format-btn:hover{border-color:var(--accent)}.ei-format-btn.active{border-color:var(--accent);background:var(--accent-soft, rgba(99, 102, 241, .08));color:var(--accent)}.ei-scale-row{display:flex;gap:6px;flex-wrap:wrap}.ei-scale-btn{padding:6px 10px;border:1px solid var(--border);background:var(--bg-soft);color:var(--text);border-radius:6px;font:500 12px var(--font-sans);cursor:pointer}.ei-scale-btn:hover{border-color:var(--accent)}.ei-scale-btn.active{border-color:var(--accent);background:var(--accent-soft, rgba(99, 102, 241, .08));color:var(--accent)}.ei-page-row{display:flex;align-items:center;gap:8px}.i2p-drop{display:flex;align-items:center;gap:12px;padding:18px 16px;border:1.5px dashed var(--border);background:var(--bg-soft);border-radius:8px;color:var(--text);cursor:pointer}.i2p-drop:hover,.i2p-drop.drag{border-color:var(--accent);background:#6366f10a}.i2p-drop-title{font:500 13px var(--font-sans)}.i2p-drop-sub{font:400 12px var(--font-sans);margin-top:2px}.i2p-list{list-style:none;padding:0;margin:12px 0 0;max-height:200px;overflow-y:auto;border:1px solid var(--border-soft, var(--border));border-radius:6px;background:var(--bg)}.i2p-row{display:flex;align-items:center;gap:10px;padding:8px 12px;font:400 13px var(--font-sans)}.i2p-row+.i2p-row{border-top:1px solid var(--border-soft, var(--border))}.i2p-row-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.i2p-row-remove{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px}.i2p-row-remove:hover{color:var(--danger, #dc2626);background:#dc262614}.mp-list{padding:0;margin:12px 0 0}.mp-row{list-style:none}.mp-idx{font:600 11px var(--font-mono);color:var(--text-muted);min-width:18px;text-align:right}.mp-row-actions{display:flex;gap:2px}.mp-row-actions .i2p-row-remove:disabled{opacity:.35;cursor:not-allowed}.mp-row-actions .i2p-row-remove:disabled:hover{color:var(--text-muted);background:transparent}.kbd-dialog{width:min(460px,calc(100vw - 32px))}.kbd-list{padding:8px 0;overflow-y:auto}.kbd-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 18px}.kbd-row+.kbd-row{border-top:1px solid var(--border-soft, var(--border))}.kbd-keys{display:inline-flex;align-items:center;gap:4px;flex-shrink:0}.kbd-key{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:22px;padding:0 6px;font:500 12px var(--font-mono);color:var(--text);background:var(--bg-soft);border:1px solid var(--border);border-bottom-width:2px;border-radius:var(--radius-xs);line-height:1}.kbd-label{font:13px var(--font-sans);color:var(--text-muted);text-align:right}.mailmerge-page{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.mp-head h1{display:inline-flex;align-items:center;gap:8px;font:700 22px var(--font-sans);color:var(--text);margin:0 0 6px}.mp-head p{color:var(--text-muted);font:14px/1.5 var(--font-sans);margin:0;max-width:720px}.mp-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:18px}@media(max-width:900px){.mp-grid{grid-template-columns:1fr}}.mp-templates,.mp-data{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:10px;min-width:0}.mp-templates h2,.mp-data h2{font:600 13px var(--font-sans);color:var(--text);margin:8px 0 0;text-transform:uppercase;letter-spacing:.4px}.mp-templates h2:first-child,.mp-data h2:first-child{margin-top:0}.mp-hint{color:var(--text-muted);font:13px/1.5 var(--font-sans);margin:0}.mp-hint code{font:12px var(--font-mono);background:var(--bg-subtle);padding:1px 5px;border-radius:3px}.mp-empty{padding:18px;border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-subtle);font:13px var(--font-sans);text-align:center;display:flex;align-items:center;justify-content:center;gap:6px}.mp-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px;max-height:360px;overflow-y:auto}.mp-list li{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-soft)}.mp-list.muted li{background:transparent;opacity:.7}.mp-list li svg{color:var(--text-subtle);flex-shrink:0}.mp-name{flex:1;min-width:0;font:500 13px var(--font-sans);color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-tag{font:600 10px var(--font-sans);color:var(--text-subtle);padding:2px 6px;border:1px solid var(--border);border-radius:999px;text-transform:uppercase;letter-spacing:.4px}.mp-nodocx summary{cursor:pointer;font:500 12px var(--font-sans);color:var(--text-muted);padding:6px 0;list-style:none}.mp-nodocx summary:before{content:"▸";display:inline-block;margin-right:6px;transition:transform .15s}.mp-nodocx[open] summary:before{transform:rotate(90deg)}.mp-data .CodeMirror,.mp-data .cm-editor{min-height:320px;max-height:520px;border:1px solid var(--border);border-radius:var(--radius-sm)}.cp-controls{display:flex;flex-direction:column;gap:14px}.cp-control{display:flex;flex-direction:column;gap:6px}.cp-label{font:600 12px var(--font-sans);color:var(--text);display:flex;align-items:center;justify-content:space-between}.cp-value{font:600 13px var(--font-mono);color:var(--accent)}.cp-presets{display:flex;gap:6px;flex-wrap:wrap}.cp-preset{font:500 12px var(--font-mono);color:var(--text-muted);background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 10px;cursor:pointer}.cp-preset:hover{background:var(--bg-muted);color:var(--text)}.cp-preset.active{background:var(--accent);color:#fff;border-color:var(--accent)}.cp-slider{width:100%;accent-color:var(--accent)}.cp-sub{font:400 12px var(--font-sans)}.cp-result{display:flex;flex-direction:column;gap:4px;padding:10px 12px;background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-sm)}.cp-result-row{display:flex;align-items:center;justify-content:space-between;font:13px var(--font-sans);color:var(--text)}.cp-result-delta{border-top:1px solid var(--border);padding-top:6px;margin-top:4px;font-weight:600;color:var(--success)}.spd-mode-row{display:flex;gap:6px}.spd-mode-btn{flex:1;font:500 12px var(--font-sans);color:var(--text-muted);background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;cursor:pointer}.spd-mode-btn:hover{background:var(--bg-muted);color:var(--text)}.spd-mode-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.spd-range{display:flex;align-items:center;gap:8px}.spd-mini-label{font:500 12px var(--font-sans);color:var(--text-muted)}.spd-num{width:72px;padding:5px 8px;font:500 13px var(--font-mono);color:var(--text);background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-sm)}.spd-num:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}.spd-list{display:flex;align-items:center;gap:8px}.spd-list-input{flex:1;padding:6px 10px;font:13px var(--font-mono);color:var(--text);background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-sm)}.spd-list-input:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}.spd-hint{font:400 12px var(--font-sans)}.api-docs{font:13px var(--font-sans);color:var(--text)}.api-docs-section{margin-bottom:18px}.api-docs-section-title{display:flex;align-items:center;gap:6px;font:600 12px var(--font-sans);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin:0 0 8px}.api-docs-steps{padding-left:20px;margin:0;line-height:1.6}.api-docs-steps li{margin-bottom:4px}.api-docs code{font:12px var(--font-mono);background:var(--bg-muted);padding:1px 4px;border-radius:3px;color:var(--text)}.api-docs-footnote{font:12px var(--font-sans);color:var(--text-muted);line-height:1.5}.api-docs-endpoints{display:flex;flex-direction:column;gap:4px}.api-docs-endpoint{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-soft);overflow:hidden}.api-docs-endpoint-head{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;background:transparent;border:none;text-align:left;cursor:pointer;color:var(--text);font:13px var(--font-sans)}.api-docs-endpoint-head:hover{background:var(--bg-muted)}.api-docs-method{font:600 10px var(--font-mono);padding:2px 6px;border-radius:3px;flex-shrink:0}.api-docs-method-post{background:#dbeafe;color:#1d4ed8}.api-docs-path{font:12px var(--font-mono);color:var(--text);flex-shrink:0}.api-docs-summary{font:12px var(--font-sans);color:var(--text-muted);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.api-docs-endpoint-body{border-top:1px solid var(--border);padding:8px 10px;background:var(--bg)}.api-docs-lang-tabs{display:flex;align-items:center;gap:4px;margin-bottom:6px}.api-docs-lang-tab{display:inline-flex;align-items:center;gap:4px;font:500 11px var(--font-sans);padding:3px 8px;background:transparent;color:var(--text-muted);border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer}.api-docs-lang-tab:hover{color:var(--text)}.api-docs-lang-tab.active{background:var(--bg-muted);color:var(--text);border-color:var(--border)}.api-docs-lang-spacer{flex:1}.api-docs-copy{display:inline-flex;align-items:center;gap:4px;font:500 11px var(--font-sans);padding:3px 8px;background:var(--bg-soft);color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer}.api-docs-copy:hover{color:var(--text)}.api-docs-code{margin:0;padding:10px 12px;background:#1e1e1e;color:#d4d4d4;border-radius:var(--radius-sm);font:12px var(--font-mono);line-height:1.5;overflow-x:auto;max-height:280px;overflow-y:auto}.api-docs-code code{background:none;padding:0;color:inherit;font:inherit}.ad-quickstart{background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 18px;margin-bottom:18px}.ad-quickstart h3{margin:0 0 8px;font:600 14px var(--font-sans);color:var(--text)}.ad-quickstart ol{padding-left:20px;margin:0 0 8px;line-height:1.6;font:13px var(--font-sans);color:var(--text)}.ad-quickstart ol li{margin-bottom:4px}.ad-quickstart code{font:12px var(--font-mono);background:var(--bg-muted);padding:1px 4px;border-radius:3px}.ad-quickstart-tip{margin:6px 0 0;font:12px var(--font-sans);color:var(--text-muted)}.ad-example{margin:12px 0 14px}.ad-example-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.ad-example-head strong{font:600 12px var(--font-sans);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.ad-example-actions{display:flex;gap:6px}.ad-copy-btn{display:inline-flex;align-items:center;gap:4px;font:500 11px var(--font-sans);padding:3px 8px;background:var(--bg-soft);color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer}.ad-copy-btn:hover{color:var(--text);background:var(--bg-muted)}.ad-copy-btn:disabled{opacity:.5;cursor:not-allowed}.ad-copy-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.ad-copy-btn-primary:hover{background:var(--accent-hover, #4338ca);color:#fff}.ad-code-block{margin:0;padding:10px 12px;background:#1e1e1e;color:#d4d4d4;border-radius:var(--radius-sm);font:12px var(--font-mono);line-height:1.5;overflow-x:auto;max-height:320px;overflow-y:auto;white-space:pre}.ad-code-block code{background:none;padding:0;color:inherit;font:inherit;white-space:pre}.ad-samples{margin:14px 0}.ad-samples>strong{display:block;font:600 12px var(--font-sans);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.ad-samples-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:8px}.ad-sample{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-soft);overflow:hidden}.ad-sample-head{display:flex;align-items:center;justify-content:space-between;padding:5px 10px;background:var(--bg-muted);border-bottom:1px solid var(--border)}.ad-sample-lang{font:600 10px var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.ad-sample .ad-code-block{max-height:240px;border-radius:0}.piv-root{display:flex;flex-direction:column;height:100%;min-height:0;background:var(--bg-muted, #f3f4f6);border-radius:var(--radius-md, 8px);overflow:hidden}.piv-toolbar{display:flex;align-items:center;gap:4px;padding:6px 10px;background:var(--bg, #fff);border-bottom:1px solid var(--border, #e5e7eb);flex:0 0 auto;flex-wrap:wrap}.piv-btn{display:inline-flex;align-items:center;gap:4px;height:28px;min-width:28px;padding:0 8px;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--text, #1f2937);font:500 12px var(--font-sans, system-ui, sans-serif);cursor:pointer;transition:background .12s ease,border-color .12s ease}.piv-btn:hover:not(:disabled){background:var(--bg-soft, #f3f4f6)}.piv-btn:disabled{opacity:.4;cursor:not-allowed}.piv-btn.is-active{background:var(--accent-soft, #eef2ff);border-color:var(--accent, #4f46e5);color:var(--accent, #4f46e5)}.piv-btn-label{font-size:12px}.piv-sep{width:1px;height:18px;background:var(--border, #e5e7eb);margin:0 4px}.piv-page-indicator{display:inline-flex;align-items:center;gap:4px;font:500 12px var(--font-mono, monospace);color:var(--text-muted, #6b7280)}.piv-page-input{width:44px;height:26px;text-align:center;border:1px solid var(--border, #e5e7eb);border-radius:4px;background:var(--bg, #fff);color:var(--text, #1f2937);font:500 12px var(--font-mono, monospace)}.piv-page-input:focus{outline:2px solid var(--accent, #4f46e5);outline-offset:-1px}.piv-page-total{font:500 12px var(--font-mono, monospace);color:var(--text-muted, #6b7280)}.piv-zoom-readout{display:inline-block;min-width:42px;text-align:center;font:500 11px var(--font-mono, monospace);color:var(--text-muted, #6b7280)}.piv-stage{flex:1 1 auto;min-height:0;display:flex;align-items:flex-start;justify-content:center;padding:16px;overflow:auto;background:var(--bg-muted, #f3f4f6)}.piv-canvas{display:block;max-width:100%;height:auto;background:#fff;box-shadow:0 1px 3px #00000014,0 4px 12px #0000000f;border-radius:2px;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.piv-skeleton{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 20px;min-height:220px;color:var(--text-muted, #6b7280);font:500 13px var(--font-sans, system-ui, sans-serif)}.piv-spin{animation:piv-spin .9s linear infinite;color:var(--accent, #4f46e5)}@keyframes piv-spin{to{transform:rotate(360deg)}}.piv-error{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 20px;min-height:220px;color:var(--danger, #b91c1c);font:500 13px var(--font-sans, system-ui, sans-serif)}.piv-error p{margin:0;max-width:360px;text-align:center}.piv-empty{display:flex;align-items:center;justify-content:center;height:100%;min-height:200px;color:var(--text-muted, #6b7280);font:500 13px var(--font-sans, system-ui, sans-serif)}@media(prefers-reduced-motion:reduce){.piv-spin{animation:none}}@media(max-width:640px){.piv-btn-label{display:none}.piv-stage{padding:8px}}
