@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--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-duration:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-blue-600:oklch(54.6% .245 262.881);--color-gray-800:oklch(27.8% .033 256.848);--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-lg:32rem;--container-2xl:42rem;--container-3xl:48rem;--container-6xl:72rem;--container-7xl:80rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:var(--primary);--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--text-5xl:3rem;--text-5xl--line-height:1;--text-6xl:3.75rem;--text-6xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-wide:.025em;--tracking-widest:.1em;--leading-snug:1.375;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-lg:.5rem;--radius-2xl:1rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--primary:#cad2c5;--secondary:#84a98c;--tertiary:#2f3e46;--complementary:#52796f;--contrast:#354f52;--background:#2f3e46;--text-muted:var(--secondary);--surface:var(--tertiary);--surface-elevated:var(--complementary);--border:var(--contrast)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components{.app-container{min-height:100vh;padding-inline:calc(var(--spacing) * 4);background-image:radial-gradient(circle,#2f3e4699 1px,#0000 1px);justify-content:center}@supports (color:color-mix(in lab,red,red)){.app-container{background-image:radial-gradient(circle,color-mix(in srgb,var(--surface) 60%,transparent) 1px,transparent 1px)}}.app-container{background-size:28px 28px;transition:background-color .3s,color .3s}.app-content{width:100%;max-width:var(--container-md);margin-inline:auto}@media(min-width:48rem){.app-content{max-width:var(--container-6xl)}}.tech-grid-wrapper{width:100%}.tech-grid-inner{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:10px;display:grid}.tech-card{background-color:var(--surface);border:1px solid var(--border);cursor:default;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:12px 8px;transition:transform .2s,background-color .2s,box-shadow .2s;display:flex}.tech-label{color:var(--text-muted);letter-spacing:.02em;text-align:center;font-size:10px;font-weight:500;line-height:1.2}}@layer utilities{.fixed{position:fixed}.relative{position:relative}.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-10{margin-bottom:calc(var(--spacing) * 10)}.mb-12{margin-bottom:calc(var(--spacing) * 12)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.table{display:table}.h-36{height:calc(var(--spacing) * 36)}.h-px{height:1px}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-screen{min-height:100vh}.w-16{width:calc(var(--spacing) * 16)}.w-36{width:calc(var(--spacing) * 36)}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-3xl{max-width:var(--container-3xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-\[200px\]{max-width:200px}.max-w-lg{max-width:var(--container-lg)}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.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}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.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)}.gap-5{gap:calc(var(--spacing) * 5)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-8{gap:calc(var(--spacing) * 8)}.gap-10{gap:calc(var(--spacing) * 10)}:where(.space-y-2\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2.5) * calc(1 - var(--tw-space-y-reverse)))}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-t-sm{border-top-left-radius:var(--radius-sm);border-top-right-radius:var(--radius-sm)}.rounded-b-sm{border-bottom-right-radius:var(--radius-sm);border-bottom-left-radius:var(--radius-sm)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-\[color\:var\(--tertiary\)\]{border-color:var(--tertiary)}.bg-\[color\:var\(--contrast\)\]{background-color:var(--contrast)}.bg-\[color\:var\(--primary\)\]{background-color:var(--primary)}.bg-\[color\:var\(--secondary\)\]{background-color:var(--secondary)}.object-cover{object-fit:cover}.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-4{padding-inline:calc(var(--spacing) * 4)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-16{padding-block:calc(var(--spacing) * 16)}.pt-1{padding-top:calc(var(--spacing) * 1)}.text-center{text-align:center}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-pretty{text-wrap:pretty}.text-\[color\:var\(--complementary\)\]{color:var(--complementary)}.text-\[color\:var\(--contrast\)\]{color:var(--contrast)}.text-\[color\:var\(--primary\)\]{color:var(--primary)}.text-\[color\:var\(--secondary\)\]{color:var(--secondary)}.text-blue-600{color:var(--color-blue-600)}.text-gray-800{color:var(--color-gray-800)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition-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))}.duration-300{--tw-duration:.3s;transition-duration:.3s}@media(hover:hover){.group-hover\:text-white:is(:where(.group):hover *){color:var(--color-white)}.hover\:bg-blue-600:hover{background-color:var(--color-blue-600)}.hover\:bg-gray-800:hover{background-color:var(--color-gray-800)}.hover\:text-\[color\:var\(--complementary\)\]:hover{color:var(--complementary)}.hover\:text-white:hover{color:var(--color-white)}}@media(min-width:40rem){.sm\:h-44{height:calc(var(--spacing) * 44)}.sm\:w-44{width:calc(var(--spacing) * 44)}.sm\:flex-row{flex-direction:row}.sm\:px-6{padding-inline:calc(var(--spacing) * 6)}.sm\:text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.sm\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.sm\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.sm\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.sm\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.sm\:text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.sm\:text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.sm\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}}@media(min-width:48rem){.md\:col-span-1{grid-column:span 1/span 1}.md\:col-span-2{grid-column:span 2/span 2}.md\:col-span-3{grid-column:span 3/span 3}.md\:grid{display:grid}.md\:h-52{height:calc(var(--spacing) * 52)}.md\:w-52{width:calc(var(--spacing) * 52)}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:items-start{align-items:flex-start}.md\:justify-start{justify-content:flex-start}.md\:gap-8{gap:calc(var(--spacing) * 8)}.md\:gap-12{gap:calc(var(--spacing) * 12)}.md\:px-8{padding-inline:calc(var(--spacing) * 8)}.md\:py-20{padding-block:calc(var(--spacing) * 20)}.md\:text-left{text-align:left}.md\:text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.md\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.md\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.md\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}}@media(min-width:64rem){.lg\:h-60{height:calc(var(--spacing) * 60)}.lg\:w-60{width:calc(var(--spacing) * 60)}.lg\:gap-12{gap:calc(var(--spacing) * 12)}.lg\:px-12{padding-inline:calc(var(--spacing) * 12)}.lg\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}}@media(min-width:80rem){.xl\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}}}:root,.dark{--primary:#cad2c5;--secondary:#84a98c;--tertiary:#354f52;--complementary:#52796f;--contrast:#2f3e46;--background:#1b2b30;--text-base:#cad2c5;--text-muted:#84a98c;--surface:#2f3e46;--surface-elevated:#354f52;--border:#52796f;background-color:var(--background);transition:background-color .3s}.light{--primary:#2f4f4f;--secondary:#4a7c6f;--tertiary:#d8e8df;--complementary:#a8c5ba;--contrast:#b8d4c8;--background:#f4f7f5;--text-base:#2f4f4f;--text-muted:#4a7c6f;--surface:#e8f0ec;--surface-elevated:#fff;--border:#a8c5ba;background-color:var(--background);transition:background-color .3s}@media(min-width:768px){.tech-grid-wrapper{height:100%}.tech-grid-inner{grid-template-columns:repeat(2,1fr);grid-auto-rows:1fr;height:100%}.tech-card{padding:14px 8px}.tech-label{font-size:11px}}@keyframes fade-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.hero-animate{animation:.55s ease-out both fade-up}@media(prefers-reduced-motion:reduce){.hero-animate{animation:none}}@keyframes name-shimmer{0%{background-position:0%}to{background-position:200%}}.hero-name{background:linear-gradient(120deg,var(--primary) 0%,var(--secondary) 40%,var(--primary) 60%,var(--secondary) 100%);-webkit-text-fill-color:transparent;background-size:200%;-webkit-background-clip:text;background-clip:text;animation:6s linear infinite name-shimmer}.hero-animate.hero-name{animation:.55s ease-out both fade-up,6s linear .55s infinite name-shimmer}@media(prefers-reduced-motion:reduce){.hero-animate.hero-name{animation:6s linear infinite name-shimmer}}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}.typewriter-cursor{color:var(--complementary);margin-left:1px;font-weight:300;animation:1s step-end infinite cursor-blink}.social-link{background-color:var(--surface);border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);border-radius:8px;justify-content:center;align-items:center;text-decoration:none;transition:background-color .2s,color .2s,transform .2s;display:flex}.social-link:hover{background-color:var(--surface-elevated);color:var(--primary);transform:translateY(-2px)}.hero-btn-primary{background-color:var(--complementary);color:var(--background);border:1px solid #0000;border-radius:10px;align-items:center;gap:8px;padding:10px 22px;font-size:.875rem;font-weight:600;text-decoration:none;transition:opacity .2s,transform .2s;display:inline-flex}.hero-btn-primary:hover{opacity:.88;transform:translateY(-1px)}.hero-btn-secondary{color:var(--primary);border:1px solid var(--border);background-color:#0000;border-radius:10px;align-items:center;gap:8px;padding:10px 22px;font-size:.875rem;font-weight:600;text-decoration:none;transition:background-color .2s,transform .2s;display:inline-flex}.hero-btn-secondary:hover{background-color:var(--surface-elevated);transform:translateY(-1px)}.bg-orb{pointer-events:none;z-index:0;will-change:transform;border-radius:50%;position:fixed}.bg-orb-1{filter:blur(70px);background:radial-gradient(circle,#52796f47,#52796f14 50%,#0000 70%);width:620px;height:620px;animation:16s ease-in-out infinite alternate orb-drift-1;top:-15%;left:-8%}.bg-orb-2{filter:blur(90px);background:radial-gradient(circle,#84a98c33,#84a98c0f 50%,#0000 70%);width:560px;height:560px;animation:20s ease-in-out infinite alternate orb-drift-2;bottom:0%;right:-10%}@keyframes orb-drift-1{0%{transform:translate(0)scale(1)}to{transform:translate(50px,35px)scale(1.12)}}@keyframes orb-drift-2{0%{transform:translate(0)scale(1)}to{transform:translate(-45px,-50px)scale(1.08)}}@media(max-width:768px){.bg-orb-1{width:380px;height:380px}.bg-orb-2{width:320px;height:320px}}@media(prefers-reduced-motion:reduce){.bg-orb{animation:none}}@keyframes gradient-border{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.hero-photo-frame{background:linear-gradient(135deg,var(--secondary),var(--complementary),var(--primary),var(--complementary),var(--secondary));background-size:300% 300%;border-radius:20px;padding:3px;animation:6s infinite gradient-border;box-shadow:0 0 30px #52796f40,0 8px 32px #0000004d}.hero-photo-frame img{border-radius:18px;display:block}.hero-name{filter:drop-shadow(0 0 18px #84a98c47)}.social-link-full{background-color:var(--surface);border:1px solid var(--border);width:100%;color:var(--text-muted);border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:.8125rem;font-weight:500;text-decoration:none;transition:background-color .2s,color .2s,transform .2s,border-color .2s;display:flex}.social-link-full:hover{background-color:var(--surface-elevated);color:var(--primary);border-color:var(--complementary);transform:translateY(-2px)}.social-link-full.social-link-primary{background-color:var(--complementary);color:var(--background);border-color:#0000;font-weight:600}.social-link-full.social-link-primary:hover{opacity:.88;color:var(--background);border-color:#0000}@keyframes btn-glow{0%,to{box-shadow:0 0 8px #52796f4d}50%{box-shadow:0 0 20px #52796f8c,0 0 40px #52796f26}}.hero-btn-primary{animation:3.5s ease-in-out infinite btn-glow}.navbar{z-index:50;background:#2f3e46b3;width:calc(100% - 32px);position:fixed;top:12px;left:50%;transform:translate(-50%)}@supports (color:color-mix(in lab,red,red)){.navbar{background:color-mix(in srgb,var(--surface) 70%,transparent)}}.navbar{-webkit-backdrop-filter:blur(18px)saturate(180%);border:1px solid #354f5273}@supports (color:color-mix(in lab,red,red)){.navbar{border:1px solid color-mix(in srgb,var(--border) 45%,transparent)}}.navbar{border-radius:14px;padding:10px 16px;box-shadow:0 4px 24px #00000038,inset 0 1px #ffffff0f}.navbar__mobile{justify-content:space-between;align-items:center;display:flex}.navbar__desktop{align-items:center;gap:2px;display:none}@media(min-width:768px){.navbar{border-radius:50px;width:auto;max-width:820px;padding:7px 14px 7px 20px}.navbar__mobile{display:none}.navbar__desktop{display:flex}}.navbar__logo{letter-spacing:.06em;color:var(--primary);background:#52796f2e;font-size:.8125rem;font-weight:700}@supports (color:color-mix(in lab,red,red)){.navbar__logo{background:color-mix(in srgb,var(--complementary) 18%,transparent)}}.navbar__logo{border:1px solid #52796f59}@supports (color:color-mix(in lab,red,red)){.navbar__logo{border:1px solid color-mix(in srgb,var(--complementary) 35%,transparent)}}.navbar__logo{border-radius:8px;padding:4px 10px}.navbar-link{color:var(--text-muted);white-space:nowrap;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:6px 11px;font-size:.8125rem;font-weight:500;text-decoration:none;transition:color .2s,background-color .2s;display:flex;position:relative}.navbar-link:hover{color:var(--primary);background-color:#52796f8c}@supports (color:color-mix(in lab,red,red)){.navbar-link:hover{background-color:color-mix(in srgb,var(--surface-elevated) 55%,transparent)}}.navbar-link--active{color:var(--primary);font-weight:600}.navbar-link__dot{background-color:var(--complementary);border-radius:50%;width:4px;height:4px;animation:.2s both dot-scale}@keyframes dot-scale{0%{transform:scale(0)}to{transform:scale(1)}}.navbar__separator{background:#354f528c;width:1px;height:18px;margin:0 8px}@supports (color:color-mix(in lab,red,red)){.navbar__separator{background:color-mix(in srgb,var(--border) 55%,transparent)}}.theme-btn{background-color:#52796f8c;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}@supports (color:color-mix(in lab,red,red)){.theme-btn{background-color:color-mix(in srgb,var(--surface-elevated) 55%,transparent)}}.theme-btn{border:1px solid #354f5273}@supports (color:color-mix(in lab,red,red)){.theme-btn{border:1px solid color-mix(in srgb,var(--border) 45%,transparent)}}.theme-btn{color:var(--text-muted);cursor:pointer;transition:background-color .2s,color .2s,transform .35s}.theme-btn:hover{background-color:var(--complementary);color:var(--background);transform:rotate(25deg)}.hamburger-btn{background-color:#52796f80;border-radius:9px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}@supports (color:color-mix(in lab,red,red)){.hamburger-btn{background-color:color-mix(in srgb,var(--surface-elevated) 50%,transparent)}}.hamburger-btn{border:1px solid #354f5273}@supports (color:color-mix(in lab,red,red)){.hamburger-btn{border:1px solid color-mix(in srgb,var(--border) 45%,transparent)}}.hamburger-btn{color:var(--text-muted);cursor:pointer;transition:background-color .2s,color .2s}.hamburger-btn:hover{background-color:var(--surface-elevated);color:var(--primary)}.drawer-overlay{z-index:60;pointer-events:none;background:0 0;transition:background .28s;position:fixed;inset:0}.drawer-overlay--open{pointer-events:all;background:#00000073}.drawer{z-index:70;background:#2f3e46d1;width:50%;min-width:240px;max-width:320px;transition:transform .28s cubic-bezier(.4,0,.2,1);position:fixed;top:0;bottom:0;right:0;transform:translate(100%)}@supports (color:color-mix(in lab,red,red)){.drawer{background:color-mix(in srgb,var(--surface) 82%,transparent)}}.drawer{-webkit-backdrop-filter:blur(24px)saturate(200%);border-left:1px solid #354f5280}@supports (color:color-mix(in lab,red,red)){.drawer{border-left:1px solid color-mix(in srgb,var(--border) 50%,transparent)}}.drawer{flex-direction:column;display:flex;box-shadow:-8px 0 40px #00000047}.drawer--open{transform:translate(0)}.drawer__header{border-bottom:1px solid #354f5261;justify-content:space-between;align-items:center;padding:18px 20px;display:flex}@supports (color:color-mix(in lab,red,red)){.drawer__header{border-bottom:1px solid color-mix(in srgb,var(--border) 38%,transparent)}}.drawer__nav{flex-direction:column;flex:1;gap:2px;padding:10px 12px;display:flex}.drawer-link{color:var(--text-muted);border-left:2px solid #0000;border-radius:10px;align-items:center;padding:13px 16px;font-size:.9375rem;font-weight:500;text-decoration:none;transition:color .2s,background-color .2s,border-color .2s,padding-left .2s;display:flex}.drawer-link:hover{color:var(--primary);background-color:#52796f99}@supports (color:color-mix(in lab,red,red)){.drawer-link:hover{background-color:color-mix(in srgb,var(--surface-elevated) 60%,transparent)}}.drawer-link:hover{padding-left:20px}.drawer-link--active{color:var(--primary);background-color:#52796f1f}@supports (color:color-mix(in lab,red,red)){.drawer-link--active{background-color:color-mix(in srgb,var(--complementary) 12%,transparent)}}.drawer-link--active{border-left-color:var(--complementary);padding-left:20px;font-weight:600}.drawer__footer{border-top:1px solid #354f5261;padding:14px 20px}@supports (color:color-mix(in lab,red,red)){.drawer__footer{border-top:1px solid color-mix(in srgb,var(--border) 38%,transparent)}}@media(prefers-reduced-motion:reduce){.navbar,.drawer,.drawer-overlay{transition:none}}.exp-timeline{flex-direction:column;padding-left:8px;display:flex}.exp-item{grid-template-columns:28px 1fr;gap:16px;display:grid}.exp-item__left{flex-direction:column;align-items:center;padding-top:20px;display:flex}.exp-item__dot{background-color:var(--surface-elevated);border:2px solid var(--border);border-radius:50%;flex-shrink:0;width:13px;height:13px;transition:background-color .2s,box-shadow .2s}.exp-item__line{background:linear-gradient(to bottom,var(--border),#354f524d);flex:1;width:1px;min-height:32px;margin-top:8px}@supports (color:color-mix(in lab,red,red)){.exp-item__line{background:linear-gradient(to bottom,var(--border),color-mix(in srgb,var(--border) 30%,transparent))}}.exp-card{background:#2f3e46bf}@supports (color:color-mix(in lab,red,red)){.exp-card{background:color-mix(in srgb,var(--surface) 75%,transparent)}}.exp-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:14px;transition:border-color .2s,box-shadow .2s;overflow:hidden}.exp-card:hover{border-color:#52796f99}@supports (color:color-mix(in lab,red,red)){.exp-card:hover{border-color:color-mix(in srgb,var(--complementary) 60%,transparent)}}.exp-card:hover{box-shadow:0 4px 20px #0000001f}.exp-card__header{border-bottom:1px solid #354f5299;flex-direction:column;gap:10px;padding:16px 20px;display:flex}@supports (color:color-mix(in lab,red,red)){.exp-card__header{border-bottom:1px solid color-mix(in srgb,var(--border) 60%,transparent)}}.exp-card__header{background:#52796f66}@supports (color:color-mix(in lab,red,red)){.exp-card__header{background:color-mix(in srgb,var(--surface-elevated) 40%,transparent)}}@media(min-width:640px){.exp-card__header{flex-direction:row;justify-content:space-between;align-items:flex-start}}.exp-card__body{padding:16px 20px}.stack-grid{grid-template-columns:1fr;gap:16px;display:grid}@media(min-width:768px){.stack-grid{grid-template-columns:repeat(3,1fr);gap:20px}}.stack-card{background:#2f3e46bf}@supports (color:color-mix(in lab,red,red)){.stack-card{background:color-mix(in srgb,var(--surface) 75%,transparent)}}.stack-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:16px;flex-direction:column;transition:border-color .2s,box-shadow .2s;display:flex;overflow:hidden}.stack-card:hover{border-color:#52796f8c}@supports (color:color-mix(in lab,red,red)){.stack-card:hover{border-color:color-mix(in srgb,var(--complementary) 55%,transparent)}}.stack-card:hover{box-shadow:0 4px 24px #0000001f}.stack-card__header{background:#52796f66;flex-direction:row;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 18px;display:flex}@supports (color:color-mix(in lab,red,red)){.stack-card__header{background:color-mix(in srgb,var(--surface-elevated) 40%,transparent)}}.stack-card__body{flex-direction:column;flex:1;gap:16px;padding:16px 18px;display:flex}.stack-category{flex-direction:column;display:flex}.stack-pill{background-color:var(--surface-elevated);border:1px solid var(--border);cursor:default;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;transition:border-color .2s,background-color .2s,transform .2s;display:inline-flex}.stack-pill:hover{background-color:#52796f}@supports (color:color-mix(in lab,red,red)){.stack-pill:hover{background-color:color-mix(in srgb,var(--surface-elevated) 80%,var(--complementary))}}.stack-pill:hover{border-color:#52796f80}@supports (color:color-mix(in lab,red,red)){.stack-pill:hover{border-color:color-mix(in srgb,var(--complementary) 50%,transparent)}}.stack-pill:hover{transform:translateY(-1px)}.stack-pill__name{color:var(--text-muted);white-space:nowrap;font-size:.75rem;font-weight:500}.stack-pill__context{color:var(--text-muted);opacity:.7;font-size:.6875rem}.portfolio-card{background:#2f3e46bf}@supports (color:color-mix(in lab,red,red)){.portfolio-card{background:color-mix(in srgb,var(--surface) 75%,transparent)}}.portfolio-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);cursor:pointer;border-radius:16px;flex-direction:column;transition:border-color .25s,box-shadow .25s,transform .25s;display:flex;overflow:hidden}.portfolio-card:hover{border-color:#52796f8c}@supports (color:color-mix(in lab,red,red)){.portfolio-card:hover{border-color:color-mix(in srgb,var(--complementary) 55%,transparent)}}.portfolio-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0000002e}.portfolio-card__img-wrap{height:200px;position:relative;overflow:hidden}.portfolio-card__img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.portfolio-card:hover .portfolio-card__img{transform:scale(1.05)}.portfolio-card__img-overlay{background:linear-gradient(#0000 40%,#2f3e46b3);position:absolute;inset:0}@supports (color:color-mix(in lab,red,red)){.portfolio-card__img-overlay{background:linear-gradient(to bottom,transparent 40%,color-mix(in srgb,var(--surface) 70%,transparent) 100%)}}.portfolio-card__dev-badge{background:#2f3e46cc;border-radius:20px;padding:3px 10px;font-size:.6875rem;font-weight:600;position:absolute;top:12px;right:12px}@supports (color:color-mix(in lab,red,red)){.portfolio-card__dev-badge{background:color-mix(in srgb,var(--surface) 80%,transparent)}}.portfolio-card__dev-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);color:var(--secondary)}.portfolio-card__body{flex-direction:column;flex:1;padding:16px 18px;display:flex}.portfolio-modal-overlay{-webkit-backdrop-filter:blur(6px);z-index:80;background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.portfolio-modal{background:#2f3e46e0}@supports (color:color-mix(in lab,red,red)){.portfolio-modal{background:color-mix(in srgb,var(--surface) 88%,transparent)}}.portfolio-modal{-webkit-backdrop-filter:blur(24px)saturate(180%);border:1px solid var(--border);border-radius:20px;flex-direction:column;width:100%;max-width:680px;max-height:88vh;display:flex;overflow-y:auto;box-shadow:0 24px 64px #00000059}.portfolio-modal__header{background:#52796fcc;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 22px;display:flex;position:sticky;top:0}@supports (color:color-mix(in lab,red,red)){.portfolio-modal__header{background:color-mix(in srgb,var(--surface-elevated) 80%,transparent)}}.portfolio-modal__header{-webkit-backdrop-filter:blur(16px);border-bottom:1px solid #354f5299}@supports (color:color-mix(in lab,red,red)){.portfolio-modal__header{border-bottom:1px solid color-mix(in srgb,var(--border) 60%,transparent)}}.portfolio-modal__header{z-index:1;border-radius:20px 20px 0 0}.portfolio-modal__close{background:#2f3e46b3;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}@supports (color:color-mix(in lab,red,red)){.portfolio-modal__close{background:color-mix(in srgb,var(--surface) 70%,transparent)}}.portfolio-modal__close{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:background-color .2s,color .2s}.portfolio-modal__close:hover{background-color:var(--surface-elevated);color:var(--primary)}.portfolio-modal__img-wrap{height:240px;overflow:hidden}.portfolio-modal__img{object-fit:cover;width:100%;height:100%}.portfolio-modal__body{padding:22px 22px 24px}.about-contact-card{background:#2f3e46bf}@supports (color:color-mix(in lab,red,red)){.about-contact-card{background:color-mix(in srgb,var(--surface) 75%,transparent)}}.about-contact-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:16px;flex-direction:column;height:100%;display:flex;overflow:hidden}.about-contact-card__header{border-bottom:1px solid #354f5299;padding:16px 18px}@supports (color:color-mix(in lab,red,red)){.about-contact-card__header{border-bottom:1px solid color-mix(in srgb,var(--border) 60%,transparent)}}.about-contact-card__header{background:#52796f66}@supports (color:color-mix(in lab,red,red)){.about-contact-card__header{background:color-mix(in srgb,var(--surface-elevated) 40%,transparent)}}.about-footer{border-top:1px solid #354f5280;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:48px;padding-top:20px;display:flex}@supports (color:color-mix(in lab,red,red)){.about-footer{border-top:1px solid color-mix(in srgb,var(--border) 50%,transparent)}}.about-footer{color:var(--text-muted);opacity:.7;font-size:.75rem}.site-footer{background:#2f3e46cc;margin-top:auto;position:relative}@supports (color:color-mix(in lab,red,red)){.site-footer{background:color-mix(in srgb,var(--surface) 80%,transparent)}}.site-footer{-webkit-backdrop-filter:blur(18px)saturate(160%)}.site-footer__divider{background:linear-gradient(90deg,#0000,#52796f80 35% 65%,#0000);height:1px}@supports (color:color-mix(in lab,red,red)){.site-footer__divider{background:linear-gradient(to right,transparent,color-mix(in srgb,var(--complementary) 50%,transparent) 35%,color-mix(in srgb,var(--complementary) 50%,transparent) 65%,transparent)}}.site-footer__inner{flex-direction:column;align-items:flex-start;gap:24px;max-width:1100px;margin:0 auto;padding:32px 24px 24px;display:flex}@media(min-width:640px){.site-footer__inner{flex-direction:row;justify-content:space-between;align-items:center;gap:32px}}.site-footer__brand{flex-direction:column;display:flex}.site-footer__nav{flex-wrap:wrap;gap:4px 2px;display:flex}.site-footer__nav-link{color:var(--text-muted);border-radius:6px;padding:5px 10px;font-size:.75rem;font-weight:500;text-decoration:none;transition:color .2s,background-color .2s}.site-footer__nav-link:hover{color:var(--primary);background-color:#52796f99}@supports (color:color-mix(in lab,red,red)){.site-footer__nav-link:hover{background-color:color-mix(in srgb,var(--surface-elevated) 60%,transparent)}}.site-footer__social{gap:8px;display:flex}.site-footer__social-icon{background-color:var(--surface-elevated);border:1px solid var(--border);width:34px;height:34px;color:var(--text-muted);border-radius:9px;justify-content:center;align-items:center;text-decoration:none;transition:background-color .2s,color .2s,border-color .2s,transform .2s;display:flex}.site-footer__social-icon:hover{background-color:var(--complementary);border-color:var(--complementary);color:var(--background);transform:translateY(-2px)}.site-footer__bottom{border-top:1px solid #354f5273;max-width:1100px;margin:0 auto;padding:14px 24px}@supports (color:color-mix(in lab,red,red)){.site-footer__bottom{border-top:1px solid color-mix(in srgb,var(--border) 45%,transparent)}}.site-footer__bottom{color:var(--text-muted);opacity:.65;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;font-size:.6875rem;display:flex}.tag-badge{letter-spacing:.03em;white-space:nowrap;background:#52796f33;border-radius:20px;align-items:center;padding:3px 10px;font-weight:600;display:inline-flex}@supports (color:color-mix(in lab,red,red)){.tag-badge{background:color-mix(in srgb,var(--complementary) 20%,transparent)}}.tag-badge{border:1px solid #52796f66}@supports (color:color-mix(in lab,red,red)){.tag-badge{border:1px solid color-mix(in srgb,var(--complementary) 40%,transparent)}}.tag-badge{color:var(--secondary);transition:background-color .2s,border-color .2s}.tag-badge[role=button]{cursor:pointer}.tag-badge[role=button]:hover{background:#52796f59}@supports (color:color-mix(in lab,red,red)){.tag-badge[role=button]:hover{background:color-mix(in srgb,var(--complementary) 35%,transparent)}}.tag-badge[role=button]:hover{border-color:#52796f99}@supports (color:color-mix(in lab,red,red)){.tag-badge[role=button]:hover{border-color:color-mix(in srgb,var(--complementary) 60%,transparent)}}.tag-badge--sm{padding:2px 8px;font-size:.6875rem}.tag-badge--md{font-size:.75rem}.article-card{background:#2f3e46bf;flex-direction:column;display:flex}@supports (color:color-mix(in lab,red,red)){.article-card{background:color-mix(in srgb,var(--surface) 75%,transparent)}}.article-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);cursor:pointer;border-radius:18px;text-decoration:none;transition:border-color .25s,box-shadow .25s,transform .25s;overflow:hidden}.article-card:hover{border-color:#52796f99}@supports (color:color-mix(in lab,red,red)){.article-card:hover{border-color:color-mix(in srgb,var(--complementary) 60%,transparent)}}.article-card:hover{transform:translateY(-3px);box-shadow:0 8px 40px #00000038}.article-card__cover{background:#52796f99;height:210px;position:relative;overflow:hidden}@supports (color:color-mix(in lab,red,red)){.article-card__cover{background:color-mix(in srgb,var(--surface-elevated) 60%,transparent)}}.article-card__cover-img{object-fit:cover;width:100%;height:100%;transition:transform .45s}.article-card:hover .article-card__cover-img{transform:scale(1.06)}.article-card__cover-placeholder{background:linear-gradient(135deg,#3a5052,#405354);justify-content:center;align-items:center;width:100%;height:100%;display:flex}@supports (color:color-mix(in lab,red,red)){.article-card__cover-placeholder{background:linear-gradient(135deg,color-mix(in srgb,var(--complementary) 30%,var(--surface)),color-mix(in srgb,var(--secondary) 20%,var(--surface)))}}.article-card__cover-initials{color:#52796f80;font-size:4rem;font-weight:800}@supports (color:color-mix(in lab,red,red)){.article-card__cover-initials{color:color-mix(in srgb,var(--complementary) 50%,transparent)}}.article-card__cover-initials{-webkit-user-select:none;user-select:none;line-height:1}.article-card__cover-overlay{background:linear-gradient(#0000 30%,#2f3e46a6);position:absolute;inset:0}@supports (color:color-mix(in lab,red,red)){.article-card__cover-overlay{background:linear-gradient(to bottom,transparent 30%,color-mix(in srgb,var(--surface) 65%,transparent) 100%)}}.article-card__tags-overlay{flex-wrap:wrap;gap:6px;display:flex;position:absolute;bottom:10px;left:14px}.article-card__body{flex-direction:column;flex:1;gap:10px;padding:16px 20px 20px;display:flex}.article-card__title{color:var(--text-base);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:1.0625rem;font-weight:700;line-height:1.35;display:-webkit-box;overflow:hidden}.article-card__excerpt{color:var(--text-muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1;font-size:.8125rem;line-height:1.6;display:-webkit-box;overflow:hidden}.article-card__meta{border-top:1px solid #354f5280;flex-wrap:wrap;align-items:center;gap:6px;margin-top:auto;padding-top:8px;display:flex}@supports (color:color-mix(in lab,red,red)){.article-card__meta{border-top:1px solid color-mix(in srgb,var(--border) 50%,transparent)}}.article-card__meta-item{color:var(--text-muted);opacity:.8;align-items:center;gap:5px;font-size:.75rem;display:flex}.article-card__meta-sep{background-color:var(--border);border-radius:50%;width:3px;height:3px}.blog-list-page{min-height:100vh;padding:96px 0 64px}.blog-list-header{align-items:center;gap:16px;margin-bottom:40px;display:flex}.blog-list-header__icon{background:#52796f2e;border-radius:13px;justify-content:center;align-items:center;width:46px;height:46px;display:flex}@supports (color:color-mix(in lab,red,red)){.blog-list-header__icon{background:color-mix(in srgb,var(--complementary) 18%,transparent)}}.blog-list-header__icon{border:1px solid #52796f59}@supports (color:color-mix(in lab,red,red)){.blog-list-header__icon{border:1px solid color-mix(in srgb,var(--complementary) 35%,transparent)}}.blog-list-header__icon{color:var(--secondary);flex-shrink:0}.blog-list-header__title{color:var(--text-base);font-size:2rem;font-weight:800;line-height:1.1}.blog-list-header__subtitle{color:var(--text-muted);margin-top:4px;font-size:.875rem}.blog-list-grid{grid-template-columns:1fr;gap:24px;display:grid}@media(min-width:640px){.blog-list-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.blog-list-grid{grid-template-columns:repeat(3,1fr)}}.blog-list-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:64px 24px;font-size:.9375rem;display:flex}.blog-list-state--error{color:#e07070}.blog-list-state__detail{opacity:.7;font-size:.8125rem}.blog-list-spinner{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.article-hero{border-radius:0 0 24px 24px;align-items:flex-end;width:100%;min-height:420px;margin-top:60px;display:flex;position:relative;overflow:hidden}@media(min-width:768px){.article-hero{min-height:520px;margin-top:72px}}.article-hero__bg{position:absolute;inset:0}.article-hero__bg-img{object-fit:cover;width:100%;height:100%}.article-hero__bg-fallback{background:linear-gradient(135deg,#3d5656 0%,#445958 50%,var(--background) 100%);width:100%;height:100%}@supports (color:color-mix(in lab,red,red)){.article-hero__bg-fallback{background:linear-gradient(135deg,color-mix(in srgb,var(--complementary) 40%,var(--background)) 0%,color-mix(in srgb,var(--secondary) 25%,var(--background)) 50%,var(--background) 100%)}}.article-hero__bg-overlay{background:linear-gradient(#0000001f,#00000073 55%,#000000d1);position:absolute;inset:0}.article-hero__content{z-index:1;flex-direction:column;gap:12px;width:100%;max-width:860px;margin:0 auto;padding:32px 20px 40px;display:flex;position:relative}@media(min-width:768px){.article-hero__content{padding:40px 32px 56px}}.article-hero__back{color:#ffffffa6;align-items:center;gap:7px;width:fit-content;font-size:.8125rem;font-weight:500;text-decoration:none;transition:color .2s;display:inline-flex}.article-hero__back:hover{color:#fffffff2}.article-hero__tags{flex-wrap:wrap;gap:8px;display:flex}.article-hero__title{color:#fff;letter-spacing:-.02em;font-size:clamp(1.6rem,4vw,2.8rem);font-weight:800;line-height:1.2}.article-hero__excerpt{color:#ffffffb8;max-width:640px;font-size:1rem;line-height:1.6}.article-hero__meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;display:flex}.article-hero__meta-chip{color:#ffffffbf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1a;border:1px solid #ffffff26;border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:.8125rem;font-weight:500;display:inline-flex}.article-hero__meta-sep{background:#ffffff59;border-radius:50%;width:4px;height:4px}.blog-post-page{min-height:100vh}.blog-post-body{max-width:760px;margin:0 auto;padding:48px 20px 80px}@media(min-width:768px){.blog-post-body{padding:56px 32px 96px}}.blog-post-state{min-height:60vh;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:32px;font-size:.9375rem;display:flex}.blog-post-state--error{color:#e07070}.article-content{color:var(--text-base);font-size:1.0625rem;line-height:1.8}.article-md-h1{color:var(--text-base);letter-spacing:-.02em;margin:0 0 1.25rem;font-size:2rem;font-weight:800;line-height:1.2}.article-md-h2{color:var(--text-base);border-bottom:1px solid #354f5299;margin:2rem 0 .875rem;padding-bottom:.5rem;font-size:1.4rem;font-weight:700}@supports (color:color-mix(in lab,red,red)){.article-md-h2{border-bottom:1px solid color-mix(in srgb,var(--border) 60%,transparent)}}.article-md-h3{color:var(--text-base);margin:1.5rem 0 .625rem;font-size:1.125rem;font-weight:700}.article-md-p{color:var(--text-muted);margin:0 0 1.25rem}.article-md-link{color:var(--secondary);text-underline-offset:3px;text-decoration:underline;transition:color .2s}.article-md-link:hover{color:var(--primary)}.article-md-pre{background:#2f3e46cc}@supports (color:color-mix(in lab,red,red)){.article-md-pre{background:color-mix(in srgb,var(--surface) 80%,transparent)}}.article-md-pre{border:1px solid var(--border);border-radius:12px;margin:0 0 1.5rem;padding:20px 22px;overflow-x:auto}.article-md-code-block{color:var(--secondary);font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem;line-height:1.65;display:block}.article-md-code-inline{color:var(--secondary);background:#52796fb3;font-family:JetBrains Mono,Fira Code,monospace;font-size:.8125rem}@supports (color:color-mix(in lab,red,red)){.article-md-code-inline{background:color-mix(in srgb,var(--surface-elevated) 70%,transparent)}}.article-md-code-inline{border:1px solid var(--border);border-radius:5px;padding:2px 7px}.article-md-ul,.article-md-ol{color:var(--text-muted);margin:0 0 1.25rem;padding-left:1.5rem}.article-md-li{margin-bottom:.4rem;line-height:1.7}.article-md-blockquote{border-left:3px solid var(--complementary);color:var(--text-muted);background:#52796f14;margin:0 0 1.5rem;padding:8px 0 8px 20px;font-style:italic}@supports (color:color-mix(in lab,red,red)){.article-md-blockquote{background:color-mix(in srgb,var(--complementary) 8%,transparent)}}.article-md-blockquote{border-radius:0 8px 8px 0}.article-md-hr{background:#354f5299;border:none;height:1px}@supports (color:color-mix(in lab,red,red)){.article-md-hr{background:color-mix(in srgb,var(--border) 60%,transparent)}}.article-md-hr{margin:2rem 0}.article-md-img{border:1px solid var(--border);border-radius:12px;width:100%;margin:.5rem 0 1.5rem}.article-md-table-wrapper{margin-bottom:1.5rem;overflow-x:auto}.article-md-table{border-collapse:collapse;width:100%;font-size:.875rem}.article-md-th{background:#52796fcc}@supports (color:color-mix(in lab,red,red)){.article-md-th{background:color-mix(in srgb,var(--surface-elevated) 80%,transparent)}}.article-md-th{color:var(--text-base);text-align:left;border:1px solid var(--border);padding:10px 14px;font-weight:600}.article-md-td{color:var(--text-muted);border:1px solid #354f5299;padding:10px 14px}@supports (color:color-mix(in lab,red,red)){.article-md-td{border:1px solid color-mix(in srgb,var(--border) 60%,transparent)}}.blog-editor-page{flex-direction:column;gap:24px;min-height:100vh;padding:84px 0 80px;display:flex}.blog-editor-header{background:#2f3e46bf;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}@supports (color:color-mix(in lab,red,red)){.blog-editor-header{background:color-mix(in srgb,var(--surface) 75%,transparent)}}.blog-editor-header{-webkit-backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:14px}.blog-editor-header__left{color:var(--text-muted);align-items:center;gap:12px;display:flex}.blog-editor-header__title{color:var(--text-base);font-size:1.125rem;font-weight:700}.blog-editor-header__actions{align-items:center;gap:12px;display:flex}.blog-editor-publish-toggle{cursor:pointer;color:var(--text-muted);align-items:center;gap:8px;font-size:.8125rem;font-weight:500;display:flex}.blog-editor-publish-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--complementary);cursor:pointer}.blog-editor-save-btn{gap:7px;padding:9px 20px;font-size:.875rem}.blog-editor-error{color:#e07070;background:#e070701f;border:1px solid #e070704d;border-radius:10px;padding:12px 18px;font-size:.875rem}.blog-editor-layout{flex-direction:column;gap:24px;display:flex}@media(min-width:1024px){.blog-editor-layout{flex-direction:row;align-items:flex-start}}.blog-editor-main{flex-direction:column;flex:1;gap:20px;min-width:0;display:flex}.blog-editor-sidebar{flex-direction:column;gap:12px;width:100%;display:flex}@media(min-width:1024px){.blog-editor-sidebar{flex-shrink:0;width:300px}}.blog-editor-meta-fields{background:#2f3e46bf;flex-direction:column;gap:14px;padding:20px;display:flex}@supports (color:color-mix(in lab,red,red)){.blog-editor-meta-fields{background:color-mix(in srgb,var(--surface) 75%,transparent)}}.blog-editor-meta-fields{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:14px}.blog-editor-field{flex-direction:column;gap:7px;display:flex}.blog-editor-label{color:var(--text-muted);align-items:center;gap:6px;font-size:.8125rem;font-weight:600;display:flex}.blog-editor-label__hint{opacity:.7;font-weight:400}.blog-editor-input{background:#52796fb3;border-radius:10px;padding:10px 14px}@supports (color:color-mix(in lab,red,red)){.blog-editor-input{background:color-mix(in srgb,var(--surface-elevated) 70%,transparent)}}.blog-editor-input{border:1px solid var(--border);color:var(--text-base);outline:none;font-size:.9375rem;transition:border-color .2s,box-shadow .2s}.blog-editor-input:focus{border-color:var(--complementary);box-shadow:0 0 0 3px #52796f2e}@supports (color:color-mix(in lab,red,red)){.blog-editor-input:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--complementary) 18%,transparent)}}.blog-editor-input--mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:.8125rem}.blog-editor-textarea{background:#52796fb3;border-radius:10px;padding:10px 14px}@supports (color:color-mix(in lab,red,red)){.blog-editor-textarea{background:color-mix(in srgb,var(--surface-elevated) 70%,transparent)}}.blog-editor-textarea{border:1px solid var(--border);color:var(--text-base);resize:vertical;outline:none;font-family:inherit;font-size:.9375rem;line-height:1.6;transition:border-color .2s,box-shadow .2s}.blog-editor-textarea:focus{border-color:var(--complementary);box-shadow:0 0 0 3px #52796f2e}@supports (color:color-mix(in lab,red,red)){.blog-editor-textarea:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--complementary) 18%,transparent)}}.blog-editor-tags-row{gap:8px;display:flex}.blog-editor-tags-input{flex:1}.blog-editor-tag-add-btn{flex-shrink:0;padding:10px 16px;font-size:1rem;font-weight:700}.blog-editor-tags-list{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.blog-editor-section-label{color:var(--text-muted);align-items:center;gap:7px;margin-bottom:2px;font-size:.8125rem;font-weight:600;display:flex}.blog-editor-md-wrap{flex-direction:column;gap:10px;display:flex}.blog-editor-md .w-md-editor{background:#2f3e46d9!important}@supports (color:color-mix(in lab,red,red)){.blog-editor-md .w-md-editor{background:color-mix(in srgb,var(--surface) 85%,transparent)!important}}.blog-editor-md .w-md-editor{border:1px solid var(--border)!important;box-shadow:none!important;border-radius:14px!important}.blog-editor-md .w-md-editor-toolbar{background:#52796fcc!important}@supports (color:color-mix(in lab,red,red)){.blog-editor-md .w-md-editor-toolbar{background:color-mix(in srgb,var(--surface-elevated) 80%,transparent)!important}}.blog-editor-md .w-md-editor-toolbar{border-bottom:1px solid var(--border)!important;border-radius:14px 14px 0 0!important}.cover-uploader{flex-direction:column;gap:10px;display:flex}.cover-uploader__zone{border:2px dashed var(--border);background:#2f3e4699;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:32px 20px;display:flex}@supports (color:color-mix(in lab,red,red)){.cover-uploader__zone{background:color-mix(in srgb,var(--surface) 60%,transparent)}}.cover-uploader__zone{cursor:pointer;text-align:center;min-height:160px;transition:border-color .2s,background-color .2s}.cover-uploader__zone:hover,.cover-uploader__zone--drag{border-color:var(--complementary);background:#52796f14}@supports (color:color-mix(in lab,red,red)){.cover-uploader__zone:hover,.cover-uploader__zone--drag{background:color-mix(in srgb,var(--complementary) 8%,transparent)}}.cover-uploader__zone--uploading{pointer-events:none;opacity:.8}.cover-uploader__icon{color:var(--text-muted);opacity:.6}.cover-uploader__label{color:var(--text-muted);font-size:.875rem}.cover-uploader__hint{color:var(--text-muted);opacity:.55;font-size:.75rem}.cover-uploader__uploading{color:var(--text-muted);flex-direction:column;align-items:center;gap:10px;width:100%;font-size:.875rem;display:flex}.cover-uploader__spinner{color:var(--complementary);animation:.9s linear infinite spin}.cover-uploader__progress-bar{background:var(--border);border-radius:4px;width:80%;height:4px;overflow:hidden}.cover-uploader__progress-fill{background:var(--complementary);border-radius:4px;height:100%;transition:width .15s}.cover-uploader__preview{border:1px solid var(--border);border-radius:14px;position:relative;overflow:hidden}.cover-uploader__img{object-fit:cover;width:100%;height:200px;display:block}.cover-uploader__remove{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;cursor:pointer;background:#0000008c;border:1px solid #ffffff26;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;transition:background-color .2s;display:flex;position:absolute;top:10px;right:10px}.cover-uploader__remove:hover{background:#e07070a6}.cover-uploader__error{color:#e07070;background:#e070701a;border:1px solid #e0707040;border-radius:8px;padding:8px 12px;font-size:.8125rem}.blog-fab{z-index:40;background-color:var(--complementary);width:52px;height:52px;color:var(--background);border-radius:16px;justify-content:center;align-items:center;text-decoration:none;transition:transform .2s,box-shadow .2s;display:flex;position:fixed;bottom:28px;right:24px;box-shadow:0 8px 28px #52796f73}.blog-fab:hover{transform:translateY(-3px)scale(1.05);box-shadow:0 12px 36px #52796f8c}.navbar-link--route{gap:5px}.navbar-session-chip{color:var(--secondary);background:#52796f26;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:.75rem;font-weight:600;display:flex}@supports (color:color-mix(in lab,red,red)){.navbar-session-chip{background:color-mix(in srgb,var(--complementary) 15%,transparent)}}.navbar-session-chip{border:1px solid #52796f59}@supports (color:color-mix(in lab,red,red)){.navbar-session-chip{border:1px solid color-mix(in srgb,var(--complementary) 35%,transparent)}}.navbar-session-chip{white-space:nowrap;max-width:120px;overflow:hidden}.navbar-session-chip__email{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.navbar-logout-btn{color:#e07070;cursor:pointer;background:#e070701f;border:1px solid #e070704d;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:background-color .2s,border-color .2s,transform .2s;display:flex}.navbar-logout-btn:hover{background:#e0707038;border-color:#e0707080;transform:translateY(-1px)}.drawer-logout-link{text-align:left;cursor:pointer;width:100%;font-family:inherit;font-size:inherit;background:0 0;color:#e07070!important;border-left-color:#0000!important}.drawer-logout-link:hover{color:#e07070!important;background-color:#e070701a!important;border-left-color:#e07070!important}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:32px 16px;display:flex;position:relative;overflow:hidden}.login-page__orb{pointer-events:none;z-index:0;border-radius:50%;position:fixed}.login-page__orb--1{filter:blur(60px);background:radial-gradient(circle,#52796f38,#0000 65%);width:480px;height:480px;animation:14s ease-in-out infinite alternate orb-drift-2;top:10%;right:-5%}.login-page__orb--2{filter:blur(70px);background:radial-gradient(circle,#84a98c29,#0000 65%);width:400px;height:400px;animation:18s ease-in-out infinite alternate orb-drift-1;bottom:5%;left:-8%}.login-card{z-index:1;background:#2f3e46c7;width:100%;max-width:420px;position:relative}@supports (color:color-mix(in lab,red,red)){.login-card{background:color-mix(in srgb,var(--surface) 78%,transparent)}}.login-card{-webkit-backdrop-filter:blur(24px)saturate(180%);border:1px solid #354f52b3}@supports (color:color-mix(in lab,red,red)){.login-card{border:1px solid color-mix(in srgb,var(--border) 70%,transparent)}}.login-card{border-radius:22px;flex-direction:column;gap:0;padding:36px 32px 28px;animation:.45s ease-out both fade-up;display:flex;box-shadow:0 24px 64px #00000047,inset 0 2px #ffffff0a}.login-card__header{align-items:center;gap:14px;margin-bottom:22px;display:flex}.login-card__icon{background:linear-gradient(135deg,#52796f59,#84a98c33);border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}@supports (color:color-mix(in lab,red,red)){.login-card__icon{background:linear-gradient(135deg,color-mix(in srgb,var(--complementary) 35%,transparent),color-mix(in srgb,var(--secondary) 20%,transparent))}}.login-card__icon{border:1px solid #52796f66}@supports (color:color-mix(in lab,red,red)){.login-card__icon{border:1px solid color-mix(in srgb,var(--complementary) 40%,transparent)}}.login-card__icon{color:var(--secondary);flex-shrink:0}.login-card__title{color:var(--text-base);letter-spacing:-.02em;font-size:1.3rem;font-weight:800;line-height:1.1}.login-card__subtitle{color:var(--text-muted);opacity:.8;margin-top:3px;font-size:.75rem}.login-card__divider{background:linear-gradient(90deg,#0000,#354f52cc 30% 70%,#0000);height:1px}@supports (color:color-mix(in lab,red,red)){.login-card__divider{background:linear-gradient(to right,transparent,color-mix(in srgb,var(--border) 80%,transparent) 30%,color-mix(in srgb,var(--border) 80%,transparent) 70%,transparent)}}.login-card__divider{margin-bottom:26px}.login-form{flex-direction:column;gap:16px;display:flex}.login-field{flex-direction:column;gap:8px;display:flex}.login-label{color:var(--text-muted);letter-spacing:.02em;font-size:.8125rem;font-weight:600}.login-input-wrap{align-items:center;display:flex;position:relative}.login-input-icon{color:var(--text-muted);opacity:.5;pointer-events:none;z-index:1;position:absolute;left:14px}.login-input{background:#52796fa6;border-radius:11px;width:100%;padding:12px 14px 12px 40px}@supports (color:color-mix(in lab,red,red)){.login-input{background:color-mix(in srgb,var(--surface-elevated) 65%,transparent)}}.login-input{border:1px solid var(--border);color:var(--text-base);outline:none;font-size:.9375rem;transition:border-color .2s,box-shadow .2s,background-color .2s}.login-input::placeholder{color:var(--text-muted);opacity:.4}.login-input:focus{border-color:var(--complementary);background:#52796fd9}@supports (color:color-mix(in lab,red,red)){.login-input:focus{background:color-mix(in srgb,var(--surface-elevated) 85%,transparent)}}.login-input:focus{box-shadow:0 0 0 3px #52796f2e,0 0 12px #52796f14}@supports (color:color-mix(in lab,red,red)){.login-input:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--complementary) 18%,transparent),0 0 12px color-mix(in srgb,var(--complementary) 8%,transparent)}}.login-input:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#e07070;background:#e070701a;border:1px solid #e0707047;border-radius:10px;align-items:flex-start;gap:10px;padding:11px 14px;font-size:.8125rem;line-height:1.5;animation:.25s ease-out both fade-up;display:flex}.login-error__dot{background:#e07070;border-radius:50%;flex-shrink:0;width:6px;height:6px;margin-top:5px}.login-btn{cursor:pointer;background:linear-gradient(135deg,var(--complementary) 0%,#5c8375 100%);border:none;border-radius:11px;justify-content:center;align-items:center;gap:9px;width:100%;margin-top:4px;padding:13px;font-size:.9375rem;font-weight:700;display:flex}@supports (color:color-mix(in lab,red,red)){.login-btn{background:linear-gradient(135deg,var(--complementary) 0%,color-mix(in srgb,var(--complementary) 80%,var(--secondary)) 100%)}}.login-btn{color:var(--background);transition:opacity .2s,transform .2s,box-shadow .2s;box-shadow:0 4px 16px #52796f59}@supports (color:color-mix(in lab,red,red)){.login-btn{box-shadow:0 4px 16px color-mix(in srgb,var(--complementary) 35%,transparent)}}.login-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 8px 24px #52796f66}@supports (color:color-mix(in lab,red,red)){.login-btn:hover:not(:disabled){box-shadow:0 8px 24px color-mix(in srgb,var(--complementary) 40%,transparent)}}.login-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.login-btn__spinner{animation:.9s linear infinite spin}.login-card__note{text-align:center;color:var(--text-muted);opacity:.5;margin-top:20px;font-size:.75rem}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-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-duration{syntax:"*";inherits:false}
