@import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&display=swap");:root{--bg:#FBFBFC;--bg-elev:#FFFFFF;--bg-sunken:#F5F6F8;--bg-code:#0B0D14;--ink:#0A0E1A;--ink-2:#2C3142;--ink-3:#5B6478;--ink-4:#8A93A6;--line:#E8EAF0;--line-strong:#D4D8E2;--accent:#1652F0;--accent-deep:#0B2E8A;--accent-soft:#EDF1FE;--accent-line:#C9D6FB;--green:#00875A;--green-soft:#E6F5EE;--green-line:#BFE5D1;--amber:#B45309;--amber-soft:#FEF3C7;--amber-line:#FCD34D;--red:#B42318;--red-soft:#FEE4E2;--red-line:#FCA5A5;--bg-primary:var(--bg);--bg-secondary:var(--bg-sunken);--bg-tertiary:var(--bg-elev);--bg-card:var(--bg-elev);--bg-glass:var(--bg-elev);--bg-hover:rgba(10,14,26,0.04);--border-subtle:var(--line);--border-medium:var(--line-strong);--border-accent:var(--accent-line);--text-primary:var(--ink);--text-secondary:var(--ink-2);--text-muted:var(--ink-3);--text-accent:var(--accent);--color-allow:var(--green);--color-allow-bg:var(--green-soft);--color-allow-glow:rgba(0,135,90,0.18);--color-challenge:var(--amber);--color-challenge-bg:var(--amber-soft);--color-challenge-glow:rgba(180,83,9,0.18);--color-deny:var(--red);--color-deny-bg:var(--red-soft);--color-deny-glow:rgba(180,35,24,0.18);--gradient-primary:var(--ink);--gradient-hero:var(--accent);--gradient-danger:var(--red);--gradient-subtle:var(--accent-soft);--shadow-sm:0 1px 0 rgba(10,14,26,0.04),0 1px 2px rgba(10,14,26,0.04);--shadow-md:0 4px 12px -2px rgba(10,14,26,0.06),0 2px 4px -1px rgba(10,14,26,0.04);--shadow-lg:0 16px 40px -8px rgba(10,14,26,0.12),0 4px 12px -2px rgba(10,14,26,0.06);--shadow-glow:0 0 0 4px rgba(22,82,240,0.12);--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--font-sans:"Söhne","Helvetica Neue",Helvetica,"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg);color:var(--ink);line-height:1.55;min-height:100vh;letter-spacing:-.005em;font-feature-settings:"ss01","cv11"}h1,h2,h3,h4,h5,h6{font-weight:500;line-height:1.15;letter-spacing:-.02em;color:var(--ink)}h1{font-size:36px;letter-spacing:-.03em}h2{font-size:28px;letter-spacing:-.025em}h3{font-size:20px;letter-spacing:-.015em}code,pre{font-family:var(--font-mono);font-feature-settings:"ss01"}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-deep)}.glass-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:border-color .12s ease,box-shadow .12s ease}.glass-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-md)}.gradient-text{color:var(--ink);background:none;-webkit-text-fill-color:currentColor}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:500;font-family:var(--font-mono);letter-spacing:.02em;text-transform:uppercase;border:1px solid var(--line);background:var(--bg-sunken);color:var(--ink-3)}.badge-allow{background:var(--green-soft);color:var(--green);border-color:var(--green-line)}.badge-challenge{background:var(--amber-soft);color:var(--amber);border-color:var(--amber-line)}.badge-deny{background:var(--red-soft);color:var(--red);border-color:var(--red-line)}.score-indicator{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;font-weight:600;font-size:13px;font-family:var(--font-mono);border:1px solid var(--line);background:var(--bg-elev)}.score-low{background:var(--green-soft);color:var(--green);border-color:var(--green-line)}.score-medium{background:var(--amber-soft);color:var(--amber);border-color:var(--amber-line)}.score-high{background:var(--red-soft);color:var(--red);border-color:var(--red-line)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid transparent;border-radius:var(--radius-md);font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;transition:all .12s ease;text-decoration:none;letter-spacing:-.005em;background:transparent;color:var(--ink);white-space:nowrap}.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink);box-shadow:var(--shadow-sm)}.btn-primary:hover{background:#1A1F33;border-color:#1A1F33;color:#fff}.btn-secondary{background:var(--bg-elev);color:var(--ink);border-color:var(--line-strong)}.btn-secondary:hover{border-color:var(--ink);background:var(--bg-elev)}.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-accent:hover{background:var(--accent-deep);border-color:var(--accent-deep);color:#fff}.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}.btn-sm{padding:6px 12px;font-size:13px;border-radius:var(--radius-sm)}.btn-lg{padding:13px 22px;font-size:15px}input,select,textarea{font-family:inherit;font-size:14px;padding:10px 12px;background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:var(--radius-md);color:var(--ink);outline:none;transition:border-color .12s ease,box-shadow .12s ease;width:100%;letter-spacing:-.005em}input::placeholder,textarea::placeholder{color:var(--ink-4)}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:var(--shadow-glow)}label{color:var(--ink-3);font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.landing-nav{justify-content:space-between;padding:18px 48px;background:rgba(251,251,252,.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);position:fixed;top:0;left:0;right:0;z-index:100;border-bottom:1px solid var(--line)}.landing-logo,.landing-nav{display:flex;align-items:center}.landing-logo{gap:10px;font-size:16px;font-weight:600;text-decoration:none;color:var(--ink);letter-spacing:-.01em}.landing-logo span{color:var(--ink);-webkit-text-fill-color:currentColor;background:none}.landing-nav-links{display:flex;align-items:center;gap:28px;list-style:none}.landing-nav-links a{color:var(--ink-2);text-decoration:none;font-size:14px;font-weight:400;transition:color .12s ease}.landing-nav-links a:hover{color:var(--ink)}.hero{min-height:92vh;display:flex;align-items:center;justify-content:center;padding:140px 48px 80px;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background-image:linear-gradient(to right,var(--line) 1px,transparent 1px),linear-gradient(to bottom,var(--line) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,black 0,transparent 70%);-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,black 0,transparent 70%);opacity:.6;pointer-events:none}.hero-content{max-width:820px;text-align:center;position:relative;z-index:1}.hero h1{font-size:clamp(40px,6vw,72px);font-weight:500;line-height:1.04;letter-spacing:-.035em;margin-bottom:24px;color:var(--ink)}.hero p{font-size:18px;line-height:1.55;color:var(--ink-2);max-width:640px;margin:0 auto 40px}.hero-buttons{gap:12px;flex-wrap:wrap}.hero-buttons,.hero-stats{display:flex;justify-content:center}.hero-stats{gap:56px;margin-top:80px}.hero-stat{text-align:center}.hero-stat-value{font-size:36px;font-weight:500;letter-spacing:-.02em;font-family:var(--font-mono);color:var(--ink);background:none;-webkit-text-fill-color:currentColor}.hero-stat-label{font-size:12px;color:var(--ink-3);margin-top:6px;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase}.features-section{padding:120px 48px;max-width:1200px;margin:0 auto}.section-header{text-align:center;margin-bottom:64px}.section-header h2{font-size:40px;font-weight:500;letter-spacing:-.03em;margin-bottom:16px}.section-header p{color:var(--ink-2);max-width:560px;margin:0 auto;font-size:17px;line-height:1.55}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:0;gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}.feature-card{padding:32px;background:var(--bg-elev);border-right:1px solid var(--line);border-bottom:1px solid var(--line)}.feature-card:hover{background:var(--bg-sunken)}.feature-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;margin-bottom:18px;background:var(--accent-soft);color:var(--accent-deep);border:1px solid var(--accent-line)}.feature-card h3{font-size:17px;font-weight:500;margin-bottom:8px;letter-spacing:-.01em}.feature-card p{color:var(--ink-2);font-size:14px;line-height:1.55}.code-section{padding:80px 48px;max-width:920px;margin:0 auto}.code-block{background:var(--bg-code);border:1px solid var(--bg-code);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}.code-header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.06)}.code-dot{width:10px;height:10px;border-radius:50%}.code-dot.red{background:#ff5f56}.code-dot.yellow{background:#ffbd2e}.code-dot.green{background:#27c93f}.code-title{margin-left:8px;color:rgba(255,255,255,.4);font-size:12px;font-family:var(--font-mono)}.code-body{padding:22px;overflow-x:auto}.code-body pre{color:#E5E7EB;font-size:13px;line-height:1.65;font-family:var(--font-mono)}.code-body .keyword{color:#C4B5FD}.code-body .string{color:#86EFAC}.code-body .comment{color:#6B7280}.code-body .function{color:#F0ABFC}.code-body .property{color:#93C5FD}.code-body .number{color:#FDE68A}.dashboard-layout{display:flex;min-height:100vh;background:var(--bg)}.sidebar{width:240px;background:var(--bg-elev);border-right:1px solid var(--line);padding:24px 0;position:fixed;top:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 22px 22px;font-size:16px;font-weight:600;text-decoration:none;color:var(--ink);border-bottom:1px solid var(--line);margin-bottom:14px;letter-spacing:-.01em}.sidebar-logo span{color:var(--ink);background:none;-webkit-text-fill-color:currentColor}.sidebar-nav{flex:1 1;padding:0 12px}.sidebar-nav a{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);color:var(--ink-2);text-decoration:none;font-size:13px;font-weight:500;margin-bottom:2px;transition:background .12s ease,color .12s ease}.sidebar-nav a:hover{background:var(--bg-sunken);color:var(--ink)}.sidebar-nav a.active{background:var(--accent-soft);color:var(--accent-deep);border:1px solid var(--accent-line)}.sidebar-footer{padding:16px 22px;border-top:1px solid var(--line)}.main-content{flex:1 1;margin-left:240px;padding:32px 40px;min-height:100vh;background:var(--bg)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px;gap:16px}.page-header h1{font-size:28px;font-weight:500;letter-spacing:-.025em;margin-bottom:4px}.page-header p{color:var(--ink-2);font-size:14px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:16px;gap:16px;margin-bottom:28px}.stat-card{padding:22px}.stat-label{font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}.stat-label,.stat-value{font-family:var(--font-mono);font-weight:500}.stat-value{font-size:30px;letter-spacing:-.025em;color:var(--ink);font-feature-settings:"ss01","tnum"}.stat-change{font-size:12px;margin-top:6px;font-family:var(--font-mono)}.stat-change.positive{color:var(--green)}.stat-change.negative{color:var(--red)}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:12px 16px;font-size:11px;font-weight:500;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono);background:var(--bg-sunken)}.data-table td,.data-table th{border-bottom:1px solid var(--line)}.data-table td{padding:14px 16px;font-size:14px;color:var(--ink);vertical-align:middle}.data-table tbody tr{transition:background .1s ease}.data-table tbody tr:hover{background:var(--bg-sunken)}.chart-container{padding:24px;margin-bottom:24px}.bar-chart{display:flex;align-items:flex-end;gap:8px;height:200px;padding-top:20px}.bar{flex:1 1;border-radius:3px 3px 0 0;min-width:40px;position:relative;transition:height .32s cubic-bezier(.4,0,.2,1),opacity .12s ease;cursor:pointer}.bar:hover{opacity:.8}.bar-label{bottom:-22px;color:var(--ink-3);white-space:nowrap}.bar-label,.bar-value{position:absolute;left:50%;transform:translateX(-50%);font-size:11px;font-family:var(--font-mono)}.bar-value{top:-20px;font-weight:500;color:var(--ink-2)}.donut-chart{display:flex;align-items:center;gap:28px;padding:8px}.donut-visual{width:160px;height:160px;border-radius:50%;position:relative}.donut-legend{display:flex;flex-direction:column;gap:10px}.legend-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-2)}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-dot.allow{background:var(--green)}.legend-dot.challenge{background:var(--amber)}.legend-dot.deny{background:var(--red)}.signal-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:500;font-family:var(--font-mono);margin:2px;border:1px solid var(--line);background:var(--bg-sunken);color:var(--ink-3);letter-spacing:.02em}.signal-tag.critical{background:var(--red-soft);color:var(--red);border-color:var(--red-line)}.signal-tag.high{background:var(--amber-soft);color:var(--amber);border-color:var(--amber-line)}.signal-tag.medium{background:var(--accent-soft);color:var(--accent-deep);border-color:var(--accent-line)}.signal-tag.low{background:var(--bg-sunken);color:var(--ink-3);border-color:var(--line)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:4px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--ink-4)}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn .24s ease-out}.animate-slide-in{animation:slideIn .2s ease-out}.animate-scale-in{animation:scaleIn .2s ease-out}.empty-state{text-align:center;padding:80px 20px;color:var(--ink-3)}.empty-state-icon{font-size:36px;margin-bottom:14px;opacity:.5}.empty-state h3{font-size:17px;color:var(--ink);margin-bottom:8px;font-weight:500}.loading-spinner{width:20px;height:20px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.footer{text-align:center;padding:56px 48px;border-top:1px solid var(--line);color:var(--ink-3);font-size:13px}.footer a{color:var(--ink-2);text-decoration:none}.footer a:hover{color:var(--ink)}@media (max-width:768px){.landing-nav{padding:14px 20px}.hero{padding:100px 20px 60px}.hero-stats{flex-direction:column;gap:24px;margin-top:56px}.features-section{padding:60px 20px}.features-grid{grid-template-columns:1fr}.sidebar{display:none}.main-content{margin-left:0;padding:20px}.stats-grid{grid-template-columns:1fr 1fr}}.t-display{font-size:72px;line-height:1.02;letter-spacing:-.04em;font-weight:500}.t-h1{font-size:56px;line-height:1.04;letter-spacing:-.035em}.t-h1,.t-h2{font-weight:500}.t-h2{font-size:40px;line-height:1.08;letter-spacing:-.03em}.t-h3{font-size:28px;line-height:1.15;letter-spacing:-.02em}.t-h3,.t-h4{font-weight:500}.t-h4{font-size:20px;line-height:1.3;letter-spacing:-.01em}.t-body-lg{font-size:18px}.t-body,.t-body-lg{line-height:1.55;color:var(--ink-2)}.t-body{font-size:15px}.t-body-sm{font-size:13px;line-height:1.5;color:var(--ink-3)}.t-mono{font-family:var(--font-mono);font-feature-settings:"ss01";font-size:13px}.t-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-weight:500}@media (max-width:768px){.t-display{font-size:44px}.t-h1{font-size:36px}.t-h2{font-size:28px}.t-h3{font-size:22px}}.btn-outline{border-color:var(--line-strong);color:var(--ink);background:var(--bg-elev)}.btn-outline:hover{border-color:var(--ink);color:var(--ink)}.btn-ghost{color:var(--ink-2);background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--bg-sunken);color:var(--ink)}.card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg)}.tag{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.02em;border-radius:999px;background:var(--bg-sunken);color:var(--ink-3);border:1px solid var(--line);font-weight:500}.tag-accent{background:var(--accent-soft);color:var(--accent-deep);border-color:var(--accent-line)}.tag-green{background:var(--green-soft);color:var(--green);border-color:var(--green-line)}.tag-amber{background:var(--amber-soft);color:var(--amber);border-color:var(--amber-line)}.tag-red{background:var(--red-soft);color:var(--red);border-color:var(--red-line)}.dot{width:6px;height:6px;border-radius:50%;display:inline-block}.dot-green{background:#10B981;box-shadow:0 0 0 3px rgba(16,185,129,.18)}.dot-amber{background:#F59E0B;box-shadow:0 0 0 3px rgba(245,158,11,.18)}.dot-red{background:#EF4444;box-shadow:0 0 0 3px rgba(239,68,68,.18)}.dot-blue{background:var(--accent);box-shadow:0 0 0 3px rgba(22,82,240,.18)}.grid-bg{background-image:linear-gradient(to right,var(--line) 1px,transparent 1px),linear-gradient(to bottom,var(--line) 1px,transparent 1px);background-size:56px 56px}.code{background:var(--bg-code);color:#E5E7EB;font-family:var(--font-mono);font-size:13px;line-height:1.65;border-radius:var(--radius-lg);overflow:hidden}.code .gutter{color:#4B5563;padding-right:16px;-webkit-user-select:none;-moz-user-select:none;user-select:none;text-align:right}.code .k{color:#C4B5FD}.code .s{color:#86EFAC}.code .n{color:#FDE68A}.code .c{color:#6B7280}.code .p{color:#93C5FD}.code .f{color:#F0ABFC}.section-divider{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.no-scrollbar::-webkit-scrollbar{display:none}.no-scrollbar{scrollbar-width:none}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.pulse-dot{animation:pulse-dot 1.5s ease-in-out infinite}input[type=range]::-webkit-slider-runnable-track{background:transparent;border:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;background:transparent;border:none}input[type=range]::-moz-range-track{background:transparent;border:none}input[type=range]::-moz-range-thumb{width:24px;height:24px;background:transparent;border:none}