/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Space+Mono:wght@400;700&display=swap";@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-300:oklch(80.8% .114 19.571);--color-red-700:oklch(50.5% .213 27.518);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-indigo-600:oklch(51.1% .262 276.966);--color-purple-50:oklch(97.7% .014 308.299);--color-purple-800:oklch(43.8% .218 303.724);--color-rose-600:oklch(58.6% .253 17.585);--color-slate-100:oklch(96.8% .007 247.896);--color-slate-200:oklch(92.9% .013 255.508);--color-slate-300:oklch(86.9% .022 252.894);--color-slate-500:oklch(55.4% .046 257.417);--color-slate-600:oklch(44.6% .043 257.281);--color-slate-700:oklch(37.2% .044 257.287);--color-slate-950:oklch(12.9% .042 264.695);--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-2xl:42rem;--container-5xl:64rem;--container-6xl:72rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25 / 1.875);--text-6xl:3.75rem;--text-6xl--line-height:1;--text-8xl:6rem;--text-8xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.relative{position:relative}.inset-0{inset:calc(var(--spacing) * 0)}.isolate{isolation:isolate}.z-10{z-index:10}.z-20{z-index:20}.mx-auto{margin-inline:auto}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-7{margin-top:calc(var(--spacing) * 7)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mt-9{margin-top:calc(var(--spacing) * 9)}.mt-10{margin-top:calc(var(--spacing) * 10)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.block{display:block}.flex{display:flex}.grid{display:grid}.inline-block{display:inline-block}.table{display:table}.h-\[80vh\]{height:80vh}.min-h-\[80vh\]{min-height:80vh}.w-80{width:calc(var(--spacing) * 80)}.w-fit{width:fit-content}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-5xl{max-width:var(--container-5xl)}.max-w-6xl{max-width:var(--container-6xl)}.max-w-md{max-width:var(--container-md)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.grid-cols-\[1fr_20rem\]{grid-template-columns:1fr 20rem}.flex-wrap{flex-wrap:wrap}.place-items-center{place-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}.overflow-hidden{overflow:hidden}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-3xl{border-radius:var(--radius-3xl)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-red-300{border-color:var(--color-red-300)}.border-slate-100{border-color:var(--color-slate-100)}.border-slate-200{border-color:var(--color-slate-200)}.border-slate-300{border-color:var(--color-slate-300)}.bg-blue-600{background-color:var(--color-blue-600)}.bg-indigo-600{background-color:var(--color-indigo-600)}.bg-purple-50{background-color:var(--color-purple-50)}.bg-rose-600{background-color:var(--color-rose-600)}.bg-slate-100{background-color:var(--color-slate-100)}.bg-slate-950\/40{background-color:#02061866}@supports (color:color-mix(in lab,red,red)){.bg-slate-950\/40{background-color:color-mix(in oklab,var(--color-slate-950) 40%,transparent)}}.bg-white{background-color:var(--color-white)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-12{padding-block:calc(var(--spacing) * 12)}.py-16{padding-block:calc(var(--spacing) * 16)}.pb-3{padding-bottom:calc(var(--spacing) * 3)}.text-center{text-align:center}.text-left{text-align:left}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-8{--tw-leading:calc(var(--spacing) * 8);line-height:calc(var(--spacing) * 8)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.whitespace-pre-wrap{white-space:pre-wrap}.text-blue-500{color:var(--color-blue-500)}.text-indigo-600{color:var(--color-indigo-600)}.text-purple-800{color:var(--color-purple-800)}.text-red-700{color:var(--color-red-700)}.text-rose-600{color:var(--color-rose-600)}.text-slate-500{color:var(--color-slate-500)}.text-slate-600{color:var(--color-slate-600)}.text-slate-700{color:var(--color-slate-700)}.text-white{color:var(--color-white)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a)}.shadow-sm,.shadow-xl{box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a),0 8px 10px -6px var(--tw-shadow-color,#0000001a)}.disabled\:opacity-60:disabled{opacity:.6}@media (min-width:40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:48rem){.md\:text-8xl{font-size:var(--text-8xl);line-height:var(--tw-leading,var(--text-8xl--line-height))}}@media (min-width:64rem){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}}@keyframes roadmap-node-in{0%{opacity:0;transform:translateY(14px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes roadmap-panel-in{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes roadmap-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes roadmap-flow{to{stroke-dashoffset:-28px}}@keyframes roadmap-glow{0%,to{opacity:.45;transform:scale(1)}50%{opacity:.9;transform:scale(1.04)}}@keyframes roadmap-sheen{0%{transform:skew(-16deg)translate(-180%)}55%,to{transform:skew(-16deg)translate(460%)}}@keyframes roadmap-aurora-a{0%,to{transform:translate(0)scale(1)}50%{transform:translate(60px,-40px)scale(1.15)}}@keyframes roadmap-aurora-b{0%,to{transform:translate(0)scale(1)}50%{transform:translate(-50px,40px)scale(1.1)}}.roadmap-canvas{--rm-canvas:#eef1f6;--rm-panel:#fff;--rm-glass:#ffffffd9;--rm-border:#e4e8ef;--rm-border-soft:#edf0f5;--rm-text:#0d1117;--rm-dim:#5b6472;--rm-mute:#9aa3b2;--rm-chip:#f3f5f9;--rm-chip-hover:#e9edf4;--rm-grid:#0f172a1a;--rm-track:#e4e8ef;--rm-done-bg:#fff;--rm-done-border:#d6f0e4;--rm-locked-bg:#e7eaf0;--rm-locked-border:#dde1e9;--rm-locked-text:#9aa3b2;--rm-stage:#0f172a21;--rm-shadow:#0f172a1a;cursor:grab;touch-action:none;min-height:0;color:var(--rm-text);background-color:var(--rm-canvas);background-image:radial-gradient(circle,var(--rm-grid) 1px,transparent 1px);background-size:30px 30px;flex:1;font-family:Manrope,system-ui,sans-serif;transition:padding-right .26s cubic-bezier(.22,.61,.36,1);position:relative;overflow:hidden}html[data-theme=dark] .roadmap-canvas{--rm-canvas:#0b0e14;--rm-panel:#0f131b;--rm-glass:#0d1118d1;--rm-border:#ffffff14;--rm-border-soft:#ffffff0f;--rm-text:#f1f4f9;--rm-dim:#9aa3b2;--rm-mute:#5b6472;--rm-chip:#ffffff0a;--rm-chip-hover:#ffffff14;--rm-grid:#ffffff12;--rm-track:#ffffff12;--rm-done-bg:#161c26;--rm-done-border:#10b98166;--rm-locked-bg:#ffffff06;--rm-locked-border:#ffffff0f;--rm-locked-text:#5b6472;--rm-stage:#ffffff29;--rm-shadow:#00000059}.roadmap-canvas:active{cursor:grabbing}.roadmap-canvas.detail-open{padding-right:340px}.roadmap-aurora{pointer-events:none;filter:blur(20px);border-radius:50%;position:absolute}.roadmap-aurora.one{background:radial-gradient(circle,#6366f11f,#0000 65%);width:520px;height:520px;animation:roadmap-aurora-a 16s ease-in-out infinite;top:-10%;left:8%}.roadmap-aurora.two{background:radial-gradient(circle,#a855f71a,#0000 65%);width:480px;height:480px;animation:roadmap-aurora-b 19s ease-in-out infinite;bottom:-12%;right:14%}.roadmap-aurora.three{background:radial-gradient(circle,#22d3ee12,#0000 65%);width:420px;height:420px;animation:roadmap-aurora-a 22s ease-in-out infinite;top:40%;left:46%}html[data-theme=dark] .roadmap-aurora.one{background:radial-gradient(circle,#6366f129,#0000 65%)}html[data-theme=dark] .roadmap-aurora.two{background:radial-gradient(circle,#a855f724,#0000 65%)}html[data-theme=dark] .roadmap-aurora.three{background:radial-gradient(circle,#22d3ee14,#0000 65%)}.roadmap-world{transform-origin:0 0;position:absolute}.roadmap-world.smooth{transition:transform .34s cubic-bezier(.22,.61,.36,1)}.roadmap-stage{color:var(--rm-stage);letter-spacing:2px;-webkit-user-select:none;user-select:none;font-family:Space Mono,monospace;font-size:.78rem;font-weight:700;top:-28px}.roadmap-edges,.roadmap-stage{pointer-events:none;position:absolute}.roadmap-edges{inset:0;overflow:visible}.roadmap-edges path{fill:none;stroke-linecap:round}.roadmap-edges path.done{stroke:#10b98180;stroke-width:2.5px}.roadmap-edges path.live{stroke:#6366f152;stroke-width:2.5px}.roadmap-edges path.locked{stroke:var(--rm-grid);stroke-width:1.5px;stroke-dasharray:4 7}.roadmap-edges path.flow{stroke:#818cf8;stroke-width:2.5px;stroke-dasharray:5 9;animation:roadmap-flow .85s linear infinite}.roadmap-edges path.flow.link{stroke:#22d3ee}.roadmap-node-wrap{width:214px;height:88px;animation:roadmap-node-in .45s cubic-bezier(.22,.61,.36,1) both;position:absolute}.roadmap-node-glow{border-radius:18px;animation:roadmap-glow 2.8s ease-in-out infinite;position:absolute;inset:-3px;box-shadow:0 0 32px #6366f199}.roadmap-node-wrap.link .roadmap-node-glow{box-shadow:0 0 32px #22d3ee73}.roadmap-node{z-index:1;border:1.5px solid var(--rm-locked-border);background:var(--rm-locked-bg);width:100%;height:100%;color:var(--rm-locked-text);box-shadow:none;text-align:left;-webkit-user-select:none;user-select:none;border-radius:15px;flex-direction:column;justify-content:center;gap:8px;padding:0 16px;transition:box-shadow .18s,border-color .18s,transform .18s,background .25s;display:flex;position:relative;overflow:hidden}.roadmap-node:not(:disabled):hover{transform:translateY(-3px)}.roadmap-node:disabled{cursor:default}.roadmap-node.done{border-color:var(--rm-done-border);background:var(--rm-done-bg);color:var(--rm-text);box-shadow:0 6px 18px var(--rm-shadow)}.roadmap-node.done:not(:disabled):hover{border-color:#10b981}.roadmap-node.hero{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-color:#a78bfa73;box-shadow:0 14px 34px #4f46e566,inset 0 1px #ffffff1f}.roadmap-node.hero.link{background:linear-gradient(135deg,#0f172a,#1e293b);border-color:#22d3ee59;box-shadow:0 14px 34px #080f1e80,inset 0 1px #ffffff14}.roadmap-node.selected{box-shadow:0 0 0 4px #10b98140,0 6px 18px var(--rm-shadow)}.roadmap-node.hero.selected{box-shadow:0 0 0 4px #6366f14d,0 14px 34px #4f46e566}.roadmap-node.hero.link.selected{box-shadow:0 0 0 4px #22d3ee40,0 14px 34px #080f1e80}.roadmap-sheen{pointer-events:none;background:linear-gradient(100deg,#0000,#ffffff38,#0000);width:42%;animation:roadmap-sheen 3.4s ease-in-out infinite;position:absolute;top:0;bottom:0;left:0}.roadmap-node-meta{z-index:2;width:100%;min-height:20px;color:var(--rm-locked-text);letter-spacing:.8px;text-transform:uppercase;justify-content:space-between;align-items:center;gap:8px;font-family:Space Mono,monospace;font-size:.6rem;font-weight:700;line-height:1;display:flex;position:relative}.roadmap-node.done .roadmap-node-meta{color:#10b981}.roadmap-node.hero .roadmap-node-meta{color:#c7d2fe}.roadmap-node.hero.link .roadmap-node-meta{color:#22d3ee}.roadmap-node-meta i{font-style:normal}.roadmap-node strong{z-index:2;-webkit-line-clamp:2;width:100%;min-height:0;color:inherit;letter-spacing:-.2px;overflow-wrap:anywhere;-webkit-box-orient:vertical;font-size:.92rem;font-weight:800;line-height:1.2;display:-webkit-box;position:relative;overflow:hidden}.roadmap-done-icon{color:#10b981;background:#10b98124;border-radius:50%;flex-shrink:0;place-items:center;width:20px;height:20px;font-size:11px;display:grid}.roadmap-link-icon{color:#22d3ee;flex-shrink:0;font-size:15px}.roadmap-live-dot{background:#fff;border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 0 4px #ffffff40}.roadmap-node-cta{z-index:2;color:#c7d2fe;justify-content:flex-end;align-items:center;width:100%;font-size:.72rem;font-weight:700;line-height:1;display:flex;position:relative}.roadmap-node.link .roadmap-node-cta{color:#22d3ee}.roadmap-legend{z-index:10;border:1px solid var(--rm-border);background:var(--rm-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 8px 24px var(--rm-shadow);border-radius:13px;flex-direction:column;gap:8px;padding:12px 16px;display:flex;position:absolute;bottom:22px;left:22px}.roadmap-legend strong{color:var(--rm-mute);letter-spacing:1px;margin-bottom:2px;font-family:Space Mono,monospace;font-size:.6rem}.roadmap-legend span{color:var(--rm-dim);align-items:center;gap:9px;font-size:.76rem;font-weight:500;display:flex}.roadmap-legend i{border-radius:50%;width:8px;height:8px;box-shadow:0 0 8px}.roadmap-legend i.done{color:#10b981;background:#10b981}.roadmap-legend i.available{color:#6366f1;background:#6366f1}.roadmap-legend i.link{color:#22d3ee;background:#22d3ee}.roadmap-legend i.locked{color:#94a3b8;background:#94a3b8}.roadmap-controls{z-index:10;align-items:center;gap:7px;display:flex;position:absolute;top:16px;right:16px}.roadmap-controls button{border:1px solid var(--rm-border);background:var(--rm-glass);width:34px;height:34px;color:var(--rm-text);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:8px;place-items:center;font-size:17px;font-weight:700;display:grid}.roadmap-controls button:hover{background:var(--rm-chip-hover)}.roadmap-controls button.reset{width:auto;padding:0 11px;font-size:16px}.roadmap-detail{z-index:20;border-left:1px solid var(--rm-border);background:var(--rm-panel);width:340px;box-shadow:-12px 0 40px var(--rm-shadow);flex-direction:column;animation:roadmap-panel-in .26s cubic-bezier(.22,.61,.36,1);display:flex;position:absolute;top:0;bottom:0;right:0;overflow:hidden}.roadmap-detail-accent{background:linear-gradient(90deg,#6366f1,#0000);flex-shrink:0;height:3px}.roadmap-detail-accent.link{background:linear-gradient(90deg,#22d3ee,#0000)}.roadmap-detail-accent.done{background:linear-gradient(90deg,#10b981,#0000)}.roadmap-detail-accent.locked{background:linear-gradient(90deg,#94a3b8,#0000)}.roadmap-detail header{border-bottom:1px solid var(--rm-border-soft);justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 22px 16px;display:flex}.roadmap-detail header div{gap:12px;display:grid}.roadmap-detail h2{color:var(--rm-text);letter-spacing:-.3px;margin:0;font-size:1.18rem;line-height:1.3}.roadmap-detail header button{border:1px solid var(--rm-border);background:var(--rm-chip);width:30px;height:30px;color:var(--rm-dim);border-radius:7px;flex-shrink:0;place-items:center;font-size:16px;display:grid}.roadmap-status{color:#6366f1;letter-spacing:.6px;text-transform:uppercase;background:#6366f11f;border:1px solid #6366f140;border-radius:5px;width:max-content;padding:4px 9px;font-size:.64rem;font-weight:700}.roadmap-status.link{color:#0891b2;background:#22d3ee1f;border-color:#22d3ee40}.roadmap-status.credited,.roadmap-status.done,.roadmap-status.grandfathered{color:#10b981;background:#10b9811f;border-color:#10b98140}.roadmap-status.locked{color:#94a3b8;background:#94a3b81f;border-color:#94a3b840}.roadmap-detail-body{flex-direction:column;flex:1;gap:16px;padding:18px 22px;display:flex;overflow:auto}.roadmap-detail-body>p{color:var(--rm-dim);margin:0;font-size:.9rem;line-height:1.7}.roadmap-detail-note{border:1px solid var(--rm-border-soft);background:var(--rm-chip);color:var(--rm-dim);border-radius:11px;padding:13px 15px;font-size:.85rem;line-height:1.6}.roadmap-detail-note.link{color:#0e7490;background:#22d3ee12;border-color:#22d3ee38}html[data-theme=dark] .roadmap-detail-note.link{color:#7dd3e8}.roadmap-dependencies{gap:7px;display:grid}.roadmap-dependencies>span{color:var(--rm-mute);letter-spacing:.7px;text-transform:uppercase;font-size:.64rem;font-weight:700}.roadmap-dependencies div{border:1px solid var(--rm-border);background:var(--rm-chip);color:var(--rm-dim);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;font-size:.78rem;display:flex}.roadmap-dependencies i{background:#94a3b8;border-radius:50%;width:7px;height:7px}.roadmap-detail footer{border-top:1px solid var(--rm-border-soft);padding:16px 22px}.roadmap-detail footer button{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:0;border-radius:11px;width:100%;padding:14px 0;font-size:.98rem;font-weight:800;box-shadow:0 8px 24px #6366f140}.roadmap-detail footer button.link{background:linear-gradient(135deg,#0891b2,#22d3ee);box-shadow:0 8px 24px #22d3ee40}.roadmap-detail footer button.done{background:linear-gradient(135deg,#059669,#10b981);box-shadow:0 8px 24px #10b98140}.roadmap-detail footer button:hover{filter:brightness(1.08);transform:translateY(-2px)}@media (max-width:759px){.roadmap-canvas.detail-open{padding-right:0}.roadmap-legend{display:none}.roadmap-controls.mobile{top:auto;right:14px;bottom:calc(20px + env(safe-area-inset-bottom));flex-direction:column;gap:8px}.roadmap-controls.mobile button{border-radius:12px;width:44px;height:44px;font-size:20px}.roadmap-controls.mobile button.reset{padding:0;font-size:16px}.roadmap-detail.mobile{border-top:1px solid var(--rm-border);border-left:0;border-radius:20px 20px 0 0;width:100%;max-height:80%;animation:roadmap-sheet-in .28s cubic-bezier(.22,.61,.36,1);top:auto;box-shadow:0 -16px 44px #00000052}.roadmap-sheet-handle{background:var(--rm-track);border-radius:3px;flex-shrink:0;width:38px;height:4px;margin:9px auto 0}.roadmap-detail.mobile footer{padding-bottom:calc(16px + env(safe-area-inset-bottom))}}:root{--blue:#4f8cff;--blue-dark:#316bd8;--teal:#6ee7b7;--ink:#1e293b;--muted:#64748b;--line:#e2e8f0;--surface:#fff;--canvas:#f8faff;--surface-soft:#f8fafc;--header:#ffffffe6;--shadow:0 18px 50px #3348701a}html[data-theme=dark]{--ink:#e6edf7;--muted:#9cacbf;--line:#26364b;--surface:#111b2b;--canvas:#0b1320;--surface-soft:#172337;--header:#0b1320e6;--shadow:0 18px 50px #0000004d;color-scheme:dark}*{box-sizing:border-box}html{background:var(--canvas)}body{background:linear-gradient(180deg,var(--surface) 0,var(--canvas) 420px);color:var(--ink);margin:0;font-family:Arial,Helvetica,sans-serif}a{color:inherit;text-decoration:none}button,input{font:inherit}button{cursor:pointer}.site-header{z-index:50;border-bottom:1px solid var(--line);background:var(--header);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);height:64px;position:sticky;top:0}.site-nav{gap:34px;max-width:1440px;height:100%;margin:auto;padding:0 24px}.brand,.site-nav{align-items:center;display:flex}.brand{gap:10px;font-weight:800}.brand-logo,.card-icon{color:#fff;background:linear-gradient(135deg,var(--blue),var(--teal));place-items:center;display:grid;box-shadow:0 7px 16px #4f8cff40}.brand-logo{border-radius:11px;width:38px;height:38px;font-size:12px}.nav-panel{flex:1;align-items:center;gap:24px;display:flex}.nav-links{gap:6px;display:flex}.nav-links a{color:var(--muted);border-radius:9px;padding:9px 12px;font-size:14px;font-weight:600}.nav-links a.active,.nav-links a:hover{color:var(--blue-dark);background:#eff6ff}.nav-user{gap:12px;margin-left:auto;font-size:14px;font-weight:600}.nav-user,.user-link{align-items:center;display:flex}.user-link{gap:9px}.user-link i{background:linear-gradient(135deg,var(--blue),var(--teal));color:#fff;border-radius:50%;place-items:center;width:36px;height:36px;font-size:11px;font-style:normal;display:grid}.icon-button{border:1px solid var(--line);background:var(--surface);width:34px;height:34px;color:var(--muted);border-radius:9px;place-items:center;display:grid}.icon-button:hover{background:var(--surface-soft);color:var(--ink)}.mobile-menu-button{margin-left:auto;display:none}.logout-button{border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:9px;padding:8px 12px;font-size:13px;font-weight:700}.logout-button:hover{color:#e11d48;background:#fff1f2;border-color:#fda4af}.site-main{min-height:calc(100vh - 64px)}.page-container{width:min(1180px,100% - 40px);margin:auto;padding:64px 0 90px}.page-heading{margin-bottom:34px}.page-heading h1{letter-spacing:-.045em;margin:7px 0 10px;font-size:clamp(34px,5vw,54px);line-height:1}.page-heading p{max-width:660px;color:var(--muted);margin:0;font-size:17px;line-height:1.6}.eyebrow{color:var(--blue-dark);letter-spacing:.14em;text-transform:uppercase;font-size:12px;font-weight:800}.page-message{color:var(--muted);text-align:center;padding:50px}.page-message.error{color:#e11d48}.primary-button{background:linear-gradient(90deg,var(--blue),var(--teal));color:#fff;border:0;border-radius:12px;justify-content:center;align-items:center;gap:10px;min-height:44px;padding:0 20px;font-weight:800;transition:all .15s;display:inline-flex;box-shadow:0 8px 20px #4f8cff40}.primary-button:hover{filter:saturate(1.1);transform:translateY(-1px)}.primary-button:disabled{cursor:not-allowed;opacity:.45;box-shadow:none;transform:none}.primary-button.compact{min-height:38px;padding:0 15px;font-size:13px}.secondary-button{border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:10px;align-items:center;gap:7px;padding:8px 12px;font-size:13px;font-weight:700;display:flex;box-shadow:0 3px 10px #33487014}.card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;display:grid}.content-card{border:1px solid var(--line);background:var(--surface);border-radius:22px;flex-direction:column;min-height:245px;padding:24px;transition:all .18s;display:flex;box-shadow:0 5px 18px #3348700d}.content-card:hover{box-shadow:var(--shadow);border-color:#93c5fd;transform:translateY(-4px)}.card-icon{border-radius:13px;width:44px;height:44px;font-weight:800}.profession-card .card-icon{background:linear-gradient(135deg,#8b5cf6,#6ee7b7)}.content-card h2{letter-spacing:-.02em;margin:24px 0 8px;font-size:20px}.content-card p{color:var(--muted);margin:0;font-size:14px;line-height:1.55}.card-meta{color:var(--muted);justify-content:space-between;gap:12px;margin-top:auto;padding-top:22px;font-size:12px;display:flex}.card-meta strong{color:var(--blue-dark)}.search-input{border:1px solid var(--line);background:var(--surface);width:100%;color:var(--ink);border-radius:14px;outline:none;margin-bottom:24px;padding:14px 16px;box-shadow:0 3px 12px #3348700a}.search-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #4f8cff21}.empty-card{border:1px dashed var(--line);color:var(--muted);text-align:center;border-radius:16px;margin-top:24px;padding:24px}.map-workspace{height:calc(100dvh - 64px);color:var(--ink);background:#f1f5f9;flex-direction:column;display:flex;overflow:hidden}.map-context-bar{border-bottom:1px solid var(--line);background:var(--surface);flex-shrink:0;justify-content:space-between;align-items:center;gap:28px;min-height:66px;padding:10px 20px;display:flex}.map-context-bar h1{margin:3px 0 0;font-size:16px;line-height:1.2}.map-context-bar p{max-width:520px;color:var(--muted);text-align:right;margin:0;font-size:12px;line-height:1.45}.map-breadcrumb{color:var(--muted);align-items:center;gap:6px;font-size:12px;display:flex}.map-breadcrumb a{color:var(--blue);font-weight:700}.map-breadcrumb i{opacity:.45;font-style:normal}.mock-map-area{cursor:grab;touch-action:none;background-color:#f8faff;background-image:radial-gradient(circle,#c7d9ff 1px,#0000 0),radial-gradient(circle,#c7d9ff 1px,#0000 0);background-position:0 0,16px 16px;background-repeat:repeat;background-size:32px 32px;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;flex:1;min-height:0;position:relative;overflow:hidden}.mock-map-area:active{cursor:grabbing}.mock-map-viewport{transform-origin:0 0;position:absolute}.mock-map-edges{pointer-events:none;position:absolute;inset:0;overflow:visible}.mock-edge{fill:none;stroke:#94a3b8;stroke-width:2px}.mock-edge.active{stroke:#4f8cff;stroke-width:2.5px}.mock-edge.next{stroke-dasharray:7 5}.mock-edge-arrow{fill:#94a3b8}.mock-edge-arrow.active{fill:#4f8cff}.mock-nodes-layer{position:absolute;inset:0}.mock-map-node{color:#1e293b;text-align:center;-webkit-user-select:none;user-select:none;background:#fff;border:2px solid #e2e8f0;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:120px;height:120px;padding:10px;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex;position:absolute;box-shadow:0 4px 12px #00000012,0 1px 3px #0000000d}.mock-map-node:hover{transform:translateY(-3px)scale(1.03);box-shadow:0 8px 24px #0000001f}.mock-map-node.selected{box-shadow:0 0 0 3px #4f8cff,0 8px 24px #4f8cff40}.mock-map-node.locked{opacity:.7;background:#f1f5f9;border-color:#cbd5e1}.mock-map-node.available{background:#eff6ff;border-color:#93c5fd}.mock-map-node.in_progress{background:#fffbeb;border-color:#fcd34d}.mock-map-node.done{background:#f0fdf4;border-color:#86efac}.mock-map-node.credited,.mock-map-node.grandfathered{background:#f5f3ff;border-color:#c4b5fd}.mock-ring-wrap{flex-shrink:0;width:44px;height:44px;position:relative}.mock-ring-wrap svg{position:absolute;inset:0;transform:rotate(-90deg)}.mock-ring-bg{fill:none;stroke:#e2e8f0;stroke-width:3px}.mock-ring-fg{fill:none;stroke-width:3px;stroke-linecap:round}.mock-ring-fg.locked{stroke:#cbd5e1}.mock-ring-fg.available{stroke:#3b82f6}.mock-ring-fg.in_progress{stroke:#f59e0b}.mock-ring-fg.done{stroke:#22c55e}.mock-ring-fg.credited,.mock-ring-fg.grandfathered{stroke:#8b5cf6}.mock-ring-inner{background:#fff;border-radius:50%;place-items:center;font-size:17px;display:grid;position:absolute;inset:4px}.mock-map-node.locked .mock-ring-inner{background:#f1f5f9}.mock-map-node.available .mock-ring-inner{background:#eff6ff}.mock-map-node.in_progress .mock-ring-inner{background:#fffbeb}.mock-map-node.done .mock-ring-inner{background:#f0fdf4}.mock-map-node.credited .mock-ring-inner,.mock-map-node.grandfathered .mock-ring-inner{background:#f5f3ff}.mock-node-title{-webkit-line-clamp:2;color:#1e293b;-webkit-box-orient:vertical;max-width:100%;font-size:12px;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.mock-map-node.locked .mock-node-title{color:#64748b}.mock-legend{z-index:10;position:absolute;top:16px;left:16px}.mock-legend-button{color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:6px;padding:7px 12px;font-size:13px;font-weight:600;display:flex;box-shadow:0 2px 6px #00000012}.mock-legend-panel{background:#fff;border:1px solid #e2e8f0;border-radius:14px;flex-direction:column;gap:7px;min-width:230px;margin-top:6px;padding:12px;display:flex;box-shadow:0 4px 16px #0000001a}.mock-legend-panel div{color:#64748b;align-items:center;gap:8px;font-size:12px;display:flex}.mock-legend-panel i{border-radius:4px;flex-shrink:0;width:12px;height:12px}.mock-legend-panel i.locked{background:#cbd5e1}.mock-legend-panel i.available{background:#3b82f6}.mock-legend-panel i.in_progress{background:#f59e0b}.mock-legend-panel i.done{background:#22c55e}.mock-legend-panel i.credited{background:#8b5cf6}.mock-map-controls{z-index:10;flex-direction:column;gap:4px;display:flex;position:absolute;bottom:20px;right:20px}.mock-map-controls button{color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-radius:10px;place-items:center;width:36px;height:36px;font-size:18px;font-weight:600;display:grid;box-shadow:0 2px 6px #00000014}.mock-map-controls button:hover{background:#f8fafc}.mock-map-controls i{background:#e2e8f0;height:1px;margin:2px 0}.mock-map-controls button.reset{font-size:13px}.mock-sidebar{z-index:15;background:#fff;border-left:1px solid #e2e8f0;flex-direction:column;width:320px;height:100%;transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:0;right:0;transform:translate(100%);box-shadow:-4px 0 20px #00000014}.mock-sidebar.open{transform:translate(0)}.mock-sidebar-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:flex-start;gap:10px;padding:20px 20px 16px;display:flex}.mock-sidebar-header h2{color:#1e293b;margin:0;font-size:17px;line-height:1.3}.mock-sidebar-close{color:#64748b;background:0 0;border:1px solid #e2e8f0;border-radius:8px;flex-shrink:0;place-items:center;width:28px;height:28px;font-size:16px;display:grid}.mock-sidebar-close:hover{background:#f8fafc}.mock-sidebar-status{border-radius:20px;align-items:center;gap:5px;margin-top:6px;padding:3px 10px;font-size:12px;font-weight:700;display:inline-flex}.mock-sidebar-status.locked{color:#64748b;background:#f1f5f9}.mock-sidebar-status.available{color:#3b82f6;background:#eff6ff}.mock-sidebar-status.in_progress{color:#f59e0b;background:#fffbeb}.mock-sidebar-status.done{color:#15803d;background:#f0fdf4}.mock-sidebar-status.credited,.mock-sidebar-status.grandfathered{color:#8b5cf6;background:#f5f3ff}.mock-sidebar-body{flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.mock-progress-wrap{flex-direction:column;gap:6px;display:flex}.mock-progress-label{color:#64748b;justify-content:space-between;font-size:13px;font-weight:500;display:flex}.mock-progress-track{background:#e2e8f0;border-radius:99px;height:8px;overflow:hidden}.mock-progress-track div{background:linear-gradient(90deg,#4f8cff,#6ee7b7);border-radius:99px;height:100%}.mock-info-block{flex-direction:column;gap:4px;display:flex}.mock-info-block>span{color:#64748b;letter-spacing:.05em;text-transform:uppercase;font-size:12px;font-weight:600}.mock-info-block p{color:#1e293b;margin:0;font-size:14px;line-height:1.5}.mock-prereq-list{flex-direction:column;gap:5px;display:flex}.mock-prereq-list div{color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;padding:7px 10px;font-size:13px;display:flex}.mock-prereq-list i{background:#cbd5e1;border-radius:50%;width:8px;height:8px}.mock-sidebar-footer{border-top:1px solid #e2e8f0;padding:16px 20px}.mock-open-button{color:#fff;background:linear-gradient(90deg,#4f8cff,#6ee7b7);border:0;border-radius:12px;width:100%;padding:12px;font-size:15px;font-weight:700;box-shadow:0 4px 12px #4f8cff4d}.mock-open-button:hover{opacity:.92;transform:translateY(-1px)}.mock-open-button:disabled{cursor:not-allowed;opacity:.45;box-shadow:none;transform:none}.mock-empty-state{color:#64748b;place-items:center;display:grid;position:absolute;inset:0}html[data-theme=dark] .map-workspace{color:#e5edf8;background:#0b1422}html[data-theme=dark] .map-context-bar{background:#111b2b;border-color:#26364b}html[data-theme=dark] .map-context-bar h1{color:#e5edf8}html[data-theme=dark] .map-breadcrumb,html[data-theme=dark] .map-context-bar p{color:#9cacbf}html[data-theme=dark] .mock-map-area{background-color:#091321;background-image:radial-gradient(circle,#8fa6c6 1px,#0000 0),radial-gradient(circle,#8fa6c6 1px,#0000 0);background-position:0 0;background-repeat:repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box}html[data-theme=dark] .mock-edge{stroke:#8fa3bf}html[data-theme=dark] .mock-edge.active{stroke:#5792ff}html[data-theme=dark] .mock-edge-arrow{fill:#8fa3bf}html[data-theme=dark] .mock-edge-arrow.active{fill:#5792ff}html[data-theme=dark] .mock-map-node{color:#e5edf8;background:#172337;border-color:#40516a;box-shadow:0 4px 14px #0000004d,0 1px 3px #00000059}html[data-theme=dark] .mock-map-node:hover{box-shadow:0 8px 26px #00000073}html[data-theme=dark] .mock-map-node.selected{box-shadow:0 0 0 3px #5792ff,0 8px 26px #00000073}html[data-theme=dark] .mock-map-node.locked{opacity:.72;background:#111b2b;border-color:#35445a}html[data-theme=dark] .mock-map-node.available{background:#132642;border-color:#5792ff}html[data-theme=dark] .mock-map-node.in_progress{background:#302614;border-color:#d79a31}html[data-theme=dark] .mock-map-node.done{background:#122b22;border-color:#43b978}html[data-theme=dark] .mock-map-node.credited,html[data-theme=dark] .mock-map-node.grandfathered{background:#241c3b;border-color:#9a7de7}html[data-theme=dark] .mock-node-title{color:#e5edf8}html[data-theme=dark] .mock-map-node.locked .mock-node-title{color:#91a0b5}html[data-theme=dark] .mock-ring-bg{stroke:#40516a}html[data-theme=dark] .mock-ring-inner{color:#e5edf8;background:#111b2b}html[data-theme=dark] .mock-map-node.locked .mock-ring-inner{background:#0d1725}html[data-theme=dark] .mock-map-node.available .mock-ring-inner{background:#0d1d33}html[data-theme=dark] .mock-map-node.in_progress .mock-ring-inner{background:#21190c}html[data-theme=dark] .mock-map-node.done .mock-ring-inner{background:#0c2119}html[data-theme=dark] .mock-map-node.credited .mock-ring-inner,html[data-theme=dark] .mock-map-node.grandfathered .mock-ring-inner{background:#191229}html[data-theme=dark] .mock-legend-button,html[data-theme=dark] .mock-legend-panel,html[data-theme=dark] .mock-map-controls button{color:#e5edf8;background:#111b2b;border-color:#35445a;box-shadow:0 3px 10px #0000004d}html[data-theme=dark] .mock-legend-panel div{color:#a8b6c9}html[data-theme=dark] .mock-map-controls button:hover{background:#172337}html[data-theme=dark] .mock-map-controls i{background:#35445a}html[data-theme=dark] .mock-sidebar{background:#111b2b;border-color:#26364b;box-shadow:-4px 0 24px #00000059}html[data-theme=dark] .mock-sidebar-footer,html[data-theme=dark] .mock-sidebar-header{border-color:#26364b}html[data-theme=dark] .mock-info-block p,html[data-theme=dark] .mock-sidebar-header h2{color:#e5edf8}html[data-theme=dark] .mock-sidebar-close{color:#9cacbf;border-color:#35445a}html[data-theme=dark] .mock-sidebar-close:hover{background:#172337}html[data-theme=dark] .mock-info-block>span,html[data-theme=dark] .mock-progress-label{color:#9cacbf}html[data-theme=dark] .mock-progress-track{background:#26364b}html[data-theme=dark] .mock-prereq-list div{color:#e5edf8;background:#172337;border-color:#35445a}html[data-theme=dark] .mock-prereq-list i{background:#6d7f97}.map-shell{background:var(--canvas);flex:1;min-height:0;position:relative;overflow:hidden}.map-shell .react-flow__controls{border:1px solid var(--line);border-radius:10px;bottom:20px;left:auto;right:20px;overflow:hidden;box-shadow:0 2px 6px #00000014}.map-shell .react-flow__controls-button{border-bottom-color:var(--line);width:36px;height:36px}.map-legend{z-index:10;position:absolute;top:16px;left:16px}.legend-panel{border:1px solid var(--line);background:var(--surface);width:230px;box-shadow:var(--shadow);border-radius:14px;gap:9px;margin-top:7px;padding:12px;display:grid}.legend-panel div{color:var(--muted);align-items:center;gap:8px;font-size:12px;display:flex}.legend-panel i{border-radius:4px;width:12px;height:12px}.legend-locked{background:#cbd5e1}.legend-available{background:#3b82f6}.legend-in_progress{background:#f59e0b}.legend-done{background:#22c55e}.legend-credited{background:#8b5cf6}.legend-link{background:linear-gradient(135deg,var(--blue),var(--teal))}.empty-state{z-index:5;color:var(--muted);place-items:center;display:grid;position:absolute;inset:0}.map-node{border:2px solid var(--line);background:var(--surface);width:120px;height:120px;color:var(--ink);text-align:center;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:10px;transition:all .15s;display:flex;box-shadow:0 4px 12px #00000012,0 1px 3px #0000000d}.map-node:hover{transform:translateY(-3px)scale(1.03);box-shadow:0 8px 24px #0000001f}.map-node.is-selected{box-shadow:0 0 0 3px var(--blue),0 10px 24px #4f8cff33}.map-node-locked{opacity:.72;background:#f1f5f9;border-color:#cbd5e1}.map-node-available{background:#eff6ff;border-color:#93c5fd}.map-node-in_progress{background:#fffbeb;border-color:#fcd34d}.map-node-done{background:#f0fdf4;border-color:#86efac}.map-node-credited,.map-node-grandfathered{background:#f5f3ff;border-color:#c4b5fd}.map-node-ring{width:44px;height:44px;position:relative}.map-node-ring svg{position:absolute;inset:0;transform:rotate(-90deg)}.map-node-ring circle{fill:none;stroke-width:3px}.map-ring-bg{stroke:#e2e8f0}.map-ring-value{stroke:var(--blue);stroke-linecap:round}.map-node-in_progress .map-ring-value{stroke:#f59e0b}.map-node-done .map-ring-value{stroke:#22c55e}.map-node-credited .map-ring-value,.map-node-grandfathered .map-ring-value{stroke:#8b5cf6}.map-node-locked .map-ring-value{stroke:#cbd5e1}.map-node-ring span{background:var(--surface);border-radius:50%;place-items:center;font-size:14px;font-weight:900;display:grid;position:absolute;inset:5px}.map-node-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:100%;font-size:12px;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.map-handle{opacity:0}.map-sidebar{z-index:20;border-left:1px solid var(--line);background:var(--surface);flex-direction:column;width:320px;height:100%;animation:slide-in .25s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:0;right:0;box-shadow:-4px 0 20px #00000014}@keyframes slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.map-sidebar-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:12px;padding:20px;display:flex}.map-sidebar-header h2{margin:0 0 8px;font-size:18px;line-height:1.3}.status-pill{border-radius:30px;gap:5px;padding:4px 9px;font-size:11px;font-weight:800;display:inline-flex}.status-locked{color:#64748b;background:#f1f5f9}.status-available{color:#2563eb;background:#eff6ff}.status-in_progress{color:#d97706;background:#fffbeb}.status-done{color:#15803d;background:#f0fdf4}.status-credited,.status-grandfathered{color:#7c3aed;background:#f5f3ff}.map-sidebar-body{flex-direction:column;flex:1;gap:22px;padding:20px;display:flex;overflow:auto}.progress-label{color:var(--muted);justify-content:space-between;margin-bottom:7px;font-size:12px;display:flex}.progress-track{background:#e2e8f0;border-radius:10px;height:8px;overflow:hidden}.progress-track div{border-radius:inherit;background:linear-gradient(90deg,var(--blue),var(--teal));height:100%}.info-block{gap:7px;display:grid}.info-block>span{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-size:10px;font-weight:800}.info-block p{margin:0;font-size:13px;line-height:1.6}.route-note{background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;gap:4px;padding:14px;font-size:12px;display:grid}.route-note span{color:var(--muted);line-height:1.5}.prerequisite-list{gap:6px;display:grid}.prerequisite-list div{border:1px solid var(--line);background:#f8fafc;border-radius:8px;align-items:center;gap:8px;padding:8px 10px;font-size:12px;display:flex}.prerequisite-list i{background:#cbd5e1;border-radius:50%;width:7px;height:7px}.map-sidebar-footer{border-top:1px solid var(--line);padding:16px 20px}.map-sidebar-footer .primary-button{width:100%}.inline-error{color:#be123c;background:#fff1f2;border:1px solid #fda4af;border-radius:12px;margin:-8px 0 20px;padding:12px 14px;font-size:13px}.demo-hint{background:var(--surface-soft);color:var(--muted);text-align:center;border-radius:10px;margin-top:18px;padding:10px 12px;font-size:12px}.rounded-2xl.border.bg-white,form.rounded-2xl,form.rounded-3xl{border-color:var(--line)!important;box-shadow:var(--shadow)!important;border-radius:22px!important}.bg-white,form.bg-white{background-color:var(--surface)!important}input.rounded-lg,input.rounded-xl{outline:none;border-color:var(--line)!important}input.rounded-lg:focus,input.rounded-xl:focus{box-shadow:0 0 0 3px #4f8cff21;border-color:var(--blue)!important}@media (max-width:900px){.card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.mobile-menu-button{display:grid}.nav-panel{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);border-radius:16px;padding:14px;display:none;position:absolute;top:64px;left:12px;right:12px}.nav-panel.is-open{gap:12px;display:grid}.nav-links,.nav-user{gap:6px;margin:0;display:grid}.logout-button,.nav-links a,.nav-user>a{align-items:center;width:100%;min-height:42px;padding:0 12px;display:flex}.nav-user{grid-template-columns:44px minmax(0,1fr)}.nav-user .theme-toggle{width:42px;height:42px}.nav-user .primary-button,.nav-user .user-link{grid-column:2}.nav-user .logout-button{grid-column:1/-1}.map-context-bar p{display:none}}@media (max-width:640px){.site-nav{padding:0 14px}.nav-user{grid-template-columns:1fr}.nav-user .primary-button,.nav-user .theme-toggle,.nav-user .user-link{grid-column:1;width:100%}.nav-user .theme-toggle:after{content:" Сменить тему";margin-left:7px}.user-link span{display:block}.page-container{width:min(100% - 28px,1180px);padding-top:40px}.card-grid{grid-template-columns:1fr}.content-card{min-height:220px}.map-context-bar{min-height:58px;padding:8px 12px}.map-context-bar h1{font-size:14px}.mock-sidebar{width:100%}.mock-legend{top:10px;left:10px}.mock-map-controls{bottom:10px;right:10px}.mock-sidebar-body{padding-bottom:90px}.mock-sidebar-footer{background:#fff;position:sticky;bottom:0}html[data-theme=dark] .mock-sidebar-footer{background:#111b2b}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}