@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700&family=Playfair+Display:wght@600;700&display=swap";:root{--zf-bg:#1e2a38;--zf-panel:#15202e;--zf-panel-hi:#1a2633;--zf-surface:#0a1422;--zf-border:#1c3a5e;--zf-border-hi:#2a5a8a;--zf-text:#f5f7fa;--zf-muted:#8699b0;--zf-link:#6fa9e3;--zf-accent:#e6b85c;--zf-accent-dim:#d9a74f;--zf-header-bg:#111a26;--zf-success:#2ecc71;--zf-warn:#e6b85c;--zf-danger:#d64550;--zf-info:#5b9bd5}*{box-sizing:border-box}html,body,#root{background:var(--zf-bg);min-height:100%;color:var(--zf-text);margin:0;padding:0;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.6}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--zf-bg)}::-webkit-scrollbar-thumb{background:var(--zf-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--zf-border-hi)}a{color:var(--zf-link);text-decoration:none}a:hover{color:var(--zf-accent)}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--zf-header-bg);border-bottom:1px solid var(--zf-border);justify-content:space-between;align-items:center;padding:14px 28px;display:flex}.app-header-left{align-items:center;gap:12px;display:flex}.app-header-right{align-items:center;gap:14px;display:flex}.project-switcher{display:inline-block;position:relative}.project-switcher-trigger{background:var(--zf-panel);color:var(--zf-text);border:1px solid var(--zf-border);cursor:pointer;border-radius:8px;align-items:center;gap:10px;min-width:180px;padding:6px 10px;font-family:inherit;transition:all .15s;display:inline-flex}.project-switcher-trigger:hover{border-color:var(--zf-border-hi);background:var(--zf-panel-hi)}.project-switcher-trigger-open{border-color:var(--zf-accent)}.project-switcher-trigger-icon{background:linear-gradient(135deg, var(--zf-border-hi), var(--zf-border));width:28px;height:28px;color:var(--zf-accent);letter-spacing:.5px;border-radius:6px;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.project-switcher-trigger-body{flex-direction:column;flex:1;align-items:flex-start;min-width:0;line-height:1.2;display:flex}.project-switcher-trigger-label{color:var(--zf-muted);text-transform:uppercase;letter-spacing:.6px;font-size:10px}.project-switcher-trigger-name{color:var(--zf-text);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:13px;font-weight:600;overflow:hidden}.project-switcher-trigger-caret{color:var(--zf-muted);font-size:12px}.project-switcher-panel{background:var(--zf-panel);border:1px solid var(--zf-border);z-index:500;border-radius:10px;min-width:340px;max-width:420px;max-height:460px;padding:6px;position:absolute;top:calc(100% + 8px);right:0;overflow-y:auto;box-shadow:0 12px 28px #00000073}.project-switcher-header{text-transform:uppercase;color:var(--zf-muted);letter-spacing:.8px;padding:10px 10px 4px;font-size:11px}.project-switcher-list{flex-direction:column;display:flex}.project-switcher-item{text-align:left;color:var(--zf-text);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:10px;font-family:inherit;transition:all .12s;display:flex}.project-switcher-item:hover{background:var(--zf-panel-hi)}.project-switcher-item-active{background:#e6b85c1a}.project-switcher-item-initials{background:var(--zf-surface);border:1px solid var(--zf-border);width:32px;height:32px;color:var(--zf-accent);letter-spacing:.5px;border-radius:8px;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.project-switcher-item-body{flex:1;min-width:0}.project-switcher-item-name{color:var(--zf-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.project-switcher-item-meta{color:var(--zf-muted);margin-top:2px;font-size:11px}.project-switcher-dot{color:var(--zf-border-hi);margin:0 6px}.project-switcher-check{color:var(--zf-accent);font-weight:700}.project-switcher-divider{background:var(--zf-border);height:1px;margin:6px 4px}.project-switcher-new{text-align:left;width:100%;color:var(--zf-accent);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:10px;font-family:inherit;font-size:13px;font-weight:600;display:block}.project-switcher-new:hover{background:var(--zf-panel-hi)}.project-switcher-create{flex-direction:column;gap:8px;padding:10px;display:flex}.project-switcher-input,.project-switcher-select{background:var(--zf-surface);color:var(--zf-text);border:1px solid var(--zf-border);border-radius:6px;padding:8px 10px;font-family:inherit;font-size:13px}.project-switcher-input:focus,.project-switcher-select:focus{border-color:var(--zf-accent);outline:none}.project-switcher-create-actions{justify-content:flex-end;gap:8px;display:flex}.modal{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;flex-direction:column;width:100%;max-width:960px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 18px 42px #00000080}.modal-header{border-bottom:1px solid var(--zf-border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-header h2{color:var(--zf-accent);margin:0;font-family:Playfair Display,serif;font-size:22px}.modal-body{padding:22px;overflow-y:auto}.projects-modal-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.projects-modal-card{background:var(--zf-surface);border:1px solid var(--zf-border);cursor:pointer;border-radius:10px;flex-direction:column;gap:6px;padding:16px;transition:all .15s;display:flex}.projects-modal-card:hover{border-color:var(--zf-border-hi);transform:translateY(-1px)}.projects-modal-card-active{border-color:var(--zf-accent);box-shadow:0 0 0 2px #e6b85c33}.projects-modal-card-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.projects-modal-card-name{color:var(--zf-text);font-size:14px;font-weight:700}.projects-modal-card-industry{color:var(--zf-accent);text-transform:uppercase;letter-spacing:.7px;font-size:11px}.projects-modal-card-desc{color:var(--zf-muted);min-height:36px;font-size:12px;line-height:1.5}.projects-modal-card-stats{border-top:1px solid var(--zf-border);grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px;padding-top:12px;display:grid}.projects-modal-stat{text-align:center}.projects-modal-stat-value{color:var(--zf-text);font-size:18px;font-weight:700}.projects-modal-stat-label{color:var(--zf-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:10px}.intake-overlay{z-index:950}.intake-modal{max-width:720px}.intake-modal .modal-close{color:var(--zf-muted);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:24px;line-height:1}.intake-modal .modal-close:hover{color:var(--zf-text)}.intake-steps{border-bottom:1px solid var(--zf-border);align-items:center;gap:0;padding:16px 22px;display:flex}.intake-step{flex-direction:column;flex-shrink:0;align-items:center;gap:4px;display:flex}.intake-step-dot{background:var(--zf-surface);border:1px solid var(--zf-border);width:28px;height:28px;color:var(--zf-muted);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.intake-step-dot-active{background:var(--zf-accent);color:var(--zf-bg,#0a1422);border-color:var(--zf-accent)}.intake-step-dot-done{background:var(--zf-accent-dim,#d4af3759);color:var(--zf-text);border-color:var(--zf-accent-dim,#d4af3759)}.intake-step-label{color:var(--zf-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px}.intake-step-bar{background:var(--zf-border);flex:1;height:2px;margin:0 8px 18px}.intake-step-bar-done{background:var(--zf-accent-dim,#d4af3759)}.intake-body{min-height:320px}.intake-step-body{flex-direction:column;gap:14px;display:flex}.intake-helper{color:var(--zf-muted);margin:0 0 4px;font-size:12px;font-style:italic}.intake-field{flex-direction:column;gap:6px;display:flex}.intake-field-label{color:var(--zf-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.intake-input,.intake-textarea,.intake-select{background:var(--zf-surface);border:1px solid var(--zf-border);color:var(--zf-text);border-radius:6px;width:100%;padding:8px 10px;font-family:inherit;font-size:13px}.intake-textarea{resize:vertical;min-height:60px;font-family:inherit}.intake-input:focus,.intake-textarea:focus,.intake-select:focus{border-color:var(--zf-accent);outline:none}.intake-footer{border-top:1px solid var(--zf-border);background:var(--zf-surface);justify-content:space-between;align-items:center;padding:14px 22px;display:flex}.intake-summary{flex-direction:column;gap:16px;display:flex}.intake-summary-group{background:var(--zf-surface);border:1px solid var(--zf-border);border-radius:8px;flex-direction:column;gap:6px;padding:12px 14px;display:flex}.intake-summary-title{color:var(--zf-accent);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:700}.intake-summary-row{border-bottom:1px dashed var(--zf-border);grid-template-columns:140px 1fr;gap:10px;padding:4px 0;font-size:12px;display:grid}.intake-summary-row:last-child{border-bottom:none}.intake-summary-k{color:var(--zf-muted)}.intake-summary-v{color:var(--zf-text);white-space:pre-wrap;word-break:break-word}.app-header h1{color:var(--zf-accent);letter-spacing:.5px;margin:0;font-family:Playfair Display,serif;font-size:24px;font-weight:700}.app-logo{width:auto;height:28px}.app-version{color:var(--zf-muted);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px}.app-avatar{background:linear-gradient(135deg, var(--zf-accent), var(--zf-accent-dim));width:36px;height:36px;color:var(--zf-bg);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.tabbar{background:var(--zf-bg);border-bottom:1px solid var(--zf-border);gap:32px;padding:0 28px;display:flex}.tab{color:var(--zf-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:14px 0;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.tab:hover{color:var(--zf-text)}.tab-active{color:var(--zf-accent);border-bottom-color:var(--zf-accent)}.breadcrumb{color:var(--zf-muted);background:var(--zf-bg);border-bottom:1px solid var(--zf-border);align-items:center;gap:6px;width:100%;max-width:1600px;margin:0 auto;padding:6px 28px;font-size:11px;display:flex}.breadcrumb-root{text-transform:uppercase;letter-spacing:.1em;font-weight:600}.breadcrumb-sep{color:var(--zf-border-hi);font-size:12px}.breadcrumb-link{color:var(--zf-link);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-family:inherit;font-size:11px}.breadcrumb-link:hover{color:var(--zf-accent);background:#e6b85c14}.breadcrumb-current{color:var(--zf-text);font-weight:600}.breadcrumb-focus{color:var(--zf-accent);background:#e6b85c14;border-radius:3px;padding:1px 6px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:10px}.module-card-highlighted{box-shadow:0 0 0 2px var(--zf-accent), 0 0 24px #e6b85c59;animation:2.2s ease-out zf-card-pulse}@keyframes zf-card-pulse{0%{box-shadow:0 0 0 2px var(--zf-accent), 0 0 0 #e6b85c00}30%{box-shadow:0 0 0 3px var(--zf-accent), 0 0 32px #e6b85c8c}to{box-shadow:0 0 0 2px var(--zf-accent), 0 0 24px #e6b85c59}}.sr-module-list{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.sr-module-pill{color:var(--zf-link);cursor:pointer;background:#6fa9e31f;border:1px solid #6fa9e34d;border-radius:12px;align-items:center;gap:4px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:600;display:inline-flex}.sr-module-pill:hover{color:var(--zf-accent);background:#e6b85c26;border-color:#e6b85c66}.sr-module-pill:focus-visible{outline:2px solid var(--zf-accent);outline-offset:2px}.skip-to-content{background:var(--zf-accent);width:1px;height:1px;color:var(--zf-surface);z-index:10000;border-radius:0 0 6px;padding:10px 16px;font-weight:600;position:absolute;top:0;left:-10000px;overflow:hidden}.skip-to-content:focus{outline:3px solid var(--zf-accent);outline-offset:2px;width:auto;height:auto;top:0;left:0}:focus-visible{outline:2px solid var(--zf-accent);outline-offset:2px;border-radius:2px}button:focus-visible,a:focus-visible,.tab:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--zf-accent);outline-offset:2px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.status-indicator{align-items:center;gap:6px;font-size:12px;font-weight:500;line-height:1;display:inline-flex}.status-indicator:before{text-align:center;border-radius:50%;width:12px;height:12px;font-size:12px;font-weight:700;line-height:12px;display:inline-block}.status-indicator.status-ok:before{content:"✓";background:var(--zf-success);color:var(--zf-surface)}.status-indicator.status-error:before{content:"✕";background:var(--zf-danger);color:#fff}.status-indicator.status-warn:before{content:"!";background:var(--zf-warn);color:var(--zf-surface)}.status-indicator.status-info:before{content:"i";background:var(--zf-info);color:#fff;font-style:italic}.status-indicator.status-pending:before{content:"…";background:var(--zf-muted);color:var(--zf-surface);font-size:10px}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}.app-main{flex:1;width:100%;max-width:1600px;margin:0 auto;padding:28px}.screen h2{color:var(--zf-text);margin:0;font-family:Playfair Display,serif;font-size:26px;font-weight:700}.screen-header{margin-bottom:24px}.screen-subtitle{color:var(--zf-muted);margin:4px 0 0;font-size:13px}.screen-stub{color:var(--zf-muted);font-style:italic}.section-label{text-transform:uppercase;letter-spacing:.13em;color:var(--zf-accent);margin:0 0 16px;font-size:12px;font-weight:700}.btn{color:var(--zf-link);border:1px solid var(--zf-border);cursor:pointer;background:0 0;border-radius:8px;padding:8px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.btn:hover{border-color:var(--zf-accent);color:var(--zf-accent)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--zf-accent);color:var(--zf-bg);border:none;border-radius:8px;padding:10px 20px;font-size:13px;font-weight:700}.btn-primary:hover{background:var(--zf-accent-dim);color:var(--zf-bg)}.btn-primary:disabled{background:var(--zf-border);color:var(--zf-muted);cursor:not-allowed}.btn-ghost{border:1px solid var(--zf-border);color:var(--zf-link);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;background:0 0;border-radius:6px;padding:6px 12px;font-family:inherit;font-size:11px;font-weight:700}.btn-ghost:hover{border-color:var(--zf-accent);color:var(--zf-accent)}.btn-danger{color:var(--zf-danger);cursor:pointer;background:0 0;border:1px solid #d6455066;border-radius:6px;padding:6px 12px;font-family:inherit;font-size:12px}.btn-danger:hover{background:#d645501a}.btn-danger:disabled{opacity:.4;cursor:not-allowed}.btn-small{padding:4px 10px;font-size:11px}.btn-file{cursor:pointer;align-items:center;display:inline-flex}.btn-icon{border:1px solid var(--zf-border);background:var(--zf-surface);width:32px;height:32px;color:var(--zf-link);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;font-size:14px;transition:all .15s;display:inline-flex}.btn-icon:hover{background:var(--zf-panel);border-color:var(--zf-accent);color:var(--zf-accent)}.btn-icon:disabled{opacity:.4;cursor:not-allowed}input[type=text],input[type=email],input[type=number],input[type=url],input[type=password],select,textarea{background:var(--zf-surface);border:1px solid var(--zf-border);color:var(--zf-text);border-radius:8px;padding:8px 12px;font-family:inherit;font-size:13px;transition:all .15s}input:focus,select:focus,textarea:focus{border-color:var(--zf-accent);outline:none}input::placeholder,textarea::placeholder{color:var(--zf-muted)}.status-badge{letter-spacing:.1em;text-transform:uppercase;border-radius:4px;align-items:center;gap:4px;padding:4px 10px;font-size:10px;font-weight:700;display:inline-flex}.status-badge:before{text-align:center;width:10px;height:10px;color:var(--zf-surface);content:"";background:currentColor;border-radius:50%;font-size:10px;line-height:10px;display:inline-block}.status-monitoring:before,.status-connected:before,.status-active:before,.status-ok:before,.status-success:before,.status-confirmed:before{content:"✓"}.status-scanning:before,.status-pending:before,.status-warn:before{content:"!"}.status-syncing:before,.status-info:before,.status-open:before,.status-unreviewed:before{content:"i"}.status-paused:before,.status-disconnected:before,.status-idle:before,.status-dismissed:before{content:"–"}.status-error:before,.status-failed:before,.status-danger:before{content:"✕"}.status-monitoring,.status-connected,.status-active,.status-ok,.status-success,.status-confirmed{color:var(--zf-success);background:#2ecc7126}.status-scanning,.status-pending,.status-warn{color:var(--zf-accent);background:#e6b85c26}.status-syncing,.status-info,.status-open,.status-unreviewed{color:var(--zf-info);background:#5b9bd526}.status-paused,.status-disconnected,.status-idle,.status-dismissed{color:var(--zf-muted);background:#8699b026}.status-error,.status-failed,.status-danger{color:var(--zf-danger);background:#d6455026}.card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;padding:18px}.progress-bar{background:var(--zf-surface);border-radius:2px;width:100%;height:4px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--zf-accent), var(--zf-accent-dim));height:100%;transition:width .3s}.dash-project-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.dash-project-selector{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.dash-project-meta{color:var(--zf-link);flex-wrap:wrap;gap:20px;font-size:13px;display:flex}.dash-meta-item{align-items:center;gap:6px;display:flex}.dash-meta-dot{background:var(--zf-accent);border-radius:50%;width:4px;height:4px}.dash-dropdown{background:var(--zf-panel);border:1px solid var(--zf-border);color:var(--zf-text);cursor:pointer;border-radius:8px;padding:10px 14px;font-family:inherit;font-size:14px}.dash-dropdown:hover{border-color:var(--zf-accent)}.dash-connections-row{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:28px;display:grid}.connection-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;padding:18px;transition:all .2s}.connection-card:hover{border-color:var(--zf-border-hi);box-shadow:0 4px 12px #e6b85c14}.connection-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:14px;display:flex}.connection-card-title{color:var(--zf-text);cursor:pointer;font-size:14px;font-weight:700;text-decoration:none}a.connection-card-title:hover{color:var(--zf-link)}.connection-card-stat{color:var(--zf-text);margin-bottom:6px;font-size:16px;font-weight:700}.connection-card-meta{color:var(--zf-muted);margin-bottom:10px;font-size:12px}.connection-card .progress-bar{margin-bottom:12px}.connection-card-actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.dash-stats-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;margin-bottom:28px;display:grid}.stat-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;padding:18px}.stat-label{text-transform:uppercase;letter-spacing:.13em;color:var(--zf-accent);margin-bottom:16px;font-size:12px;font-weight:700}.queue-stat{border-bottom:1px solid var(--zf-border);justify-content:space-between;align-items:center;padding:10px 0;font-size:13px;display:flex}.queue-stat:last-child{border-bottom:none}.queue-stat-name{color:var(--zf-muted)}.queue-stat-value{color:var(--zf-text);font-size:15px;font-weight:700}.queue-stat-value.success{color:var(--zf-success)}.queue-stat-value.danger{color:var(--zf-danger)}.throughput{color:var(--zf-accent);margin-top:12px;font-size:24px;font-weight:700}.throughput-label{color:var(--zf-muted);margin-left:4px;font-size:11px;font-weight:400}.donut-container{justify-content:center;margin-bottom:20px;display:flex}.donut{width:140px;height:140px;box-shadow:inset 0 0 0 40px var(--zf-panel);border-radius:50%;justify-content:center;align-items:center;display:flex}.donut-center{text-align:center}.donut-value{color:var(--zf-text);font-size:20px;font-weight:700}.donut-text{color:var(--zf-muted);font-size:11px}.signal-breakdown{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px;display:grid}.breakdown-item{text-align:center}.breakdown-value{color:var(--zf-text);font-size:18px;font-weight:700}.breakdown-label{color:var(--zf-muted);font-size:11px}.signal-stats{border-top:1px solid var(--zf-border);padding-top:14px}.stat-row{justify-content:space-between;margin-bottom:8px;font-size:13px;display:flex}.stat-row-label{color:var(--zf-muted)}.stat-row-value{color:var(--zf-text);font-weight:500}.needs-attention{color:var(--zf-text);cursor:pointer;background:#d645501a;border-radius:6px;align-items:center;gap:8px;margin-top:14px;padding:10px;font-size:12px;transition:all .15s;display:flex}.needs-attention:hover{background:#d645502e}.needs-dot{background:var(--zf-danger);border-radius:50%;width:6px;height:6px}.specs-list{flex-direction:column;gap:10px;margin-bottom:14px;display:flex}.spec-item{background:var(--zf-surface);border-radius:6px;justify-content:space-between;align-items:center;padding:12px;transition:all .15s;display:flex}.spec-item:hover{background:var(--zf-panel-hi)}.spec-info{flex:1}.spec-name{color:var(--zf-text);margin-bottom:4px;font-size:13px;font-weight:600;text-decoration:none;display:block}a.spec-name:hover{color:var(--zf-link)}.spec-meta{color:var(--zf-muted);flex-wrap:wrap;gap:16px;font-size:11px;display:flex}.spec-actions{gap:8px;display:flex}.activity-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;padding:18px}.processing-errors-panel{background:var(--zf-panel);border:1px solid var(--zf-danger,#e74c3c);border-radius:12px;margin-bottom:18px;padding:18px}.processing-errors-header{justify-content:space-between;align-items:baseline;margin-bottom:12px;display:flex}.processing-errors-title{color:var(--zf-text);font-size:14px;font-weight:700}.processing-errors-total{color:var(--zf-muted);font-size:12px}.processing-error-group{margin-bottom:14px}.processing-error-group:last-child{margin-bottom:0}.processing-error-group-header{border-bottom:1px solid var(--zf-border);justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;padding:8px 0;display:flex}.processing-error-group-name{color:var(--zf-text);flex:1;font-size:13px;font-weight:600}.processing-error-group-count{color:var(--zf-muted);margin-right:8px;font-size:12px}.processing-error-rows{flex-direction:column;gap:6px;display:flex}.processing-error-row{border-bottom:1px dashed var(--zf-border);grid-template-columns:1fr 2fr auto;align-items:center;gap:10px;padding:6px 0;display:grid}.processing-error-row:last-child{border-bottom:none}.processing-error-file{flex-direction:column;gap:2px;min-width:0;display:flex}.processing-error-name{color:var(--zf-text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.processing-error-stage{text-transform:uppercase;letter-spacing:.5px;color:var(--zf-muted);font-size:10px}.processing-error-msg{color:var(--zf-danger,#e74c3c);font-size:11px;font-family:var(--zf-mono,monospace);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.activity-title{color:var(--zf-text);margin-bottom:16px;font-size:14px;font-weight:700}.activity-list{flex-direction:column;gap:12px;display:flex}.activity-item{border-bottom:1px solid var(--zf-border);align-items:flex-start;gap:12px;padding-bottom:12px;display:flex}.activity-item:last-child{border-bottom:none;padding-bottom:0}.activity-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.activity-dot.success{background:var(--zf-success)}.activity-dot.signal{background:var(--zf-accent)}.activity-dot.info{background:var(--zf-info)}.activity-dot.danger{background:var(--zf-danger)}.activity-content{flex:1}.activity-message{color:var(--zf-text);margin-bottom:4px;font-size:13px}.activity-time{color:var(--zf-muted);font-size:11px}.provider-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:36px;display:grid}.provider-tile{background:var(--zf-panel);border:1px solid var(--zf-border);text-align:center;cursor:pointer;color:inherit;font-family:inherit;font-size:inherit;border-radius:12px;flex-direction:column;align-items:center;gap:12px;width:100%;padding:18px;transition:all .2s;display:flex}.provider-tile:hover{border-color:var(--zf-border-hi);background:var(--zf-panel-hi)}.provider-tile:focus-visible{outline:2px solid var(--zf-accent);outline-offset:2px}.provider-tile:disabled,.provider-tile.disabled{opacity:.5;cursor:not-allowed}.provider-icon{background:linear-gradient(135deg, var(--zf-accent), var(--zf-accent-dim));width:48px;height:48px;color:var(--zf-bg);border-radius:8px;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.provider-name{color:var(--zf-text);font-size:13px;font-weight:600}.provider-sub{color:var(--zf-muted);font-size:11px}.conn-table-wrapper{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;overflow:hidden}.conn-table{border-collapse:collapse;width:100%}.conn-table th{background:var(--zf-surface);border-bottom:1px solid var(--zf-border);text-align:left;text-transform:uppercase;letter-spacing:.1em;color:var(--zf-accent);padding:14px 18px;font-size:11px;font-weight:700}.conn-table td{border-bottom:1px solid var(--zf-border);color:var(--zf-text);padding:14px 18px;font-size:13px}.conn-table tr:last-child>td{border-bottom:none}.conn-table tbody tr.conn-row:hover{background:var(--zf-panel-hi);cursor:pointer}.conn-provider-cell{align-items:center;gap:10px;display:flex}.conn-row-icon{background:linear-gradient(135deg, var(--zf-accent), var(--zf-accent-dim));width:32px;height:32px;color:var(--zf-bg);border-radius:6px;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:inline-flex}.conn-rename-input{background:var(--zf-surface);border:1px solid var(--zf-accent);color:var(--zf-text);border-radius:4px;padding:4px 8px;font-size:12px}.conn-detail-row td{background:var(--zf-surface);padding:16px 18px}.conn-detail-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (width<=720px){.conn-detail-grid{grid-template-columns:1fr}}.conn-detail-section{flex-direction:column;gap:10px;display:flex}.conn-detail-title{text-transform:uppercase;letter-spacing:.1em;color:var(--zf-accent);font-size:11px;font-weight:700}.conn-cap-list{flex-wrap:wrap;gap:6px;display:flex}.conn-cap-pill{color:var(--zf-link);background:#6fa9e326;border-radius:4px;padding:3px 10px;font-size:11px;font-weight:600}.conn-history-list{flex-direction:column;gap:6px;font-size:12px;display:flex}.conn-history-line{color:var(--zf-muted);gap:10px;display:flex}.conn-history-time{color:var(--zf-muted);flex-shrink:0;width:140px}.conn-actions-inline{flex-wrap:wrap;gap:8px;display:flex}.conn-form-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;margin-bottom:20px;padding:18px}.conn-form-title{color:var(--zf-text);margin-bottom:12px;font-size:14px;font-weight:700}.conn-form-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;display:flex}.conn-form-row input[type=text],.conn-form-row input[type=url]{flex:1;min-width:220px}.conn-form-hint{color:var(--zf-muted);margin-top:4px;font-size:11px}.conn-error{color:var(--zf-danger);margin-top:6px;font-size:12px}.conn-success{color:var(--zf-success);margin-top:6px;font-size:12px}.folder-browser{background:var(--zf-bg);border:1px solid var(--zf-border);border-radius:10px;flex-direction:column;gap:10px;padding:12px;display:flex}.folder-browser-toolbar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.folder-browser-path{min-width:200px;color:var(--zf-text);background:var(--zf-panel);border:1px solid var(--zf-border);text-overflow:ellipsis;white-space:nowrap;border-radius:6px;flex:1;padding:6px 8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;overflow:hidden}.folder-browser-list{border:1px solid var(--zf-border);background:var(--zf-panel);border-radius:8px;max-height:280px;padding:6px;overflow-y:auto}.folder-browser-item{text-align:left;width:100%;color:var(--zf-text);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:8px;padding:6px 8px;font-size:13px;display:flex}.folder-browser-item:hover{background:var(--zf-panel-hi);border-color:var(--zf-border)}.folder-browser-item:focus-visible{outline:2px solid var(--zf-accent);outline-offset:1px}.folder-browser-icon{color:var(--zf-accent);font-size:11px}.folder-browser-files{color:var(--zf-muted);padding:6px 8px;font-size:11px;font-style:italic}.folder-browser-empty{color:var(--zf-muted);text-align:center;padding:12px;font-size:12px;font-style:italic}.folder-browser-actions{justify-content:flex-end;gap:8px;display:flex}.signal-review{grid-template-columns:250px 1fr 380px;gap:16px;height:calc(100vh - 190px);min-height:600px;display:grid}@media (width<=1100px){.signal-review{grid-template-columns:220px 1fr}.signal-review .sr-right{display:none}}.sr-left,.sr-center,.sr-right{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;overflow-y:auto}.sr-left{padding:16px}.sr-center{flex-direction:column;padding:18px;display:flex}.sr-right{padding:18px}.sr-panel-label{letter-spacing:.13em;color:var(--zf-accent);text-transform:uppercase;margin:0 0 14px;font-size:10px;font-weight:700}.category-node{cursor:pointer;margin-bottom:6px}.category-node-header{border-radius:6px;align-items:center;gap:8px;padding:8px 10px;transition:all .15s;display:flex}.category-node-header:hover{background:#6fa9e314}.category-node.selected>.category-node-header{border-left:3px solid var(--zf-accent);background:#e6b85c1a;padding-left:7px}.category-name{color:var(--zf-text);flex:1;font-size:12px}.count-badge{color:var(--zf-link);background:#6fa9e326;border-radius:8px;padding:2px 8px;font-size:10px;font-weight:700}.count-badge.conflict{color:var(--zf-danger);background:#d6455026}.confidence-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.confidence-dot.high{background:var(--zf-success)}.confidence-dot.medium{background:var(--zf-accent)}.confidence-dot.low{background:var(--zf-danger)}.sr-list-controls{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.sr-search{flex:1;min-width:180px}.sr-filter-pills{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.filter-pill{cursor:pointer;border:1px solid var(--zf-border);color:var(--zf-link);background:0 0;border-radius:6px;padding:5px 14px;font-family:inherit;font-size:11px;font-weight:600;transition:all .2s}.filter-pill:hover{border-color:var(--zf-accent);color:var(--zf-accent)}.filter-pill.active{background:var(--zf-accent);color:var(--zf-bg);border-color:var(--zf-accent)}.sr-bulk-bar{border:1px solid var(--zf-border);color:var(--zf-link);background:#e6b85c14;border-radius:8px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;padding:10px 14px;font-size:12px;display:flex}.sr-bulk-text{flex:1}.sr-signal-list{flex-direction:column;flex:1;gap:10px;padding-right:4px;display:flex;overflow-y:auto}.signal-card{background:var(--zf-panel);border:1px solid var(--zf-border);cursor:pointer;border-left:3px solid #0000;border-radius:8px;grid-template-columns:3px auto 1fr auto;align-items:start;gap:12px;padding:14px;transition:all .2s;display:grid}.signal-card:hover{background:var(--zf-panel-hi)}.signal-card.selected{border-left-color:var(--zf-accent);background:#e6b85c14}.signal-card input[type=checkbox]{margin-top:3px}.confidence-bar{border-radius:2px;align-self:stretch;width:3px;min-height:48px}.confidence-bar.high{background:var(--zf-success)}.confidence-bar.medium{background:var(--zf-accent)}.confidence-bar.low{background:var(--zf-danger)}.signal-content{flex-direction:column;gap:6px;min-width:0;display:flex}.signal-title{color:var(--zf-text);font-size:13px;font-weight:700}.signal-meta{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.signal-pill{color:var(--zf-link);background:#6fa9e326;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600}.signal-pill.category{color:var(--zf-accent);background:#e6b85c26}.signal-pill.confidence{color:var(--zf-success);background:#2ecc7126}.signal-description{color:var(--zf-muted);font-size:11px;line-height:1.5}.signal-right{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.sr-detail-title{color:var(--zf-text);margin-bottom:12px;font-family:Playfair Display,serif;font-size:18px;font-weight:700}.sr-info-grid{background:var(--zf-surface);border-radius:8px;grid-template-columns:auto 1fr;gap:8px 14px;margin-bottom:14px;padding:12px;font-size:12px;display:grid}.sr-info-label{color:var(--zf-muted)}.sr-info-value{color:var(--zf-text);font-weight:500}.sr-section-heading{letter-spacing:.13em;color:var(--zf-accent);text-transform:uppercase;margin:14px 0 8px;font-size:10px;font-weight:700}.sr-evidence{flex-direction:column;gap:6px;display:flex}.sr-evidence-item{background:var(--zf-surface);border:1px solid var(--zf-border);color:var(--zf-text);white-space:pre-wrap;word-break:break-word;border-radius:6px;padding:8px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px}.sr-related-pills{flex-wrap:wrap;gap:6px;display:flex}.sr-action-row{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.sr-modify-form{background:var(--zf-surface);border-radius:8px;margin-top:14px;padding:12px}.sr-modify-form label{color:var(--zf-muted);margin:6px 0 3px;font-size:11px;display:block}.sr-modify-form input[type=range]{width:100%}.sr-modify-form textarea{resize:vertical;width:100%;min-height:60px}.sr-timeline{color:var(--zf-muted);flex-direction:column;gap:6px;margin-top:14px;font-size:11px;display:flex}.sr-timeline-line{gap:8px;display:flex}.sr-timeline-time{width:90px;color:var(--zf-muted);flex-shrink:0}.sr-view-toggle{gap:6px;margin-bottom:12px;display:flex}.fm-layout{grid-template-columns:1fr 340px;gap:20px;padding-bottom:80px;display:grid}@media (width<=1100px){.fm-layout{grid-template-columns:1fr}}.fm-bundle-row{background:var(--zf-surface-2,#ffffff08);border:1px solid var(--zf-border,#ffffff14);border-radius:6px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;padding:10px 14px;display:flex}.fm-bundle-label{color:var(--zf-muted);margin-right:4px;font-size:12px;font-weight:600}.bundle-apply-btn{padding:6px 10px;font-size:12px}.fm-bundle-select{background:var(--zf-panel);color:var(--zf-text);border:1px solid var(--zf-border);cursor:pointer;border-radius:6px;min-width:240px;padding:6px 10px;font-family:inherit;font-size:12px}.fm-bundle-select:hover{border-color:var(--zf-border-hi)}.fm-bundle-select:focus{border-color:var(--zf-accent);outline:none;box-shadow:0 0 0 2px #e6b85c33}.fm-bundle-hint{color:var(--zf-muted);margin-left:4px;font-size:11px;font-style:italic}.module-card-bundle-badge{text-transform:uppercase;letter-spacing:.04em;color:var(--zf-link);background:#5b9bd52e;border:1px solid #5b9bd559;border-radius:4px;align-self:flex-start;margin-top:-4px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.bundle-confirm-modal{max-width:600px}.bundle-confirm-desc{color:var(--zf-muted);margin:0 0 14px;font-size:12px;font-style:italic}.bundle-confirm-summary{background:var(--zf-surface);border:1px solid var(--zf-border);border-radius:8px;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px;padding:12px;display:grid}.bundle-confirm-stat{flex-direction:column;align-items:center;gap:4px;display:flex}.bundle-confirm-stat-num{color:var(--zf-accent);font-family:Playfair Display,serif;font-size:22px;font-weight:800}.bundle-confirm-stat-label{color:var(--zf-muted);text-transform:uppercase;letter-spacing:.06em;text-align:center;font-size:10px}.bundle-confirm-section{margin-bottom:12px}.bundle-confirm-section-muted{opacity:.7}.bundle-confirm-section-warn .bundle-confirm-heading{color:var(--zf-warn)}.bundle-confirm-heading{text-transform:uppercase;letter-spacing:.1em;color:var(--zf-accent);margin-bottom:6px;font-size:11px;font-weight:700}.bundle-preview-list{border:1px solid var(--zf-border);border-radius:6px;max-height:150px;margin:0;padding:0;list-style:none;overflow-y:auto}.bundle-preview-item{border-bottom:1px solid var(--zf-border);justify-content:space-between;padding:5px 10px;font-size:12px;display:flex}.bundle-preview-item:last-child{border-bottom:none}.bundle-preview-name{color:var(--zf-text)}.bundle-preview-loe{color:var(--zf-muted);font-size:11px}.bundle-preview-empty{color:var(--zf-muted);border:1px dashed var(--zf-border);border-radius:6px;padding:8px 10px;font-size:12px;font-style:italic}.bundle-confirm-loe-row{background:var(--zf-surface);border:1px solid var(--zf-border);color:var(--zf-muted);border-radius:6px;margin-top:12px;padding:10px 12px;font-size:12px}.bundle-confirm-loe-row strong{color:var(--zf-text);font-weight:700}.bundle-confirm-arrow{color:var(--zf-accent);padding:0 4px}.fm-section{margin-bottom:32px}.fm-section-heading{color:var(--zf-text);margin:0 0 16px;font-family:Playfair Display,serif;font-size:18px;font-weight:700}.fm-cards{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;display:grid}.module-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;flex-direction:column;gap:12px;padding:18px;display:flex}.module-card.enabled{border-color:var(--zf-accent)}.module-card.module-card-suggested{position:relative;box-shadow:inset 0 0 0 1px #d4af3759}.module-card-suggested-badge{color:#0a1422;letter-spacing:.04em;text-transform:uppercase;z-index:1;background:linear-gradient(135deg,#d4af37 0%,#e9c964 100%);border-radius:10px;padding:3px 10px;font-size:10px;font-weight:700;position:absolute;top:-10px;right:12px;box-shadow:0 2px 6px #d4af3759}.fm-loe-card{background:linear-gradient(180deg, var(--zf-panel) 0%, var(--zf-surface) 100%)}.fm-loe-big{align-items:baseline;gap:4px;margin:8px 0 2px;display:flex}.fm-loe-big-num{color:var(--zf-accent);font-family:Playfair Display,serif;font-size:30px;font-weight:800}.fm-loe-big-unit{color:var(--zf-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.fm-loe-weeks{color:var(--zf-muted);border-bottom:1px solid var(--zf-border);margin-bottom:10px;padding-bottom:10px;font-size:11px;font-style:italic}.fm-loe-row{color:var(--zf-text);justify-content:space-between;align-items:center;padding:3px 0;font-size:12px;display:flex}.fm-loe-row span{color:var(--zf-muted)}.fm-loe-count{border-top:1px dashed var(--zf-border);color:var(--zf-muted);margin-top:6px;padding-top:6px;font-size:11px}.fm-stat-pill.fm-stat-suggested{color:var(--zf-accent);background:#d4af3726;border-color:#d4af374d}.fm-stat-pill.fm-stat-total{color:var(--zf-link);background:#6fa9e31f;font-weight:600}.module-card-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.module-title{color:var(--zf-text);font-size:15px;font-weight:700}.module-source-badge{text-transform:uppercase;letter-spacing:.08em;color:var(--zf-link);background:#6fa9e326;border-radius:4px;margin-top:6px;padding:3px 8px;font-size:10px;font-weight:700;display:inline-block}.module-source-badge.synthezoid{color:var(--zf-accent);background:#e6b85c26}.module-source-badge.devzoid{color:var(--zf-info);background:#5b9bd526}.toggle-switch{width:40px;height:22px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:var(--zf-surface);border:1px solid var(--zf-border);border-radius:22px;transition:all .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--zf-muted);border-radius:50%;width:14px;height:14px;transition:all .2s;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.toggle-slider{border-color:var(--zf-accent);background:#e6b85c2e}.toggle-switch input:checked+.toggle-slider:before{background:var(--zf-accent);transform:translate(18px)}.module-signals{flex-wrap:wrap;gap:6px;display:flex}.module-conf{color:var(--zf-muted);grid-template-columns:auto 1fr auto;align-items:center;gap:8px;font-size:11px;display:grid}.module-conf-bar{background:var(--zf-surface);border-radius:2px;height:4px;overflow:hidden}.module-conf-fill{background:var(--zf-success);height:100%}.module-loe{grid-template-columns:auto 1fr auto;align-items:center;gap:8px;display:grid}.loe-cells{gap:3px;display:flex}.loe-cell{background:var(--zf-surface);border:1px solid var(--zf-border);border-radius:2px;width:14px;height:8px}.loe-cell.active{background:var(--zf-accent);border-color:var(--zf-accent)}.module-deps{color:var(--zf-muted);font-size:11px}.fm-sidebar{flex-direction:column;gap:16px;display:flex}.fm-sidebar .card{padding:16px}.fm-sidebar-heading{text-transform:uppercase;letter-spacing:.13em;color:var(--zf-accent);margin-bottom:12px;font-size:12px;font-weight:700}.gap-item{border-bottom:1px solid var(--zf-border);padding:10px;font-size:12px}.gap-item:last-child{border-bottom:none}.gap-item-title{color:var(--zf-text);font-weight:600}.gap-item-meta{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.gap-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700}.gap-badge.extension{color:var(--zf-success);background:#2ecc7126}.gap-badge.integration{color:var(--zf-info);background:#5b9bd526}.gap-badge.custom_module,.gap-badge.custom-module{color:var(--zf-danger);background:#d6455026}.gap-badge.industry{color:var(--zf-accent);background:#e6b85c26}.priority-pill{color:var(--zf-muted);background:#8699b026;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600}.priority-pill.high{color:var(--zf-danger);background:#d6455026}.priority-pill.med,.priority-pill.medium{color:var(--zf-accent);background:#e6b85c26}.fm-summary-bar{background:var(--zf-header-bg);border-top:1px solid var(--zf-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin:20px -28px -28px;padding:14px 28px;display:flex;position:sticky;bottom:0;left:0;right:0}.fm-stat-pills{flex-wrap:wrap;gap:10px;display:flex}.fm-stat-pill{background:var(--zf-panel);border:1px solid var(--zf-border);color:var(--zf-muted);border-radius:6px;padding:6px 12px;font-size:12px}.fm-stat-pill strong{color:var(--zf-text);font-weight:700}.modal-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;width:100%;max-width:520px;max-height:90vh;padding:22px;overflow-y:auto}.modal-title{color:var(--zf-text);margin:0 0 16px;font-family:Playfair Display,serif;font-size:20px;font-weight:700}.modal-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.modal-close{color:var(--zf-muted);cursor:pointer;background:0 0;border:none;font-size:18px}.spec-layout{grid-template-columns:260px 1fr;gap:20px;display:grid}@media (width<=900px){.spec-layout{grid-template-columns:1fr}}.spec-project-scope{background:var(--zf-panel);border:1px solid var(--zf-border);border-left:3px solid var(--zf-accent);border-radius:6px;align-items:center;gap:10px;margin-bottom:14px;padding:10px 14px;display:flex}.spec-project-scope-label{text-transform:uppercase;letter-spacing:.12em;color:var(--zf-muted);font-size:10px;font-weight:700}.spec-project-scope-name{color:var(--zf-text);font-family:Playfair Display,serif;font-size:14px;font-weight:700}.spec-project-scope-industry{color:var(--zf-accent);text-transform:uppercase;letter-spacing:.08em;background:#e6b85c1f;border-radius:10px;padding:2px 8px;font-size:11px}.spec-project-scope-hint{color:var(--zf-muted);margin-left:auto;font-size:11px;font-style:italic}.spec-sidebar{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;max-height:70vh;padding:16px;overflow-y:auto}.spec-nav-item{cursor:pointer;color:var(--zf-text);border-radius:6px;align-items:center;gap:10px;padding:8px 10px;font-size:13px;transition:all .15s;display:flex}.spec-nav-item:hover{background:var(--zf-surface)}.spec-nav-item.active{color:var(--zf-accent);background:#e6b85c1a}.spec-nav-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.spec-nav-dot.populated{background:var(--zf-success)}.spec-nav-dot.partial{background:var(--zf-accent)}.spec-nav-dot.empty{background:var(--zf-muted)}.spec-nav-actions{gap:4px;margin-left:auto;display:flex}.spec-nav-controls{border-top:1px solid var(--zf-border);flex-wrap:wrap;gap:8px;margin-top:14px;padding-top:14px;display:flex}.spec-main{flex-direction:column;gap:16px;display:flex}.spec-controls{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;flex-wrap:wrap;align-items:center;gap:10px;padding:14px;display:flex}.spec-controls input[type=text]{flex:1;min-width:160px}.spec-warning{border-left:3px solid var(--zf-accent);color:var(--zf-text);background:#e6b85c1a;border-radius:6px;padding:10px 14px;font-size:13px}.spec-error{border-left:3px solid var(--zf-danger);color:var(--zf-text);background:#d645501a;border-radius:6px;padding:10px 14px;font-size:13px}.spec-success{border-left:3px solid var(--zf-success);color:var(--zf-text);background:#2ecc711a;border-radius:6px;padding:10px 14px;font-size:13px}.spec-preview-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;max-height:60vh;padding:24px;overflow-y:auto}.spec-preview-card h3{color:var(--zf-accent);margin:16px 0 10px;font-family:Playfair Display,serif;font-size:18px}.spec-preview-card h3:first-child{margin-top:0}.spec-preview-card table{border-collapse:collapse;width:100%;margin:8px 0;font-size:12px}.spec-preview-card th,.spec-preview-card td{border:1px solid var(--zf-border);text-align:left;padding:6px 10px}.spec-preview-card th{background:var(--zf-surface);color:var(--zf-muted)}.spec-version-table{border-collapse:collapse;width:100%;font-size:13px}.spec-version-table th,.spec-version-table td{border-bottom:1px solid var(--zf-border);text-align:left;padding:10px 12px}.spec-version-table th{background:var(--zf-surface);color:var(--zf-accent);text-transform:uppercase;letter-spacing:.08em;font-size:11px}.diff-added{color:var(--zf-success);background:#2ecc7126;border-radius:3px;padding:2px 6px}.diff-removed{color:var(--zf-danger);background:#d6455026;border-radius:3px;padding:2px 6px;text-decoration:line-through}.sidebar-label{text-transform:uppercase;letter-spacing:.13em;color:var(--zf-accent);margin-bottom:12px;font-size:10px;font-weight:700}.section-list{margin:0;padding:0;list-style:none}.spec-nav-item{cursor:pointer;color:var(--zf-muted);border-left:3px solid #0000;border-radius:6px;align-items:center;gap:10px;margin-bottom:4px;padding:10px 12px;font-size:12px;transition:all .2s;display:flex}.spec-nav-item:hover{color:var(--zf-link);background:#6ea9e314}.spec-nav-item.active{color:var(--zf-accent);border-left-color:var(--zf-accent);background:#e6b85c1a}.spec-nav-title{flex:1}.spec-nav-tag{text-transform:uppercase;letter-spacing:.08em;color:var(--zf-muted);background:var(--zf-surface);border-radius:3px;padding:2px 6px;font-size:9px}.spec-nav-add-input{background:var(--zf-surface);border:1px solid var(--zf-border);color:var(--zf-text);border-radius:6px;flex:1;min-width:0;padding:6px 8px;font-size:12px}.version-input{color:var(--zf-muted);align-items:center;gap:8px;font-size:12px;display:flex}.version-input input{background:var(--zf-surface);border:1px solid var(--zf-border);color:var(--zf-text);border-radius:6px;width:80px;padding:8px 12px;font-size:12px}.spec-controls-meta{color:var(--zf-muted);letter-spacing:.03em;margin-left:auto;font-size:11px}.generate-btn{background:var(--zf-accent);color:var(--zf-bg);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;border:none;border-radius:8px;padding:12px 28px;font-size:13px;font-weight:700;transition:all .2s}.generate-btn:hover:not(:disabled){background:var(--zf-accent-hi);transform:translateY(-1px)}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.warning-icon{margin-right:4px;font-size:16px}.spec-warning{align-items:center;gap:8px;display:flex}.preview-section{margin-bottom:8px}.section-heading{text-transform:uppercase;letter-spacing:.08em;color:var(--zf-accent);margin-bottom:12px;font-size:13px;font-weight:700}.spec-preview-card{color:#2c3e50;border:1px solid var(--zf-border);background:#fff;border-radius:12px;max-width:800px;max-height:60vh;margin:0 auto;padding:32px;font-size:13px;line-height:1.7;overflow-y:auto}.spec-cover{text-align:center;border-bottom:2px solid var(--zf-accent);margin-bottom:32px;padding-bottom:24px}.spec-logo-area{background:var(--zf-accent);width:60px;height:60px;color:var(--zf-bg);border-radius:8px;justify-content:center;align-items:center;margin:0 auto 16px;font-family:Playfair Display,serif;font-size:22px;font-weight:700;display:flex}.spec-title-main{color:#1e2a38;margin:12px 0 6px;font-family:Playfair Display,serif;font-size:28px;font-weight:700}.spec-subtitle{color:var(--zf-link);margin-bottom:4px;font-size:14px}.spec-date{color:var(--zf-muted);margin-top:16px;font-size:11px}.spec-doc-heading{margin:20px 0 10px;font-family:Playfair Display,serif;font-size:18px;font-weight:700;color:#1e2a38!important}.spec-doc-text{color:#4a5568;text-align:left;margin-bottom:12px}.spec-version-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;padding:18px}.action-buttons{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.action-buttons .btn-small,.btn-small{border:1px solid var(--zf-border);color:var(--zf-link);cursor:pointer;background:0 0;border-radius:6px;align-items:center;padding:6px 12px;font-size:11px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.action-buttons .btn-small:hover,.btn-small:hover{background:#6ea9e31a}.spec-diff-radio{color:var(--zf-muted);cursor:pointer;align-items:center;gap:2px;font-size:10px;display:inline-flex}.version-row.selected{background:#e6b85c14}.version-row.focused{box-shadow:inset 3px 0 0 var(--zf-gold);background:#e6b85c2e}.version-row:hover{background:#6ea9e30d}a.spec-version-link{color:var(--zf-text);font-weight:600;text-decoration:none}a.spec-version-link:hover{color:var(--zf-link);text-decoration:underline}.spec-diff-actions{justify-content:flex-end;margin-top:12px;display:flex}.diff-preview{background:var(--zf-surface);border:1px solid var(--zf-border);border-radius:8px;margin-top:12px;padding:12px 16px;font-family:ui-monospace,Monaco,monospace;font-size:12px;line-height:1.7}.diff-preview-head{border-bottom:1px solid var(--zf-border);color:var(--zf-muted);text-transform:uppercase;letter-spacing:.08em;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;font-family:DM Sans,sans-serif;font-size:11px;display:flex}.diff-row{color:var(--zf-text);padding:2px 0}.diff-empty{color:var(--zf-muted);font-style:italic}.brand-grid{grid-template-columns:minmax(380px,1fr) 1fr;gap:24px;display:grid}@media (width<=1000px){.brand-grid{grid-template-columns:1fr}}.brand-form,.brand-previews{flex-direction:column;gap:16px;display:flex}.brand-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;padding:18px}.brand-card h3,.brand-previews h3{text-transform:uppercase;letter-spacing:.13em;color:var(--zf-accent);margin:0 0 12px;font-size:12px;font-weight:700}.brand-field{flex-direction:column;gap:6px;margin-bottom:10px;display:flex}.brand-field-label{color:var(--zf-muted);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:600}.brand-color-row{grid-template-columns:120px 40px 1fr;align-items:center;gap:10px;margin-bottom:8px;display:grid}.brand-color-label{color:var(--zf-muted);font-size:12px}.brand-color-row input[type=color]{border:1px solid var(--zf-border);cursor:pointer;background:0 0;border-radius:6px;width:40px;height:32px;padding:0}.brand-color-hex{background:var(--zf-surface);border:1px solid var(--zf-border);color:var(--zf-text);border-radius:6px;padding:6px 8px;font-family:ui-monospace,monospace;font-size:12px}.brand-logo-uploader{background:var(--zf-surface);border:1px dashed var(--zf-border);border-radius:8px;align-items:center;gap:12px;margin-bottom:10px;padding:12px;display:flex}.brand-logo-preview{background:#fff;border-radius:4px;max-width:180px;max-height:44px;padding:4px}.brand-logo-empty{color:var(--zf-muted);font-size:12px;font-style:italic}.brand-logo-sizes{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px;display:grid}.brand-preview-card{border-radius:8px;overflow:hidden;box-shadow:0 4px 14px #00000040}.brand-doc-preview{color:#333;background:#fff;border-radius:8px;padding:24px;box-shadow:0 4px 14px #00000040}.brand-contrast-list{flex-direction:column;gap:8px;display:flex}.contrast-badge{background:var(--zf-surface);border-left:3px solid var(--zf-border);border-radius:6px;align-items:flex-start;gap:10px;padding:10px 12px;font-size:12px;display:flex}.contrast-mark{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:inline-flex}.contrast-pass .contrast-mark{background:var(--zf-success)}.contrast-warn .contrast-mark{background:var(--zf-accent)}.contrast-fail .contrast-mark{background:var(--zf-danger)}.contrast-pass{border-left-color:var(--zf-success)}.contrast-warn{border-left-color:var(--zf-accent)}.contrast-fail{border-left-color:var(--zf-danger)}.contrast-label{color:var(--zf-text);font-weight:600}.contrast-meta{color:var(--zf-muted);margin-top:2px;font-size:11px}.contrast-suggest{color:var(--zf-muted);margin-top:3px;font-size:11px}.contrast-suggest code{background:#ffffff0f;border-radius:3px;padding:1px 4px}.brand-actions{border-top:1px solid var(--zf-border);flex-wrap:wrap;gap:8px;margin-top:4px;padding-top:16px;display:flex}.brand-message{border-radius:8px;margin-bottom:12px;padding:10px 14px;font-size:13px}.brand-message-ok{color:var(--zf-success);background:#2ecc711a;border:1px solid #2ecc7166}.brand-message-error{color:var(--zf-danger);background:#d645501a;border:1px solid #d6455066}.brand-message-info{color:var(--zf-link);border:1px solid var(--zf-border);background:#6fa9e31a}.form-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;height:fit-content;padding:24px}.form-section{margin-bottom:24px}.form-section:last-child{margin-bottom:0}.form-label{text-transform:uppercase;letter-spacing:.13em;color:var(--zf-accent);margin-bottom:12px;font-size:10px;font-weight:700;display:block}.form-group{margin-bottom:14px}.form-group label{color:var(--zf-muted);margin-bottom:6px;font-size:12px;font-weight:500;display:block}.form-group input,.form-group select{background:var(--zf-bg);border:1px solid var(--zf-border);width:100%;color:var(--zf-text);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:12px}.form-group input:focus,.form-group select:focus{border-color:var(--zf-accent);outline:none;box-shadow:0 0 0 3px #e6b85c1a}.logo-upload-area{border:2px dashed var(--zf-border);text-align:center;cursor:pointer;background:#1c3a5e4d;border-radius:8px;padding:22px;transition:all .2s}.logo-upload-area:hover{border-color:var(--zf-link);background:#6ea9e31a}.upload-icon{margin-bottom:6px;font-size:28px}.upload-text{color:var(--zf-muted);margin-bottom:4px;font-size:12px}.upload-hint{color:var(--zf-muted);opacity:.7;font-size:10px}.logo-preview{color:#fff;border-radius:8px;justify-content:center;align-items:center;width:60px;height:60px;margin:12px auto 0;font-family:Playfair Display,serif;font-size:20px;font-weight:700;display:flex}.logo-preview-img{background:#fff;border-radius:8px;max-width:180px;max-height:60px;margin:12px auto 0;padding:6px;display:block}.logo-sizes{grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;display:grid}.color-row{background:#1c3a5e4d;border-radius:6px;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;margin-bottom:6px;padding:10px 12px;display:grid}.color-label{color:var(--zf-muted);font-size:12px;font-weight:500}.color-swatch-wrap{cursor:pointer;width:32px;height:32px;display:inline-block;position:relative}.color-swatch-input{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.color-swatch{border:1px solid var(--zf-border);border-radius:6px;width:32px;height:32px;display:block}.color-hex{background:var(--zf-surface);border:1px solid var(--zf-border);color:var(--zf-link);border-radius:6px;padding:6px 8px;font-family:ui-monospace,Monaco,monospace;font-size:11px;font-weight:600}.font-preview{color:var(--zf-text);text-align:center;background:#1c3a5e4d;border-radius:6px;margin-top:8px;padding:14px;font-size:14px}.action-bar{border-top:1px solid var(--zf-border);flex-wrap:wrap;gap:10px;margin-top:16px;padding-top:16px;display:flex}.action-bar .btn-primary,.action-bar .btn-ghost,.action-bar .btn-file{text-transform:uppercase;letter-spacing:.08em;cursor:pointer;text-align:center;border-radius:8px;flex:1;min-width:110px;padding:10px 20px;font-family:inherit;font-size:11px;font-weight:700;transition:all .2s}.action-bar .btn-primary{background:var(--zf-accent);color:var(--zf-bg);border:none}.action-bar .btn-primary:hover{background:var(--zf-accent-hi);transform:translateY(-1px)}.action-bar .btn-ghost,.action-bar .btn-file{color:var(--zf-link);border:1px solid var(--zf-border);background:0 0}.action-bar .btn-ghost:hover,.action-bar .btn-file:hover{border-color:var(--zf-link);background:#6ea9e31a}.action-bar .btn-ghost.btn-danger{color:var(--zf-danger);border-color:var(--zf-danger)}.brand-reset-confirm{border:1px solid var(--zf-danger);background:#d6455014;border-radius:8px;flex:100%;align-items:center;gap:6px;padding:6px 10px;display:inline-flex}.brand-reset-prompt{color:var(--zf-text);flex:1;font-size:11px}.preview-container{flex-direction:column;gap:20px;display:flex}.preview-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;padding:20px}.preview-title{text-transform:uppercase;letter-spacing:.08em;color:var(--zf-accent);margin-bottom:14px;font-size:12px;font-weight:700}.ui-preview-header{border-radius:8px 8px 0 0;justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.ui-preview-brand{color:#fff;font-family:Playfair Display,serif;font-size:15px;font-weight:700}.ui-preview-dot{background:#fff3;border-radius:4px;width:22px;height:22px}.ui-preview-nav{background:#0e2847;padding:0;display:flex}.ui-preview-nav-item{color:#8bb8dd;border-bottom:2px solid #0000;padding:8px 12px;font-size:10px;font-weight:600}.ui-preview-content{background:var(--zf-panel);border-radius:0 0 8px 8px;padding:14px}.ui-preview-card{border:1px solid var(--zf-border);border-radius:8px;margin-bottom:8px;padding:10px;font-size:11px}.ui-preview-button{color:#fff;cursor:pointer;border:none;border-radius:6px;margin-top:6px;padding:8px 14px;font-size:11px;font-weight:700}.doc-preview{color:#2c3e50;background:#fff;border-radius:8px;padding:18px;font-size:11px}.doc-header{color:#fff;border-radius:4px;justify-content:center;align-items:center;height:54px;margin-bottom:12px;font-weight:700;display:flex}.doc-title{margin-bottom:8px;font-family:Playfair Display,serif;font-size:14px;font-weight:700}.doc-table{border-collapse:collapse;width:100%;margin-top:8px}.doc-table th{color:#fff;text-align:left;padding:6px;font-size:10px;font-weight:700}.doc-table td{color:#2c3e50;border-bottom:1px solid #e0e0e0;padding:6px;font-size:10px}.contrast-list{margin:0;padding:0;list-style:none}.contrast-item{background:#1c3a5e4d;border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:6px;padding:10px 12px;font-size:12px;display:flex}.contrast-item .contrast-label{color:var(--zf-muted);flex:1;font-weight:500}.contrast-item .contrast-badge{text-transform:uppercase;letter-spacing:.08em;background:var(--zf-surface);border:none;border-radius:4px;align-items:center;gap:6px;padding:4px 10px;font-size:10px;font-weight:700;display:inline-flex}.contrast-item .badge-pass{color:var(--zf-success);background:#2ecc7133}.contrast-item .badge-warn{color:var(--zf-accent);background:#e6b85c33}.contrast-item .badge-fail{color:var(--zf-danger);background:#d6455033}.contrast-ratio{color:var(--zf-link);margin-left:4px;font-size:11px;font-weight:600}.admin-tabs{border-bottom:1px solid var(--zf-border);gap:28px;margin-bottom:24px;display:flex}.admin-tab{color:var(--zf-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 0;font-family:inherit;font-size:13px;font-weight:500}.admin-tab:hover{color:var(--zf-text)}.admin-tab-active{color:var(--zf-accent);border-bottom-color:var(--zf-accent)}.admin-body{max-width:1100px}.admin-section h3{text-transform:uppercase;letter-spacing:.13em;color:var(--zf-accent);margin:0 0 16px;font-size:12px;font-weight:700}.admin-section h4{text-transform:uppercase;letter-spacing:.1em;color:var(--zf-muted);margin:16px 0 12px;font-size:11px;font-weight:700}.admin-section>*+*{margin-top:4px}.admin-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;margin-bottom:16px;padding:20px}.admin-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}@media (width<=600px){.admin-grid{grid-template-columns:1fr}}.admin-field{flex-direction:column;gap:6px;display:flex}.admin-field span{color:var(--zf-muted);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:600}.admin-meters{flex-direction:column;gap:12px;display:flex}.usage-meter{background:var(--zf-surface);border:1px solid var(--zf-border);border-radius:8px;padding:12px 14px}.meter-header{justify-content:space-between;margin-bottom:8px;font-size:12px;display:flex}.meter-label{color:var(--zf-text);font-weight:600}.meter-count{color:var(--zf-muted);font-family:ui-monospace,monospace}.meter-track{background:var(--zf-bg);border-radius:3px;height:6px;overflow:hidden}.meter-fill{background:var(--zf-info);height:100%;transition:width .2s}.meter-fill.meter-warn{background:var(--zf-accent)}.meter-fill.meter-critical{background:var(--zf-danger)}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--zf-border);padding:12px 14px}.admin-table th{background:var(--zf-surface);color:var(--zf-accent);text-transform:uppercase;letter-spacing:.1em;font-size:11px;font-weight:700}.admin-table tr:last-child>td{border-bottom:none}.admin-table td select{background:var(--zf-surface);border:1px solid var(--zf-border);color:var(--zf-text);border-radius:4px;padding:4px 8px;font-size:12px}.admin-empty{color:var(--zf-muted);text-align:center;padding:16px;font-style:italic}.admin-invite-row{flex-wrap:wrap;gap:8px;display:flex}.admin-invite-row input[type=email]{flex:1;min-width:220px}.admin-audit-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.admin-audit-filters{flex-wrap:wrap;gap:8px;display:flex}.admin-audit-integrity{margin:8px 0;font-size:12px}.integrity-ok{color:var(--zf-success)}.integrity-warn{color:var(--zf-danger)}.admin-audit-row{cursor:pointer}.admin-audit-row-open{background:var(--zf-panel-hi)}.admin-audit-toggle{color:var(--zf-muted);font-size:12px}.admin-audit-detail-row td{background:var(--zf-surface);padding:14px}.admin-audit-detail{font-size:12px}.admin-audit-detail h5{text-transform:uppercase;color:var(--zf-accent);letter-spacing:.08em;margin:0 0 8px;font-size:11px}.admin-audit-hash{word-break:break-all;margin-top:6px;font-family:ui-monospace,monospace;font-size:11px}.admin-detail-block{flex-direction:column;gap:4px;display:flex}.admin-detail-line{font-size:12px}.admin-detail-key{color:var(--zf-muted);font-weight:600}.admin-detail-value{color:var(--zf-text);font-family:ui-monospace,monospace}.admin-audit-footer{color:var(--zf-muted);margin-top:10px;font-size:12px}.admin-health-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:14px 0;display:grid}.admin-health-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;padding:16px}.admin-health-card h4{text-transform:uppercase;color:var(--zf-accent);letter-spacing:.1em;margin:0 0 10px;font-size:11px}.admin-health-card div{color:var(--zf-text);margin-top:4px;font-size:13px}.health-status{border-radius:8px;margin-bottom:12px;padding:10px 14px;font-size:13px}.health-ok{color:var(--zf-success);background:#2ecc711f}.health-warn{color:var(--zf-accent);background:#e6b85c1f}.health-down{color:var(--zf-danger);background:#d645501f}.admin-actions{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.subtab-nav{background:var(--zf-panel);border-bottom:1px solid var(--zf-border);margin:-24px -24px 24px;padding:0 24px;display:flex}.subtab{color:var(--zf-muted);cursor:pointer;text-transform:uppercase;letter-spacing:.08em;background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 16px;font-family:inherit;font-size:12px;font-weight:600;transition:all .2s}.subtab:hover{color:var(--zf-link)}.subtab.active{color:var(--zf-accent);border-bottom-color:var(--zf-accent)}.admin-main{padding:0}.admin-section{margin-bottom:28px}.admin-section:last-child{margin-bottom:0}.section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--zf-accent);margin-bottom:14px;font-size:13px;font-weight:700}.form-grid{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;padding:22px;display:grid}.form-grid .form-group{margin-bottom:0}@media (width<=700px){.form-grid{grid-template-columns:1fr}}.usage-grid{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px;display:grid}@media (width<=800px){.usage-grid{grid-template-columns:1fr}}.usage-item{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:8px;padding:14px}.usage-label{color:var(--zf-text);margin-bottom:6px;font-size:12px;font-weight:600}.usage-text{color:var(--zf-muted);margin-bottom:10px;font-size:12px;font-weight:500}.usage-bar{background:#0f1b2a;border-radius:4px;height:8px;overflow:hidden}.usage-fill{border-radius:4px;height:100%;transition:width .3s}.usage-fill.blue{background:var(--zf-info)}.usage-fill.amber{background:var(--zf-accent)}.usage-fill.green{background:var(--zf-success)}.usage-fill.red{background:var(--zf-danger)}.admin-btn-primary{background:var(--zf-accent);color:var(--zf-bg);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-family:inherit;font-size:12px;font-weight:700;transition:all .2s}.admin-btn-primary:hover{background:var(--zf-accent-hi);transform:translateY(-1px)}.data-table{border-collapse:collapse;background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;width:100%;margin-bottom:18px;overflow:hidden}.data-table thead{background:var(--zf-bg)}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--zf-accent);border-bottom:1px solid var(--zf-border);padding:12px 16px;font-size:11px;font-weight:700}.data-table td{color:var(--zf-text);border-bottom:1px solid var(--zf-border);padding:12px 16px;font-size:12px}.data-table tbody tr:hover{background:#6ea9e30d}.data-table tbody tr:last-child>td{border-bottom:none}.role-select{background:var(--zf-bg);border:1px solid var(--zf-border);color:var(--zf-text);cursor:pointer;border-radius:6px;padding:6px 10px;font-family:inherit;font-size:11px}.role-select:focus{border-color:var(--zf-accent);outline:none}.role-select:disabled{opacity:.7;cursor:not-allowed}.badge{text-transform:uppercase;letter-spacing:.08em;border-radius:4px;padding:4px 10px;font-size:10px;font-weight:700;display:inline-block}.badge-success{color:var(--zf-success);background:#2ecc7133}.badge-warning{color:var(--zf-accent);background:#e6b85c33}.badge-danger{color:var(--zf-danger);background:#d6455033}.badge-info{color:var(--zf-info);background:#5b9bd533}.btn-small.danger{color:var(--zf-danger);border-color:#d645504d}.btn-small.danger:hover{background:#d645501a}.btn-small:disabled{opacity:.5;cursor:not-allowed}.invite-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;grid-template-columns:1fr 1fr auto;align-items:flex-end;gap:14px;margin-bottom:18px;padding:22px;display:grid}.invite-card .form-group{margin-bottom:0}@media (width<=720px){.invite-card{grid-template-columns:1fr}}.pending-invites{border-top:1px solid var(--zf-border);margin-top:14px;padding-top:14px}.pending-label{text-transform:uppercase;letter-spacing:.08em;color:var(--zf-muted);margin-bottom:10px;font-size:11px;font-weight:700}.invite-item{border-bottom:1px solid var(--zf-border);justify-content:space-between;align-items:center;padding:10px 0;font-size:12px;display:flex}.invite-item:last-child{border-bottom:none}.invite-email{color:var(--zf-text)}.invite-status{color:var(--zf-muted)}.filter-bar{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:18px;padding:16px;display:flex}.filter-group{flex-direction:column;flex:1;gap:6px;display:flex}.filter-group label{text-transform:uppercase;letter-spacing:.08em;color:var(--zf-accent);font-size:10px;font-weight:700}.filter-group input,.filter-group select{background:var(--zf-bg);border:1px solid var(--zf-border);color:var(--zf-text);border-radius:6px;padding:8px 12px;font-family:inherit;font-size:12px}.export-btn{color:var(--zf-link);border:1px solid var(--zf-border);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;background:0 0;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:11px;font-weight:600;transition:all .2s}.export-btn:hover{background:#6ea9e31a}.integrity-badge{border:1px solid var(--zf-success);color:var(--zf-success);background:#2ecc711a;border-radius:6px;align-items:center;gap:8px;margin-bottom:16px;padding:8px 12px;font-size:11px;font-weight:600;display:inline-flex}.integrity-badge.integrity-warn{border-color:var(--zf-accent);color:var(--zf-accent);background:#e6b85c1a}.integrity-badge .integrity-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.audit-row{cursor:pointer}.audit-row.expanded{background:#e6b85c0d}.expand-toggle{color:var(--zf-link);text-align:center;width:18px;font-size:11px;display:inline-block}.detail-row td{background:#0f1b2a;padding:0}.detail-cell{padding:16px}.detail-content{grid-template-columns:160px 1fr;gap:10px 16px;font-size:12px;display:grid}.detail-item{display:contents}.detail-key{color:var(--zf-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:500}.detail-value{color:var(--zf-text);word-break:break-word;font-size:12px}.detail-value.audit-hash{color:var(--zf-link);font-family:ui-monospace,Monaco,monospace;font-size:11px}.audit-footer{color:var(--zf-muted);text-align:right;margin-top:8px;font-size:11px}.status-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:12px;align-items:center;gap:14px;margin-bottom:20px;padding:18px 20px;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px;display:inline-block}.status-text{font-size:17px;font-weight:700}.health-grid{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px;display:grid}@media (width<=800px){.health-grid{grid-template-columns:1fr}}.health-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:8px;padding:16px}.health-label{text-transform:uppercase;letter-spacing:.05em;color:var(--zf-muted);margin-bottom:8px;font-size:11px;font-weight:700}.health-value{color:var(--zf-text);margin-bottom:4px;font-size:14px;font-weight:700}.health-card .health-status{color:var(--zf-muted);background:0 0;margin:0;padding:0;font-size:11px;font-weight:500}.health-sync-header{justify-content:space-between;align-items:center;gap:12px;margin:20px 0 14px;display:flex}.health-sync-header .section-title{margin:0}.refresh-btn{color:var(--zf-link);border:1px solid var(--zf-border);cursor:pointer;background:0 0;border-radius:6px;padding:8px 14px;font-family:inherit;font-size:11px;font-weight:600;transition:all .2s}.refresh-btn:hover{border-color:var(--zf-link);background:#6ea9e31a}.toast-host{z-index:9000;pointer-events:none;flex-direction:column;gap:10px;max-width:420px;display:flex;position:fixed;bottom:20px;right:20px}.toast{pointer-events:auto;background:var(--zf-panel-hi);min-width:260px;color:var(--zf-text);border:1px solid var(--zf-border);border-radius:8px;align-items:center;gap:10px;padding:12px 14px;font-size:13px;animation:.18s ease-out toast-in;display:flex;box-shadow:0 8px 24px #00000059}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;font-weight:700;display:inline-flex}.toast-success{border-left:3px solid var(--zf-success)}.toast-success .toast-icon{color:var(--zf-success);background:#2ecc7126}.toast-error{border-left:3px solid var(--zf-danger)}.toast-error .toast-icon{color:var(--zf-danger);background:#d6455026}.toast-warning{border-left:3px solid var(--zf-warn)}.toast-warning .toast-icon{color:var(--zf-warn);background:#e6b85c26}.toast-info{border-left:3px solid var(--zf-info)}.toast-info .toast-icon{color:var(--zf-info);background:#5b9bd526}.toast-msg{flex:1;line-height:1.35}.toast-action{border:1px solid var(--zf-border);color:var(--zf-link);cursor:pointer;background:0 0;border-radius:4px;padding:4px 10px;font-family:inherit;font-size:11px;font-weight:600}.toast-action:hover{border-color:var(--zf-link);background:#6ea9e31a}.toast-close{color:var(--zf-muted);cursor:pointer;background:0 0;border:0;padding:0 4px;font-size:18px;line-height:1}.toast-close:hover{color:var(--zf-text)}.zf-empty{border:1px dashed var(--zf-border);text-align:center;background:var(--zf-panel);border-radius:10px;margin:16px 0;padding:32px 28px}.zf-empty-title{color:var(--zf-text);margin:0 0 8px;font-family:Playfair Display,serif;font-size:18px}.zf-empty-body{color:var(--zf-muted);max-width:480px;margin:0 auto 16px;font-size:13px;line-height:1.5}.zf-empty-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.zf-empty-steps{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;margin-top:14px;display:flex}.zf-step{color:var(--zf-muted);border:1px solid var(--zf-border);background:var(--zf-surface);border-radius:999px;padding:4px 10px;font-size:11px}.zf-step.zf-step-active{border-color:var(--zf-accent);color:var(--zf-accent)}.zf-step-sep{color:var(--zf-muted);font-size:12px}.eb-shell{justify-content:center;padding:48px 24px;display:flex}.eb-card{border:1px solid var(--zf-border);background:var(--zf-surface);border-radius:12px;width:100%;max-width:520px;padding:24px 28px;box-shadow:0 8px 24px #0000002e}.eb-title{color:var(--zf-text);margin:0 0 8px;font-family:Playfair Display,serif;font-size:22px}.eb-body{color:var(--zf-muted);margin:0 0 16px;font-size:13px;line-height:1.5}.eb-detail{background:var(--zf-bg);border:1px solid var(--zf-border);color:var(--zf-text);white-space:pre-wrap;word-break:break-word;border-radius:6px;max-height:120px;margin:0 0 16px;padding:10px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;overflow:auto}.eb-actions{justify-content:flex-end;gap:10px;display:flex}.shortcut-backdrop{z-index:2000;background:#050c16bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.shortcut-panel{background:var(--zf-panel);border:1px solid var(--zf-border-hi);border-radius:12px;width:min(640px,90vw);max-height:80vh;padding:20px;overflow:auto;box-shadow:0 12px 40px #00000080}.shortcut-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.shortcut-header h2{color:var(--zf-accent);margin:0;font-family:Playfair Display,serif;font-size:22px}.shortcut-table{border-collapse:collapse;width:100%;font-size:13px}.shortcut-table th{text-align:left;color:var(--zf-muted);border-bottom:1px solid var(--zf-border);text-transform:uppercase;letter-spacing:.5px;padding:8px 10px;font-size:11px;font-weight:600}.shortcut-table td{border-bottom:1px dashed var(--zf-border);color:var(--zf-text);vertical-align:top;padding:8px 10px}.shortcut-table tr:last-child td{border-bottom:none}.shortcut-table kbd{background:var(--zf-surface);border:1px solid var(--zf-border-hi);color:var(--zf-accent);white-space:nowrap;border-radius:4px;padding:2px 8px;font-family:DM Mono,SF Mono,Consolas,monospace;font-size:12px}.shortcut-scope{color:var(--zf-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.sr-quick-actions{border-bottom:1px solid var(--zf-border);gap:8px;padding:8px 0;display:flex}:root{--demo-bg:#0e1f2a;--demo-panel:#15283a;--demo-border:#1e4258;--demo-accent:#3fb6a8;--demo-accent-dark:#2a9087;--demo-text:#f5f7fa;--demo-muted:#8fa3b7;--demo-success:#46c997;--demo-warn:#e6b85c;--demo-danger:#e65c5c;--demo-info:#5b9bd5}.spec-demo-banner{border:1px solid var(--zf-border-hi);background:linear-gradient(135deg,#e6b85c1f,#e6b85c0a);border-radius:12px;justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px;padding:14px 18px;display:flex}.spec-demo-banner-text{color:var(--zf-text);font-size:13px;line-height:1.5}.screen-header-actions{margin-top:12px}.screen-header-actions .btn{font-size:12px}.demo-chooser{max-width:1100px;margin:0 auto;padding:28px 32px}.demo-chooser-header h2{letter-spacing:.01em;margin:0 0 6px;font-family:Playfair Display,serif;font-size:28px}.demo-chooser-header p{color:var(--zf-muted);margin:0 0 18px;font-size:14px}.demo-chooser-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}.demo-chooser-card{background:var(--zf-panel);border:1px solid var(--zf-border);text-align:left;cursor:pointer;color:var(--zf-text);border-radius:14px;padding:22px 22px 20px 26px;font-family:inherit;transition:all .15s;position:relative;overflow:hidden}.demo-chooser-card:hover{background:var(--zf-panel-hi);transform:translateY(-2px);box-shadow:0 12px 32px #00000059}.demo-chooser-card-accent{width:4px;position:absolute;top:0;bottom:0;left:0}.demo-chooser-card h3{letter-spacing:.005em;margin:0 0 4px;font-size:18px}.demo-chooser-card-tag{color:var(--zf-muted);margin:0 0 14px;font-size:13px}.demo-chooser-card-org{color:var(--zf-text);opacity:.85;margin:0 0 16px;font-size:12px}.demo-chooser-card-cta{color:var(--zf-accent);font-size:12px;font-weight:700}.demo-shell{background:var(--demo-bg);height:calc(100vh - 200px);min-height:640px;color:var(--demo-text);border:1px solid var(--demo-border);border-radius:14px;grid-template-columns:240px 1fr;display:grid;overflow:hidden}.demo-sidebar{border-right:1px solid var(--demo-border);background:#0000002e;flex-direction:column;gap:16px;min-height:0;padding:16px 14px;display:flex;overflow-y:auto}.demo-sidebar-brand{border-bottom:1px solid var(--demo-border);align-items:center;gap:12px;padding:4px 4px 12px;display:flex}.demo-sidebar-mark{width:36px;height:36px;color:var(--demo-bg);letter-spacing:.02em;border-radius:8px;justify-content:center;align-items:center;font-size:13px;font-weight:800;display:inline-flex}.demo-sidebar-brand-body{flex-direction:column;min-width:0;display:flex}.demo-sidebar-app{color:var(--demo-text);font-size:14px;font-weight:700}.demo-sidebar-org{color:var(--demo-muted);font-size:11px}.demo-nav{flex-direction:column;gap:2px;display:flex}.demo-nav-item{color:var(--demo-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:9px 10px;font-family:inherit;font-size:13px;transition:all .12s;display:flex}.demo-nav-item:hover{color:var(--demo-text);background:#ffffff0a}.demo-nav-item-active{background:var(--demo-accent);color:var(--demo-bg);font-weight:700}.demo-nav-item-active:hover{background:var(--demo-accent);color:var(--demo-bg)}.demo-nav-item svg{flex-shrink:0}.demo-sidebar-foot{flex-direction:column;gap:8px;margin-top:auto;display:flex}.demo-sidebar-watermark{color:var(--demo-muted);padding:4px 4px 0;font-size:11px}.demo-sidebar-watermark strong{color:var(--zf-accent)}.demo-exit-btn{border:1px solid var(--demo-border);color:var(--demo-muted);cursor:pointer;background:0 0;border-radius:6px;padding:7px 10px;font-family:inherit;font-size:11px}.demo-exit-btn:hover{border-color:var(--demo-accent);color:var(--demo-accent)}.demo-main{background:var(--demo-bg);flex-direction:column;min-width:0;min-height:0;display:flex}.demo-topbar{border-bottom:1px solid var(--demo-border);background:#0000001f;align-items:center;gap:18px;padding:12px 22px;display:flex}.demo-topbar-left{flex-direction:column;gap:0;min-width:200px;display:flex}.demo-topbar-title{letter-spacing:.005em;margin:0;font-family:Playfair Display,serif;font-size:16px}.demo-topbar-tag{color:var(--demo-muted);font-size:11px}.demo-topbar-search{border:1px solid var(--demo-border);background:#0003;border-radius:8px;flex:1;align-items:center;gap:8px;max-width:400px;padding:6px 10px;display:flex}.demo-topbar-search-icon{color:var(--demo-muted);font-size:14px}.demo-topbar-search input{color:var(--demo-text);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:13px}.demo-topbar-right{align-items:center;gap:10px;display:flex}.demo-overlay-toggle{border:1px solid var(--demo-border);color:var(--demo-text);cursor:pointer;background:#ffffff0a;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:12px;display:inline-flex}.demo-overlay-toggle:hover{border-color:var(--demo-accent)}.demo-overlay-toggle-on{background:var(--demo-accent);color:var(--demo-bg);border-color:var(--demo-accent)}.demo-overlay-dot{background:var(--demo-accent);border-radius:50%;width:8px;height:8px;display:inline-block}.demo-overlay-toggle-on .demo-overlay-dot{background:var(--demo-bg)}.demo-topbar-switch{border:1px solid var(--demo-border);color:var(--demo-muted);cursor:pointer;background:0 0;border-radius:8px;padding:6px 12px;font-family:inherit;font-size:12px}.demo-topbar-switch:hover{color:var(--demo-text);border-color:var(--demo-accent)}.demo-topbar-user{align-items:center;gap:8px;display:flex}.demo-topbar-user-meta{flex-direction:column;align-items:flex-end;display:flex}.demo-topbar-user-name{font-size:12px;font-weight:700}.demo-topbar-user-role{color:var(--demo-muted);font-size:10px}.demo-topbar-avatar{width:32px;height:32px;color:var(--demo-bg);letter-spacing:.02em;border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.demo-canvas{flex:1 1 0;min-height:0;padding:22px 26px 26px;position:relative;overflow:hidden auto}.demo-canvas.overlay-on{padding-right:360px}.demo-page-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.demo-page-title{margin:0 0 4px;font-family:Playfair Display,serif;font-size:24px}.demo-page-sub{color:var(--demo-muted);margin:0;font-size:13px}.demo-page-actions{gap:8px;display:flex}.demo-page-toolbar{background:var(--demo-panel);border:1px solid var(--demo-border);border-radius:10px;gap:8px;margin-bottom:12px;padding:10px 12px;display:flex}.demo-page-body{flex-direction:column;gap:14px;display:flex}.demo-card{background:var(--demo-panel);border:1px solid var(--demo-border);border-radius:12px;flex-direction:column;gap:12px;padding:16px 18px;display:flex}.demo-card-tight{justify-content:center;align-items:center;padding:14px}.demo-card-empty{color:var(--demo-muted);font-style:italic}.demo-card-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.demo-card-head h3{letter-spacing:.02em;color:var(--demo-text);margin:0;font-size:14px;font-weight:700}.demo-card-meta{color:var(--demo-muted);font-size:11px}.demo-card-subtitle{text-transform:uppercase;letter-spacing:.06em;color:var(--demo-muted);margin-top:4px;font-size:11px;font-weight:700}.demo-card-foot-note{color:var(--demo-muted);font-size:11px;font-style:italic}.demo-grid{gap:12px;display:grid}.demo-grid-kpi{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.demo-grid-kpi-narrow{grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px}.demo-grid-gauge{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.demo-split{gap:14px;display:grid}.demo-split-1-1{grid-template-columns:1fr 1fr}.demo-split-2-1{grid-template-columns:2fr 1fr}.demo-split-1-2{grid-template-columns:1fr 2fr}@media (width<=1100px){.demo-split-1-1,.demo-split-2-1,.demo-split-1-2{grid-template-columns:1fr}}.demo-btn{border:1px solid var(--demo-border);color:var(--demo-text);cursor:pointer;background:#ffffff0a;border-radius:8px;padding:8px 14px;font-family:inherit;font-size:12px;transition:all .12s}.demo-btn:hover{border-color:var(--demo-accent)}.demo-btn-primary{background:var(--demo-accent);color:var(--demo-bg);border-color:var(--demo-accent);font-weight:700}.demo-btn-primary:hover{background:var(--demo-accent-dark);border-color:var(--demo-accent-dark)}.demo-btn-secondary{background:0 0}.demo-btn-link{color:var(--demo-accent);cursor:pointer;background:0 0;border:none;padding:4px 0;font-family:inherit;font-size:12px}.demo-btn-row{flex-wrap:wrap;gap:8px;display:flex}.demo-tab-pills{flex-wrap:wrap;gap:6px;display:flex}.demo-tab-pill{border:1px solid var(--demo-border);color:var(--demo-muted);cursor:pointer;background:0 0;border-radius:999px;padding:6px 12px;font-family:inherit;font-size:12px}.demo-tab-pill:hover{color:var(--demo-text);border-color:var(--demo-accent)}.demo-tab-pill-active{background:var(--demo-accent);color:var(--demo-bg);border-color:var(--demo-accent);font-weight:700}.demo-table-wrap{overflow-x:auto}.demo-table{border-collapse:collapse;width:100%;font-size:12px}.demo-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--demo-muted);border-bottom:1px solid var(--demo-border);padding:8px 10px;font-size:10px;font-weight:700}.demo-table-th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.demo-table-th-sortable:hover{color:var(--demo-text)}.demo-table-sort{margin-left:4px;font-size:9px}.demo-table tbody td{color:var(--demo-text);border-bottom:1px solid #ffffff0a;padding:9px 10px}.demo-table-row-clickable{cursor:pointer}.demo-table-row-clickable:hover td{background:#ffffff08}.demo-table-align-right{text-align:right}.demo-table-align-center{text-align:center}.demo-table-empty{text-align:center;color:var(--demo-muted);padding:28px 12px;font-style:italic}.demo-table-th-expand{width:22px;padding-right:0!important}.demo-table-expand-cell{width:22px;color:var(--demo-muted);padding-right:0!important}.demo-table-expand-caret{color:var(--demo-muted);font-size:11px;transition:transform .12s;display:inline-block}.demo-table-expand-caret-open{color:var(--demo-accent);transform:rotate(90deg)}.demo-table-row-expanded td{background:#ffffff0a}.demo-table-detail-row td{border-bottom:1px solid var(--demo-border)}.demo-table-detail-cell{background:#0000002e;padding:14px 18px!important}.demo-table-detail-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px 22px;font-size:12px;display:grid}.demo-table-detail-grid dt{color:var(--demo-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;font-size:10px;font-weight:700}.demo-table-detail-grid dd{color:var(--demo-text);margin:0 0 8px}.demo-table-detail-foot{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.demo-table-filter{align-items:center;gap:10px;margin-bottom:10px;display:flex}.demo-table-filter-input{border:1px solid var(--demo-border);max-width:320px;color:var(--demo-text);font:inherit;background:#0000002e;border-radius:6px;outline:none;flex:1;padding:6px 10px;font-size:12px}.demo-table-filter-input:focus{border-color:var(--demo-accent)}.demo-table-filter-count{color:var(--demo-muted);font-size:11px;font-style:italic}.demo-filter-row{flex-wrap:wrap;gap:8px;margin:6px 0 12px;display:flex}.demo-filter-select{border:1px solid var(--demo-border);color:var(--demo-text);font:inherit;cursor:pointer;background:#0000002e;border-radius:6px;padding:6px 10px;font-size:12px}.demo-filter-select:focus{border-color:var(--demo-accent);outline:none}.demo-toggle{color:var(--demo-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:12px;display:inline-flex}.demo-toggle input{accent-color:var(--demo-accent)}.metric-card{background:var(--demo-panel);border:1px solid var(--demo-border);border-radius:12px;flex-direction:column;gap:4px;min-height:92px;padding:14px 16px;display:flex}.metric-card-label{text-transform:uppercase;letter-spacing:.08em;color:var(--demo-muted);font-size:10px;font-weight:600}.metric-card-value-row{align-items:baseline;gap:6px;display:flex}.metric-card-value{letter-spacing:.005em;font-family:Playfair Display,serif;font-size:24px;font-weight:700;line-height:1.1}.metric-card-unit,.metric-card-delta{color:var(--demo-muted);font-size:11px}.metric-card-trend-up,.metric-card-trend-down{color:var(--demo-success)}.metric-card-trend-flat{color:var(--demo-muted)}.metric-card-foot{color:var(--demo-muted);font-size:10px}.metric-card-good{border-color:#46c99766}.metric-card-warn{border-color:#e6b85c66}.metric-card-bad{border-color:#e65c5c66}.demo-badge{letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;border-radius:999px;padding:2px 9px;font-size:10px;font-weight:700;display:inline-block}.demo-badge-success{color:#6cd9aa;background:#46c9972e}.demo-badge-warning{color:#f0c876;background:#e6b85c2e}.demo-badge-info{color:#7dbef0;background:#5b9bd52e}.demo-badge-danger{color:#f08383;background:#e65c5c2e}.demo-badge-neutral{color:var(--demo-muted);background:#ffffff0f}.kanban-board{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;display:grid}.kanban-lane{border:1px solid var(--demo-border);background:#00000026;border-radius:12px;flex-direction:column;gap:8px;min-height:140px;padding:10px;display:flex}.kanban-lane-head{text-transform:uppercase;letter-spacing:.05em;color:var(--demo-muted);justify-content:space-between;align-items:center;padding:0 4px;font-size:11px;font-weight:700;display:flex}.kanban-lane-count{background:#ffffff0f;border-radius:999px;padding:2px 7px;font-size:10px}.kanban-lane-body{flex-direction:column;gap:6px;display:flex}.kanban-card{background:var(--demo-panel);border:1px solid var(--demo-border);cursor:pointer;border-radius:8px;flex-direction:column;gap:4px;padding:10px;transition:all .12s;display:flex}.kanban-card:hover{border-color:var(--demo-accent);transform:translateY(-1px)}.kanban-card-meta{justify-content:space-between;align-items:center;display:flex}.kanban-card-id{color:var(--demo-muted);letter-spacing:.04em;font-size:10px;font-weight:700}.kanban-card-title{font-size:12px;font-weight:600;line-height:1.35}.kanban-card-sub{color:var(--demo-muted);font-size:11px}.kanban-card-foot{color:var(--demo-muted);justify-content:space-between;margin-top:4px;font-size:10px;display:flex}.timeline-view{margin:0;padding:0 0 0 16px;list-style:none;position:relative}.timeline-view:before{content:"";background:var(--demo-border);width:2px;position:absolute;top:0;bottom:0;left:4px}.timeline-entry{padding:6px 0 12px 14px;position:relative}.timeline-dot{background:var(--demo-info);border:2px solid var(--demo-bg);width:12px;height:12px;box-shadow:0 0 0 2px var(--demo-info);border-radius:50%;position:absolute;top:10px;left:-16px}.timeline-dot-success{background:var(--demo-success);box-shadow:0 0 0 2px var(--demo-success)}.timeline-dot-warning{background:var(--demo-warn);box-shadow:0 0 0 2px var(--demo-warn)}.timeline-dot-danger{background:var(--demo-danger);box-shadow:0 0 0 2px var(--demo-danger)}.timeline-dot-info{background:var(--demo-info);box-shadow:0 0 0 2px var(--demo-info)}.timeline-dot-neutral{background:var(--demo-muted);box-shadow:0 0 0 2px var(--demo-muted)}.timeline-meta{color:var(--demo-muted);gap:10px;font-size:10px;display:flex}.timeline-time{font-weight:700}.timeline-actor{color:var(--demo-text)}.timeline-text{margin-top:3px;font-size:12px}.timeline-detail{color:var(--demo-muted);margin-top:3px;font-size:11px}.demo-form-section{border:none;margin:0;padding:0}.demo-form-legend{text-transform:uppercase;letter-spacing:.06em;color:var(--demo-muted);margin-bottom:10px;padding:0;font-size:11px;font-weight:700}.demo-form-desc{color:var(--demo-muted);margin:-4px 0 12px;font-size:12px}.demo-form-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (width<=700px){.demo-form-grid{grid-template-columns:1fr}}.demo-form-field{flex-direction:column;gap:4px;display:flex}.demo-form-field-full{grid-column:1/-1}.demo-form-field-third{grid-column:span 1}.demo-form-label{color:var(--demo-muted);font-size:11px;font-weight:600}.demo-form-required{color:var(--demo-danger)}.demo-form-input{border:1px solid var(--demo-border);color:var(--demo-text);background:#0000002e;border-radius:6px;padding:8px 10px;font-family:inherit;font-size:13px}.demo-form-input:focus{border-color:var(--demo-accent);outline:none}.demo-form-textarea{resize:vertical;min-height:64px}.demo-form-hint{color:var(--demo-muted);font-size:10px}.demo-form-checkbox{color:var(--demo-text);cursor:pointer;align-items:center;gap:8px;font-size:12px;display:flex}.demo-form-banner{border:1px solid var(--demo-border);background:#00000029;border-radius:10px;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:6px;padding:12px 14px;display:flex}.demo-form-banner-name{font-size:14px;font-weight:700}.demo-form-banner-meta{color:var(--demo-muted);margin-top:2px;font-size:11px}.demo-form-banner-flags{flex-wrap:wrap;gap:6px;display:flex}.demo-list{flex-direction:column;gap:6px;max-height:540px;display:flex;overflow-y:auto}.demo-list-card{border:1px solid var(--demo-border);cursor:pointer;text-align:left;color:var(--demo-text);background:#00000026;border-radius:8px;flex-direction:column;gap:4px;padding:10px 12px;font-family:inherit;transition:all .12s;display:flex}.demo-list-card:hover{border-color:var(--demo-accent)}.demo-list-card-active{border-color:var(--demo-accent);background:#3fb6a81a}.demo-list-card-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.demo-list-card-id{color:var(--demo-muted);font-size:10px}.demo-list-card-meta{color:var(--demo-muted);font-size:11px}.demo-list-card-tag{gap:6px;display:flex}.demo-list-card-clamp{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.compliance-gauge{justify-content:center;align-items:center;display:inline-flex;position:relative}.compliance-gauge-track{stroke:#ffffff14}.compliance-gauge-arc{stroke:var(--demo-success);transition:stroke-dashoffset .4s,stroke .2s}.compliance-gauge-good .compliance-gauge-arc{stroke:var(--demo-success)}.compliance-gauge-warn .compliance-gauge-arc{stroke:var(--demo-warn)}.compliance-gauge-bad .compliance-gauge-arc{stroke:var(--demo-danger)}.compliance-gauge-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.compliance-gauge-value{font-family:Playfair Display,serif;font-size:22px;font-weight:700}.compliance-gauge-label{color:var(--demo-muted);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.module-overlay{border-left:1px solid var(--demo-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a1420f5;flex-direction:column;gap:16px;width:340px;padding:18px 18px 22px;display:flex;position:absolute;top:0;bottom:0;right:0;overflow-y:auto}.module-overlay-header{border-bottom:1px solid var(--demo-border);justify-content:space-between;align-items:center;padding-bottom:10px;display:flex}.module-overlay-header strong{letter-spacing:.01em;color:var(--zf-accent);font-family:Playfair Display,serif;font-size:14px}.module-overlay-screen{color:var(--demo-muted);font-size:11px}.module-overlay-section h4{text-transform:uppercase;letter-spacing:.08em;color:var(--demo-muted);margin:0 0 8px;font-size:10px}.module-overlay-card{border:1px solid var(--demo-border);background:#ffffff0a;border-radius:8px;flex-direction:column;gap:4px;margin-bottom:8px;padding:10px;display:flex}.module-overlay-card-head{align-items:baseline;gap:8px;display:flex}.module-overlay-id{color:var(--zf-accent);letter-spacing:.04em;font-size:10px;font-weight:700}.module-overlay-name{font-size:12px;font-weight:600}.module-overlay-where{color:var(--demo-muted);font-size:11px;line-height:1.4}.module-overlay-loe{color:var(--demo-success);font-size:10px}.module-overlay-signals{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.module-overlay-signal{color:var(--demo-text);align-items:flex-start;gap:8px;font-size:11px;display:flex}.module-overlay-signal-tag{color:var(--demo-accent);text-transform:uppercase;white-space:nowrap;background:#3fb6a81f;border-radius:4px;flex-shrink:0;padding:1px 6px;font-size:9px;font-weight:700}.module-overlay-foot{color:var(--demo-muted);border-top:1px solid var(--demo-border);padding-top:10px;font-size:10px}.module-overlay-empty{color:var(--demo-muted);font-size:12px}.demo-bullets{flex-direction:column;gap:6px;margin:0;padding-left:18px;font-size:13px;display:flex}.demo-bullets li{line-height:1.5}.demo-quote{border-left:3px solid var(--demo-accent);color:var(--demo-text);background:#ffffff05;border-radius:0 6px 6px 0;padding:6px 10px;font-size:12px;font-style:italic}.demo-attachment-list{flex-direction:column;gap:6px;display:flex}.demo-attachment{border:1px solid var(--demo-border);background:#0000002e;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;font-size:12px;display:flex}.demo-attachment-icon{font-size:14px}.demo-detail-grid{background:#00000024;border-radius:10px;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;padding:12px;display:grid}.demo-detail-label{text-transform:uppercase;letter-spacing:.06em;color:var(--demo-muted);margin-bottom:2px;font-size:10px}.study-detail-meta{background:#00000024;border-radius:10px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;padding:12px;display:grid}.study-meta-label{text-transform:uppercase;letter-spacing:.06em;color:var(--demo-muted);margin-bottom:2px;font-size:10px}.study-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--demo-muted);margin:4px 0 0;font-size:11px}.study-check-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.study-check{background:#00000024;border-radius:6px;grid-template-columns:24px 1fr auto;align-items:center;gap:10px;padding:8px 10px;font-size:12px;display:grid}.study-check-mark{color:var(--demo-muted);text-align:center;font-weight:700}.study-check-done .study-check-mark{color:var(--demo-success)}.study-check-meta{color:var(--demo-muted);font-size:11px}.study-signals{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;display:grid}.study-signal{background:#00000024;border-radius:8px;flex-direction:column;gap:4px;padding:8px 12px;display:flex}.study-signal-name{font-size:12px;font-weight:600}.study-signal-bar{background:#ffffff0f;border-radius:3px;height:6px;overflow:hidden}.study-signal-bar-fill{background:var(--demo-success);width:100%;height:100%}.study-signal-bar-fair .study-signal-bar-fill{background:var(--demo-warn);width:70%}.study-signal-bar-poor .study-signal-bar-fill{background:var(--demo-danger);width:35%}.study-signal-q{color:var(--demo-muted);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.hypnogram{border:1px solid var(--demo-border);color:var(--demo-text);background:#00000024;border-radius:8px;padding:12px}.hypnogram-title{text-transform:uppercase;letter-spacing:.06em;color:var(--demo-muted);margin-bottom:6px;font-size:11px;font-weight:700}.hypnogram svg{width:100%;height:auto}.demo-signoff{border:1px dashed var(--demo-border);background:#00000024;border-radius:10px;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex}.demo-signoff-label{text-transform:uppercase;letter-spacing:.06em;color:var(--demo-muted);font-size:10px}.demo-signoff-name{font-family:Playfair Display,serif;font-size:13px;font-weight:600}.gantt{flex-direction:column;gap:8px;display:flex}.gantt-row{grid-template-columns:220px 1fr 110px;align-items:center;gap:10px;display:grid}.gantt-row-label{font-size:12px}.gantt-row-track{background:#0000002e;border-radius:4px;height:22px;position:relative;overflow:hidden}.gantt-bar{border-radius:4px;position:absolute;top:0;bottom:0}.gantt-bar-complete{background:linear-gradient(90deg, var(--demo-success), #6ad9aa)}.gantt-bar-active{background:linear-gradient(90deg, var(--demo-warn), #f4d28a)}.gantt-bar-planned{border:1px dashed var(--demo-border);background:#ffffff1a}.gantt-row-date{color:var(--demo-text);white-space:nowrap;pointer-events:none;font-size:10px;position:absolute;top:50%;left:8px;transform:translateY(-50%)}.demo-thread{flex-direction:column;gap:10px;display:flex}.demo-thread-msg{border:1px solid var(--demo-border);background:#00000024;border-radius:8px;flex-direction:column;gap:4px;padding:10px 12px;display:flex}.demo-thread-meta{color:var(--demo-muted);font-size:11px}.demo-thread-body{font-size:13px;line-height:1.5}.heat-map{border-collapse:separate;border-spacing:4px;width:100%}.heat-map th{text-transform:uppercase;letter-spacing:.06em;color:var(--demo-muted);background:0 0;padding:4px;font-size:10px;font-weight:700}.heat-corner{width:50px}.heat-cell{vertical-align:middle;text-align:center;border-radius:6px;height:60px;padding:4px}.heat-cell.cell-low{background:#46c9972e}.heat-cell.cell-med{background:#e6b85c38}.heat-cell.cell-high{background:#e65c5c42}.heat-pill{color:var(--demo-text);background:#0006;border-radius:999px;margin:2px;padding:2px 6px;font-size:10px;font-weight:700;display:inline-block}.heat-pill-button{cursor:pointer;border:1px solid #0000;font-family:inherit}.heat-pill-button:hover{border-color:var(--demo-accent);background:#000000a6}.heat-pill-selected{background:var(--demo-accent);color:var(--demo-bg);border-color:var(--demo-accent)}.demo-risk-detail{margin-top:14px}.demo-stage-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:14px;display:grid}.demo-stage-card{background:var(--demo-panel);border:1px solid var(--demo-border);color:var(--demo-text);font:inherit;cursor:pointer;text-align:left;border-radius:10px;flex-direction:column;align-items:flex-start;gap:4px;padding:12px 14px;transition:all .12s;display:flex}.demo-stage-card:hover{border-color:var(--demo-accent);background:#ffffff0a}.demo-stage-card-active{border-color:var(--demo-accent);box-shadow:0 0 0 1px var(--demo-accent);background:#ffffff0f}.demo-stage-card-label{text-transform:uppercase;letter-spacing:.06em;color:var(--demo-muted);font-size:10px;font-weight:700}.demo-stage-card-value{font-family:Playfair Display,serif;font-size:22px}.demo-stage-card-meta{color:var(--demo-muted);font-size:11px}.demo-bar-list{flex-direction:column;gap:6px;display:flex}.demo-bar-row{grid-template-columns:minmax(140px,200px) minmax(0,1fr) minmax(40px,max-content);align-items:center;gap:10px;font-size:12px;display:grid}.demo-bar-track{background:#0000002e;border-radius:4px;height:8px;overflow:hidden}.demo-bar-fill{background:linear-gradient(90deg, var(--demo-accent), var(--demo-accent-dark));height:100%}.demo-bar-count{text-align:right;white-space:nowrap;font-size:12px;font-weight:700}.demo-integration-row{grid-template-columns:minmax(0,1.4fr) minmax(80px,.6fr) minmax(150px,.8fr);align-items:center;gap:12px;padding:4px 0;font-size:12px;display:grid}.demo-integration-row>*{white-space:nowrap;text-overflow:ellipsis;min-width:0;overflow:hidden}.demo-integration-row .demo-integration-sync{text-align:right;color:var(--demo-muted);font-weight:600}.stage-progress{flex-wrap:wrap;align-items:center;gap:6px;padding:8px 0;display:flex}.stage-pill{background:var(--demo-panel,var(--zf-panel));border:1px solid var(--demo-border,var(--zf-border));color:var(--demo-muted,var(--zf-muted));white-space:nowrap;border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:11px;display:inline-flex}.stage-pill-step{background:var(--demo-border,var(--zf-border));width:18px;height:18px;color:var(--demo-text,var(--zf-text));border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:inline-flex}.stage-pill-active{border-color:var(--demo-accent,var(--zf-accent));color:var(--demo-text,var(--zf-text));background:#ffffff0a}.stage-pill-active .stage-pill-step{background:var(--demo-accent,var(--zf-accent));color:#1a1410}.stage-pill-done{color:var(--demo-text,var(--zf-text));border-color:var(--demo-accent-dark,var(--zf-accent-dim))}.stage-pill-done .stage-pill-step{background:var(--demo-accent-dark,var(--zf-accent-dim));color:#1a1410}.stage-pill-sep{color:var(--demo-muted,var(--zf-muted));font-size:14px}.stage-pill-sep-done{color:var(--demo-accent,var(--zf-accent))}.demo-compliance-dashboard{flex-direction:column;gap:16px;display:flex}.demo-trend-up{color:var(--demo-success);font-weight:600}.demo-trend-down{color:var(--demo-danger);font-weight:600}.demo-trend-flat{color:var(--demo-muted)}.demo-feedback-widget{background:var(--demo-panel,#1c1c20);border:1px solid var(--demo-border,#333);z-index:40;color:var(--demo-text,#e8e8ec);border-radius:999px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:none;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 16px #0006}.demo-feedback-widget-rated{padding:8px 14px}.demo-feedback-prompt{opacity:.85}.demo-feedback-thanks{color:var(--demo-accent,#5da8e0);font-weight:600}.demo-feedback-btn{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:999px;padding:4px 8px;font-size:16px;line-height:1}.demo-feedback-btn:hover{border-color:var(--demo-accent,#5da8e0);background:#ffffff0a}.demo-survey-overlay{z-index:60;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.demo-survey-card{background:var(--demo-panel,#1c1c20);border:1px solid var(--demo-border,#333);width:480px;max-width:calc(100vw - 32px);color:var(--demo-text,#e8e8ec);border-radius:12px;padding:24px}.demo-survey-card h3{margin:0 0 8px}.demo-survey-sub{opacity:.85;margin:12px 0 6px}.demo-survey-stars{gap:6px;display:flex}.demo-survey-star{cursor:pointer;color:#ffffff59;background:0 0;border:none;padding:0 4px;font-size:28px}.demo-survey-star-on{color:var(--demo-accent,#5da8e0)}.demo-survey-features{grid-template-columns:1fr 1fr;gap:6px 16px;margin-bottom:4px;display:grid}.demo-survey-feature{align-items:center;gap:6px;font-size:13px;display:flex}.demo-survey-comment{border:1px solid var(--demo-border,#333);width:100%;color:inherit;resize:vertical;background:#00000040;border-radius:6px;padding:8px}.demo-survey-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.demo-repnotes{background:var(--demo-panel,#1c1c20);border:1px solid var(--demo-border,#333);color:var(--demo-text,#e8e8ec);border-radius:8px;padding:16px}.demo-repnotes-head{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.demo-repnotes-head h4{margin:0}.demo-repnotes-meta{opacity:.65;font-size:12px}.demo-repnotes-input{border:1px solid var(--demo-border,#333);width:100%;color:inherit;resize:vertical;background:#00000040;border-radius:6px;padding:8px}.demo-repnotes-tags{flex-wrap:wrap;gap:6px;margin:10px 0;display:flex}.demo-repnotes-tag{border:1px solid var(--demo-border,#333);color:inherit;cursor:pointer;background:0 0;border-radius:999px;padding:4px 10px;font-size:12px}.demo-repnotes-tag-on{background:var(--demo-accent,#5da8e0);border-color:var(--demo-accent,#5da8e0);color:#0a0a0a}.demo-repnotes-actions{align-items:center;gap:12px;display:flex}.demo-repnotes-saved{color:var(--demo-accent,#5da8e0);font-size:12px}.demo-health-dashboard{background:var(--demo-panel,#1c1c20);border:1px solid var(--demo-border,#333);color:var(--demo-text,#e8e8ec);border-radius:8px;padding:20px}.demo-health-head{justify-content:space-between;align-items:baseline;margin-bottom:16px;display:flex}.demo-health-head h3{margin:0}.demo-health-overall{opacity:.85;align-items:center;gap:6px;font-size:13px;display:flex}.demo-health-summary{grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:18px;display:grid}.demo-health-stat{border:1px solid var(--demo-border,#333);text-align:center;background:#0003;border-radius:6px;padding:10px 12px}.demo-health-stat-label{opacity:.7;text-transform:uppercase;letter-spacing:.04em;font-size:11px}.demo-health-stat-value{margin-top:4px;font-size:22px;font-weight:600}.demo-health-rows{flex-direction:column;gap:12px;display:flex}.demo-health-row{border:1px solid var(--demo-border,#333);background:#0000002e;border-radius:6px;padding:12px 14px}.demo-health-row-broken{border-left:4px solid #e2674b}.demo-health-row-stale{border-left:4px solid #e2a93b}.demo-health-row-healthy{border-left:4px solid #4caf8e}.demo-health-row-head{align-items:center;gap:12px;font-size:14px;display:flex}.demo-health-row-name{flex:1;font-weight:600}.demo-health-row-meta{opacity:.65;font-size:12px}.demo-health-issue-list{color:#ffffffd9;margin:8px 0 0;padding-left:18px;font-size:13px}.demo-health-issue-broken{color:#f0a892}.demo-health-issue-warning{color:#ffd49a}.demo-health-issue-kind{background:#ffffff0f;border-radius:3px;margin-right:4px;padding:1px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px}.pp-section{margin-top:32px}.pp-divider{background:linear-gradient(to right, transparent, var(--zf-border), transparent);height:1px;margin-bottom:24px}.pp-section-header h3{letter-spacing:.01em;color:var(--zf-text);margin:0 0 6px;font-family:Playfair Display,serif;font-size:22px}.pp-section-header p{color:var(--zf-muted);max-width:720px;margin:0 0 18px;font-size:13px}.pp-grid{gap:16px;display:grid}.pp-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:14px;flex-direction:column;gap:14px;padding:18px 20px 20px;display:flex}.pp-card-expanded{border-color:var(--zf-accent);box-shadow:0 16px 40px #00000073}.pp-card-head{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.pp-card-titles{flex:1;min-width:0}.pp-card-title{color:var(--zf-text);letter-spacing:.005em;margin:0 0 4px;font-size:16px}.pp-card-desc{color:var(--zf-muted);max-width:720px;margin:0;font-size:12px;line-height:1.5}.pp-card-canvas{background:var(--zf-bg);border:1px solid var(--zf-border);border-radius:10px;padding:14px;overflow:hidden}.pp-card-expanded .pp-card-canvas{padding:18px}.pp-screen{color:var(--zf-text);gap:12px;font-size:12px;display:grid}.pp-panel{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:8px;min-height:0;padding:12px}.pp-panel-label{letter-spacing:.13em;text-transform:uppercase;color:var(--zf-muted);margin-bottom:8px;font-size:10px;font-weight:700}.pp-panel-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.pp-panel-filters{gap:6px;display:flex}.pp-pill{background:var(--zf-bg);border:1px solid var(--zf-border);color:var(--zf-muted);border-radius:999px;padding:3px 8px;font-size:10px}.pp-pill-active{background:var(--zf-accent);color:var(--zf-bg);border-color:var(--zf-accent)}.pp-detail-title{color:var(--zf-text);margin:4px 0 8px;font-size:14px}.pp-signal-review{grid-template-columns:180px 1fr 220px}.pp-card-expanded .pp-signal-review{grid-template-columns:220px 1fr 280px}@media (width<=900px){.pp-signal-review{grid-template-columns:1fr}}.pp-doc-item{cursor:default;border:1px solid #0000;border-radius:6px;margin-bottom:4px;padding:8px 10px}.pp-doc-active{background:var(--zf-bg);border-color:var(--zf-accent)}.pp-doc-name{color:var(--zf-text);word-break:break-all;margin-bottom:4px;font-size:12px}.pp-doc-meta{color:var(--zf-muted);justify-content:space-between;font-size:10px;display:flex}.pp-signal-list{flex-direction:column;gap:6px;max-height:360px;display:flex;overflow-y:auto}.pp-signal-row{border:1px solid var(--zf-border);background:var(--zf-bg);border-radius:6px;padding:8px 10px}.pp-signal-active{border-color:var(--zf-accent);background:#6ea9e314}.pp-signal-row-top{justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;display:flex}.pp-signal-name{color:var(--zf-text);font-size:12px}.pp-signal-row-bot{color:var(--zf-muted);align-items:center;gap:8px;font-size:10px;display:flex}.pp-signal-doc{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.pp-cat-badge{color:#1a1a1a;border-radius:999px;padding:2px 8px;font-size:10px;font-weight:600}.pp-conf-badge{border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600}.pp-conf-high{color:#7bb285;background:#7bb2852e}.pp-conf-med{color:#d6a35e;background:#d6a35e2e}.pp-conf-low{color:#d64550;background:#d645502e}.pp-signal-status{text-transform:uppercase;letter-spacing:.06em;border-radius:4px;padding:1px 6px;font-size:10px}.pp-signal-status-confirmed{color:#7bb285}.pp-signal-status-pending{color:var(--zf-muted)}.pp-detail-meta{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:12px;display:flex}.pp-detail-section{margin-bottom:12px}.pp-detail-section-label{letter-spacing:.13em;text-transform:uppercase;color:var(--zf-muted);margin-bottom:4px;font-size:9px;font-weight:700}.pp-detail-pattern,.pp-detail-quote{background:var(--zf-bg);border:1px solid var(--zf-border);color:var(--zf-text);border-radius:6px;padding:8px 10px;font-size:11px;line-height:1.55}.pp-detail-quote{color:var(--zf-muted);font-style:italic}.pp-mapping-card{background:var(--zf-bg);border:1px solid var(--zf-border);border-radius:6px;padding:8px 10px}.pp-mapping-name{color:var(--zf-accent);font-size:12px;font-weight:600}.pp-mapping-sub{color:var(--zf-muted);margin-top:2px;font-size:10px}.pp-mapping-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.pp-mapping-flow{align-items:center;gap:8px;display:flex}.pp-flow-blob{background:var(--zf-panel);border:1px solid var(--zf-border);color:var(--zf-text);border-radius:999px;padding:4px 12px;font-size:11px}.pp-flow-arrow{color:var(--zf-accent);font-weight:600}.pp-bundle-row{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:8px;padding:12px}.pp-bundle-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;display:grid}.pp-bundle-btn{background:var(--zf-bg);border:1px solid var(--zf-border);border-radius:6px;flex-direction:column;gap:4px;padding:10px;display:flex}.pp-bundle-applied{border-color:var(--zf-accent)}.pp-bundle-name{color:var(--zf-text);font-size:12px;font-weight:600}.pp-bundle-count{color:var(--zf-muted);font-size:10px}.pp-bundle-tag{background:var(--zf-accent);color:var(--zf-bg);border-radius:999px;align-self:flex-start;margin-top:2px;padding:2px 8px;font-size:10px;font-weight:600}.pp-bundle-tag-ghost{color:var(--zf-muted);border:1px solid var(--zf-border);background:0 0}.pp-module-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;display:grid}.pp-module-card{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:8px;padding:10px 12px}.pp-module-wired{border-color:#7bb28566}.pp-module-override{border-color:#d6a35e66}.pp-module-unmet{border-color:#d6455066}.pp-module-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.pp-module-name{color:var(--zf-text);font-size:12px;font-weight:600}.pp-module-status{text-transform:uppercase;letter-spacing:.1em;color:var(--zf-muted);font-size:9px}.pp-module-meta{color:var(--zf-muted);gap:10px;margin-bottom:6px;font-size:10px;display:flex}.pp-module-bar{background:var(--zf-bg);border-radius:2px;height:4px;overflow:hidden}.pp-module-bar-fill{background:var(--zf-accent);height:100%}.pp-spec-builder{grid-template-columns:1fr 240px}@media (width<=900px){.pp-spec-builder{grid-template-columns:1fr}}.pp-spec-doc{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:8px;min-height:360px;padding:16px}.pp-spec-page{color:#2a2622;background:#f6f3ec;border-radius:6px;padding:24px 28px;font-family:Playfair Display,serif}.pp-spec-meta{color:#7d756c;text-transform:uppercase;letter-spacing:.13em;font-family:ui-sans-serif,system-ui;font-size:10px}.pp-spec-title{color:#2a2622;margin:6px 0 4px;font-size:22px}.pp-spec-subtitle{color:#5b5247;margin-bottom:18px;font-family:ui-sans-serif,system-ui;font-size:12px}.pp-spec-toc{background:#0000000a;border-radius:6px;margin-bottom:18px;padding:10px 14px;font-family:ui-sans-serif,system-ui}.pp-spec-toc-label{letter-spacing:.13em;text-transform:uppercase;color:#7d756c;margin-bottom:6px;font-size:9px;font-weight:700}.pp-toc-item{color:#2a2622;gap:8px;padding:2px 0;font-size:11px;display:flex}.pp-toc-active{color:#1f6feb;font-weight:600}.pp-toc-num{color:#7d756c;min-width:14px;font-weight:600}.pp-spec-section-preview{font-family:ui-sans-serif,system-ui}.pp-spec-h2{color:#2a2622;margin-bottom:8px;font-size:14px;font-weight:700}.pp-spec-line{background:#00000014;border-radius:3px;width:100%;height:6px;margin-bottom:5px}.pp-spec-side{flex-direction:column;gap:14px;display:flex}.pp-spec-cfg{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:8px;flex-direction:column;gap:6px;padding:10px 12px;display:flex}.pp-spec-cfg-row{color:var(--zf-muted);justify-content:space-between;font-size:11px;display:flex}.pp-spec-cfg-val{color:var(--zf-text);font-weight:600}.pp-spec-progress{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:8px;padding:10px 12px}.pp-spec-progress-bar{background:var(--zf-bg);border-radius:3px;height:6px;margin-bottom:6px;overflow:hidden}.pp-spec-progress-fill{background:var(--zf-accent);height:100%}.pp-spec-progress-label{color:var(--zf-muted);font-size:10px}.pp-spec-actions{flex-direction:column;gap:6px;display:flex}.pp-spec-btn{text-align:center;letter-spacing:.02em;border-radius:6px;padding:8px 12px;font-size:12px;font-weight:600}.pp-spec-btn-primary{background:var(--zf-accent);color:var(--zf-bg)}.pp-spec-btn-ghost{color:var(--zf-muted);border:1px solid var(--zf-border);background:0 0}.pp-branding{grid-template-columns:1fr 1fr}@media (width<=900px){.pp-branding{grid-template-columns:1fr}}.pp-branding-form,.pp-branding-preview{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:8px;flex-direction:column;gap:10px;padding:14px;display:flex}.pp-branding-row{flex-direction:column;gap:4px;display:flex}.pp-branding-row label{letter-spacing:.1em;text-transform:uppercase;color:var(--zf-muted);font-size:10px;font-weight:700}.pp-branding-input{background:var(--zf-bg);border:1px solid var(--zf-border);color:var(--zf-text);border-radius:6px;padding:6px 10px;font-size:12px}.pp-branding-input-mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.pp-color-row{align-items:center;gap:8px;display:flex}.pp-color-swatch{border:1px solid var(--zf-border);border-radius:6px;flex-shrink:0;width:28px;height:28px}.pp-logo-drop{background:var(--zf-bg);border:1px dashed var(--zf-border);border-radius:6px;align-items:center;gap:10px;padding:10px;display:flex}.pp-logo-mark{color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex}.pp-logo-meta{color:var(--zf-text);font-size:12px}.pp-logo-meta-sub{color:var(--zf-muted);margin-top:2px;font-size:10px}.pp-branded-shell{border:1px solid var(--zf-border);background:var(--zf-bg);border-radius:8px;overflow:hidden}.pp-branded-header{border-bottom:2px solid var(--zf-accent);background:var(--zf-panel);align-items:center;gap:10px;padding:10px 12px;display:flex}.pp-branded-title{color:var(--zf-text);font-size:13px;font-weight:700}.pp-branded-sub{color:var(--zf-muted);margin-top:2px;font-size:10px}.pp-branded-body{flex-wrap:wrap;gap:6px;padding:10px 12px;display:flex}.pp-branded-pill{border:1px solid var(--zf-border);color:var(--zf-muted);background:var(--zf-panel);border-radius:999px;padding:4px 10px;font-size:11px}.pp-branded-cta{text-align:center;border-radius:6px;margin:0 12px 12px;padding:8px 12px;font-size:12px;font-weight:700}.pp-admin{grid-template-columns:1.4fr 1fr}@media (width<=900px){.pp-admin{grid-template-columns:1fr}}.pp-admin-users,.pp-admin-side{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:8px;flex-direction:column;gap:10px;padding:12px;display:flex}.pp-admin-table{border-collapse:collapse;width:100%;font-size:12px}.pp-admin-table th{text-align:left;text-transform:uppercase;letter-spacing:.1em;color:var(--zf-muted);border-bottom:1px solid var(--zf-border);padding:6px 8px;font-size:10px}.pp-admin-table td{border-bottom:1px solid var(--zf-border);color:var(--zf-text);padding:8px}.pp-admin-name{font-weight:600}.pp-admin-email{color:var(--zf-muted);margin-top:2px;font-size:10px}.pp-role-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:2px 8px;font-size:10px;font-weight:600}.pp-role-owner{color:var(--zf-accent);background:#6ea9e32e}.pp-role-admin{color:#d6a35e;background:#d6a35e2e}.pp-role-editor{color:#7bb285;background:#7bb2852e}.pp-role-viewer{color:var(--zf-muted);background:#ffffff0f}.pp-admin-settings{flex-direction:column;gap:6px;display:flex}.pp-admin-setting{background:var(--zf-bg);border-radius:6px;justify-content:space-between;padding:6px 8px;font-size:11px;display:flex}.pp-admin-setting>span:first-child{color:var(--zf-muted)}.pp-admin-setting>span:last-child{color:var(--zf-text);font-weight:600}.pp-audit-log{flex-direction:column;gap:4px;display:flex}.pp-audit-row{background:var(--zf-bg);border-radius:6px;grid-template-columns:60px 1fr;align-items:baseline;gap:8px;padding:6px 8px;font-size:11px;display:grid}.pp-audit-ts{color:var(--zf-muted);font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.pp-audit-action{color:var(--zf-accent);grid-column:2;margin-right:6px;font-weight:600}.pp-audit-actor{color:var(--zf-muted);grid-column:2;font-size:10px}.pp-audit-target{color:var(--zf-text);grid-column:2;font-size:11px}.login-shell{min-height:100vh;color:var(--zf-text);background:#0d1520;display:flex}.login-brand{border-right:1px solid var(--zf-border);background:linear-gradient(160deg,#15202e 0%,#0d1520 60%,#1e2a38 100%);flex:1.4;justify-content:center;align-items:center;padding:48px;display:flex;position:relative;overflow:hidden}.login-brand:before{content:"";pointer-events:none;background-image:radial-gradient(circle at 30% 20%,#e6b85c14 0%,#0000 40%),radial-gradient(circle at 70% 80%,#5b9bd50f 0%,#0000 50%);position:absolute;inset:0}.login-brand-inner{text-align:left;max-width:440px;position:relative}.login-logo-mark{background:var(--zf-accent);color:#1e2a38;border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:24px;font-family:Playfair Display,serif;font-size:32px;font-weight:700;display:inline-flex;box-shadow:0 8px 32px #e6b85c40}.login-brand-name{color:var(--zf-text);margin:0 0 8px;font-family:Playfair Display,serif;font-size:40px;font-weight:700}.login-brand-tagline{color:var(--zf-accent);margin:0 0 48px;font-size:18px;font-weight:500}.login-feature-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.login-feature-list li{color:var(--zf-muted);letter-spacing:.05em;text-transform:uppercase;padding-left:20px;font-size:14px;position:relative}.login-feature-list li:before{content:"";background:var(--zf-accent);border-radius:50%;width:8px;height:8px;position:absolute;top:8px;left:0}.login-main{z-index:1;flex:1;justify-content:center;align-items:center;padding:48px 24px;display:flex;position:relative}.login-card{width:100%;max-width:400px}.login-heading{color:var(--zf-text);margin:0 0 8px;font-size:28px;font-weight:600}.login-sub{color:var(--zf-muted);margin:0 0 32px;font-size:14px}.login-form{flex-direction:column;gap:12px;display:flex}.login-oauth{background:var(--zf-panel);border:1px solid var(--zf-border);width:100%;height:48px;color:var(--zf-text);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:12px;font-size:15px;font-weight:500;transition:border-color .2s,background .2s;display:flex}.login-oauth:hover:not(:disabled){border-color:var(--zf-accent);background:var(--zf-panel-hi)}.login-oauth:disabled{opacity:.6;cursor:not-allowed}.login-oauth-disabled{opacity:.5;cursor:not-allowed}.login-oauth-disabled:hover{border-color:var(--zf-border);background:var(--zf-panel)}.login-oauth-label{text-align:left;flex:1}.login-oauth-badge{letter-spacing:.06em;text-transform:uppercase;color:var(--zf-muted);border:1px solid var(--zf-border);background:#ffffff0f;border-radius:999px;padding:3px 8px;font-size:10px;font-weight:600}.login-oauth-icon{width:20px;height:20px;color:var(--zf-accent);justify-content:center;align-items:center;font-weight:700;display:inline-flex}.login-divider{color:var(--zf-muted);text-transform:uppercase;letter-spacing:.1em;align-items:center;gap:12px;margin:8px 0;font-size:12px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--zf-border);flex:1;height:1px}.login-label{color:var(--zf-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:8px;font-size:12px}.login-input{border:1px solid var(--zf-border);width:100%;height:44px;color:var(--zf-text);background:#0d1520;border-radius:8px;padding:0 14px;font-family:inherit;font-size:15px;transition:border-color .2s,box-shadow .2s}.login-input:focus{border-color:var(--zf-accent);outline:none;box-shadow:0 0 0 3px #e6b85c33}.login-textarea{resize:vertical;height:auto;padding:12px 14px}.login-hint{color:var(--zf-muted);margin:4px 0 0;font-size:12px}.login-hint code{background:var(--zf-panel);color:var(--zf-accent);border-radius:4px;padding:1px 6px}.login-error{color:#f08e95;background:#d645501a;border:1px solid #d6455066;border-radius:8px;padding:10px 12px;font-size:13px}.login-notice{color:#6fdfa3;background:#2ecc711a;border:1px solid #2ecc7166;border-radius:8px;padding:10px 12px;font-size:13px}.login-submit{background:var(--zf-accent);color:#1e2a38;cursor:pointer;border:none;border-radius:8px;width:100%;height:48px;margin-top:8px;font-size:15px;font-weight:600;transition:background .2s,transform .1s}.login-submit:hover:not(:disabled){background:#f0c96e}.login-submit:active:not(:disabled){transform:scale(.99)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-link{color:var(--zf-accent);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;padding:0;font-size:14px;-webkit-text-decoration:underline #e6b85c4d;text-decoration:underline #e6b85c4d}.login-link:hover:not(:disabled){-webkit-text-decoration-color:var(--zf-accent);text-decoration-color:var(--zf-accent)}.login-link:disabled{opacity:.6;cursor:not-allowed}.login-request-row{text-align:center;color:var(--zf-muted);margin-top:16px;font-size:13px}.login-modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0d1520d9;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.login-modal{background:var(--zf-panel);border:1px solid var(--zf-border);border-radius:16px;flex-direction:column;gap:8px;width:100%;max-width:480px;max-height:90vh;padding:32px;display:flex;overflow-y:auto}.login-modal-head{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.login-modal-head h3{color:var(--zf-text);margin:0;font-size:22px;font-weight:600}.login-modal-close{color:var(--zf-muted);cursor:pointer;background:0 0;border:none;padding:0 8px;font-size:28px;line-height:1}.login-modal-close:hover{color:var(--zf-accent)}.login-modal-sub{color:var(--zf-muted);margin:0 0 16px;font-size:13px}.login-modal-actions{justify-content:flex-end;gap:12px;margin-top:16px;display:flex}.login-modal-actions .login-submit{width:auto;margin:0;padding:0 20px}.app-logout{border:1px solid var(--zf-border);color:var(--zf-text);cursor:pointer;background:0 0;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:border-color .2s,color .2s}.app-logout:hover{border-color:var(--zf-accent);color:var(--zf-accent)}.access-request-list{flex-direction:column;gap:10px;display:flex}.access-request-row{border:1px solid var(--zf-border);background:var(--zf-panel);border-radius:8px;grid-template-columns:1fr auto;gap:12px;padding:12px 14px;display:grid}.access-request-row.is-pending{border-color:#e6b85c66}.access-request-row.is-approved{opacity:.7;border-color:#2ecc7166}.access-request-row.is-denied{opacity:.6;border-color:#d6455066}.access-request-meta{color:var(--zf-muted);margin-top:4px;font-size:12px}.access-request-meta strong{color:var(--zf-text);font-weight:500}.access-request-actions{align-items:center;gap:8px;display:flex}.access-request-actions button{border:1px solid var(--zf-border);background:var(--zf-panel-hi);color:var(--zf-text);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:12px}.access-request-actions button.approve{color:#6fdfa3;border-color:#2ecc7180}.access-request-actions button.deny{color:#f08e95;border-color:#d6455080}@media (width<=768px){.login-shell{flex-direction:column}.login-brand{border-right:none;border-bottom:1px solid var(--zf-border);flex:none;padding:32px 24px}.login-brand-name{font-size:28px}.login-brand-tagline{margin-bottom:24px;font-size:14px}.login-feature-list{display:none}.login-main{padding:32px 24px}}
