:root{--crm-blue: #2563eb;--crm-blue-dark: #1d4ed8;--crm-blue-light: #3b82f6;--crm-green: #16a34a;--crm-green-dark: #15803d;--crm-orange: #ea580c;--desk-bg: #f4f5f7;--crm-bg-page: #f4f5f7;--crm-card: #ffffff;--crm-border: #e5e7eb;--crm-text: #111827;--crm-muted: #6b7280;--crm-sidebar: #ffffff;--crm-danger: #dc2626;--crm-success: var(--crm-green);--radius: 8px;--radius-sm: 6px;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .06);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,PingFang SC,Microsoft YaHei,sans-serif;color:var(--crm-text);line-height:1.5;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--crm-bg-page)}a{color:var(--crm-blue);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit;color:inherit}.login-screen{min-height:100vh;background:var(--crm-bg-page);display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.login-screen--split{padding:2rem max(2rem,min(12vw,14rem)) 2rem clamp(1.25rem,4vw,3rem)}.login-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,4.5rem);width:100%;max-width:1120px;margin:0 auto;align-items:center}.login-col{min-width:0;display:flex}.login-col--left,.login-col--right{justify-content:center;align-items:center}.login-intro{text-align:center;max-width:32rem;width:100%}.auth-language-row{display:flex;justify-content:flex-end;margin-bottom:1rem}.auth-language-row--center{justify-content:center}.login-intro .brand-logo-img--auth{max-height:144px;max-width:min(800px,100%)}.login-logo-row{display:flex;justify-content:center;margin-bottom:1.5rem}.login-title-main{margin:0 0 .4rem;font-size:clamp(1.875rem,2.5vw,2.375rem);font-weight:600;color:var(--crm-text);line-height:1.2;letter-spacing:-.03em}.login-after-logo-placeholder{margin:0 0 .4rem;height:clamp(2.25rem,3vw,2.85rem);flex-shrink:0}.login-tagline-en{margin:0 0 .75rem;font-size:clamp(2.125rem,2.7vw,2.5rem);font-weight:500;font-style:italic;color:var(--crm-muted);letter-spacing:.02em;line-height:1.3}.login-title-sub{margin:0 0 1.25rem;font-size:clamp(1.0625rem,1.2vw,1.1875rem);color:var(--crm-muted);font-weight:400;line-height:1.55}@media(max-width:840px){.login-split{grid-template-columns:1fr;gap:2.5rem;max-width:440px}.login-col--left{order:1}.login-col--right{order:2}.login-intro .brand-logo-img--auth{max-height:128px}.login-auth-card{transform:none}}.login-center{width:100%;max-width:480px;text-align:center}.auth-card-white{width:100%;background:var(--crm-card);border-radius:var(--radius);box-shadow:var(--shadow-xs);padding:1.75rem 1.75rem 1.5rem;border:1px solid var(--crm-border);text-align:left}.login-auth-card{width:100%;max-width:440px;padding:2rem 2rem 1.75rem;transform:translate(50%)}.auth-card-heading{margin:0 0 1.35rem;font-size:clamp(1.1875rem,1.4vw,1.375rem);font-weight:600;color:var(--crm-text);text-align:center;letter-spacing:-.02em}.login-auth-card .input-row{margin-bottom:1.05rem}.login-auth-card .input-row input{padding:.85rem 0;font-size:1.0625rem}.login-captcha-input-wrap{margin-bottom:0}.login-auth-card .captcha-row{margin-bottom:1.05rem}.input-row{display:flex;align-items:center;gap:.65rem;border:1px solid var(--crm-border);border-radius:var(--radius-sm);padding:0 .85rem;margin-bottom:1rem;background:#fafafa;transition:border-color .12s ease}.input-row:focus-within{border-color:var(--crm-blue);box-shadow:0 0 0 2px #2563eb1a}.input-row .input-icon{color:#90a4b8;flex-shrink:0}.input-row input{flex:1;min-width:0;border:none;background:transparent;padding:.75rem 0;outline:none}.input-row input::placeholder{color:#9aa8b8}.captcha-row{display:flex;gap:.65rem;align-items:stretch;margin-bottom:1rem}.captcha-row .input-row{flex:1;margin-bottom:0}.captcha-box{display:flex;align-items:center;gap:.5rem;padding:0 .85rem;background:#f3f4f6;border:1px solid var(--crm-border);border-radius:var(--radius-sm);font-weight:600;font-size:1.125rem;letter-spacing:.15em;color:var(--crm-text);-webkit-user-select:none;user-select:none}.captcha-refresh{border:1px solid var(--crm-border);background:#fff;border-radius:var(--radius-sm);width:44px;height:44px;flex-shrink:0;cursor:pointer;color:var(--crm-muted);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-xs)}.captcha-refresh:hover{background:#f9fafb;color:var(--crm-text)}.btn-login-main{width:100%;padding:.875rem 1rem;border:1px solid var(--crm-blue-dark);border-radius:var(--radius-sm);background:var(--crm-blue);color:#fff;font-size:1.0625rem;font-weight:600;cursor:pointer;box-shadow:var(--shadow-xs);margin-top:.25rem}.btn-login-main:hover{background:var(--crm-blue-dark)}.auth-footer{display:flex;justify-content:space-between;align-items:center;margin-top:1.25rem;font-size:1.0625rem;text-align:center}.auth-footer a{font-size:inherit}.login-auth-footer{justify-content:center;gap:2rem;margin-top:1.5rem;font-size:1.0625rem}.auth-footer .muted-link{color:var(--crm-muted)}.auth-footer .muted-link:hover{color:var(--crm-blue)}.link-button{background:transparent;border:none;padding:0;font:inherit;cursor:pointer}.error{color:var(--crm-danger);font-size:.9375rem;margin:0 0 .75rem}.login-auth-card .error{font-size:1rem}.desk-root{display:flex;flex-direction:column;min-height:100vh;background:var(--desk-bg)}.desk-header{height:52px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem;background:#fff;border-bottom:1px solid var(--crm-border)}.desk-header-left{display:flex;align-items:center;gap:.75rem}.desk-header-right{display:flex;align-items:center;gap:1rem}.desk-header-link{display:inline-flex;align-items:center;padding:.48rem .9rem;border-radius:999px;border:1px solid #dbe7f3;background:#f8fbff;color:#334155;text-decoration:none;font-size:.82rem;font-weight:700;transition:border-color .16s ease,background .16s ease,color .16s ease,box-shadow .16s ease}.desk-header-link:hover{border-color:#93c5fd;color:#1d4ed8;box-shadow:0 8px 18px #3b82f61f}.desk-header-link--active{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#60a5fa;color:#1d4ed8}.language-switcher{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem;border:1px solid var(--crm-border);border-radius:999px;background:#fafafa}.language-switcher__button{border:none;background:transparent;color:var(--crm-muted);padding:.3rem .65rem;border-radius:999px;cursor:pointer}.language-switcher__button:hover{color:var(--crm-text)}.language-switcher__button--active{background:#fff;color:var(--crm-text);box-shadow:var(--shadow-xs)}.language-switcher--compact .language-switcher__button{font-size:.8125rem;padding:.2rem .55rem}.desk-header-icon{width:36px;height:36px;border:1px solid var(--crm-border);border-radius:var(--radius-sm);background:#fafafa;color:var(--crm-muted);cursor:pointer;display:flex;align-items:center;justify-content:center}.desk-header-icon:hover{background:#f3f4f6;color:var(--crm-text);border-color:#d1d5db}.desk-user{display:flex;align-items:center;gap:.6rem;font-size:.9rem;color:var(--crm-text)}.desk-user-avatar{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--crm-blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem}.desk-body{display:flex;flex:1;min-height:0}@media(max-width:768px){.desk-body{flex-direction:column}.app-sidebar{width:100%!important;flex-direction:row;flex-wrap:wrap}.app-sidebar .nav-links{display:flex;flex-wrap:wrap;width:100%}}.app-sidebar{width:220px;flex-shrink:0;background:var(--crm-sidebar);color:var(--crm-text);padding:1rem .6rem;display:flex;flex-direction:column;gap:.125rem;border-right:1px solid var(--crm-border);transition:width .15s ease}.app-sidebar-head{position:relative;display:flex;align-items:center;justify-content:center;margin:0 .5rem .65rem;padding:.4rem 2.75rem .65rem .4rem;border-bottom:1px solid var(--crm-border);min-height:2.85rem}.app-sidebar-head--collapsed{justify-content:center;margin-left:0;margin-right:0;padding:0 0 .65rem;min-height:0}.app-sidebar-head .app-brand{margin:0 auto;padding:0;border:none;flex:1 1 auto;min-width:0;text-align:center;font-size:calc(1.375rem * 2 / 3);font-weight:600;line-height:1.2;color:var(--crm-muted);letter-spacing:.04em}.app-sidebar-toggle{position:absolute;right:.35rem;top:50%;transform:translateY(-50%);flex-shrink:0;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid var(--crm-border);border-radius:var(--radius-sm);background:#fafafa;color:var(--crm-muted);cursor:pointer;padding:0}.app-sidebar-head--collapsed .app-sidebar-toggle{position:static;transform:none}.app-sidebar-toggle:hover{background:#f3f4f6;color:var(--crm-text);border-color:#d1d5db}@media(min-width:769px){.app-sidebar--collapsed{width:3.75rem;padding-left:.35rem;padding-right:.35rem}.app-sidebar--collapsed .nav-link{justify-content:center;padding:.55rem .25rem}.app-sidebar--collapsed .nav-link svg{width:40px;height:40px}.app-sidebar--collapsed .nav-link-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-sidebar--collapsed .nav-link{position:relative}}.app-brand{font-size:.6875rem;font-weight:600;line-height:1.35;color:var(--crm-muted);letter-spacing:.04em}.nav-link{display:flex;align-items:center;gap:.5rem;padding:.5rem .65rem;border-radius:var(--radius-sm);color:var(--crm-text);font-size:.8125rem}.nav-link svg{opacity:.7;flex-shrink:0}.nav-link-label{min-width:0}.nav-link:hover{background:#f3f4f6;color:var(--crm-text);text-decoration:none}.nav-link:hover svg{opacity:.85}.nav-link.active{background:#eff6ff;color:var(--crm-blue-dark);font-weight:600}.nav-link.active svg{opacity:1}.app-sidebar-footer{margin-top:auto;padding-top:1rem;border-top:1px solid var(--crm-border);font-size:.75rem;color:var(--crm-muted)}.app-main{flex:1;padding:1.5rem 1.75rem 2rem;overflow:auto;min-width:0}.workspace-columns{display:flex;gap:1rem;align-items:stretch;min-height:calc(100vh - 56px - 3rem)}.pane-list{width:300px;flex-shrink:0;background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);display:flex;flex-direction:column;max-height:calc(100vh - 88px);overflow:hidden}.pane-list-header{padding:1rem 1rem .35rem;font-size:.72rem;font-weight:700;letter-spacing:.06em;color:var(--crm-muted)}.pane-list-tools{display:flex;gap:.5rem;padding:.5rem 1rem .85rem;align-items:center}.pane-search{flex:1;display:flex;align-items:center;gap:.45rem;border:1px solid var(--crm-border);border-radius:var(--radius-sm);padding:0 .65rem;background:#f7f9fc}.pane-search input{border:none;background:transparent;flex:1;min-width:0;padding:.5rem 0;outline:none;font-size:.9rem}.btn-add-green{width:40px;height:40px;flex-shrink:0;border:1px solid var(--crm-green-dark);border-radius:var(--radius-sm);background:var(--crm-green);color:#fff;font-size:1.35rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-xs)}.btn-add-green:hover{background:var(--crm-green-dark)}.pane-list-scroll{overflow-y:auto;flex:1;border-top:1px solid var(--crm-border)}.pane-list-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;cursor:pointer;border-bottom:1px solid #f0f2f5;text-align:left;width:100%;border-left:3px solid transparent;background:#fff;font:inherit;color:inherit}.pane-list-item:hover{background:#f5f9ff}.pane-list-item.active{background:#e8f2ff;border-left-color:var(--crm-blue)}.pane-avatar{width:40px;height:40px;border-radius:var(--radius-sm);background:#e5e7eb;color:var(--crm-text);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.pane-item-title{font-weight:600;font-size:.92rem;color:var(--crm-text)}.pane-item-sub{font-size:.78rem;color:var(--crm-muted);margin-top:.15rem}.pane-detail{flex:1;background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);box-shadow:var(--shadow-xs);padding:1.35rem 1.5rem;min-width:0}.tabs-bar{display:flex;gap:1.25rem;border-bottom:1px solid var(--crm-border);margin-bottom:1.25rem}.tabs-bar button{background:none;border:none;padding:.6rem 0;color:var(--crm-muted);font-weight:700;font-size:.72rem;letter-spacing:.08em;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tabs-bar button.active{color:var(--crm-blue);border-bottom-color:var(--crm-blue)}.section-cap{font-size:.7rem;font-weight:700;letter-spacing:.1em;color:var(--crm-muted);text-transform:uppercase;margin:0 0 1rem}.form-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem 1.25rem}.shell-card{background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);box-shadow:var(--shadow-xs);padding:1.25rem 1.4rem}@media(max-width:960px){.workspace-columns{flex-direction:column}.pane-list{width:100%;max-height:320px}.form-grid-2{grid-template-columns:1fr}}.card{background:var(--crm-card);border:1px solid var(--crm-border);border-radius:var(--radius);padding:1.15rem 1.35rem;box-shadow:var(--shadow-xs)}.grid-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1rem;margin-bottom:1.5rem}.stat{font-size:1.65rem;font-weight:700;color:var(--crm-blue-dark)}.stat-label{font-size:.82rem;color:var(--crm-muted)}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{text-align:left;padding:.7rem .6rem;border-bottom:1px solid var(--crm-border)}th{color:var(--crm-muted);font-weight:600;font-size:.82rem}tbody tr:hover td{background:#f9fafb}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.5rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--crm-border);background:#fff;color:var(--crm-text);cursor:pointer}.btn:hover{border-color:var(--crm-blue-light);color:var(--crm-blue-dark)}.btn:disabled{background:#e5e7eb;border-color:#d1d5db;color:#94a3b8;cursor:not-allowed}.btn:disabled:hover{background:#e5e7eb;border-color:#d1d5db;color:#94a3b8}.input-plain{border:1px solid var(--crm-border);border-radius:var(--radius-sm);padding:.5rem .75rem;background:#fff}.input-plain:focus{outline:none;border-color:var(--crm-blue);box-shadow:0 0 0 2px #1d6fe526}.btn-primary{background:var(--crm-blue);border-color:var(--crm-blue-dark);color:#fff}.btn-primary:hover{background:var(--crm-blue-dark);color:#fff}.btn-success{background:var(--crm-green);border-color:var(--crm-green-dark);color:#fff}.btn-success:hover{filter:brightness(1.08);color:#fff}.btn-danger{background:var(--crm-danger);border-color:#b91c1c;color:#fff}.btn-danger:hover{background:#b91c1c;border-color:#991b1b;color:#fff}.keys-icon-danger-btn{padding:.45rem;min-width:2.25rem;min-height:2.25rem}.keys-icon-danger-btn svg{display:block}.btn-ghost{background:transparent;border-color:var(--crm-border);color:var(--crm-muted)}.btn-ghost:hover{background:#f9fafb;color:var(--crm-text);border-color:#d1d5db}.btn.btn-header-ghost{background:transparent;color:var(--crm-muted);padding:.375rem .65rem;font-size:.8125rem}.btn.btn-header-ghost:hover{background:#f9fafb;color:var(--crm-text);border-color:#d1d5db}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.field label{font-size:.8rem;color:var(--crm-muted);font-weight:500}.field input,.field select,.field textarea{padding:.55rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--crm-border);background:#fafcfe}.field textarea{min-height:88px;resize:vertical}.page-title{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.page-title h2{margin:0;font-size:1.35rem;color:var(--crm-text);font-weight:700}.badge{display:inline-block;padding:.15rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500;background:#eff6ff;color:var(--crm-blue-dark);border:1px solid #dbeafe}.badge.badge-success{background:#f0fdf4;color:var(--crm-green-dark);border-color:#bbf7d0}.badge.badge-warn{background:#fff7ed;color:#c2410c;border-color:#fed7aa}.data-table-wrap{background:var(--crm-card);border:1px solid var(--crm-border);border-radius:var(--radius);overflow:auto}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th,.data-table td{padding:.65rem .85rem;text-align:left;border-bottom:1px solid var(--crm-border)}.data-table th{font-weight:600;color:var(--crm-muted);font-size:.78rem;background:#fafbfc}.mini-bar{height:8px;border-radius:4px;background:var(--crm-border);overflow:hidden}.mini-bar>span{display:block;height:100%;background:var(--crm-blue);border-radius:4px}.kanban{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.5rem}.kanban-col{min-width:240px;background:#f5f9fd;border:1px solid var(--crm-border);border-radius:var(--radius);padding:.85rem}.kanban-col h3{margin:0 0 .75rem;font-size:.85rem;color:var(--crm-muted);font-weight:600}.kanban-card{background:var(--crm-card);border:1px solid var(--crm-border);border-radius:var(--radius-sm);padding:.65rem .75rem;margin-bottom:.5rem;cursor:grab;box-shadow:0 1px 4px #0000000a}.kanban-card:active{cursor:grabbing}.muted{color:var(--crm-muted);font-size:.88rem}.timeline{border-left:2px solid var(--crm-border);margin-left:.5rem;padding-left:1rem}.timeline-item{margin-bottom:1rem;position:relative}.timeline-item:before{content:"";position:absolute;left:-1.2rem;top:.35rem;width:8px;height:8px;border-radius:50%;background:var(--crm-blue)}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--desk-bg);color:var(--crm-muted)}.saas-main{width:100%;max-width:none;margin:0}.saas-page{padding-bottom:2rem}.saas-page .page-title h2{margin-bottom:.25rem}.saas-subtitle{margin:0;line-height:1.45}.saas-tenant-pill{font-size:.8125rem;padding:.2rem .55rem;border:1px solid var(--crm-border);border-radius:6px;background:#fafafa;color:var(--crm-muted)}.saas-card{background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);box-shadow:0 1px 2px #0f172a0d}.saas-card-pad{padding:1.25rem 1.35rem}.saas-card-head{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin-bottom:1rem}.saas-card-title{font-weight:700;font-size:1rem;color:var(--crm-text)}.saas-balance{font-weight:500}.saas-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem}@media(max-width:900px){.saas-grid-2{grid-template-columns:1fr}}.saas-stat-card{box-shadow:0 1px 2px #0f172a0d!important;border-radius:var(--radius)}.saas-stat-em{color:var(--crm-green-dark)}ul.saas-chart{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}.saas-chart-row{display:grid;grid-template-columns:52px 1fr 72px;align-items:center;gap:.65rem;font-size:.82rem}.saas-chart-label{color:var(--crm-muted);font-variant-numeric:tabular-nums}.saas-chart-bar-wrap{height:10px;background:#eef1f6;border-radius:5px;overflow:hidden}.saas-chart-bar{height:100%;border-radius:4px;background:var(--crm-blue);min-width:4px}.saas-chart-val{text-align:right;font-variant-numeric:tabular-nums;color:var(--crm-text)}.saas-table-wrap{box-shadow:0 1px 2px #0f172a0d;border-radius:var(--radius)}.saas-table-embed{border-radius:var(--radius-sm)}.saas-code{font-size:.78rem;background:#f1f5f9;padding:.12rem .35rem;border-radius:4px;border:1px solid var(--crm-border)}.saas-pre{margin-top:1rem;padding:.85rem;background:#f8fafc;border:1px solid var(--crm-border);border-radius:var(--radius-sm);font-size:.78rem;overflow:auto;max-height:280px}.badge.badge-muted{background:#f1f5f9;color:var(--crm-muted)}.muted-sm{font-size:.82rem;color:var(--crm-muted)}.nowrap{white-space:nowrap}.tabular-nums{font-variant-numeric:tabular-nums}.mini-bar-soft>span{background:#6ba3f5}.dash-page{padding:0 0 2.5rem;width:100%;max-width:none;margin:0}.dash-pad{padding:.5rem 0}.dash-header{margin-bottom:1.5rem}.dash-title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:var(--crm-text);margin:0 0 .35rem}.dash-subtitle{font-size:.88rem;margin:0}.dash-plan{display:inline-block;margin-left:.5rem;padding:.12rem .45rem;font-size:.72rem;font-weight:600;color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;vertical-align:middle}.dash-kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:1.75rem}.dash-kpi{background:#fff;border-radius:var(--radius);border:1px solid var(--crm-border);box-shadow:var(--shadow-xs);padding:1.25rem 1.35rem;min-height:104px}.dash-kpi:hover{border-color:#d1d5db}.dash-kpi--blue{border-top:3px solid #2563eb}.dash-kpi--green{border-top:3px solid #22c55e;background:#fff}.dash-kpi-label{font-size:.8rem;font-weight:500;margin-bottom:.5rem;color:#64748b}.dash-kpi--green .dash-kpi-label{color:#15803d}.dash-kpi-value{font-size:1.32rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:#1e293b}.dash-kpi-value--green{color:#166534}.dash-kpi-unit{margin-left:.35rem;font-size:.72rem;font-weight:600;color:#94a3b8;vertical-align:middle}.dash-kpi-hint{margin-top:.4rem;font-size:.72rem;color:var(--crm-muted);line-height:1.35}.dash-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.75rem}@media(max-width:900px){.dash-grid-2{grid-template-columns:1fr}}.dash-card{background:#fff;border-radius:var(--radius);border:1px solid var(--crm-border);box-shadow:var(--shadow-xs);padding:1.25rem 1.35rem;margin-bottom:1.75rem}.dash-card:last-child{margin-bottom:0}.dash-grid-2 .dash-card{margin-bottom:0}.dash-card-title{font-size:.95rem;font-weight:600;color:var(--crm-text);margin:0 0 .35rem}.dash-card-desc{font-size:.78rem;margin:0 0 1rem}.dash-card--risks{border-left:3px solid #ea580c;background:#fff}.dash-chart-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.85rem}.dash-chart-item{display:grid;grid-template-columns:minmax(3.2rem,auto) 1fr minmax(4.5rem,auto);gap:.75rem;align-items:center}.dash-chart-date,.dash-chart-model{font-size:.78rem;color:#64748b;font-variant-numeric:tabular-nums;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-chart-model{color:var(--crm-text);font-variant-numeric:normal}.dash-chart-track{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;min-width:0}.dash-chart-fill{height:100%;border-radius:4px;min-width:2px}.dash-chart-fill--blue{background:#2563eb}.dash-chart-fill--indigo{background:#4f46e5}.dash-chart-num{font-size:.78rem;font-variant-numeric:tabular-nums;color:#475569;text-align:right}.dash-risk-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.dash-risk{padding:.75rem .85rem;border-radius:var(--radius-sm);border:1px solid var(--crm-border);background:#fff}.dash-risk--info{border-left:3px solid #94a3b8}.dash-risk--warning{border-left:3px solid #ea580c;background:#fff7edd9;border-color:#fed7aa}.dash-risk--critical{border-left:3px solid #dc2626;background:#fef2f2bf;border-color:#fecaca}.dash-risk-title{font-size:.84rem;font-weight:600;color:var(--crm-text);margin:0 0 .25rem}.dash-risk-detail{font-size:.77rem;line-height:1.45;margin:0}.dash-table-wrap{border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--crm-border);margin-top:.25rem}.dash-table{width:100%;border-collapse:collapse;font-size:.82rem;background:#fff}.dash-table thead th{text-align:left;padding:.65rem .85rem;background:#f8fafc;color:#64748b;font-size:.74rem;font-weight:600;border-bottom:1px solid var(--crm-border)}.dash-table tbody td{padding:.65rem .85rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.dash-table tbody tr:last-child td{border-bottom:none}.dash-table tbody tr:hover{background:#fafbfc}.dash-td-time{font-variant-numeric:tabular-nums;font-size:.78rem;color:#64748b;white-space:nowrap}.dash-td-num{font-variant-numeric:tabular-nums}.dash-code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.76rem;padding:.12rem .35rem;background:#f1f5f9;border-radius:4px;border:1px solid #e2e8f0}.dash-badge{display:inline-block;padding:.15rem .45rem;font-size:.7rem;font-weight:600;border-radius:999px;background:#f1f5f9;color:#64748b}.dash-badge--ok{background:#dcfce7;color:#166534}.brand-logo-img{display:block;height:auto;width:auto;object-fit:contain;flex-shrink:0}.brand-logo-img--header{max-height:68px;max-width:400px}.desk-header .brand-logo-img--header{max-height:45px;max-width:267px}@media(max-width:480px){.brand-logo-img--header{max-height:56px;max-width:320px}.desk-header .brand-logo-img--header{max-height:37px;max-width:213px}}.brand-logo-img--auth{max-height:112px;max-width:min(680px,88vw);margin:0 auto}.keys-page{width:100%;max-width:none;margin:0;padding-bottom:2rem}.keys-page-pad{padding:.5rem 0}.keys-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.keys-header-actions{display:flex;gap:.75rem;flex-wrap:wrap}.keys-title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .35rem;color:var(--crm-text)}.keys-subtitle{font-size:.88rem;margin:0;max-width:none;line-height:1.45}.keys-inline-code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78em;padding:.08rem .3rem;background:#f1f5f9;border-radius:4px;border:1px solid var(--crm-border)}.keys-table-card{background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);box-shadow:0 1px 3px #0f172a0f;overflow:hidden}.keys-table-scroll{overflow-x:auto}.keys-table{width:100%;border-collapse:collapse;font-size:.82rem;min-width:900px}.keys-table thead th{text-align:left;padding:.7rem .9rem;background:#f8fafc;color:#64748b;font-size:.74rem;font-weight:600;border-bottom:1px solid var(--crm-border);white-space:nowrap}.keys-table tbody td{padding:.65rem .9rem;border-bottom:1px solid #f1f5f9;vertical-align:middle;color:var(--crm-text)}.keys-table tbody tr:hover{background:#fafbfc}.keys-table tbody tr:last-child td{border-bottom:none}.keys-table-empty{text-align:center;padding:2rem 1rem!important}.keys-td-strong{font-weight:600}.keys-td-models{max-width:5rem}.keys-td-time{font-size:.78rem;color:#64748b;font-variant-numeric:tabular-nums;white-space:nowrap}.keys-mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.76rem;color:#475569}.keys-badge{display:inline-block;padding:.14rem .5rem;font-size:.68rem;font-weight:600;border-radius:999px}.keys-badge--ok{background:#dcfce7;color:#166534}.keys-badge--off{background:#f1f5f9;color:#64748b}.keys-badge--revoked{background:#ffedd5;color:#c2410c}.keys-switch{position:relative;display:inline-flex;align-items:center;cursor:pointer}.keys-switch input{position:absolute;opacity:0;width:0;height:0}.keys-switch-ui{width:2.25rem;height:1.2rem;background:#cbd5e1;border-radius:999px;transition:background .15s;position:relative}.keys-switch-ui:after{content:"";position:absolute;width:.95rem;height:.95rem;background:#fff;border-radius:50%;top:.125rem;left:.15rem;transition:transform .15s;box-shadow:0 1px 2px #0f172a26}.keys-switch input:checked+.keys-switch-ui{background:#2563eb}.keys-switch input:checked+.keys-switch-ui:after{transform:translate(1rem)}.keys-switch input:disabled+.keys-switch-ui{opacity:.45}.keys-details{margin-top:1.75rem;padding:1rem 1.15rem;background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius)}.keys-details summary{cursor:pointer;font-weight:600;font-size:.88rem;color:var(--crm-text)}.keys-details-hint{margin:.65rem 0 .85rem;font-size:.8rem}.keys-play-grid{display:flex;flex-direction:column;gap:.65rem}.keys-play-row{display:flex;flex-wrap:wrap;gap:.65rem;align-items:center}.keys-play-row .input-plain{min-width:160px;flex:1}.keys-play-message{resize:vertical;min-height:5.5rem;font-family:inherit;line-height:1.55}.keys-pre{margin-top:.75rem;padding:.85rem;background:#f8fafc;border:1px solid var(--crm-border);border-radius:var(--radius-sm);font-size:.75rem;overflow:auto;max-height:260px}.keys-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:80;display:flex;align-items:center;justify-content:center;padding:1rem}.keys-modal{background:#fff;border-radius:var(--radius);border:1px solid var(--crm-border);box-shadow:0 8px 32px #0f172a14;width:100%;max-width:440px;max-height:calc(100vh - 2rem);overflow-y:auto}.keys-modal--narrow{max-width:400px}.keys-modal-hd{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.15rem .5rem;border-bottom:1px solid #f1f5f9}.keys-modal-hd h2{margin:0;font-size:1.05rem;font-weight:700}.keys-form{padding:1rem 1.15rem 1.15rem;display:flex;flex-direction:column;gap:.85rem}.keys-field{display:flex;flex-direction:column;gap:.35rem}.keys-field-row{display:flex;gap:.75rem;flex-wrap:wrap}.keys-field--half{flex:1 1 160px}.keys-label{font-size:.78rem;font-weight:600;color:#475569}.keys-textarea{resize:vertical;min-height:3.2rem;font-family:inherit}.keys-models-list{display:flex;flex-direction:column;gap:.45rem;padding:.7rem .8rem;border:1px solid var(--crm-border);border-radius:var(--radius-sm);background:#fff;max-height:15rem;overflow-y:auto}.keys-model-option{display:flex;align-items:flex-start;gap:.55rem;font-size:.84rem;color:var(--crm-text)}.keys-model-option-text{display:flex;flex-direction:column;gap:.18rem;line-height:1.35}.keys-models-empty{padding:.7rem .8rem;border:1px dashed var(--crm-border);border-radius:var(--radius-sm);background:#f8fafc;font-size:.82rem}.keys-form-error{margin:0;font-size:.82rem}.keys-modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.35rem}.provider-delete-warning{border:1px solid rgba(220,38,38,.18);background:#fef2f2;border-radius:var(--radius-sm);padding:.85rem .95rem}.provider-delete-title{margin:0 0 .45rem;font-weight:700;color:#7f1d1d}.provider-delete-text{margin:.25rem 0 0;line-height:1.5}.keys-reveal-title{margin:0;padding:1.1rem 1.15rem 0;font-size:1.05rem}.keys-reveal-hint{margin:.5rem 1.15rem 0;font-size:.82rem}.keys-reveal-box{margin:.85rem 1.15rem 0;padding:.75rem;background:#f8fafc;border-radius:var(--radius-sm);border:1px solid var(--crm-border);overflow:auto}.keys-reveal-token{font-size:.72rem;word-break:break-all;line-height:1.45}.keys-modal--narrow .keys-modal-actions{padding:1rem 1.15rem 1.15rem}.model-hub-page{display:flex;flex-direction:column;gap:1.15rem;padding-bottom:2rem}.model-hub-hero{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(20rem,1fr);gap:1rem;padding:1.45rem;border-radius:26px;border:1px solid rgba(148,163,184,.18);background:radial-gradient(circle at top left,rgba(59,130,246,.18),transparent 28%),radial-gradient(circle at bottom right,rgba(14,165,233,.14),transparent 30%),linear-gradient(135deg,#0f172a,#172554);color:#dbeafe;box-shadow:0 16px 42px #0f172a2e}.model-hub-hero-copy{display:flex;flex-direction:column;gap:.9rem}.model-hub-kicker{display:inline-flex;width:fit-content;align-items:center;padding:.32rem .72rem;border-radius:999px;background:#3b82f624;border:1px solid rgba(125,211,252,.28);color:#bfdbfe;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.model-hub-hero h1{margin:0;font-size:2rem;letter-spacing:-.04em;color:#fff}.model-hub-hero p{margin:0;color:#dbeafeeb;line-height:1.75}.model-hub-hero-actions,.model-hub-card-actions{display:flex;flex-wrap:wrap;gap:.7rem}.model-hub-hero-actions .btn-ghost{background:#0f172a47;color:#e0f2fe;border-color:#94a3b847}.model-hub-stats{display:grid;gap:.8rem}.model-hub-stat-card{display:flex;flex-direction:column;gap:.32rem;padding:.95rem 1rem;border-radius:18px;background:#0f172a6b;border:1px solid rgba(148,163,184,.16)}.model-hub-stat-card span{font-size:.75rem;color:#93c5fd;text-transform:uppercase;letter-spacing:.08em}.model-hub-stat-card strong,.model-hub-stat-card code{color:#fff;font-size:1.2rem;letter-spacing:-.03em}.model-hub-filter-bar{display:grid;grid-template-columns:minmax(16rem,1.4fr) repeat(2,minmax(11rem,.85fr));gap:.9rem;padding:1rem 1.05rem;border-radius:22px;border:1px solid var(--crm-border);background:#ffffffeb;box-shadow:0 10px 26px #0f172a0d}.model-hub-filter-group{display:flex;flex-direction:column;gap:.4rem}.model-hub-filter-label,.model-hub-section-label{font-size:.75rem;font-weight:700;color:#64748b;letter-spacing:.04em;text-transform:uppercase}.model-hub-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.model-hub-card,.model-hub-empty,.model-hub-note-card{padding:1.15rem;border-radius:24px;border:1px solid var(--crm-border);background:#fffffff0;box-shadow:0 12px 28px #0f172a0f}.model-hub-empty{grid-column:1 / -1;text-align:center}.model-hub-card{display:flex;flex-direction:column;gap:.95rem}.model-hub-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.8rem}.model-hub-card-head h2,.model-hub-note-card h2,.model-hub-empty h2{margin:0 0 .28rem;color:#0f172a;letter-spacing:-.03em}.model-hub-provider-badge{display:inline-flex;align-items:center;padding:.34rem .62rem;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:.74rem;font-weight:700;text-transform:uppercase}.model-hub-model-id{display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.9rem .95rem;border-radius:18px;background:#f8fbff;border:1px solid #dbe7f3}.model-hub-model-id code,.model-hub-endpoint-card code{display:block;margin-top:.3rem;font-size:.8rem;color:#0f172a;word-break:break-word}.model-hub-price-grid,.model-hub-endpoint-grid,.model-hub-notes{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.model-hub-price-card,.model-hub-endpoint-card{padding:.9rem .95rem;border-radius:18px;border:1px solid #e2e8f0;background:linear-gradient(180deg,#fff,#f8fafc)}.model-hub-price-card span,.model-hub-price-card small{display:block}.model-hub-price-card span{font-size:.78rem;color:#64748b}.model-hub-price-card strong{display:block;margin:.32rem 0 .1rem;color:#0f172a;font-size:1.18rem}.model-hub-price-card small,.model-hub-endpoint-card p,.model-hub-note-card p,.model-hub-section p{color:#475569;line-height:1.68}.model-hub-pill-row{display:flex;flex-wrap:wrap;gap:.5rem}.model-hub-pill{display:inline-flex;align-items:center;padding:.34rem .68rem;border-radius:999px;background:#e0f2fe;border:1px solid #bae6fd;color:#0369a1;font-size:.75rem;font-weight:600}.model-hub-pill--subtle{background:#f1f5f9;border-color:#e2e8f0;color:#475569}.model-hub-section{display:flex;flex-direction:column;gap:.45rem}.model-hub-section p,.model-hub-note-card p{margin:0}.usage-page{width:100%;max-width:none;margin:0;padding-bottom:2rem}.usage-page-pad{padding:.5rem 0}.usage-header{margin-bottom:1.25rem}.usage-title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .35rem;color:var(--crm-text)}.usage-subtitle{font-size:.88rem;margin:0;max-width:none;line-height:1.45}.usage-filters{background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);padding:1rem 1.15rem .85rem;margin-bottom:1.25rem;box-shadow:0 1px 3px #0f172a0f}.usage-filter-grid{display:grid;grid-template-columns:minmax(220px,1.4fr) repeat(3,minmax(140px,1fr));gap:1rem 1.25rem;align-items:end}@media(max-width:960px){.model-hub-hero,.model-hub-filter-bar,.model-hub-grid,.model-hub-price-grid,.model-hub-endpoint-grid,.model-hub-notes{grid-template-columns:1fr}.usage-filter-grid{grid-template-columns:1fr 1fr}}@media(max-width:560px){.model-hub-model-id,.model-hub-card-head{flex-direction:column;align-items:stretch}.usage-filter-grid{grid-template-columns:1fr}}.usage-filter-block{display:flex;flex-direction:column;gap:.45rem}.usage-filter-field{display:flex;flex-direction:column;gap:.35rem}.usage-filter-label{font-size:.75rem;font-weight:600;color:#64748b}.usage-date-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.usage-input{min-width:0;flex:1 1 120px}.usage-date-sep{font-size:.8rem;color:var(--crm-muted)}.usage-preset-row{display:flex;flex-wrap:wrap;gap:.35rem}.usage-chip{font-size:.78rem!important;padding:.25rem .55rem!important;min-height:auto}.usage-filter-meta{margin:.75rem 0 0;font-size:.82rem}.usage-table-card{background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);box-shadow:0 1px 3px #0f172a0f;overflow:hidden}.usage-table-scroll{overflow-x:auto}.usage-table{width:100%;border-collapse:collapse;font-size:.8rem;min-width:1080px}.usage-table thead th{text-align:left;padding:.65rem .75rem;background:#f8fafc;color:#64748b;font-size:.72rem;font-weight:600;border-bottom:1px solid var(--crm-border);white-space:nowrap}.usage-table tbody td{padding:.55rem .75rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.usage-table tbody tr:last-child td{border-bottom:none}.usage-row{cursor:pointer;transition:background .12s ease}.usage-row:hover,.usage-row:focus-visible{background:#f1f5f9;outline:none}.usage-table-empty{text-align:center;padding:2rem 1rem!important}.usage-td-time{font-size:.76rem;color:#64748b;font-variant-numeric:tabular-nums;white-space:nowrap}.usage-td-name{font-weight:500;max-width:8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.usage-td-strong{font-weight:600}.usage-code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.74rem;padding:.1rem .3rem;background:#f1f5f9;border-radius:4px;border:1px solid #e2e8f0}.usage-code-sm{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.72rem;word-break:break-all}.usage-badge{display:inline-block;padding:.12rem .45rem;font-size:.65rem;font-weight:600;border-radius:999px}.usage-badge--ok{background:#dcfce7;color:#166534}.usage-badge--err{background:#fee2e2;color:#b91c1c}.usage-badge--hit{background:#dbeafe;color:#1d4ed8}.usage-badge--miss{background:#f1f5f9;color:#64748b}.usage-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;z-index:88}.usage-drawer{position:fixed;top:0;right:0;width:100%;max-width:min(640px,100%);height:100%;background:#fff;border-left:1px solid var(--crm-border);box-shadow:-4px 0 24px #0f172a0f;z-index:90;display:flex;flex-direction:column}.usage-drawer-hd{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:1rem 1.15rem;border-bottom:1px solid var(--crm-border)}.usage-drawer-hd h2{margin:0;font-size:1.05rem;font-weight:700}.usage-drawer-close{font-size:.88rem!important}.usage-drawer-body{flex:1;overflow-y:auto;padding:1rem 1.15rem 1.5rem}.usage-dl{display:grid;grid-template-columns:7.2rem 1fr;gap:.5rem .75rem;margin:0;font-size:.84rem}.usage-dl dt{margin:0;color:#64748b;font-weight:500}.usage-dl dd{margin:0;color:var(--crm-text);word-break:break-word}.usage-dl-note{margin-left:.35rem;font-size:.78rem}.admin-usage-filter-grid{grid-template-columns:minmax(260px,1.7fr) repeat(3,minmax(180px,1fr))}.admin-usage-toggle{display:flex;gap:.5rem}.admin-usage-subtle{display:inline-block;margin-top:.2rem;font-size:.75rem;color:#64748b}.admin-usage-trend-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.admin-usage-trend-card{background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);box-shadow:var(--shadow-xs);padding:1rem 1rem .85rem}.admin-usage-trend-head{display:flex;justify-content:space-between;gap:.75rem;align-items:flex-start;margin-bottom:.85rem}.admin-usage-trend-name{font-size:.84rem;font-weight:600;color:var(--crm-text);line-height:1.35}.admin-usage-trend-total{font-size:.76rem;color:#475569;white-space:nowrap}.admin-usage-trend-bars{height:120px;display:grid;grid-auto-flow:column;grid-auto-columns:minmax(8px,1fr);align-items:end;gap:.28rem}.admin-usage-trend-bar-col{height:100%;display:flex;align-items:end}.admin-usage-trend-bar-col>span{display:block;width:100%;border-radius:999px 999px 3px 3px;background:linear-gradient(180deg,#818cf8,#4f46e5);min-height:0}.admin-usage-trend-axis{margin-top:.55rem;display:flex;justify-content:space-between;font-size:.72rem;color:#64748b;font-variant-numeric:tabular-nums}.admin-usage-trend-empty{background:#fff;border:1px dashed var(--crm-border);border-radius:var(--radius);padding:1rem 1.1rem}.admin-usage-expand{min-width:4.5rem;padding:.3rem .65rem;font-size:.76rem}.admin-usage-detail-row td{background:#fbfdff}.admin-usage-detail-wrap{padding:.25rem 0}.admin-usage-detail-empty{margin:.4rem 0}.admin-usage-detail-table{width:100%;border-collapse:collapse;font-size:.78rem}.admin-usage-detail-table th{text-align:left;padding:.55rem .65rem;font-size:.7rem;color:#64748b;background:#f8fafc;border-bottom:1px solid #e2e8f0}.admin-usage-detail-table td{padding:.55rem .65rem;border-bottom:1px solid #eef2f7;vertical-align:top}.admin-usage-detail-table tr:last-child td{border-bottom:none}@media(max-width:960px){.admin-usage-filter-grid{grid-template-columns:1fr 1fr}}@media(max-width:560px){.admin-usage-filter-grid{grid-template-columns:1fr}.admin-usage-toggle{flex-wrap:wrap}}.usage-reason{display:block;margin-top:.25rem;font-size:.76rem;color:#c2410c}.usage-drawer-note{margin-top:1.25rem;padding-top:1rem;border-top:1px solid #f1f5f9}.usage-drawer-note-cap{display:block;font-size:.78rem;font-weight:600;color:#475569;margin-bottom:.35rem}.opt-page{width:100%;max-width:none;margin:0;padding-bottom:2.5rem}.opt-page-pad{padding:.5rem 0}.opt-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.25rem;flex-wrap:wrap;margin-bottom:1.5rem}.opt-header-main{flex:1;min-width:0}.opt-header--hero{padding:1.25rem 1.35rem;background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);box-shadow:var(--shadow-xs)}.opt-title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .5rem;color:var(--crm-text)}.opt-lead{margin:0 0 .5rem;font-size:.95rem;line-height:1.5;color:#334155;max-width:none}.opt-meta{margin:0;font-size:.82rem}.opt-hero-badge{flex-shrink:0;min-width:11rem;padding:1rem 1.15rem;background:#fafafa;border:1px solid var(--crm-border);border-left:3px solid #22c55e;border-radius:var(--radius);box-shadow:var(--shadow-xs);text-align:center}.opt-hero-badge-cap{display:block;font-size:.72rem;font-weight:700;color:#15803d;text-transform:uppercase;letter-spacing:.06em}.opt-hero-badge-val{display:block;font-size:1.35rem;font-weight:700;font-variant-numeric:tabular-nums;color:#166534;margin:.35rem 0;letter-spacing:-.02em}.opt-hero-badge-sub{font-size:.75rem}.opt-kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.15rem;margin-bottom:1.5rem}@media(max-width:900px){.opt-kpi-row{grid-template-columns:1fr}}.opt-kpi{background:#fff;border-radius:var(--radius);border:1px solid var(--crm-border);padding:1.2rem 1.25rem;box-shadow:var(--shadow-xs)}.opt-kpi--rate{border-top:3px solid #2563eb}.opt-kpi--tokens{border-top:3px solid #64748b}.opt-kpi--money{border-top:3px solid #22c55e}.opt-kpi-label{font-size:.8rem;font-weight:600;color:#64748b;margin-bottom:.45rem}.opt-kpi--rate .opt-kpi-label{color:#1d4ed8}.opt-kpi--money .opt-kpi-label{color:#15803d}.opt-kpi-value{font-size:1.75rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.03em;color:#1e293b;line-height:1.1}.opt-kpi--rate .opt-kpi-value{color:#1d4ed8}.opt-kpi-unit{margin-left:.2rem;font-size:1.1rem;font-weight:700}.opt-kpi-value--tokens{font-size:1.65rem}.opt-kpi-value--money{font-size:1.75rem;color:#166534}.opt-money-sym{font-size:1.2rem;margin-right:.12rem;opacity:.9}.opt-kpi-foot{margin-top:.5rem;font-size:.76rem;line-height:1.4}.opt-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.5rem;align-items:stretch}@media(max-width:960px){.opt-grid-2{grid-template-columns:1fr}}.opt-card{background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);padding:1.15rem 1.25rem;box-shadow:var(--shadow-xs)}.opt-card--form{border-left:3px solid #2563eb}.opt-card-hd{margin-bottom:1rem}.opt-card-title{font-size:.98rem;font-weight:700;margin:0 0 .35rem;color:var(--crm-text)}.opt-card-desc{margin:0;font-size:.8rem;line-height:1.45}.opt-table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid #f1f5f9}.opt-table{width:100%;border-collapse:collapse;font-size:.8rem}.opt-table thead th{text-align:left;padding:.6rem .75rem;background:#f8fafc;color:#64748b;font-size:.72rem;font-weight:600;border-bottom:1px solid var(--crm-border);white-space:nowrap}.opt-table tbody td{padding:.55rem .75rem;border-bottom:1px solid #f1f5f9;vertical-align:top}.opt-table tbody tr:last-child td{border-bottom:none}.opt-td-preview{max-width:280px;line-height:1.4;color:var(--crm-text)}.opt-td-em{font-weight:600;color:#15803d}.opt-pill{display:inline-block;padding:.1rem .45rem;font-size:.65rem;font-weight:600;border-radius:999px}.opt-pill--db{background:#dbeafe;color:#1d4ed8}.opt-template-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem;max-height:520px;overflow-y:auto}.opt-template-item{padding:.85rem .9rem;border:1px solid #f1f5f9;border-radius:var(--radius-sm);background:#fafbfc}.opt-template-top{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;margin-bottom:.35rem}.opt-template-name{font-weight:700;font-size:.88rem}.opt-template-saved{flex-shrink:0;font-size:.78rem;font-weight:700;color:#166534;font-variant-numeric:tabular-nums}.opt-template-desc{margin:0 0 .45rem;font-size:.78rem}.opt-template-snippet{margin:0;padding:.55rem .65rem;background:#fff;border:1px solid var(--crm-border);border-radius:6px;font-size:.72rem;line-height:1.45;white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:#475569;max-height:6.5rem;overflow:auto}.opt-template-foot{margin-top:.35rem;font-size:.72rem}.opt-form{display:flex;flex-direction:column;gap:1.1rem;max-width:420px}.opt-field{display:flex;flex-direction:column;gap:.35rem}.opt-form-label{font-size:.82rem;font-weight:600;color:#475569}.opt-switch-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.opt-switch{position:relative;display:inline-flex;cursor:pointer}.opt-switch input{position:absolute;opacity:0;width:0;height:0}.opt-switch-ui{width:2.35rem;height:1.25rem;background:#cbd5e1;border-radius:999px;position:relative;transition:background .15s}.opt-switch-ui:after{content:"";position:absolute;width:1rem;height:1rem;background:#fff;border-radius:50%;top:.125rem;left:.15rem;transition:transform .15s;box-shadow:0 1px 2px #0f172a1f}.opt-switch input:checked+.opt-switch-ui{background:#2563eb}.opt-switch input:checked+.opt-switch-ui:after{transform:translate(1.05rem)}.opt-range{width:100%;accent-color:#2563eb}.opt-threshold-val{color:#1d4ed8;font-variant-numeric:tabular-nums}.opt-hint{font-size:.75rem}.opt-form-actions{margin-top:.25rem}.rt-page{width:100%;max-width:none;margin:0;padding-bottom:2.5rem}.rt-page-pad{padding:.5rem 0}.rt-header{margin-bottom:1.35rem}.rt-title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .4rem;color:var(--crm-text)}.rt-lead{margin:0;font-size:.88rem;line-height:1.45;max-width:none}.rt-card{background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);padding:1.15rem 1.25rem;margin-bottom:1.25rem;box-shadow:var(--shadow-xs)}.rt-card--strategy{border-top:3px solid #4f46e5}.rt-card-hd{margin-bottom:1rem}.rt-card-title{font-size:.98rem;font-weight:700;margin:0 0 .35rem;color:var(--crm-text)}.rt-card-desc{margin:0;font-size:.8rem;line-height:1.45}.rt-mode-row{display:flex;flex-wrap:wrap;gap:.65rem}.rt-mode-pill{flex:1 1 140px;max-width:200px;display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;padding:.65rem .85rem;border-radius:var(--radius-sm);border:1px solid var(--crm-border);background:#fff;cursor:pointer;text-align:left;transition:border-color .12s ease;font:inherit}.rt-mode-pill:hover:not(:disabled){border-color:#c7d2fe}.rt-mode-pill:disabled{opacity:.55;cursor:not-allowed}.rt-mode-pill--active{border-color:#4f46e5;background:#eef2ff}.rt-mode-label{font-size:.88rem;font-weight:700;color:var(--crm-text)}.rt-mode-sub{font-size:.72rem;color:#64748b}.rt-strategy-hint{margin:.85rem 0 0;font-size:.78rem}.rt-strategy-err{margin:.65rem 0 0;font-size:.82rem}.rt-chain-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.rt-chain-card{padding:.85rem 1rem;border:1px solid #e2e8f0;border-radius:var(--radius-sm);background:#fafbfc}.rt-chain-cap{font-weight:700;font-size:.88rem;margin-bottom:.35rem;color:#312e81}.rt-chain-desc{margin:0 0 .65rem;font-size:.76rem;line-height:1.4}.rt-chain-track{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .25rem;line-height:1.5}.rt-chain-step-wrap{display:inline-flex;align-items:center;gap:.25rem}.rt-chain-arrow{color:#6366f1;font-weight:700;font-size:.95rem;margin:0 .1rem}.rt-chain-step{display:inline-block;padding:.25rem .5rem;font-size:.74rem;font-weight:600;background:#fff;border:1px solid #c7d2fe;border-radius:6px;color:#3730a3}.rt-table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid #f1f5f9}.rt-table{width:100%;border-collapse:collapse;font-size:.82rem}.rt-table thead th{text-align:left;padding:.65rem .75rem;background:#f8fafc;color:#64748b;font-size:.72rem;font-weight:600;border-bottom:1px solid var(--crm-border);white-space:nowrap}.rt-table tbody td{padding:.55rem .75rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.rt-table tbody tr:last-child td{border-bottom:none}.rt-table--compact tbody td{padding:.45rem .65rem;font-size:.78rem}.rt-priority{font-weight:800;font-variant-numeric:tabular-nums;color:#4f46e5;width:3rem}.rt-td-name{font-weight:600}.rt-td-score{font-weight:600;color:#047857}.rt-td-rate{font-weight:600;color:#1d4ed8}.rt-code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.74rem;padding:.1rem .35rem;background:#f1f5f9;border-radius:4px;border:1px solid #e2e8f0}.rt-badge{display:inline-block;padding:.12rem .45rem;font-size:.65rem;font-weight:600;border-radius:999px}.rt-badge--ok{background:#dcfce7;color:#166534}.rt-badge--warn{background:#ffedd5;color:#c2410c}.rt-badge--muted{background:#f1f5f9;color:#64748b}.rt-route-bars{display:flex;flex-direction:column;gap:.85rem}.rt-route-item{padding:.65rem .75rem;border:1px solid #f1f5f9;border-radius:var(--radius-sm);background:#fafbfc}.rt-route-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.4rem}.rt-route-slug{font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.04em;color:#4338ca}.rt-route-count{font-size:.78rem;font-variant-numeric:tabular-nums;color:#64748b}.rt-route-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.rt-route-bar>span{display:block;height:100%;border-radius:4px;background:#4f46e5;min-width:4px}.rt-route-reason{display:block;margin-top:.35rem;font-size:.72rem;color:#c2410c}.rt-route-sub{font-size:.72rem;margin-top:.35rem;display:inline-block}.rt-td-time{font-size:.76rem;color:#64748b;font-variant-numeric:tabular-nums;white-space:nowrap}.rt-reason{font-size:.72rem;color:#9a3412;word-break:break-word}.rt-empty{text-align:center;padding:1.25rem 1rem!important}.bill-page{width:100%;max-width:none;margin:0;padding-bottom:2.5rem}.bill-page-pad{padding:.5rem 0}.bill-hero{margin-bottom:1.5rem;padding:1.35rem 1.5rem;border-radius:var(--radius);background:#fff;color:var(--crm-text);border:1px solid var(--crm-border);box-shadow:var(--shadow-xs)}.bill-hero-text{max-width:none}.bill-title{margin:0 0 .4rem;font-size:1.25rem;font-weight:600;letter-spacing:-.02em;color:var(--crm-text)}.bill-subtitle{margin:0;font-size:.875rem;color:var(--crm-muted);line-height:1.45}.bill-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.75rem}.bill-kpi{background:#fff;border-radius:var(--radius);border:1px solid var(--crm-border);padding:1.1rem 1.15rem;box-shadow:var(--shadow-xs);position:relative;overflow:hidden}.bill-kpi:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:#d1d5db}.bill-kpi--spend:before{background:#2563eb}.bill-kpi--bal:before{background:#4f46e5}.bill-kpi--usage:before{background:#7c3aed}.bill-kpi--save:before{background:#16a34a}.bill-kpi-label{font-size:.75rem;font-weight:600;color:#64748b;margin-bottom:.4rem}.bill-kpi-value{font-size:1.25rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:#0f172a}.bill-kpi-value--bal{color:#3730a3}.bill-kpi-value--save{color:#166534}.bill-kpi-hint{margin-top:.4rem;font-size:.72rem;line-height:1.35}.bill-section{margin-bottom:1.75rem}.bill-section--table{margin-bottom:0}.bill-section-title{font-size:1rem;font-weight:700;margin:0 0 .35rem;color:var(--crm-text)}.bill-section-desc{margin:0 0 1rem;font-size:.82rem;line-height:1.45}.bill-current-wrap{max-width:min(520px,100%)}.bill-empty-hint{margin:0;font-size:.88rem}.bill-plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.bill-plan-card{position:relative;padding:1.15rem 1.2rem;border-radius:var(--radius);border:1px solid var(--crm-border);background:#fff;transition:border-color .12s ease}.bill-plan-card:hover{border-color:#d1d5db}.bill-plan-card--current{border-color:#2563eb;background:#fafafa;box-shadow:var(--shadow-xs)}.bill-plan-ribbon{position:absolute;top:.65rem;right:.65rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#1d4ed8;background:#dbeafe;padding:.2rem .5rem;border-radius:999px}.bill-plan-name{font-size:1rem;font-weight:600;color:var(--crm-text);margin-bottom:.15rem}.bill-plan-code{font-size:.75rem;margin-bottom:.65rem}.bill-plan-price{margin-bottom:.35rem}.bill-plan-price-val{font-size:1.125rem;font-weight:700;font-variant-numeric:tabular-nums;color:#0f172a}.bill-plan-price-unit{margin-left:.35rem;font-size:.78rem}.bill-plan-quota{font-size:.8rem;margin-bottom:.5rem}.bill-plan-desc{margin:0;font-size:.76rem;line-height:1.45}.bill-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--crm-border);box-shadow:0 1px 3px #0f172a0f;background:#fff}.bill-table{width:100%;border-collapse:collapse;font-size:.82rem}.bill-table thead th{text-align:left;padding:.7rem .9rem;background:#f8fafc;color:#64748b;font-size:.72rem;font-weight:600;border-bottom:1px solid var(--crm-border);white-space:nowrap}.bill-table tbody td{padding:.6rem .9rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.bill-table tbody tr:last-child td{border-bottom:none}.bill-table tbody tr:hover{background:#fafbfc}.bill-table-empty{text-align:center;padding:2rem 1rem!important}.admin-users-membership{display:flex;align-items:center;gap:.5rem;padding:.2rem 0;min-height:2.5rem}.admin-users-membership--actions{justify-content:flex-start}.admin-users-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap;white-space:nowrap}.admin-users-actions .btn{flex-shrink:0;white-space:nowrap}.bill-td-date{font-size:.78rem;color:#64748b;font-variant-numeric:tabular-nums;white-space:nowrap}.bill-td-amt{font-weight:600}.bill-td-desc{max-width:360px;font-size:.78rem;line-height:1.4;color:#475569}.bill-type-pill{display:inline-block;padding:.14rem .5rem;font-size:.68rem;font-weight:600;border-radius:999px}.bill-type-pill--usage{background:#dbeafe;color:#1e40af}.bill-type-pill--cache{background:#dcfce7;color:#166534}.bill-status{display:inline-block;padding:.12rem .45rem;font-size:.68rem;font-weight:600;border-radius:999px}.bill-status--settled{background:#e0e7ff;color:#3730a3}.bill-status--waived{background:#ecfdf5;color:#047857}.keys-modal--wide{max-width:520px}.rc-wrap{margin:0 0 2rem;padding:0}.rc-wrap--page{margin-top:0}.rc-toast{position:fixed;bottom:1.25rem;left:50%;transform:translate(-50%);z-index:80;padding:.55rem 1rem;background:#1e293b;color:#f8fafc;border-radius:var(--radius-sm);font-size:.85rem;box-shadow:var(--shadow-sm)}.rc-head{margin-bottom:.75rem}.rc-title{margin:0 0 .25rem;font-size:1.2rem;font-weight:700;color:var(--crm-text)}.rc-sub{margin:0;font-size:.88rem}.rc-note{font-size:.82rem;margin:0 0 1rem}.rc-cards-grid{display:grid;gap:1rem;align-items:stretch;grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr))}.rc-card{background:var(--crm-card);border:1px solid var(--crm-border);border-radius:var(--radius);padding:1rem 1.1rem;box-shadow:var(--shadow-xs)}.rc-card-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--crm-muted);margin-bottom:.35rem}.rc-card-value{font-size:1.45rem;font-weight:700;color:var(--crm-blue);line-height:1.2}.rc-card-meta{margin-top:.5rem;font-size:.82rem}.rc-card-hint{font-size:.75rem;margin:.65rem 0 0}.rc-entry-desc{font-size:.82rem;margin:0 0 .75rem}.rc-pay-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.6rem;margin-bottom:1rem}.rc-pay-tile{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;padding:.65rem .65rem .75rem;border:1px solid var(--crm-border);border-radius:var(--radius-sm);background:#fff;cursor:pointer;text-align:left;transition:border-color .12s ease,box-shadow .12s ease}.rc-pay-tile:hover{border-color:#cbd5e1;box-shadow:var(--shadow-xs)}.rc-pay-tile--active{border-color:var(--crm-blue);box-shadow:0 0 0 1px #2563eb33}.rc-pay-tile--rec:after{content:"";position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 1.6rem 1.6rem 0;border-color:transparent rgba(37,99,235,.12) transparent transparent}.rc-pay-ico{width:26px;height:26px;color:var(--crm-blue)}.rc-pay-ico--wechat{color:#059669}.rc-pay-ico--alipay{color:#2563eb}.rc-pay-tile-label{font-size:.82rem;font-weight:600;color:var(--crm-text)}.rc-intl-pill,.rc-rec-pill{font-size:.65rem;font-weight:600;padding:.12rem .38rem;border-radius:999px;border:1px solid var(--crm-border);color:var(--crm-muted);background:#f8fafc}.rc-rec-pill{border-color:#2563eb59;color:var(--crm-blue);background:#eff6ff}.rc-cta{width:100%}.rc-follow{margin:1rem 0;padding:1rem 1.1rem;border:1px solid var(--crm-border);border-radius:var(--radius);background:#fafbfc}.rc-follow-hd{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:baseline;margin-bottom:.5rem}.rc-follow-tip{font-size:.84rem;margin:0 0 .75rem;line-height:1.5}.rc-bank-dl{margin:0;display:grid;gap:.5rem 1.25rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));font-size:.84rem}.rc-bank-dl dt{margin:0;font-weight:600;color:var(--crm-muted);font-size:.72rem}.rc-bank-dl dd{margin:.15rem 0 0;color:var(--crm-text)}.rc-follow-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.rc-qr-layout{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-start}.rc-qr-placeholder{flex:0 0 auto;width:160px;height:160px;border:1px dashed #cbd5e1;border-radius:var(--radius-sm);background:repeating-linear-gradient(-45deg,#f1f5f9,#f1f5f9 6px,#fff 6px,#fff 12px);display:flex;align-items:center;justify-content:center;text-align:center}.rc-qr-placeholder-inner{display:flex;flex-direction:column;gap:.35rem;font-size:.78rem;font-weight:600;color:#64748b;padding:.5rem}.rc-qr-placeholder-inner small{font-weight:500}.rc-qr-side{flex:1 1 200px;font-size:.88rem}.rc-qr-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.rc-qr-dismiss{margin-top:.75rem}.rc-table-block{margin-top:1.5rem}.rc-table-title{margin:0 0 .25rem;font-size:1rem;font-weight:700}.rc-table-desc{margin:0 0 .65rem;font-size:.82rem}.rc-table-wrap{border:1px solid var(--crm-border);border-radius:var(--radius);overflow:auto;background:#fff;box-shadow:var(--shadow-xs)}.rc-table{width:100%;border-collapse:collapse;font-size:.82rem}.rc-table thead th{text-align:left;padding:.65rem .75rem;background:#f8fafc;color:#475569;font-weight:600;border-bottom:1px solid var(--crm-border);white-space:nowrap}.rc-table tbody td{padding:.6rem .75rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.rc-table tbody tr:last-child td{border-bottom:none}.rc-table tbody tr:hover td{background:#fafbfc}.rc-table-empty{text-align:center;padding:2rem 1rem}.rc-td-time{white-space:nowrap;color:#475569}.rc-mono{font-family:ui-monospace,monospace;font-size:.78rem}.rc-col-actions{text-align:right;white-space:nowrap}.rc-action-group{display:inline-flex;flex-wrap:wrap;gap:.35rem;justify-content:flex-end}.rc-badge{display:inline-block;padding:.15rem .45rem;border-radius:999px;font-size:.72rem;font-weight:600}.rc-badge--ok{background:#ecfdf5;color:#15803d}.rc-badge--warn{background:#fff7ed;color:#c2410c}.rc-badge--err{background:#fef2f2;color:#b91c1c}.rc-badge--muted{background:#f3f4f6;color:#6b7280}.rc-instructions{margin-top:1.5rem;padding:1rem 1.1rem;border:1px solid var(--crm-border);border-radius:var(--radius);background:#fff}.rc-instructions-title{margin:0 0 .5rem;font-size:.95rem;font-weight:700}.rc-instructions-list{margin:0;padding-left:1.1rem;font-size:.82rem;line-height:1.55}.rc-instructions-strong{color:var(--crm-text);font-weight:600}.rc-drawer-chips{display:flex;flex-wrap:wrap;gap:.4rem}.rc-chip{border:1px solid var(--crm-border);background:#fff;border-radius:999px;padding:.3rem .6rem;font-size:.78rem;cursor:pointer;color:var(--crm-text)}.rc-chip--on{border-color:var(--crm-blue);background:#eff6ff;color:var(--crm-blue-dark)}.rc-switch-field{flex-direction:row;align-items:center;justify-content:space-between;gap:.75rem}.rc-switch{position:relative;width:44px;height:26px;border-radius:999px;border:1px solid #cbd5e1;background:#e5e7eb;cursor:pointer;padding:0;flex-shrink:0;transition:background .15s ease}.rc-switch--on{background:var(--crm-blue);border-color:var(--crm-blue)}.rc-switch-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:var(--shadow-xs);transition:transform .15s ease}.rc-switch--on .rc-switch-knob{transform:translate(18px)}.fin-page{width:100%;max-width:none;margin:0;padding-bottom:2.5rem}.fin-page-pad{padding:.5rem 0}.fin-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.fin-title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .35rem;color:var(--crm-text)}.fin-subtitle{margin:0;font-size:.88rem;max-width:none;line-height:1.45}.fin-note{margin:0 0 1.25rem;font-size:.82rem;line-height:1.45}.fin-kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.fin-kpi{background:#fff;border:1px solid var(--crm-border);border-radius:var(--radius);box-shadow:var(--shadow-xs);padding:1.1rem 1.15rem}.fin-kpi-label{font-size:.78rem;font-weight:600;color:var(--crm-muted);margin-bottom:.4rem}.fin-kpi-value{font-size:1.25rem;font-weight:700;color:var(--crm-text)}.fin-kpi-hint{margin-top:.35rem;font-size:.72rem}.fin-section{margin-bottom:1.5rem}.fin-section-title{font-size:1rem;font-weight:700;margin:0 0 .35rem;color:var(--crm-text)}.fin-section-desc{margin:0 0 .85rem;font-size:.82rem}.fin-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--crm-border);background:#fff;box-shadow:var(--shadow-xs)}.fin-table{width:100%;border-collapse:collapse;font-size:.82rem;min-width:0;table-layout:auto}.fin-table thead th{text-align:left;padding:.65rem .85rem;background:#f8fafc;color:#64748b;font-size:.72rem;font-weight:600;border-bottom:1px solid var(--crm-border);white-space:nowrap}.fin-table thead th.fin-col-status{text-align:center}.fin-table tbody td{padding:.55rem .85rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.fin-table tbody tr:last-child td{border-bottom:none}.fin-row-click{cursor:pointer}.fin-row-click:hover td{background:#fafbfc}.fin-table-empty{text-align:center;padding:2rem 1rem!important}.fin-td-time{font-size:.76rem;color:#64748b;font-variant-numeric:tabular-nums;white-space:nowrap}.fin-td-sub{font-size:.76rem;color:#475569}.fin-td-ellip{max-width:12rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fin-mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.76rem}.fin-col-status{text-align:center;white-space:nowrap;min-width:6.5rem;width:1%}.fin-col-status .fin-badge{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;vertical-align:middle;max-width:none}.fin-col-actions{white-space:nowrap;min-width:9rem}.fin-action-stack{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.fin-row-btn{font-size:.78rem;padding:.3rem .55rem}.fin-dash{font-size:.85rem}.fin-badge{display:inline-block;padding:.12rem .45rem;font-size:.65rem;font-weight:600;border-radius:6px;border:1px solid transparent}.fin-badge--ok{background:#ecfdf5;color:#047857;border-color:#bbf7d0}.fin-badge--warn{background:#fffbeb;color:#b45309;border-color:#fde68a}.fin-badge--info{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.fin-badge--err{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.fin-badge--muted{background:#f4f4f5;color:#71717a;border-color:#e4e4e7}.fin-drawer{max-width:min(640px,100%)}.fin-dl dt{font-size:.78rem}.fin-drawer-actions{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--crm-border);display:flex;flex-wrap:wrap;gap:.5rem}.integration-page{display:flex;flex-direction:column;gap:1.25rem;padding-bottom:2rem}.integration-hero{position:relative;display:grid;grid-template-columns:minmax(0,1.65fr) minmax(18rem,1fr);gap:1rem;padding:1.55rem;border-radius:28px;overflow:hidden;background:radial-gradient(circle at top left,rgba(59,130,246,.22),transparent 30%),radial-gradient(circle at bottom right,rgba(14,165,233,.16),transparent 34%),linear-gradient(135deg,#020617,#0f172a 42%,#172554);color:#dbeafe;border:1px solid rgba(148,163,184,.16);box-shadow:0 20px 50px #02061747}.integration-hero:after{content:"";position:absolute;inset:auto -10% -30% auto;width:18rem;height:18rem;background:radial-gradient(circle,rgba(56,189,248,.18),transparent 62%);pointer-events:none}.integration-hero h1{margin:0 0 .7rem;font-size:2.15rem;letter-spacing:-.05em;color:#fff}.integration-hero p{margin:0;max-width:50rem;line-height:1.75;color:#dbeafee6}.integration-kicker{display:inline-flex;align-items:center;width:fit-content;margin-bottom:.85rem;padding:.32rem .72rem;border-radius:999px;background:#3b82f624;border:1px solid rgba(125,211,252,.28);color:#bfdbfe;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.integration-hero-copy,.integration-hero-panel{display:flex;flex-direction:column}.integration-hero-copy{position:relative;z-index:1;gap:1rem}.integration-hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}.integration-hero-actions .btn{border-color:#94a3b838}.integration-hero-actions .btn-ghost{background:#0f172a47;color:#e0f2fe}.integration-hero-actions .btn-ghost:hover{background:#1e293b80;border-color:#94a3b857;color:#fff}.integration-hero-panel{position:relative;z-index:1;gap:.85rem}.integration-mini-card{display:flex;flex-direction:column;gap:.38rem;padding:1rem 1.05rem;border-radius:18px;background:#0f172a75;border:1px solid rgba(148,163,184,.16);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.integration-mini-card span{font-size:.72rem;color:#93c5fd;text-transform:uppercase;letter-spacing:.08em}.integration-mini-card code{color:#f8fafc;font-size:.82rem;line-height:1.55;word-break:break-word}.integration-section-nav{display:flex;flex-wrap:wrap;gap:.7rem}.integration-section-link{display:inline-flex;align-items:center;padding:.58rem .92rem;border-radius:999px;border:1px solid #dbe7f3;background:#ffffffd1;color:#334155;text-decoration:none;font-size:.82rem;font-weight:600;box-shadow:0 6px 18px #0f172a0d;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,color .16s ease}.integration-section-link:hover{transform:translateY(-1px);border-color:#93c5fd;color:#1d4ed8;box-shadow:0 10px 24px #3b82f61f}.integration-endpoint-grid,.integration-capability-grid,.integration-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.integration-endpoint-grid,.integration-capability-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.integration-grid--triple{grid-template-columns:1.15fr 1fr .85fr}.integration-card,.integration-capability-card,.integration-sdk-card{background:#ffffffeb;border:1px solid var(--crm-border);border-radius:24px;box-shadow:0 10px 26px #0f172a12;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.integration-card,.integration-sdk-card,.integration-card--wide{padding:1.28rem}.integration-card h2,.integration-sdk-card h2{margin:0 0 .9rem;color:var(--crm-text);letter-spacing:-.02em}.integration-capability-card{padding:1rem 1.05rem}.integration-capability-title{display:block;margin-bottom:.45rem;font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#64748b}.integration-capability-value{display:block;margin-bottom:.45rem;font-size:1.32rem;letter-spacing:-.03em;color:#0f172a}.integration-capability-card p{margin:0;color:#475569;line-height:1.65}.integration-endpoint-card{display:flex;flex-direction:column;gap:.8rem;padding:1.08rem 1.1rem;border-radius:22px;border:1px solid #dbe7f3;background:radial-gradient(circle at top right,rgba(191,219,254,.28),transparent 32%),linear-gradient(180deg,#fff,#f8fbff);box-shadow:0 12px 30px #0f172a0f}.integration-endpoint-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.integration-endpoint-head strong{color:#0f172a;font-size:.96rem;line-height:1.45}.integration-endpoint-code{display:block;padding:.9rem .95rem;border-radius:16px;background:#0f172afa;border:1px solid #1e293b;color:#e0f2fe;font-size:.82rem;line-height:1.7;word-break:break-word}.integration-endpoint-copy{width:fit-content}.integration-endpoint-card p{margin:0;color:#475569;line-height:1.7}.integration-support-list{display:grid;gap:.78rem}.integration-support-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:.92rem .98rem;border-radius:18px;border:1px solid #e2e8f0;background:linear-gradient(180deg,#fff,#f8fafc)}.integration-support-feature{display:block;margin-bottom:.3rem;color:#0f172a;font-size:.9rem}.integration-support-detail{margin:0;color:#475569;line-height:1.65;font-size:.84rem}.integration-support-badge{display:inline-flex;align-items:center;justify-content:center;min-width:4.8rem;padding:.38rem .62rem;border-radius:999px;font-size:.75rem;font-weight:700;white-space:nowrap}.integration-support-badge--available{background:#dcfce7;color:#166534}.integration-support-badge--limited{background:#fee2e2;color:#b91c1c}.integration-support-badge--planned{background:#e0f2fe;color:#0369a1}.integration-error-list,.integration-faq-list,.integration-changelog-list{display:grid;gap:.78rem}.integration-error-row{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(14rem,.9fr);gap:1rem;padding:.95rem 1rem;border-radius:18px;border:1px solid #e2e8f0;background:linear-gradient(180deg,#fff,#f8fafc)}.integration-error-head{display:flex;align-items:center;gap:.65rem;margin-bottom:.45rem}.integration-error-head code{display:inline-flex;align-items:center;justify-content:center;min-width:3.25rem;padding:.28rem .5rem;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:.75rem;font-weight:700}.integration-error-main p{margin:0;color:#475569;line-height:1.65}.integration-error-action{padding:.82rem .9rem;border-radius:14px;background:#f8fbff;border:1px solid #dbe7f3;color:#334155;line-height:1.65;font-size:.83rem}.integration-faq-item{border:1px solid #e2e8f0;border-radius:18px;background:linear-gradient(180deg,#fff,#f8fafc);overflow:hidden}.integration-faq-item summary{cursor:pointer;list-style:none;padding:.95rem 1rem;font-weight:700;color:#0f172a}.integration-faq-item summary::-webkit-details-marker{display:none}.integration-faq-item p{margin:0;padding:0 1rem 1rem;color:#475569;line-height:1.7}.integration-changelog-item{padding:.95rem 1rem;border-radius:18px;border:1px solid #e2e8f0;background:linear-gradient(180deg,#fff,#f8fafc)}.integration-changelog-meta{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.7rem}.integration-changelog-date{color:#64748b;font-size:.78rem;font-weight:600}.integration-changelog-title{display:block;margin-bottom:.7rem;color:#0f172a}.integration-step-list,.integration-bullet-list{margin:0;padding-left:1.15rem}.integration-step-list li,.integration-bullet-list li{display:grid;gap:.3rem;color:#334155;line-height:1.65}.integration-step-list li+li,.integration-bullet-list li+li{margin-top:.8rem}.integration-bullet-list--tight li+li{margin-top:.5rem}.integration-spec-list{display:grid;gap:.72rem}.integration-spec-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.88rem .98rem;border-radius:16px;background:linear-gradient(180deg,#f8fbff,#f8fafc);border:1px solid #e2e8f0}.integration-spec-label{font-size:.82rem;color:#64748b}.integration-spec-value{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem;color:#0f172a;text-align:right}.integration-role-box{margin-top:.9rem;padding:.95rem 1rem;border-radius:18px;border:1px solid #dbe7f3;background:linear-gradient(180deg,#f8fbff,#fff)}.integration-role-box strong{display:block;margin-bottom:.7rem;color:#0f172a}.integration-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.95rem}.integration-sdk-card .integration-section-head{margin-bottom:1rem}.integration-section-head--subtle{margin-top:1rem}.integration-sdk-shell{display:grid;grid-template-columns:minmax(15rem,17rem) minmax(0,1fr);gap:1rem}.integration-sdk-tabs{display:flex;flex-direction:column;gap:.65rem}.integration-sdk-tab{display:flex;align-items:center;justify-content:flex-start;width:100%;padding:.85rem .95rem;border-radius:18px;border:1px solid #dbe7f3;background:#fff;color:#334155;font-weight:600;cursor:pointer;text-align:left;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease,background .16s ease,color .16s ease}.integration-sdk-tab:hover{transform:translateY(-1px);border-color:#93c5fd;box-shadow:0 8px 22px #3b82f61f;color:#1d4ed8}.integration-sdk-tab--active{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#60a5fa;color:#1d4ed8;box-shadow:inset 0 0 0 1px #2563eb14}.integration-sdk-view{display:flex;flex-direction:column;gap:.9rem}.integration-sdk-meta{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem}.integration-sdk-meta h3{margin:0 0 .35rem;color:#0f172a;letter-spacing:-.02em}.integration-sdk-meta p{margin:0;max-width:42rem;color:#475569;line-height:1.7}.integration-sdk-badges{display:flex;flex-wrap:wrap;gap:.5rem}.integration-chip{display:inline-flex;align-items:center;padding:.36rem .68rem;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:.75rem;font-weight:600}.integration-install-box{display:flex;flex-direction:column;gap:.55rem;padding:.85rem .95rem;border-radius:18px;border:1px solid #dbe7f3;background:#f8fbff}.integration-install-label{font-size:.78rem;font-weight:700;color:#475569}.integration-install-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap}.integration-install-row code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:#0f172a;font-size:.82rem}.integration-code-block{margin:0;overflow-x:auto;padding:1rem 1.06rem;border-radius:18px;background:linear-gradient(180deg,#0f172afa,#0f172af0);color:#dbeafe;font-size:.82rem;line-height:1.68;border:1px solid #1e293b;box-shadow:inset 0 1px #ffffff0a}@media(max-width:1180px){.integration-hero,.integration-endpoint-grid,.integration-capability-grid,.integration-grid,.integration-grid--triple,.integration-sdk-shell,.integration-error-row{grid-template-columns:1fr}}@media(max-width:720px){.keys-header-actions,.integration-hero-actions,.integration-endpoint-head,.integration-section-head,.integration-support-row,.integration-spec-item,.integration-sdk-meta,.integration-install-row{flex-direction:column;align-items:stretch}.integration-changelog-meta{flex-direction:column;align-items:flex-start}.integration-hero{padding:1.18rem;border-radius:22px}.integration-hero h1{font-size:1.72rem}.integration-card,.integration-card--wide,.integration-sdk-card,.integration-capability-card{padding:1rem;border-radius:18px}.integration-spec-value{text-align:left}.integration-section-nav{gap:.55rem}.integration-section-link{width:100%;justify-content:center}}
