@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-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-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;--tw-duration:initial;--tw-ease:initial;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-animation-delay:0s;--tw-animation-direction:normal;--tw-animation-duration:initial;--tw-animation-fill-mode:none;--tw-animation-iteration-count:1;--tw-enter-blur:0;--tw-enter-opacity:1;--tw-enter-rotate:0;--tw-enter-scale:1;--tw-enter-translate-x:0;--tw-enter-translate-y:0;--tw-exit-blur:0;--tw-exit-opacity:1;--tw-exit-rotate:0;--tw-exit-scale:1;--tw-exit-translate-x:0;--tw-exit-translate-y:0}}}@layer theme{:root,:host{--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-50:oklch(97.1% .013 17.38);--color-red-100:oklch(93.6% .032 17.717);--color-red-200:oklch(88.5% .062 18.334);--color-red-500:oklch(63.7% .237 25.331);--color-yellow-50:oklch(98.7% .026 102.212);--color-yellow-200:oklch(94.5% .129 101.54);--color-yellow-500:oklch(79.5% .184 86.047);--color-green-50:oklch(98.2% .018 155.826);--color-green-200:oklch(92.5% .084 155.995);--color-green-500:oklch(72.3% .219 149.579);--color-blue-50:oklch(97% .014 254.604);--color-blue-200:oklch(88.2% .059 254.128);--color-blue-500:oklch(62.3% .214 259.815);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-lg:32rem;--container-4xl:56rem;--container-5xl:64rem;--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);--font-weight-medium:500;--font-weight-semibold:600;--tracking-wider:.05em;--radius-md:calc(var(--radius) * .8);--ease-out:cubic-bezier(0, 0, .2, 1);--animate-spin:spin 1s linear infinite;--blur-sm:8px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:"Geist Variable", sans-serif;--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;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}*{border-color:var(--border);outline-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){*{outline-color:color-mix(in oklab,var(--ring) 50%,transparent)}}body{background-color:var(--background);color:var(--foreground)}html{font-family:Geist Variable,sans-serif}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-2{top:calc(var(--spacing) * 2)}.top-4{top:calc(var(--spacing) * 4)}.right-2{right:calc(var(--spacing) * 2)}.right-4{right:calc(var(--spacing) * 4)}.left-2{left:calc(var(--spacing) * 2)}.z-50{z-index:50}.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}}.mx-auto{margin-inline:auto}.my-4{margin-block:calc(var(--spacing) * 4)}.my-6{margin-block:calc(var(--spacing) * 6)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mr-auto{margin-right:auto}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-auto{margin-left:auto}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.aspect-\(--ratio\){aspect-ratio:var(--ratio)}.size-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.size-7{width:calc(var(--spacing) * 7);height:calc(var(--spacing) * 7)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.size-full{width:100%;height:100%}.h-3{height:calc(var(--spacing) * 3)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-auto{height:auto}.max-h-\[80vh\]{max-height:80vh}.max-h-\[90vh\]{max-height:90vh}.max-h-full{max-height:100%}.min-h-screen{min-height:100vh}.w-3{width:calc(var(--spacing) * 3)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-8{width:calc(var(--spacing) * 8)}.w-full{width:100%}.w-px{width:1px}.max-w-4xl{max-width:var(--container-4xl)}.max-w-5xl{max-width:var(--container-5xl)}.max-w-full{max-width:100%}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.min-w-0{min-width:calc(var(--spacing) * 0)}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.scale-110{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-\[min\(var\(--radius-md\)\,10px\)\]{border-radius:min(var(--radius-md),10px)}.rounded-\[min\(var\(--radius-md\)\,12px\)\]{border-radius:min(var(--radius-md),12px)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius)}.rounded-xl{border-radius:calc(var(--radius) * 1.4)}.rounded-r-lg{border-top-right-radius:var(--radius);border-bottom-right-radius:var(--radius)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-none{--tw-border-style:none;border-style:none}.border-blue-200{border-color:var(--color-blue-200)}.border-border{border-color:var(--border)}.border-gray-200{border-color:var(--color-gray-200)}.border-gray-300{border-color:var(--color-gray-300)}.border-green-200{border-color:var(--color-green-200)}.border-primary{border-color:var(--primary)}.border-red-200{border-color:var(--color-red-200)}.border-transparent{border-color:#0000}.border-yellow-200{border-color:var(--color-yellow-200)}.border-t-transparent{border-top-color:#0000}.bg-accent,.bg-accent\/30{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.bg-accent\/30{background-color:color-mix(in oklab,var(--accent) 30%,transparent)}}.bg-background,.bg-background\/80{background-color:var(--background)}@supports (color:color-mix(in lab,red,red)){.bg-background\/80{background-color:color-mix(in oklab,var(--background) 80%,transparent)}}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black) 50%,transparent)}}.bg-black\/80{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.bg-black\/80{background-color:color-mix(in oklab,var(--color-black) 80%,transparent)}}.bg-black\/90{background-color:#000000e6}@supports (color:color-mix(in lab,red,red)){.bg-black\/90{background-color:color-mix(in oklab,var(--color-black) 90%,transparent)}}.bg-blue-50{background-color:var(--color-blue-50)}.bg-destructive\/10{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.bg-destructive\/10{background-color:color-mix(in oklab,var(--destructive) 10%,transparent)}}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-200{background-color:var(--color-gray-200)}.bg-green-50{background-color:var(--color-green-50)}.bg-primary,.bg-primary\/5{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.bg-primary\/5{background-color:color-mix(in oklab,var(--primary) 5%,transparent)}}.bg-red-50{background-color:var(--color-red-50)}.bg-secondary{background-color:var(--secondary)}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.bg-white\/10{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.bg-white\/90{background-color:#ffffffe6}@supports (color:color-mix(in lab,red,red)){.bg-white\/90{background-color:color-mix(in oklab,var(--color-white) 90%,transparent)}}.bg-yellow-50{background-color:var(--color-yellow-50)}.bg-clip-padding{background-clip:padding-box}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-2{padding:calc(var(--spacing) * 2)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-10{padding-block:calc(var(--spacing) * 10)}.py-20{padding-block:calc(var(--spacing) * 20)}.text-center{text-align:center}.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-\[0\.8rem\]{font-size:.8rem}.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-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.whitespace-nowrap{white-space:nowrap}.text-blue-500{color:var(--color-blue-500)}.text-destructive{color:var(--destructive)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-green-500{color:var(--color-green-500)}.text-muted-foreground{color:var(--muted-foreground)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-red-500{color:var(--color-red-500)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-white{color:var(--color-white)}.text-yellow-500{color:var(--color-yellow-500)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.opacity-0{opacity:0}.opacity-40{opacity:.4}.opacity-60{opacity:.6}.opacity-100{opacity:1}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px 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)}.shadow-sm{--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)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px 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-2{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + 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)}.ring-blue-500{--tw-ring-color:var(--color-blue-500)}.ring-offset-2{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.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,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-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-all{transition-property:all;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))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-500{--tw-duration:.5s;transition-duration:.5s}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.paused{animation-play-state:paused}@media(hover:hover){.hover\:scale-\[1\.02\]:hover{scale:1.02}.hover\:border-primary\/50:hover{border-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.hover\:border-primary\/50:hover{border-color:color-mix(in oklab,var(--primary) 50%,transparent)}}.hover\:bg-accent:hover,.hover\:bg-accent\/80:hover{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-accent\/80:hover{background-color:color-mix(in oklab,var(--accent) 80%,transparent)}}.hover\:bg-background:hover{background-color:var(--background)}.hover\:bg-destructive\/10:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/10:hover{background-color:color-mix(in oklab,var(--destructive) 10%,transparent)}}.hover\:bg-destructive\/20:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/20:hover{background-color:color-mix(in oklab,var(--destructive) 20%,transparent)}}.hover\:bg-gray-100:hover{background-color:var(--color-gray-100)}.hover\:bg-muted:hover{background-color:var(--muted)}.hover\:bg-red-100:hover{background-color:var(--color-red-100)}.hover\:bg-secondary\/80:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab,var(--secondary) 80%,transparent)}}.hover\:bg-white\/20:hover{background-color:#fff3}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/20:hover{background-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.hover\:bg-white\/50:hover{background-color:#ffffff80}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/50:hover{background-color:color-mix(in oklab,var(--color-white) 50%,transparent)}}.hover\:text-foreground:hover{color:var(--foreground)}.hover\:underline:hover{text-decoration-line:underline}}.focus\:ring-0:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(0px + 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)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:border-destructive\/40:focus-visible{border-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:border-destructive\/40:focus-visible{border-color:color-mix(in oklab,var(--destructive) 40%,transparent)}}.focus-visible\:border-ring:focus-visible{border-color:var(--ring)}.focus-visible\:ring-3:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + 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)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:color-mix(in oklab, var(--ring) 50%, transparent)}}.active\:translate-y-px:active{--tw-translate-y:1px;translate:var(--tw-translate-x) var(--tw-translate-y)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}:where([data-slot=button-group]) .in-data-\[slot\=button-group\]\:rounded-lg{border-radius:var(--radius)}.has-data-\[icon\=inline-end\]\:pr-1\.5:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 1.5)}.has-data-\[icon\=inline-end\]\:pr-2:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 2)}.has-data-\[icon\=inline-end\]\:pr-3:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 3)}.has-data-\[icon\=inline-start\]\:pl-1\.5:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 1.5)}.has-data-\[icon\=inline-start\]\:pl-2:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 2)}.has-data-\[icon\=inline-start\]\:pl-3:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 3)}.aria-expanded\:bg-muted[aria-expanded=true]{background-color:var(--muted)}.aria-expanded\:bg-secondary[aria-expanded=true]{background-color:var(--secondary)}.aria-expanded\:text-foreground[aria-expanded=true]{color:var(--foreground)}.aria-expanded\:text-secondary-foreground[aria-expanded=true]{color:var(--secondary-foreground)}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:var(--destructive)}.aria-invalid\:ring-3[aria-invalid=true]{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + 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)}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}@media(min-width:40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:48rem){.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:gap-6{gap:calc(var(--spacing) * 6)}}.dark\:border-input:is(.dark *){border-color:var(--input)}.dark\:bg-destructive\/20:is(.dark *){background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-destructive\/20:is(.dark *){background-color:color-mix(in oklab,var(--destructive) 20%,transparent)}}.dark\:bg-input\/30:is(.dark *){background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-input\/30:is(.dark *){background-color:color-mix(in oklab,var(--input) 30%,transparent)}}@media(hover:hover){.dark\:hover\:bg-destructive\/30:is(.dark *):hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-destructive\/30:is(.dark *):hover{background-color:color-mix(in oklab,var(--destructive) 30%,transparent)}}.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:color-mix(in oklab,var(--input) 50%,transparent)}}.dark\:hover\:bg-muted\/50:is(.dark *):hover{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-muted\/50:is(.dark *):hover{background-color:color-mix(in oklab,var(--muted) 50%,transparent)}}}.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.dark\:aria-invalid\:border-destructive\/50:is(.dark *)[aria-invalid=true]{border-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:aria-invalid\:border-destructive\/50:is(.dark *)[aria-invalid=true]{border-color:color-mix(in oklab,var(--destructive) 50%,transparent)}}.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*=size-]){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3\.5 svg:not([class*=size-]){width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}@media(hover:hover){.\[a\]\:hover\:bg-primary\/80:is(a):hover{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.\[a\]\:hover\:bg-primary\/80:is(a):hover{background-color:color-mix(in oklab,var(--primary) 80%,transparent)}}}}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-cyrillic-wght-normal-CHSlOQsW.woff2)format("woff2-variations");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-latin-ext-wght-normal-DMtmJ5ZE.woff2)format("woff2-variations");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 Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-latin-wght-normal-Dm3htQBi.woff2)format("woff2-variations");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:ABC Diatype;src:local(ABC Diatype Regular),local(ABCDiatype-Regular);font-weight:400;font-style:normal}*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafafa;--text:#171717;--text-secondary:#525252;--text-tertiary:#a3a3a3;--border:oklch(92.2% 0 0);--accent:oklch(97% 0 0);--hover-bg:#f5f5f5;--accent-color:#3b82f6;--background:oklch(100% 0 0);--foreground:oklch(14.5% 0 0);--card:oklch(100% 0 0);--card-foreground:oklch(14.5% 0 0);--popover:oklch(100% 0 0);--popover-foreground:oklch(14.5% 0 0);--primary:oklch(20.5% 0 0);--primary-foreground:oklch(98.5% 0 0);--secondary:oklch(97% 0 0);--secondary-foreground:oklch(20.5% 0 0);--muted:oklch(97% 0 0);--muted-foreground:oklch(55.6% 0 0);--accent-foreground:oklch(20.5% 0 0);--destructive:oklch(57.7% .245 27.325);--input:oklch(92.2% 0 0);--ring:oklch(70.8% 0 0);--chart-1:oklch(80.9% .105 251.813);--chart-2:oklch(62.3% .214 259.815);--chart-3:oklch(54.6% .245 262.881);--chart-4:oklch(48.8% .243 264.376);--chart-5:oklch(42.4% .199 265.638);--radius:.625rem;--sidebar:oklch(98.5% 0 0);--sidebar-foreground:oklch(14.5% 0 0);--sidebar-primary:oklch(20.5% 0 0);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(97% 0 0);--sidebar-accent-foreground:oklch(20.5% 0 0);--sidebar-border:oklch(92.2% 0 0);--sidebar-ring:oklch(70.8% 0 0)}[data-theme=dark]{--bg:#141414;--text:#e5e5e5;--text-secondary:#a3a3a3;--text-tertiary:#737373;--border:#2a2a2a;--accent:#3a3a3a;--hover-bg:#1f1f1f;--accent-color:#60a5fa}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;font-size:15px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;-webkit-tap-highlight-color:#0000;font-family:ABC Diatype,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;transition:background .3s,color .3s}a{color:inherit;text-decoration:none}::selection{background:var(--text);color:var(--bg)}button{font-family:inherit}.dark{--background:oklch(14.5% 0 0);--foreground:oklch(98.5% 0 0);--card:oklch(20.5% 0 0);--card-foreground:oklch(98.5% 0 0);--popover:oklch(20.5% 0 0);--popover-foreground:oklch(98.5% 0 0);--primary:oklch(92.2% 0 0);--primary-foreground:oklch(20.5% 0 0);--secondary:oklch(26.9% 0 0);--secondary-foreground:oklch(98.5% 0 0);--muted:oklch(26.9% 0 0);--muted-foreground:oklch(70.8% 0 0);--accent:oklch(26.9% 0 0);--accent-foreground:oklch(98.5% 0 0);--destructive:oklch(70.4% .191 22.216);--border:oklch(100% 0 0/.1);--input:oklch(100% 0 0/.15);--ring:oklch(55.6% 0 0);--chart-1:oklch(80.9% .105 251.813);--chart-2:oklch(62.3% .214 259.815);--chart-3:oklch(54.6% .245 262.881);--chart-4:oklch(48.8% .243 264.376);--chart-5:oklch(42.4% .199 265.638);--sidebar:oklch(20.5% 0 0);--sidebar-foreground:oklch(98.5% 0 0);--sidebar-primary:oklch(48.8% .243 264.376);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(26.9% 0 0);--sidebar-accent-foreground:oklch(98.5% 0 0);--sidebar-border:oklch(100% 0 0/.1);--sidebar-ring:oklch(55.6% 0 0)}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-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}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size: 12px;--rc-drag-handle-mobile-size: 24px;--rc-drag-handle-bg-colour: rgba(0, 0, 0, .2);--rc-drag-bar-size: 6px;--rc-border-color: rgba(255, 255, 255, .7);--rc-focus-color: #0088ff}.ReactCrop{position:relative;display:inline-block;cursor:crosshair;max-width:100%}.ReactCrop *,.ReactCrop *:before,.ReactCrop *:after{box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{overflow:hidden;max-height:inherit}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-width:100%;max-height:inherit}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video{touch-action:none}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{touch-action:none}.ReactCrop__crop-mask{position:absolute;inset:0;pointer-events:none;width:calc(100% + .5px);height:calc(100% + .5px)}.ReactCrop__crop-selection{position:absolute;top:0;left:0;transform:translateZ(0);cursor:move}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{pointer-events:none;content:"";position:absolute;inset:-1px;border:1px solid var(--rc-border-color);opacity:.3}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed white}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){animation:marching-ants 1s;background-image:linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%);background-size:10px 1px,10px 1px,1px 10px,1px 10px;background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;color:#fff;animation-play-state:running;animation-timing-function:linear;animation-iteration-count:infinite}.ReactCrop__crop-selection:focus{outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{content:"";display:block;position:absolute;background-color:#fff6}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after{width:1px;height:100%}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{width:100%;height:1px}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{position:absolute;width:var(--rc-drag-handle-size);height:var(--rc-drag-handle-size);background-color:var(--rc-drag-handle-bg-colour);border:1px solid var(--rc-border-color)}.ReactCrop__drag-handle:focus{background:var(--rc-focus-color)}.ReactCrop .ord-nw{top:0;left:0;transform:translate(-50%,-50%);cursor:nw-resize}.ReactCrop .ord-n{top:0;left:50%;transform:translate(-50%,-50%);cursor:n-resize}.ReactCrop .ord-ne{top:0;right:0;transform:translate(50%,-50%);cursor:ne-resize}.ReactCrop .ord-e{top:50%;right:0;transform:translate(50%,-50%);cursor:e-resize}.ReactCrop .ord-se{bottom:0;right:0;transform:translate(50%,50%);cursor:se-resize}.ReactCrop .ord-s{bottom:0;left:50%;transform:translate(-50%,50%);cursor:s-resize}.ReactCrop .ord-sw{bottom:0;left:0;transform:translate(-50%,50%);cursor:sw-resize}.ReactCrop .ord-w{top:50%;left:0;transform:translate(-50%,-50%);cursor:w-resize}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{top:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(-50%)}.ReactCrop__drag-bar.ord-e{right:0;top:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(50%)}.ReactCrop__drag-bar.ord-s{bottom:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(50%)}.ReactCrop__drag-bar.ord-w{top:0;left:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(-50%)}.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle,.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w{display:none}@media(pointer:coarse){.ReactCrop .ord-n,.ReactCrop .ord-e,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{width:var(--rc-drag-handle-mobile-size);height:var(--rc-drag-handle-mobile-size)}}.container{max-width:580px;margin:0 auto;padding:48px 24px 80px;min-height:100vh}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:56px}.header-left{display:flex;align-items:center;gap:20px}.header-profile-image{width:32px;height:32px;border-radius:8px;object-fit:cover;object-position:center 15%;transition:filter .3s ease}[data-theme=dark] .header-profile-image{filter:invert(1) hue-rotate(180deg)}.nav{display:flex;gap:24px}.nav-link{font-size:.9rem;color:var(--text-secondary);position:relative;transition:color .2s ease;cursor:pointer}.nav-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--text);transition:width .2s ease}@media(hover:hover){.nav-link:hover{color:var(--text)}.nav-link:hover:after{width:100%}}.header-right{display:flex;align-items:center;gap:16px}.theme-dropdown{position:relative}.theme-toggle{width:28px;height:28px;border-radius:6px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease;color:var(--text-tertiary)}@media(hover:hover){.theme-toggle:hover{background:var(--hover-bg);color:var(--text)}}.theme-toggle svg{width:15px;height:15px}.theme-toggle.active{background:var(--accent);color:#fff}.theme-toggle.active:hover{background:var(--accent);opacity:.9}.theme-dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:4px;display:flex;gap:2px;box-shadow:0 4px 12px #0000001a;z-index:100}.theme-dropdown-item{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;border-radius:6px;color:var(--text-tertiary);transition:all .15s ease}.theme-dropdown-item:hover,.theme-dropdown-item.active{background:var(--hover-bg);color:var(--text)}.theme-dropdown-icon{display:flex;align-items:center;justify-content:center}.theme-dropdown-icon svg{width:14px;height:14px}.location{font-size:.85rem;color:var(--text-tertiary);display:flex;align-items:center;gap:6px}.location-icon{width:14px;height:14px;stroke:var(--text-tertiary)}.profile{margin-bottom:40px}.profile-name{font-size:1.5rem;font-weight:600;color:var(--text);margin:0 0 4px}.profile-title{font-size:.95rem;color:var(--text-secondary);margin:0}.section{margin-bottom:48px}.section-title{font-size:.75rem;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.section-divider{width:60px;height:1px;background:var(--border);margin:48px auto}.bio{color:var(--text-secondary);font-size:.95rem;line-height:1.75}.bio p{margin-bottom:16px}.bio p:last-child{margin-bottom:0}.bio a{color:inherit;text-decoration:underline;text-underline-offset:2px;transition:opacity .2s ease}.bio a:after{content:"";display:inline-block;width:.7em;height:.7em;margin-left:.15em;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3Cpolyline points='15 3 21 3 21 9'/%3E%3Cline x1='10' y1='14' x2='21' y2='3'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;vertical-align:baseline;position:relative;top:.05em}[data-theme=dark] .bio a:after{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3Cpolyline points='15 3 21 3 21 9'/%3E%3Cline x1='10' y1='14' x2='21' y2='3'/%3E%3C/svg%3E")}@media(hover:hover){.bio a:hover{opacity:.7}}.bio kbd{display:inline-flex;align-items:center;justify-content:center;padding:.125rem .375rem;font-size:11px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-weight:500;background:var(--hover-bg);border:1px solid var(--border);border-bottom-width:2px;border-radius:4px;color:var(--text-secondary);line-height:1;vertical-align:baseline;box-shadow:inset 0 -1px #00000014;-webkit-user-select:none;user-select:none;-webkit-box-decoration-break:clone;box-decoration-break:clone}.bio em{font-style:italic}.work-list{display:flex;flex-direction:column}.work-item{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 12px;cursor:pointer;margin:0 -12px;border-radius:12px;text-decoration:none;background:transparent;border:1px solid transparent;width:calc(100% + 24px);text-align:left;color:inherit;font-family:inherit;position:relative;transition:background .2s ease}@media(hover:hover){.work-item:hover{background:var(--hover-bg)}}.work-item{border-bottom:1px solid var(--border-color, rgba(255, 255, 255, .1))}.work-item:last-child{border-bottom:none}.work-info{flex:1;display:flex;align-items:baseline;gap:10px}.work-name{font-size:.95rem;font-weight:500}.work-description{font-size:.875rem;color:var(--text-secondary)}.work-meta{display:flex;align-items:center;gap:12px;flex-shrink:0}.work-year{font-size:.85rem;color:var(--text-tertiary)}.work-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.work-modal{background:var(--bg);border-radius:16px;max-width:480px;width:calc(100% - 48px);max-height:calc(100vh - 48px);overflow:hidden;box-shadow:0 12px 40px #00000040;border:1px solid var(--border);position:relative;display:flex;flex-direction:column}.work-modal-with-images{max-width:520px}.work-modal-content{padding:24px;overflow-y:auto}.work-modal-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px;gap:16px;padding-right:36px}.work-modal-title{font-size:1.25rem;font-weight:600;margin:0;line-height:1.3}.work-modal-year{font-size:.85rem;color:var(--text-tertiary);flex-shrink:0}.work-modal-details{font-size:.925rem;color:var(--text-secondary);line-height:1.7;margin:0 0 20px}.work-modal-tech{display:flex;flex-wrap:wrap;gap:8px}.work-modal-tag{font-size:.75rem;padding:5px 12px;background:var(--hover-bg);border-radius:14px;color:var(--text-secondary);font-weight:500}.work-modal-close{position:absolute;top:16px;right:16px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg);border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);border-radius:8px;transition:all .2s ease;z-index:10}@media(hover:hover){.work-modal-close:hover{background:var(--hover-bg);color:var(--text);border-color:transparent}}.work-modal-close svg{width:14px;height:14px}.work-modal-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.work-modal-link{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;padding:8px 14px;background:var(--hover-bg);border-radius:10px;color:var(--text);text-decoration:none;font-weight:500;transition:all .2s ease}.work-modal-link svg{width:14px;height:14px;opacity:.6;transition:all .2s ease}@media(hover:hover){.work-modal-link:hover{background:var(--text);color:var(--bg)}.work-modal-link:hover svg{opacity:1;transform:translate(2px,-2px)}}.image-carousel{position:relative;background:var(--hover-bg);border-bottom:1px solid var(--border)}.image-carousel-container{aspect-ratio:16 / 10;overflow:hidden;position:relative}.image-carousel-image{width:100%;height:100%;object-fit:cover;display:block}.image-carousel-nav{position:absolute;bottom:12px;left:12px;display:flex;gap:8px;z-index:5}.image-carousel-btn{width:32px;height:32px;border-radius:8px;background:var(--bg);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s ease}.image-carousel-btn:hover{background:#8080801a;color:var(--text)}.image-carousel-btn svg{width:14px;height:14px}.image-carousel-dots{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;gap:6px;z-index:5}.image-carousel-dot{width:8px;height:8px;border-radius:50%;background:var(--bg);border:none;cursor:pointer;opacity:.5;transition:all .2s ease;padding:0}.image-carousel-dot.active{opacity:1;transform:scale(1.2)}.image-carousel-dot:hover{opacity:.8}.experience-list{display:flex;flex-direction:column;gap:16px;margin-top:-4px}.experience-row{display:flex;align-items:center;gap:6px}.experience-company{font-size:.95rem;font-weight:500;color:var(--text);white-space:nowrap;min-width:140px}.experience-line{flex:1;height:1px;background:var(--border);min-width:20px}.experience-role{font-size:.9rem;color:var(--text-tertiary);white-space:nowrap;text-align:right}.experience-date{font-size:.9rem;color:var(--text-tertiary);white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums;display:inline-flex;align-items:center;justify-content:flex-end;flex-shrink:0}.blink-cursor{animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.social-links{display:flex;gap:20px;margin-top:24px}.social-link{font-size:.9rem;color:var(--text-secondary);display:flex;align-items:center;gap:6px;transition:color .2s ease}@media(hover:hover){.social-link:hover{color:var(--text)}}.social-link svg{width:16px;height:16px;transition:transform .2s ease}@media(hover:hover){.social-link:hover svg{transform:none}}.concise-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg);position:relative}.concise-header{position:absolute;top:20px;right:20px;display:flex;align-items:center;gap:4px;padding:4px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px}.concise-back-btn{width:28px;height:28px;border-radius:6px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease;color:var(--text-tertiary)}.concise-back-btn svg{width:15px;height:15px}@media(hover:hover){.concise-back-btn:hover{background:var(--hover-bg);color:var(--text)}}.concise-content{max-width:400px;width:100%;text-align:center}.concise-profile{margin-bottom:24px}.concise-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;margin-bottom:16px;transition:filter .3s ease}[data-theme=dark] .concise-avatar{filter:invert(1) hue-rotate(180deg)}.concise-name{font-size:1.25rem;font-weight:600;color:var(--text);margin:0 0 4px}.concise-title{font-size:.9rem;color:var(--text-secondary);margin:0}.concise-bio{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin:0 0 28px}.concise-links{display:flex;flex-direction:row;justify-content:center;gap:16px}.concise-link-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:transparent;border:none;border-radius:50%;color:var(--text-secondary);text-decoration:none;transition:all .2s ease}.concise-link-icon svg{width:20px;height:20px}@media(hover:hover){.concise-link-icon:hover{background:var(--hover-bg);color:var(--text)}}.latency-section{margin-top:32px;padding:12px 0;border-top:1px solid var(--border);display:flex;justify-content:center}.latency-chart-container{position:relative;height:140px;width:100%;max-width:420px;border-radius:8px;overflow:visible;background:transparent}.latency-description{margin-top:12px;font-size:.75rem;color:var(--text-tertiary);text-align:center}.footer{margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.footer-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.footer-text{font-size:.8rem;color:var(--text-tertiary)}.footer-link{font-size:.8rem;color:var(--text-tertiary);text-decoration:none;transition:color .2s ease}@media(hover:hover){.footer-link:hover{color:var(--text)}}.footer-quote-inline{font-size:.8rem;font-style:italic;color:var(--text-tertiary)}.footer-dot{font-size:.8rem;color:var(--text-tertiary)}.footer-right{display:flex;align-items:center;gap:12px}.footer-time{font-size:.8rem;color:var(--text-tertiary);font-variant-numeric:tabular-nums}.back-to-top{width:28px;height:28px;border-radius:6px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease;color:var(--text-tertiary)}@media(hover:hover){.back-to-top:hover{background:var(--hover-bg);color:var(--text)}}.back-to-top svg{width:14px;height:14px}.concise-btn-wrapper{position:relative;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px}.concise-view-btn{width:28px;height:28px;border-radius:6px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease;color:var(--text-tertiary)}.concise-view-btn svg{width:14px;height:14px}@media(hover:hover){.concise-view-btn:hover{background:var(--hover-bg);color:var(--text)}}.concise-tooltip{position:absolute;bottom:calc(100% + 8px);left:14px;transform:translate(-50%);padding:6px 10px;background:#1a1a1a;border:1px solid #333;border-radius:6px;font-size:.75rem;color:#fff;white-space:nowrap;pointer-events:none;box-shadow:0 2px 8px #0003}.concise-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1a1a1a;margin-top:-1px}.shelf-page .blog-blur-bottom{max-width:none;left:0;transform:none}.shelf-infinite-layout{position:relative;padding:0;height:100vh;overflow:hidden;display:flex;flex-direction:column}.shelf-fixed-header{position:relative;z-index:100;background:var(--bg);padding:32px 24px 24px;flex-shrink:0}.shelf-fixed-header .blog-header,.shelf-fixed-header .blog-list-title{max-width:1152px;margin:0 auto;padding:0}.shelf-fixed-header:after{content:"";position:absolute;bottom:-40px;left:0;right:0;height:40px;background:linear-gradient(to bottom,var(--bg) 0%,transparent 100%);pointer-events:none;z-index:10}.shelf-scroll-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 24px 200px;scrollbar-width:none;-ms-overflow-style:none}.shelf-scroll-container .shelf-content{max-width:1152px;margin:0 auto}.shelf-scroll-container::-webkit-scrollbar{display:none}.shelf-scroll-container.edit-mode{padding-bottom:100px}.shelf-blur-overlay{display:flex;align-items:flex-end;justify-content:center;padding-bottom:32px;height:160px;background:linear-gradient(to top,var(--bg) 0%,var(--bg) 30%,transparent 100%)}.shelf-blur-text{color:var(--text);font-size:.9rem;font-style:italic;text-align:center;max-width:500px;line-height:1.6;opacity:.7;padding:0 24px}[data-theme=dark] .shelf-blur-text{color:#fff}[data-theme=light] .shelf-blur-text{color:#000}@media(max-width:768px){.shelf-fixed-header{padding:24px 16px 0}.shelf-scroll-container{padding:0 16px 180px}.shelf-blur-text{font-size:.85rem;max-width:320px}}.status-badge{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-secondary);background:var(--hover-bg);padding:6px 12px;border-radius:20px;margin-top:16px;transition:background .2s ease}@media(hover:hover){.status-badge:hover{background:var(--border)}}.status-dot{width:6px;height:6px;background:#22c55e;border-radius:50%;animation:pulse 2s ease-in-out infinite}.divider{height:1px;background:var(--border);margin:8px 0}.accordion-list{display:flex;flex-direction:column}.accordion-list>div{border-bottom:1px solid var(--border)}.accordion-list>div:last-child{border-bottom:none}.accordion{border-bottom:none}.accordion-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:16px 0;background:none;border:none;cursor:pointer;text-align:left;color:var(--text);font-size:.95rem;font-weight:500;transition:color .2s ease}@media(hover:hover){.accordion-header:hover,.accordion-header:hover .accordion-icon{color:var(--text-secondary)}}.accordion-header.open,.accordion-header.open .accordion-icon,.accordion-title.active{color:var(--text)}.accordion-icon{position:relative;width:10px;height:10px;color:var(--text-tertiary);transition:color .2s ease}.accordion-icon-bar{position:absolute;background:currentColor;border-radius:.5px;transition:transform .25s ease,opacity .25s ease}.accordion-icon-horizontal{width:10px;height:1.5px;top:50%;left:0;transform:translateY(-50%)}.accordion-icon-vertical{width:1.5px;height:10px;top:0;left:50%;transform:translate(-50%)}.accordion-icon.open .accordion-icon-vertical{transform:translate(-50%) rotate(90deg);opacity:0}.accordion-content{padding:8px 0 16px;font-size:.9rem;color:var(--text-secondary);line-height:1.7}.accordion-content p{margin-bottom:12px}.accordion-content p:first-child{padding-left:16px;border-left:2px solid var(--border)}.accordion-content ul{margin:8px 0;padding-left:20px;list-style:disc}.accordion-content li{margin-bottom:6px;padding:0}.accordion-content strong{font-weight:600;color:var(--text)}.accordion-content em{font-style:italic;color:var(--text-tertiary)}.blog-container{max-width:640px;margin:0 auto;padding:48px 24px 80px;min-height:100vh}.blog-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:48px}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.85rem}.breadcrumb-link{color:var(--text-tertiary);transition:color .2s ease}@media(hover:hover){.breadcrumb-link:hover{color:var(--text)}}.breadcrumb-sep{color:var(--text-tertiary)}.breadcrumb-current{color:var(--text-secondary)}.blog-title{font-size:1.5rem;font-weight:600;margin-bottom:32px}.blog-empty{color:var(--text-tertiary);font-size:.9rem}.blog-loading-spinner-container{display:flex;justify-content:center;align-items:center;padding:48px 0}.blog-loading-spinner{width:24px;height:24px;border:2px solid var(--text-tertiary);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.post-list{list-style:none}.post-item{display:flex;flex-direction:column;gap:4px;padding:16px 12px;margin:0 -12px;border-radius:8px;transition:background .15s ease}@media(hover:hover){.post-item:hover{background:var(--hover-bg)}}.post-date{font-size:.8rem;color:var(--text-tertiary);font-variant-numeric:tabular-nums}.post-title-link{font-size:.95rem;font-weight:500;color:var(--text)}.add-post-btn{width:28px;height:28px;border-radius:6px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:background .2s ease,color .2s ease}@media(hover:hover){.add-post-btn:hover{background:var(--hover-bg);color:var(--text)}}.add-post-btn svg{width:15px;height:15px}.blog-article{margin-top:32px}.article-header{margin-bottom:32px}.article-title{font-size:1.5rem;font-weight:600;margin-bottom:12px;line-height:1.3}.article-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.article-date{font-size:.85rem;color:var(--text-tertiary)}.article-actions{display:flex;align-items:center;gap:12px;margin-top:16px}.copy-link-btn{width:24px;height:24px;color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:0;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}.copy-link-btn svg{width:14px;height:14px}@media(hover:hover){.copy-link-btn:hover{background:var(--hover-bg);color:var(--text)}}.edit-link,.delete-btn{font-size:.8rem;color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s ease,color .2s ease}@media(hover:hover){.edit-link:hover{background:var(--hover-bg);color:var(--text)}}@media(hover:hover){.delete-btn:hover{background:#fef2f2;color:#dc2626}[data-theme=dark] .delete-btn:hover{background:#2a1515;color:#f87171}}.article-content{font-size:.95rem;line-height:1.8;color:var(--text-secondary)}.article-content h1,.article-content h2,.article-content h3{color:var(--text);margin-top:32px;margin-bottom:16px;line-height:1.4}.article-content h1{font-size:1.5rem}.article-content h2{font-size:1.25rem}.article-content h3{font-size:1.1rem}.article-content p{margin-bottom:16px}.article-content a{color:var(--accent-color);text-decoration:underline;text-underline-offset:3px}.article-content ul,.article-content ol{margin-bottom:16px;padding-left:24px}.article-content li{margin-bottom:8px}.article-content blockquote{border-left:3px solid var(--border);padding-left:16px;margin:16px 0;font-style:italic;color:var(--text-tertiary)}.article-content kbd{display:inline-flex;align-items:center;justify-content:center;padding:.125rem .375rem;font-size:11px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-weight:500;background:var(--hover-bg);border:1px solid var(--border);border-bottom-width:2px;border-radius:4px;color:var(--text-secondary);line-height:1;vertical-align:baseline;box-shadow:inset 0 -1px #00000014;-webkit-user-select:none;user-select:none;-webkit-box-decoration-break:clone;box-decoration-break:clone}.article-content hr{border:none;margin:32px auto;display:flex;justify-content:center;align-items:center;height:2px;background:transparent}.article-content hr:before{content:"— — — — — —";color:var(--text-tertiary);font-size:.9rem;letter-spacing:.5em;opacity:.5}.heading-with-link{position:relative;cursor:pointer;scroll-margin-top:100px}.heading-with-link:focus,.more-articles-tab:focus{outline:none}.heading-link-icon{opacity:0;margin-left:8px;color:var(--text-tertiary);font-weight:400;transition:opacity .2s ease}@media(hover:hover){.heading-with-link:hover .heading-link-icon{opacity:1}}.code-block{margin:16px 0;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.code-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--hover-bg);border-bottom:1px solid var(--border)}.code-language{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.copy-btn{width:24px;height:24px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);border-radius:4px;transition:background .2s ease,color .2s ease}@media(hover:hover){.copy-btn:hover{background:var(--border);color:var(--text)}}.copy-btn svg{width:14px;height:14px}.inline-code{background:var(--hover-bg);padding:2px 6px;border-radius:4px;font-size:.875em;font-family:SF Mono,Fira Code,monospace}.editor-container{max-width:800px}.editor-main{margin-top:32px}.editor-fields{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.editor-title-input{font-size:1.5rem;font-weight:600;padding:12px 0;border:none;background:none;color:var(--text);outline:none;border-bottom:1px solid var(--border)}.editor-slug-input{font-size:.85rem;padding:8px 0;border:none;background:none;color:var(--text-secondary);outline:none}.editor-slug-input::placeholder{color:var(--text-tertiary)}.editor-toolbar{display:flex;align-items:center;gap:4px;padding:8px;background:var(--hover-bg);border-radius:8px;margin-bottom:16px;flex-wrap:wrap}.editor-toolbar button{padding:6px 10px;background:none;border:none;cursor:pointer;color:var(--text-secondary);border-radius:4px;font-size:.85rem;transition:background .2s ease,color .2s ease}.editor-toolbar button.active{background:var(--bg);color:var(--text)}@media(hover:hover){.editor-toolbar button:hover{background:var(--bg);color:var(--text)}}.toolbar-divider{width:1px;height:20px;background:var(--border);margin:0 4px}.editor-textarea{width:100%;min-height:400px;padding:16px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-family:SF Mono,Fira Code,monospace;font-size:16px;line-height:1.6;resize:vertical;outline:none}.editor-textarea:focus{border-color:var(--text-tertiary)}.editor-preview{min-height:400px;padding:16px;border:1px solid var(--border);border-radius:8px;background:var(--bg)}.editor-actions{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.publish-toggle{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text-secondary);cursor:pointer}.publish-toggle input{width:16px;height:16px;cursor:pointer}.editor-buttons{display:flex;gap:12px}.cancel-btn{padding:8px 16px;background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:border-color .2s ease,color .2s ease}@media(hover:hover){.cancel-btn:hover{border-color:var(--text-tertiary);color:var(--text)}}.save-btn{padding:8px 16px;background:var(--text);border:none;border-radius:6px;color:var(--bg);font-size:.9rem;cursor:pointer;transition:opacity .2s ease}@media(hover:hover){.save-btn:hover{opacity:.9}}.auth-required{text-align:center;padding:64px 0}.auth-required p{color:var(--text-secondary);margin-bottom:16px}.back-link{color:var(--text-tertiary);font-size:.9rem;transition:color .2s ease}@media(hover:hover){.back-link:hover{color:var(--text)}}.logout-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease;color:var(--text-secondary)}@media(hover:hover){.logout-btn:hover{background:var(--hover-bg);color:var(--text)}}.logout-btn svg{width:16px;height:16px}.footer-secret{cursor:default;-webkit-user-select:none;user-select:none}.login-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.login-modal{background:var(--bg);padding:24px;border-radius:12px;box-shadow:0 20px 60px #0003;width:280px}.login-modal form{display:flex;flex-direction:column;gap:12px}.login-modal input{padding:10px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:16px;outline:none;transition:border-color .2s ease}.login-modal input:focus{border-color:var(--text-tertiary)}.login-modal input.error{border-color:#dc2626;animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.login-modal button{padding:10px 16px;background:var(--text);border:none;border-radius:6px;color:var(--bg);font-size:.9rem;cursor:pointer;transition:opacity .2s ease}@media(hover:hover){.login-modal button:hover{opacity:.9}}.mobile-menu-toggle{display:none;width:32px;height:32px;border-radius:8px;border:none;background:transparent;cursor:pointer;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease;color:var(--text-secondary);order:-1}.mobile-menu-toggle svg{width:18px;height:18px}@media(hover:hover){.mobile-menu-toggle:hover{background:var(--hover-bg);color:var(--text)}}.nav-mobile{display:none;position:absolute;top:100%;left:-20px;right:-20px;background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:12px 0;flex-direction:column;gap:4px;z-index:100;overflow:hidden}.nav-link-mobile{display:block;padding:12px 20px;font-size:.95rem;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.nav-link-mobile:hover{color:var(--text);background:var(--hover-bg)}.footer-quote-row{margin-bottom:12px}@media(max-width:520px){.container{padding:32px 20px 64px}.header{flex-wrap:wrap;position:relative;gap:12px;margin-bottom:40px}.header-left{gap:12px}.header-profile-image{width:28px;height:28px;border-radius:6px}.nav-desktop{display:none}.mobile-menu-toggle,.nav-mobile{display:flex}.header-right{margin-left:auto}.footer{padding-top:20px}.footer-quote-row{margin-bottom:16px}.footer-quote-inline{font-size:.85rem}.footer-bottom{flex-direction:column;gap:16px;align-items:flex-start}.footer-left{order:2;width:100%;justify-content:center}.footer-right{order:1;width:100%;justify-content:space-between}.footer-time{font-size:.85rem}.experience-row{flex-wrap:wrap;gap:6px}.experience-company{min-width:auto;font-size:.9rem;width:100%}.experience-line{display:none}.experience-role{min-width:auto;text-align:left}.experience-date{min-width:auto;margin-left:auto;font-size:.8rem}.work-item{flex-direction:column;gap:8px}.work-meta{align-self:flex-start}.blog-container{padding:32px 16px 64px}.article-title{font-size:1.25rem}.editor-toolbar{gap:2px;padding:6px}.editor-toolbar button{padding:4px 8px;font-size:.8rem}}.blog-blur-bottom{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:720px;height:64px;pointer-events:none;z-index:50;background:linear-gradient(to top,var(--bg) 0%,var(--bg) 8%,transparent 100%)}.blog-list-layout{display:flex;flex-direction:column;min-height:100vh;max-width:640px;margin:0 auto;padding:32px 24px 80px}.blog-list-header{flex-shrink:0;width:100%;max-width:800px;margin:0 auto 24px;padding:0 20px;box-sizing:border-box}.blog-list-title{flex-shrink:0;width:100%;max-width:800px;margin:0 auto;padding:0 20px;box-sizing:border-box}.blog-list-content{flex:1 0 auto;padding-bottom:24px}.blog-list-footer{flex-shrink:0;margin-top:auto;padding-bottom:24px}.footer-bottom{display:flex;justify-content:space-between;align-items:center}.footer-signature{display:flex;justify-content:center;margin-top:-70px;margin-bottom:-40px}.signature-img{height:100px;width:auto;opacity:.4;transition:opacity .2s ease,filter .2s ease}[data-theme=light] .signature-img{filter:invert(1)}@media(max-width:520px){.footer-signature{margin-top:16px;margin-bottom:0}.signature-img{height:80px}}.post-list-simple{list-style:none}.post-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;transition:opacity .2s ease}@media(hover:hover){.post-row:hover{opacity:.7}}.post-row-title{font-size:.95rem;color:var(--text)}.post-row-date{font-size:.85rem;color:var(--text-tertiary);font-variant-numeric:tabular-nums;flex-shrink:0;margin-left:24px}.article-views{font-size:.85rem;color:var(--text-tertiary)}.article-views-pill{display:flex;align-items:center;gap:4px;font-size:.7rem;color:var(--text-secondary);background:var(--hover-bg);padding:4px 8px;border-radius:12px}.article-views-icon{width:12px;height:12px}.listen-btn-small{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:var(--text);border:none;border-radius:8px;color:var(--bg);cursor:pointer;transition:all .2s ease}.listen-btn-small svg{width:12px;height:12px;margin-left:1px}@media(hover:hover){.listen-btn-small:hover{opacity:.85;transform:scale(1.05)}}.share-btn-icon{display:flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;background:var(--text);border:none;border-radius:8px;color:var(--bg);cursor:pointer;transition:all .2s ease}.share-btn-icon svg{width:12px;height:12px}.share-btn-icon.copied{background:#22c55e;color:#fff}@media(hover:hover){.share-btn-icon:hover{opacity:.85;transform:scale(1.05)}}.toast{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:6px;font-size:.8rem;font-weight:500}.toast svg{width:14px;height:14px;color:#22c55e}.share-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.share-modal{background:var(--bg);border-radius:16px;width:100%;max-width:420px;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0003}.share-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px}.share-modal-header h2{font-size:1.1rem;font-weight:600;margin:0}.share-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-tertiary);border-radius:50%;transition:all .2s ease}.share-modal-close svg{width:20px;height:20px}@media(hover:hover){.share-modal-close:hover{background:var(--hover-bg);color:var(--text)}}.share-preview-card{display:block;width:calc(100% - 32px);margin:0 16px 20px;background:none;border:none;border-radius:12px;overflow:hidden;cursor:pointer;text-align:left;transition:transform .2s ease}@media(hover:hover){.share-preview-card:hover{transform:scale(.98)}}.share-preview-image{width:100%;aspect-ratio:16 / 9;object-fit:cover;border-radius:12px 12px 0 0}.share-preview-placeholder{width:100%;aspect-ratio:16 / 9;background:var(--hover-bg);border-radius:12px 12px 0 0}.share-preview-info{padding:12px 16px;background:#333;border-radius:0 0 12px 12px}[data-theme=light] .share-preview-info{background:#f0f0f0}.share-preview-source{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:.8rem;color:#ffffffb3}[data-theme=light] .share-preview-source{color:#0009}.share-preview-icon{width:20px;height:20px;border-radius:4px;background:#fff}.share-preview-title{font-size:1rem;font-weight:600;margin:0;color:#fff;line-height:1.3}[data-theme=light] .share-preview-title{color:#1a1a1a}.share-options{display:flex;justify-content:center;gap:8px;padding:0 16px 24px;flex-wrap:wrap}.share-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 16px;background:none;border:none;cursor:pointer;color:var(--text);font-size:.75rem;transition:opacity .2s ease;min-width:70px}@media(hover:hover){.share-option:hover{opacity:.7}}.share-option-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--hover-bg);border-radius:50%}.share-option-icon svg{width:22px;height:22px}.share-option-wrapper{position:relative}.share-more-dropdown{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:var(--bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 20px #00000026;min-width:180px;overflow:hidden}.share-more-dropdown button{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;cursor:pointer;color:var(--text);font-size:.9rem;text-align:left;transition:background .15s ease}@media(hover:hover){.share-more-dropdown button:hover{background:var(--hover-bg)}}.share-more-dropdown button svg{width:20px;height:20px;flex-shrink:0}.share-hn-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:#f60;color:#fff;font-weight:700;font-size:.75rem;border-radius:2px}.citation-ref{color:var(--accent-color);text-decoration:none;font-size:.8em;vertical-align:super}@media(hover:hover){.citation-ref:hover{text-decoration:underline}}.citations-section{margin-top:48px;padding-top:24px;border-top:1px solid var(--border)}.citations-title{font-size:1rem;font-weight:600;margin-bottom:16px;color:var(--text)}.citations-list{list-style:none;counter-reset:citation;padding-left:0}.citation-item{counter-increment:citation;display:flex;gap:8px;font-size:.875rem;color:var(--text-secondary);padding:8px 0;border-bottom:1px solid var(--border)}.citation-item:last-child{border-bottom:none}.citation-item:before{content:counter(citation) ".";color:var(--text-tertiary);font-weight:500;flex-shrink:0;width:20px}.citation-back{color:var(--accent-color);font-size:.75rem;margin-right:4px;text-decoration:none}@media(hover:hover){.citation-back:hover{text-decoration:underline}}.citation-text{flex:1}.editor-split{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.editor-pane{display:flex;flex-direction:column}.editor-pane .editor-textarea{flex:1;min-height:500px;resize:none}.preview-pane{display:flex;flex-direction:column}.preview-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:8px}.preview-pane .editor-preview{flex:1;overflow-y:auto}.floating-toolbar{position:fixed;display:flex;align-items:center;gap:2px;padding:6px 8px;background:var(--bg);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 20px #00000026;z-index:100}.floating-toolbar button{padding:6px 8px;background:none;border:none;cursor:pointer;color:var(--text-secondary);border-radius:4px;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease}@media(hover:hover){.floating-toolbar button:hover{background:var(--hover-bg);color:var(--text)}}.toolbar-divider-v{width:1px;height:18px;background:var(--border);margin:0 4px}.citation-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.citation-modal{background:var(--bg);padding:24px;border-radius:12px;box-shadow:0 20px 60px #0003;width:400px;max-width:90vw}.citation-modal h3{font-size:1rem;font-weight:600;margin-bottom:16px;color:var(--text)}.citation-modal form{display:flex;flex-direction:column;gap:16px}.citation-modal textarea{width:100%;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:16px;line-height:1.5;resize:vertical;font-family:inherit;outline:none;transition:border-color .2s ease}.citation-modal textarea:focus{border-color:var(--text-tertiary)}.citation-modal-actions{display:flex;justify-content:flex-end;gap:12px}.editor-container{max-width:1200px}@media(max-width:768px){.editor-split{grid-template-columns:1fr}.preview-pane{order:-1}.post-row{flex-direction:column;align-items:flex-start;gap:4px}.post-row-date{margin-left:0}}.listen-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--accent-color);color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s ease}@media(hover:hover){.listen-btn:hover{opacity:.9;transform:scale(1.02)}}.listen-btn svg{width:12px;height:12px;fill:currentColor;stroke:none}.audio-player{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:1000;background:var(--bg);border:1px solid var(--border);border-radius:48px;box-shadow:0 4px 24px #0000001f;padding:8px 16px;display:flex;align-items:center;gap:12px}.audio-player-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--text);border:none;cursor:pointer;color:var(--bg);border-radius:50%;transition:all .2s ease;flex-shrink:0}@media(hover:hover){.audio-player-btn:hover{opacity:.85}}.audio-player-btn svg{width:14px;height:14px}.audio-player-progress{position:relative;width:120px;height:4px;background:var(--border);border-radius:2px;cursor:pointer;overflow:hidden}.audio-player-progress-bar{position:absolute;top:0;left:0;height:100%;background:var(--text);border-radius:2px;transition:width .1s ease}.audio-player-close{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-tertiary);border-radius:50%;transition:all .2s ease;flex-shrink:0}@media(hover:hover){.audio-player-close:hover{color:var(--text)}}.audio-player-close svg{width:14px;height:14px}.audio-player-middle{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.audio-player-time{font-size:.7rem;color:var(--text-tertiary);white-space:nowrap;font-variant-numeric:tabular-nums}.audio-player-loading-text{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.audio-player-btn:disabled{cursor:wait}.audio-player-btn .loading-spinner{animation:spin 1s linear infinite}@media(max-width:480px){.audio-player{width:calc(100% - 32px);left:50%;bottom:24px;transform:translate(-50%)}.audio-player-progress{flex:1;min-width:60px}.audio-player-middle{flex:1;min-width:0}}.blog-post-layout{position:relative}.article-header-new{margin-bottom:32px;text-align:center}.article-title-main{font-size:2rem;font-weight:700;margin-bottom:16px;line-height:1.2;color:var(--text);letter-spacing:-.02em}.article-meta-line{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.9rem;color:var(--text-secondary);margin-bottom:20px;flex-wrap:wrap}.article-meta-dot{color:var(--text-tertiary)}.article-meta-icon{width:14px;height:14px;opacity:.7}.article-subtitle{font-size:1.15rem;color:var(--text-tertiary);margin-bottom:28px;font-weight:400;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.5}.article-author-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px}.article-author-actions{display:flex;align-items:center;gap:6px;margin-left:12px;padding-left:12px;border-left:1px solid var(--border)}.article-author-image{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid var(--border)}.article-author-image-bg{background:linear-gradient(145deg,#e8e8e8,#d0d0d0,#c8c8c8)}.article-author-name{font-size:.8rem;font-weight:600;color:var(--text)}.article-actions-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.article-engagement{display:flex;gap:8px}.engagement-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:none;border:1px solid var(--border);border-radius:24px;color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s ease}@media(hover:hover){.engagement-btn:hover{background:var(--hover-bg);color:var(--text)}}.engagement-btn svg{width:18px;height:18px}.share-btn{padding:8px 20px;background:none;border:1px solid var(--border);border-radius:24px;color:var(--text);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}@media(hover:hover){.share-btn:hover{background:var(--hover-bg)}}.article-admin-actions{display:flex;gap:8px;margin-top:8px}.article-divider{height:1px;background:var(--border);margin:24px 0}.toc-toggle-btn-minimal{position:fixed;left:24px;top:50%;transform:translateY(-50%);z-index:100;background:transparent;border:none;padding:12px 8px;cursor:grab;-webkit-user-select:none;user-select:none;width:48px;contain:layout style}.toc-toggle-btn-minimal:active{cursor:grabbing}.toc-lines-minimal{display:flex;flex-direction:column;gap:6px;align-items:center;contain:layout style}.toc-line-minimal{display:block;width:24px;height:2px;background:var(--border);border-radius:1px;transition:background .2s ease,opacity .2s ease,transform .2s ease;transform-origin:center;will-change:transform,background}.toc-line-minimal.active{background:var(--text);transform:scaleX(1.2)}@media(hover:hover){.toc-toggle-btn-minimal:hover .toc-line-minimal{background:var(--text-secondary)}.toc-toggle-btn-minimal:hover .toc-line-minimal.active{background:var(--text)}}.toc-popup{position:fixed;left:80px;transform-origin:left center;z-index:99;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:12px 20px;min-width:200px;max-width:280px;box-shadow:0 4px 24px #00000014}.toc-popup-header{display:flex;align-items:center;gap:8px;font-size:.7rem;font-weight:600;color:var(--text-tertiary);letter-spacing:.5px;margin-bottom:16px}.toc-header-icon{width:14px;height:14px;flex-shrink:0}.toc-popup-nav{display:flex;flex-direction:column;gap:2px}.toc-popup-item{display:block;width:100%;text-align:left;background:none;border:none;padding:8px 12px;margin:0 -12px;width:calc(100% + 24px);font-size:1rem;font-weight:400;color:var(--text-tertiary);cursor:pointer;transition:all .15s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-radius:8px}.toc-popup-item.active{color:var(--text);font-weight:600}.toc-popup-item-sub{padding-left:24px;font-size:.9rem}@media(hover:hover){.toc-popup-item:hover{color:var(--text);background:var(--hover-bg)}}.toc-toggle-btn,.toc-sidebar{display:none}.more-articles{margin-top:64px;padding-top:0}.more-articles-tabs-container{display:flex;align-items:center}.more-articles-tabs{display:flex;align-items:center;gap:0;background:var(--hover-bg);padding:4px;border-radius:24px;width:fit-content}.more-articles-tab{padding:10px 18px;background:none;border:none;border-radius:20px;font-size:.9rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}@media(hover:hover){.more-articles-tab:hover{color:var(--text)}}.more-articles-tab.active{background:var(--bg);color:var(--text);box-shadow:0 1px 3px #00000014}.more-articles-divider{height:1px;background:var(--border);margin:20px 0}.more-articles-list{display:flex;flex-direction:column}.more-article-item{display:flex;flex-direction:row;align-items:center;gap:20px;padding:24px 0;border-bottom:1px solid var(--border);text-decoration:none;transition:opacity .2s ease}.more-article-item:last-child{border-bottom:none}@media(hover:hover){.more-article-item:hover{opacity:.7}}.more-article-content{flex:1;min-width:0}.more-article-image{width:80px;height:80px;object-fit:cover;border-radius:8px;flex-shrink:0}.more-article-title{font-size:1.25rem;font-weight:600;color:var(--text);margin-bottom:6px;line-height:1.35}.more-article-subtitle{font-size:.95rem;color:var(--text-secondary);margin-bottom:10px;line-height:1.5}.more-article-meta{font-size:.8rem;color:var(--text-tertiary);letter-spacing:.2px}.see-all-btn{display:inline-flex;align-items:center;gap:5px;margin-top:24px;padding:8px 14px;background:var(--hover-bg);border:none;border-radius:6px;color:var(--text);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}@media(hover:hover){.see-all-btn:hover{background:var(--border)}}.see-all-btn svg{width:14px;height:14px}.article-listen-section{margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}.listen-btn-large{display:inline-flex;align-items:center;gap:10px;padding:12px 24px;background:var(--text);color:var(--bg);border:none;border-radius:30px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}@media(hover:hover){.listen-btn-large:hover{opacity:.9;transform:scale(1.02)}}.listen-btn-large svg{width:16px;height:16px}.editor-subtitle-input{font-size:1rem;padding:8px 0;border:none;background:none;color:var(--text-secondary);outline:none;border-bottom:1px solid var(--border)}.editor-image-field{display:flex;flex-direction:column;gap:12px}.editor-image-input{font-size:16px;padding:10px 12px;border:1px dashed var(--border);border-radius:8px;background:none;color:var(--text-secondary);outline:none;transition:border-color .2s ease}.editor-image-input:focus{border-color:var(--text-tertiary);border-style:solid}.editor-image-input::placeholder{color:var(--text-tertiary)}.editor-image-preview{position:relative;width:200px;height:120px;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.editor-image-preview img{width:100%;height:100%;object-fit:cover}.editor-image-remove{position:absolute;top:8px;right:8px;width:24px;height:24px;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}@media(hover:hover){.editor-image-remove:hover{background:#000000e6}}.editor-image-remove svg{width:14px;height:14px}.post-row-enhanced{display:flex;justify-content:space-between;align-items:center;padding:16px 0;transition:opacity .2s ease;border-bottom:1px solid var(--border)}.post-row-enhanced:last-child{border-bottom:none}@media(hover:hover){.post-row-enhanced:hover{opacity:.7}}.post-row-content{display:flex;flex-direction:column;gap:4px;flex:1;padding-right:16px}.post-row-subtitle{font-size:.85rem;color:var(--text-tertiary)}.post-row-image{width:60px;height:60px;flex-shrink:0;border-radius:6px;overflow:hidden}.post-row-image img{width:100%;height:100%;object-fit:cover}@media(max-width:1024px){.toc-toggle-btn-minimal,.toc-popup{display:none}}@media(max-width:640px){.article-title-main{font-size:1.5rem}.article-meta-line{font-size:.8rem;gap:6px}.article-subtitle{font-size:1rem}.article-author-row{flex-wrap:wrap;justify-content:center}.article-author-actions{width:100%;justify-content:center;margin-left:0;margin-top:12px;padding-left:0;border-left:none}.share-btn-icon{width:30px;height:30px}.article-views-pill{font-size:.65rem;padding:3px 6px}.more-articles-tabs{width:100%;overflow-x:auto}.more-article-image{width:80px;height:80px}.more-article-title{font-size:1rem}}.touch-none{touch-action:none}.touch-pan-x{touch-action:pan-x}.touch-pan-y{touch-action:pan-y}.gpu-accelerated{transform:translateZ(0);backface-visibility:hidden}.will-change-transform{will-change:transform}.will-change-opacity{will-change:opacity}.will-change-scroll{will-change:scroll-position}.edit-mode-btn{width:28px;height:28px;border-radius:6px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--text-tertiary)}.edit-mode-btn:hover{background:var(--hover-bg);color:var(--text)}.edit-mode-btn.active{background:var(--accent-color, #3b82f6);color:#fff}.edit-mode-btn svg{width:14px;height:14px}.logout-btn-small{width:28px;height:28px;border-radius:6px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--text-tertiary)}.logout-btn-small:hover{background:var(--hover-bg);color:var(--text)}.logout-btn-small svg{width:14px;height:14px}.edit-mode-indicator{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:var(--accent-color, #3b82f6);color:#fff;font-size:.75rem;font-weight:500;padding:6px 14px;border-radius:20px;z-index:100;pointer-events:none;box-shadow:0 2px 10px #00000026}.editable-section{position:relative;transition:all .2s ease;border-radius:12px}.editable-section.editable-hover{outline:2px dashed var(--accent-color, #3b82f6);outline-offset:12px}.edit-indicator{position:absolute;top:-28px;right:0;background:var(--accent-color, #3b82f6);color:#fff;font-size:.7rem;font-weight:500;padding:4px 10px;border-radius:6px;white-space:nowrap;pointer-events:none;box-shadow:0 2px 8px #00000026}.inline-editor-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.inline-editor{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:24px;width:100%;max-width:440px;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.inline-editor-large{max-width:560px}.editor-title{font-size:1.1rem;font-weight:600;margin-bottom:20px;color:var(--text)}.editor-section{margin-bottom:24px}.editor-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.editor-section-header label{font-size:.85rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.editor-field{margin-bottom:16px}.editor-field label{display:block;font-size:.8rem;color:var(--text-tertiary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.editor-field input,.editor-field textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s ease;box-sizing:border-box}.editor-field input:focus,.editor-field textarea:focus{border-color:var(--accent-color, #3b82f6)}.editor-field textarea{resize:vertical;min-height:60px}.editor-formatting-toolbar{display:flex;gap:4px;margin-bottom:6px}.formatting-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:.9rem;cursor:pointer;transition:all .15s ease}.formatting-btn:hover{background:var(--hover-bg);border-color:var(--text-tertiary)}.formatting-btn strong{font-weight:700}.formatting-btn em{font-style:italic}.editor-field-small{flex:0 0 100px}.editor-row{display:flex;gap:12px}.editor-row .editor-field{flex:1}.editor-field-row{display:flex;gap:8px;margin-bottom:12px}.editor-field-row textarea{flex:1}.editor-link-row{display:flex;gap:8px;margin-bottom:12px}.editor-link-row input{flex:1;padding:8px 10px;font-size:.9rem}.editor-item-card{background:var(--hover-bg);border-radius:10px;padding:16px;margin-bottom:12px}.editor-item-card .editor-field{margin-bottom:12px}.editor-item-card .editor-field:last-of-type{margin-bottom:0}.editor-image-actions{display:flex;gap:8px}.editor-image-picker{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px;margin-top:10px;overflow:hidden}.editor-image-picker-empty{text-align:center;color:var(--text-tertiary);font-size:.85rem;padding:16px;margin:0}.editor-image-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:8px;max-height:160px;overflow-y:auto}.editor-image-picker-item{aspect-ratio:1;border:none;border-radius:6px;overflow:hidden;cursor:pointer;padding:0;background:transparent;transition:all .15s ease}.editor-image-picker-item:hover{transform:scale(1.05);box-shadow:0 2px 8px #00000026}.editor-image-picker-item img{width:100%;height:100%;object-fit:cover}.editor-images-list{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}.editor-image-item{position:relative;width:80px;height:60px;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.editor-image-item img{width:100%;height:100%;object-fit:cover}.editor-image-item-actions{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;gap:2px;padding:3px;background:linear-gradient(transparent,#000000b3);opacity:0;transition:opacity .15s ease}.editor-image-item:hover .editor-image-item-actions{opacity:1}.editor-image-move-btn,.editor-image-remove-btn{width:20px;height:20px;border:none;border-radius:4px;background:#ffffffe6;color:#333;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s ease}.editor-image-move-btn:disabled{opacity:.3;cursor:not-allowed}.editor-image-move-btn:hover:not(:disabled),.editor-image-remove-btn:hover{background:#fff;transform:scale(1.1)}.editor-image-remove-btn{background:#ef4444e6;color:#fff}.editor-image-remove-btn:hover{background:#ef4444}.editor-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.cancel-btn{padding:8px 16px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s ease}.cancel-btn:hover:not(:disabled){background:var(--hover-bg);color:var(--text)}.cancel-btn:disabled{opacity:.5;cursor:not-allowed}.save-btn{padding:8px 20px;border:none;border-radius:8px;background:var(--accent-color, #3b82f6);color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.save-btn:hover:not(:disabled){opacity:.9}.save-btn:disabled{opacity:.5;cursor:not-allowed}.add-btn{padding:4px 10px;border:1px dashed var(--border);border-radius:6px;background:transparent;color:var(--text-tertiary);font-size:.8rem;cursor:pointer;transition:all .2s ease}.add-btn:hover{border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #3b82f6)}.add-btn-small{padding:2px 8px;font-size:.75rem}.editor-link-row{display:flex;gap:8px;margin-top:8px;align-items:center}.editor-link-label{flex:0 0 140px}.editor-link-url{flex:1}.remove-link-btn{width:28px;height:28px;flex-shrink:0;border:none;border-radius:6px;background:transparent;color:var(--text-tertiary);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.remove-link-btn:hover{background:#ef44441a;color:#ef4444}.remove-btn{width:28px;height:28px;flex-shrink:0;border:none;border-radius:6px;background:transparent;color:var(--text-tertiary);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.remove-btn:hover{background:#ef44441a;color:#ef4444}.remove-item-btn{width:100%;padding:6px;margin-top:12px;border:none;border-radius:6px;background:transparent;color:var(--text-tertiary);font-size:.8rem;cursor:pointer;transition:all .2s ease}.remove-item-btn:hover{background:#ef44441a;color:#ef4444}.skeleton-header{display:flex;justify-content:space-between;align-items:center;padding:20px 0;margin-bottom:20px}.skeleton-nav{display:flex;gap:24px}.skeleton-nav-item{width:50px;height:14px;border-radius:4px;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-header-right{display:flex;align-items:center;gap:16px}.skeleton-location{width:80px;height:14px;border-radius:4px;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-theme-btn{width:28px;height:28px;border-radius:6px;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.loading-skeleton{padding-top:20px}.skeleton-profile{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:40px}.skeleton-avatar{width:40px;height:40px;border-radius:10px;background:var(--hover-bg);margin-bottom:20px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-text{height:16px;border-radius:4px;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-name{width:120px;height:22px;margin-bottom:8px}.skeleton-title{width:140px;height:14px}.skeleton-section{margin-bottom:48px}.skeleton-heading{width:60px;height:14px;margin-bottom:20px}.skeleton-paragraph{width:100%;height:16px;margin-bottom:12px}.skeleton-paragraph-short{width:70%}.skeleton-social-links{display:flex;gap:20px;margin-top:16px}.skeleton-social-link{width:70px;height:14px;border-radius:4px;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-accordion{width:100%;height:48px;border-radius:8px;background:var(--hover-bg);margin-bottom:8px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-work-item{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--border)}.skeleton-work-item:before{content:"";width:60%;height:16px;border-radius:4px;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-work-item:after{content:"";width:40px;height:14px;border-radius:4px;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-experience-row{display:flex;align-items:center;gap:16px;padding:12px 0}.skeleton-experience-row:before{content:"";width:120px;height:14px;border-radius:4px;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-experience-row:after{content:"";flex:1;height:1px;background:var(--border)}.skeleton-breadcrumb{width:150px;height:14px;border-radius:4px;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-theme-toggle{width:28px;height:28px;border-radius:6px;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-article-title{width:80%;height:32px;border-radius:6px;background:var(--hover-bg);margin-bottom:16px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-article-meta{width:200px;height:14px;border-radius:4px;background:var(--hover-bg);margin-bottom:12px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-article-subtitle{width:60%;height:18px;border-radius:4px;background:var(--hover-bg);margin-bottom:24px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-article-author{display:flex;align-items:center;gap:12px}.skeleton-author-image{width:40px;height:40px;border-radius:50%;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-author-name{width:100px;height:14px;border-radius:4px;background:var(--hover-bg);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-article-content{padding-top:24px}.skeleton-article-content .skeleton-paragraph{height:16px;border-radius:4px;background:var(--hover-bg);margin-bottom:16px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-article-content .skeleton-short{width:45%}.skeleton-article-content .skeleton-medium{width:70%}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.8}}@media(max-width:640px){.skeleton-nav{display:none}.skeleton-header{justify-content:flex-end}}.blog-editor-page{min-height:100vh;background:var(--bg)}.editor-header{position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:var(--bg);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.editor-header-left{display:flex;align-items:center;gap:16px}.editor-back-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;color:var(--text-secondary);transition:all .2s ease}.editor-back-btn:hover{background:var(--hover-bg);color:var(--text)}.editor-save-status{font-size:.85rem}.editor-save-status .saving{color:var(--text-tertiary)}.editor-save-status .saved{display:flex;align-items:center;gap:6px;color:var(--text-secondary)}.editor-save-status .saved-dot{width:8px;height:8px;border-radius:50%;background:#22c55e}.editor-save-status .unsaved{color:#f59e0b}.editor-header-right{display:flex;align-items:center;gap:12px}.editor-preview-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:.9rem;cursor:pointer;transition:all .2s ease}.editor-preview-btn:hover{background:var(--hover-bg)}.editor-publish-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:8px;background:#c2410c;color:#fff;font-size:.9rem;cursor:pointer;transition:all .2s ease}.editor-publish-btn:hover{background:#9a3412}.editor-publish-btn:disabled{opacity:.6;cursor:not-allowed}.editor-main{max-width:800px;margin:0 auto;padding:48px 24px 100px}.editor-metadata{margin-bottom:32px}.editor-image-field{margin-bottom:24px}.editor-image-input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:.9rem}.editor-image-input:focus{outline:none;border-color:var(--accent-color)}.editor-image-input-row{display:flex;gap:8px}.editor-image-input-row .editor-image-input{flex:1}.editor-image-file-input{display:none}.editor-image-upload-btn{display:flex;align-items:center;gap:6px;padding:12px 16px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.editor-image-upload-btn:hover{border-color:var(--text-tertiary);color:var(--text)}.editor-image-upload-btn:disabled{opacity:.6;cursor:not-allowed}.editor-image-upload-btn .upload-spinner{width:14px;height:14px;border:2px solid var(--text-tertiary);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.editor-image-preview{margin-top:12px;position:relative;border-radius:12px;overflow:hidden}.editor-image-preview img{width:100%;max-height:300px;object-fit:cover}.editor-image-remove{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:8px;border:none;background:#00000080;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.editor-image-remove:hover{background:#000000b3}.image-crop-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.image-crop-modal{background:var(--bg);border-radius:16px;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.image-crop-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.image-crop-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text)}.image-crop-close{background:none;border:none;padding:8px;cursor:pointer;color:var(--text-secondary);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.image-crop-close:hover{background:var(--bg-secondary);color:var(--text)}.image-crop-aspect-options{display:flex;gap:8px;padding:12px 20px;border-bottom:1px solid var(--border)}.aspect-option{padding:6px 14px;border:1px solid var(--border);border-radius:20px;background:transparent;color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s ease}.aspect-option:hover{border-color:var(--text-tertiary);color:var(--text)}.aspect-option.active{background:var(--text);border-color:var(--text);color:var(--bg)}.image-crop-container{flex:1;overflow:auto;padding:20px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);min-height:300px}.image-crop-area{max-width:100%;max-height:60vh}.image-crop-preview{max-width:100%;max-height:60vh;display:block}.image-crop-actions{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-top:1px solid var(--border);gap:12px}.image-crop-actions-right{display:flex;gap:12px}.image-crop-reset{display:flex;align-items:center;gap:6px;padding:10px 16px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s ease}.image-crop-reset:hover{border-color:var(--text-tertiary);color:var(--text)}.image-crop-cancel{padding:10px 20px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s ease}.image-crop-cancel:hover{border-color:var(--text-tertiary);color:var(--text)}.image-crop-confirm{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;background:var(--text);color:var(--bg);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.image-crop-confirm:hover{opacity:.9}.ReactCrop{max-width:100%}.ReactCrop__crop-selection{border:2px solid white;box-shadow:0 0 0 9999px #00000080}.editor-title-input{width:100%;padding:0;border:none;background:transparent;color:var(--text);font-size:2.5rem;font-weight:700;line-height:1.2;margin-bottom:12px}.editor-title-input::placeholder{color:var(--text-tertiary)}.editor-title-input:focus{outline:none}.editor-subtitle-input{width:100%;padding:0;border:none;background:transparent;color:var(--text-secondary);font-size:1.25rem;margin-bottom:16px}.editor-subtitle-input::placeholder{color:var(--text-tertiary)}.editor-subtitle-input:focus{outline:none}.editor-meta-row{display:flex;align-items:center;gap:16px;margin-bottom:16px}.editor-author-tags{display:flex;gap:8px;flex-wrap:wrap}.author-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:var(--hover-bg);border-radius:20px;font-size:.85rem;color:var(--text)}.author-tag-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:var(--border);border-radius:50%;color:var(--text-secondary);cursor:pointer}.author-tag-remove:hover{background:var(--text-tertiary);color:var(--text)}.editor-date-picker{position:relative}.date-picker-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s ease}.date-picker-btn:hover{border-color:var(--text-tertiary)}.date-picker-dropdown{position:absolute;top:100%;left:0;margin-top:4px;padding:8px;background:var(--bg);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:50}.date-picker-dropdown input{padding:8px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text)}.editor-slug-input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:var(--hover-bg);color:var(--text-secondary);font-size:.85rem;font-family:monospace}.editor-slug-input:focus{outline:none;border-color:var(--accent-color)}.editor-content-area{min-height:400px}.block-editor{border:1px solid var(--border);border-radius:12px;background:var(--bg);overflow:hidden}.block-editor-wrapper{padding:24px;min-height:300px}.block-editor-content{outline:none;min-height:200px;font-size:1rem;line-height:1.75;color:var(--text)}.block-editor-content>*:first-child{margin-top:0}.block-editor-content p{margin-bottom:1em}.block-editor-content p.is-empty:first-child:before{content:attr(data-placeholder);color:var(--text-tertiary);float:left;pointer-events:none;height:0}.block-editor-content h1{font-size:2rem;font-weight:700;margin:1.5em 0 .5em}.block-editor-content h2{font-size:1.5rem;font-weight:600;margin:1.5em 0 .5em}.block-editor-content h3{font-size:1.25rem;font-weight:600;margin:1.25em 0 .5em}.block-editor-content ul,.block-editor-content ol{padding-left:1.5em;margin-bottom:1em}.block-editor-content li{margin-bottom:.25em}.block-editor-content blockquote{border-left:3px solid var(--border);padding-left:1em;margin:1em 0;color:var(--text-secondary);font-style:italic}.block-editor-content pre{background:var(--hover-bg);padding:16px;border-radius:8px;overflow-x:auto;margin:1em 0;font-family:SF Mono,Menlo,Monaco,monospace;font-size:.9rem}.block-editor-content code{background:var(--hover-bg);padding:2px 6px;border-radius:4px;font-family:SF Mono,Menlo,Monaco,monospace;font-size:.9em}.block-editor-content pre code{background:transparent;padding:0}.block-editor-content a{color:var(--accent-color);text-decoration:underline}.block-editor-content mark{background:#fef08a;padding:0 2px;border-radius:2px}.block-editor-content hr{border:none;border-top:1px solid var(--border);margin:2em 0}.block-editor-content .task-list{list-style:none;padding-left:0}.block-editor-content .task-item{display:flex;align-items:flex-start;gap:8px}.block-editor-content .task-item>label{margin-top:4px}.block-editor-content .task-item input[type=checkbox]{margin-top:6px;width:16px;height:16px;accent-color:var(--accent-color)}.block-editor-content table{border-collapse:collapse;width:100%;margin:1em 0}.block-editor-content th,.block-editor-content td{border:1px solid var(--border);padding:8px 12px;text-align:left}.block-editor-content th{background:var(--hover-bg);font-weight:600}.editor-toolbar{display:flex;align-items:center;gap:4px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--hover-bg);flex-wrap:wrap}.toolbar-group{display:flex;align-items:center;gap:2px;position:relative}.toolbar-divider{width:1px;height:24px;background:var(--border);margin:0 8px}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.toolbar-btn:hover{background:var(--bg);color:var(--text)}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-btn.active{background:var(--bg);color:var(--text)}.toolbar-dropdown-btn{width:auto;padding:0 12px;gap:4px;font-size:.85rem}.toolbar-dropdown{position:absolute;top:100%;left:0;margin-top:4px;min-width:160px;padding:4px;background:var(--bg);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:100}.toolbar-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;border-radius:6px;background:transparent;color:var(--text);font-size:.9rem;cursor:pointer;text-align:left}.toolbar-dropdown-item:hover,.toolbar-dropdown-item.active{background:var(--hover-bg)}.floating-menu{display:flex;align-items:center;padding:4px;background:var(--bg);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #00000026}.floating-menu-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.floating-menu-btn:hover,.floating-menu-btn.active{background:var(--hover-bg);color:var(--text)}.floating-menu-link-input{display:flex;align-items:center;gap:8px;padding:0 8px}.floating-menu-link-input input{width:200px;padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:.85rem}.floating-menu-link-input input:focus{outline:none;border-color:var(--accent-color)}.floating-menu-link-input .add-btn{padding:6px 12px;border:none;border-radius:6px;background:var(--accent-color);color:#fff;font-size:.85rem;cursor:pointer}.floating-menu-link-input .remove-btn{padding:6px 12px;border:none;border-radius:6px;background:transparent;color:#ef4444;font-size:.85rem;cursor:pointer}.floating-menu-link-input .remove-btn:hover{background:#fef2f2}.slash-command-menu{width:320px;max-height:400px;background:var(--bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px #00000026;overflow:hidden}.slash-command-search{padding:12px 16px;border-bottom:1px solid var(--border);font-size:.9rem;color:var(--text-secondary)}.slash-command-results{max-height:300px;overflow-y:auto;padding:8px}.slash-command-group{margin-bottom:8px}.slash-command-group:last-child{margin-bottom:0}.slash-command-group-title{padding:8px 12px 4px;font-size:.75rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.slash-command-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s ease}.slash-command-item:hover,.slash-command-item.selected{background:var(--hover-bg)}.slash-command-item-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary)}.slash-command-item-content{flex:1;min-width:0}.slash-command-item-title{display:block;font-size:.9rem;font-weight:500;color:var(--text)}.slash-command-item-description{display:block;font-size:.8rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slash-command-empty{padding:24px;text-align:center;color:var(--text-tertiary)}.slash-command-footer{display:flex;justify-content:center;gap:16px;padding:8px 16px;border-top:1px solid var(--border);background:var(--hover-bg);font-size:.75rem;color:var(--text-tertiary)}.slash-command-footer kbd{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .25rem;background:var(--bg);border:1px solid var(--border);border-bottom-width:2px;border-radius:4px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-size:10px;font-weight:500;margin-right:2px;box-shadow:inset 0 -1px #00000014;-webkit-user-select:none;user-select:none}.callout-block{position:relative}.callout-block .callout-content{outline:none}.callout-block .callout-content p{margin:0}.callout-variant-selector{opacity:0;transition:opacity .2s ease}.callout-block:hover .callout-variant-selector{opacity:1}.divider-block{cursor:default}.image-block{position:relative}.image-block img{display:block}.image-placeholder{min-height:150px;display:flex;align-items:center;justify-content:center}.preview-modal-overlay{position:fixed;inset:0;z-index:1000;background:#0009;display:flex;align-items:center;justify-content:center;padding:24px}.preview-modal{width:100%;max-width:800px;max-height:90vh;background:var(--bg);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}.preview-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border)}.preview-modal-header h2{font-size:1.1rem;font-weight:600}.preview-modal-close{width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center}.preview-modal-close:hover{background:var(--hover-bg);color:var(--text)}.preview-modal-content{flex:1;overflow-y:auto;padding:24px}.preview-title-image{margin:-24px -24px 24px}.preview-title-image img{width:100%;max-height:300px;object-fit:cover}.preview-article{max-width:600px;margin:0 auto}.preview-header{margin-bottom:32px}.preview-title{font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:8px}.preview-subtitle{font-size:1.15rem;color:var(--text-secondary);margin-bottom:12px}.preview-date{font-size:.9rem;color:var(--text-tertiary)}.preview-body{line-height:1.75}.icon-picker-overlay{position:fixed;inset:0;z-index:1000;background:#0009;display:flex;align-items:center;justify-content:center;padding:24px}.icon-picker-modal{width:100%;max-width:480px;max-height:80vh;background:var(--bg);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}.icon-picker-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.icon-picker-header h3{font-size:1rem;font-weight:600}.icon-picker-close{width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center}.icon-picker-close:hover{background:var(--hover-bg)}.icon-picker-search{display:flex;align-items:center;gap:8px;padding:12px 20px;border-bottom:1px solid var(--border)}.icon-picker-search input{flex:1;border:none;background:transparent;color:var(--text);font-size:.9rem;outline:none}.icon-picker-categories{display:flex;flex-wrap:wrap;gap:6px;padding:12px 20px;border-bottom:1px solid var(--border)}.icon-picker-category{padding:4px 12px;border:1px solid var(--border);border-radius:20px;background:transparent;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .15s ease}.icon-picker-category:hover{background:var(--hover-bg)}.icon-picker-category.active{background:var(--text);border-color:var(--text);color:var(--bg)}.icon-picker-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;padding:16px;overflow-y:auto;max-height:400px}.icon-picker-item{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.icon-picker-item:hover{background:var(--hover-bg);color:var(--text)}.icon-picker-empty{padding:48px;text-align:center;color:var(--text-tertiary)}.tippy-box{background:transparent;border:none}.tippy-content{padding:0}.image-upload-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.image-upload-modal{background:var(--bg);border:1px solid var(--border);border-radius:12px;width:100%;max-width:560px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.image-upload-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.image-upload-header h2{font-size:1.1rem;font-weight:600}.image-upload-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center}.image-upload-close:hover{background:var(--hover-bg);color:var(--text)}.image-upload-tabs{display:flex;gap:4px;padding:12px 20px;border-bottom:1px solid var(--border)}.image-upload-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .15s ease}.image-upload-tab:hover{background:var(--hover-bg)}.image-upload-tab.active{background:var(--text);color:var(--bg)}.image-upload-content{flex:1;overflow-y:auto;padding:20px}.image-upload-dropzone{border:2px dashed var(--border);border-radius:12px;padding:48px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:all .2s ease;color:var(--text-secondary)}.image-upload-dropzone:hover,.image-upload-dropzone.drag-active{border-color:var(--accent);background:var(--hover-bg)}.image-upload-dropzone.uploading{cursor:wait;opacity:.7}.image-upload-library{min-height:200px}.image-upload-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.image-upload-item{position:relative;aspect-ratio:16/10;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .15s ease}.image-upload-item:hover{border-color:var(--accent)}.image-upload-item img{width:100%;height:100%;object-fit:cover}.image-upload-item-delete{position:absolute;top:6px;right:6px;background:#000000b3;border:none;border-radius:4px;padding:4px;color:#fff;cursor:pointer;opacity:0;transition:opacity .15s ease}.image-upload-item:hover .image-upload-item-delete{opacity:1}.image-upload-item-delete:hover{background:#ef4444}.image-upload-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px;color:var(--text-tertiary)}.image-upload-url{display:flex;gap:12px}.image-upload-url input{flex:1;padding:12px 16px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:.95rem}.image-upload-url input:focus{outline:none;border-color:var(--accent)}.image-upload-url button{padding:12px 24px;border:none;border-radius:8px;background:var(--text);color:var(--bg);font-size:.95rem;font-weight:500;cursor:pointer;transition:opacity .15s ease}.image-upload-url button:hover{opacity:.9}.image-upload-url button:disabled{opacity:.5;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.toc-highlight{background:#80808033;border-radius:8px;padding:8px 12px;margin:-8px -12px;display:inline-block;animation:toc-highlight-fade 2s ease-out forwards}@keyframes toc-highlight-fade{0%{background:#80808040}70%{background:#80808033}to{background:transparent}}.blog-search-bar{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:800px;margin:0 auto 32px;padding:0 20px;box-sizing:border-box}.blog-search-input{display:flex;align-items:center;gap:8px}.blog-search-input svg{width:16px;height:16px;color:var(--text-tertiary);flex-shrink:0}.blog-search-input input{border:none;background:transparent;color:var(--text);font-size:.95rem;outline:none;width:120px}.blog-search-input input::placeholder{color:var(--text-tertiary)}.blog-view-toggle{display:flex;gap:12px}.view-toggle-btn{width:24px;height:24px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s ease;color:var(--text-tertiary);padding:0}.view-toggle-btn.active{color:var(--text)}.view-toggle-btn:hover:not(.active){color:var(--text-secondary)}.view-toggle-btn svg{width:18px;height:18px}.blog-card-list{display:flex;flex-direction:column;max-width:800px;margin:0 auto;padding:0 20px}.blog-card{display:flex;justify-content:space-between;align-items:center;padding:16px 0;transition:opacity .2s ease;border-bottom:1px solid var(--border)}.blog-card:last-child{border-bottom:none}@media(hover:hover){.blog-card:hover{opacity:.7}}.blog-card-content{display:flex;flex-direction:column;gap:4px;flex:1;padding-right:16px}.blog-card-title{font-size:1rem;font-weight:500;color:var(--text);margin:0}.blog-card-subtitle{font-size:.85rem;color:var(--text-tertiary);margin:0;line-height:1.4}.blog-card-meta{font-size:.85rem;color:var(--text-tertiary);margin-top:4px}.blog-card-image{width:60px;height:60px;flex-shrink:0;border-radius:6px;overflow:hidden;background:var(--hover-bg);display:flex;align-items:center;justify-content:center}.blog-card-image img{width:100%;height:100%;object-fit:cover}.blog-card-image-placeholder{display:none}.blog-table-list{max-width:800px;margin:0 auto;padding:0 20px}.blog-year-group{display:grid;grid-template-columns:80px 1fr;gap:32px;margin-bottom:24px}.blog-year-group:last-child{margin-bottom:0}.blog-year-header{padding-top:12px}.blog-year-label{font-size:.95rem;color:var(--text-tertiary);font-variant-numeric:tabular-nums;font-weight:400}.blog-year-entries{border-top:1px solid var(--border)}.blog-table-row{display:grid;grid-template-columns:1fr auto;gap:24px;padding:12px 0;align-items:center;border-bottom:1px solid var(--border);transition:opacity .2s ease}.blog-table-row:last-child{border-bottom:none}@media(hover:hover){.blog-table-row:hover{opacity:.7}}.blog-table-title{font-size:.95rem;color:var(--text);font-weight:500}.blog-table-date{font-size:.9rem;color:var(--text-tertiary);font-variant-numeric:tabular-nums}@media(max-width:640px){.blog-card-image{width:50px;height:50px}.blog-year-group{grid-template-columns:60px 1fr;gap:16px;margin-bottom:20px}.blog-year-label{font-size:.85rem}.blog-table-row{gap:12px;padding:10px 0}.blog-table-date{font-size:.85rem}.blog-table-title{font-size:.9rem}}.shelf-artistic-title{font-family:Cormorant Garamond,serif;font-size:2.5rem;font-weight:500;font-style:italic;color:var(--text);letter-spacing:.02em;margin-bottom:32px}.shelf-artistic-title:after{content:"";display:inline-block;width:.18em;height:.18em;background:currentColor;border-radius:50%;margin-left:.12em;vertical-align:baseline}.blog-list-layout.shelf-page{max-width:1200px}.shelf-container{max-width:1200px;padding:32px 24px 64px}.shelf-container .blog-header{margin-bottom:0}.shelf-title-section{margin-top:32px;margin-bottom:40px}.shelf-title{font-family:Cormorant Garamond,serif;font-size:3rem;font-weight:500;font-style:italic;color:var(--text);letter-spacing:.02em}.shelf-content{max-width:100%;width:100%}.shelf-description{text-align:center;color:var(--text-tertiary);font-size:.95rem;font-style:italic;max-width:500px;margin:60px auto 40px}.shelf-quote-card{background:var(--bg-secondary);border-radius:12px;padding:28px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;min-height:140px}.shelf-quote-card:hover{transform:scale(1.02);box-shadow:0 8px 24px #00000014}[data-theme=dark] .shelf-quote-card:hover{box-shadow:0 8px 24px #0000004d}.shelf-quote-card.dark{color:#fff}.shelf-quote-icon{width:24px;height:24px;color:var(--text-tertiary);opacity:.5;flex-shrink:0}.shelf-quote-card.dark .shelf-quote-icon{color:#fff6}.shelf-quote-card blockquote{font-size:1.15rem;font-style:italic;line-height:1.65;color:var(--text);margin:0}.shelf-quote-card.dark blockquote{color:#fff}.shelf-quote-card cite{display:flex;flex-direction:column;align-items:center;gap:2px;font-style:normal}.shelf-quote-card .quote-author{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.shelf-quote-card.dark .quote-author{color:#ffffffd9}.shelf-quote-card .quote-source{font-size:.75rem;color:var(--text-tertiary)}.shelf-quote-card.dark .quote-source{color:#fff9}.shelf-quote-card.bar-style{padding:24px;align-items:flex-start;text-align:left}.shelf-quote-bar-wrapper{display:flex;gap:16px;align-items:stretch;width:100%}.shelf-quote-bar-line{width:3px;background:var(--text-tertiary);border-radius:2px;flex-shrink:0;opacity:.5}.shelf-quote-card.dark .shelf-quote-bar-line{background:#fff6}.shelf-quote-bar-content{display:flex;flex-direction:column;gap:12px}.shelf-quote-card.bar-style blockquote{font-style:normal}.shelf-quote-card.bar-style cite{align-items:flex-start}.shelf-quote-preview{background:var(--bg);border-radius:16px;padding:48px;max-width:560px;display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center}.shelf-quote-preview.dark{color:#fff}.shelf-quote-preview .shelf-quote-icon{width:32px;height:32px}.shelf-quote-preview blockquote{font-size:1.5rem;font-style:italic;line-height:1.7;color:var(--text);margin:0}.shelf-quote-preview.dark blockquote{color:#fff}.shelf-quote-preview cite{display:flex;flex-direction:column;gap:4px;font-style:normal}.shelf-quote-preview .quote-author{font-size:1rem;font-weight:500;color:var(--text-secondary)}.shelf-quote-preview.dark .quote-author{color:#ffffffd9}.shelf-quote-preview .quote-source{font-size:.875rem;color:var(--text-tertiary)}.shelf-quote-preview.dark .quote-source{color:#fff9}.shelf-quote-preview.bar-style{align-items:flex-start;text-align:left;padding:40px}.shelf-quote-preview.bar-style .shelf-quote-bar-wrapper{width:100%}.shelf-quote-preview.bar-style .shelf-quote-bar-line{width:4px}.shelf-quote-preview.bar-style blockquote{font-style:normal;font-size:1.35rem}.shelf-quote-preview.bar-style cite{align-items:flex-start;margin-top:8px}@media(max-width:768px){.shelf-container{padding:24px 16px 48px}.shelf-title{font-size:2.5rem}.shelf-title-section{margin-top:24px;margin-bottom:32px}.shelf-description{font-size:.9rem;margin-top:40px}.shelf-quote-card{padding:20px}.shelf-quote-card blockquote{font-size:1rem}.shelf-quote-preview{padding:32px}.shelf-quote-preview blockquote{font-size:1.25rem}}.shelf-empty{color:var(--text-tertiary);text-align:center;padding:60px 0}.shelf-masonry{column-count:4;column-gap:20px}@media(max-width:1100px){.shelf-masonry{column-count:3}}@media(max-width:768px){.shelf-masonry{column-count:2;column-gap:16px}}@media(max-width:480px){.shelf-masonry{column-count:1}}.shelf-item{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;background:var(--bg-secondary);transition:transform .2s ease,box-shadow .2s ease;break-inside:avoid;margin-bottom:16px}@media(max-width:768px){.shelf-item{margin-bottom:12px}}.shelf-item-image:hover{transform:scale(1.02);box-shadow:0 8px 30px #0000001f;cursor:pointer}[data-theme=dark] .shelf-item-image:hover{box-shadow:0 8px 30px #0006}.shelf-item img{width:100%;height:auto;display:block}.shelf-item-caption{position:absolute;bottom:0;left:0;right:0;padding:12px;background:linear-gradient(transparent,#000000b3);opacity:0;transition:opacity .2s ease}.shelf-item:hover .shelf-item-caption{opacity:1}.shelf-item-caption span{color:#fff;font-size:.85rem;font-weight:500}.shelf-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.shelf-modal{background:var(--bg);border-radius:16px;padding:28px;width:100%;max-width:440px;box-shadow:0 20px 60px #0003}[data-theme=dark] .shelf-modal{box-shadow:0 20px 60px #00000080;border:1px solid var(--border)}.shelf-modal h2{font-size:1.25rem;font-weight:600;color:var(--text);margin-bottom:20px}.shelf-upload-zone{border:2px dashed var(--border);border-radius:12px;padding:40px 20px;text-align:center;cursor:pointer;transition:border-color .2s ease,background .2s ease}.shelf-upload-zone:hover,.shelf-upload-zone.active{border-color:var(--accent);background:var(--bg-secondary)}.shelf-upload-zone svg{width:40px;height:40px;color:var(--text-tertiary);margin-bottom:12px}.shelf-upload-zone p{color:var(--text-secondary);font-size:.95rem}.shelf-image-preview{position:relative;border-radius:12px;overflow:hidden;background:var(--bg-secondary)}.shelf-image-preview img{width:100%;max-height:250px;object-fit:contain;display:block}.shelf-preview-change{position:absolute;bottom:12px;right:12px;padding:8px 14px;border:none;border-radius:6px;background:#000000b3;color:#fff;font-size:.8rem;cursor:pointer;transition:background .2s ease}.shelf-preview-change:hover{background:#000000d9}.shelf-upload-caption{margin-top:16px}.shelf-upload-caption input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:8px;background:var(--bg-secondary);color:var(--text);font-size:.95rem;transition:border-color .2s ease}.shelf-upload-caption input:focus{outline:none;border-color:var(--accent)}.shelf-upload-caption input::placeholder{color:var(--text-tertiary)}.shelf-modal-actions{display:flex;justify-content:flex-end;margin-top:20px;gap:12px}.shelf-modal-cancel{padding:10px 20px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s ease}.shelf-modal-cancel:hover{background:var(--bg-secondary);color:var(--text)}.shelf-uploading{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px;color:var(--text-secondary);font-size:.9rem}.shelf-preview-overlay{background:#000000e6}.shelf-preview-modal{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.shelf-preview-modal img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px}.shelf-preview-caption{color:#fff;font-size:.95rem;margin-top:16px;text-align:center}.shelf-preview-close{position:absolute;top:-50px;right:0;background:transparent;border:none;cursor:pointer;padding:8px}.shelf-preview-close svg{width:28px;height:28px;color:#fff;opacity:.8;transition:opacity .2s ease}.shelf-preview-close:hover svg{opacity:1}.shelf-preview-delete{position:absolute;top:-50px;left:0;background:transparent;border:none;cursor:pointer;padding:8px}.shelf-preview-delete svg{width:24px;height:24px;color:#ef4444;opacity:.8;transition:opacity .2s ease}.shelf-preview-delete:hover svg{opacity:1}.shelf-item-quote{background:var(--bg-secondary);padding:24px;display:flex;align-items:center;justify-content:center}.shelf-item-quote.shelf-item-small{padding:16px}.shelf-item-quote.shelf-item-medium{padding:24px}.shelf-item-quote.shelf-item-large{padding:32px}.shelf-item-quote.dark-bg{color:#fff}.shelf-quote-content{display:flex;flex-direction:column;gap:12px;text-align:center}.shelf-quote-mark{width:24px;height:24px;color:var(--text-tertiary);margin:0 auto;opacity:.5}.shelf-item-quote.dark-bg .shelf-quote-mark{color:#fff6}.shelf-quote-content blockquote{font-size:1rem;font-style:italic;line-height:1.6;color:var(--text);margin:0}.shelf-item-small .shelf-quote-content blockquote{font-size:.9rem}.shelf-item-large .shelf-quote-content blockquote{font-size:1.15rem}.shelf-item-quote.dark-bg blockquote{color:#fff}.shelf-quote-content cite{display:flex;flex-direction:column;gap:2px;font-style:normal;font-size:.85rem}.shelf-quote-content .quote-author{color:var(--text-secondary);font-weight:500}.shelf-item-quote.dark-bg .quote-author{color:#ffffffd9}.shelf-quote-content .quote-source{color:var(--text-tertiary);font-size:.8rem}.shelf-item-quote.dark-bg .quote-source{color:#fff9}.shelf-item-quote.bar-style{text-align:left}.shelf-item-quote.bar-style .shelf-quote-content{display:flex;flex-direction:row;align-items:stretch;gap:16px;text-align:left}.shelf-quote-bar{width:3px;min-height:100%;background:var(--text-tertiary);border-radius:2px;flex-shrink:0;opacity:.5}.shelf-item-quote.dark-bg .shelf-quote-bar{background:#fff6}.shelf-item-quote.bar-style blockquote{font-style:normal}.shelf-item-quote.bar-style cite{align-items:flex-start}.shelf-item-text{background:var(--bg-secondary);padding:16px;display:flex;align-items:center;justify-content:center}.shelf-item-text.shelf-item-small{padding:12px}.shelf-item-text.shelf-item-medium{padding:20px}.shelf-item-text.shelf-item-large{padding:28px}.shelf-item-text.dark-bg{color:#fff}.shelf-text-content{display:flex;flex-direction:column;gap:6px;text-align:center}.shelf-text-content .text-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);font-weight:600}.shelf-item-text.dark-bg .text-label{color:#ffffff80}.shelf-text-content p{font-size:.95rem;color:var(--text);margin:0;line-height:1.5}.shelf-item-text.dark-bg p{color:#fff}.shelf-type-selector{display:flex;gap:8px;margin-bottom:20px}.shelf-type-selector .type-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;border:1px solid var(--border);border-radius:10px;background:transparent;color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s ease}.shelf-type-selector .type-btn svg{width:22px;height:22px}.shelf-type-selector .type-btn:hover{background:var(--bg-secondary);color:var(--text)}.shelf-type-selector .type-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.shelf-form{display:flex;flex-direction:column;gap:12px}.shelf-form textarea,.shelf-form input[type=text]{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:8px;background:var(--bg-secondary);color:var(--text);font-size:.95rem;font-family:inherit;transition:border-color .2s ease;resize:none}.shelf-form textarea:focus,.shelf-form input[type=text]:focus{outline:none;border-color:var(--accent)}.shelf-form textarea::placeholder,.shelf-form input::placeholder{color:var(--text-tertiary)}.shelf-form-row{display:flex;align-items:center;gap:12px;margin-top:4px}.shelf-form-row label{font-size:.85rem;color:var(--text-secondary);min-width:80px}.size-selector{display:flex;gap:6px}.size-selector .size-btn{padding:6px 14px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.8rem;text-transform:capitalize;cursor:pointer;transition:all .2s ease}.size-selector .size-btn:hover{background:var(--bg-secondary)}.size-selector .size-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.style-selector{display:flex;gap:6px}.style-selector .style-btn{padding:6px 14px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s ease}.style-selector .style-btn:hover{background:var(--bg-secondary)}.style-selector .style-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.color-selector{display:flex;gap:8px}.color-selector .color-btn{width:28px;height:28px;border:2px solid var(--border);border-radius:50%;cursor:pointer;transition:all .2s ease}.color-selector .color-btn:hover{transform:scale(1.1)}.color-selector .color-btn.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--accent)}.shelf-modal-submit{padding:10px 20px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.shelf-modal-submit:hover:not(:disabled){opacity:.9}.shelf-modal-submit:disabled{opacity:.5;cursor:not-allowed}.shelf-add-modal{max-width:480px}.shelf-preview-quote,.shelf-preview-text{background:var(--bg);padding:40px;border-radius:12px;max-width:500px;text-align:center}.shelf-preview-quote blockquote{font-size:1.25rem;font-style:italic;line-height:1.7;color:var(--text);margin:0 0 20px}.shelf-preview-quote cite{display:flex;flex-direction:column;gap:4px;font-style:normal}.shelf-preview-quote .quote-author{color:var(--text-secondary);font-weight:500;font-size:.95rem}.shelf-preview-quote .quote-source{color:var(--text-tertiary);font-size:.85rem}.shelf-preview-text .text-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);font-weight:600;margin-bottom:8px}.shelf-preview-text p{font-size:1.1rem;color:var(--text);margin:0;line-height:1.6}.edit-mode-toggle{width:28px;height:28px;border-radius:6px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:background .2s ease,color .2s ease}.edit-mode-toggle:hover{background:var(--hover-bg);color:var(--text)}.edit-mode-toggle.active{background:var(--accent);color:#fff}.edit-mode-toggle svg{width:15px;height:15px}.shelf-reorder-list{display:flex;flex-direction:column;gap:12px;max-width:600px;margin:0 auto}.shelf-reorder-list .shelf-item{break-inside:unset;margin-bottom:0;max-height:200px;overflow:hidden}.shelf-reorder-list .shelf-item-image{height:auto}.shelf-reorder-list .shelf-item-image img{max-height:180px;width:auto;max-width:100%;object-fit:contain}.shelf-item-edit-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;background:#00000080;border:none;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s ease;z-index:10}.shelf-item:hover .shelf-item-edit-btn{opacity:1}.shelf-item-edit-btn svg{width:14px;height:14px;color:#fff}.shelf-item-edit-btn:hover{background:#000000b3}.shelf-item.edit-mode{cursor:grab;-webkit-user-select:none;user-select:none}.shelf-item.edit-mode:active{cursor:grabbing}.shelf-item-drag-handle{position:absolute;top:8px;left:8px;width:28px;height:28px;background:#00000080;border-radius:6px;display:flex;align-items:center;justify-content:center;z-index:10}.shelf-item-drag-handle svg{width:16px;height:16px;color:#fff}.shelf-reorder-item{position:relative;display:flex;align-items:center;gap:12px;padding:12px 12px 12px 48px;background:var(--bg-secondary);border-radius:8px;cursor:grab;-webkit-user-select:none;user-select:none}.shelf-reorder-item:active{cursor:grabbing}.shelf-reorder-item.dark-bg{color:#fff}.shelf-reorder-item img{max-height:80px;width:auto;border-radius:4px}.shelf-reorder-quote,.shelf-reorder-text{font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.shelf-edit-hint{font-size:.85rem;color:var(--text-tertiary);margin-top:8px}.shelf-preview-edit{position:absolute;top:-50px;left:40px;background:transparent;border:none;cursor:pointer;padding:8px}.shelf-preview-edit svg{width:22px;height:22px;color:#fff;opacity:.8;transition:opacity .2s ease}.shelf-preview-edit:hover svg{opacity:1}.shelf-edit-modal{max-width:500px;width:100%}.shelf-edit-image-preview{width:100%;max-height:200px;border-radius:8px;overflow:hidden;margin-bottom:16px}.shelf-edit-image-preview img{width:100%;height:100%;object-fit:contain}.shelf-modal-actions-right{display:flex;gap:12px}.shelf-modal-delete{padding:10px 20px;border:1px solid #ef4444;border-radius:8px;background:transparent;color:#ef4444;font-size:.9rem;cursor:pointer;transition:all .2s ease;margin-right:auto}.shelf-modal-delete:hover{background:#ef4444;color:#fff}
