.app{min-height:100vh;display:flex;flex-direction:column;position:relative}.scan-line{position:fixed;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.4;animation:scan 4s ease-in-out infinite;pointer-events:none;z-index:100}@keyframes scan{0%,to{transform:translate(-100%)}50%{transform:translate(100vw)}}.app-header{background:#111418e6;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:50}.header-inner{max-width:1200px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.header-brand{display:flex;align-items:center;gap:14px}.brand-icon{width:40px;height:40px;background:linear-gradient(135deg,#00e5a026,#00e5a00d);border:1px solid rgba(0,229,160,.3);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--accent)}.brand-name{font-size:20px;font-weight:800;letter-spacing:-.03em;line-height:1}.brand-name .accent{color:var(--accent)}.brand-sub{font-size:11px;color:var(--muted);font-family:var(--font-mono);margin-top:3px}.app-main{flex:1;max-width:1200px;margin:0 auto;width:100%;padding:32px 24px}.roles-grid{display:flex;flex-direction:column;gap:24px}.center-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:16px;color:var(--muted);text-align:center}.empty-hero{display:flex;flex-direction:column;align-items:center;gap:12px;max-width:400px}.empty-glyph{width:72px;height:72px;border:1px solid var(--border2);border-radius:18px;display:flex;align-items:center;justify-content:center;color:var(--border2);margin-bottom:8px}.empty-hero h2{color:var(--text);font-size:20px}.empty-hero p{color:var(--muted);font-size:13px;line-height:1.6}.err-box{max-width:420px;text-align:left;border-color:var(--danger)}.err-title{color:var(--danger);font-weight:700;margin-bottom:6px}.err-detail{font-family:var(--font-mono);font-size:12px;color:var(--muted);margin-bottom:8px}.err-hint{font-size:12px;color:var(--muted)}.role-card{display:flex;flex-direction:column;gap:0;padding:0;overflow:hidden;border-color:var(--border2);transition:border-color .2s}.role-card:hover{border-color:#00e5a04d}.role-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 20px 16px;border-bottom:1px solid var(--border)}.role-info{flex:1;min-width:0}.role-name-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.role-icon{color:var(--accent);flex-shrink:0}.role-name{font-size:17px;font-weight:700;letter-spacing:-.02em}.role-desc{font-size:12px;color:var(--muted);margin-bottom:8px}.role-stats{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.role-stats strong{color:var(--text)}.stat-sep{color:var(--border2)}.role-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.tasks-section{padding:12px 20px;display:flex;flex-direction:column;gap:6px;min-height:40px}.loading-row{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12px;padding:8px 0}.empty-tasks{display:flex;align-items:center;gap:10px;padding:16px;border:1px dashed var(--border2);border-radius:8px;color:var(--muted);font-size:12px}.empty-icon{color:var(--border2);flex-shrink:0}.task-row{border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:border-color .15s}.task-row:hover{border-color:var(--border2)}.task-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;cursor:pointer;gap:12px;background:#ffffff03;transition:background .15s}.task-header:hover{background:#ffffff08}.task-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.task-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.chevron{color:var(--muted);transition:transform .2s;flex-shrink:0}.chevron.open{transform:rotate(90deg)}.task-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.perm-count{font-size:11px;color:var(--muted);font-family:var(--font-mono)}.task-perms{display:flex;flex-wrap:wrap;gap:6px;padding:10px 12px 12px 32px;border-top:1px solid var(--border);background:#0003}.perm-badge{display:inline-flex;align-items:center;gap:0;font-family:var(--font-mono);font-size:11px;border-radius:4px;overflow:hidden;cursor:pointer;border:1px solid rgba(0,229,160,.15);transition:border-color .12s,box-shadow .12s}.perm-badge:hover{border-color:#00e5a080;box-shadow:0 0 8px #00e5a026}.perm-badge:hover .perm-copy-icon{opacity:1}.perm-svc{background:#00e5a01f;color:var(--accent);padding:3px 6px;font-weight:700}.perm-sep{background:#00e5a00f;color:#00e5a066;padding:3px 1px}.perm-action{color:#00e5a0cc;padding:3px 6px 3px 4px}.perm-copy-icon{opacity:0;transition:opacity .15s;margin-right:5px;color:var(--muted)}.perm-badge svg:last-child{margin-right:5px;color:var(--accent)}.add-task-wrap{border-top:1px solid var(--border);background:#00000026;display:flex;flex-direction:column}.add-task-form{padding:14px 20px 20px;display:flex;flex-direction:column;gap:10px}.role-suggestions-bar{padding:8px 20px 0}.role-suggestions-toggle{display:inline-flex;align-items:center;gap:6px;background:none;border:1px dashed var(--border2);border-radius:20px;padding:5px 12px;font-size:12px;color:var(--muted);cursor:pointer;transition:all .15s}.role-suggestions-toggle:hover,.role-suggestions-toggle.active{border-color:var(--accent);color:var(--accent);background:#00e5a00f}.role-sug-count{background:var(--accent);color:#000;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700;line-height:1.4}.role-sug-chevron{transition:transform .2s;margin-left:2px}.role-sug-chevron.open{transform:rotate(90deg)}.role-suggestions-panel{margin:8px 20px 0;padding:14px;background:#00e5a008;border:1px solid rgba(0,229,160,.12);border-radius:10px}.role-sug-loading{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;padding:4px 0}.role-sug-empty{color:var(--muted);font-size:12px;margin:0}.role-sug-hint{font-size:12px;color:var(--muted);margin:0 0 10px}.role-sug-hint strong{color:var(--text)}.role-sug-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:6px}.role-sug-chip{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:8px 10px;background:#ffffff08;border:1px solid var(--border2);border-radius:8px;cursor:pointer;text-align:left;transition:all .15s;width:100%}.role-sug-chip:hover{border-color:var(--accent);background:#00e5a00f;transform:translateY(-1px)}.role-sug-chip-name{font-size:12px;font-weight:600;color:var(--text);line-height:1.3}.role-sug-chip-cat{font-size:10px;color:var(--accent);font-family:var(--font-mono);font-weight:500}.role-sug-chip-desc{font-size:11px;color:var(--muted);line-height:1.4;margin-top:2px}.add-task-row{display:flex;gap:8px;align-items:stretch}.add-task-row .task-input-wrap{flex:1;min-width:0;position:relative}.add-task-row .task-input-wrap input{width:100%}.add-task-row select{width:140px;flex-shrink:0}.add-task-row .btn{flex-shrink:0;white-space:nowrap}.task-suggestions-dropdown{background:#111820;border:1px solid var(--border2);border-radius:10px;box-shadow:0 16px 48px #000c,0 0 0 1px #00e5a014;overflow:hidden;max-height:380px;overflow-y:auto}.task-suggestions-group-label{display:flex;align-items:center;gap:6px;padding:8px 14px 4px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-family:var(--font-mono);border-top:1px solid var(--border)}.task-suggestions-group-label:first-child{border-top:none}.task-suggestions-group-label.ai{color:#a78bfa}.task-suggestion-item{padding:9px 14px;cursor:pointer;transition:background .1s;border-left:2px solid transparent}.task-suggestion-item:hover,.task-suggestion-item.highlighted{background:#ffffff0d;border-left-color:var(--accent)}.task-suggestion-item.ai-suggestion:hover,.task-suggestion-item.ai-suggestion.highlighted{background:#a78bfa12;border-left-color:#a78bfa}.task-suggestion-main{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.task-suggestion-name{font-size:13px;font-weight:600;color:var(--text)}.task-suggestion-ai-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:700;padding:1px 6px;border-radius:4px;background:#a78bfa26;color:#a78bfa;font-family:var(--font-mono)}.task-suggestion-category{font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;background:#00e5a01a;color:var(--accent);font-family:var(--font-mono);margin-left:auto}.task-suggestion-desc{font-size:11.5px;color:var(--muted);margin-top:2px;line-height:1.4}.suggest-panel{background:#00e5a008;border:1px solid rgba(0,229,160,.2);border-radius:8px;overflow:hidden}.suggest-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid rgba(0,229,160,.15)}.suggest-title{font-size:12px;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:6px}.suggest-loading{display:flex;align-items:center;gap:8px;padding:12px;color:var(--muted);font-size:12px}.suggest-err{padding:10px 12px;color:var(--danger);font-size:12px}.suggest-perms{display:flex;flex-wrap:wrap;gap:6px;padding:10px 12px}.perm-disclaimer{display:flex;align-items:flex-start;gap:7px;width:100%;padding:8px 12px;margin-top:2px;background:#ffb8000f;border-top:1px solid rgba(255,184,0,.15);border-radius:0 0 6px 6px;font-size:11px;color:var(--muted);line-height:1.5}.perm-disclaimer-inline{border-radius:6px;border:1px solid rgba(255,184,0,.15);margin-top:4px}.perm-disclaimer-icon{color:var(--warn);flex-shrink:0;margin-top:1px}.new-role-btn{flex-shrink:0}.create-role-form{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;border-color:#00e5a033}.form-title{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:700;margin-bottom:2px;color:var(--text)}.create-role-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-btns{display:flex;justify-content:flex-end;gap:8px}.form-err{font-size:12px;color:var(--danger)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.modal{background:var(--surface);border:1px solid var(--border2);border-radius:14px;width:100%;max-width:680px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border)}.modal-title{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;color:var(--accent)}.modal-sub{font-size:11px;color:var(--muted);margin-top:4px;font-family:var(--font-mono)}.modal-loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--muted)}.policy-json{flex:1;overflow:auto;padding:20px;font-family:var(--font-mono);font-size:12px;line-height:1.7;color:var(--code);background:#0000004d;white-space:pre}.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border)}.btn-icon{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;transition:color .15s,background .15s}.btn-icon:hover{color:var(--text);background:#ffffff0d}.btn-icon.danger:hover{color:var(--danger);background:#ff3b5c14}.muted-text{color:var(--muted);font-size:12px}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.accent{color:var(--accent)}.risk-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:20px;font-size:10px;font-weight:700;font-family:var(--font-mono);letter-spacing:.04em;border:1px solid;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.risk-badge-lg{font-size:12px;padding:3px 10px}.perm-badge-flagged{border-color:#ef444466!important;animation:pulse-flag 2s ease-in-out infinite}.perm-badge-flagged .perm-svc{background:#ef444426!important;color:#f87171!important}.perm-badge-flagged .perm-action{color:#fca5a5!important}.perm-flag-icon{color:#ef4444;margin-left:4px;flex-shrink:0}@keyframes pulse-flag{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 0 3px #ef444426}}.task-row-flagged{border-color:#ef44444d!important}.polp-note{display:flex;gap:8px;align-items:flex-start;font-size:11px;color:var(--muted);line-height:1.5}.polp-note-icon{color:#f59e0b;flex-shrink:0;margin-top:1px}.polp-note span{flex:1}.task-notes{display:flex;flex-direction:column;gap:6px;padding:8px 12px 12px 32px;border-top:1px dashed var(--border);background:#f59e0b08}.suggest-risk-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid rgba(0,229,160,.1)}.suggest-count{font-size:11px;color:var(--muted);font-family:var(--font-mono)}.suggest-notes{display:flex;flex-direction:column;gap:6px;padding:8px 12px;border-bottom:1px solid rgba(0,229,160,.1);background:#f59e0b0a}.stat-flagged{display:inline-flex;align-items:center;gap:4px;color:#f87171}.stat-flagged svg{flex-shrink:0}.btn-audit{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:6px;font-size:12px;font-weight:600;font-family:var(--font-ui);cursor:pointer;background:transparent;color:#f59e0b;border:1px solid rgba(245,158,11,.3);transition:all .15s}.btn-audit:hover{background:#f59e0b14;border-color:#f59e0b}.modal-wide{max-width:820px}.audit-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:0}.audit-disclaimer{display:flex;align-items:flex-start;gap:8px;padding:10px 20px;background:#ffb8000d;border-bottom:1px solid rgba(255,184,0,.12);font-size:11px;color:var(--muted);line-height:1.5}.audit-summary{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;padding:20px;border-bottom:1px solid var(--border);background:#0003}.audit-summary-left{display:flex;flex-direction:column;gap:10px}.audit-overall-risk{display:flex;align-items:center;gap:10px}.audit-risk-label{font-size:11px;color:var(--muted);font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em}.audit-stat-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.audit-stat strong{color:var(--text)}.audit-stat-sep{color:var(--border2)}.audit-risk-bars{display:flex;flex-direction:column;gap:8px;min-width:200px}.audit-risk-bar-item{display:flex;align-items:center;gap:8px}.audit-risk-bar-label{font-size:11px;font-weight:700;font-family:var(--font-mono);width:52px;text-align:right}.audit-risk-bar-track{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.audit-risk-bar-fill{height:100%;border-radius:3px;transition:width .4s ease;min-width:2px}.audit-risk-bar-count{font-size:11px;color:var(--muted);font-family:var(--font-mono);width:16px;text-align:right}.audit-flagged-section{padding:16px 20px;border-bottom:1px solid var(--border);background:#ef44440a}.audit-section-title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--text);margin-bottom:6px}.audit-section-title .flag-icon{color:#ef4444}.audit-section-sub{font-size:11px;color:var(--muted);margin-bottom:10px;line-height:1.6}.audit-flagged-perms{display:flex;flex-wrap:wrap;gap:6px}.audit-findings{padding:16px 20px;display:flex;flex-direction:column;gap:8px}.audit-finding{border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:border-color .15s}.audit-finding-low{border-left:3px solid #22d3a5}.audit-finding-medium{border-left:3px solid #f59e0b}.audit-finding-high{border-left:3px solid #f97316}.audit-finding-critical{border-left:3px solid #ef4444}.audit-finding-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;gap:10px}.audit-finding-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.audit-finding-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.audit-finding-count{font-size:11px;color:var(--muted);font-family:var(--font-mono);flex-shrink:0}.audit-finding-notes{padding:8px 14px 12px;border-top:1px dashed var(--border);background:#00000026;display:flex;flex-direction:column;gap:6px}.audit-err{padding:20px;color:var(--danger);font-size:13px}.audit-empty{font-size:12px;color:var(--muted);text-align:center;padding:24px}.cloud-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;font-family:var(--font-mono);letter-spacing:.06em;border:1px solid;text-transform:uppercase}.role-card-azure{border-color:#0078d440!important}.role-card-azure:hover{border-color:#0078d480!important}.role-card-azure .role-icon{color:#0078d4!important}.perm-badge-azure{border-color:#0078d433!important}.perm-badge-azure:hover{border-color:#0078d499!important;box-shadow:0 0 8px #0078d42e!important}.perm-badge-azure .perm-svc{background:#0078d41f!important;color:#4da6ff!important}.perm-badge-azure .perm-sep{background:#0078d40f!important;color:#0078d466!important}.perm-badge-azure .perm-action{color:#4da6ffd9!important}.policy-json-azure{color:#4da6ff!important}.cloud-toggle{display:flex;align-items:center;gap:12px}.cloud-toggle-label{font-size:12px;color:var(--muted);font-weight:600;white-space:nowrap}.cloud-toggle-btns{display:flex;border:1px solid var(--border2);border-radius:8px;overflow:hidden}.cloud-toggle-btn{background:transparent;color:var(--muted);border:none;padding:6px 14px;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s;font-family:var(--font-ui)}.cloud-toggle-btn:first-child{border-right:1px solid var(--border2)}.cloud-toggle-btn:hover{color:var(--text);background:#ffffff0a}.cloud-toggle-btn.active{background:#00e5a01a;color:var(--accent)}.cloud-toggle-btn.azure-active{background:#0078d41f;color:#4da6ff}.cloud-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}.aws-dot{background:#f90}.azure-dot{background:#0078d4}.modal-hint{display:flex;align-items:center;gap:10px;padding:8px 20px;background:#0078d40f;border-bottom:1px solid rgba(0,120,212,.15);font-size:12px;color:var(--muted)}.modal-hint code{font-family:var(--font-mono);font-size:11px;color:#4da6ff;background:#0078d41a;padding:2px 8px;border-radius:4px}.header-right{display:flex;align-items:center;gap:10px}.btn-ai{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:8px;font-size:13px;font-weight:600;font-family:var(--font-ui);cursor:pointer;border:1px solid rgba(168,85,247,.4);background:#a855f714;color:#c084fc;transition:all .18s;position:relative;overflow:hidden}.btn-ai:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(168,85,247,.15),transparent);opacity:0;transition:opacity .18s}.btn-ai:hover{border-color:#a855f7b3;color:#e879f9;background:#a855f724}.btn-ai:hover:before{opacity:1}.btn-mode-toggle{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:6px;font-size:12px;font-weight:600;font-family:var(--font-ui);cursor:pointer;background:transparent;color:var(--muted);border:1px solid var(--border2);transition:all .15s}.btn-mode-toggle:hover{color:var(--text);border-color:#fff3}.btn-mode-toggle.active{background:#60a5fa1a;border-color:#60a5fa59;color:#60a5fa}.btn-mode-toggle.active svg{color:#60a5fa}.managed-mode-bar{display:flex;align-items:center;gap:8px;padding:8px 20px;background:#60a5fa0f;border-bottom:1px solid rgba(96,165,250,.15);font-size:11px;color:#93c5fd}.managed-mode-bar svg{flex-shrink:0;color:#60a5fa}.managed-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;font-family:var(--font-mono);letter-spacing:.05em;background:#60a5fa1a;color:#60a5fa;border:1px solid rgba(96,165,250,.25);text-transform:uppercase}.managed-mode-tag{display:inline-flex;align-items:center;gap:3px;padding:1px 7px;border-radius:20px;font-size:9px;font-weight:700;font-family:var(--font-mono);background:#60a5fa1a;color:#93c5fd;border:1px solid rgba(96,165,250,.2);text-transform:uppercase;letter-spacing:.04em}.task-managed-section{padding:10px 14px 14px 32px;border-top:1px solid var(--border);background:#0000002e;display:flex;flex-direction:column;gap:10px}.managed-loading{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--muted)}.managed-no-match{font-size:11px;color:var(--muted);font-style:italic}.managed-role-badge{border:1px solid rgba(96,165,250,.2);border-radius:8px;padding:10px 12px;background:#60a5fa0a;display:flex;flex-direction:column;gap:6px;transition:border-color .15s}.managed-role-badge:hover{border-color:#60a5fa66}.managed-role-header{display:flex;align-items:center;gap:8px}.managed-role-name{font-size:13px;font-weight:600;color:#93c5fd;font-family:var(--font-mono)}.managed-role-notes{font-size:11px;color:var(--muted);line-height:1.55;margin:0}.managed-role-ref{display:flex;align-items:center;gap:6px}.managed-role-ref code{font-family:var(--font-mono);font-size:10px;color:#60a5fab3;background:#60a5fa14;padding:2px 8px;border-radius:4px;word-break:break-all}.btn-inline-copy{background:transparent;border:none;cursor:pointer;color:var(--muted);padding:2px;display:flex;align-items:center;border-radius:3px;transition:color .12s;flex-shrink:0}.btn-inline-copy:hover{color:var(--text)}.suggest-managed-list{display:flex;flex-direction:column;gap:10px;padding:12px}.suggest-no-managed{font-size:12px;color:var(--muted);font-style:italic;padding:8px}.export-managed-list{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px;max-height:260px;overflow-y:auto}.ai-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;justify-content:flex-end}.ai-drawer{width:520px;max-width:100vw;height:100vh;background:var(--surface);border-left:1px solid rgba(168,85,247,.25);display:flex;flex-direction:column;box-shadow:-12px 0 60px #00000080;animation:slideInRight .25s cubic-bezier(.16,1,.3,1)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ai-drawer-header{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid rgba(168,85,247,.2);background:#a855f70a;flex-shrink:0;gap:12px}.ai-drawer-title{display:flex;align-items:flex-start;gap:12px}.ai-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#a855f74d,#ec489933);border:1px solid rgba(168,85,247,.35);display:flex;align-items:center;justify-content:center;color:#c084fc;flex-shrink:0}.ai-title-text{font-size:15px;font-weight:700;color:var(--text);line-height:1.2}.ai-title-sub{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.4}.ai-header-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.ai-cloud-toggle{border-color:#a855f74d!important}.ai-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px;scroll-behavior:smooth}.ai-msg{display:flex;gap:10px;align-items:flex-start;animation:msgIn .2s ease}@keyframes msgIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ai-msg-avatar{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px}.ai-msg-user .ai-msg-avatar{background:#00e5a01a;border:1px solid rgba(0,229,160,.2);color:var(--accent);align-self:flex-start;margin-left:auto;order:2}.ai-msg-assistant .ai-msg-avatar{background:#a855f71f;border:1px solid rgba(168,85,247,.25);color:#c084fc}.ai-msg-user{flex-direction:row-reverse}.ai-msg-user .ai-msg-body{align-items:flex-end}.ai-msg-body{display:flex;flex-direction:column;gap:8px;max-width:calc(100% - 44px)}.ai-msg-text{font-size:13px;line-height:1.6;color:var(--text);background:#ffffff0a;border:1px solid var(--border);border-radius:10px;padding:10px 13px;margin:0;word-break:break-word}.ai-msg-user .ai-msg-text{background:#00e5a012;border-color:#00e5a033}.ai-msg-assistant .ai-msg-text{background:#a855f70d;border-color:#a855f726}.ai-inline-code{font-family:var(--font-mono);font-size:11px;background:#ffffff12;padding:1px 5px;border-radius:3px;color:var(--accent)}.ai-msg-text ul{margin:6px 0 0;padding-left:18px}.ai-msg-text li{margin-bottom:3px}.ai-thinking{display:flex;align-items:center;gap:5px;padding:12px 14px;background:#a855f70d;border:1px solid rgba(168,85,247,.15);border-radius:10px}.ai-thinking span{width:6px;height:6px;border-radius:50%;background:#a855f780;animation:dot-bounce 1.2s ease-in-out infinite}.ai-thinking span:nth-child(2){animation-delay:.2s}.ai-thinking span:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-6px);opacity:1}}.ai-rec{border:1px solid rgba(168,85,247,.25);border-radius:10px;background:#a855f70a;overflow:hidden;width:100%}.ai-rec-low{border-color:#22d3a54d;background:#22d3a50a}.ai-rec-medium{border-color:#f59e0b4d;background:#f59e0b0a}.ai-rec-high{border-color:#f973164d;background:#f973160a}.ai-rec-critical{border-color:#ef44444d;background:#ef44440a}.ai-rec-header{padding:10px 14px 6px;border-bottom:1px solid rgba(255,255,255,.05)}.ai-rec-title{display:flex;align-items:center;gap:7px;flex-wrap:wrap;font-size:13px;color:var(--text)}.ai-rec-title svg{color:var(--accent);flex-shrink:0}.ai-rec-rationale{font-size:11px;color:var(--muted);line-height:1.55;padding:6px 14px 4px;margin:0}.ai-rec-tasks,.ai-rec-managed{padding:6px 14px 10px;display:flex;flex-direction:column;gap:4px}.ai-rec-section-label{font-size:10px;font-weight:700;font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;display:block}.ai-task-chip{display:inline-flex;align-items:center;font-size:11px;color:var(--text);background:#00e5a012;border:1px solid rgba(0,229,160,.18);border-radius:5px;padding:3px 9px;font-family:var(--font-mono);width:fit-content}.ai-managed-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:#93c5fd;background:#60a5fa14;border:1px solid rgba(96,165,250,.2);border-radius:5px;padding:3px 9px;font-family:var(--font-mono);width:fit-content}.ai-apply-btn{margin:6px 14px 12px;width:calc(100% - 28px);justify-content:center}.ai-followup{font-size:12px;color:#c084fc;font-style:italic;margin:0;padding:6px 2px 0}.ai-limit-banner{display:flex;align-items:center;gap:7px;font-size:11.5px;padding:8px 16px;border-top:1px solid}.ai-limit-warn{color:#f59e0b;border-color:#f59e0b33;background:#f59e0b0f}.ai-limit-reached{color:var(--danger);border-color:#ef444433;background:#ef44440f}.ai-input:disabled{opacity:.5;cursor:not-allowed}.ai-input-area{display:flex;gap:8px;padding:14px 16px;border-top:1px solid rgba(168,85,247,.2);background:#a855f708;flex-shrink:0;align-items:flex-end}.ai-input{flex:1;background:#ffffff0d;border:1px solid rgba(168,85,247,.25);border-radius:10px;color:var(--text);font-family:var(--font-ui);font-size:13px;padding:10px 14px;resize:none;line-height:1.5;outline:none;transition:border-color .15s;min-height:42px;max-height:120px}.ai-input:focus{border-color:#a855f78c}.ai-input::placeholder{color:var(--muted)}.ai-send-btn{width:40px;height:40px;border-radius:10px;border:1px solid rgba(168,85,247,.35);background:#a855f71f;color:#c084fc;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.ai-send-btn:hover:not(:disabled){background:#a855f740;border-color:#a855f799}.ai-send-btn:disabled{opacity:.4;cursor:not-allowed}.affiliate-banner{display:flex;align-items:center;gap:12px;padding:8px 20px;background:#f59e0b0f;border-bottom:1px solid rgba(245,158,11,.15);font-size:12px;color:var(--muted);flex-wrap:wrap}.banner-tag{font-size:9px;font-weight:700;font-family:var(--font-mono);padding:1px 6px;border-radius:3px;background:#f59e0b26;color:#f59e0b;text-transform:uppercase;letter-spacing:.06em;flex-shrink:0}.banner-text{flex:1;min-width:200px}.banner-text strong{color:var(--text)}.banner-link{color:#f59e0b;text-decoration:none;font-weight:600;font-size:12px;white-space:nowrap;flex-shrink:0}.banner-link:hover{text-decoration:underline}.banner-dismiss{cursor:pointer;color:var(--muted);font-size:11px;flex-shrink:0;opacity:.5}.banner-dismiss:hover{opacity:1}.sidebar-ads{width:260px;flex-shrink:0;display:flex;flex-direction:column;gap:16px;align-self:flex-start;position:sticky;top:80px}.affiliate-ad{background:var(--surface);border:1px solid var(--border2);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px}.ad-tag{font-size:9px;font-weight:700;font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.ad-sponsor{font-size:13px;font-weight:700;color:var(--text)}.ad-headline{font-size:13px;font-weight:600;color:var(--text);line-height:1.4}.ad-body{font-size:11px;color:var(--muted);line-height:1.6}.ad-cta{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;color:var(--accent);text-decoration:none;margin-top:4px}.ad-cta:hover{text-decoration:underline}.sidebar-upgrade-card{background:#a78bfa0f;border:1px solid rgba(167,139,250,.2);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px}.sidebar-upgrade-card strong{color:var(--text);font-size:13px}.sidebar-upgrade-card p{font-size:11px;color:var(--muted);line-height:1.55}.sidebar-upgrade-card .btn{justify-content:center}.app-layout{display:flex;gap:24px;align-items:flex-start}.roles-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:0}.tier-badge-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;font-size:11px;font-weight:700;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;background:transparent;border:1px solid;cursor:pointer;transition:all .15s}.tier-badge-btn:hover{filter:brightness(1.2)}.tier-upgrade-hint{font-size:9px;background:#a78bfa33;color:#a78bfa;padding:1px 5px;border-radius:3px;margin-left:2px}.upgrade-callout{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#a78bfa0f;border:1px solid rgba(167,139,250,.2);border-radius:10px;margin-bottom:20px;font-size:12px;color:var(--muted)}.upgrade-callout svg{color:#a78bfa;flex-shrink:0}.upgrade-callout strong{color:var(--text)}.upgrade-callout-btn{display:inline-flex;align-items:center;gap:5px;margin-left:auto;background:#a78bfa1a;color:#a78bfa;border:1px solid rgba(167,139,250,.3);border-radius:6px;padding:4px 12px;font-size:11px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s}.upgrade-callout-btn:hover{background:#a78bfa33}.btn-suggest{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:8px;font-size:12px;font-weight:600;font-family:var(--font-ui);cursor:pointer;background:transparent;color:#34d399;border:1px solid rgba(52,211,153,.3);transition:all .15s}.btn-suggest:hover{background:#34d39914;border-color:#34d39999}.empty-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:8px}.btn-approval{gap:7px;font-size:12px}.btn-lock-icon{opacity:.6;margin-left:-2px}.tier-gate{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;color:var(--muted);border:1px dashed var(--border2);cursor:pointer;transition:all .15s}.tier-gate:hover{border-color:#a78bfa66;color:#a78bfa}.btn-audit-locked{opacity:.6;cursor:pointer}.btn-audit-locked:hover{opacity:1}.modal-pricing{max-width:900px!important}.pricing-billing-toggle{display:flex;gap:0;padding:14px 20px 0;border-bottom:1px solid var(--border)}.billing-opt{padding:7px 20px;font-size:13px;font-weight:600;font-family:var(--font-ui);color:var(--muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .15s;margin-bottom:-1px;display:flex;align-items:center;gap:6px}.billing-opt.active{color:var(--accent);border-bottom-color:var(--accent)}.billing-save{font-size:9px;font-weight:700;font-family:var(--font-mono);background:#00e5a026;color:var(--accent);padding:1px 5px;border-radius:3px;text-transform:uppercase}.pricing-success{margin:16px 20px 0;display:flex;align-items:flex-start;gap:12px;padding:14px;background:#22d3a512;border:1px solid rgba(34,211,165,.25);border-radius:10px}.success-icon{color:#22d3a5;flex-shrink:0;margin-top:2px}.pricing-success strong{color:var(--text);font-size:14px}.pricing-success p{color:var(--muted);font-size:12px;margin-top:4px}.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:20px}.pricing-card{border:1px solid var(--border2);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:12px;position:relative;transition:border-color .2s,box-shadow .2s;background:#ffffff04}.pricing-card:hover{border-color:var(--plan-accent, var(--border2));box-shadow:0 0 0 1px var(--plan-accent, transparent)}.pricing-card-featured{border-color:#a78bfa66;background:#a78bfa0a;box-shadow:0 0 0 1px #a78bfa26}.pricing-card-current{opacity:.8}.pricing-popular-tag{position:absolute;top:-11px;left:50%;transform:translate(-50%);font-size:10px;font-weight:700;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;background:#a78bfa;color:#000;padding:2px 10px;border-radius:20px;white-space:nowrap}.pricing-current-tag{position:absolute;top:-11px;right:14px;font-size:10px;font-weight:700;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;background:var(--border2);color:var(--muted);padding:2px 10px;border-radius:20px}.pricing-card-header{display:flex;align-items:flex-start;gap:12px}.pricing-icon{width:42px;height:42px;border-radius:10px;border:1px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pricing-tier-name{font-size:13px;font-weight:700;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em}.pricing-price{display:flex;align-items:baseline;gap:3px;flex-wrap:wrap}.price-free{font-size:18px;font-weight:700;color:var(--muted)}.price-amount{font-size:28px;font-weight:800;color:var(--text);letter-spacing:-.03em}.price-period{font-size:13px;color:var(--muted)}.price-billed{font-size:11px;color:var(--muted);width:100%}.pricing-features{list-style:none;display:flex;flex-direction:column;gap:7px;flex:1}.pricing-features li{display:flex;align-items:flex-start;gap:7px;font-size:12px;color:var(--muted);line-height:1.4}.pricing-features li svg{flex-shrink:0;margin-top:1px}.pricing-cta{width:100%;justify-content:center;margin-top:4px}.pricing-cta-current{cursor:default!important}.pricing-err{padding:0 20px 16px;color:var(--danger);font-size:12px}.pricing-footer{padding:12px 20px 20px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.pricing-footer p{font-size:11px;color:var(--muted);line-height:1.5}.pricing-footer a{color:var(--accent);text-decoration:none}.pricing-footer a:hover{text-decoration:underline}.modal-suggest{max-width:640px!important}.suggest-form{padding:20px;display:flex;flex-direction:column;gap:0;overflow-y:auto;max-height:calc(85vh - 80px)}.suggest-section{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.suggest-label{font-size:11px;font-weight:700;font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.suggest-label-hint{font-weight:400;text-transform:none;letter-spacing:0;font-family:var(--font-ui)}.task-input-row{display:flex;gap:8px}.task-input-row input{flex:1}.task-input-row .btn{flex-shrink:0;white-space:nowrap}.suggest-task-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.suggest-task-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-family:var(--font-mono);color:var(--text);background:#00e5a012;border:1px solid rgba(0,229,160,.2);border-radius:5px;padding:3px 8px}.suggest-task-chip button{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:0;display:flex;align-items:center;transition:color .12s}.suggest-task-chip button:hover{color:var(--danger)}.suggest-submitter{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.suggest-submitter .suggest-section:last-child{grid-column:1 / -1}.suggest-success{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;text-align:center}.success-icon-lg{color:#22d3a5}.suggest-success h3{font-size:18px;font-weight:700}.suggest-success p{font-size:13px;color:var(--muted);max-width:340px;line-height:1.6}.modal-approval{max-width:760px!important}.approval-tabs{display:flex;align-items:center;gap:4px;padding:10px 16px;border-bottom:1px solid var(--border);background:#00000040;flex-shrink:0}.approval-tab{display:flex;align-items:center;gap:6px;padding:7px 16px;font-size:12px;font-weight:600;font-family:var(--font-ui);color:var(--muted);background:transparent;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s;white-space:nowrap}.approval-tab:hover{color:var(--text);background:#ffffff0f;border-color:var(--border2)}.approval-tab.active{color:#000;background:var(--accent);border-color:var(--accent)}.approval-tab.active svg{color:#000}.approval-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.approval-loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--muted)}.approval-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:48px;color:var(--muted);font-size:13px}.approval-card{border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:8px;background:#ffffff04;transition:border-color .15s}.approval-card:hover{border-color:var(--border2)}.approval-card-pending{border-left:3px solid #f59e0b}.approval-card-approved{border-left:3px solid #22d3a5}.approval-card-rejected{border-left:3px solid #ef4444}.approval-card-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.approval-card-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0;flex-wrap:wrap}.approval-card-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.approval-role-name{font-size:14px;font-weight:700}.approval-date{font-size:11px;color:var(--muted);font-family:var(--font-mono)}.approval-submitter{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);font-family:var(--font-mono)}.approval-desc,.approval-usecase{font-size:12px;color:var(--muted);line-height:1.55}.approval-usecase strong{color:var(--text)}.approval-tasks{display:flex;flex-wrap:wrap;gap:5px;align-items:center}.approval-tasks-label{font-size:10px;font-weight:700;font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-right:4px}.approval-task-chip{display:inline-flex;font-size:11px;font-family:var(--font-mono);color:var(--text);background:#00e5a00f;border:1px solid rgba(0,229,160,.15);border-radius:4px;padding:2px 8px}.approval-reviewer-notes{display:flex;align-items:flex-start;gap:6px;font-size:12px;color:var(--muted);padding:6px 10px;background:#ffffff08;border-radius:6px}.approval-reviewer-notes svg{flex-shrink:0;color:var(--muted);margin-top:1px}.approval-reviewed-at{font-size:11px;color:var(--muted);font-family:var(--font-mono)}.approval-materialized{display:flex;align-items:center;gap:5px;font-size:11px;color:#22d3a5;font-family:var(--font-mono)}.approval-actions{margin-top:4px}.approval-review-btn{font-size:12px;gap:6px}.approval-review-form{display:flex;flex-direction:column;gap:8px}.approval-review-form textarea{font-size:12px;resize:vertical;min-height:60px}.approval-review-btns{display:flex;gap:8px;justify-content:flex-end}.btn-approve{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:6px;font-size:12px;font-weight:600;font-family:var(--font-ui);cursor:pointer;background:#22d3a51a;color:#22d3a5;border:1px solid rgba(34,211,165,.3);transition:all .15s}.btn-approve:hover{background:#22d3a533;border-color:#22d3a5}.btn-reject{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:6px;font-size:12px;font-weight:600;font-family:var(--font-ui);cursor:pointer;background:#ef444412;color:#f87171;border:1px solid rgba(239,68,68,.25);transition:all .15s}.btn-reject:hover{background:#ef444426;border-color:#ef4444}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em}.ai-gate{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:48px 32px;text-align:center}.ai-gate-icon{width:64px;height:64px;border-radius:16px;background:#a78bfa1a;border:1px solid rgba(167,139,250,.25);display:flex;align-items:center;justify-content:center;color:#a78bfa99}.ai-gate h3{font-size:16px;font-weight:700}.ai-gate p{font-size:13px;color:var(--muted);max-width:280px;line-height:1.6}.perm-badge{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none}.perm-remove-btn{display:none;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:#ef444426;border:none;cursor:pointer;color:#f87171;padding:0;margin-left:2px;flex-shrink:0;transition:background .12s}.perm-remove-btn:hover{background:#ef444459}.perm-badge-removable .perm-remove-btn,.perm-badge:hover .perm-remove-btn{display:inline-flex}.perm-removing{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--muted);font-family:var(--font-mono);padding:4px 0}.perm-add-btn{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-family:var(--font-mono);color:var(--muted);background:none;border:1px dashed var(--border2);border-radius:6px;padding:3px 9px;cursor:pointer;transition:color .15s,border-color .15s;height:24px}.perm-add-btn:hover{color:var(--accent);border-color:var(--accent)}.perm-add-row{display:flex;align-items:flex-start;gap:6px;width:100%;margin-top:2px;flex-wrap:wrap}.perm-add-input-wrap{position:relative;flex:1;min-width:200px}.perm-add-input{width:100%;height:30px;padding:0 10px;font-family:var(--font-mono);font-size:12px;background:var(--bg);border:1px solid var(--accent);border-radius:6px;color:var(--text);outline:none;box-shadow:0 0 0 2px #00e5a01f}.perm-add-input::placeholder{color:var(--muted)}.perm-add-input:disabled{opacity:.5}.perm-autocomplete{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border2);border-radius:8px;list-style:none;overflow:hidden;z-index:80;box-shadow:0 8px 24px #0006}.perm-ac-item{padding:6px 10px;cursor:pointer;transition:background .1s;display:flex;align-items:center}.perm-ac-item:hover,.perm-ac-active{background:#00e5a014}.perm-add-confirm,.perm-add-cancel{height:30px;padding:0 10px;flex-shrink:0}.perm-add-err{width:100%;font-size:11px;font-family:var(--font-mono);color:var(--danger);padding:2px 0}.settings-drawer{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:100vw;background:var(--surface-raised);border-left:1px solid var(--border2);display:flex;flex-direction:column;z-index:200;box-shadow:-8px 0 40px #0006}.settings-avatar{background:#64748b26!important;border-color:#64748b4d!important;color:#94a3b8!important}.settings-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:0}.settings-section{padding:18px 0;border-bottom:1px solid var(--border)}.settings-section:last-child{border-bottom:none}.settings-section-title{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--text);margin-bottom:8px}.settings-section-desc{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:14px}.settings-label{display:block;font-size:11px;font-weight:700;font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.settings-hint{font-size:11px;color:var(--muted);margin-top:5px;font-family:var(--font-mono);word-break:break-all}.settings-key-row{display:flex;gap:8px;align-items:center}.settings-key-row input{flex:1}.settings-override-active{display:flex;align-items:center;gap:6px;font-size:11px;color:#22d3a5;font-family:var(--font-mono);margin-top:10px}.settings-info-box{font-size:12px;color:var(--muted);background:#22d3a50f;border:1px solid rgba(34,211,165,.2);border-radius:8px;padding:10px 12px;margin-top:10px;line-height:1.6}.settings-footer{display:flex;gap:10px;justify-content:flex-end;padding:16px 20px;border-top:1px solid var(--border);flex-shrink:0}.pricing-mode-toggle{display:flex;flex-direction:column;gap:8px}.pricing-mode-btn{display:flex;align-items:center;gap:9px;padding:10px 14px;border-radius:8px;font-size:13px;font-weight:600;font-family:var(--font-ui);color:var(--muted);background:transparent;border:1px solid var(--border2);cursor:pointer;transition:all .15s;text-align:left}.pricing-mode-btn:hover{border-color:var(--accent);color:var(--text)}.pricing-mode-btn.active{color:var(--accent);border-color:#00e5a066;background:#00e5a00f}.free-mode-info{display:flex;flex-direction:column;align-items:center;gap:14px;padding:48px 32px;text-align:center}.free-mode-info h3{font-size:18px;font-weight:700}.free-mode-info p{font-size:13px;color:var(--muted);max-width:380px;line-height:1.6}.free-mode-info code{font-family:var(--font-mono);font-size:12px;background:#ffffff12;padding:1px 6px;border-radius:4px}.admin-auth-form{display:flex;flex-direction:column;align-items:center;gap:14px;padding:48px 32px;text-align:center}.admin-auth-icon{width:64px;height:64px;border-radius:16px;background:#a78bfa1a;border:1px solid rgba(167,139,250,.25);display:flex;align-items:center;justify-content:center;color:#a78bfacc}.admin-auth-form h3{font-size:16px;font-weight:700}.admin-auth-form p{font-size:12px;color:var(--muted);line-height:1.6;max-width:300px}.admin-auth-form p code{font-family:var(--font-mono);background:#ffffff12;padding:1px 5px;border-radius:4px;font-size:11px}.admin-auth-form input{width:100%;max-width:320px;text-align:center;letter-spacing:.08em}.approval-tab-refresh{margin-left:auto;padding:7px 10px;background:transparent;border:1px solid var(--border2);color:var(--muted);cursor:pointer;border-radius:6px;transition:all .12s;display:flex;align-items:center}.approval-tab-refresh:hover{color:var(--text);background:#ffffff0d}.approval-target-role{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);font-family:var(--font-mono)}.approval-target-role svg{color:var(--accent)}.approval-target-role strong{color:var(--text)}.rate-limit-note{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);font-family:var(--font-mono);padding:8px 10px;background:#f59e0b0d;border:1px solid rgba(245,158,11,.15);border-radius:6px;margin-bottom:4px}.rate-limit-note svg{color:#f59e0b;flex-shrink:0}.ai-override-badge{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;background:#00e5a01a;color:var(--accent);border:1px solid rgba(0,229,160,.3);border-radius:4px;padding:1px 6px;margin-left:6px;vertical-align:middle}.header-settings{color:var(--muted);transition:color .15s}.header-settings:hover{color:var(--text)}.admin-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.admin-page-header{display:flex;align-items:center;gap:16px;padding:14px 24px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10}.admin-page-back{font-size:13px;padding:6px 14px;white-space:nowrap}.admin-page-title{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:15px;font-weight:700;color:var(--text);letter-spacing:.01em}.admin-panel-inline{flex:1;max-width:1100px;width:100%;margin:32px auto;padding:0 24px 48px;display:flex;flex-direction:column;gap:0}.admin-panel-inline .admin-auth-form{margin:40px auto 0}.admin-panel-inline .approval-body{max-height:none;overflow:visible}.analytics-full-bleed{flex:1;width:100%;padding:0 28px 48px;box-sizing:border-box}.admin-panel-inline .approval-tabs{position:sticky;top:57px;z-index:5;background:var(--bg);border-bottom:1px solid var(--border);margin-bottom:16px}.admin-page-tabs{display:flex;gap:4px;margin-left:auto;background:#0000004d;padding:4px;border-radius:8px;border:1px solid var(--border)}.admin-page-tab{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:5px;border:1px solid transparent;background:transparent;color:var(--muted);font-family:var(--font-mono);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.admin-page-tab:hover{color:var(--text);background:#ffffff0f;border-color:var(--border2)}.admin-page-tab.active{color:#000;background:var(--accent);border-color:var(--accent)}.admin-page-tab.active svg{color:#000}.admin-sign-out{margin-left:auto;color:var(--muted);opacity:.7}.admin-sign-out:hover{color:var(--danger);border-color:var(--danger);background:#ff3b5c14;opacity:1}.modal-export{width:min(860px,96vw);max-height:90vh;display:flex;flex-direction:column}.export-tab-bar{display:flex;align-items:center;gap:4px;padding:10px 16px;border-bottom:1px solid var(--border);background:#00000040;flex-shrink:0;overflow-x:auto;scrollbar-width:none}.export-tab-bar::-webkit-scrollbar{display:none}.export-tab{display:flex;align-items:center;padding:7px 14px;font-family:var(--font-mono);font-size:11.5px;font-weight:600;color:var(--muted);background:transparent;border:1px solid transparent;border-radius:6px;cursor:pointer;white-space:nowrap;transition:all .15s}.export-tab:hover{color:var(--text);background:#ffffff0f;border-color:var(--border2)}.export-tab.active{color:#000;background:var(--accent);border-color:var(--accent)}.export-tab-bar .export-tab-policy{margin-left:auto}.export-tab-bar .export-tab-policy:not(.active){color:var(--muted);border-color:var(--border2);background:#ffffff08}.export-disclaimer{display:flex;align-items:flex-start;gap:10px;margin:0 20px 16px;padding:12px 14px;background:#ffb80012;border:1px solid rgba(255,184,0,.2);border-radius:8px;font-size:12px;color:var(--muted);line-height:1.6}.export-disclaimer strong{color:var(--warn)}.export-disclaimer-icon{color:var(--warn);flex-shrink:0;margin-top:2px}.export-hint{display:flex;align-items:center;gap:10px;padding:9px 20px;background:#22d3a50d;border-bottom:1px solid rgba(34,211,165,.15);font-size:12px;flex-shrink:0;overflow-x:auto}.export-hint span{color:var(--accent);font-size:11px;flex-shrink:0}.export-hint code{font-family:var(--font-mono);font-size:11.5px;color:var(--text);white-space:nowrap}.export-code{flex:1;overflow:auto;margin:0;padding:20px 24px;font-family:var(--font-mono);font-size:12px;line-height:1.65;background:#0d0d14;color:#e2e8f0;border:none;border-radius:0;white-space:pre;-moz-tab-size:2;tab-size:2}.export-code-hcl,.export-code-bicep{color:#e2e8f0}.export-code-yaml{color:#f0ede6}.export-code-py{color:#e8e0ff}.export-code-json{color:#e2f0ec}.notify-loading{display:flex;align-items:center;gap:8px;padding:20px 0 8px;font-size:13px;color:var(--muted)}.notify-url-row{display:flex;gap:8px;align-items:center;margin-top:6px}.notify-url-row input{flex:1;font-family:var(--font-mono);font-size:12px}.notify-test-btn{flex-shrink:0;display:flex;align-items:center;gap:6px;padding:0 14px;height:36px;font-size:12px;font-weight:600;border-radius:7px;border:1px solid var(--border2);background:#ffffff0a;color:var(--muted);cursor:pointer;transition:all .15s;white-space:nowrap}.notify-test-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:#00e5a00f}.notify-test-btn:disabled{opacity:.4;cursor:not-allowed}.notify-test-btn.notify-test-ok{border-color:#22d3a5;color:#22d3a5;background:#22d3a514}.notify-test-btn.notify-test-err{border-color:#f87171;color:#f87171;background:#f8717114}.notify-platform-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.notify-platform-btn{padding:5px 14px;border-radius:6px;border:1px solid var(--border2);background:transparent;color:var(--muted);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.notify-platform-btn:hover{border-color:#ffffff40;color:var(--text);background:#ffffff0d}.notify-platform-btn.active{border-color:#00e5a080;color:var(--accent);background:#00e5a014;font-weight:600}.notify-events{display:flex;flex-direction:column;gap:10px;margin-top:8px;padding:14px 16px;background:#0003;border:1px solid var(--border);border-radius:8px}.notify-event-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none}.notify-event-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.notify-event-row svg{color:var(--muted);flex-shrink:0}.notify-templates-header{display:flex;align-items:center;gap:6px;margin-top:16px;padding:8px 0;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;border-top:1px solid var(--border);-webkit-user-select:none;user-select:none;transition:color .15s}.notify-templates-header:hover{color:var(--text)}.notify-templates-header svg{color:var(--muted);flex-shrink:0}.notify-templates-header .settings-hint{font-weight:400;font-family:var(--font-mono);letter-spacing:.01em}.notify-templates{display:flex;flex-direction:column;gap:12px;margin-top:4px}.notify-tpl-block{background:#0003;border:1px solid var(--border);border-radius:8px;padding:12px 14px;transition:opacity .15s}.notify-tpl-block.notify-tpl-muted{opacity:.5}.notify-tpl-label{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:8px}.notify-tpl-disabled-tag{font-size:10px;font-weight:500;text-transform:none;letter-spacing:0;padding:2px 7px;border-radius:4px;background:#ffffff0f;border:1px solid var(--border2);color:var(--muted)}.notify-tpl-textarea{width:100%;box-sizing:border-box;background:#00000040;border:1px solid var(--border2);border-radius:6px;color:var(--text);font-family:var(--font-mono);font-size:11.5px;line-height:1.6;padding:8px 10px;resize:vertical;min-height:80px;transition:border-color .15s}.notify-tpl-textarea:focus{outline:none;border-color:#00e5a066}.notify-tpl-textarea::placeholder{color:#fff3}.notify-tpl-reset{margin-top:6px;background:none;border:none;padding:0;font-size:11px;color:var(--muted);cursor:pointer;transition:color .15s}.notify-tpl-reset:hover{color:var(--accent)}.notify-save-row{margin-top:16px;display:flex;justify-content:flex-end}.analytics-loading,.analytics-error{display:flex;align-items:center;gap:10px;padding:40px;color:var(--muted);font-size:13px}.analytics-error{color:var(--danger)}.analytics-panel{padding:24px 28px;display:flex;flex-direction:column;gap:20px}.analytics-toolbar{display:flex;align-items:center;justify-content:space-between}.analytics-title{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--text)}.analytics-period-btns{display:flex;gap:4px}.analytics-period-btn{padding:4px 12px;border-radius:6px;border:1px solid var(--border2);background:transparent;color:var(--muted);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.analytics-period-btn:hover{border-color:var(--accent);color:var(--accent)}.analytics-period-btn.active{background:#00e5a01f;border-color:var(--accent);color:var(--accent)}.analytics-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px 18px;display:flex;flex-direction:column;gap:4px;transition:border-color .15s}.kpi-card:hover{border-color:var(--border2)}.kpi-card[data-danger=true]{border-color:#ff3b5c59}.kpi-card[data-danger=true] .kpi-value{color:var(--danger)}.kpi-label{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.kpi-value{font-size:28px;font-weight:700;color:var(--accent);line-height:1;letter-spacing:-.02em}.kpi-unit{font-size:14px;font-weight:500;color:var(--muted);margin-left:2px}.kpi-sub{font-size:10px;color:var(--muted)}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.analytics-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px 18px;display:flex;flex-direction:column;gap:12px}.analytics-card.wide{grid-column:1 / -1}.analytics-card-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}.analytics-empty{font-size:12px;color:var(--muted);font-style:italic}.spark-wrap{overflow-x:auto}.sparkline{display:block}.spark-empty{color:var(--muted);font-size:12px}.spark-axis{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);margin-top:-4px}.bar-chart{display:flex;flex-direction:column;gap:6px}.bar-row{display:grid;grid-template-columns:130px 1fr 44px;align-items:center;gap:8px;font-size:11px}.bar-label{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px}.bar-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.bar-value{text-align:right;color:var(--muted);font-size:11px;font-variant-numeric:tabular-nums}.funnel{display:flex;flex-direction:column;gap:8px}.funnel-row{display:grid;grid-template-columns:80px 1fr 36px;align-items:center;gap:8px;font-size:11px}.funnel-label{color:var(--muted)}.funnel-bar-track{height:8px;background:var(--border);border-radius:4px;overflow:hidden}.funnel-bar-fill{height:100%;border-radius:4px;transition:width .4s ease;min-width:2px}.funnel-value{text-align:right;color:var(--text);font-size:11px;font-variant-numeric:tabular-nums}.event-table{width:100%;border-collapse:collapse;font-size:11px}.event-table th{text-align:left;color:var(--muted);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.06em;padding:0 4px 8px;border-bottom:1px solid var(--border)}.event-table td{padding:5px 4px;color:var(--text);border-bottom:1px solid var(--border)}.event-table tr:last-child td{border-bottom:none}.event-table code{background:var(--bg);border-radius:3px;padding:1px 5px;font-size:10px;color:var(--accent)}.event-table td:last-child{text-align:right;color:var(--muted);font-variant-numeric:tabular-nums}.analytics-view-tabs{display:flex;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:3px}.analytics-view-tab{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:6px;border:none;background:transparent;color:var(--muted);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.analytics-view-tab:hover{color:var(--text)}.analytics-view-tab.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 3px #0006}.evt-filter-bar{display:flex;align-items:center;gap:12px;padding:2px 0 4px}.evt-filter-select{padding:6px 10px;background:var(--surface);border:1px solid var(--border2);border-radius:7px;color:var(--text);font-size:12px;cursor:pointer;min-width:200px}.evt-filter-select:focus{outline:none;border-color:var(--accent)}.evt-count{font-size:11px;color:var(--muted)}.evt-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:10px}.evt-table{width:100%;border-collapse:collapse;font-size:11.5px;min-width:1060px}.evt-table thead th{padding:9px 12px;text-align:left;font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);background:var(--surface);border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0;z-index:1}.evt-table thead th:last-child{border-radius:0 10px 0 0}.evt-table thead th:first-child{border-radius:10px 0 0}.evt-row{border-bottom:1px solid var(--border);transition:background .1s}.evt-row:last-child{border-bottom:none}.evt-row:hover{background:#ffffff06}.evt-row-expandable{cursor:pointer}.evt-row-open{background:#00e5a00a}.evt-table td{padding:8px 12px;vertical-align:middle;color:var(--text)}.evt-ts{white-space:nowrap;color:var(--muted);font-variant-numeric:tabular-nums;font-size:11px}.evt-ms{text-align:right;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap}.evt-ip{font-family:monospace;font-size:10.5px;color:var(--muted);white-space:nowrap;letter-spacing:.01em;min-width:140px}.evt-client-ip{font-family:monospace;font-size:11px;color:var(--text);white-space:nowrap}.evt-ua{font-size:10px;color:var(--muted);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.evt-badge{display:inline-block;padding:2px 7px;border-radius:5px;border:1px solid currentColor;font-size:10px;font-weight:600;letter-spacing:.03em;white-space:nowrap;font-family:SF Mono,Fira Code,monospace;opacity:.9}.evt-payload-cell{max-width:260px}.evt-payload-preview{font-size:10.5px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;max-width:260px}.evt-expand-hint{color:var(--accent);font-size:9px;margin-left:3px}.evt-no-payload{color:var(--border2)}.evt-expanded-row{background:var(--surface)}.evt-expanded-row td{padding:0;border-top:1px solid var(--border)}.evt-detail{padding:0}.evt-detail-meta{display:flex;flex-wrap:wrap;gap:6px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--bg)}.evt-detail-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:5px;font-size:11px;background:#ffffff0a;border:1px solid var(--border);color:var(--text);font-family:SF Mono,Fira Code,monospace}.evt-detail-chip-label{font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-right:2px}.evt-method-post{border-color:#00e5a04d;color:var(--accent)}.evt-method-delete{border-color:#ff3b5c4d;color:#ff3b5c}.evt-method-patch{border-color:#f0a5004d;color:#f0a500}.evt-method-get{border-color:#64a0ff4d;color:#64a0ff}.evt-status-2xx{border-color:#00e5a04d;color:var(--accent)}.evt-status-4xx{border-color:#f0a5004d;color:#f0a500}.evt-status-5xx{border-color:#ff3b5c4d;color:#ff3b5c}.evt-detail-body{display:flex;gap:0;min-height:60px}.evt-detail-fields{flex:1;padding:10px 14px;display:flex;flex-direction:column;gap:5px;border-right:1px solid var(--border);min-width:0}.evt-detail-row{display:flex;gap:10px;align-items:baseline;font-size:11px;line-height:1.5}.evt-detail-key{font-family:SF Mono,Fira Code,monospace;font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);flex-shrink:0;width:80px}.evt-detail-val{color:var(--text);font-size:11px;word-break:break-all;min-width:0}.evt-detail-val.evt-detail-muted{color:var(--muted)}.evt-detail-request-body{width:340px;flex-shrink:0;display:flex;flex-direction:column;min-width:0}.evt-detail-section-label{padding:6px 14px 4px;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);background:var(--bg)}.evt-payload-json{margin:0;padding:10px 14px;font-size:11px;font-family:SF Mono,Fira Code,Cascadia Code,monospace;color:var(--accent);background:var(--bg);white-space:pre-wrap;word-break:break-all;line-height:1.6;flex:1;overflow-y:auto;max-height:200px}.evt-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 0 4px}.evt-page-btn{padding:5px 14px;font-size:12px}.evt-page-info{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums;min-width:120px;text-align:center}.account-btn{display:flex;align-items:center;gap:6px;font-size:12px;padding:6px 12px;white-space:nowrap}.account-menu{display:flex;align-items:center;gap:6px}.account-email{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--accent);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-logout-btn{padding:5px 8px;color:var(--muted)}.account-logout-btn:hover{color:var(--danger);border-color:var(--danger)}.account-tabs{display:flex;border-bottom:1px solid var(--border);margin:0 -20px;padding:0 20px}.account-tab{flex:1;padding:10px 0;background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;margin-bottom:-1px}.account-tab:hover{color:var(--text)}.account-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.account-body{padding:20px 0 4px;display:flex;flex-direction:column}.account-info{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--muted);background:#00e5a00f;border:1px solid rgba(0,229,160,.15);border-radius:8px;padding:10px 12px;margin-bottom:16px;line-height:1.5}.account-info svg{flex-shrink:0;margin-top:1px;color:var(--accent)}.form-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.account-submit{display:flex;align-items:center;justify-content:center;gap:8px}.account-switch{text-align:center;font-size:12px;color:var(--muted);margin-top:14px}.link-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:inherit;padding:0;text-decoration:underline;text-underline-offset:2px}.link-btn:hover{opacity:.8}.account-email-btn{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--accent);max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:5px 10px}.account-email-btn:hover{color:var(--text)}.modal-account{width:400px;max-width:96vw}.account-signed-in-as{font-size:12px;color:var(--muted);margin:0 0 18px}.account-signed-in-as strong{color:var(--text)}.account-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin:0 0 12px}.danger-title{color:var(--danger)}.account-divider{height:1px;background:var(--border);margin:20px 0}.btn-danger-outline{background:transparent;border:1px solid var(--danger);color:var(--danger);display:flex;align-items:center;gap:6px;font-size:13px;padding:8px 16px;border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.btn-danger-outline:hover{background:var(--danger);color:#fff}.btn-danger{background:var(--danger);color:#fff;border:1px solid var(--danger);display:flex;align-items:center;gap:6px;font-size:13px;padding:8px 16px;border-radius:8px;cursor:pointer;opacity:1;transition:opacity .15s}.btn-danger:hover{opacity:.85}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.account-delete-confirm{display:flex;flex-direction:column;gap:0}.account-delete-warning{font-size:12px;color:var(--danger);margin:0 0 14px;line-height:1.5}.form-success{font-size:12px;color:var(--accent)}.empty-new-role-btn{font-size:13px;padding:9px 20px}.mobile-menu-btn{display:none;align-items:center;justify-content:center;background:none;border:1px solid var(--border2);border-radius:8px;color:var(--text);padding:7px;cursor:pointer;transition:border-color .15s,background .15s;flex-shrink:0}.mobile-menu-btn:hover{background:#ffffff0d;border-color:var(--accent)}.mobile-nav{display:none;flex-direction:column;gap:8px;padding:12px 16px 16px;border-top:1px solid var(--border);background:#111418fa;animation:mobileNavIn .18s ease}@keyframes mobileNavIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.mobile-nav-btn{width:100%;justify-content:center}.mobile-nav-divider{height:1px;background:var(--border);margin:4px 0}.mobile-nav-account{display:flex;flex-direction:column;gap:8px}.mobile-nav-email{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--accent);padding:2px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 768px){.header-inner{padding:12px 16px}.header-right{display:none}.mobile-menu-btn,.mobile-nav{display:flex}.brand-name{font-size:17px}.brand-sub{display:none}.brand-icon{width:34px;height:34px}.app-main{padding:16px 12px 32px}.create-role-fields{grid-template-columns:1fr}.mobile-nav .new-role-btn{width:100%;justify-content:center}.upgrade-callout{font-size:12px;padding:9px 12px;flex-wrap:wrap;gap:6px}.role-card-header{flex-direction:column;gap:12px;padding:16px 14px 12px}.role-actions{width:100%;justify-content:flex-end;flex-wrap:wrap;gap:6px}.role-name{font-size:15px}.tasks-section{padding:10px 14px}.task-perms{padding:8px 10px 10px}.add-task-form{padding:12px 14px 16px}.add-task-row{flex-wrap:wrap}.add-task-row .task-input-wrap{width:100%;flex:unset}.add-task-row select{width:100%}.add-task-row .btn{width:100%;justify-content:center}.role-export-bar{flex-wrap:wrap;gap:6px;padding:10px 14px}.export-btn-group{flex-wrap:wrap}.empty-hero{max-width:100%;padding:0 8px}.empty-actions{flex-direction:column;align-items:stretch;width:100%;max-width:280px}.empty-actions .btn,.empty-actions .empty-new-role-btn{width:100%;justify-content:center}.modal-overlay{align-items:flex-end;padding:0}.modal{max-width:100%;width:100%;max-height:90vh;border-radius:18px 18px 0 0;border-left:none;border-right:none;border-bottom:none}.modal:before{content:"";display:block;width:40px;height:4px;background:var(--border2);border-radius:2px;margin:10px auto -6px;flex-shrink:0}.modal-account{width:100%}.ai-drawer-overlay{align-items:flex-end;justify-content:stretch}.ai-drawer{width:100%;height:88vh;border-left:none;border-top:1px solid rgba(168,85,247,.3);border-radius:18px 18px 0 0;animation:slideInUp .25s cubic-bezier(.16,1,.3,1)}.ai-drawer:before{content:"";display:block;width:40px;height:4px;background:#a855f766;border-radius:2px;margin:10px auto -4px;flex-shrink:0}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.modal-policy,.modal-wide,.modal-approval,.modal-suggest,.modal-pricing{max-width:100%!important}.analytics-full-bleed{padding:0 12px 32px}.analytics-panel{padding:16px 0}.evt-table-wrap{font-size:11px}.evt-table th:nth-child(3),.evt-table td:nth-child(3),.evt-table th:nth-child(5),.evt-table td:nth-child(5),.evt-table th:nth-child(6),.evt-table td:nth-child(6),.evt-table th:nth-child(7),.evt-table td:nth-child(7){display:none}.affiliate-banner{font-size:11px;padding:6px 12px;gap:8px}.banner-text{min-width:0}.app-layout{flex-direction:column}.sidebar-ads{display:none}.pricing-grid{grid-template-columns:1fr}.pricing-card{min-width:0}.suggest-submitter{grid-template-columns:1fr}.suggest-submitter .suggest-section:last-child{grid-column:1}.admin-page-header{padding:10px 14px;flex-wrap:wrap;gap:8px}.admin-panel-inline{padding:0 12px 32px}.admin-page-tabs{gap:2px;margin-left:0;width:100%;justify-content:flex-end}.admin-page-tab{font-size:11px;padding:5px 10px}.analytics-kpis{grid-template-columns:repeat(2,1fr)}.analytics-grid{grid-template-columns:1fr}.mobile-nav .tier-badge-btn{width:100%;justify-content:center}}@media (max-width: 380px){.brand-name{font-size:15px}.brand-icon{width:30px;height:30px}.analytics-kpis{grid-template-columns:1fr}.app-main{padding:12px 10px 24px}}.ads-slots{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.ads-slot-card{border:1px solid var(--border2);border-radius:10px;overflow:hidden;transition:border-color .15s}.ads-slot-card:has(.ads-slot-header:hover){border-color:var(--accent)}.ads-slot-disabled{opacity:.6}.ads-slot-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff05;transition:background .15s}.ads-slot-header:hover{background:#ffffff0a}.ads-slot-info{display:flex;align-items:center;gap:10px;min-width:0}.ads-slot-num{font-size:11px;font-weight:700;font-family:var(--font-mono);color:var(--muted);flex-shrink:0}.ads-slot-sponsor{font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ads-slot-badge-off{font-size:10px;font-weight:700;padding:1px 6px;border-radius:4px;background:#ef44441f;color:var(--danger);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.ads-slot-controls{display:flex;align-items:center;gap:10px;flex-shrink:0}.ads-slot-toggle{position:relative;display:flex;align-items:center;cursor:pointer}.ads-slot-toggle input{display:none}.ads-toggle-track{width:32px;height:18px;background:var(--border2);border-radius:9px;position:relative;transition:background .2s;display:block}.ads-toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:12px;height:12px;border-radius:50%;background:#fff;transition:transform .2s}.ads-slot-toggle input:checked~.ads-toggle-track{background:var(--accent)}.ads-slot-toggle input:checked~.ads-toggle-track:after{transform:translate(14px)}.ads-slot-chevron{color:var(--muted);transition:transform .2s}.ads-slot-chevron.open{transform:rotate(90deg)}.ads-slot-body{padding:14px 14px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px;background:#0000001f}.ads-field-row{display:flex;flex-direction:column;gap:5px}.ads-textarea{background:var(--bg);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-family:var(--font-ui);font-size:13px;padding:8px 10px;resize:vertical;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box}.ads-textarea:focus{border-color:var(--accent)}.ads-preview{margin-top:6px}.ads-preview-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px}.ads-preview-card{background:var(--surface);border:1px solid var(--border2);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:5px;max-width:320px;opacity:.9}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0c0f;--surface: #111418;--border: #1e2530;--border2: #2a3545;--accent: #00e5a0;--accent2: #0077ff;--danger: #ff3b5c;--warn: #ffb800;--text: #e2e8f0;--muted: #64748b;--code: #a3e635;--font-ui: "Syne", sans-serif;--font-mono:"Space Mono", monospace}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-ui);font-size:14px;line-height:1.6}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}button{font-family:var(--font-ui);cursor:pointer;border:none;outline:none}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;letter-spacing:.02em;transition:all .15s}.btn-primary{background:var(--accent);color:#000}.btn-primary:hover{background:#00ffb3;transform:translateY(-1px);box-shadow:0 4px 20px #00e5a04d}.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--border2)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:transparent;color:var(--danger);border:1px solid transparent;padding:4px 8px;font-size:12px}.btn-danger:hover{border-color:var(--danger);background:#ff3b5c14}input,textarea,select{font-family:var(--font-ui);background:var(--bg);border:1px solid var(--border2);color:var(--text);border-radius:6px;padding:8px 12px;font-size:13px;outline:none;width:100%;transition:border-color .15s}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #00e5a01a}input::placeholder{color:var(--muted)}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.05em}.tag-perm{background:#00e5a014;color:var(--accent);border:1px solid rgba(0,229,160,.2)}.tag-category{background:#0077ff1a;color:var(--accent2);border:1px solid rgba(0,119,255,.25)}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeSlideIn .25s ease forwards}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}
