*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8f9fb;--white:#fff;--text:#1e293b;--text-secondary:#64748b;--border:#e2e8f0;--green:#10b981;--green-light:#ecfdf5;--red:#ef4444;--red-light:#fef2f2;--yellow:#f59e0b;--yellow-light:#fffbeb;--purple:#8b5cf6;--purple-light:#f5f3ff;--blue:#3b82f6;--blue-light:#eff6ff;--accent:#6366f1;--accent-light:#eef2ff;--shadow:0 1px 3px #0000000f;--radius:16px;--radius-sm:10px;--radius-xs:8px;--mono:"JetBrains Mono",monospace}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,-apple-system,sans-serif}.container{max-width:1200px;margin:0 auto;padding:0 24px 48px}header{padding:20px 0}header a{color:var(--text-secondary);font-size:.95rem;font-weight:600;text-decoration:none}header a:hover{color:var(--green)}.page-hero{text-align:center;padding:12px 0 16px}.page-hero h1{letter-spacing:-.02em;margin-bottom:2px;font-size:1.7rem;font-weight:800}.page-hero .subtitle{color:var(--purple);font-size:.88rem;font-weight:600}.page-hero p{color:var(--text-secondary);max-width:580px;margin:6px auto 0;font-size:.92rem}.spec-pills{flex-wrap:wrap;justify-content:center;gap:6px;margin-top:10px;display:flex}.spec-pill{border-radius:12px;padding:3px 10px;font-size:.72rem;font-weight:600}.spec-pill.gcse{background:var(--blue-light);color:var(--blue)}.spec-pill.alevel{background:var(--purple-light);color:var(--purple)}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;padding:20px}.card-header{align-items:center;gap:8px;margin-bottom:12px;display:flex}.card-header .icon{border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.9rem;display:flex}.card-header h3{text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;font-weight:700}.btn{border:1.5px solid var(--border);border-radius:var(--radius-xs);background:var(--white);color:var(--text);cursor:pointer;box-shadow:var(--shadow);align-items:center;gap:5px;padding:8px 16px;font-family:inherit;font-size:.82rem;font-weight:600;transition:all .15s;display:inline-flex}.btn:hover{border-color:var(--green);color:var(--green);transform:translateY(-1px)}.btn.primary{background:var(--green);border-color:var(--green);color:#fff}.btn.primary:hover{background:#059669}.btn.active{background:var(--green);border-color:var(--green);color:#fff}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.form-select{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-xs);color:var(--text);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding:8px 30px 8px 12px;font-size:.85rem;font-weight:600}.controls{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.controls label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.two-col{grid-template-columns:1fr 340px;align-items:start;gap:16px;display:grid}@media (width<=900px){.two-col{grid-template-columns:1fr}}#graph-canvas{background:var(--white);border:2px solid var(--border);border-radius:var(--radius);cursor:crosshair;width:100%;height:480px;display:block}.onboarding{margin-bottom:8px;position:relative}.onboarding-banner{background:var(--green-light);border-radius:var(--radius-sm);border:1px solid #10b98133;padding:14px 18px;font-size:.88rem;line-height:1.6}.onboarding-banner strong{color:var(--green)}.onboarding-banner .dismiss{float:right;cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:0 0 0 8px;font-size:1rem}.step-desc{color:var(--text-secondary);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);min-height:2.5em;margin-top:8px;padding:10px 14px;font-size:.88rem;line-height:1.6}.result-banner{border-radius:var(--radius-sm);text-align:center;margin-top:10px;padding:16px;font-size:1.05rem;font-weight:700;display:none}.result-banner.show{display:block}.result-banner.success{background:var(--green-light);color:var(--green);border:1px solid #10b98133}.result-banner.fail{background:var(--red-light);color:var(--red)}.legend{flex-wrap:wrap;gap:12px;padding:6px 0;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:5px;font-size:.75rem;font-weight:600;display:flex}.legend-dot{border-radius:50%;width:12px;height:12px}.dist-table{border-collapse:collapse;width:100%;font-size:.82rem}.dist-table th,.dist-table td{text-align:center;border-bottom:1px solid var(--border);padding:7px 10px}.dist-table th{color:var(--text-secondary);text-transform:uppercase;background:var(--bg);font-size:.7rem;font-weight:700}.dist-table td{font-family:var(--mono)}.dist-table tr.visited td{color:var(--green);font-weight:600}.dist-table tr.current td{background:var(--red-light);color:var(--red);font-weight:600}.dist-table tr.queued td{color:var(--yellow);font-weight:600}.dist-table tr.path td{background:var(--purple-light);color:var(--purple);font-weight:700}.how-it-works{color:var(--text-secondary);font-size:.85rem;line-height:1.8}.how-it-works ol{margin-top:6px;padding-left:18px}.how-it-works li{margin-bottom:4px}.how-it-works strong{color:var(--text)}.complexity{border-top:1px solid var(--border);gap:12px;margin-top:12px;padding-top:12px;display:flex}.complexity .item{text-align:center;flex:1}.complexity .item .label{text-transform:uppercase;color:var(--text-secondary);font-size:.68rem;font-weight:600}.complexity .item .val{font-family:var(--mono);color:var(--green);font-size:.85rem;font-weight:700}.complexity .item .explain{color:var(--text-secondary);margin-top:2px;font-size:.68rem}.build-help{color:var(--text-secondary);background:var(--green-light);border-radius:var(--radius-sm);border:1px solid #10b98126;margin-top:8px;padding:12px 16px;font-size:.84rem;line-height:1.6}.build-help strong{color:var(--green)}.challenge{background:var(--yellow-light);border-radius:var(--radius-sm);border:1px solid #f59e0b33;margin-top:10px;padding:12px 16px;font-size:.85rem}.challenge strong{color:var(--yellow)}input[type=range]{accent-color:var(--green);width:90px}
