@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-sans:"Pretendard Variable", Pretendard, "Apple SD Gothic Neo", "Noto Sans KR", -apple-system, BlinkMacSystemFont, system-ui, "Segoe UI", Helvetica, Arial, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-widest:.1em;--leading-relaxed:1.625;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 2px #1a140e0f}@supports (color:color-mix(in lab,red,red)){:root,:host{--shadow-sm:0 1px 2px color-mix(in oklch, var(--color-text-primary), transparent 94%)}}:root,:host{--shadow-md:0 12px 28px #1a140e17, 0 2px 8px #006f650f}@supports (color:color-mix(in lab,red,red)){:root,:host{--shadow-md:0 12px 28px color-mix(in oklch, var(--color-text-primary), transparent 91%), 0 2px 8px color-mix(in oklch, var(--color-accent), transparent 94%)}}:root,:host{--shadow-lg:0 28px 56px #1a140e1f, 0 8px 20px #006f6514}@supports (color:color-mix(in lab,red,red)){:root,:host{--shadow-lg:0 28px 56px color-mix(in oklch, var(--color-text-primary), transparent 88%), 0 8px 20px color-mix(in oklch, var(--color-accent), transparent 92%)}}:root,:host{--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);--color-bg-primary:oklch(97.8% .009 83);--color-bg-secondary:oklch(94.8% .014 86);--color-bg-tertiary:oklch(90.4% .018 88);--color-text-primary:oklch(19.8% .016 72);--color-text-secondary:oklch(38.5% .017 77);--color-text-tertiary:oklch(56.2% .018 78);--color-accent:oklch(48.5% .103 184);--color-accent-strong:oklch(43.8% .14 184);--color-accent-hover:oklch(39.6% .109 184);--color-accent-light:oklch(92.4% .039 184);--color-border:oklch(84.2% .021 84);--color-border-strong:oklch(66.4% .026 82);--color-verified:oklch(62% .16 155);--color-cat-ai:oklch(48.5% .103 184);--color-cat-dev:oklch(46% .09 252);--color-cat-guide:oklch(47.2% .088 137);--font-display:"Pretendard Variable", Pretendard, "Apple SD Gothic Neo", "Noto Sans KR", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--radius-pill:9999px}}@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;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{.collapse{visibility:collapse}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-8{top:calc(var(--spacing) * 8)}.top-10{top:calc(var(--spacing) * 10)}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.m-0{margin:calc(var(--spacing) * 0)}.mx-auto{margin-inline:auto}.my-8{margin-block:calc(var(--spacing) * 8)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mt-14{margin-top:calc(var(--spacing) * 14)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-10{margin-bottom:calc(var(--spacing) * 10)}.mb-16{margin-bottom:calc(var(--spacing) * 16)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.min-h-screen{min-height:100vh}.max-w-\[720px\]{max-width:720px}.flex-1{flex:1}.flex-shrink,.shrink{flex-shrink:1}.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.scroll-mt-20{scroll-margin-top:calc(var(--spacing) * 20)}.list-none{list-style-type:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.justify-center{justify-content:center}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-4{gap:calc(var(--spacing) * 4)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.rounded-\[24px\]{border-radius:24px}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-border{border-color:var(--color-border)}.bg-bg-secondary{background-color:var(--color-bg-secondary)}.p-0{padding:calc(var(--spacing) * 0)}.p-5{padding:calc(var(--spacing) * 5)}.p-8{padding:calc(var(--spacing) * 8)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-12{padding-block:calc(var(--spacing) * 12)}.pt-8{padding-top:calc(var(--spacing) * 8)}.text-center{text-align:center}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.text-\[20px\]{font-size:20px}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-wrap{text-wrap:wrap}.text-text-tertiary{color:var(--color-text-tertiary)}.uppercase{text-transform:uppercase}.no-underline{text-decoration-line:none}.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)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);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,)}.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,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.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))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media(min-width:40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:px-6{padding-inline:calc(var(--spacing) * 6)}.sm\:py-20{padding-block:calc(var(--spacing) * 20)}.sm\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}}@media(min-width:64rem){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:80rem){.xl\:block{display:block}.xl\:hidden{display:none}}}.dark{--color-bg-primary:oklch(18.5% .013 82);--color-bg-secondary:oklch(23.3% .014 82);--color-bg-tertiary:oklch(29% .016 82);--color-text-primary:oklch(94.5% .012 86);--color-text-secondary:oklch(77% .018 86);--color-text-tertiary:oklch(61.5% .018 86);--color-accent:oklch(73% .091 184);--color-accent-strong:oklch(79% .12 184);--color-accent-hover:oklch(80% .085 184);--color-cat-ai:oklch(73% .091 184);--color-cat-ai-light:#006f6524}@supports (color:color-mix(in lab,red,red)){.dark{--color-cat-ai-light:color-mix(in oklch, var(--color-cat-ai), transparent 86%)}}.dark{--color-cat-dev:oklch(76% .08 252);--color-cat-dev-light:#2f5a8924}@supports (color:color-mix(in lab,red,red)){.dark{--color-cat-dev-light:color-mix(in oklch, var(--color-cat-dev), transparent 86%)}}.dark{--color-cat-guide:oklch(74% .091 137);--color-cat-guide-light:#43673324}@supports (color:color-mix(in lab,red,red)){.dark{--color-cat-guide-light:color-mix(in oklch, var(--color-cat-guide), transparent 86%)}}.dark{--color-accent-light:#006f651f}@supports (color:color-mix(in lab,red,red)){.dark{--color-accent-light:color-mix(in oklch, var(--color-accent), transparent 88%)}}.dark{--color-verified:oklch(75% .13 155);--color-verified-light:#00a05b24}@supports (color:color-mix(in lab,red,red)){.dark{--color-verified-light:color-mix(in oklch, var(--color-verified), transparent 86%)}}.dark{--color-border:oklch(37% .015 82);--color-border-strong:oklch(49% .017 82);--shadow-sm:0 1px 2px oklch(10% .01 72/.3);--shadow-md:0 4px 18px oklch(10% .01 72/.45), 0 2px 8px oklch(10% .01 72/.32);--shadow-lg:0 14px 28px oklch(10% .01 72/.52), 0 7px 15px oklch(10% .01 72/.38)}html{font-family:var(--font-sans);color:var(--color-text-primary);background-color:var(--color-bg-primary);font-feature-settings:"lnum","locl";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{color:var(--color-text-primary);background:linear-gradient(90deg,#d2cabc2e 1px,transparent 1px),linear-gradient(0deg,#d2cabc24 1px,transparent 1px),var(--color-bg-primary);line-height:1.6}@supports (color:color-mix(in lab,red,red)){body{background:linear-gradient(90deg,color-mix(in oklch,var(--color-border),transparent 82%) 1px,transparent 1px),linear-gradient(0deg,color-mix(in oklch,var(--color-border),transparent 86%) 1px,transparent 1px),var(--color-bg-primary)}}body{background-size:44px 44px,44px 44px,auto;transition:background-color .2s,color .2s}body:before{content:"";z-index:60;pointer-events:none;opacity:.16;mix-blend-mode:multiply;background-image:linear-gradient(115deg,#0000 0 48%,#1a140e0a 48% 52%,#0000 52% 100%);position:fixed;inset:0}@supports (color:color-mix(in lab,red,red)){body:before{background-image:linear-gradient(115deg,transparent 0 48%,color-mix(in oklch,var(--color-text-primary),transparent 96%) 48% 52%,transparent 52% 100%)}}body:before{background-size:9px 9px}.dark body:before{opacity:.08;mix-blend-mode:screen}.skip-link{z-index:80;border-radius:var(--radius-md);background:var(--color-text-primary);color:var(--color-bg-primary);padding:10px 14px;font-size:13px;font-weight:700;text-decoration:none;transition:transform .18s;position:fixed;top:12px;left:16px;transform:translateY(-160%)}.skip-link:focus{transform:translateY(0)}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.site-header{z-index:50;border-bottom:1px solid #d2cabce6;position:sticky;top:0}@supports (color:color-mix(in lab,red,red)){.site-header{border-bottom:1px solid color-mix(in oklch,var(--color-border),transparent 10%)}}.site-header{background:#fbf7f1e6}@supports (color:color-mix(in lab,red,red)){.site-header{background:color-mix(in oklch,var(--color-bg-primary),transparent 10%)}}.site-header{-webkit-backdrop-filter:blur(18px)saturate(1.1);backdrop-filter:blur(18px)saturate(1.1);box-shadow:inset 0 1px #fbf7f1b3}@supports (color:color-mix(in lab,red,red)){.site-header{box-shadow:0 1px color-mix(in oklch,var(--color-bg-primary),transparent 30%) inset}}.site-nav{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:18px;width:min(1280px,100% - 28px);min-height:68px;margin:0 auto;display:grid}.site-brand{color:var(--color-text-primary);font-family:var(--font-display);letter-spacing:0;align-items:center;gap:10px;font-size:15px;font-weight:860;display:inline-flex}.brand-mark{color:var(--color-accent);filter:drop-shadow(0 8px 14px #006f6533);display:inline-grid}@supports (color:color-mix(in lab,red,red)){.brand-mark{filter:drop-shadow(0 8px 14px color-mix(in oklch,var(--color-accent),transparent 80%))}}.desktop-nav{justify-content:center;align-items:center;gap:3px;display:none}.nav-link,.mobile-menu-link{color:var(--color-text-secondary);font-size:14px;font-weight:720;text-decoration:none;transition:color .18s,background-color .18s,transform .18s}.nav-link{border-radius:var(--radius-md);align-items:center;min-height:36px;padding:0 12px;display:inline-flex}.nav-link:hover,.nav-link.is-active{color:var(--color-text-primary);background:#e4dfd2bd}@supports (color:color-mix(in lab,red,red)){.nav-link:hover,.nav-link.is-active{background:color-mix(in oklch,var(--color-bg-tertiary),transparent 26%)}}.nav-tools{align-items:center;gap:8px;display:none}.nav-search,.mobile-search,.hero-search{border:1px solid var(--color-border);background:#fbf7f1eb;align-items:center;display:flex}@supports (color:color-mix(in lab,red,red)){.nav-search,.mobile-search,.hero-search{background:color-mix(in oklch,var(--color-bg-primary),transparent 8%)}}.nav-search,.mobile-search,.hero-search{transition:border-color .18s,box-shadow .18s,transform .18s;box-shadow:inset 0 1px oklch(100% 5.96046e-8 none/.6)}.nav-search:focus-within,.mobile-search:focus-within,.hero-search:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 4px #006f6529}@supports (color:color-mix(in lab,red,red)){.nav-search:focus-within,.mobile-search:focus-within,.hero-search:focus-within{box-shadow:0 0 0 4px color-mix(in oklch,var(--color-accent),transparent 84%)}}.nav-search{border-radius:var(--radius-md);width:clamp(190px,24vw,320px);height:40px;overflow:hidden}.nav-search input,.mobile-search input,.hero-search input{min-width:0;color:var(--color-text-primary);font:inherit;background:0 0;border:0;outline:0;flex:1}.nav-search input{padding:0 10px 0 13px;font-size:13px}.nav-search button,.mobile-search button,.hero-search button{cursor:pointer;color:var(--color-bg-primary);background:linear-gradient(135deg,var(--color-accent),var(--color-accent-strong));border:0;font-weight:760;box-shadow:0 12px 24px #006f6538}@supports (color:color-mix(in lab,red,red)){.nav-search button,.mobile-search button,.hero-search button{box-shadow:0 12px 24px color-mix(in oklch,var(--color-accent),transparent 78%)}}.nav-search button,.mobile-search button,.hero-search button{transition:transform .18s,background-color .18s,box-shadow .18s}.nav-search button{align-self:stretch;place-items:center;width:38px;display:inline-grid}.nav-search button:active,.mobile-search button:active,.hero-search button:active,.icon-button:active,.language-switch:active{transform:translateY(1px)scale(.98)}.nav-search button:hover,.mobile-search button:hover,.hero-search button:hover{box-shadow:0 16px 28px #006f6547}@supports (color:color-mix(in lab,red,red)){.nav-search button:hover,.mobile-search button:hover,.hero-search button:hover{box-shadow:0 16px 28px color-mix(in oklch,var(--color-accent),transparent 72%)}}.language-switch,.icon-button{border-radius:var(--radius-md);border:1px solid #589589;justify-content:center;align-items:center;height:38px;display:inline-flex}@supports (color:color-mix(in lab,red,red)){.language-switch,.icon-button{border:1px solid color-mix(in oklch,var(--color-accent),var(--color-border) 42%)}}.language-switch,.icon-button{background:#d3f0ea}@supports (color:color-mix(in lab,red,red)){.language-switch,.icon-button{background:color-mix(in oklch,var(--color-accent-light),var(--color-bg-primary) 18%)}}.language-switch,.icon-button{color:var(--color-text-primary);box-shadow:0 8px 18px #006f651f}@supports (color:color-mix(in lab,red,red)){.language-switch,.icon-button{box-shadow:0 8px 18px color-mix(in oklch,var(--color-accent),transparent 88%)}}.language-switch,.icon-button{transition:border-color .18s,background-color .18s,color .18s,transform .18s,box-shadow .18s}.language-switch{min-width:38px;color:var(--color-accent);padding:0 10px;font-size:12px;font-weight:820}.language-switch.is-disabled{color:var(--color-text-tertiary);cursor:not-allowed;opacity:.72}.icon-button{cursor:pointer;width:38px}.language-switch:hover,.icon-button:hover{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-strong));color:var(--color-bg-primary);border-color:#0000;box-shadow:0 14px 26px #006f653d}@supports (color:color-mix(in lab,red,red)){.language-switch:hover,.icon-button:hover{box-shadow:0 14px 26px color-mix(in oklch,var(--color-accent),transparent 76%)}}.mobile-nav-actions{justify-content:flex-end;align-items:center;gap:7px;display:flex}.mobile-menu{border:1px solid var(--color-border);border-radius:0 0 var(--radius-lg) var(--radius-lg);background:#fbf7f1f5;width:min(1280px,100% - 28px);margin:0 auto 14px;padding:12px}@supports (color:color-mix(in lab,red,red)){.mobile-menu{background:color-mix(in oklch,var(--color-bg-primary),transparent 4%)}}.mobile-menu{box-shadow:var(--shadow-md)}.mobile-search{border-radius:var(--radius-md);min-height:46px;overflow:hidden}.mobile-search input{padding:0 13px;font-size:15px}.mobile-search button{align-self:stretch;padding:0 15px;font-size:13px}.mobile-menu-links{gap:4px;padding-top:10px;display:grid}.mobile-menu-link{border-radius:var(--radius-md);align-items:center;min-height:42px;padding:0 10px;display:flex}.mobile-menu-link:hover,.mobile-menu-link.is-active{color:var(--color-text-primary);background:var(--color-bg-secondary)}.site-footer{border-top:1px solid var(--color-border);background:#f2ede3d1;margin-top:auto}@supports (color:color-mix(in lab,red,red)){.site-footer{background:color-mix(in oklch,var(--color-bg-secondary),transparent 18%)}}.site-footer{color:var(--color-text-tertiary)}.site-footer-inner{flex-direction:column;gap:18px;width:min(1280px,100% - 32px);margin:0 auto;padding:30px 0;font-size:13px;display:flex}.site-footer-inner>div:first-child{gap:4px;display:grid}.site-footer strong{color:var(--color-text-primary)}.footer-links{flex-wrap:wrap;gap:14px;display:flex}.footer-links a{color:var(--color-text-tertiary)}.footer-links a:hover{color:var(--color-text-primary)}@media(min-width:860px){.desktop-nav,.nav-tools{display:flex}.mobile-nav-actions{display:none}.site-footer-inner{flex-direction:row;justify-content:space-between;align-items:center}}.prose{max-width:68ch;color:var(--color-text-primary);letter-spacing:0;word-break:keep-all;overflow-wrap:break-word;font-variant-numeric:tabular-nums;font-size:clamp(17.25px,1.4vw,18.5px);line-height:1.92}.prose h1{letter-spacing:0;text-wrap:balance;margin-top:0;margin-bottom:22px;font-size:clamp(34px,4vw,42px);font-weight:820;line-height:1.12}.prose h2{letter-spacing:0;border-top:1px solid #d2cabceb;margin-top:86px;margin-bottom:22px;padding-top:24px;font-size:clamp(24px,3.2vw,31px);font-weight:820;line-height:1.34;position:relative}@supports (color:color-mix(in lab,red,red)){.prose h2{border-top:1px solid color-mix(in oklch,var(--color-border),transparent 8%)}}.prose h2{text-wrap:balance;scroll-margin-top:88px}.prose h2:before{content:"";border-radius:var(--radius-pill);background:var(--color-accent);width:46px;height:3px;margin-bottom:16px;display:block}.prose h3{letter-spacing:0;text-wrap:balance;margin-top:48px;margin-bottom:12px;font-size:clamp(20px,2.1vw,23px);font-weight:800;line-height:1.4}.prose p{text-wrap:pretty;margin:0 0 22px}.prose>p:first-of-type{color:var(--color-text-primary);font-size:clamp(18px,1.8vw,20px);line-height:1.86}.prose.prose-has-summary>.summary-box:first-child,.prose.prose-has-summary>.post-toc+.summary-box{display:none}.prose>h2+p{border:1px solid var(--color-border);border-left:5px solid var(--color-accent);border-radius:var(--radius-lg);background:var(--color-bg-secondary);margin-bottom:26px;padding:17px 18px}.prose strong{color:var(--color-text-primary);font-weight:820}.prose a{color:var(--color-accent);-webkit-text-decoration:underline #006f6557;text-decoration:underline #006f6557}@supports (color:color-mix(in lab,red,red)){.prose a{-webkit-text-decoration-color:color-mix(in srgb,var(--color-accent),transparent 66%);text-decoration-color:color-mix(in srgb,var(--color-accent),transparent 66%)}}.prose a{text-underline-offset:3px;transition:text-decoration-color .15s}.prose a:hover{-webkit-text-decoration-color:var(--color-accent);text-decoration-color:var(--color-accent)}.prose blockquote{border:1px solid var(--color-border);border-left:5px solid var(--color-accent);border-radius:var(--radius-lg);background:var(--color-bg-secondary);color:var(--color-text-secondary);margin:38px 0;padding:20px 22px}.prose blockquote p:last-child{margin-bottom:0}.prose code{font-family:var(--font-mono);background:#e4dfd2eb;font-size:.84em}@supports (color:color-mix(in lab,red,red)){.prose code{background:color-mix(in oklch,var(--color-bg-tertiary),transparent 8%)}}.prose code{border-radius:var(--radius-sm);border:1px solid #d2cabccc;padding:2px 6px 3px}@supports (color:color-mix(in lab,red,red)){.prose code{border:1px solid color-mix(in oklch,var(--color-border),transparent 20%)}}.prose pre{background:#e9e5db}@supports (color:color-mix(in lab,red,red)){.prose pre{background:color-mix(in oklch,var(--color-bg-secondary),var(--color-text-primary) 4%)}}.prose pre{border:1px solid var(--color-border);border-radius:var(--radius-lg);margin:34px 0;padding:20px;line-height:1.72;position:relative;overflow-x:auto}.prose pre code{background:0 0;border:0;padding:0;font-size:13.5px}.prose pre .code-copy-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-primary);color:var(--color-text-tertiary);cursor:pointer;opacity:0;align-items:center;gap:4px;padding:4px 8px;font-family:inherit;font-size:11px;transition:opacity .15s,color .15s,background .15s;display:flex;position:absolute;top:8px;right:8px}.prose pre:hover .code-copy-btn,.prose pre:focus-within .code-copy-btn{opacity:1}.prose pre .code-copy-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.prose>img,.prose>p>img,.prose>figure:not(.image-guide) img{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin:36px 0 10px}.prose>figure:not(.image-guide) figcaption{color:var(--color-text-tertiary);text-align:center;margin-top:12px;font-size:13px;line-height:1.6}.prose>table{border-collapse:collapse;border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:100%;margin:36px 0;font-size:14px;line-height:1.65;display:block;overflow-x:auto}.prose>table::-webkit-scrollbar{height:8px}.prose>table::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-pill)}.prose>table th{text-align:left;border-bottom:2px solid var(--color-border-strong);background:#eceee4;padding:12px 14px;font-weight:780}@supports (color:color-mix(in lab,red,red)){.prose>table th{background:color-mix(in oklch,var(--color-bg-secondary),var(--color-accent-light) 14%)}}.prose>table td{border-bottom:1px solid var(--color-border);padding:12px 14px}.prose ul,.prose ol{margin:0 0 24px;padding-left:26px}.prose li{margin-bottom:8px;padding-left:2px}.prose li::marker{color:var(--color-accent);font-weight:800}.prose li>p{margin-bottom:10px}@media(max-width:640px){.prose{overflow-wrap:anywhere;max-width:100%;font-size:16.5px;line-height:1.8}.prose p{margin-bottom:19px}.prose>p:first-of-type{font-size:17px;line-height:1.78}.prose h2{margin-top:52px;margin-bottom:16px;padding-top:18px;scroll-margin-top:80px;font-size:23px;line-height:1.32}.prose h2:before{width:42px;margin-bottom:13px}.prose h3{margin-top:38px;margin-bottom:10px;font-size:19px;line-height:1.36}.prose>h2+p,.prose>h2+p:first-of-type{border-radius:var(--radius-md);border-left-width:4px;margin-bottom:22px;padding:13px 14px;font-size:16.5px;line-height:1.74}.prose blockquote{border-radius:var(--radius-md);border-left-width:4px;margin:30px 0;padding:16px}.prose pre{border-radius:var(--radius-md);-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;margin:28px 0;padding:16px 14px;line-height:1.62}.prose pre code{font-size:12.75px}.prose>table{white-space:nowrap;border-radius:var(--radius-md);-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;margin:30px 0;font-size:13px;line-height:1.56;box-shadow:inset -28px 0 18px -24px #006f6594}@supports (color:color-mix(in lab,red,red)){.prose>table{box-shadow:inset -28px 0 18px -24px color-mix(in oklch,var(--color-accent),transparent 42%)}}.prose>table th,.prose>table td{padding:10px 12px}.prose ul,.prose ol{margin-bottom:20px;padding-left:22px}.prose li{margin-bottom:6px}.prose>img,.prose>p>img,.prose>figure:not(.image-guide) img{border-radius:var(--radius-md);margin:28px 0 8px}.prose>figure:not(.image-guide) figcaption{font-size:12.5px;line-height:1.5}.prose pre .code-copy-btn{opacity:1}}.prose hr{border:none;border-top:1px solid var(--color-border);margin:56px 0}.reading-progress{z-index:45;background:0 0;height:3px;position:sticky;top:68px}.reading-progress span{background:var(--color-accent);transform-origin:0;width:100%;height:100%;transition:transform 80ms linear;display:block;transform:scaleX(0)}.post-layout{grid-template-columns:minmax(0,1fr);align-items:flex-start;gap:56px;width:min(1180px,100% - 32px);margin:0 auto;padding:38px 0 76px;display:grid}@media(min-width:640px){.post-layout{width:min(1180px,100% - 48px);padding:58px 0 96px}}.post-article{width:100%;min-width:0;max-width:740px;margin:0 auto}.post-head{border-bottom:1px solid var(--color-border);gap:16px;margin-bottom:36px;padding-bottom:30px;display:grid}.post-kicker-row{flex-wrap:wrap;gap:8px;display:flex}.post-category-chip{border-radius:var(--radius-sm);align-items:center;min-height:27px;padding:0 9px;font-size:12px;font-weight:840;text-decoration:none;display:inline-flex}.post-title{max-width:860px;color:var(--color-text-primary);font-family:var(--font-display);letter-spacing:0;text-wrap:balance;margin:0;font-size:clamp(32px,5vw,52px);font-weight:900;line-height:1.12}.post-description{max-width:720px;color:var(--color-text-secondary);text-wrap:pretty;margin:0 0 18px;font-size:clamp(17px,1.6vw,19px);line-height:1.82}.post-meta{color:var(--color-text-tertiary);flex-wrap:wrap;gap:8px 14px;font-size:13px;line-height:1.5;display:flex}.post-meta span{align-items:center;gap:8px;display:inline-flex}.post-meta span+span:before{content:"";border-radius:var(--radius-pill);background:var(--color-border-strong);width:4px;height:4px}.post-hero-figure{margin:0 0 44px}.post-hero-figure img{border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;box-shadow:var(--shadow-md);display:block}.article-afterword{border-top:1px solid var(--color-border);gap:34px;margin-top:62px;padding-top:26px;display:grid}.article-panel{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-secondary);padding:18px 20px}.article-panel:first-of-type{border-top:1px solid var(--color-border)}.article-panel-head{gap:5px;display:grid}.article-panel-eyebrow{color:var(--color-text-tertiary);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:12px;font-weight:820}.article-panel-copy{color:var(--color-text-secondary);margin:0;font-size:14px;line-height:1.65}.share-panel{gap:16px;display:grid}.share-actions,.topic-links{flex-wrap:wrap;gap:8px;display:flex}.article-chip,.topic-link{border-radius:var(--radius-md);justify-content:center;align-items:center;min-height:36px;font-size:13px;font-weight:780;text-decoration:none;transition:transform .16s,border-color .16s,background-color .16s,color .16s,box-shadow .16s;display:inline-flex}.article-chip{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-strong));color:var(--color-bg-primary);border:1px solid #0000;padding:0 12px;box-shadow:0 12px 24px #006f652e}@supports (color:color-mix(in lab,red,red)){.article-chip{box-shadow:0 12px 24px color-mix(in oklch,var(--color-accent),transparent 82%)}}.article-chip{cursor:pointer}.topic-link{border:1px solid #71a094;padding:0 11px}@supports (color:color-mix(in lab,red,red)){.topic-link{border:1px solid color-mix(in oklch,var(--color-accent),var(--color-border) 54%)}}.topic-link{background:#d4f1ea}@supports (color:color-mix(in lab,red,red)){.topic-link{background:color-mix(in oklch,var(--color-accent-light),var(--color-bg-primary) 20%)}}.topic-link{color:var(--color-accent-strong)}.article-chip:hover,.topic-link:hover{transform:translateY(-1px);box-shadow:0 16px 28px #006f653d}@supports (color:color-mix(in lab,red,red)){.article-chip:hover,.topic-link:hover{box-shadow:0 16px 28px color-mix(in oklch,var(--color-accent),transparent 76%)}}.topic-link:hover{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-strong));color:var(--color-bg-primary);border-color:#0000}.article-chip:active,.topic-link:active{transform:translateY(1px)scale(.98)}.related-panel{gap:18px;display:grid}.related-head{justify-content:space-between;align-items:flex-end;gap:16px;display:flex}.related-title{color:var(--color-text-primary);letter-spacing:0;margin:0;font-size:22px;font-weight:820;line-height:1.32}.related-subtitle{color:var(--color-text-tertiary);font-size:13px}.related-grid{grid-template-columns:1fr;gap:14px;display:grid}.author-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-secondary);color:var(--color-text-secondary);margin-top:44px;padding:18px 20px 20px;font-size:14px;line-height:1.7}.author-card strong{color:var(--color-text-primary);font-weight:820}.author-card a{color:var(--color-accent);font-weight:760;text-decoration:none}@media(max-width:640px){.post-layout{gap:40px;width:min(100% - 24px,100%);padding:30px 0 68px}.post-head{gap:13px;margin-bottom:28px;padding-bottom:24px}.post-category-chip{min-height:25px;padding:0 8px;font-size:11px}.post-title{font-size:clamp(29px,8vw,32px);line-height:1.15}.post-description{margin-bottom:12px;font-size:16px;line-height:1.72}.post-meta{gap:6px 10px;font-size:12px;line-height:1.45}.post-meta span{gap:6px}.post-meta span+span:before{width:3px;height:3px}.post-hero-figure{margin-bottom:34px}.post-hero-figure img{border-radius:var(--radius-lg)}.article-afterword{gap:26px;margin-top:48px;padding-top:22px}.article-panel{border-radius:var(--radius-md);padding:16px}.share-panel{gap:14px}.article-chip,.topic-link{min-height:38px}.share-actions .article-chip{flex:calc(50% - 4px)}.related-head{flex-direction:column;align-items:flex-start;gap:4px}.related-title{font-size:20px}.author-card{border-radius:var(--radius-md);margin-top:34px;padding:16px}}@media(min-width:720px){.share-panel{grid-template-columns:minmax(0,1fr) auto;align-items:end}.share-actions{justify-content:flex-end}.related-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.toc-sidebar{display:none}@media(min-width:1100px){.toc-sidebar{width:260px;max-height:calc(100vh - 120px);display:block;position:sticky;top:92px;overflow-y:auto}.post-layout{grid-template-columns:minmax(0,740px) 260px;justify-content:center}.post-article{margin:0}}.toc-nav{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-secondary);padding:16px}.toc-title{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);margin:0 0 12px;padding:0;font-size:12px;font-weight:820}.toc-list{border-left:1px solid var(--color-border);margin:0;padding:0;list-style:none}.toc-list li{margin:0}.toc-link{color:var(--color-text-tertiary);border-left:1px solid #0000;margin-left:-1px;padding:5px 0 5px 13px;font-size:13px;line-height:1.5;text-decoration:none;transition:color .15s,border-color .15s;display:block}.toc-link:hover{color:var(--color-text-secondary)}.toc-link.toc-active{color:var(--color-accent);border-left-color:var(--color-accent);font-weight:500}.techjup-pet{right:calc(18px + env(safe-area-inset-right));bottom:calc(18px + env(safe-area-inset-bottom));z-index:75;width:max-content;color:var(--color-text-primary);font-family:var(--font-mono);pointer-events:none;-webkit-user-select:none;user-select:none;touch-action:none;transition:opacity .18s,transform .18s;display:block;position:fixed;transform:none}.techjup-pet[data-has-position=true]{bottom:auto;right:auto}.techjup-pet__creature{min-width:78px;min-height:82px;color:var(--color-text-primary);cursor:grab;filter:drop-shadow(0 12px 18px #1a140e2e);background:0 0;border:0;place-items:center;padding:8px 7px 7px;display:grid;position:relative}@supports (color:color-mix(in lab,red,red)){.techjup-pet__creature{filter:drop-shadow(0 12px 18px color-mix(in oklch,var(--color-text-primary),transparent 82%))}}.techjup-pet__creature{pointer-events:auto;text-align:center;touch-action:none;-webkit-tap-highlight-color:transparent;transition:filter .18s,opacity .18s,transform .18s cubic-bezier(.16,1,.3,1)}.techjup-pet__creature:before,.techjup-pet__creature:after{content:"";opacity:0;pointer-events:none;border-radius:999px;transition:opacity .18s,transform .18s;position:absolute}.techjup-pet__creature:before{background:radial-gradient(circle,#006f6547,#0000 68%);inset:16px 8px 8px}@supports (color:color-mix(in lab,red,red)){.techjup-pet__creature:before{background:radial-gradient(circle,color-mix(in oklch,var(--color-accent),transparent 72%),transparent 68%)}}.techjup-pet__creature:before{filter:blur(7px)}.techjup-pet__creature:after{border:1px dashed #006f6570;inset:4px 2px}@supports (color:color-mix(in lab,red,red)){.techjup-pet__creature:after{border:1px dashed color-mix(in oklch,var(--color-accent),transparent 56%)}}.techjup-pet__creature:after{transform:scale(.88)}.techjup-pet__creature:hover{filter:drop-shadow(0 16px 22px #1a140e38)}@supports (color:color-mix(in lab,red,red)){.techjup-pet__creature:hover{filter:drop-shadow(0 16px 22px color-mix(in oklch,var(--color-text-primary),transparent 78%))}}.techjup-pet__creature:hover{transform:translateY(-1px)}.techjup-pet__creature:active,.techjup-pet.is-pressing .techjup-pet__creature{transform:translateY(1px)scale(.98)}.techjup-pet.is-dragging .techjup-pet__creature{cursor:grabbing;transform:scale(.96)rotate(-1.5deg)}.techjup-pet__creature:focus-visible{outline:2px solid var(--color-accent);outline-offset:5px;border-radius:18px}.techjup-pet__level{z-index:1;border:1px solid #d2cabccc;align-items:center;min-height:18px;padding:0 6px;display:inline-flex;position:absolute;top:0;right:0}@supports (color:color-mix(in lab,red,red)){.techjup-pet__level{border:1px solid color-mix(in oklch,var(--color-border),transparent 20%)}}.techjup-pet__level{border-radius:var(--radius-pill);background:#fbf7f1e6}@supports (color:color-mix(in lab,red,red)){.techjup-pet__level{background:color-mix(in oklch,var(--color-bg-primary),transparent 10%)}}.techjup-pet__level{color:var(--color-accent-strong);box-shadow:var(--shadow-sm);font-family:var(--font-sans);letter-spacing:.02em;font-size:10px;font-weight:850}.techjup-pet__ascii{z-index:1;color:inherit;letter-spacing:.02em;white-space:pre;margin:0;font-size:13px;font-weight:850;line-height:1.12;position:relative}.techjup-pet[data-pet-level="1"] .techjup-pet__ascii{color:#312b24}@supports (color:color-mix(in lab,red,red)){.techjup-pet[data-pet-level="1"] .techjup-pet__ascii{color:color-mix(in oklch,var(--color-text-primary),var(--color-text-tertiary) 24%)}}.techjup-pet[data-pet-level="2"] .techjup-pet__ascii{color:#16211a}@supports (color:color-mix(in lab,red,red)){.techjup-pet[data-pet-level="2"] .techjup-pet__ascii{color:color-mix(in oklch,var(--color-text-primary),var(--color-accent) 14%)}}.techjup-pet[data-pet-level="2"] .techjup-pet__ascii{text-shadow:0 1px #fbf7f1bf}@supports (color:color-mix(in lab,red,red)){.techjup-pet[data-pet-level="2"] .techjup-pet__ascii{text-shadow:0 1px 0 color-mix(in oklch,var(--color-bg-primary),transparent 25%)}}.techjup-pet[data-pet-level="2"] .techjup-pet__creature:before{opacity:.42}.techjup-pet[data-pet-level="3"] .techjup-pet__ascii{color:var(--color-accent-strong);text-shadow:0 1px #fbf7f1bf,0 10px 24px #006f653d}@supports (color:color-mix(in lab,red,red)){.techjup-pet[data-pet-level="3"] .techjup-pet__ascii{text-shadow:0 1px 0 color-mix(in oklch,var(--color-bg-primary),transparent 25%),0 10px 24px color-mix(in oklch,var(--color-accent),transparent 76%)}}.techjup-pet[data-pet-level="3"] .techjup-pet__creature:before{opacity:.58;transform:scale(1.12)}.techjup-pet[data-pet-level="3"] .techjup-pet__creature:after{opacity:.52;transform:scale(1)}.techjup-pet[data-pet-mood=happy] .techjup-pet__creature{transform:translateY(-2px)}.techjup-pet[data-pet-mood=focused] .techjup-pet__creature{filter:drop-shadow(0 18px 24px #006f653d)}@supports (color:color-mix(in lab,red,red)){.techjup-pet[data-pet-mood=focused] .techjup-pet__creature{filter:drop-shadow(0 18px 24px color-mix(in oklch,var(--color-accent),transparent 76%))}}.techjup-pet[data-pet-mood=sleepy] .techjup-pet__creature{opacity:.72}.techjup-pet[data-pet-mood=dizzy] .techjup-pet__creature{transform:rotate(1.5deg)}.techjup-pet.is-leveling .techjup-pet__creature{animation:.92s cubic-bezier(.16,1,.3,1) techjup-pet-level}.techjup-pet.is-speaking .techjup-pet__creature{transform:translateY(-2px)}.techjup-pet__bubble{border:1px solid #b8bfb2;width:max-content;max-width:min(210px,100vw - 28px);padding:7px 9px;position:absolute;bottom:calc(100% + 7px);right:0}@supports (color:color-mix(in lab,red,red)){.techjup-pet__bubble{border:1px solid color-mix(in oklch,var(--color-border),var(--color-accent) 12%)}}.techjup-pet__bubble{background:#fbf7f1ed;border-radius:14px 14px 4px}@supports (color:color-mix(in lab,red,red)){.techjup-pet__bubble{background:color-mix(in oklch,var(--color-bg-primary),transparent 7%)}}.techjup-pet__bubble{color:var(--color-text-primary);box-shadow:0 1px oklch(100% 5.96046e-8 none/.42) inset,var(--shadow-sm);font-family:var(--font-sans);pointer-events:none;font-size:12px;font-weight:760;line-height:1.35}.dark .techjup-pet__bubble{box-shadow:0 1px oklch(100% 5.96046e-8 none/.12) inset,var(--shadow-sm)}.techjup-pet__bubble[hidden],.techjup-pet__popover[hidden],.techjup-pet__creature[hidden],.techjup-pet__wake[hidden]{display:none}.techjup-pet__popover{border:1px solid #bdc1b3;width:min(224px,100vw - 24px);padding:10px;position:absolute;bottom:calc(100% + 8px);right:0}@supports (color:color-mix(in lab,red,red)){.techjup-pet__popover{border:1px solid color-mix(in oklch,var(--color-border),var(--color-accent) 10%)}}.techjup-pet__popover{background:#fbf7f1f5;border-radius:18px}@supports (color:color-mix(in lab,red,red)){.techjup-pet__popover{background:color-mix(in oklch,var(--color-bg-primary),transparent 4%)}}.techjup-pet__popover{box-shadow:0 1px oklch(100% 5.96046e-8 none/.42) inset,var(--shadow-md);color:var(--color-text-primary);font-family:var(--font-sans);pointer-events:auto}.dark .techjup-pet__popover{box-shadow:0 1px oklch(100% 5.96046e-8 none/.12) inset,var(--shadow-md)}.techjup-pet__popover-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:9px;display:flex}.techjup-pet__popover-title{color:var(--color-text-primary);letter-spacing:-.01em;margin:0;font-size:13px;font-weight:860}.techjup-pet__icon-button{border:1px solid var(--color-border);background:#f2ede3d1;border-radius:12px;place-items:center;width:30px;height:30px;display:inline-grid}@supports (color:color-mix(in lab,red,red)){.techjup-pet__icon-button{background:color-mix(in oklch,var(--color-bg-secondary),transparent 18%)}}.techjup-pet__icon-button{color:var(--color-text-secondary);cursor:pointer}.techjup-pet__stats{gap:6px;margin:0;display:grid}.techjup-pet__stats div{justify-content:space-between;align-items:center;gap:10px;min-height:24px;display:flex}.techjup-pet__stats dt{color:var(--color-text-tertiary);font-size:11px;font-weight:760}.techjup-pet__stats dd{color:var(--color-text-primary);margin:0;font-size:12px;font-weight:820}.techjup-pet__progress{border-radius:var(--radius-pill);background:#d2cabca6;height:5px;margin:9px 0 10px;overflow:hidden}@supports (color:color-mix(in lab,red,red)){.techjup-pet__progress{background:color-mix(in oklch,var(--color-border),transparent 35%)}}.techjup-pet__progress span{border-radius:inherit;background:var(--color-accent);width:0%;height:100%;transition:width .24s;display:block}.techjup-pet__actions{grid-template-columns:1fr 1fr;gap:7px;display:grid}.techjup-pet__actions button,.techjup-pet__wake{border:1px solid #c1c3b5;min-height:36px}@supports (color:color-mix(in lab,red,red)){.techjup-pet__actions button,.techjup-pet__wake{border:1px solid color-mix(in oklch,var(--color-border),var(--color-accent) 8%)}}.techjup-pet__actions button,.techjup-pet__wake{background:#f2ede3e0;border-radius:13px}@supports (color:color-mix(in lab,red,red)){.techjup-pet__actions button,.techjup-pet__wake{background:color-mix(in oklch,var(--color-bg-secondary),transparent 12%)}}.techjup-pet__actions button,.techjup-pet__wake{color:var(--color-accent-strong);cursor:pointer;font-family:var(--font-sans);letter-spacing:-.01em;pointer-events:auto;font-size:11px;font-weight:820;transition:transform .16s,border-color .16s,background-color .16s}.techjup-pet__actions button:hover,.techjup-pet__wake:hover{border-color:#438c81}@supports (color:color-mix(in lab,red,red)){.techjup-pet__actions button:hover,.techjup-pet__wake:hover{border-color:color-mix(in oklch,var(--color-accent),var(--color-border) 32%)}}.techjup-pet__actions button:hover,.techjup-pet__wake:hover{background:#e6f4ee}@supports (color:color-mix(in lab,red,red)){.techjup-pet__actions button:hover,.techjup-pet__wake:hover{background:color-mix(in oklch,var(--color-accent-light),var(--color-bg-primary) 58%)}}.techjup-pet__actions button:active,.techjup-pet__wake:active{transform:translateY(1px)scale(.98)}.techjup-pet__wake{border-radius:var(--radius-pill);min-width:96px;min-height:44px;padding:0 13px}@keyframes techjup-pet-level{0%{transform:scale(1)}35%{transform:translateY(-7px)scale(1.08)rotate(-1.5deg)}70%{transform:translateY(2px)scale(.98)rotate(1deg)}to{transform:scale(1)}}@media(max-width:640px){.techjup-pet{right:calc(12px + env(safe-area-inset-right));bottom:calc(12px + env(safe-area-inset-bottom));transform:none}.techjup-pet__creature{min-width:70px;min-height:74px;padding:7px 5px 5px}.techjup-pet__ascii{font-size:12px;line-height:1.08;transform:none}.techjup-pet__level{min-height:17px;padding-inline:5px;font-size:9px}.techjup-pet__bubble{max-width:min(188px,100vw - 24px);padding:6px 8px;font-size:11px}.techjup-pet__popover{border-radius:17px;width:min(218px,100vw - 20px);padding:9px}.techjup-pet__wake{min-height:44px}}@media(prefers-reduced-motion:reduce){.techjup-pet.is-leveling .techjup-pet__creature{animation:none!important}}::selection{background:var(--color-accent-light);color:var(--color-accent)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}@media(prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.techjup-pet{transform:none!important}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
