:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{width:100%;margin:0;padding:0}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.client-landing{min-height:100vh;background:#061739;padding:2rem}.landing-header{text-align:center;background:#fff;padding:2rem;margin-bottom:3rem;border-radius:12px;box-shadow:0 4px 12px #0003}.header-logos{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:0 2rem}.landing-header .logo{height:80px;width:auto;object-fit:contain}.logo-left{max-width:400px}.logo-right{max-width:250px}.landing-header h1{font-size:2.5rem;margin-bottom:.5rem;color:#061739}.landing-header h2{font-size:1.8rem;font-weight:300;color:#061739}.campaigns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem;max-width:1400px;margin:0 auto}.campaign-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a;transition:transform .2s,box-shadow .2s;text-decoration:none;color:inherit;display:block}.campaign-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000026}.campaign-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.campaign-card-header h3{font-size:1.5rem;color:#1e3a8a;margin:0}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600}.status-badge.status-completed{background:#d1fae5;color:#065f46}.status-badge.status-in-progress{background:#fef3c7;color:#92400e}.status-badge.status-mixed{background:#e0e7ff;color:#3730a3}.status-badge.status-unknown{background:#f3f4f6;color:#6b7280}.status-container{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.status-breakdown{display:flex;flex-direction:column;gap:.25rem;font-size:.75rem;color:#6b7280;text-align:right}.breakdown-item{white-space:nowrap}.campaign-card-body{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.campaign-stat{text-align:center}.stat-label{display:block;font-size:.875rem;color:#6b7280;margin-bottom:.5rem}.stat-value{display:block;font-size:1.5rem;font-weight:700;color:#1e3a8a}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background:#061739;color:#061739;display:flex;justify-content:center;align-items:flex-start;min-height:100vh}#root{width:100%;display:flex;justify-content:center}:root{--phish-navy: #061739;--phish-blue: #0055a2;--phish-sky: #428bc9;--phish-light: #e9f2f9;--success: #10b981;--warning: #f59e0b;--danger: #ef4444}.dashboard{min-height:100vh;padding-bottom:60px;width:100%;margin:0}.dashboard-header{background:#fff;color:var(--phish-navy);padding:30px 60px;box-shadow:0 2px 8px #0617391a;margin-bottom:30px}.header-logos{display:flex;align-items:center;justify-content:space-between;gap:40px;max-width:1600px;margin:0 auto}.logo-left{height:60px;width:auto;object-fit:contain}.logo-right{height:50px;width:auto;object-fit:contain}.header-content{flex:1;text-align:center}.dashboard-header h1{font-size:2.5rem;margin-bottom:8px;font-weight:700;color:var(--phish-navy)}.subtitle{font-size:1.1rem;color:var(--phish-blue);margin-bottom:12px;font-weight:500}.metadata{display:flex;justify-content:center;gap:16px;font-size:.95rem;color:#6b7280;flex-wrap:wrap}.dashboard-content{max-width:1600px;margin:0 auto;padding:0 60px 60px;display:flex;flex-direction:column;gap:30px}.dashboard-section{background:#fff;border-radius:16px;padding:40px;box-shadow:0 4px 12px #00000014;width:100%;margin:0 auto}.dashboard-row{display:grid;grid-template-columns:1fr 1fr;gap:30px;width:100%;margin:0 auto}.section-title{font-size:2rem;margin-bottom:32px;color:var(--phish-navy);display:flex;align-items:center;gap:12px;font-weight:700}.executive-dashboard{width:100%;margin:0 auto}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:0 auto 40px}.kpi-card{background:#fff;border-radius:12px;padding:28px;border-top:5px solid;transition:all .3s ease;min-height:180px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 2px 8px #0000000f}.kpi-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.kpi-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}.kpi-icon{padding:12px;border-radius:10px}.kpi-header h3{font-size:.95rem;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.kpi-value{font-size:3rem;font-weight:700;color:var(--phish-navy);margin-bottom:10px;line-height:1}.kpi-subtitle{font-size:.9rem;color:#6b7280}.ai-summary{background:linear-gradient(135deg,#f9fafb,#fff);border-left:4px solid var(--phish-blue);border-radius:12px;padding:32px;margin-top:20px}.ai-summary-title{font-size:1.5rem;color:var(--phish-navy);margin-bottom:24px;font-weight:700;padding-bottom:12px;border-bottom:2px solid #e5e7eb}.ai-summary-content{font-size:1rem;line-height:1.9;color:#374151}.ai-summary-content p{margin-bottom:16px}.ai-summary-content strong{color:var(--phish-navy);font-weight:600}.ai-summary-content ul{margin:12px 0;padding-left:24px}.ai-summary-content li{margin-bottom:8px;line-height:1.6}.chart-container{width:100%;min-height:450px;display:flex;flex-direction:column;justify-content:center;padding:20px 0}.custom-tooltip{background:#fff;border:2px solid var(--phish-blue);border-radius:8px;padding:14px;box-shadow:0 4px 12px #00000026}.custom-tooltip .label{margin-bottom:10px;font-weight:600;color:var(--phish-navy)}.custom-tooltip p{margin:6px 0;font-size:.95rem}.simulation-funnel{width:100%}.funnel-stages{display:flex;flex-direction:column;align-items:center;gap:8px;margin:30px 0}.funnel-stage{border-radius:8px;padding:20px;box-shadow:0 2px 8px #00000014;transition:all .3s ease}.funnel-stage:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.funnel-stage-content{display:flex;flex-direction:column;gap:12px}.funnel-stage-main{display:flex;align-items:center;gap:16px}.funnel-stage-label{font-size:1rem;font-weight:600;color:#374151;flex:1;display:flex;align-items:center;gap:12px}.funnel-stage-value{font-size:1.8rem;font-weight:700;color:var(--phish-navy);min-width:80px;text-align:right}.funnel-stage-breakdown{font-size:.85rem;color:#6b7280;padding-left:36px;line-height:1.4}.funnel-metrics{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:30px}.funnel-metric-card{background:linear-gradient(135deg,#f9fafb,#fff);border:2px solid #e5e7eb;border-radius:12px;padding:24px}.funnel-metric-label{font-size:.95rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.funnel-metric-value{font-size:2.5rem;font-weight:700;color:var(--phish-navy);margin-bottom:8px}.funnel-metric-subtitle{font-size:.9rem;color:#6b7280}.dept-list{display:flex;flex-direction:column;gap:12px;margin-top:12px}.dept-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#fff;border-left:3px solid var(--phish-blue);border-radius:6px}.dept-name{font-weight:600;color:var(--phish-navy);text-transform:uppercase;font-size:.9rem;letter-spacing:.5px}.dept-rate{font-size:1.3rem;font-weight:700;color:#ef4444}.funnel-container{padding:20px 0}.funnel-stage{margin-bottom:32px}.funnel-label{display:flex;justify-content:space-between;margin-bottom:10px;font-size:1rem}.funnel-name{font-weight:600;color:var(--phish-navy)}.funnel-stats{color:#6b7280;font-weight:500}.funnel-bar-container{width:100%;height:50px;background:#f3f4f6;border-radius:10px;overflow:hidden}.funnel-bar{height:100%;border-radius:10px;transition:width .4s ease}.funnel-note{margin-top:24px;padding:16px;background:#e0f2fe;border-left:5px solid var(--phish-blue);border-radius:6px}.funnel-note p{color:var(--phish-navy);font-weight:600}.split-charts{display:grid;grid-template-columns:1fr 1fr;gap:30px}.split-chart h3{text-align:center;margin-bottom:20px;color:var(--phish-navy);font-size:1.2rem;font-weight:600}.chart-stat{text-align:center;margin-top:16px;font-weight:700;color:var(--phish-blue);font-size:1.1rem}.bot-note{margin-top:24px;padding:14px;background:#f9fafb;border-radius:8px;text-align:center}.bot-note p{color:#6b7280;font-size:.95rem}.security-insights{margin-top:32px;padding-top:32px;border-top:2px solid #e5e7eb}.insights-title{font-size:1.3rem;font-weight:700;color:var(--phish-navy);margin-bottom:20px}.insight-cards{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.insight-card{background:linear-gradient(135deg,#f9fafb,#fff);border:2px solid #e5e7eb;border-radius:12px;padding:20px}.insight-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.insight-header h4{font-size:1.1rem;font-weight:600;color:var(--phish-navy);margin:0}.insight-stat{font-size:1.8rem;font-weight:700;color:var(--phish-blue);margin-bottom:12px}.insight-text{font-size:.95rem;line-height:1.6;color:#374151}.bot-detection-note{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#f3f4f6;border-radius:8px;color:#6b7280;font-size:.9rem}.risk-matrix-legend{margin-top:20px;padding:16px;background:#fef3c7;border-radius:8px;text-align:center}.risk-matrix-legend p{color:#92400e;font-weight:600}.table-container{width:100%}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:20px}.table-controls{display:flex;align-items:center;gap:20px}.table-controls label{display:flex;align-items:center;gap:10px;font-size:.95rem;color:var(--phish-navy);font-weight:500}.table-controls select{padding:8px 16px;border:2px solid #d1d5db;border-radius:8px;font-size:.95rem;cursor:pointer;background:#fff}.table-controls select:hover{border-color:var(--phish-blue)}.record-count{padding:8px 16px;background:#dbeafe;color:var(--phish-blue);border-radius:8px;font-weight:700;font-size:.95rem}.table-wrapper{overflow-x:auto}.risk-table{width:100%;border-collapse:collapse;font-size:.95rem}.risk-table thead{background:#f8fafc;border-bottom:2px solid var(--phish-blue)}.risk-table th{padding:16px;text-align:left;font-weight:700;color:var(--phish-navy);cursor:pointer;-webkit-user-select:none;user-select:none}.risk-table th:hover{background:#f1f5f9}.risk-table td{padding:14px 16px;border-bottom:1px solid #f3f4f6}.risk-table tbody tr:hover{background:#f8fafc}.risk-table .numeric{text-align:center;font-weight:600}.status-cell{text-align:center}.campaign-cell{color:#6b7280;font-size:.9rem}.no-data{text-align:center;padding:60px!important;color:#9ca3af;font-style:italic;font-size:1.1rem}.heatmap-wrapper{overflow-x:auto}.heatmap-table{width:100%;border-collapse:collapse;font-size:.95rem}.heatmap-table th{padding:14px;background:#f8fafc;font-weight:700;color:var(--phish-navy);border:1px solid #e5e7eb}.dept-header{text-align:left;min-width:150px}.metric-header{text-align:center;min-width:100px}.dept-cell{padding:14px;font-weight:700;background:#f8fafc;border:1px solid #e5e7eb;color:var(--phish-navy)}.heatmap-cell{padding:14px;text-align:center;font-weight:700;border:1px solid #e5e7eb;transition:all .2s;cursor:help}.heatmap-cell:hover{transform:scale(1.08);box-shadow:0 0 12px #0055a24d;z-index:10}.heatmap-legend{margin-top:24px;display:flex;gap:30px;justify-content:center;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:12px}.legend-gradient{width:140px;height:24px;border-radius:6px;border:1px solid #d1d5db}.gradient-negative{background:linear-gradient(to right,#f3f4f6,#fed7aa,#fb923c,#ef4444)}.gradient-positive{background:linear-gradient(to right,#f3f4f6,#d1fae5,#6ee7b7,#10b981)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:24px}.loading-spinner{width:60px;height:60px;border:5px solid #e5e7eb;border-top-color:var(--phish-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;padding:20px;text-align:center}.error-container h2{color:var(--danger);font-size:2rem}.error-container p{color:#6b7280;font-size:1.1rem}@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.dashboard-row,.split-charts{grid-template-columns:1fr}.dashboard-content{padding:0 20px 40px}.dashboard-section{padding:30px}}@media(max-width:768px){.dashboard-header h1{font-size:2rem}.dashboard-header{padding:40px 20px}.metadata{flex-direction:column;gap:10px}.table-header{flex-direction:column;align-items:stretch}.kpi-grid{grid-template-columns:1fr}.kpi-value{font-size:2.5rem}.section-title{font-size:1.5rem}}
