:root{--bg: #0f1419;--surface: #161b22;--surface-2: #1c232d;--border: #2a313c;--text: #e6edf3;--text-dim: #8b949e;--accent: #1f6feb;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{background:var(--bg);color:var(--text)}.app{display:flex;flex-direction:column;height:100vh}.app__header{display:flex;align-items:center;gap:16px;padding:14px 22px;background:var(--surface);border-bottom:1px solid var(--border)}.app__brand{font-size:20px;font-weight:700;letter-spacing:-.5px}.app__brand span{color:var(--accent)}.app__tagline{margin:0;color:var(--text-dim);font-size:13px;flex:1}.app__tagline code{background:var(--surface-2);padding:1px 6px;border-radius:4px;font-size:12px}.btn{background:var(--accent);color:#fff;border:none;border-radius:7px;padding:9px 16px;font-size:14px;font-weight:600;cursor:pointer}.btn:hover{filter:brightness(1.1)}.btn--ghost{background:transparent;border:1px solid var(--border);color:var(--text);margin-top:6px}.toolbar{display:flex;align-items:center;gap:10px;padding:8px 16px;background:var(--surface-2);border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}.toolbar__filters{display:flex;gap:6px;flex-wrap:wrap}.filter-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s,border-color .15s,color .15s}.filter-pill:not(.filter-pill--active){opacity:.45}.filter-pill i{width:8px;height:8px;border-radius:50%;background:var(--text-dim);display:inline-block;flex-shrink:0}.filter-pill__count{background:var(--surface);border-radius:10px;padding:0 5px;font-size:11px;color:var(--text-dim)}.toolbar__search{background:var(--surface);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:13px;padding:5px 10px;outline:none;width:180px;transition:border-color .15s}.toolbar__search:focus{border-color:var(--accent)}.toolbar__changes{display:flex;gap:6px;flex-wrap:wrap;margin-left:auto}.change-chip{font-size:12px;font-weight:600;border:1px solid;border-radius:20px;padding:3px 10px}.toolbar__counts{display:flex;gap:14px;font-size:12px;color:var(--text-dim)}.toolbar__export{font-size:12px;padding:5px 12px;flex-shrink:0}.app__body{flex:1;min-height:0}.dropzone{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-dim);cursor:pointer;text-align:center}.dropzone__icon{font-size:56px;color:var(--accent)}.dropzone code{background:var(--surface-2);padding:2px 6px;border-radius:4px;color:var(--text)}.dropzone__error{color:#e5484d;font-weight:600}.workspace{display:grid;grid-template-columns:1fr 380px;height:100%}.graph-canvas{height:100%;min-width:0;background:radial-gradient(circle at 30% 20%,#131922,#0c1015)}@media (max-width: 720px){.workspace{grid-template-columns:1fr;grid-template-rows:1fr auto}.panel{border-left:none;border-top:1px solid var(--border);max-height:45vh}}.panel{position:relative;border-left:1px solid var(--border);background:var(--surface);padding:22px;overflow-y:auto}.panel--empty{display:flex;align-items:center;justify-content:center;color:var(--text-dim);text-align:center}.panel__close{position:absolute;top:12px;right:14px;background:none;border:none;color:var(--text-dim);font-size:24px;cursor:pointer;line-height:1}.panel__type{font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}.panel__title{margin:4px 0 2px;font-size:20px;display:flex;align-items:center;gap:8px}.panel__icon{font-size:22px;line-height:1}.panel__addr{font-size:12px;color:var(--text-dim)}.panel__badges{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}.panel__severity,.panel__badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;color:#0c1015}.panel__hint{font-size:13px;color:var(--text-dim);margin:0 0 8px}.diff{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.diff__row{background:var(--surface-2);border-radius:6px;padding:8px 10px}.diff__key{font-family:monospace;font-size:12px;color:var(--text);font-weight:600}.diff__values{display:flex;align-items:center;gap:8px;margin-top:4px;font-family:monospace;font-size:12px;flex-wrap:wrap}.diff__before{color:#f85149;text-decoration:line-through;word-break:break-all}.diff__arrow{color:var(--text-dim)}.diff__after{color:#3fb950;word-break:break-all}.panel h3{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin:18px 0 8px}.panel__clean{color:#30a46c}.finding{display:flex;gap:10px;background:var(--surface-2);border-radius:8px;padding:12px;margin-bottom:10px}.finding__bar{width:4px;border-radius:2px;flex-shrink:0}.finding__body strong{font-size:14px}.finding__body p{margin:4px 0;font-size:13px;color:var(--text-dim)}.finding__fix{color:#58c98a!important}.finding__rule{font-size:11px;color:var(--text-dim);font-family:monospace}.panel__attrs{background:var(--surface-2);border-radius:8px;padding:12px;font-size:12px;overflow-x:auto;color:var(--text-dim);max-height:260px}.user-menu{display:flex;align-items:center;gap:10px;flex-shrink:0}.user-menu__email{font-size:13px;color:var(--text-dim);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu__quota{font-size:12px;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);border-radius:20px;padding:3px 10px}.user-menu__quota--warn{color:#f0883e;border-color:#f0883e44}.btn--upgrade{background:#f0883e}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px;width:380px;max-width:calc(100vw - 32px);position:relative}.modal--wide{width:760px}.modal__close{position:absolute;top:14px;right:18px;background:none;border:none;color:var(--text-dim);font-size:22px;cursor:pointer;line-height:1}.modal__title{margin:0 0 24px;font-size:22px}.modal__tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:24px}.modal__tab{background:none;border:none;color:var(--text-dim);font-size:14px;font-weight:600;padding:0 0 10px;margin-right:20px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.modal__tab--active{color:var(--text);border-bottom-color:var(--accent)}.modal__form{display:flex;flex-direction:column;gap:8px}.modal__label{font-size:13px;color:var(--text-dim);margin-top:8px}.modal__input{background:var(--surface-2);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:14px;padding:10px 12px;outline:none;transition:border-color .15s}.modal__input:focus{border-color:var(--accent)}.modal__error{color:#e5484d;font-size:13px;margin:4px 0 0}.modal__submit{margin-top:16px}.modal__footer{margin:16px 0 0;font-size:13px;color:var(--text-dim);text-align:center}.modal__link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:inherit;padding:0;text-decoration:underline}.scans{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;max-height:60vh;overflow-y:auto}.scans__empty{color:var(--text-dim);text-align:center;padding:24px}.scan-row{display:flex;align-items:center;gap:14px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:12px 14px;cursor:pointer;transition:border-color .15s}.scan-row:hover{border-color:var(--accent)}.scan-row__main{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.scan-row__name{font-weight:600;font-size:14px}.scan-row__date{font-size:12px;color:var(--text-dim)}.scan-row__stats{display:flex;gap:10px;font-size:12px;color:var(--text-dim);flex-shrink:0}.scan-row__crit{color:#f85149;font-weight:600}.scan-row__drift{color:#a371f7;font-weight:600}.scan-row__delete{background:none;border:none;cursor:pointer;font-size:15px;opacity:.6;flex-shrink:0}.scan-row__delete:hover{opacity:1}.verify-banner{display:flex;align-items:center;gap:12px;padding:9px 22px;background:#1c2d1c;border-bottom:1px solid #30a46c44;font-size:13px;color:var(--text-dim);flex-shrink:0}.verify-banner--sent{background:#12261e;color:#3fb950}.verify-banner__btn{background:none;border:1px solid #30a46c44;border-radius:6px;color:#3fb950;font-size:12px;padding:3px 10px;cursor:pointer}.verify-banner__btn:hover{border-color:#30a46c}.verify-banner__dismiss{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:16px;margin-left:auto}.auth__done{display:flex;flex-direction:column;gap:16px;padding:8px 0;font-size:14px;color:var(--text)}.onboarding{padding:32px}.onboarding__steps{display:flex;align-items:center;gap:0;margin-bottom:32px}.onboarding__step{display:flex;align-items:center;gap:8px;cursor:default}.onboarding__step--done{cursor:pointer}.onboarding__step-num{width:26px;height:26px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.onboarding__step--active .onboarding__step-num{background:var(--accent);border-color:var(--accent);color:#fff}.onboarding__step--done .onboarding__step-num{background:#30a46c;border-color:#30a46c;color:#fff}.onboarding__step-label{font-size:13px;color:var(--text-dim);white-space:nowrap}.onboarding__step--active .onboarding__step-label{color:var(--text);font-weight:600}.onboarding__step-line{flex:1;height:1px;background:var(--border);min-width:32px;margin:0 8px}.onboarding__body{display:flex;flex-direction:column;gap:16px}.onboarding__title{font-size:20px;font-weight:700;margin:0}.onboarding__optional{font-size:13px;font-weight:400;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);border-radius:20px;padding:2px 8px;margin-left:8px}.onboarding__desc{font-size:14px;color:var(--text-dim);margin:0;line-height:1.6}.onboarding__hint{font-size:13px;color:var(--text-dim);margin:0}.onboarding__cmd-block{position:relative}.onboarding__cmd{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:14px 16px;font-size:13px;color:var(--text);white-space:pre;overflow-x:auto;margin:0}.onboarding__cmd--sm{font-size:12px;padding:10px 14px}.onboarding__copy{position:absolute;top:8px;right:8px;padding:4px 12px;font-size:12px}.onboarding__actions{display:flex;gap:10px;margin-top:8px}.onboarding__dropzone{border:2px dashed var(--border);border-radius:10px;padding:32px;text-align:center;cursor:pointer;color:var(--text-dim);font-size:14px;transition:border-color .15s}.onboarding__dropzone:hover{border-color:var(--accent)}.onboarding__dropzone-icon{font-size:40px;display:block;margin-bottom:8px;color:var(--accent)}.onboarding__drift-steps{display:flex;flex-direction:column;gap:18px}.onboarding__drift-step{display:flex;gap:14px;align-items:flex-start}.onboarding__drift-num{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.onboarding__drift-step p{margin:4px 0 0;font-size:13px;color:var(--text-dim)}.onboarding__keybtn{margin-top:8px;font-size:13px;padding:6px 14px}.modal--tall{max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.modal--tall .drift-detail__body,.modal--tall .scans{overflow-y:auto;flex:1;min-height:0}.apikey__subtitle{font-size:13px;color:var(--text-dim);margin:-12px 0 20px}.apikey__form{display:flex;gap:10px;margin-bottom:20px}.apikey__name-input{flex:1}.apikey__empty{color:var(--text-dim);font-size:13px;padding:16px 0}.apikeys{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;max-height:40vh;overflow-y:auto}.apikey-row{display:flex;align-items:center;gap:14px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:12px 14px}.apikey-row__main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.apikey-row__name{font-weight:600;font-size:14px}.apikey-row__prefix{font-family:monospace;font-size:12px;color:var(--text-dim)}.apikey-row__meta{display:flex;flex-direction:column;align-items:flex-end;font-size:11px;color:var(--text-dim);gap:2px;flex-shrink:0}.apikey-row__revoke{background:none;border:none;cursor:pointer;color:var(--text-dim);font-size:14px;flex-shrink:0;opacity:.6}.apikey-row__revoke:hover{opacity:1;color:#f85149}.apikey__reveal{background:#12261e;border:1px solid #30a46c44;border-radius:8px;padding:14px 16px;margin-bottom:20px}.apikey__reveal-label{font-size:13px;color:#30a46c;font-weight:600;margin:0 0 10px}.apikey__reveal-row{display:flex;gap:10px;align-items:center}.apikey__reveal-value{flex:1;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:8px 10px;word-break:break-all;color:var(--text)}.apikey__copy-btn{flex-shrink:0;padding:7px 14px;font-size:13px}.apikey__reveal-hint{font-size:12px;color:var(--text-dim);margin:8px 0 0}.apikey__reveal-hint code{font-size:11px}.drift-detail__header{margin-bottom:16px}.drift-detail__summary{font-size:13px;color:var(--text-dim);margin:4px 0 0}.drift-detail__clean{color:#30a46c;font-size:14px;padding:16px 0}.drift-detail__body{display:flex;flex-direction:column;gap:16px;padding-bottom:8px}.drift-section__title{font-size:13px;text-transform:uppercase;letter-spacing:.5px;margin:0 0 10px}.drift-section__title--red{color:#f85149}.drift-section__title--purple{color:#a371f7}.drift-missing{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.drift-missing__row{display:flex;align-items:center;gap:12px;background:var(--surface-2);border-radius:6px;padding:8px 12px;font-size:13px}.drift-missing__addr{color:var(--text);font-weight:600}.drift-missing__id{color:var(--text-dim);font-family:monospace;font-size:12px}.drift-missing__note{color:#f85149;margin-left:auto;font-size:12px}.drift-resource{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:12px 14px}.drift-resource__addr{display:flex;align-items:center;gap:10px;margin:0 0 10px;font-size:13px}.drift-resource__id{color:var(--text-dim);font-family:monospace;font-size:11px}.diff__live-note{color:#3fb950;font-size:11px;margin-left:4px}.drift-empty{color:var(--text-dim);font-size:13px;display:flex;flex-direction:column;gap:8px;padding:8px 0 16px}.drift-empty__cmd{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:12px 14px;font-size:12px;color:var(--text);white-space:pre;overflow-x:auto}.scan-row__clean{color:#30a46c;font-weight:600}.scan-row__loading{color:var(--text-dim);font-size:12px}.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width: 720px){.pricing-grid{grid-template-columns:1fr}}.pricing-card{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:22px;display:flex;flex-direction:column;gap:12px}.pricing-card--current{border-color:var(--accent)}.pricing-card__name{font-size:15px;font-weight:700}.pricing-card__price{font-size:26px;font-weight:700;color:var(--accent)}.pricing-card__features{list-style:none;padding:0;margin:0;flex:1;display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-dim)}.pricing-card__features li:before{content:"✓ ";color:#30a46c}.pricing-card__badge{font-size:12px;color:var(--accent);font-weight:600;text-align:center;padding:8px;border:1px solid var(--accent);border-radius:6px}
