*,:before,:after{box-sizing:border-box}body{color:#0f172a;-webkit-font-smoothing:antialiased;background:#f8fafc;margin:0;font-family:system-ui,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5}#root{min-height:100vh}h1,h2,h3{margin:0 0 .5rem;line-height:1.25}p{margin:0 0 1rem}p:last-child{margin-bottom:0}a{color:#2563eb}select,input[type=checkbox]{accent-color:#2563eb}.info-box{border:1px solid #e5e7eb;border-left:5px solid var(--tool-color,#2563eb);background:#f8fafc;border-radius:6px;margin-bottom:1.25rem;padding:1.25rem 1.5rem}.info-box h3{color:var(--tool-color,#0f172a);margin-bottom:.5rem;font-size:1rem;font-weight:700}.info-box p{color:#374151;margin:0;font-size:.9rem;line-height:1.6}.site{flex-direction:column;min-height:100vh;display:flex}.site-header{background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.site-logo{color:#0d9488;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;text-decoration:none;display:flex}.site-logo-icon{flex-shrink:0;width:28px;height:28px}.site-header nav{gap:1.5rem;display:flex}.site-header nav a{color:#334155;font-size:.95rem;text-decoration:none}.site-header nav a:hover,.site-header nav a.active{color:#0d9488}.site-main{flex:1;width:100%;max-width:900px;margin:0 auto;padding:2rem 1.5rem}.site-footer{text-align:center;color:#6b7280;border-top:1px solid #e5e7eb;padding:1.5rem 2rem;font-size:.85rem}.site-footer a{color:#0d9488}.g-term{text-underline-offset:3px;cursor:help;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.g-tip{z-index:9999;color:#f1f5f9;pointer-events:none;white-space:normal;text-align:left;background:#0f172a;border-radius:6px;width:300px;padding:.65rem .8rem;font-size:.78rem;font-weight:400;line-height:1.55;text-decoration:none;position:fixed;box-shadow:0 4px 16px #0000004d}.g-tip:after{content:"";top:100%;left:var(--arrow-left,14px);border:5px solid #0000;border-top-color:#0f172a;position:absolute;transform:translate(-50%)}.home-hero{margin-bottom:2.5rem}.home-hero h1{color:#0f172a;margin-bottom:.75rem;font-size:2rem;font-weight:700}.home-hero p{color:#4b5563;font-size:1.1rem}.tool-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.tool-card{border:1px solid #e5e7eb;border-left:5px solid var(--tool-color,#e5e7eb);background:#f8fafc;border-radius:6px;padding:1.25rem 1.5rem}.tool-card.live a{color:inherit;text-decoration:none}.tool-card.live:hover{background:#f1f5f9}.tool-card h2{color:var(--tool-color,#0f172a);align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:1rem;font-weight:700;display:flex}.tool-card.coming-soon h2{opacity:.6}.tool-card p{color:#374151;font-size:.9rem;line-height:1.6}.tool-card-fixes-badge{background:color-mix(in srgb, var(--tool-color) 10%, white);color:var(--tool-color);border:1px solid color-mix(in srgb, var(--tool-color) 30%, white);border-radius:999px;margin-top:.75rem;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-block}.badge{color:#9ca3af;text-transform:uppercase;letter-spacing:.04em;background:#f3f4f6;border-radius:999px;padding:.2rem .5rem;font-size:.7rem;font-weight:500}.tooltip-wrapper{vertical-align:middle;align-items:center;margin-left:.35rem;display:inline-flex;position:relative}.tooltip-icon{color:#334155;cursor:help;-webkit-user-select:none;user-select:none;background:#d1d5db;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:1rem;height:1rem;font-size:.65rem;font-weight:700;line-height:1;display:inline-flex}.tooltip-bubble{z-index:20;color:#f9fafb;pointer-events:none;text-align:left;background:#1f2937;border-radius:6px;width:240px;padding:.6rem .75rem;font-size:.78rem;font-weight:400;line-height:1.5;display:none;position:absolute;bottom:calc(100% + 7px);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0003}.tooltip-bubble:after{content:"";border:5px solid #0000;border-top-color:#1f2937;position:absolute;top:100%;left:50%;transform:translate(-50%)}.tooltip-wrapper:hover .tooltip-bubble{display:block}.methodology-cards{flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem;display:flex}.methodology-card{cursor:pointer;text-align:left;background:#fff;border:2px solid #e5e7eb;border-radius:8px;flex-direction:column;flex:1;gap:.2rem;min-width:120px;padding:.75rem 1rem;transition:border-color .15s;display:flex}.methodology-card:hover{border-color:#86efac}.methodology-card.selected{background:#f0fdf4;border-color:#1a5c3a}.methodology-card-label{color:#0f172a;font-size:.95rem;font-weight:700}.methodology-card.selected .methodology-card-label{color:#1a5c3a}.methodology-card-sublabel{color:#6b7280;font-size:.78rem}.methodology-description{color:#4b5563;background:#f1f5f9;border:1px solid #e5e7eb;border-radius:6px;margin:0;padding:.75rem;font-size:.85rem;line-height:1.6}.preset-bar{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.btn-sm{padding:.35rem .85rem;font-size:.82rem}.btn-clear{color:#9ca3af;cursor:pointer;background:0 0;border:none;padding:0;font-size:.82rem}.btn-clear:hover{color:#334155}.stride-table-wrapper{overflow-x:auto}.stride-table{border-collapse:collapse;width:100%;font-size:.875rem}.stride-table th{text-align:left;color:#334155;background:#f1f5f9;border-bottom:2px solid #e5e7eb;padding:.6rem .75rem;font-weight:600}.stride-table td{vertical-align:top;color:#334155;border-bottom:1px solid #f3f4f6;padding:.75rem}.stride-table tr:last-child td{border-bottom:none}.stride-badge{color:#fff;white-space:nowrap;cursor:help;border-radius:4px;padding:.2rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.stride-badge-wrapper{display:inline-block;position:relative}.stride-tooltip{z-index:10;color:#f9fafb;pointer-events:none;background:#1f2937;border-radius:6px;flex-direction:column;gap:.3rem;width:260px;padding:.75rem;font-size:.8rem;font-weight:400;line-height:1.5;display:none;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 4px 12px #0003}.stride-tooltip strong{margin-bottom:.3rem;font-size:.85rem;display:block}.stride-tooltip:before{content:"";background:#1f2937;width:10px;height:10px;position:absolute;top:-5px;left:12px;transform:rotate(45deg)}.stride-badge-wrapper:hover .stride-tooltip{display:flex}.dread-cell{min-width:130px;position:relative}.dread-score-btn{color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:4px;align-items:center;gap:.25rem;padding:.25rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.dread-score-btn:hover{filter:brightness(1.1)}.dread-breakdown{z-index:20;background:#fff;border:1px solid #d1d5db;border-radius:6px;flex-direction:column;gap:.5rem;min-width:240px;padding:.75rem;display:flex;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 4px 16px #0000001f}.dread-field label{cursor:default;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.dread-field-label{color:#334155;flex:1;font-size:.8rem;font-weight:600}.dread-field input[type=number]{text-align:center;color:#0f172a;border:1px solid #d1d5db;border-radius:4px;width:3rem;padding:.2rem .4rem;font-size:.8rem}.dread-field-tip{color:#9ca3af;font-size:.72rem;display:block}.threat-summary{flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:1rem;font-size:.85rem;display:flex}.summary-total{color:#334155;font-weight:600}.summary-pill{color:#fff;border-radius:999px;padding:.15rem .6rem;font-size:.75rem;font-weight:600}.summary-critical{background:#b91c1c}.summary-high{background:#c2410c}.summary-medium{background:#b45309}.summary-low{background:#15803d}.summary-privacy{background:#6d28d9}.why-btn{color:#1a5c3a;cursor:pointer;background:0 0;border:none;margin-top:.4rem;padding:0;font-size:.78rem;font-weight:500;display:inline-block}.why-btn:hover{text-decoration:underline}.linddun-table-wrapper{overflow-x:auto}.linddun-table{border-collapse:collapse;width:100%;font-size:.875rem}.linddun-table th{text-align:left;color:#334155;background:#f1f5f9;border-bottom:2px solid #e5e7eb;padding:.6rem .75rem;font-weight:600}.linddun-table td{vertical-align:top;color:#334155;border-bottom:1px solid #f3f4f6;padding:.75rem}.linddun-table tr:last-child td{border-bottom:none}.linddun-badge{color:#fff;white-space:nowrap;cursor:help;border-radius:4px;padding:.2rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.linddun-badge-wrapper{display:inline-block;position:relative}.linddun-tooltip{z-index:10;color:#f9fafb;pointer-events:none;background:#1f2937;border-radius:6px;flex-direction:column;gap:.3rem;width:280px;padding:.75rem;font-size:.8rem;font-weight:400;line-height:1.5;display:none;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 4px 12px #0003}.linddun-tooltip strong{margin-bottom:.3rem;font-size:.85rem;display:block}.linddun-tooltip:before{content:"";background:#1f2937;width:10px;height:10px;position:absolute;top:-5px;left:12px;transform:rotate(45deg)}.linddun-badge-wrapper:hover .linddun-tooltip{display:flex}.why-row td{padding:0 .75rem .75rem}.why-content{border-left-style:solid;border-left-width:3px;padding:.75rem;font-size:.85rem}.why-content strong{margin-bottom:.4rem;display:block}.why-content p{color:#334155;margin:0;line-height:1.65}.pasta-summary{background:#f1f5f9;border:1px solid #e5e7eb;border-radius:6px;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:2rem;padding:.75rem 1rem;font-size:.85rem;display:flex}.pasta-summary-total,.pasta-summary-actors{color:#334155;font-weight:600}.pasta-risk-pill{color:#fff;text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:.15rem .5rem;font-size:.72rem;font-weight:700;display:inline-block}.pasta-section{margin-bottom:2rem}.pasta-section h3{color:#0f172a;margin-bottom:.25rem;font-size:1rem;font-weight:700}.pasta-section-intro{color:#6b7280;margin-bottom:1rem;font-size:.85rem}.pasta-actor-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem;display:grid}.pasta-actor-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;font-size:.85rem}.pasta-actor-name{color:#0f172a;margin-bottom:.4rem;font-weight:700}.pasta-actor-desc{color:#4b5563;margin-bottom:.5rem;line-height:1.5}.pasta-actor-motivation{color:#6b7280;font-size:.8rem}.pasta-scenario-list{flex-direction:column;gap:.5rem;display:flex}.pasta-scenario{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.pasta-scenario.open{border-color:#86efac}.pasta-scenario-header{cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:1rem;width:100%;padding:.875rem 1rem;display:flex}.pasta-scenario-header:hover{background:#f1f5f9}.pasta-scenario.open .pasta-scenario-header{background:#f0fdf4}.pasta-scenario-title{color:#0f172a;flex:1;font-size:.9rem;font-weight:600}.pasta-scenario-meta{flex-shrink:0;align-items:center;gap:.75rem;font-size:.8rem;display:flex}.pasta-likelihood{color:#6b7280;white-space:nowrap}.pasta-chevron{color:#6b7280;font-size:.75rem}.pasta-scenario-body{border-top:1px solid #e5e7eb;flex-direction:column;gap:1rem;padding:0 1rem 1rem;display:flex}.pasta-scenario-actor{color:#334155;padding-top:1rem;font-size:.85rem}.pasta-scenario-narrative,.pasta-scenario-impact{font-size:.875rem}.pasta-scenario-narrative strong,.pasta-scenario-impact strong{color:#0f172a;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.4rem;font-size:.82rem;display:block}.pasta-scenario-narrative p,.pasta-scenario-impact p{color:#334155;margin:0;line-height:1.65}.pasta-scenario-impact{background:#fff7ed;border:1px solid #fed7aa;border-radius:6px;padding:.75rem}.analysis-tabs{border-bottom:2px solid #e5e7eb;gap:0;margin-bottom:1.5rem;display:flex}.analysis-tab{color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:.6rem 1.25rem;font-size:.9rem;font-weight:500}.analysis-tab:hover{color:#1a5c3a}.analysis-tab.active{color:#1a5c3a;border-bottom-color:#1a5c3a;font-weight:600}.threat-model{max-width:800px}.tm-header{border:1px solid #e5e7eb;border-left:5px solid var(--tool-color,#1a5c3a);background:#f8fafc;border-radius:6px;margin-bottom:2rem;padding:1.25rem 1.5rem}.tm-header h1{color:var(--tool-color,#1a5c3a);margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.tm-header p{color:#374151;margin:0}.tm-steps{border-bottom:2px solid #e5e7eb;gap:0;margin-bottom:2rem;padding-bottom:1rem;display:flex}.tm-step{color:#9ca3af;flex:1;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.tm-step.active{color:#1a5c3a;font-weight:600}.tm-step.done{color:#16a34a}.tm-step-number{border:2px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:1.75rem;height:1.75rem;font-size:.8rem;font-weight:700;display:flex}.tm-step.done .tm-step-number:after{content:"✓"}.tm-step.done .tm-step-number{font-size:0}.tm-step.done .tm-step-number:after{font-size:.8rem}.tm-content{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:2rem}.step-actions{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:.75rem;margin-top:2rem;padding-top:1.5rem;display:flex}.btn{cursor:pointer;border:1px solid #0000;border-radius:6px;padding:.5rem 1.25rem;font-size:.9rem;font-weight:500}.btn-primary{color:#fff;background:#1a5c3a}.btn-primary:hover{background:#14472e}.btn-secondary{color:#334155;background:#fff;border-color:#d1d5db}.btn-secondary:hover{background:#f9fafb}.btn:disabled{opacity:.5;cursor:not-allowed}.field-group{margin-bottom:1.5rem}.field-group label{color:#0f172a;margin-bottom:.5rem;font-size:.9rem;font-weight:600;display:block}.field-group select{color:#0f172a;background:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:.5rem .75rem;font-size:.9rem}.checkbox-group{flex-direction:column;gap:.5rem;display:flex}.checkbox-group label{cursor:pointer;align-items:center;gap:.5rem;font-weight:400;display:flex}.pe{max-width:800px}.pe-header{border:1px solid #e5e7eb;border-left:5px solid var(--tool-color,#1e40af);background:#f8fafc;border-radius:6px;margin-bottom:1.5rem;padding:1.25rem 1.5rem}.pe-header h1{color:var(--tool-color,#1e40af);margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.pe-header p{color:#374151;margin:0}.pe-privacy{color:#6b7280;align-items:center;gap:.4rem;margin-bottom:1.5rem;font-size:.8rem;display:flex}.pe-privacy-icon{color:#16a34a}.pe-input-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.pe-input-row{align-items:center;gap:.5rem;display:flex}.pe-input{color:#0f172a;letter-spacing:.04em;border:1px solid #d1d5db;border-radius:6px;flex:1;min-width:0;padding:.6rem .75rem;font-family:monospace;font-size:1rem}.pe-input:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb26}.pe-toggle-btn{color:#6b7280;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #d1d5db;border-radius:6px;flex-shrink:0;padding:.6rem .9rem;font-size:.85rem}.pe-toggle-btn:hover{color:#0f172a;background:#f9fafb}.pe-char-count{color:#9ca3af;text-align:right;margin-top:.4rem;font-size:.78rem}.pe-meter-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.pe-meter-header{justify-content:space-between;align-items:baseline;margin-bottom:.75rem;display:flex}.pe-meter-label{color:#6b7280;font-size:.85rem}.pe-strength-label{font-size:1rem;font-weight:700}.pe-meter-track{background:#e5e7eb;border-radius:999px;height:12px;margin-bottom:.5rem;position:relative;overflow:hidden}.pe-meter-fill{border-radius:999px;height:100%;transition:width .2s,background-color .2s}.pe-meter-ticks{height:18px;position:relative}.pe-meter-tick{color:#9ca3af;white-space:nowrap;font-size:.68rem;position:absolute;transform:translate(-50%)}.pe-meter-empty{text-align:center;color:#9ca3af;margin-top:.5rem;font-size:.875rem}.pe-stats-row{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}.pe-stat-card{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1.25rem}.pe-stat-value{color:#0f172a;margin-bottom:.3rem;font-size:2rem;font-weight:700;line-height:1}.pe-stat-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;font-weight:600}.pe-stat-sublabel{color:#9ca3af;margin-top:.15rem;font-size:.7rem}.pe-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.pe-section-title{color:#0f172a;margin-bottom:1rem;font-size:.9rem;font-weight:600}.pe-crack-table{border-collapse:collapse;width:100%;font-size:.875rem}.pe-crack-table th{text-align:left;color:#334155;background:#f1f5f9;border-bottom:2px solid #e5e7eb;padding:.5rem .75rem;font-size:.8rem;font-weight:600}.pe-crack-table td{vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:.65rem .75rem}.pe-crack-table tr:last-child td{border-bottom:none}.pe-crack-scenario{color:#0f172a;font-weight:500}.pe-crack-detail{color:#6b7280;margin-top:.1rem;font-size:.78rem}.pe-crack-speed{color:#6b7280;white-space:nowrap;font-family:monospace;font-size:.8rem}.pe-crack-time{white-space:nowrap;font-weight:600}.pe-crack-time.red{color:#dc2626}.pe-crack-time.yellow{color:#d97706}.pe-crack-time.green{color:#16a34a}.pe-charset-row{flex-wrap:wrap;gap:.5rem;display:flex}.pe-charset-pill{border:1px solid;border-radius:999px;align-items:center;gap:.3rem;padding:.3rem .75rem;font-size:.8rem;font-weight:500;display:inline-flex}.pe-charset-pill.active{color:#1d4ed8;background:#eff6ff;border-color:#93c5fd}.pe-charset-pill.inactive{color:#9ca3af;background:#f9fafb;border-color:#e5e7eb}.pe-pattern-none{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500;display:flex}.pe-pattern-warning{background:#fff7ed;border:1px solid #fed7aa;border-radius:8px;align-items:flex-start;gap:.75rem;margin-bottom:.5rem;padding:.75rem 1rem;font-size:.875rem;display:flex}.pe-pattern-warning:last-child{margin-bottom:0}.pe-pattern-icon{color:#ea580c;flex-shrink:0;padding-top:.1rem}.pe-pattern-body{flex:1}.pe-pattern-desc{color:#0f172a;margin-bottom:.15rem;font-weight:500}.pe-pattern-penalty{color:#9a3412;font-size:.78rem}.pe-education{border-top:1px solid #e5e7eb;margin-top:2.5rem;padding-top:2rem}.pe-education h2{color:#0f172a;margin-bottom:1rem;font-size:1.25rem;font-weight:700}@media (width<=600px){.pe-stats-row{grid-template-columns:repeat(2,1fr)}.pe-crack-detail{display:none}}@media (width<=400px){.pe-stats-row{grid-template-columns:1fr}}.cc{max-width:900px;margin:0 auto}.cc-header{border-left:5px solid var(--tool-color);background:#fff;border-radius:0 6px 6px 0;margin-bottom:1.75rem;padding:1rem 1.25rem;box-shadow:0 1px 3px #0000000f}.cc-header h1{color:var(--tool-color);margin:0 0 .4rem;font-size:1.6rem}.cc-header p{color:#475569;margin:0;line-height:1.5}.cc-vector-paste{margin-bottom:1.5rem}.cc-vector-input{color:#1e293b;box-sizing:border-box;background:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:.6rem .875rem;font-family:Courier New,monospace;font-size:.875rem;transition:border-color .15s}.cc-vector-input:focus{border-color:var(--tool-color);box-shadow:0 0 0 3px color-mix(in srgb, var(--tool-color) 15%, transparent);outline:none}.cc-vector-input--error{background:#fff5f5;border-color:#dc2626}.cc-parse-error{color:#dc2626;margin:.35rem 0 0;font-size:.8rem}.cc-layout{grid-template-columns:1fr 300px;align-items:start;gap:1.75rem;display:grid}.cc-progress-bar-wrapper{align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.cc-progress-bar{background:#e5e7eb;border-radius:3px;flex:1;height:6px;overflow:hidden}.cc-progress-fill{background:var(--tool-color);border-radius:3px;height:100%;transition:width .2s}.cc-progress-label{color:#64748b;white-space:nowrap;font-size:.775rem}.cc-group{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1.5rem;padding:1rem 1.25rem}.cc-group-title{color:var(--tool-color);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .2rem;font-size:.95rem;font-weight:700}.cc-group-desc{color:#64748b;margin:0 0 1rem;font-size:.82rem}.cc-metric-row{margin-bottom:.875rem;position:relative}.cc-metric-row:last-child{margin-bottom:0}.cc-metric-label{align-items:center;gap:.5rem;margin-bottom:.35rem;display:flex}.cc-metric-name{color:#1e293b;font-size:.85rem;font-weight:600}.cc-metric-abbr{color:#94a3b8;background:#f1f5f9;border-radius:3px;padding:1px 5px;font-size:.75rem}.cc-metric-options{flex-wrap:wrap;gap:.4rem;display:flex}.cc-option-btn{color:#475569;cursor:pointer;background:#f8fafc;border:1.5px solid #d1d5db;border-radius:5px;padding:.3rem .75rem;font-size:.82rem;font-weight:500;transition:border-color .12s,background .12s,color .12s}.cc-option-btn:hover{border-color:var(--tool-color);color:var(--tool-color);background:color-mix(in srgb, var(--tool-color) 6%, white)}.cc-option-btn.selected{border-color:var(--tool-color);background:var(--tool-color);color:#fff}.cc-option-tooltip{color:#64748b;background:#f8fafc;border:1px solid #e5e7eb;border-radius:4px;margin-top:.3rem;padding:.3rem .6rem;font-size:.775rem;line-height:1.4}.cc-score-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;gap:1rem;padding:1.25rem;display:flex;position:sticky;top:1rem}.cc-gauge-track{background:#e5e7eb;border-radius:6px;height:12px;position:relative;overflow:hidden}.cc-gauge-fill{border-radius:6px;height:100%;transition:width .3s,background-color .3s;position:absolute;top:0;left:0}.cc-gauge-labels{color:#475569;justify-content:space-between;margin-top:.25rem;font-size:.7rem;display:flex}.cc-score-display{text-align:center;padding:.5rem 0}.cc-score-number{letter-spacing:-.02em;font-size:3.5rem;font-weight:800;line-height:1;transition:color .3s}.cc-score-sublabel{color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;margin-top:.2rem;font-size:.78rem}.cc-score-dash{color:#d1d5db;font-size:3rem;font-weight:300;line-height:1}.cc-severity-badge{letter-spacing:.04em;border-radius:20px;margin-top:.6rem;padding:.3rem 1rem;font-size:.85rem;font-weight:700;display:inline-block}.cc-vector-display{background:#f8fafc;border:1px solid #e5e7eb;border-radius:5px;align-items:center;gap:.5rem;padding:.5rem .75rem;display:flex}.cc-vector-code{color:#475569;word-break:break-all;background:0 0;flex:1;font-family:Courier New,monospace;font-size:.7rem}.cc-copy-btn{border:1.5px solid var(--tool-color);color:var(--tool-color);cursor:pointer;white-space:nowrap;background:#fff;border-radius:4px;flex-shrink:0;padding:.25rem .6rem;font-size:.75rem;font-weight:600;transition:background .12s,color .12s}.cc-copy-btn:hover{background:var(--tool-color);color:#fff}.cc-reset-btn{color:#64748b;cursor:pointer;background:#f8fafc;border:1.5px solid #d1d5db;border-radius:5px;width:100%;padding:.5rem;font-size:.82rem;font-weight:600;transition:border-color .12s,color .12s}.cc-reset-btn:hover{color:#1e293b;border-color:#94a3b8}.cc-severity-scale{border-top:1px solid #f1f5f9;padding-top:.75rem}.cc-scale-title{color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem;font-size:.72rem;font-weight:700}.cc-scale-row{align-items:center;gap:.5rem;padding:.2rem 0;display:flex}.cc-scale-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.cc-scale-label{color:#1e293b;flex:1;font-size:.8rem;font-weight:600}.cc-scale-range{color:#64748b;font-family:Courier New,monospace;font-size:.78rem}.cc-education{margin-top:2.5rem}.cc-education h2{color:#0f172a;margin:0 0 1rem;font-size:1.2rem}.cc-education .info-box{margin-bottom:1rem}@media (width<=768px){.cc-layout{grid-template-columns:1fr}.cc-score-panel{order:-1;position:static}}@media (width<=480px){.cc-header h1{font-size:1.3rem}.cc-option-btn{padding:.3rem .55rem;font-size:.78rem}}.csg{max-width:900px;margin:0 auto}.csg-header{border-left:5px solid var(--tool-color);background:#fff;border-radius:0 6px 6px 0;margin-bottom:1.75rem;padding:1rem 1.25rem;box-shadow:0 1px 3px #0000000f}.csg-header h1{color:var(--tool-color);margin:0 0 .4rem;font-size:1.6rem}.csg-header p{color:#475569;margin:0;line-height:1.5}.csg-output-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:2rem;overflow:hidden}.csg-output-tabs{background:#f8fafc;border-bottom:1px solid #e5e7eb;display:flex}.csg-output-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.6rem 1.1rem;font-size:.83rem;font-weight:600;transition:color .12s,border-color .12s}.csg-output-tab:hover{color:#1e293b}.csg-output-tab.active{color:var(--tool-color);border-bottom-color:var(--tool-color);background:#fff}.csg-output-code-wrap{min-height:62px;padding:1rem 1.25rem;overflow-x:auto}.csg-output-code-wrap.empty .csg-output-code{color:#94a3b8;font-style:italic}.csg-output-code{color:#1e293b;white-space:pre-wrap;word-break:break-all;background:0 0;font-family:Courier New,monospace;font-size:.82rem}.csg-output-actions{background:#f8fafc;border-top:1px solid #f1f5f9;justify-content:flex-end;gap:.5rem;padding:.6rem 1rem;display:flex}.csg-copy-btn{border:1.5px solid var(--tool-color);color:var(--tool-color);cursor:pointer;background:#fff;border-radius:5px;padding:.35rem .9rem;font-size:.82rem;font-weight:600;transition:background .12s,color .12s}.csg-copy-btn:hover:not(:disabled){background:var(--tool-color);color:#fff}.csg-copy-btn:disabled{opacity:.4;cursor:not-allowed}.csg-reset-btn{color:#64748b;cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:5px;padding:.35rem .75rem;font-size:.82rem;font-weight:600;transition:border-color .12s,color .12s}.csg-reset-btn:hover{color:#1e293b;border-color:#94a3b8}.csg-directives{flex-direction:column;gap:1.5rem;margin-bottom:2.5rem;display:flex}.csg-category-title{color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin:0 0 .6rem;font-size:.78rem;font-weight:700}.csg-card{background:#fff;border:1px solid #e5e7eb;border-radius:7px;margin-bottom:.5rem;padding:.9rem 1.1rem;transition:border-color .15s}.csg-card.enabled{border-color:color-mix(in srgb, var(--tool-color) 30%, #e5e7eb);border-left:3px solid var(--tool-color)}.csg-card-header{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.4rem;display:flex}.csg-card-toggle-label{cursor:pointer;align-items:center;gap:.5rem;display:flex}.csg-card-toggle{width:1rem;height:1rem;accent-color:var(--tool-color);cursor:pointer;flex-shrink:0}.csg-directive-name{color:#64748b;background:#f1f5f9;border-radius:4px;padding:.15rem .5rem;font-family:Courier New,monospace;font-size:.88rem;font-weight:700;transition:color .12s,background .12s}.csg-directive-name.active{color:var(--tool-color);background:color-mix(in srgb, var(--tool-color) 10%, white)}.csg-warning-badge{color:#b45309;white-space:nowrap;background:#fef3c7;border:1px solid #fde68a;border-radius:4px;padding:.15rem .5rem;font-size:.72rem;font-weight:600}.csg-directive-desc{color:#475569;margin:0;font-size:.85rem;line-height:1.5}.csg-card:not(.enabled) .csg-directive-desc{color:#94a3b8}.csg-sources-section{border-top:1px solid #f1f5f9;margin-top:.75rem;padding-top:.75rem}.csg-sources{flex-wrap:wrap;gap:.4rem;margin-bottom:.6rem;display:flex}.csg-source-chip{color:#475569;cursor:pointer;background:#f8fafc;border:1.5px solid #d1d5db;border-radius:4px;padding:.25rem .7rem;font-family:Courier New,monospace;font-size:.78rem;font-weight:500;transition:border-color .12s,background .12s,color .12s}.csg-source-desc{color:#475569;margin:.35rem 0 .15rem;font-size:.8rem;line-height:1.5}.csg-source-chip:hover{border-color:var(--tool-color);color:var(--tool-color);background:color-mix(in srgb, var(--tool-color) 6%, white)}.csg-source-chip.selected{border-color:var(--tool-color);background:var(--tool-color);color:#fff}.csg-custom-sources{flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem;display:flex}.csg-custom-chip{background:#f1f5f9;border:1px solid #d1d5db;border-radius:4px;align-items:center;gap:.2rem;padding:.2rem .3rem .2rem .6rem;display:inline-flex}.csg-custom-chip code{color:#334155;background:0 0;font-family:Courier New,monospace;font-size:.78rem}.csg-custom-remove{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:3px;padding:0 .2rem;font-size:1rem;line-height:1;transition:color .1s,background .1s}.csg-custom-remove:hover{color:#dc2626;background:#fee2e2}.csg-custom-input-row{align-items:center;gap:.4rem;display:flex}.csg-custom-input{color:#1e293b;background:#fff;border:1px solid #d1d5db;border-radius:5px;flex:1;min-width:0;padding:.4rem .75rem;font-family:Courier New,monospace;font-size:.82rem;transition:border-color .15s}.csg-custom-input:focus{border-color:var(--tool-color);box-shadow:0 0 0 2px color-mix(in srgb, var(--tool-color) 15%, transparent);outline:none}.csg-add-btn{border:1.5px solid var(--tool-color);color:var(--tool-color);cursor:pointer;white-space:nowrap;background:#fff;border-radius:5px;flex-shrink:0;padding:.4rem .9rem;font-size:.82rem;font-weight:600;transition:background .12s,color .12s}.csg-add-btn:hover:not(:disabled){background:var(--tool-color);color:#fff}.csg-add-btn:disabled{opacity:.4;cursor:not-allowed}.csg-education{margin-top:2.5rem}.csg-education h2{color:#0f172a;margin:0 0 1rem;font-size:1.2rem}.csg-education .info-box{margin-bottom:1rem}@media (width<=600px){.csg-header h1{font-size:1.3rem}.csg-source-chip{padding:.2rem .55rem;font-size:.73rem}.csg-output-tab{padding:.5rem .75rem;font-size:.78rem}}.jd{max-width:800px}.jd-header{border:1px solid #e5e7eb;border-left:5px solid var(--tool-color,#6d28d9);background:#f8fafc;border-radius:6px;margin-bottom:1.5rem;padding:1.25rem 1.5rem}.jd-header h1{color:var(--tool-color,#6d28d9);margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.jd-header p{color:#374151;margin:0}.jd-privacy{color:#6b7280;align-items:center;gap:.4rem;margin-bottom:1.5rem;font-size:.8rem;display:flex}.jd-privacy-icon{color:#16a34a}.jd-input-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1.5rem;padding:1.25rem}.jd-textarea{box-sizing:border-box;color:#0f172a;resize:vertical;border:1px solid #d1d5db;border-radius:6px;width:100%;min-height:88px;padding:.75rem;font-family:Menlo,Consolas,Monaco,monospace;font-size:.78rem}.jd-textarea:focus{border-color:var(--tool-color,#6d28d9);outline:none;box-shadow:0 0 0 3px #6d28d91f}.jd-input-actions{gap:.5rem;margin-top:.75rem;display:flex}.jd-example-btn{border:1.5px solid var(--tool-color,#6d28d9);color:var(--tool-color,#6d28d9);cursor:pointer;background:#fff;border-radius:6px;padding:.45rem .9rem;font-size:.85rem;font-weight:500}.jd-example-btn:hover{background:#f5f3ff}.jd-clear-btn{color:#6b7280;cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:6px;padding:.45rem .9rem;font-size:.85rem}.jd-clear-btn:hover{color:#0f172a;background:#f9fafb}.jd-error{color:#991b1b;background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;margin-bottom:1.5rem;padding:1rem 1.25rem;font-size:.875rem}.jd-token-display{word-break:break-all;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1.5rem;padding:1rem 1.25rem;font-family:Menlo,Consolas,Monaco,monospace;font-size:.75rem;line-height:1.65}.jd-part-header{color:#6d28d9;font-weight:600}.jd-part-payload{color:#b45309;font-weight:600}.jd-part-sig{color:#0e7490;font-weight:600}.jd-dot{color:#9ca3af;padding:0 1px;font-weight:700}.jd-panels{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}.jd-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;min-width:0;padding:1.25rem}.jd-panel-label{text-transform:uppercase;letter-spacing:.07em;margin-bottom:.75rem;font-size:.72rem;font-weight:700;display:block}.jd-panel-label--header{color:#6d28d9}.jd-panel-label--payload{color:#b45309}.jd-panel-label--sig{color:#0e7490}.jd-panel-label-row{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.jd-panel-label-row .jd-panel-label{margin-bottom:0}.jd-json{color:#0f172a;white-space:pre;background:#f8fafc;border:1px solid #f1f5f9;border-radius:4px;margin:0 0 .75rem;padding:.75rem;font-family:Menlo,Consolas,Monaco,monospace;font-size:.77rem;line-height:1.5;overflow-x:auto}.jd-copy-btn{color:#6b7280;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #d1d5db;border-radius:5px;flex-shrink:0;padding:.25rem .65rem;font-size:.75rem}.jd-copy-btn:hover{color:#0f172a;background:#f9fafb}.jd-sig-note{color:#6b7280;margin:0 0 .75rem;font-size:.8rem;font-style:italic;line-height:1.5}.jd-sig-value{color:#0e7490;word-break:break-all;background:#ecfeff;border:1px solid #a5f3fc;border-radius:4px;padding:.5rem;font-family:Menlo,Consolas,Monaco,monospace;font-size:.7rem;line-height:1.5}.jd-sig-empty{color:#dc2626;font-size:.82rem;font-weight:500}.jd-claims{border-top:1px solid #f1f5f9;padding-top:.75rem}.jd-claim-row{flex-wrap:wrap;align-items:baseline;gap:.4rem;margin-bottom:.3rem;font-size:.74rem;display:flex}.jd-claim-row:last-child{margin-bottom:0}.jd-claim-key{color:#b45309;background:#fffbeb;border-radius:3px;flex-shrink:0;padding:.1rem .3rem;font-family:Menlo,Consolas,Monaco,monospace;font-size:.7rem}.jd-claim-meta{color:#9ca3af;flex-shrink:0}.jd-claim-date{color:#374151}.jd-findings-section{margin-bottom:1.5rem}.jd-findings-title{color:#0f172a;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:1rem;font-weight:700;display:flex}.jd-findings-count{color:#374151;background:#f3f4f6;border-radius:999px;justify-content:center;align-items:center;min-width:1.5rem;height:1.5rem;padding:0 .35rem;font-size:.75rem;font-weight:700;display:inline-flex}.jd-finding{border:1px solid;border-radius:8px;margin-bottom:.5rem;padding:.875rem 1rem}.jd-finding:last-child{margin-bottom:0}.jd-finding--critical{background:#fff1f2;border-color:#fecdd3}.jd-finding--high{background:#fff7ed;border-color:#fed7aa}.jd-finding--medium{background:#fffbeb;border-color:#fde68a}.jd-finding--info{background:#eff6ff;border-color:#bfdbfe}.jd-finding-head{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.4rem;display:flex}.jd-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:999px;flex-shrink:0;padding:.15rem .5rem;font-size:.68rem;font-weight:700;display:inline-block}.jd-badge--critical{color:#fff;background:#dc2626}.jd-badge--high{color:#fff;background:#ea580c}.jd-badge--medium{color:#fff;background:#d97706}.jd-badge--info{color:#fff;background:#2563eb}.jd-finding-title{color:#0f172a;font-size:.875rem;font-weight:600}.jd-finding-body{color:#374151;margin:0;font-size:.825rem;line-height:1.55}.jd-finding-remediation{color:#374151;border-top:1px solid #00000012;margin-top:.6rem;padding-top:.6rem;font-size:.825rem;line-height:1.55}.jd-finding-fix-label{color:#15803d;margin-right:.35rem;font-weight:700}.jd-no-findings{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.875rem 1rem;font-size:.875rem;font-weight:500;display:flex}.jd-education{border-top:1px solid #e5e7eb;margin-top:2.5rem;padding-top:2rem}.jd-education h2{color:#0f172a;margin-bottom:1rem;font-size:1.25rem;font-weight:700}@media (width<=768px){.jd-panels{grid-template-columns:1fr}}@media (width<=480px){.jd-header h1{font-size:1.4rem}}
