@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.06d3mdzz5bre_.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.11.cyxs5p-0z~.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.16t1db8_9y2o~.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist", "Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.0q3udbd2bu5yp.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.0gw~uztddq1df.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.0.q-h669a_dqa.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono", "Geist Mono Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-semibold:600;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.invisible{visibility:hidden}.visible{visibility:visible}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-5{margin-top:calc(var(--spacing) * 5)}.block{display:block}.contents{display:contents}.grid{display:grid}.hidden{display:none}.table{display:table}.h-full{height:100%}.resize{resize:both}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}.border{border-style:var(--tw-border-style);border-width:1px}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.leading-7{--tw-leading:calc(var(--spacing) * 7);line-height:calc(var(--spacing) * 7)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-\[var\(--muted\)\]{color:var(--muted)}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--background:#0b1018;--panel:#131b28;--foreground:#f5f9ff;--muted:#a8b2c2;--line:#1d2839;--accent:#55e6a5;--shadow-soft:0 24px 80px #00000059}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:linear-gradient(180deg, #0d141e 0%, var(--background) 100%);min-height:100vh;color:var(--foreground);font-family:var(--font-geist-sans), sans-serif;margin:0}a{color:inherit;text-decoration:none}img,svg{display:block}.shell{width:min(1200px,100% - 2rem);margin:0 auto}.site-body{flex-direction:column;min-height:100vh;display:flex}.site-header{z-index:100;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0b1018eb;position:relative}.site-header__inner{justify-content:space-between;align-items:center;gap:1rem;min-height:4.5rem;display:flex}.site-brand{flex-direction:column;gap:.15rem;display:flex}.site-brand__title{letter-spacing:.08em;text-transform:uppercase;font-size:1rem;font-weight:700}.site-brand__subtitle{color:var(--accent);letter-spacing:.2em;text-transform:uppercase;font-size:.72rem;font-weight:700}.header-avatar{align-items:center;gap:.65rem;display:flex}.header-avatar__imageLink{cursor:pointer;background:0 0;border:2px solid #8ef0b4e0;border-radius:999px;padding:.08rem;transition:box-shadow .18s,border-color .18s;display:inline-flex;box-shadow:0 0 0 2px #8ef0b429}.header-avatar__imageLink:hover,.header-avatar__imageLink:focus-visible{border-color:#9bffc1;box-shadow:0 0 0 3px #8ef0b447}.header-avatar__image{width:2.4rem;height:2.4rem;color:var(--accent);letter-spacing:.08em;background:#8ef0b41f;border:1px solid #8ef0b48c;border-radius:999px;flex:0 0 2.4rem;justify-content:center;align-items:center;font-size:.82rem;font-weight:700;display:inline-flex;overflow:hidden}.header-avatar__imageContent{object-fit:cover;object-position:center;border-radius:999px;width:100%;height:100%;display:block}.header-avatar__modal{z-index:999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#04090ee0;place-items:start center;padding:5.5rem 1rem 1rem;display:grid;position:fixed;inset:0}.header-avatar__modalCard{background:linear-gradient(#131b28fa,#0d141efa);border:1px solid #8ef0b46b;border-radius:1rem;width:min(88vw,560px);padding:.75rem;position:relative;box-shadow:0 30px 80px #00000080}.header-avatar__modalImage{object-fit:cover;object-position:center;border-radius:.8rem;width:100%;height:min(72vw,520px);max-height:72vh}.header-avatar__modalClose{color:var(--foreground);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;background:#080d14e6;border:1px solid #8ef0b473;border-radius:.45rem;padding:.35rem .55rem;font-size:.72rem;font-weight:700;position:absolute;top:.45rem;right:.45rem}.header-avatar__content{flex-direction:column;gap:.08rem;display:flex}.header-avatar__name,.header-avatar__role{margin:0}.header-avatar__name{color:var(--foreground);font-size:.84rem;font-weight:600}.header-avatar__role{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:.72rem}.section-label,.hero-slab__eyebrow{color:var(--accent);letter-spacing:.24em;text-transform:uppercase;margin:0 0 .75rem;font-size:.76rem;font-weight:700}.site-main{flex:1}.site-footer__description,.site-footer__list a,.site-footer__list span,.site-footer__copyright,.hero-slab__body,.prose-shell p,.prose-shell li,.prose-shell blockquote{color:var(--muted)}.site-footer__list a:hover,.site-footer__list a:focus-visible,.site-footer__portfolio:hover,.site-footer__portfolio:focus-visible,.prose-shell a:hover,.prose-shell a:focus-visible{color:var(--accent)}.hero-slab{padding:2.25rem 0 2rem}.hero-slab__panel,.content-card{border:1px solid var(--line);box-shadow:var(--shadow-soft);background:linear-gradient(#131b28f5,#0e1520f5)}.hero-slab__panel{border-radius:1.1rem;padding:1.7rem}.hero-slab__title{max-width:16ch;margin:0;font-size:clamp(2rem,6vw,3rem);line-height:1.05}.hero-slab__body{max-width:52rem;margin:1rem 0 0;line-height:1.75}.hero-slab__actions{flex-wrap:wrap;gap:.9rem;margin-top:1.4rem;display:flex}.portfolio-blog{isolation:isolate;padding:3.5rem 0 3.75rem;position:relative;overflow:hidden}.portfolio-blog__bg{z-index:-1;pointer-events:none;position:absolute;inset:0}.portfolio-blog__particles{opacity:.5;position:absolute;inset:0}.portfolio-blog__glow,.post-detail__glow{filter:blur(120px);opacity:.12;pointer-events:none;z-index:-1;border-radius:50%;width:60vw;height:60vw;position:absolute}.portfolio-blog__glow--1,.post-detail__glow--1{background:radial-gradient(circle, var(--accent) 0%, transparent 70%);animation:20s ease-in-out infinite alternate glow-float;top:-10%;left:-10%}.portfolio-blog__glow--2,.post-detail__glow--2{background:radial-gradient(circle,#009efd 0%,#0000 70%);animation:25s ease-in-out infinite alternate-reverse glow-float;bottom:-10%;right:-10%}@keyframes glow-float{0%{transform:translate(0)scale(1)}to{transform:translate(10%,15%)scale(1.1)}}.portfolio-blog__inner{z-index:1;position:relative}.portfolio-blog__header{text-align:center;margin-bottom:3.5rem}.portfolio-blog__eyebrow{color:var(--accent);letter-spacing:.26em;text-transform:uppercase;margin:0 0 1rem;font-size:.78rem;font-weight:700}.portfolio-blog__title{letter-spacing:-.02em;margin:0;font-size:clamp(2.6rem,6.2vw,4.25rem);font-weight:600;line-height:1.04}.blog-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1.75rem;display:grid}.blog-grid__empty{grid-column:1/-1}.blog-card{padding:0}.blog-card__link{flex-direction:column;gap:0;height:100%;display:flex}.blog-card__media{background:#000000a6;border-radius:5px;height:15rem;position:relative;overflow:hidden}.blog-card__image{object-fit:cover;object-position:center;width:100%;height:100%}.blog-card__mediaPlaceholder{color:#f5f9ffb3;letter-spacing:.08em;place-items:center;width:100%;height:100%;font-size:2.1rem;display:grid}.blog-card__date{background:var(--accent);color:#09101a;letter-spacing:.02em;text-transform:uppercase;border-radius:5px;padding:.65rem 1.25rem;font-size:.82rem;font-weight:500;position:absolute;top:1.25rem;right:1.25rem;box-shadow:0 16px 32px #0000000a}.blog-card__meta{color:var(--foreground);align-items:center;gap:1.25rem;margin-top:10px;margin-bottom:15px;font-size:.85rem;font-weight:600;display:flex}.blog-card__metaItem{white-space:nowrap;align-items:center;gap:.45rem;display:inline-flex}.blog-card__metaItem svg{color:var(--accent);width:1.1rem;height:1.1rem}.blog-card__title{color:var(--foreground);margin:0 0 12px;font-size:1.25rem;font-weight:700;line-height:1.3;transition:color .2s}.blog-card__link:hover .blog-card__title{color:var(--accent)}.blog-card__excerpt{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:1rem;line-height:1.75;display:-webkit-box;overflow:hidden}.blog-grid__sentinel{min-height:1px}.blog-grid__loadingMore{grid-template-columns:repeat(3,minmax(0,1fr));gap:1.75rem;display:grid}.skeleton{background:linear-gradient(90deg,#ffffff0f,#ffffff1f,#ffffff0f) 0 0/220% 100%;border-radius:.6rem;animation:1.1s ease-in-out infinite shimmer}.blog-card__mediaSkeleton{border-radius:5px;width:100%;height:100%}.blog-card__dateSkeleton{border-radius:5px;width:10.5rem;height:2.45rem;position:absolute;top:1.1rem;right:1.1rem}.blog-card__metaSkeleton{width:7.2rem;height:1.1rem}.blog-card__titleSkeleton{width:92%;height:1.45rem}.blog-card__excerptSkeleton{width:100%;height:1rem}.blog-card__excerptSkeleton--short{width:72%}@keyframes shimmer{0%{background-position:140% 0}to{background-position:-60% 0}}.button-primary,.button-secondary{letter-spacing:.06em;text-transform:uppercase;border-radius:.45rem;justify-content:center;align-items:center;min-height:2.9rem;padding:.7rem 1.1rem;font-size:.84rem;font-weight:500;transition:transform .18s,border-color .18s,background .18s,color .18s,box-shadow .18s;display:inline-flex}.button-primary{background:var(--accent);color:#0a1117}.button-primary:hover,.button-primary:focus-visible{transform:translateY(-1px);box-shadow:0 0 0 3px #8ef0b424}.button-secondary{border:1px solid var(--line);color:var(--foreground);background:#ffffff05}.button-secondary:hover,.button-secondary:focus-visible{border-color:#8ef0b457;transform:translateY(-1px)}.content-card{border-radius:1rem;padding:1.2rem}.prose-shell{width:min(860px,100% - 2rem);margin:0 auto;padding:2.25rem 0 3rem}.prose-shell h1,.prose-shell h2,.prose-shell h3,.prose-shell h4{color:var(--foreground)}.prose-shell a{color:var(--accent)}.prose-shell ul,.prose-shell ol{padding-left:1.25rem}.prose-shell blockquote{border-left:3px solid var(--accent);margin:1.5rem 0;padding-left:1rem}.post-detail{isolation:isolate;padding:2.1rem 0 3.6rem;position:relative;overflow:hidden}.post-detail__inner{z-index:1;position:relative}.post-detail__bg{pointer-events:none;z-index:0;opacity:.92;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000 0%,#000c 60%,#0000 100%);mask-image:linear-gradient(#000 0%,#000c 60%,#0000 100%)}.post-detail__particles{width:100%;height:100%}.post-detail__header,.post-detail__media,.post-detail__content{z-index:1;position:relative}.post-detail__header{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);margin-bottom:1.4rem;padding:1.3rem}.post-detail__title{letter-spacing:-.02em;text-wrap:balance;max-width:18ch;margin:0;font-size:clamp(2.1rem,6vw,4.2rem);line-height:1.04}.post-detail__meta{color:var(--muted);letter-spacing:.2em;text-transform:uppercase;flex-wrap:wrap;gap:.7rem;margin-top:1rem;font-size:.73rem;font-weight:700;display:flex}.post-detail__meta span{color:#f5f9ffe0;background:#8ef0b412;border:1px solid #8ef0b43d;border-radius:.4rem;padding:.35rem .55rem}.post-detail__excerpt{max-width:70ch;color:var(--muted);margin:1rem 0 0;font-size:1.05rem;line-height:1.85}.post-detail__actions{margin-top:1.2rem}.post-detail__backBtn{color:#e8fff2;background:linear-gradient(#8ef0b433,#8ef0b414);border-color:#8ef0b4a8;font-weight:800;box-shadow:0 0 0 1px #8ef0b438,0 8px 20px #00000047}.post-detail__backBtn:hover,.post-detail__backBtn:focus-visible{background:linear-gradient(#8ef0b44d,#8ef0b41f);border-color:#9bffc1;box-shadow:0 0 0 3px #8ef0b442,0 10px 24px #00000052}.post-detail__media{border-radius:1.1rem;margin-bottom:1.4rem;padding:.45rem;overflow:hidden}.post-detail__image{object-fit:cover;object-position:center;border-radius:.75rem;width:100%;height:clamp(240px,46vw,560px);box-shadow:0 28px 70px #00000073}.post-detail__content{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);max-width:none;margin:0;padding:1.35rem}.post-detail__contentWrap{z-index:1;position:relative}.pretext-body{--gif-shift-x:0px;--gif-shift-y:0px;--gif-pulse:0;--gif-word-shift:0px;--gif-letter-shift:0em;--gif-shadow-blur:0px;position:relative;overflow:hidden}.pretext-body__pauseBtn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:2.45rem;height:2.45rem;color:var(--foreground);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;z-index:4;background:#0b101838;border:1px solid #f5f9ff59;border-radius:999px;justify-content:center;align-items:center;padding:0;font-size:.72rem;font-weight:700;transition:border-color .18s,background .18s,box-shadow .18s,color .18s;display:inline-flex;position:absolute;top:.8rem;right:.8rem}.pretext-body__pauseBtn:hover,.pretext-body__pauseBtn:focus-visible{color:#ddffe9;background:#8ef0b429;border-color:#8ef0b4e6;box-shadow:0 0 0 3px #8ef0b424}.pretext-body__pauseIcon{justify-content:center;align-items:center;width:1rem;height:1rem;line-height:1;display:inline-flex}.pretext-body__pauseIcon--play{border-top:.34rem solid #0000;border-bottom:.34rem solid #0000;border-left:.54rem solid;width:0;height:0;margin-left:.07rem}.pretext-body__pauseIcon--pause{width:.68rem;height:.74rem;position:relative}.pretext-body__pauseIcon--pause:before,.pretext-body__pauseIcon--pause:after{content:"";background:currentColor;border-radius:.1rem;width:.16rem;height:100%;position:absolute;top:0}.pretext-body__pauseIcon--pause:before{left:0}.pretext-body__pauseIcon--pause:after{right:0}.pretext-body__pauseLabel{color:var(--foreground);letter-spacing:.08em;opacity:0;pointer-events:none;background:#0b1018eb;border:1px solid #8ef0b466;border-radius:.35rem;padding:.25rem .45rem;font-size:.66rem;font-weight:700;transition:opacity .18s,transform .18s;position:absolute;top:50%;right:calc(100% + .55rem);transform:translateY(-50%)translate(.3rem)}.pretext-body__pauseBtn:hover .pretext-body__pauseLabel,.pretext-body__pauseBtn:focus-visible .pretext-body__pauseLabel{opacity:1;transform:translateY(-50%)translate(0)}.pretext-body__mascot{float:right;width:clamp(118px,20vw,162px);height:clamp(118px,20vw,162px);box-shadow:none;shape-outside:inset(0 round 12px);shape-margin:.55rem;z-index:2;background:0 0;border:none;border-radius:0;margin:2.85rem 0 .85rem 1rem;position:relative;overflow:hidden;transform:translate(-8px)}.pretext-body__mascotFreeze{object-fit:cover;pointer-events:none;z-index:2;width:100%;height:100%;display:none;position:absolute;inset:0}.pretext-body__mascotImage{object-fit:cover;filter:saturate(1.05)contrast(1.03)drop-shadow(0 8px 14px #00000059);z-index:1;width:100%;height:100%;transform:translate3d(calc(var(--gif-shift-x) * .25), calc(var(--gif-shift-y) * .25), 0);display:block;position:relative}.pretext-body--gifFrozen.pretext-body--paused .pretext-body__mascotFreeze{display:block}.pretext-body--gifFrozen.pretext-body--paused .pretext-body__mascotImage{opacity:0}.pretext-body__line{opacity:0;filter:blur(5px);transition:opacity .42s,transform .42s,filter .42s;transform:translateY(.7rem)}.pretext-body--ready .pretext-body__line{opacity:1;transform:translate3d(var(--gif-shift-x), var(--gif-shift-y), 0);filter:blur();word-spacing:var(--gif-word-shift);letter-spacing:var(--gif-letter-shift);text-shadow:0 0 var(--gif-shadow-blur) #8ef0b433, 0 0 calc(var(--gif-shadow-blur) * .35) #f5f9ff1f;animation:2.2s ease-in-out infinite pretext-shift}.pretext-body--paused .pretext-body__line{word-spacing:0;letter-spacing:0;text-shadow:none;animation:none;transform:translate(0)}.pretext-body__line:first-of-type{transition-delay:40ms}.pretext-body__line:nth-of-type(2){transition-delay:.11s}.pretext-body__line:nth-of-type(3){transition-delay:.18s}.pretext-body__line:nth-of-type(4){transition-delay:.25s}.pretext-body__line:nth-of-type(5){transition-delay:.32s}.pretext-body__line:nth-of-type(odd){animation-delay:.26s}.pretext-body__line:nth-of-type(3n){animation-delay:.52s}@keyframes pretext-shift{0%,to{transform:translate3d(calc(var(--gif-shift-x) * .5), calc(var(--gif-shift-y) * .4), 0)}25%{transform:translate3d(calc(var(--gif-shift-x) * -.9), calc(var(--gif-shift-y) * .7), 0)}55%{transform:translate3d(calc(var(--gif-shift-x) * 1.1), calc(var(--gif-shift-y) * -.85), 0)}78%{transform:translate3d(calc(var(--gif-shift-x) * -.45), calc(var(--gif-shift-y) * -.4), 0)}}.post-prose__h2,.post-prose__h3,.post-prose__p,.post-prose__ul,.post-prose__ol,.post-prose__quote{color:var(--muted);text-wrap:pretty;margin:0;font-size:1.04rem;line-height:1.9}.post-prose__p+.post-prose__p,.post-prose__p+.post-prose__h2,.post-prose__p+.post-prose__h3,.post-prose__h2+.post-prose__p,.post-prose__h3+.post-prose__p,.post-prose__ul+.post-prose__p,.post-prose__ol+.post-prose__p,.post-prose__quote+.post-prose__p,.post-prose__p+.post-prose__ul,.post-prose__p+.post-prose__ol,.post-prose__p+.post-prose__quote{margin-top:1.1rem}.post-prose__h2,.post-prose__h3{color:var(--foreground);letter-spacing:-.01em;text-wrap:balance;line-height:1.3}.post-prose__h2{margin-top:2.3rem;font-size:clamp(1.5rem,3.7vw,2.1rem);font-weight:800}.post-prose__h3{margin-top:1.9rem;font-size:clamp(1.25rem,3vw,1.55rem);font-weight:700}.post-prose__ul{list-style-type:disc}.post-prose__ol{list-style-type:decimal}.post-prose__ul,.post-prose__ol{gap:.55rem;margin-top:1rem;padding-left:1.5rem;display:grid}.post-prose__quote{color:#f5f9ffe0;background:linear-gradient(90deg,#8ef0b417,#0000 75%);border-left:3px solid #8ef0b4e0;border-radius:0 .45rem .45rem 0;margin-top:1.5rem;padding:.7rem 0 .7rem 1rem}.post-prose__strong{color:var(--foreground);margin:0 .15em;font-weight:700}.post-prose__em{color:#f5f9ffeb;margin:0 .15em}.post-prose__inline-code{color:var(--accent);background:#8ef0b426;border-radius:4px;margin:0 .2em;padding:.15em .35em;font-family:monospace;font-size:.85em}.post-prose__link{color:var(--accent);text-underline-offset:2px;text-decoration:underline;text-decoration-thickness:1.5px}.post-prose__link:hover,.post-prose__link:focus-visible{color:#c2ffd9}.post-prose__code-block{border-radius:8px;margin-top:1.5rem;position:relative;overflow:hidden;box-shadow:0 4px 15px #0003}.post-prose__code-header{color:var(--muted);background:#131b28f2;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:.5rem 1rem;font-family:monospace;font-size:.75rem;display:flex}.post-prose__code-filename{color:var(--foreground);font-weight:600}.post-prose__copy-btn{color:var(--muted);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:4px;align-items:center;gap:.35rem;padding:.3rem .6rem;font-size:.7rem;font-weight:600;transition:all .2s;display:flex}.post-prose__copy-btn:hover{border-color:var(--accent);color:var(--accent);background:#8ef0b426}.post-prose__table-container{background:#131b2866;border:1px solid #ffffff1a;border-radius:8px;margin-top:1.5rem;margin-bottom:1.5rem;overflow-x:auto}.post-prose__table{border-collapse:collapse;text-align:left;width:100%;font-size:.95rem}.post-prose__table th,.post-prose__table td{color:var(--muted);border-bottom:1px solid #ffffff0d;padding:.85rem 1.2rem}.post-prose__table th{color:var(--foreground);letter-spacing:.02em;background:#131b28f2;font-weight:700}.post-prose__table tr:last-child td{border-bottom:none}.post-prose__table tr:hover td{background:#ffffff05}.faq-accordion{flex-direction:column;gap:1rem;margin:2rem 0;display:flex}.faq-item{background:#131b2866;border:1px solid #ffffff1a;border-radius:8px;transition:all .3s;overflow:hidden}.faq-item[open]{background:#1d283999;border-color:#8ef0b44d}.faq-question{cursor:pointer;color:var(--foreground);-webkit-user-select:none;user-select:none;align-items:center;padding:1.2rem 1.5rem;font-weight:600;display:flex}.faq-question::-webkit-details-marker{display:none}.faq-question:before{content:"+";color:var(--accent,#8ef0b4);margin-right:1rem;font-size:1.4rem;font-weight:400;line-height:1;transition:transform .3s}.faq-item[open] .faq-question:before{content:"−";transform:rotate(180deg)}.faq-answer{color:var(--muted);padding:0 1.5rem 1.2rem;line-height:1.6}.faq-answer p{margin:0}.faq-answer code{color:var(--accent,#8ef0b4);background:#ffffff0d;border-radius:4px;padding:.1rem .4rem;font-size:.85em}.site-footer{z-index:100;background:radial-gradient(1200px 520px at 50% 0,#8ef0b41f,#0000 62%),radial-gradient(900px 360px at 10% 10%,#ffffff12,#0000 58%),linear-gradient(#0a1018fa 0%,#070a10fa 100%);border-top:1px solid #1d2839d9;margin-top:2.5rem;position:relative;overflow:hidden}.site-footer__top{grid-template-columns:minmax(0,2.2fr) minmax(0,1fr) minmax(0,1fr);gap:3.75rem;padding:3.75rem 0 2.75rem;display:grid}.site-footer__eyebrow{color:var(--accent);letter-spacing:.3em;text-transform:uppercase;margin:0 0 1.4rem;font-size:.78rem;font-weight:700}.site-footer__headline{letter-spacing:-.02em;max-width:22ch;margin:0;font-size:clamp(2.35rem,4.75vw,3.7rem);line-height:1.05}.site-footer__description{max-width:56ch;margin:1.5rem 0 0;line-height:1.9}.site-footer__list{flex-direction:column;gap:1rem;margin:0;padding:0;list-style:none;display:flex}.site-footer__list a,.site-footer__list span{font-size:1rem;line-height:1.7;display:inline-block}.site-footer__bottom{border-top:1px solid #1d2839bf;justify-content:space-between;align-items:center;gap:1.25rem;padding:1.55rem 0 2.25rem;display:flex}.site-footer__copyright{letter-spacing:.01em;margin:0;font-size:.95rem}.site-footer__actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.site-footer__divider{color:#a8b2c29e;font-size:1rem;line-height:1}.site-footer__portfolio{color:var(--muted);letter-spacing:.01em;font-size:1rem;font-weight:600}.scroll-top{--scroll-progress:0;width:2.8rem;height:2.8rem;color:var(--foreground);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer;opacity:0;pointer-events:none;z-index:120;background:#0b1018db;border:none;border-radius:999px;justify-content:center;align-items:center;font-size:1.1rem;transition:opacity .18s,transform .18s,border-color .18s,background .18s,box-shadow .18s;display:inline-flex;position:fixed;bottom:1.1rem;right:1.1rem;transform:translateY(.8rem);box-shadow:0 12px 26px #00000059,0 0 0 1px #ffffff14}.scroll-top--visible{opacity:1;pointer-events:auto;transform:translateY(0)}.scroll-top__ring{pointer-events:none;position:absolute;inset:0}.scroll-top__ringSvg{width:100%;height:100%;transform:rotate(-90deg)}.scroll-top__ringTrack,.scroll-top__ringProgress{fill:none;stroke-width:2.5px}.scroll-top__ringTrack{stroke:#f5f9ff59}.scroll-top__ringProgress{stroke:#8ef0b4f2;stroke-linecap:round;transition:stroke-dashoffset .12s linear}.scroll-top:hover,.scroll-top:focus-visible{background:#8ef0b433;box-shadow:0 14px 28px #00000061,0 0 0 3px #8ef0b447}.scroll-top__arrow{z-index:1;border-top:2px solid;border-right:2px solid;width:.58rem;height:.58rem;display:inline-block;position:relative;transform:translateY(1px)rotate(-45deg)}@media (max-width:960px){.blog-card__media{height:16.5rem}.blog-grid,.blog-grid__loadingMore{grid-template-columns:repeat(2,minmax(0,1fr))}.site-footer__top{grid-template-columns:1fr;gap:2.5rem;padding-top:3rem}.site-footer__bottom{flex-direction:column;align-items:flex-start}.site-footer__actions{width:100%}}@media (max-width:640px){.scroll-top{width:2.55rem;height:2.55rem;bottom:.8rem;right:.8rem}.blog-card__media{height:13.75rem}.header-avatar__content{display:none}.hero-slab{padding-top:1.2rem}.hero-slab__panel,.content-card{padding:1rem}.portfolio-blog{padding-top:2.5rem}.portfolio-blog__header{text-align:left;margin-bottom:2rem}.blog-grid,.blog-grid__loadingMore{grid-template-columns:1fr}.site-footer__top{padding:2.75rem 0 2.25rem}.post-detail{padding-top:1.2rem}.post-detail__header,.post-detail__content{padding:1rem}.post-detail__title{font-size:clamp(1.9rem,10vw,2.6rem)}.pretext-body__mascot{float:none;shape-outside:none;width:112px;height:112px;margin:2.8rem auto .95rem;transform:none}.pretext-body__pauseBtn{width:2.25rem;height:2.25rem;top:.55rem;right:.55rem}.pretext-body__pauseLabel{top:calc(100% + .45rem);left:50%;right:auto;transform:translate(-50%)translateY(-.15rem)}.pretext-body__pauseBtn:hover .pretext-body__pauseLabel,.pretext-body__pauseBtn:focus-visible .pretext-body__pauseLabel{transform:translate(-50%)translateY(0)}.post-detail__excerpt,.post-prose__h2,.post-prose__h3,.post-prose__p,.post-prose__ul,.post-prose__ol,.post-prose__quote{font-size:1rem}}.post-footer{border-top:1px solid #8ef0b426;margin-top:6rem;padding:4rem 0;position:relative}.post-footer:before{content:"";background:linear-gradient(90deg, var(--accent), transparent);width:100px;height:1px;position:absolute;top:-1px;left:0}.interactions{align-items:center;gap:1.5rem;margin-bottom:4.5rem;display:flex}.interaction-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--muted);letter-spacing:.04em;text-transform:uppercase;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;align-items:center;gap:.75rem;padding:.75rem 1.6rem;font-size:.85rem;font-weight:700;transition:all .4s cubic-bezier(.16,1,.3,1);display:inline-flex;box-shadow:0 4px 12px #0000001a}.interaction-btn:hover{color:var(--foreground);background:#8ef0b414;border-color:#8ef0b466;transform:translateY(-2px);box-shadow:0 8px 24px #0003,0 0 15px #8ef0b41a}.interaction-btn.active{border-color:var(--accent);color:var(--accent);background:#8ef0b426;box-shadow:0 0 30px #8ef0b433}.interaction-btn svg{stroke-width:2.5px;width:1.1rem;height:1.1rem;transition:transform .5s cubic-bezier(.16,1,.3,1)}.interaction-btn.active svg{fill:currentColor;animation:.7s cubic-bezier(.16,1,.3,1) heart-pop-premium;transform:scale(1.15)rotate(-5deg)}@keyframes heart-pop-premium{0%{transform:scale(1)}30%{transform:scale(1.4)rotate(10deg)}60%{transform:scale(.9)rotate(-5deg)}to{transform:scale(1.15)rotate(-5deg)}}.comment-section{max-width:860px;margin:0 auto}.comment-section__title{letter-spacing:-.02em;align-items:center;gap:1rem;margin-top:5rem;margin-bottom:3rem;font-size:1.8rem;font-weight:800;display:flex}.comment-section__title svg{color:var(--accent);filter:drop-shadow(0 0 8px #8ef0b466)}.comment-list{flex-direction:column;gap:2rem;margin-bottom:5rem;display:flex}.comment-item{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff05;border:1px solid #ffffff0d;border-radius:1.5rem;gap:1.5rem;padding:2rem;animation:.6s cubic-bezier(.16,1,.3,1) forwards fade-in-up-premium;display:flex;position:relative;overflow:hidden}.comment-item:after{content:"";pointer-events:none;background:linear-gradient(135deg,#8ef0b408 0%,#0000 100%);position:absolute;inset:0}.comment-item__avatar{color:#0b1018;background:linear-gradient(135deg,#2af598 0%,#009efd 100%);border-radius:14px;flex-shrink:0;place-items:center;width:3.2rem;height:3.2rem;font-size:1.1rem;font-weight:800;display:grid;box-shadow:0 8px 20px #0000004d}.comment-item__content{z-index:1;flex:1;position:relative}.comment-item__header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.comment-item__author{color:var(--foreground);align-items:center;gap:.5rem;font-size:1rem;font-weight:700;display:flex}.comment-item__author:after{content:"";background:var(--accent);opacity:.6;border-radius:50%;width:4px;height:4px}.comment-item__date{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);opacity:.8;font-size:.75rem;font-weight:600}.comment-item__text{color:#f5f9ffcc;letter-spacing:.01em;font-size:1rem;line-height:1.7}.comment-form{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffff05;border:1px solid #8ef0b426;border-radius:2rem;padding:3rem;box-shadow:0 20px 50px #0003}.comment-form__title{letter-spacing:-.01em;margin-bottom:2rem;font-size:1.4rem;font-weight:700}.comment-form__grid{gap:1.75rem;display:grid}.comment-form__field{flex-direction:column;gap:.75rem;display:flex}.comment-form__label{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);opacity:.9;font-size:.75rem;font-weight:800}.comment-form__input,.comment-form__textarea{color:var(--foreground);background:#0000004d;border:1px solid #ffffff14;border-radius:12px;padding:1rem 1.25rem;font-family:inherit;font-size:1rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.comment-form__input:focus,.comment-form__textarea:focus{background:#8ef0b405;border-color:#8ef0b480;outline:none;transform:scale(1.005);box-shadow:0 0 0 4px #8ef0b40d}.comment-form__textarea{min-height:160px;line-height:1.6}.comment-form__submit{border-radius:12px;margin-top:1rem;padding:1rem 2rem;font-size:.9rem;box-shadow:0 10px 30px #8ef0b433}@keyframes fade-in-up-premium{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.post-footer{margin-top:4rem;padding:2.5rem 0}.comment-form{padding:2rem}.comment-item{flex-direction:column;gap:1rem;padding:1.5rem}.comment-item__avatar{width:2.8rem;height:2.8rem}}@keyframes loader-slide{0%{left:-40%}50%{left:100%}to{left:-40%}}.interaction-btn__wrapper{position:relative}.btn-icon-relative{justify-content:center;align-items:center;display:flex;position:relative}.heart-burst{pointer-events:none;background:radial-gradient(circle, var(--accent) 0%, transparent 70%);opacity:0;border-radius:50%;width:100px;height:100px;animation:.8s cubic-bezier(.16,1,.3,1) forwards heart-burst-premium;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes heart-burst-premium{0%{opacity:.8;transform:translate(-50%,-50%)scale(0)}to{opacity:0;transform:translate(-50%,-50%)scale(2.5)}}.share-toast,.success-toast{white-space:nowrap;z-index:10;border-radius:12px;padding:.75rem 1.25rem;font-size:.85rem;font-weight:700;animation:.4s cubic-bezier(.16,1,.3,1) fade-in-up-premium;position:absolute;bottom:calc(100% + 1rem);left:50%;transform:translate(-50%)}.share-toast{color:#0b1018;background:#8ef0b4f2;box-shadow:0 10px 25px #8ef0b44d}.success-toast{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--accent);color:var(--accent);text-align:center;background:#8ef0b414;border-radius:14px;justify-content:center;align-items:center;gap:.8rem;width:100%;margin-bottom:2.5rem;padding:1.25rem;font-weight:600;display:flex;position:relative;box-shadow:0 8px 32px #0003}.premium-glass{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff08;border:1px solid #ffffff14;border-radius:1.5rem}.comment-count-chip{color:var(--accent);opacity:.6;font-size:1.1rem;font-weight:500}.skeleton-comment{pointer-events:none}.avatar-skeleton{border-radius:14px;flex-shrink:0;width:3.2rem;height:3.2rem}.title-skeleton{width:140px;height:1.2rem;margin-bottom:.75rem}.text-skeleton{width:100%;height:.9rem;margin-bottom:.5rem}.text-skeleton.short{width:60%}.empty-comments{text-align:center;color:var(--muted);padding:3rem;font-style:italic}.post-prose__inline-code{color:var(--accent);background:#ffffff1a;border-radius:.25rem;padding:.15rem .3rem;font-family:monospace;font-size:.9em}.post-prose__code-block{border-radius:8px;margin:1.5rem 0;overflow:hidden;box-shadow:0 4px 12px #0003}.post-prose__code-filename{color:#9cdcfe;background:#1e1e1e;border-bottom:1px solid #333;padding:.5rem 1rem;font-family:monospace;font-size:.85rem}.reading-progress{z-index:1000;background:0 0;width:100%;height:3px;position:fixed;top:0;left:0}.reading-progress__bar{background:linear-gradient(90deg, var(--accent), #9bffc1);height:100%;transition:width .1s ease-out;box-shadow:0 0 10px #55e6a566}.post-prose__callout{background:#131b2866;border:1px solid #ffffff1a;border-radius:12px;gap:1rem;margin:1.5rem 0;padding:1.25rem 1.5rem;display:flex}.post-prose__callout--info{border-left:4px solid #3b82f6}.post-prose__callout--tip{border-left:4px solid var(--accent)}.post-prose__callout--warning{border-left:4px solid #f59e0b}.post-prose__callout--success{border-left:4px solid #10b981}.post-prose__callout-icon{flex-shrink:0;margin-top:.1rem}.post-prose__callout-text{color:var(--foreground);font-size:.95rem;line-height:1.6}.post-toc{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0b101866;border:1px solid #ffffff14;border-radius:1.5rem;max-height:calc(100vh - 8rem);padding:1.8rem;position:sticky;top:6rem;overflow-y:auto;box-shadow:0 10px 30px #0003,inset 0 0 0 1px #ffffff08}.post-toc::-webkit-scrollbar{width:4px}.post-toc::-webkit-scrollbar-track{background:0 0}.post-toc::-webkit-scrollbar-thumb{background:#8ef0b41a;border-radius:10px}.post-toc::-webkit-scrollbar-thumb:hover{background:#8ef0b44d}.post-toc__title{letter-spacing:.15em;text-transform:uppercase;color:var(--accent);opacity:.8;align-items:center;gap:.6rem;margin-bottom:1.5rem;font-size:.7rem;font-weight:800;display:flex}.post-toc__title:before{content:"";background:var(--accent);opacity:.5;width:12px;height:1px;display:inline-block}.post-toc__list{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.post-toc__item{color:var(--muted);border-radius:8px;font-size:.88rem;line-height:1.4;transition:all .3s cubic-bezier(.16,1,.3,1);position:relative}.post-toc__link{padding:.5rem .8rem;transition:transform .3s;display:block}.post-toc__item:hover{color:var(--foreground);background:#ffffff08}.post-toc__item.active{color:var(--accent);background:#8ef0b40f;font-weight:600}.post-toc__item:after{content:"";background:var(--accent);opacity:0;border-radius:0 4px 4px 0;width:3px;height:1rem;transition:all .4s cubic-bezier(.16,1,.3,1);position:absolute;top:50%;left:0;transform:translateY(-50%)scaleY(0)}.post-toc__item.active:after{opacity:1;transform:translateY(-50%)scaleY(1)}.post-toc__item--h3{padding-left:1rem;font-size:.82rem}.post-toc__item--h3.active:after{left:1rem}.post-badge{letter-spacing:.05em;text-transform:uppercase;border:1px solid #ffffff1a;border-radius:999px;align-items:center;padding:.35rem .75rem;font-size:.72rem;font-weight:700;display:inline-flex}.post-badge--beginner{color:#10b981;background:#10b9811a;border-color:#10b98133}.post-badge--intermediate{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b33}.post-badge--advanced{color:#ef4444;background:#ef44441a;border-color:#ef444433}.post-detail__layout{grid-template-columns:260px 1fr;align-items:stretch;gap:3rem;display:grid}.post-detail__sidebar{display:block}.post-detail__main{min-width:0}@media (max-width:1024px){.post-detail__layout{grid-template-columns:1fr;gap:2rem}.post-detail__sidebar{display:none}}.floating-share{z-index:90;opacity:0;pointer-events:none;transition:all .5s cubic-bezier(.16,1,.3,1);position:fixed;top:50%;right:2rem;transform:translateY(-50%)translate(100px)}.floating-share.show{opacity:1;pointer-events:auto;transform:translateY(-50%)translate(0)}.floating-share__inner{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0b101899;border:1px solid #ffffff14;border-radius:99px;flex-direction:column;gap:.75rem;padding:.75rem;display:flex;box-shadow:0 20px 50px #0000004d}.floating-share__btn{width:2.8rem;height:2.8rem;color:var(--muted);cursor:pointer;background:#ffffff08;border:1px solid #ffffff0d;border-radius:50%;place-items:center;transition:all .3s cubic-bezier(.16,1,.3,1);display:grid;position:relative}.floating-share__btn:hover{color:var(--hover-color,var(--accent));background:#ffffff14;border-color:#ffffff26;transform:scale(1.1)}.floating-share__btn.copied{color:var(--accent);border-color:var(--accent);background:#8ef0b41a}.floating-share__tooltip{background:var(--accent);color:#0b1018;white-space:nowrap;opacity:0;pointer-events:none;border-radius:6px;padding:.5rem .8rem;font-size:.75rem;font-weight:700;transition:all .3s cubic-bezier(.16,1,.3,1);position:absolute;top:50%;right:calc(100% + 1rem);transform:translateY(-50%)translate(10px);box-shadow:0 10px 20px #0003}.floating-share__tooltip:after{content:"";border-style:solid;border-width:5px;border-color:transparent transparent transparent var(--accent);position:absolute;top:50%;left:100%;transform:translateY(-50%)}.floating-share__btn:hover .floating-share__tooltip{opacity:1;transform:translateY(-50%)translate(0)}.floating-share__divider{background:#ffffff1a;width:1.5rem;height:1px;margin:.25rem auto}@media (max-width:1200px){.floating-share{right:1rem}}@media (max-width:768px){.floating-share{display:none}}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
