*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.prose{color:var(--color-text-primary);max-width:65ch}.prose :where(p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em}.prose :where([class~=lead]):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-lead);font-size:1.25em;line-height:1.6;margin-top:1.2em;margin-bottom:1.2em}.prose :where(a):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--color-accent);text-decoration:underline;font-weight:500}.prose :where(a):not(:where([class~=not-prose],[class~=not-prose] *)):hover{color:var(--color-accent-dark)}.prose :where(strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--color-text-primary);font-weight:600}.prose :where(a strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(blockquote strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(thead th strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(ol):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:decimal;margin-top:1.25em;margin-bottom:1.25em;padding-inline-start:1.625em}.prose :where(ol[type=A]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-alpha}.prose :where(ol[type=a]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-alpha}.prose :where(ol[type=A s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-alpha}.prose :where(ol[type=a s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-alpha}.prose :where(ol[type=I]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-roman}.prose :where(ol[type=i]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-roman}.prose :where(ol[type=I s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-roman}.prose :where(ol[type=i s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-roman}.prose :where(ol[type="1"]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:decimal}.prose :where(ul):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:disc;margin-top:1.25em;margin-bottom:1.25em;padding-inline-start:1.625em}.prose :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *))::marker{font-weight:400;color:var(--tw-prose-counters)}.prose :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *))::marker{color:var(--tw-prose-bullets)}.prose :where(dt):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);font-weight:600;margin-top:1.25em}.prose :where(hr):not(:where([class~=not-prose],[class~=not-prose] *)){border-color:var(--tw-prose-hr);border-top-width:1px;margin-top:3em;margin-bottom:3em}.prose :where(blockquote):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:500;font-style:italic;color:var(--color-text-secondary);border-inline-start-width:.25rem;border-inline-start-color:var(--tw-prose-quote-borders);quotes:"\201C""\201D""\2018""\2019";margin-top:1.6em;margin-bottom:1.6em;padding-inline-start:1em;border-left-color:var(--color-accent)}.prose :where(blockquote p:first-of-type):not(:where([class~=not-prose],[class~=not-prose] *)):before{content:open-quote}.prose :where(blockquote p:last-of-type):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:close-quote}.prose :where(h1):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--color-text-primary);font-weight:800;font-size:2.25em;margin-top:0;margin-bottom:.8888889em;line-height:1.1111111}.prose :where(h1 strong):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:900;color:inherit}.prose :where(h2):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--color-text-primary);font-weight:700;font-size:1.5em;margin-top:2em;margin-bottom:1em;line-height:1.3333333}.prose :where(h2 strong):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:800;color:inherit}.prose :where(h3):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--color-text-primary);font-weight:600;font-size:1.25em;margin-top:1.6em;margin-bottom:.6em;line-height:1.6}.prose :where(h3 strong):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:700;color:inherit}.prose :where(h4):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--color-text-primary);font-weight:600;margin-top:1.5em;margin-bottom:.5em;line-height:1.5}.prose :where(h4 strong):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:700;color:inherit}.prose :where(img):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(picture):not(:where([class~=not-prose],[class~=not-prose] *)){display:block;margin-top:2em;margin-bottom:2em}.prose :where(video):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(kbd):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:500;font-family:inherit;color:var(--tw-prose-kbd);box-shadow:0 0 0 1px var(--tw-prose-kbd-shadows),0 3px 0 var(--tw-prose-kbd-shadows);font-size:.875em;border-radius:.3125rem;padding-top:.1875em;padding-inline-end:.375em;padding-bottom:.1875em;padding-inline-start:.375em}.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--color-text-primary);font-weight:600;font-size:.875em}.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):before{content:"`"}.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:"`"}.prose :where(a code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(h1 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(h2 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-size:.875em}.prose :where(h3 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-size:.9em}.prose :where(h4 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(blockquote code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(thead th code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(pre):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-pre-code);background-color:var(--tw-prose-pre-bg);overflow-x:auto;font-weight:400;font-size:.875em;line-height:1.7142857;margin-top:1.7142857em;margin-bottom:1.7142857em;border-radius:.375rem;padding-top:.8571429em;padding-inline-end:1.1428571em;padding-bottom:.8571429em;padding-inline-start:1.1428571em}.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)){background-color:transparent;border-width:0;border-radius:0;padding:0;font-weight:inherit;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)):before{content:none}.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:none}.prose :where(table):not(:where([class~=not-prose],[class~=not-prose] *)){width:100%;table-layout:auto;margin-top:2em;margin-bottom:2em;font-size:.875em;line-height:1.7142857}.prose :where(thead):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:1px;border-bottom-color:var(--tw-prose-th-borders)}.prose :where(thead th):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);font-weight:600;vertical-align:bottom;padding-inline-end:.5714286em;padding-bottom:.5714286em;padding-inline-start:.5714286em}.prose :where(tbody tr):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:1px;border-bottom-color:var(--tw-prose-td-borders)}.prose :where(tbody tr:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:0}.prose :where(tbody td):not(:where([class~=not-prose],[class~=not-prose] *)){vertical-align:baseline}.prose :where(tfoot):not(:where([class~=not-prose],[class~=not-prose] *)){border-top-width:1px;border-top-color:var(--tw-prose-th-borders)}.prose :where(tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)){vertical-align:top}.prose :where(th,td):not(:where([class~=not-prose],[class~=not-prose] *)){text-align:start}.prose :where(figure>*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose :where(figcaption):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-captions);font-size:.875em;line-height:1.4285714;margin-top:.8571429em}.prose{--tw-prose-body:#374151;--tw-prose-headings:#111827;--tw-prose-lead:#4b5563;--tw-prose-links:#111827;--tw-prose-bold:#111827;--tw-prose-counters:#6b7280;--tw-prose-bullets:#d1d5db;--tw-prose-hr:#e5e7eb;--tw-prose-quotes:#111827;--tw-prose-quote-borders:#e5e7eb;--tw-prose-captions:#6b7280;--tw-prose-kbd:#111827;--tw-prose-kbd-shadows:rgba(17,24,39,.1);--tw-prose-code:#111827;--tw-prose-pre-code:#e5e7eb;--tw-prose-pre-bg:#1f2937;--tw-prose-th-borders:#d1d5db;--tw-prose-td-borders:#e5e7eb;--tw-prose-invert-body:#d1d5db;--tw-prose-invert-headings:#fff;--tw-prose-invert-lead:#9ca3af;--tw-prose-invert-links:#fff;--tw-prose-invert-bold:#fff;--tw-prose-invert-counters:#9ca3af;--tw-prose-invert-bullets:#4b5563;--tw-prose-invert-hr:#374151;--tw-prose-invert-quotes:#f3f4f6;--tw-prose-invert-quote-borders:#374151;--tw-prose-invert-captions:#9ca3af;--tw-prose-invert-kbd:#fff;--tw-prose-invert-kbd-shadows:hsla(0,0%,100%,.1);--tw-prose-invert-code:#fff;--tw-prose-invert-pre-code:#d1d5db;--tw-prose-invert-pre-bg:rgba(0,0,0,.5);--tw-prose-invert-th-borders:#4b5563;--tw-prose-invert-td-borders:#374151;font-size:1rem;line-height:1.75}.prose :where(picture>img):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose :where(li):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.5em;margin-bottom:.5em}.prose :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:.375em}.prose :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:.375em}.prose :where(.prose>ul>li p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.75em;margin-bottom:.75em}.prose :where(.prose>ul>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em}.prose :where(.prose>ul>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.25em}.prose :where(.prose>ol>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em}.prose :where(.prose>ol>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.25em}.prose :where(ul ul,ul ol,ol ul,ol ol):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.75em;margin-bottom:.75em}.prose :where(dl):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em}.prose :where(dd):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.5em;padding-inline-start:1.625em}.prose :where(hr+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(h2+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(h3+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(h4+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(thead th:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose :where(thead th:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose :where(tbody td,tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)){padding-top:.5714286em;padding-inline-end:.5714286em;padding-bottom:.5714286em;padding-inline-start:.5714286em}.prose :where(tbody td:first-child,tfoot td:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose :where(tbody td:last-child,tfoot td:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose :where(figure):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(.prose>:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(.prose>:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:0}.prose-lg{font-size:1.125rem;line-height:1.7777778}.prose-lg :where(p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.3333333em;margin-bottom:1.3333333em}.prose-lg :where([class~=lead]):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:1.2222222em;line-height:1.4545455;margin-top:1.0909091em;margin-bottom:1.0909091em}.prose-lg :where(blockquote):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.6666667em;margin-bottom:1.6666667em;padding-inline-start:1em}.prose-lg :where(h1):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:2.6666667em;margin-top:0;margin-bottom:.8333333em;line-height:1}.prose-lg :where(h2):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:1.6666667em;margin-top:1.8666667em;margin-bottom:1.0666667em;line-height:1.3333333}.prose-lg :where(h3):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:1.3333333em;margin-top:1.6666667em;margin-bottom:.6666667em;line-height:1.5}.prose-lg :where(h4):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.7777778em;margin-bottom:.4444444em;line-height:1.5555556}.prose-lg :where(img):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.7777778em;margin-bottom:1.7777778em}.prose-lg :where(picture):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.7777778em;margin-bottom:1.7777778em}.prose-lg :where(picture>img):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose-lg :where(video):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.7777778em;margin-bottom:1.7777778em}.prose-lg :where(kbd):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:.8888889em;border-radius:.3125rem;padding-top:.2222222em;padding-inline-end:.4444444em;padding-bottom:.2222222em;padding-inline-start:.4444444em}.prose-lg :where(code):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:.8888889em}.prose-lg :where(h2 code):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:.8666667em}.prose-lg :where(h3 code):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:.875em}.prose-lg :where(pre):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:.8888889em;line-height:1.75;margin-top:2em;margin-bottom:2em;border-radius:.375rem;padding-top:1em;padding-inline-end:1.5em;padding-bottom:1em;padding-inline-start:1.5em}.prose-lg :where(ol):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.3333333em;margin-bottom:1.3333333em;padding-inline-start:1.5555556em}.prose-lg :where(ul):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.3333333em;margin-bottom:1.3333333em;padding-inline-start:1.5555556em}.prose-lg :where(li):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.6666667em;margin-bottom:.6666667em}.prose-lg :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:.4444444em}.prose-lg :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:.4444444em}.prose-lg :where(.prose-lg>ul>li p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.8888889em;margin-bottom:.8888889em}.prose-lg :where(.prose-lg>ul>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.3333333em}.prose-lg :where(.prose-lg>ul>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.3333333em}.prose-lg :where(.prose-lg>ol>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.3333333em}.prose-lg :where(.prose-lg>ol>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.3333333em}.prose-lg :where(ul ul,ul ol,ol ul,ol ol):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.8888889em;margin-bottom:.8888889em}.prose-lg :where(dl):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.3333333em;margin-bottom:1.3333333em}.prose-lg :where(dt):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.3333333em}.prose-lg :where(dd):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.6666667em;padding-inline-start:1.5555556em}.prose-lg :where(hr):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:3.1111111em;margin-bottom:3.1111111em}.prose-lg :where(hr+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose-lg :where(h2+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose-lg :where(h3+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose-lg :where(h4+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose-lg :where(table):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:.8888889em;line-height:1.5}.prose-lg :where(thead th):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:.75em;padding-bottom:.75em;padding-inline-start:.75em}.prose-lg :where(thead th:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose-lg :where(thead th:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose-lg :where(tbody td,tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)){padding-top:.75em;padding-inline-end:.75em;padding-bottom:.75em;padding-inline-start:.75em}.prose-lg :where(tbody td:first-child,tfoot td:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose-lg :where(tbody td:last-child,tfoot td:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose-lg :where(figure):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.7777778em;margin-bottom:1.7777778em}.prose-lg :where(figure>*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose-lg :where(figcaption):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:.8888889em;line-height:1.5;margin-top:1em}.prose-lg :where(.prose-lg>:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose-lg :where(.prose-lg>:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:0}.visible{visibility:visible}.static{position:static}.mx-auto{margin-left:auto;margin-right:auto}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-16{margin-bottom:4rem}.mb-2{margin-bottom:.5rem}.mb-20{margin-bottom:5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.mt-0\.5{margin-top:.125rem}.mt-12{margin-top:3rem}.mt-20{margin-top:5rem}.mt-24{margin-top:6rem}.mt-4{margin-top:1rem}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-16{height:4rem}.h-24{height:6rem}.h-48{height:12rem}.h-\[40vh\]{height:40vh}.h-\[60vh\]{height:60vh}.h-\[80vh\]{height:80vh}.h-screen{height:100vh}.w-16{width:4rem}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.flex-shrink-0{flex-shrink:0}.grow{flex-grow:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.rounded-2xl{border-radius:1rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border-t{border-top-width:1px}.border-\[var\(--color-border\)\]{border-color:var(--color-border)}.bg-\[var\(--color-bg-muted\)\]{background-color:var(--color-bg-muted)}.bg-\[var\(--color-bg-secondary\)\]{background-color:var(--color-bg-secondary)}.object-cover{-o-object-fit:cover;object-fit:cover}.p-10{padding:2.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-20{padding-top:5rem;padding-bottom:5rem}.pt-12{padding-top:3rem}.pt-8{padding-top:2rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.text-\[var\(--color-purple\)\]{color:var(--color-purple)}.text-\[var\(--color-text-muted\)\]{color:var(--color-text-muted)}.text-\[var\(--color-text-primary\)\]{color:var(--color-text-primary)}.text-\[var\(--color-text-secondary\)\]{color:var(--color-text-secondary)}.text-\[var\(--color-text-subtle\)\]{color:var(--color-text-subtle)}.text-\[var\(--color-text-tertiary\)\]{color:var(--color-text-tertiary)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--font-sans:-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",Roboto,"Helvetica Neue",sans-serif;--font-serif:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,"Times New Roman",serif;--font-mono:"SF Mono","Fira Code","Monaco","Consolas","Liberation Mono",monospace;--text-xs:clamp(0.75rem,0.7rem + 0.25vw,0.8125rem);--text-sm:clamp(0.8125rem,0.775rem + 0.2vw,0.875rem);--text-base:clamp(0.9375rem,0.9rem + 0.2vw,1rem);--text-lg:clamp(1.0625rem,1rem + 0.3vw,1.125rem);--text-xl:clamp(1.1875rem,1.1rem + 0.4vw,1.25rem);--text-2xl:clamp(1.375rem,1.2rem + 0.9vw,1.5rem);--text-3xl:clamp(1.75rem,1.5rem + 1.25vw,2rem);--text-4xl:clamp(2.25rem,1.8rem + 2.25vw,2.75rem);--text-5xl:clamp(2.75rem,2rem + 3.75vw,3.5rem);--text-6xl:clamp(3.25rem,2.25rem + 5vw,4.5rem);--leading-none:1;--leading-tight:1.15;--leading-snug:1.3;--leading-normal:1.5;--leading-relaxed:1.65;--leading-loose:1.8;--tracking-tighter:-0.04em;--tracking-tight:-0.02em;--tracking-normal:0;--tracking-wide:0.025em;--tracking-wider:0.05em;--tracking-widest:0.1em;--space-0:0;--space-px:1px;--space-0-5:0.125rem;--space-1:0.25rem;--space-1-5:0.375rem;--space-2:0.5rem;--space-2-5:0.625rem;--space-3:0.75rem;--space-3-5:0.875rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-7:1.75rem;--space-8:2rem;--space-9:2.25rem;--space-10:2.5rem;--space-11:2.75rem;--space-12:3rem;--space-14:3.5rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--space-28:7rem;--space-32:8rem;--sidebar-width:280px;--container-max:1200px;--container-narrow:720px;--content-max:65ch;--radius-none:0;--radius-sm:0.25rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-3xl:2rem;--radius-full:9999px;--duration-75:75ms;--duration-100:100ms;--duration-150:150ms;--duration-200:200ms;--duration-300:300ms;--duration-500:500ms;--duration-700:700ms;--ease-in:cubic-bezier(0.4,0,1,1);--ease-out:cubic-bezier(0,0,0.2,1);--ease-in-out:cubic-bezier(0.4,0,0.2,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1);--z-base:0;--z-dropdown:1000;--z-sticky:1100;--z-fixed:1200;--z-modal-backdrop:1300;--z-modal:1400;--z-tooltip:1600;--color-purple:#8b5cf6;--color-purple-light:#a78bfa;--color-purple-dark:#7c3aed;--primary-50:#faf5ff;--primary-100:#f3e8ff;--primary-200:#e9d5ff;--primary-300:#d8b4fe;--primary-400:#c084fc;--primary-500:#a855f7;--primary-600:#9333ea;--primary-700:#7c3aed;--primary-800:#6b21a8;--primary-900:#581c87;--primary-950:#3b0764}:root,[data-theme=light]{--neutral-0:#fff;--neutral-50:#fafafa;--neutral-100:#f5f5f5;--neutral-150:#ededed;--neutral-200:#e5e5e5;--neutral-300:#d4d4d4;--neutral-400:#a3a3a3;--neutral-500:#737373;--neutral-600:#525252;--neutral-700:#404040;--neutral-800:#262626;--neutral-900:#171717;--neutral-950:#0a0a0a;--color-bg:var(--neutral-0);--color-bg-subtle:var(--neutral-50);--color-bg-muted:var(--neutral-100);--color-bg-emphasis:var(--neutral-150);--color-bg-inverse:var(--neutral-950);--color-text:var(--neutral-950);--color-text-subtle:var(--neutral-600);--color-text-muted:var(--neutral-400);--color-text-inverse:var(--neutral-0);--color-text-primary:var(--color-text);--color-text-secondary:var(--color-text-subtle);--color-text-tertiary:var(--color-text-muted);--color-border:var(--neutral-200);--color-border-subtle:var(--neutral-100);--color-border-emphasis:var(--neutral-300);--color-border-dark:var(--neutral-300);--color-bg-secondary:var(--color-bg-subtle);--color-bg-tertiary:var(--color-bg-muted);--color-accent:var(--neutral-950);--color-accent-subtle:hsla(0,0%,4%,.06);--color-accent-dark:var(--neutral-800);--color-primary:var(--primary-700);--color-primary-hover:var(--primary-800);--color-primary-subtle:rgba(124,58,237,.1);--color-primary-text:#fff;--shadow-xs:0 1px 2px rgba(0,0,0,.04);--shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 6px -1px rgba(0,0,0,.07),0 2px 4px -1px rgba(0,0,0,.04);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -2px rgba(0,0,0,.04);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.08),0 10px 10px -5px rgba(0,0,0,.03);--shadow-2xl:0 25px 50px -12px rgba(0,0,0,.15);--ring-color:hsla(0,0%,4%,.5);--ring-offset:var(--neutral-0)}[data-theme=dark]{--color-bg:var(--neutral-950);--color-bg-subtle:var(--neutral-900);--color-bg-muted:var(--neutral-800);--color-bg-emphasis:var(--neutral-700);--color-bg-inverse:var(--neutral-0);--color-text:var(--neutral-50);--color-text-subtle:var(--neutral-400);--color-text-muted:var(--neutral-500);--color-text-inverse:var(--neutral-950);--color-text-primary:var(--color-text);--color-text-secondary:var(--color-text-subtle);--color-text-tertiary:var(--color-text-muted);--color-border:var(--neutral-800);--color-border-subtle:var(--neutral-900);--color-border-emphasis:var(--neutral-700);--color-border-dark:var(--neutral-600);--color-bg-secondary:var(--color-bg-subtle);--color-bg-tertiary:var(--color-bg-muted);--color-accent:var(--neutral-50);--color-accent-subtle:hsla(0,0%,98%,.06);--color-accent-dark:var(--neutral-200);--color-primary:var(--primary-400);--color-primary-hover:var(--primary-300);--color-primary-subtle:rgba(192,132,252,.15);--color-primary-text:var(--neutral-950);--shadow-xs:0 1px 2px rgba(0,0,0,.2);--shadow-sm:0 1px 3px rgba(0,0,0,.25),0 1px 2px rgba(0,0,0,.2);--shadow-md:0 4px 6px -1px rgba(0,0,0,.3),0 2px 4px -1px rgba(0,0,0,.2);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.35),0 4px 6px -2px rgba(0,0,0,.2);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.4),0 10px 10px -5px rgba(0,0,0,.2);--shadow-2xl:0 25px 50px -12px rgba(0,0,0,.5);--ring-color:hsla(0,0%,98%,.5);--ring-offset:var(--neutral-950)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg);transition:background-color var(--duration-300) var(--ease-in-out),color var(--duration-300) var(--ease-in-out)}::-moz-selection{background-color:var(--color-accent);color:var(--color-text-inverse)}::selection{background-color:var(--color-accent);color:var(--color-text-inverse)}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);font-weight:600;line-height:var(--leading-tight);color:var(--color-text);letter-spacing:var(--tracking-tight);text-wrap:balance}h1{font-size:var(--text-5xl);font-weight:700;letter-spacing:var(--tracking-tighter);line-height:var(--leading-none);margin-bottom:var(--space-8)}h2{font-size:var(--text-3xl);margin-bottom:var(--space-6)}h3{font-size:var(--text-2xl);margin-bottom:var(--space-5)}h4{font-size:var(--text-xl)}h4,h5{margin-bottom:var(--space-4)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base);margin-bottom:var(--space-3)}p{color:var(--color-text-subtle);line-height:var(--leading-relaxed)}.heading-serif{font-family:var(--font-serif);font-weight:400;letter-spacing:var(--tracking-normal)}.lead{font-size:var(--text-xl);line-height:var(--leading-relaxed);color:var(--color-text-subtle)}a{color:var(--color-text);text-decoration:none;transition:color var(--duration-150) var(--ease-out),opacity var(--duration-150) var(--ease-out)}a:hover{opacity:.7}a:focus-visible{outline:2px solid var(--ring-color);outline-offset:2px;border-radius:var(--radius-sm)}b,strong{font-weight:600;color:var(--color-text)}em,i{font-style:italic}code{font-size:.875em;background-color:var(--color-bg-muted);padding:.2em .4em;border-radius:var(--radius-md)}code,pre{font-family:var(--font-mono)}pre{font-size:var(--text-sm);background-color:var(--color-bg-subtle);padding:var(--space-6);border-radius:var(--radius-xl);overflow-x:auto;border:1px solid var(--color-border)}pre code{background:none;padding:0}blockquote{font-family:var(--font-serif);font-size:var(--text-xl);font-style:italic;border-left:2px solid var(--color-text);margin:var(--space-8) 0}blockquote,ol,ul{padding-left:var(--space-6);color:var(--color-text-subtle)}li{margin-bottom:var(--space-2);line-height:var(--leading-relaxed)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background-color:var(--color-bg-subtle);border-right:1px solid var(--color-border);display:flex;flex-direction:column;z-index:var(--z-fixed);transition:transform var(--duration-300) var(--ease-in-out)}.sidebar-header{padding:var(--space-8) var(--space-6);border-bottom:1px solid var(--color-border)}.sidebar-logo-link{display:flex;align-items:center;gap:var(--space-3)}.sidebar-logo-link:hover{opacity:1}.sidebar-logo{width:44px;height:44px;background-color:var(--color-text);color:var(--color-bg);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-base);transition:transform var(--duration-500) var(--ease-spring)}.sidebar-logo-link:hover .sidebar-logo{transform:scale(1.05)}.sidebar-identity{display:flex;flex-direction:column}.sidebar-name{font-weight:600;font-size:var(--text-base);color:var(--color-text)}.sidebar-title{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px}.sidebar-search{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border)}.search-button{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-150) var(--ease-out);color:var(--color-text-muted);font-size:var(--text-sm)}.search-button:hover{border-color:var(--color-border-emphasis);background-color:var(--color-bg-muted)}.search-button-text{flex:1;text-align:left}.search-button-kbd{font-family:var(--font-mono);font-size:var(--text-xs);padding:2px 6px;background-color:var(--color-bg-muted);border-radius:var(--radius-sm)}.sidebar-nav{flex:1;padding:var(--space-4) 0;overflow-y:auto}.sidebar-nav-list{list-style:none;padding:0;margin:0}.sidebar-nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-6);color:var(--color-text-subtle);font-size:var(--text-sm);font-weight:500;transition:all var(--duration-150) var(--ease-out);position:relative}.sidebar-nav-link:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background-color:var(--color-text);transform:scaleY(0);transition:transform var(--duration-200) var(--ease-out)}.sidebar-nav-link:hover{opacity:1}.sidebar-nav-link.active,.sidebar-nav-link:hover{color:var(--color-text);background-color:var(--color-accent-subtle)}.sidebar-nav-link.active:before{transform:scaleY(1)}.sidebar-nav-icon{display:flex;align-items:center;justify-content:center;opacity:.6;transition:opacity var(--duration-150) var(--ease-out)}.sidebar-nav-link.active .sidebar-nav-icon,.sidebar-nav-link:hover .sidebar-nav-icon{opacity:1}.sidebar-footer{padding:var(--space-6);border-top:1px solid var(--color-border)}.sidebar-footer-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.sidebar-social{display:flex;gap:var(--space-2)}.sidebar-social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--color-text-muted);border-radius:var(--radius-lg);transition:all var(--duration-150) var(--ease-out)}.sidebar-social-link:hover{color:var(--color-text);background-color:var(--color-accent-subtle);opacity:1}.sidebar-copyright,.theme-toggle{font-size:var(--text-xs);color:var(--color-text-muted)}.theme-toggle{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:none;border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-150) var(--ease-out);font-weight:500}.theme-toggle:hover{color:var(--color-text);background-color:var(--color-accent-subtle);border-color:var(--color-border-emphasis)}.theme-toggle-label{white-space:nowrap}.sidebar-mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:64px;background-color:var(--color-bg-subtle);border-bottom:1px solid var(--color-border);padding:0 var(--space-4);align-items:center;justify-content:space-between;z-index:calc(var(--z-fixed) + 1)}.sidebar-mobile-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:none;border:none;cursor:pointer;color:var(--color-text);border-radius:var(--radius-lg);transition:background-color var(--duration-150) var(--ease-out)}.sidebar-mobile-toggle:hover{background-color:var(--color-accent-subtle)}.sidebar-mobile-overlay{display:none;position:fixed;inset:0;background-color:rgba(0,0,0,.5);z-index:calc(var(--z-fixed) - 1);backdrop-filter:blur(4px);animation:fadeIn var(--duration-200) var(--ease-out)}@media (max-width:1024px){.sidebar{transform:translateX(-100%)}.sidebar.sidebar-open{transform:translateX(0)}.sidebar-mobile-header{display:flex}.sidebar-mobile-overlay{display:block}.main-content{margin-left:0!important;padding-top:64px!important}}.floating-header{position:fixed;top:0;left:0;right:0;height:72px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-8);z-index:var(--z-fixed);pointer-events:none}.floating-header:before{content:"";position:absolute;top:0;left:0;right:0;height:120px;background:linear-gradient(180deg,hsla(0,0%,100%,.85) 0,hsla(0,0%,100%,.7) 25%,hsla(0,0%,100%,.4) 55%,hsla(0,0%,100%,0));backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);mask-image:linear-gradient(180deg,#000 0,#000 50%,transparent);-webkit-mask-image:linear-gradient(180deg,#000 0,#000 50%,transparent);pointer-events:none;z-index:-1}[data-theme=dark] .floating-header:before{background:linear-gradient(180deg,hsla(0,0%,4%,.85) 0,hsla(0,0%,4%,.7) 25%,hsla(0,0%,4%,.4) 55%,hsla(0,0%,4%,0))}.floating-header>*{pointer-events:auto}.header-brand{display:flex;align-items:center;gap:var(--space-3);transition:opacity var(--duration-200) var(--ease-out)}.header-brand:hover{opacity:.7}.header-logo{flex-shrink:0}.header-name{font-size:var(--text-lg);font-weight:600;color:var(--color-text);letter-spacing:var(--tracking-tight)}.header-social{display:flex;align-items:center;gap:var(--space-1)}.header-social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;color:var(--color-text-muted);border-radius:var(--radius-lg);transition:all var(--duration-200) var(--ease-out)}.header-social-link:hover{color:var(--color-text);background:linear-gradient(135deg,hsla(0,0%,100%,.1),hsla(0,0%,100%,.03));box-shadow:0 0 20px hsla(0,0%,100%,.05),inset 0 1px 0 hsla(0,0%,100%,.1);opacity:1}[data-theme=light] .header-social-link:hover{background:linear-gradient(135deg,rgba(0,0,0,.06),rgba(0,0,0,.02));box-shadow:0 0 20px rgba(0,0,0,.03),inset 0 1px 0 hsla(0,0%,100%,.5)}.floating-sidebar{position:fixed;left:0;top:50%;transform:translateY(-50%);width:200px;display:flex;flex-direction:column;padding:var(--space-8);z-index:var(--z-fixed);background:transparent;pointer-events:none}.floating-nav,.floating-sidebar>*{pointer-events:auto}.floating-nav{flex:0 0 auto}.floating-nav-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-1)}.floating-nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-lg);transition:color .25s var(--ease-spring),transform .25s var(--ease-spring);position:relative;background:transparent}.floating-nav-link:hover{transform:translateX(6px);opacity:1}.floating-nav-link.active,.floating-nav-link.active .floating-nav-icon,.floating-nav-link:hover,.floating-nav-link:hover .floating-nav-icon{color:var(--color-purple)}.floating-nav-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-text-muted);transition:color .25s var(--ease-spring)}.floating-nav-icon svg{width:18px;height:18px}.floating-nav-label{transition:color .25s var(--ease-spring)}.floating-sidebar-footer{margin-top:var(--space-6)}.theme-toggle-fixed{display:none}@media (min-width:641px){.theme-toggle-fixed{display:block;position:fixed;bottom:var(--space-6);left:var(--space-6);z-index:var(--z-fixed)}}.mobile-dropdown{display:none}.mobile-dropdown-trigger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--duration-150) var(--ease-out)}.mobile-dropdown-trigger:hover{border-color:var(--color-border-emphasis);background-color:var(--color-accent-subtle)}.dropdown-chevron{transition:transform var(--duration-200) var(--ease-out)}.dropdown-chevron.open{transform:rotate(180deg)}.mobile-dropdown-menu{position:absolute;top:calc(100% + var(--space-2));left:0;min-width:200px;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-2);z-index:var(--z-dropdown);animation:dropdownFadeIn .15s var(--ease-out)}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.mobile-dropdown-list{list-style:none;margin:0;padding:0}.mobile-dropdown-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:var(--color-text-subtle);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-lg);transition:all var(--duration-150) var(--ease-out)}.mobile-dropdown-link:hover{color:var(--color-text);background-color:var(--color-accent-subtle);opacity:1}.mobile-dropdown-link.active{color:var(--color-purple);background-color:rgba(139,92,246,.1)}.mobile-dropdown-icon{display:flex;align-items:center;color:inherit}.mobile-dropdown-icon svg{width:18px;height:18px}.mobile-dropdown-check{margin-left:auto;color:var(--color-purple)}.mobile-dropdown-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border);margin-top:var(--space-2)}.mobile-menu-toggle{display:flex;position:fixed;left:var(--space-6);top:50%;transform:translateY(-50%);width:44px;height:44px;background:transparent;border:none;cursor:pointer;color:var(--color-text-muted);z-index:calc(var(--z-fixed) + 1);border-radius:var(--radius-lg);align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s var(--ease-out),visibility .3s var(--ease-out),color var(--duration-200) var(--ease-out)}.mobile-menu-toggle:hover{color:var(--color-purple)}@keyframes sidebarOpen{0%{opacity:0;transform:translateY(-50%) translateX(-20px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}@keyframes sidebarClose{0%{opacity:1;transform:translateY(-50%) translateX(0)}to{opacity:0;transform:translateY(-50%) translateX(-20px)}}.floating-sidebar.mobile-menu-expanded.opening{animation:sidebarOpen .3s var(--ease-spring) forwards}.floating-sidebar.mobile-menu-expanded.closing{animation:sidebarClose .25s var(--ease-out) forwards}@keyframes slideInBounce{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes slideOutLeft{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(-20px)}}.floating-nav-item.slide-in{animation:slideInBounce .3s var(--ease-spring) forwards;opacity:0}.floating-nav-item.slide-out{animation:slideOutLeft .25s var(--ease-out) forwards}.mobile-menu-expanded .floating-nav,.mobile-menu-expanded .floating-nav-item,.mobile-menu-expanded .floating-nav-list{width:100%}.mobile-menu-expanded .floating-nav-link{width:100%;box-sizing:border-box;padding-left:var(--space-4);margin-left:calc(-1 * var(--space-2));padding-right:var(--space-6)}.mobile-menu-expanded .floating-nav-link:hover{color:var(--color-purple);transform:translateX(6px)}.mobile-menu-expanded .floating-nav-link:hover .floating-nav-icon{color:var(--color-purple)}.layout-wrapper{display:flex;min-height:100vh;padding:0}.main-content{flex:1;min-height:100vh;margin-left:220px;margin-right:80px;padding-top:72px;padding-left:0;transition:margin .4s cubic-bezier(.4,0,.2,1),padding .4s cubic-bezier(.4,0,.2,1),transform .4s cubic-bezier(.4,0,.2,1)}.mobile-dropdown,.mobile-menu-expanded,.mobile-menu-toggle{display:none}.floating-sidebar.desktop-sidebar{display:flex;opacity:1;transform:translateY(-50%) translateX(0);transition:opacity .3s var(--ease-out),transform .3s var(--ease-out);pointer-events:auto}.floating-sidebar.desktop-sidebar .floating-nav-item{opacity:1;transform:translateX(0);transition:opacity .25s var(--ease-out),transform .25s var(--ease-out)}.floating-sidebar.desktop-sidebar .floating-nav-item:first-child{transition-delay:0ms}.floating-sidebar.desktop-sidebar .floating-nav-item:nth-child(2){transition-delay:30ms}.floating-sidebar.desktop-sidebar .floating-nav-item:nth-child(3){transition-delay:60ms}.floating-sidebar.desktop-sidebar .floating-nav-item:nth-child(4){transition-delay:90ms}.floating-sidebar.desktop-sidebar .floating-nav-item:nth-child(5){transition-delay:.12s}@media (max-width:1280px){.main-content{margin-left:200px;margin-right:40px}}@media (max-width:1024px) and (min-width:641px){.floating-sidebar.desktop-sidebar{display:none}.mobile-menu-toggle.desktop-narrow-only{display:flex;opacity:1;visibility:visible}.floating-sidebar.mobile-menu-expanded{display:flex;flex-direction:column;position:fixed;left:56px;top:50%;transform:translateY(-50%);width:auto;min-width:160px;min-height:280px;padding:var(--space-4);z-index:var(--z-fixed);pointer-events:auto}.main-content{margin-left:0;margin-right:24px;padding-left:56px}body.menu-open .main-content{transform:translateX(180px)}.theme-toggle-fixed{display:none}}@media (max-width:640px){.floating-header{padding:0 var(--space-4);height:64px}.header-name{font-size:var(--text-base)}.floating-sidebar.desktop-sidebar{display:none}.hero{margin-left:0}}@media (max-width:640px) and (hover:none),(max-width:640px) and (pointer:coarse){.mobile-dropdown.touch-only{display:block;position:fixed;top:var(--space-4);left:var(--space-4);right:var(--space-4);z-index:var(--z-fixed);margin-left:140px;margin-right:0;width:auto}.header-brand{max-width:130px;flex-shrink:0}.header-logo{width:20px;height:22px}.header-name{font-size:var(--text-sm)}.mobile-menu-toggle.desktop-narrow-only{display:none}.main-content{margin-left:0;margin-right:0;padding-top:72px}.theme-toggle-fixed{display:none}}@media (max-width:640px) and (hover:hover) and (pointer:fine){.mobile-dropdown.touch-only{display:none}.mobile-menu-toggle.desktop-narrow-only{display:flex;opacity:1;visibility:visible}.floating-sidebar.mobile-menu-expanded{display:flex;flex-direction:column;position:fixed;left:56px;top:50%;transform:translateY(-50%);width:auto;min-width:160px;min-height:280px;padding:var(--space-4);z-index:var(--z-fixed);pointer-events:auto}.main-content{margin-left:0;margin-right:0;padding-top:72px;padding-left:56px}body.menu-open .main-content{transform:translateX(180px)}}.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--space-6)}@media (min-width:641px){.container{padding:0 var(--space-12)}}@media (min-width:1280px){.container{padding:0 var(--space-16)}}.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 var(--space-6)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--duration-700) var(--ease-in-out) forwards}.animate-fade-in-up{animation:fadeInUp var(--duration-700) var(--ease-in-out) forwards}.animate-scale-in{animation:scaleIn var(--duration-500) var(--ease-in-out) forwards}.stagger-1{animation-delay:.08s;opacity:0}.stagger-2{animation-delay:.16s;opacity:0}.stagger-3{animation-delay:.24s;opacity:0}.stagger-4{animation-delay:.32s;opacity:0}.stagger-5{animation-delay:.4s;opacity:0}.page-content{animation:fadeInUp var(--duration-700) var(--ease-in-out) forwards}.page-top-spacing{padding-top:var(--space-8)}@media (min-width:768px){.page-top-spacing{padding-top:var(--space-12)}}.card{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--duration-200) var(--ease-out)}.card:hover{border-color:var(--color-border-emphasis);box-shadow:var(--shadow-lg)}.content-card{display:block;position:relative;border-radius:var(--radius-2xl);overflow:hidden;background-color:var(--color-bg-subtle);border:1px solid var(--color-border-subtle);transition:all var(--duration-300) var(--ease-out)}.content-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--color-border);opacity:1}.content-card-image{width:100%;aspect-ratio:16/10;-o-object-fit:cover;object-fit:cover;transition:transform var(--duration-700) var(--ease-out)}.content-card:hover .content-card-image{transform:scale(1.02)}.content-card-content{padding:var(--space-6)}.content-card-title{font-size:var(--text-xl);font-weight:600;margin-bottom:var(--space-4);color:var(--color-text)}.content-card-excerpt{color:var(--color-text-subtle);font-size:var(--text-sm);line-height:var(--leading-relaxed);margin-bottom:var(--space-5);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.content-card-meta{display:flex;align-items:center;gap:var(--space-4);font-size:var(--text-xs);color:var(--color-text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-lg);transition:all var(--duration-150) var(--ease-out);cursor:pointer;border:none;text-decoration:none}.btn-primary{background-color:var(--color-primary);color:var(--color-primary-text);border-color:var(--color-primary)}.btn-primary:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover);transform:translateY(-1px);opacity:1}.btn-secondary{background-color:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-accent-subtle);border-color:var(--color-border-emphasis)}.btn-ghost{background-color:transparent;color:var(--color-text-subtle);padding:var(--space-2) var(--space-4)}.btn-ghost:hover{color:var(--color-text);background-color:var(--color-accent-subtle)}.tag{display:inline-flex;padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:500;background-color:var(--color-bg-muted);color:var(--color-text-subtle);border-radius:var(--radius-full);transition:all var(--duration-150) var(--ease-out)}.tag:hover{background-color:var(--color-text);color:var(--color-bg);opacity:1}.divider{height:1px;background-color:var(--color-border);margin:var(--space-12) 0}.hero{padding:var(--space-20) 0 var(--space-24);min-height:75vh;display:flex;flex-direction:column;justify-content:center}.hero-greeting{font-size:var(--text-sm);font-weight:500;color:var(--color-text-muted);margin-bottom:var(--space-4);letter-spacing:var(--tracking-widest);text-transform:uppercase}.hero-name{color:var(--color-purple);font-weight:700}.hero-title{font-size:var(--text-6xl);font-weight:700;letter-spacing:var(--tracking-tighter);line-height:var(--leading-none);margin-bottom:var(--space-10)}.hero-subtitle{font-size:var(--text-xl);color:var(--color-text-subtle);max-width:36rem;line-height:var(--leading-relaxed);margin-bottom:var(--space-12)}.hero-cta{display:flex;flex-wrap:wrap;gap:var(--space-4)}.hero-content{display:flex;flex-direction:column;gap:var(--space-12)}@media (min-width:768px){.hero-content{flex-direction:row;align-items:center;justify-content:space-between;gap:var(--space-16)}}.hero-text{flex:1;max-width:36rem}.hero-portrait{display:flex;justify-content:center;order:-1}@media (min-width:768px){.hero-portrait{order:0;flex-shrink:0}}.hero-portrait-image{width:280px;height:350px;-o-object-fit:cover;object-fit:cover;-o-object-position:center top;object-position:center top;border-radius:var(--radius-2xl);filter:grayscale(100%);transition:filter var(--duration-300) var(--ease-out)}@media (min-width:768px){.hero-portrait-image{width:320px;height:400px}}@media (min-width:1024px){.hero-portrait-image{width:360px;height:450px}}.hero-portrait:hover .hero-portrait-image{filter:grayscale(0)}.search-modal-overlay{position:fixed;inset:0;background-color:rgba(0,0,0,.6);backdrop-filter:blur(8px);z-index:var(--z-modal-backdrop);display:flex;align-items:flex-start;justify-content:center;padding:12vh var(--space-4) var(--space-4);animation:fadeIn var(--duration-150) var(--ease-out)}.search-modal{width:100%;max-width:560px;background-color:var(--color-bg);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);overflow:hidden;animation:scaleIn var(--duration-200) var(--ease-out);border:1px solid var(--color-border)}.search-input-wrapper{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border)}.search-icon{color:var(--color-text-muted);flex-shrink:0}.search-input{flex:1;background:none;border:none;font-size:var(--text-lg);color:var(--color-text);outline:none;font-family:var(--font-sans)}.search-input::-moz-placeholder{color:var(--color-text-muted)}.search-input::placeholder{color:var(--color-text-muted)}.search-kbd{font-family:var(--font-mono);font-size:var(--text-xs);padding:4px 8px;background-color:var(--color-bg-muted);border-radius:var(--radius-md);color:var(--color-text-muted)}.search-results{max-height:360px;overflow-y:auto;padding:var(--space-2)}.search-result{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);transition:background-color var(--duration-100) var(--ease-out);cursor:pointer}.search-result.selected,.search-result:hover{background-color:var(--color-accent-subtle);opacity:1}.search-result-type{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:var(--color-bg-muted);border-radius:var(--radius-lg);color:var(--color-text-muted);flex-shrink:0}.search-result-content{flex:1;min-width:0}.search-result-title{font-weight:500;color:var(--color-text);font-size:var(--text-sm)}.search-result-excerpt{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-arrow{color:var(--color-text-muted);opacity:0;transition:opacity var(--duration-150) var(--ease-out)}.search-result.selected .search-result-arrow,.search-result:hover .search-result-arrow{opacity:1}.search-hints,.search-no-results{padding:var(--space-10) var(--space-6);text-align:center;color:var(--color-text-muted)}.search-hint-keys{display:flex;justify-content:center;gap:var(--space-6);margin-top:var(--space-4);font-size:var(--text-xs)}.search-hint-keys kbd{font-family:var(--font-mono);padding:2px 6px;background-color:var(--color-bg-muted);border-radius:var(--radius-sm);margin-right:4px}.about-header{display:grid;grid-template-columns:1fr;gap:var(--space-10);margin-bottom:var(--space-16)}@media (min-width:768px){.about-header{grid-template-columns:160px 1fr;align-items:start;gap:var(--space-12)}}.about-avatar{width:160px;height:160px;border-radius:var(--radius-2xl);background-color:var(--color-bg-muted);align-items:center;font-family:var(--font-serif);font-size:var(--text-5xl);color:var(--color-text-muted)}.about-avatar,.about-portrait{display:flex;justify-content:center}.about-portrait-image{width:160px;height:200px;-o-object-fit:cover;object-fit:cover;-o-object-position:center top;object-position:center top;border-radius:var(--radius-2xl);filter:grayscale(100%);transition:filter var(--duration-300) var(--ease-out)}.about-portrait:hover .about-portrait-image{filter:grayscale(0)}.about-intro h1{margin-bottom:var(--space-6)}.about-intro .lead{margin-bottom:var(--space-8)}.about-section{margin-bottom:var(--space-16)}.about-section h2{font-size:var(--text-2xl);margin-bottom:var(--space-8)}.experience-item{padding:var(--space-6) 0;border-bottom:1px solid var(--color-border)}.experience-item:last-child{border-bottom:none}.experience-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-2)}.experience-title{font-weight:600;font-size:var(--text-lg);color:var(--color-text)}.experience-period{font-size:var(--text-sm);color:var(--color-text-muted)}.experience-company{margin-bottom:var(--space-3)}.experience-company,.experience-description{font-size:var(--text-sm);color:var(--color-text-subtle)}.experience-description{line-height:var(--leading-relaxed)}.cta-section{background:var(--color-surface);border:1px solid var(--color-border)}.content-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8)}@media (min-width:768px){.content-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1280px){.content-grid{gap:var(--space-10)}}.featured-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8)}@media (min-width:768px){.featured-grid{grid-template-columns:repeat(2,1fr)}}.section-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--space-10);padding-bottom:var(--space-5);border-bottom:1px solid var(--color-border)}.section-title{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-widest);color:var(--color-text-muted)}.section-link{font-size:var(--text-sm);font-weight:500;color:var(--color-text-subtle);display:flex;align-items:center;gap:var(--space-2)}.section-link:hover{color:var(--color-text);opacity:1}.prose{max-width:var(--content-max);line-height:var(--leading-relaxed)}.prose>*+*{margin-top:var(--space-8)}.prose h2,.prose h3,.prose h4{margin-top:var(--space-14);margin-bottom:var(--space-6)}.prose img{border-radius:var(--radius-2xl);margin:var(--space-10) 0}.prose hr{border:none;height:1px;background-color:var(--color-border);margin:var(--space-12) 0}.prose a{text-decoration:underline;text-underline-offset:2px}.prose a:hover{opacity:.7}.skip-to-main{position:absolute;left:-9999px;top:0;z-index:9999;padding:var(--space-4);background-color:var(--color-text);color:var(--color-bg);font-weight:500}.skip-to-main:focus{left:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.focus-ring:focus-visible{outline:2px solid var(--ring-color);outline-offset:2px;border-radius:var(--radius-sm)}.text-balance{text-wrap:balance}.contact-btn{display:inline-flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);font-size:var(--text-base);font-weight:500;background-color:var(--color-bg-subtle);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:background-color var(--duration-200) var(--ease-out),border-color var(--duration-200) var(--ease-out),transform var(--duration-200) var(--ease-spring),box-shadow var(--duration-200) var(--ease-out);cursor:pointer;text-decoration:none}.contact-btn:hover{background-color:var(--color-bg-muted);border-color:var(--color-purple);color:var(--color-purple);transform:translateY(-2px);box-shadow:var(--shadow-md);opacity:1}.contact-btn svg{transition:color var(--duration-200) var(--ease-out)}.contact-btn:hover svg{color:var(--color-purple)}.location-map-container{width:100%}.location-map{position:relative;width:100%;height:300px;border-radius:var(--radius-2xl);overflow:hidden;background-color:var(--color-bg-muted)}.location-map-iframe{width:100%;height:100%;border:none;filter:grayscale(100%) contrast(.9);opacity:.7}[data-theme=dark] .location-map-iframe{filter:grayscale(100%) contrast(.9) invert(1);opacity:.5}.location-map-overlay{position:absolute;inset:0;pointer-events:none}.location-circle,.location-map-overlay{display:flex;align-items:center;justify-content:center}.location-circle{width:180px;height:180px;border-radius:50%;background-color:rgba(139,92,246,.15);border:2px solid var(--color-purple);animation:pulse-ring 3s ease-in-out infinite}.location-circle-inner{width:12px;height:12px;border-radius:50%;background-color:var(--color-purple);box-shadow:0 0 20px rgba(139,92,246,.5)}@keyframes pulse-ring{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}@media (min-width:641px){.location-map{height:350px}.location-circle{width:220px;height:220px}}.case-study-card{display:block;position:relative;border-radius:var(--radius-2xl);overflow:hidden;background-color:var(--color-bg-subtle);border:1px solid var(--color-border-subtle);transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .4s cubic-bezier(.34,1.56,.64,1),border-color var(--duration-300) var(--ease-out)}.case-study-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-2xl);border-color:var(--color-border);opacity:1}.case-study-images{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1);padding:var(--space-1);background-color:var(--color-bg-muted)}.case-study-image-container{position:relative;overflow:hidden;border-radius:var(--radius-xl)}.case-study-image-label{position:absolute;top:var(--space-3);left:var(--space-3);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-wide);background-color:rgba(0,0,0,.6);color:#fff;border-radius:var(--radius-md);z-index:1;backdrop-filter:blur(4px)}.case-study-image{width:100%;aspect-ratio:4/3;-o-object-fit:cover;object-fit:cover;transition:transform var(--duration-700) var(--ease-out)}.case-study-image-before{filter:grayscale(40%) brightness(.95)}.case-study-card:hover .case-study-image{transform:scale(1.03)}.case-study-cover{overflow:hidden}.case-study-cover-image{width:100%;aspect-ratio:16/9;-o-object-fit:cover;object-fit:cover;transition:transform var(--duration-700) var(--ease-out)}.case-study-card:hover .case-study-cover-image{transform:scale(1.03)}.case-study-content{padding:var(--space-8)}.case-study-subtitle{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);font-size:var(--text-sm);margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-weight:500}.case-study-subtitle,.case-study-subtitle-separator{color:var(--color-text-muted)}.case-study-title{font-size:var(--text-2xl);font-weight:600;color:var(--color-text);margin-bottom:var(--space-6);line-height:var(--leading-snug)}.case-study-excerpt{font-size:var(--text-base);color:var(--color-text-subtle);line-height:var(--leading-relaxed);margin-bottom:var(--space-8)}.case-study-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);list-style:none;padding:0;margin:0}.case-study-grid{display:flex;flex-direction:column;gap:var(--space-10)}@media (max-width:640px){.case-study-images{grid-template-columns:1fr}.case-study-content{padding:var(--space-6)}.case-study-title{font-size:var(--text-xl)}.case-study-excerpt{font-size:var(--text-sm)}}.case-study-page{animation:fadeIn var(--duration-500) var(--ease-out) forwards}.case-study-hero{width:100%;margin-bottom:var(--space-8);background-color:var(--color-bg-muted)}.case-study-hero-cover{width:100%;height:auto;max-height:70vh;-o-object-fit:cover;object-fit:cover}.case-study-hero-comparison{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1);padding:var(--space-1)}.case-study-hero-image-wrapper{position:relative;overflow:hidden}.case-study-hero-label{position:absolute;top:var(--space-4);left:var(--space-4);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-wide);background-color:rgba(0,0,0,.7);color:#fff;border-radius:var(--radius-lg);z-index:1;backdrop-filter:blur(8px)}.case-study-hero-image{width:100%;height:auto;max-height:60vh;-o-object-fit:cover;object-fit:cover}.case-study-hero-image-before{filter:grayscale(40%) brightness(.95)}.case-study-page-subtitle{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-weight:500}@media (max-width:768px){.case-study-hero-comparison{grid-template-columns:1fr}.case-study-hero-image{max-height:40vh}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.writing-page{max-width:900px;overflow-x:hidden}.writing-header{margin-bottom:var(--space-12)}.writing-header h1{margin-bottom:var(--space-4)}.writing-subtitle{font-size:var(--text-xl);color:var(--color-text-subtle);max-width:36rem;line-height:var(--leading-relaxed)}.writing-hero{margin-bottom:var(--space-16)}.writing-hero-card{display:block;position:relative;border-radius:var(--radius-2xl);overflow:hidden;background-color:var(--color-bg-subtle);border:1px solid var(--color-border-subtle);transition:all var(--duration-300) var(--ease-out)}.writing-hero-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--color-border);opacity:1}.writing-hero-image-container{position:relative;overflow:hidden}.writing-hero-image{width:100%;aspect-ratio:16/9;-o-object-fit:cover;object-fit:cover;transition:transform var(--duration-700) var(--ease-out)}.writing-hero-card:hover .writing-hero-image{transform:scale(1.02)}.writing-hero-badge{position:absolute;top:var(--space-4);left:var(--space-4);padding:var(--space-1-5) var(--space-4);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-wide);background-color:var(--color-purple);color:#fff;border-radius:var(--radius-full)}.writing-hero-content{padding:var(--space-8)}.writing-hero-title{font-size:var(--text-3xl);font-weight:600;color:var(--color-text);margin-bottom:var(--space-4);line-height:var(--leading-snug)}.writing-hero-excerpt{font-size:var(--text-lg);color:var(--color-text-subtle);line-height:var(--leading-relaxed);margin-bottom:var(--space-6)}.writing-hero-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm)}.writing-hero-meta,.writing-meta-separator{color:var(--color-text-muted)}.writing-section{margin-bottom:var(--space-16)}.writing-section-header{margin-bottom:var(--space-6);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.writing-section-title{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-widest);color:var(--color-text-muted)}.writing-pinned-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-6)}.writing-pinned-card{display:block;border-radius:var(--radius-xl);overflow:hidden;background-color:var(--color-bg-subtle);border:1px solid var(--color-border-subtle);transition:all var(--duration-300) var(--ease-out)}.writing-pinned-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--color-border);opacity:1}.writing-pinned-image-container{overflow:hidden}.writing-pinned-image{width:100%;aspect-ratio:16/10;-o-object-fit:cover;object-fit:cover;transition:transform var(--duration-500) var(--ease-out)}.writing-pinned-card:hover .writing-pinned-image{transform:scale(1.03)}.writing-pinned-content{padding:var(--space-5)}.writing-pinned-title{font-size:var(--text-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--space-2);line-height:var(--leading-snug)}.writing-pinned-excerpt{font-size:var(--text-sm);color:var(--color-text-subtle);line-height:var(--leading-relaxed);margin-bottom:var(--space-4);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.writing-pinned-meta{font-size:var(--text-xs);color:var(--color-text-muted)}.writing-list-section{margin-bottom:var(--space-16)}.writing-list-toolbar{position:sticky;top:72px;z-index:var(--z-sticky);background-color:var(--color-bg);padding:var(--space-4) 0;margin-bottom:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.writing-list-toolbar:before{content:"";position:absolute;top:calc(-1 * var(--space-4));left:calc(-1 * var(--space-6));right:calc(-1 * var(--space-6));bottom:0;background:linear-gradient(to bottom,var(--color-bg) 0,var(--color-bg) 70%,hsla(0,0%,100%,0) 100%);z-index:-1;pointer-events:none}[data-theme=dark] .writing-list-toolbar:before{background:linear-gradient(to bottom,var(--color-bg) 0,var(--color-bg) 70%,hsla(0,0%,4%,0) 100%)}.writing-list-toolbar-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.writing-search{position:relative;display:flex;align-items:center;flex:1;max-width:280px}.writing-search-icon{position:absolute;left:var(--space-3);color:var(--color-text-muted);pointer-events:none}.writing-search-input{width:100%;padding:var(--space-2) var(--space-10);font-size:var(--text-sm);font-family:var(--font-sans);background-color:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);outline:none;transition:all var(--duration-150) var(--ease-out)}.writing-search-input::-moz-placeholder{color:var(--color-text-muted)}.writing-search-input::placeholder{color:var(--color-text-muted)}.writing-search-input:focus{border-color:var(--color-purple);box-shadow:0 0 0 3px var(--color-primary-subtle)}.writing-search-clear{position:absolute;right:var(--space-2);display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:none;border:none;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-md);transition:all var(--duration-150) var(--ease-out)}.writing-search-clear:hover{color:var(--color-text);background-color:var(--color-bg-muted)}.writing-filters{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.writing-filter-tag{padding:var(--space-1-5) var(--space-4);font-size:var(--text-xs);font-weight:500;background-color:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-subtle);cursor:pointer;transition:all var(--duration-150) var(--ease-out)}.writing-filter-tag:hover{border-color:var(--color-border-emphasis);color:var(--color-text)}.writing-filter-tag.active{background-color:var(--color-purple);border-color:var(--color-purple);color:#fff}.writing-sort{display:flex;align-items:center;gap:var(--space-2)}.writing-sort-label{font-size:var(--text-sm);color:var(--color-text-muted)}.writing-sort-select{padding:var(--space-2) var(--space-8) var(--space-2) var(--space-3);font-size:var(--text-sm);font-family:var(--font-sans);background-color:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);cursor:pointer;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23737373' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-2) center;transition:all var(--duration-150) var(--ease-out)}.writing-sort-select:hover{border-color:var(--color-border-emphasis)}.writing-sort-select:focus{border-color:var(--color-purple);box-shadow:0 0 0 3px var(--color-primary-subtle)}.writing-active-filters{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;padding-top:var(--space-2);border-top:1px solid var(--color-border-subtle)}.writing-active-filters-label{font-size:var(--text-xs);color:var(--color-text-muted)}.writing-active-filter{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2) var(--space-1) var(--space-3);font-size:var(--text-xs);background-color:var(--color-primary-subtle);color:var(--color-purple);border-radius:var(--radius-full)}.writing-active-filter button{display:flex;align-items:center;justify-content:center;width:16px;height:16px;background:none;border:none;color:inherit;cursor:pointer;border-radius:50%;font-size:var(--text-sm);transition:background-color var(--duration-100) var(--ease-out)}.writing-active-filter button:hover{background-color:rgba(139,92,246,.2)}.writing-clear-filters{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:500;background:none;border:none;color:var(--color-purple);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.writing-clear-filters:hover{color:var(--color-primary-hover)}.writing-no-results{text-align:center;padding:var(--space-12) 0}.writing-no-results p{margin-bottom:var(--space-4)}.writing-list{display:flex;flex-direction:column}.writing-list-item{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-8);padding:var(--space-6) 0;border-bottom:1px solid var(--color-border-subtle);transition:all var(--duration-200) var(--ease-out)}.writing-list-item:first-child{padding-top:0}.writing-list-item:last-child{border-bottom:none}.writing-list-item:hover{opacity:1}.writing-list-item:hover .writing-list-title{color:var(--color-purple)}.writing-list-content{flex:1;min-width:0}.writing-list-title{font-size:var(--text-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--space-2);transition:color var(--duration-200) var(--ease-out)}.writing-list-excerpt{font-size:var(--text-sm);color:var(--color-text-subtle);line-height:var(--leading-relaxed);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.writing-list-meta{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-2);flex-shrink:0;font-size:var(--text-sm);color:var(--color-text-muted)}.writing-list-tag{font-size:var(--text-xs);padding:var(--space-1) var(--space-3);background-color:var(--color-bg-muted);border-radius:var(--radius-full)}.writing-empty{text-align:center;padding:var(--space-20) 0}.writing-empty-icon{width:64px;height:64px;margin:0 auto var(--space-6);background-color:var(--color-bg-muted);border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.writing-empty h2{font-size:var(--text-xl);margin-bottom:var(--space-2)}.writing-empty p{max-width:400px;margin:0 auto}.writing-nav{margin-top:var(--space-12);padding-top:var(--space-12);display:flex;justify-content:center}@media (max-width:768px){.writing-subtitle{font-size:var(--text-lg)}.writing-hero-content{padding:var(--space-6)}.writing-hero-title{font-size:var(--text-2xl)}.writing-section{margin-bottom:var(--space-12)}.writing-pinned-grid{grid-template-columns:1fr}}@media (max-width:640px){.writing-header{margin-bottom:var(--space-6)}.writing-header h1{font-size:var(--text-2xl)}.writing-subtitle{font-size:var(--text-sm);line-height:var(--leading-normal)}.writing-hero{margin-bottom:var(--space-6)}.writing-hero-card{border-radius:var(--radius-lg);max-width:100%;box-sizing:border-box}.writing-hero-image-container{width:100%;max-width:100%}.writing-hero-image{width:100%;height:auto;aspect-ratio:16/9;-o-object-fit:cover;object-fit:cover}.writing-hero-content{padding:var(--space-4);width:100%;box-sizing:border-box}.writing-hero-title{font-size:var(--text-lg);margin-bottom:var(--space-2)}.writing-hero-excerpt{font-size:var(--text-sm);margin-bottom:var(--space-3)}.writing-hero-badge{padding:2px var(--space-2);font-size:9px}.writing-hero-meta{font-size:var(--text-xs)}.writing-section{margin-bottom:var(--space-6)}.writing-section-header{margin-bottom:var(--space-3)}.writing-pinned-card{border-radius:var(--radius-md);max-width:100%;box-sizing:border-box}.writing-pinned-image-container{width:100%;max-width:100%}.writing-pinned-image{width:100%;height:auto;aspect-ratio:16/10;-o-object-fit:cover;object-fit:cover}.writing-pinned-content{padding:var(--space-3);width:100%;box-sizing:border-box}.writing-pinned-title{font-size:var(--text-sm);margin-bottom:var(--space-1)}.writing-pinned-excerpt{-webkit-line-clamp:2}.writing-pinned-excerpt,.writing-pinned-meta{font-size:var(--text-xs)}.writing-list-section{margin-bottom:var(--space-6)}.writing-list-toolbar{top:56px;padding:var(--space-2) 0;gap:var(--space-2)}.writing-list-toolbar-row{flex-direction:column;align-items:stretch;gap:var(--space-2)}.writing-list-toolbar-row:first-child{flex-direction:row;align-items:center}.writing-section-title{font-size:9px}.writing-search{max-width:none;flex:1}.writing-search-input{font-size:16px;padding:var(--space-2) var(--space-3);padding-left:var(--space-8)}.writing-filters{overflow-x:auto;flex-wrap:nowrap;padding-bottom:var(--space-1);margin:0 calc(-1 * var(--space-4));padding-left:var(--space-4);padding-right:var(--space-4);-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;gap:var(--space-1-5)}.writing-filters::-webkit-scrollbar{display:none}.writing-filter-tag{flex-shrink:0;padding:var(--space-1-5) var(--space-3);font-size:var(--text-xs)}.writing-sort{width:100%;justify-content:space-between}.writing-sort-label{font-size:var(--text-xs)}.writing-sort-select{flex:1;max-width:140px;font-size:16px;padding:var(--space-1-5) var(--space-2)}.writing-active-filters{padding-top:var(--space-2);font-size:var(--text-xs)}.writing-active-filter{padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}.writing-list-item{flex-direction:row;justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) 0}.writing-list-title{font-size:var(--text-sm);margin-bottom:0}.writing-list-excerpt{display:none}.writing-list-meta{flex-direction:column;align-items:flex-end;gap:var(--space-1);font-size:10px}.writing-list-tag{font-size:9px;padding:2px var(--space-2)}.writing-empty{padding:var(--space-8) 0}.writing-empty-icon{width:40px;height:40px}.writing-empty h2{font-size:var(--text-base)}.writing-empty p{font-size:var(--text-sm)}.writing-nav{margin-top:var(--space-6);padding-top:var(--space-6)}.writing-no-results{padding:var(--space-6) 0}}@media (max-width:380px){.writing-header h1{font-size:var(--text-xl)}.writing-subtitle{font-size:var(--text-xs)}.writing-hero-title{font-size:var(--text-base)}.writing-hero-excerpt{display:none}.writing-hero-content{padding:var(--space-3)}.writing-list-toolbar-row:first-child{flex-direction:column;align-items:stretch}.writing-section-title{text-align:center;width:100%}.writing-search{order:-1}.writing-list-item{padding:var(--space-2) 0}.writing-list-title{font-size:var(--text-xs)}.writing-sort{justify-content:center}.writing-sort-select{max-width:none;width:100%}.writing-pinned-grid{gap:var(--space-3)}}.reading-panel-overlay{position:fixed;inset:0;z-index:var(--z-modal-backdrop);display:flex;justify-content:flex-end;animation:fadeIn var(--duration-200) var(--ease-out)}.reading-panel-overlay:before{content:"";position:absolute;inset:0;background-color:rgba(0,0,0,.5);backdrop-filter:blur(4px)}.reading-panel{position:relative;width:85%;height:100%;background-color:var(--color-bg);box-shadow:var(--shadow-2xl);display:flex;flex-direction:column;animation:slideInRight var(--duration-300) var(--ease-out)}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}@keyframes slideOutRight{0%{transform:translateX(0)}to{transform:translateX(100%)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.reading-panel-overlay.closing{animation:fadeOut var(--duration-500) var(--ease-out) forwards}.reading-panel-overlay.closing .reading-panel{animation:slideOutRight var(--duration-500) var(--ease-in-out) forwards}.reading-panel-header{position:absolute;top:0;left:0;right:0;z-index:10;padding:var(--space-4) var(--space-6);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);min-height:72px;pointer-events:none}.reading-panel-header>*{pointer-events:auto}.reading-panel-header:before{content:"";position:absolute;top:0;left:0;right:0;height:120px;background:linear-gradient(180deg,hsla(0,0%,100%,.95) 0,hsla(0,0%,100%,.85) 30%,hsla(0,0%,100%,.5) 60%,hsla(0,0%,100%,0));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);mask-image:linear-gradient(180deg,#000 0,#000 40%,transparent);-webkit-mask-image:linear-gradient(180deg,#000 0,#000 40%,transparent);pointer-events:none;z-index:-1}[data-theme=dark] .reading-panel-header:before{background:linear-gradient(180deg,hsla(0,0%,4%,.95) 0,hsla(0,0%,4%,.85) 30%,hsla(0,0%,4%,.5) 60%,hsla(0,0%,4%,0))}.reading-panel-header-title{flex:1;font-size:var(--text-base);font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.reading-panel-close-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:none;border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-150) var(--ease-out);flex-shrink:0}.reading-panel-close-btn:hover{color:var(--color-text);background-color:var(--color-accent-subtle);border-color:var(--color-border-emphasis)}.reading-panel-content{flex:1;overflow-y:auto;overscroll-behavior:contain;padding-top:72px;padding-bottom:100px;position:relative}.reading-progress-bar{position:fixed;right:24px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:5}.reading-progress-line{width:12px;height:2px;background-color:var(--color-border);border-radius:1px;transition:all var(--duration-200) var(--ease-out)}.reading-progress-line.active,.reading-progress-line.past{width:16px;background-color:var(--color-purple)}.reading-progress-line.active{box-shadow:0 0 8px rgba(139,92,246,.4)}.reading-panel-article{max-width:720px;margin:0 auto;padding:var(--space-4) var(--space-6) var(--space-8)}.reading-panel-cover{margin:0 calc(-1 * var(--space-6)) var(--space-8);overflow:hidden}.reading-panel-cover-image{width:100%;height:auto;max-height:400px;-o-object-fit:cover;object-fit:cover}.reading-panel-body{padding:0}.reading-panel-article-header{margin-bottom:var(--space-10)}.reading-panel-title{font-size:var(--text-4xl);font-weight:700;line-height:var(--leading-tight);margin-bottom:var(--space-4)}.reading-panel-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm)}.reading-panel-meta,.reading-panel-meta-separator{color:var(--color-text-muted)}.reading-panel-prose{max-width:none}.reading-panel-footer{position:absolute;bottom:0;left:0;right:0;z-index:10;padding:var(--space-4) var(--space-6);display:flex;justify-content:space-between;align-items:stretch;gap:var(--space-4);pointer-events:none}.reading-panel-footer>*{pointer-events:auto}.reading-panel-footer:before{content:"";position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(0deg,hsla(0,0%,100%,.95) 0,hsla(0,0%,100%,.85) 30%,hsla(0,0%,100%,.5) 60%,hsla(0,0%,100%,0));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);mask-image:linear-gradient(0deg,#000 0,#000 40%,transparent);-webkit-mask-image:linear-gradient(0deg,#000 0,#000 40%,transparent);pointer-events:none;z-index:-1}[data-theme=dark] .reading-panel-footer:before{background:linear-gradient(0deg,hsla(0,0%,4%,.95) 0,hsla(0,0%,4%,.85) 30%,hsla(0,0%,4%,.5) 60%,hsla(0,0%,4%,0))}.reading-panel-footer-btn{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);color:var(--color-text-subtle);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--duration-150) var(--ease-out);flex:1;max-width:280px}.reading-panel-footer-btn:hover:not(:disabled){color:var(--color-text);background-color:var(--color-bg-subtle);border-color:var(--color-border-emphasis);box-shadow:var(--shadow-md)}.reading-panel-footer-btn:disabled{opacity:.4;cursor:not-allowed}.reading-panel-footer-btn-prev{justify-content:flex-start}.reading-panel-footer-btn-next{justify-content:flex-end;margin-left:auto}.reading-panel-footer-btn-next.at-bottom{background-color:var(--color-purple);border-color:var(--color-purple);color:#fff}.reading-panel-footer-btn-next.at-bottom .reading-panel-footer-direction,.reading-panel-footer-btn-next.at-bottom .reading-panel-footer-title{color:#fff}.reading-panel-footer-btn-next.at-bottom:hover{background-color:var(--color-purple-dark);border-color:var(--color-purple-dark)}.reading-panel-footer-text{display:flex;flex-direction:column}.reading-panel-footer-btn-prev .reading-panel-footer-text{align-items:flex-start}.reading-panel-footer-btn-next .reading-panel-footer-text{align-items:flex-end}.reading-panel-footer-direction{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide);line-height:1;margin-bottom:var(--space-1)}.reading-panel-footer-title{font-size:var(--text-sm);font-weight:500;color:var(--color-text);white-space:nowrap;line-height:1.3}.reading-panel-footer-btn-next .reading-panel-footer-title{text-align:right}.reading-panel-footer-btn:disabled .reading-panel-footer-title{color:var(--color-text-muted)}@media (max-width:768px){.reading-panel-footer-title{display:none}.reading-panel-footer-btn{max-width:none;flex:0 0 auto;padding:var(--space-3)}.reading-panel-footer-direction{margin-bottom:0}}@media (max-width:640px){.reading-panel-overlay{display:none}}.article-page{min-height:100vh;background-color:var(--color-bg)}.article-page-header{position:fixed;top:0;left:0;right:0;z-index:var(--z-fixed);padding:var(--space-4) var(--space-6);background:linear-gradient(180deg,hsla(0,0%,100%,.9) 0,hsla(0,0%,100%,.8) 50%,hsla(0,0%,100%,0));backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}[data-theme=dark] .article-page-header{background:linear-gradient(180deg,hsla(0,0%,4%,.9) 0,hsla(0,0%,4%,.8) 50%,hsla(0,0%,4%,0))}.article-page-nav{display:flex;justify-content:center;align-items:center;gap:var(--space-2)}.article-page-close-btn,.article-page-nav-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:none;border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-subtle);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--duration-150) var(--ease-out);text-decoration:none}.article-page-close-btn:hover,.article-page-nav-btn:hover:not(:disabled){color:var(--color-text);background-color:var(--color-accent-subtle);border-color:var(--color-border-emphasis);opacity:1}.article-page-nav-btn:disabled{opacity:.4;cursor:not-allowed}.article-page-close-btn{color:var(--color-text-muted)}.article-page-close-btn:hover{color:var(--color-text);border-color:var(--color-border-emphasis)}.article-page-nav-label{display:none}@media (min-width:768px){.article-page-nav-label{display:inline}}.article-page-content{padding-top:80px}.article-page-cover{width:100%;overflow:hidden}.article-page-cover-image{width:100%;height:auto;max-height:50vh;-o-object-fit:cover;object-fit:cover}.article-page-body{max-width:720px;margin:0 auto;padding:var(--space-8) var(--space-6)}.article-page-article-header{margin-bottom:var(--space-10)}.article-page-title{font-size:var(--text-4xl);font-weight:700;line-height:var(--leading-tight);margin-bottom:var(--space-4)}.article-page-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm)}.article-page-meta,.article-page-meta-separator{color:var(--color-text-muted)}.article-page-prose{max-width:none}@media (max-width:768px){.article-page-body{padding:var(--space-6) var(--space-6)}.article-page-title{font-size:var(--text-3xl)}.article-page-cover-image{max-height:40vh}}@media (max-width:640px){.article-page-header{padding:var(--space-3) var(--space-4)}.article-page-nav{gap:var(--space-1)}.article-page-close-btn,.article-page-nav-btn{padding:var(--space-2) var(--space-2-5);gap:var(--space-1)}.article-page-close-btn svg,.article-page-nav-btn svg{width:18px;height:18px}.article-page-content{padding-top:64px}.article-page-cover-image{max-height:35vh}.article-page-body{padding:var(--space-5) var(--space-4)}.article-page-article-header{margin-bottom:var(--space-8)}.article-page-title{font-size:var(--text-2xl);margin-bottom:var(--space-3)}.article-page-meta{font-size:var(--text-xs);flex-wrap:wrap}.article-page-prose{font-size:var(--text-base)}.article-page-prose h2{font-size:var(--text-xl)}.article-page-prose h3{font-size:var(--text-lg)}.article-page-prose pre{padding:var(--space-4)}.article-page-prose img,.article-page-prose pre{margin-left:calc(-1 * var(--space-4));margin-right:calc(-1 * var(--space-4));border-radius:0}.article-page-prose img{width:calc(100% + var(--space-8));max-width:none}.article-page-prose blockquote{padding-left:var(--space-4);margin-left:0;font-size:var(--text-base)}}@media (max-width:380px){.article-page-close-btn,.article-page-nav-btn{padding:var(--space-1-5) var(--space-2)}.article-page-title{font-size:var(--text-xl)}.article-page-prose{font-size:var(--text-sm)}}.claude-code-badge{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:var(--z-fixed);display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-xs);font-weight:500;color:var(--color-text-secondary);text-decoration:none;white-space:nowrap;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-full);transition:all var(--duration-200) var(--ease-out)}.claude-code-badge:hover{color:var(--color-text);border-color:var(--color-border-emphasis);background:var(--glass-bg-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.claude-code-badge svg{flex-shrink:0}@media (max-width:640px){.claude-code-badge{bottom:var(--space-4);right:var(--space-4);padding:var(--space-2) var(--space-3);font-size:11px}.claude-code-badge svg{width:14px;height:14px}}.systems-to-clarity-hero{position:relative;width:100%;height:100vh;min-height:600px;max-height:900px;overflow:hidden;background:linear-gradient(180deg,var(--color-bg) 0,var(--color-bg-subtle) 100%)}.systems-to-clarity-canvas{position:absolute;inset:0;z-index:1}.systems-to-clarity-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;z-index:2;padding:var(--space-8);pointer-events:none}.systems-to-clarity-hook{font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-text-subtle);letter-spacing:var(--tracking-wide);margin-bottom:var(--space-6);max-width:400px}.systems-to-clarity-title{font-family:var(--font-serif);font-size:clamp(2.5rem,6vw,5rem);font-weight:400;color:var(--color-text);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);margin:0;max-width:700px}.systems-to-clarity-year{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-4);letter-spacing:var(--tracking-widest)}.pull-quote-card{position:relative;margin:var(--space-16) calc(-1 * var(--space-8));padding:var(--space-10) var(--space-8);background:var(--color-bg)}.pull-quote-card:after,.pull-quote-card:before{content:"";position:absolute;left:0;right:0;height:1px;background:var(--color-border);z-index:1}.pull-quote-card:before{top:0}.pull-quote-card:after{bottom:0}.pull-quote-canvas{position:absolute;top:0;left:0;z-index:3;pointer-events:none}.pull-quote-inner{position:relative;z-index:2}.pull-quote-content{font-family:var(--font-serif);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:400;line-height:var(--leading-snug);color:var(--color-text);letter-spacing:var(--tracking-tight);text-align:center;max-width:800px;margin:0 auto}.pull-quote-attribution{display:block;font-family:var(--font-sans);font-size:var(--text-sm);font-style:normal;color:var(--color-text-muted);text-align:center;margin-top:var(--space-4)}@media (min-width:769px){.pull-quote-card{margin-left:calc(-1 * var(--space-16));margin-right:calc(-1 * var(--space-16));padding-left:var(--space-16);padding-right:var(--space-16)}}.full-bleed-image{margin:var(--space-16) calc(-50vw + 50%);width:100vw;position:relative}.full-bleed-image-container{position:relative;width:100%;overflow:hidden}.full-bleed-image-wrapper{position:absolute;inset:-30px;width:calc(100% + 60px);height:calc(100% + 60px)}.full-bleed-image-img{-o-object-fit:cover;object-fit:cover}.full-bleed-image-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.02));pointer-events:none}.full-bleed-image-caption{font-family:var(--font-sans);font-size:var(--text-sm);color:var(--color-text-muted);text-align:center;padding:var(--space-4) var(--space-8);max-width:var(--container-narrow);margin:0 auto}.editorial-article-body .section-header{display:block;margin:var(--space-20) 0 var(--space-8);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border-subtle);text-align:left}.editorial-article-body .section-header-icon{margin-bottom:var(--space-3)}.editorial-article-body .section-header-icon svg{display:block}.editorial-article-body .section-header-title{font-family:var(--font-sans);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-widest);color:var(--color-text-muted);margin:0;text-align:left}.section-header-subtitle{font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-text-subtle);margin-top:var(--space-2)}.editorial-paragraph{font-family:var(--font-serif);font-size:var(--text-lg);line-height:var(--leading-relaxed);color:var(--color-text);margin-bottom:var(--space-6)}.editorial-paragraph-lead{font-size:var(--text-xl);color:var(--color-text-subtle);line-height:var(--leading-loose)}.editorial-paragraph-dropcap:first-letter{font-family:var(--font-serif);font-size:4em;float:left;line-height:.8;padding-right:var(--space-3);padding-top:var(--space-1);color:var(--color-text);font-weight:400}.principle-card{padding:var(--space-6) 0;border-bottom:1px solid var(--color-border-subtle)}.principle-card:last-child{border-bottom:none}.principle-card-number{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-muted);display:block;margin-bottom:var(--space-2)}.principle-card-title{font-family:var(--font-sans);font-size:var(--text-xl);font-weight:600;color:var(--color-text);margin:0 0 var(--space-3)}.principle-card-content{font-family:var(--font-serif);font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--color-text-subtle)}.editorial-article{min-height:100vh}.editorial-article-body{max-width:var(--container-narrow);margin:0 auto;padding:var(--space-16) var(--space-6)}.editorial-article-intro,.editorial-article-section{margin-bottom:var(--space-12)}.editorial-article-section h3{font-family:var(--font-sans);font-size:var(--text-2xl);font-weight:600;color:var(--color-text);margin:0 0 var(--space-4);letter-spacing:var(--tracking-tight)}.editorial-article-closing{margin-top:var(--space-8)}.closing-hero{position:relative;width:100%;height:200px;margin-top:var(--space-16);overflow:hidden}.closing-hero-canvas{position:absolute;top:0;left:0}.editorial-nav{position:fixed;top:0;left:0;right:0;z-index:var(--z-fixed);padding:var(--space-4) var(--space-6);display:flex;justify-content:space-between;align-items:center;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border-subtle)}.editorial-nav-back{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--color-text-subtle);text-decoration:none;transition:color var(--duration-200) var(--ease-out)}.editorial-nav-back:hover{color:var(--color-text)}.editorial-nav-back svg{width:20px;height:20px}@media (max-width:768px){.systems-to-clarity-hero{height:80vh;min-height:500px}.pull-quote{margin:var(--space-12) 0;padding:var(--space-6) 0}.full-bleed-image{margin:var(--space-12) calc(-50vw + 50%)}.editorial-article-body{padding:var(--space-10) var(--space-4)}.section-header{margin:var(--space-14) 0 var(--space-6)}}.article-header{position:relative;z-index:10;background:var(--color-bg);padding:var(--space-6);padding-top:var(--space-4)}.article-header-nav{margin-bottom:var(--space-8)}.article-header-back{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--color-text-subtle);text-decoration:none;transition:color var(--duration-200) var(--ease-out)}.article-header-back:hover{color:var(--color-text)}.article-header-back svg{width:18px;height:18px}.article-header-content{max-width:var(--container-narrow);margin:0 auto}.article-header-title{font-family:var(--font-serif);font-size:clamp(2.5rem,6vw,4rem);font-weight:400;color:var(--color-text);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);margin:0 0 var(--space-4)}.article-header-hook{font-family:var(--font-sans);font-size:var(--text-lg);color:var(--color-text-subtle);line-height:var(--leading-relaxed);margin:0 0 var(--space-6);max-width:500px;text-wrap:balance}.article-header-meta{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle)}.article-header-tags{display:flex;gap:var(--space-2);flex-wrap:wrap}.article-header-tag{font-family:var(--font-sans);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--color-text-muted);background:var(--color-bg-subtle);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}.article-header-date{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted)}.venn-diagram-hero{position:relative;width:100%;height:250vh;background:var(--color-bg)}.venn-diagram-sticky{position:sticky;top:0;left:0;width:100%;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.venn-diagram-canvas{position:absolute;top:0;left:0}.editorial-article{position:relative}.editorial-article .article-header{position:absolute;top:0;left:0;right:0;z-index:20;background:linear-gradient(180deg,var(--color-bg) 0,var(--color-bg) 70%,transparent 100%);padding-bottom:var(--space-12);pointer-events:none}.editorial-article .article-header-content,.editorial-article .article-header-nav{pointer-events:auto}.scroll-indicator{position:absolute;bottom:var(--space-16);left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:var(--color-text-muted);transition:opacity var(--duration-500) var(--ease-out)}.scroll-indicator.visible{opacity:1}.scroll-indicator.hidden{opacity:0;pointer-events:none}.scroll-indicator-text{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-widest)}.scroll-indicator-arrow{animation:scrollBounce 2s ease-in-out infinite}@keyframes scrollBounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}@media (max-width:768px){.article-header{padding:var(--space-4)}.article-header-meta{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.article-header-date{order:-1}.venn-diagram-hero{height:220vh}.scroll-indicator{bottom:var(--space-12)}.editorial-article .article-header{padding-bottom:var(--space-8)}}@media (max-width:480px){.venn-diagram-hero{height:200vh}}.design-philosophy-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-5);margin-bottom:var(--space-8);background:linear-gradient(135deg,#7c3aed,#8b5cf6 50%,#a78bfa);border-radius:var(--radius-xl);animation:fadeInDown .4s var(--ease-out)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.design-philosophy-banner-content{display:flex;align-items:center;gap:var(--space-2);flex:1;text-decoration:none;color:#fff;transition:opacity var(--duration-200) var(--ease-out)}.design-philosophy-banner-content:hover{opacity:.9}.design-philosophy-banner-text{font-size:var(--text-sm);font-weight:500}.design-philosophy-banner-cta{font-size:var(--text-sm);font-weight:600;text-decoration:underline;text-underline-offset:2px}.design-philosophy-banner-dismiss{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);background:hsla(0,0%,100%,.15);border:none;color:#fff;cursor:pointer;flex-shrink:0;transition:background var(--duration-200) var(--ease-out)}.design-philosophy-banner-dismiss:hover{background:hsla(0,0%,100%,.25)}@media (max-width:640px){.design-philosophy-banner{flex-direction:column;align-items:flex-start;padding:var(--space-4);gap:var(--space-3)}.design-philosophy-banner-content{flex-direction:column;align-items:flex-start;gap:var(--space-1)}.design-philosophy-banner-dismiss{position:absolute;top:var(--space-3);right:var(--space-3)}.design-philosophy-banner{position:relative}}.hover\:text-\[var\(--color-accent\)\]:hover{color:var(--color-accent)}.hover\:text-\[var\(--color-text\)\]:hover{color:var(--color-text)}.group:hover .group-hover\:scale-105{--tw-scale-x:1.05;--tw-scale-y:1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@media (min-width:768px){.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:text-5xl{font-size:3rem;line-height:1}}@media (min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}