*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;font-family:Open Sans,ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;tab-size:4;-webkit-tap-highlight-color:transparent}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{color:inherit;font-family:inherit;font-feature-settings:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.z-10{z-index:10}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.flex-grow,.grow{flex-grow:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.px-4{padding-left:1rem;padding-right:1rem}.py-12{padding-bottom:3rem;padding-top:3rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.text-center{text-align:center}.text-sm{font-size:.875rem;line-height:1.25rem}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.outline{outline-style:solid}.blur{--tw-blur:blur(8px)}.blur,.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;scrollbar-gutter:stable}:root,html{color-scheme:light only}:root{--primary:#1a1a1a;--secondary:#444;--tertiary:#666;--border:#e5e5e5;--border-dark:#d0d0d0;--bg-main:#fafafa;--bg-card:#fff;--bg-subtle:#fafafa;--bg-nav:hsla(0,0%,100%,.85);--shadow-sm:0 1px 3px rgba(0,0,0,.06);--shadow-md:0 2px 8px rgba(0,0,0,.08)}[data-theme=dark]{color-scheme:dark;--primary:#ececec;--secondary:#dedede;--tertiary:#cecece;--border:#333;--border-dark:#444;--bg-main:#0a0a0a;--bg-card:#141414;--bg-subtle:#1a1a1a;--bg-nav:hsla(0,0%,8%,.85);--shadow-sm:0 1px 3px rgba(0,0,0,.3);--shadow-md:0 2px 8px rgba(0,0,0,.4)}body{background:var(--bg-main);color:var(--primary);font-family:Public Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:300;line-height:1.6;overflow-x:hidden;padding:0}.container{background:var(--bg-card);border-radius:16px;box-shadow:var(--shadow-sm);margin:0 auto;max-width:1100px;overflow:visible;position:relative}.language-switcher{align-items:center;display:flex;gap:.5rem;position:absolute;right:1rem;top:1rem;z-index:1000}.lang-toggle{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;display:flex;overflow:hidden}.lang-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:.75rem;font-weight:600;padding:6px 12px;transition:all .2s ease}.lang-btn:hover{background:var(--bg-main);color:var(--text-primary)}.lang-btn.active{background:var(--primary);color:#fff}.google-translate-hidden{display:none}.goog-te-gadget{color:transparent!important;font-family:inherit!important;font-size:0!important}.goog-te-combo{background:var(--bg-card)!important;border:1px solid var(--border)!important;border-radius:8px!important;box-shadow:var(--shadow-sm)!important;color:var(--primary)!important;cursor:pointer!important;display:inline-block!important;font-family:inherit!important;font-size:.875rem!important;height:auto!important;line-height:1.5!important;margin:0!important;outline:none!important;padding:6px 10px!important;transition:all .2s;vertical-align:middle}.goog-te-combo:hover{background-color:var(--bg-main)!important;border-color:var(--border-dark)!important}.goog-logo-link,.goog-te-gadget>span{display:none!important}#google_element{display:inline-block}.goog-te-banner-frame,.skiptranslate iframe{display:none!important}body{top:0!important}#goog-gt-tt,.goog-te-balloon-frame{display:none!important}.goog-text-highlight{background:none!important;box-shadow:none!important}header{background:var(--bg-card);border-end-end-radius:inherit;border-end-start-radius:inherit;padding:1.5rem 2.5rem 1.5rem 3rem;position:relative}.header-divider{background:var(--border);height:1.5px;margin:0 auto;transform:scaleX(0);transform-origin:center;transition:transform .75s cubic-bezier(.25,1,.5,1);transition-delay:var(--divider-delay);width:95%}.header-divider.expanded{height:2px;transform:scaleX(1);transition-delay:0s;width:95%}.header-content{display:flex;flex-direction:column;padding-top:1rem}.profile-group{gap:1.5rem;margin-bottom:3.5rem}.header-intro,.profile-group{align-items:center;display:flex}.header-intro{flex-direction:row;gap:3rem;justify-content:space-between;max-width:100%}.intro-content{display:flex;flex:1;flex-direction:column;gap:1.5rem;max-width:60%;padding:0 3rem}.intro-image-wrapper{align-items:center;display:flex;flex:1;justify-content:center;padding-bottom:3.5rem;padding-top:1rem}.intro-img{border-bottom:1px solid #f1f1f1;border-right:1px solid #f1f1f1;border-color:#f1f1f1 #f1f1f1 #e8e8e8;border-radius:16px;border-style:solid;border-width:1px 1.5px 4px 1px;box-shadow:var(--shadow-sm);height:auto;-o-object-fit:cover;object-fit:cover;transform:scale(.75) rotate(6deg);transition:transform .6s cubic-bezier(.3,0,.2,1);width:225px;will-change:transform}[data-theme=dark] .intro-img{border-bottom:1px solid #3e3e3e;border-right:1px solid #3e3e3e;border-color:#3e3e3e;border-style:solid;border-width:1px 1.5px 4px 1px}.header-intro.is-active .intro-img{transform:scale(1) rotate(6deg);transition-delay:25ms}@media(max-width:768px){.header-intro{flex-direction:column;text-align:left}.intro-content{margin-top:0;max-width:100%;padding:0 1rem;text-align:left}.intro-image-wrapper{display:flex;justify-content:center;margin-bottom:0;margin-top:0;padding:2rem 0;width:100%}.intro-img{max-width:250px;transform:scale(.75) rotate(4deg);width:100%}.header-intro.is-active .intro-img{transform:scale(1) rotate(4deg)}}.headline{color:var(--primary);font-size:2.25rem;font-weight:700;line-height:1.2;margin:0}.intro-text{color:var(--tertiary);font-size:1rem;line-height:1.6;margin:0}.profile-img{border:4px solid var(--bg-main);border-radius:50%;box-shadow:var(--shadow-md);flex-shrink:0;height:130px;-o-object-fit:cover;object-fit:cover;width:130px}.header-text{display:flex;flex:1;flex-direction:column;height:130px;justify-content:center;padding:.25rem 0}.header-text h2{background-color:#10183c;color:#fff;font-size:1.2rem;font-weight:500;letter-spacing:-.02em;line-height:1.1;margin-bottom:0;padding:0 .3rem;width:-moz-fit-content;width:fit-content}.subtitle{color:var(--secondary);color:var(--tertiary);font-size:1.25rem;font-weight:400;margin-bottom:0}.header-contacts{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}.contact-chip{align-items:center;background:var(--bg-main);border:1px solid var(--border);border-radius:9999px;color:var(--secondary);display:inline-flex;font-size:.875rem;height:36px;padding:.5rem .6rem;text-decoration:none;transition:box-shadow .3s ease,transform .3s ease}.contact-chip.is-expanded,.contact-chip:hover{background:var(--bg-card);border-color:var(--border-dark);box-shadow:var(--shadow-sm);color:var(--primary)}.contact-icon{flex-shrink:0;height:16px;stroke:var(--tertiary);width:16px}.contact-chip.is-expanded .contact-icon,.contact-chip:hover .contact-icon{stroke:var(--primary)}.email-chip .contact-text{display:inline-block;margin-left:.5rem}.social-chip .slide-text{display:inline-block;margin-left:0;max-width:0;opacity:0;overflow:hidden;transition:max-width .35s cubic-bezier(.4,0,.2,1),opacity .25s cubic-bezier(.4,0,.2,1),margin-left .35s cubic-bezier(.4,0,.2,1);white-space:nowrap;will-change:max-width,opacity,margin-left}@media(min-width:768px){.social-chip.is-expanded .slide-text,.social-chip:hover .slide-text{margin-left:.5rem;max-width:200px;opacity:1}}main{padding:3rem}section{margin-bottom:4rem}section:last-child{margin-bottom:0}.section-header{align-items:center;display:flex;margin-bottom:2.5rem;padding-bottom:.75rem}.section-number{color:var(--tertiary);font-family:Courier New,monospace;font-size:.875rem;font-weight:600;margin-right:1rem}.section-header h2{color:var(--primary);font-size:1.75rem;font-weight:600;letter-spacing:-.02em}.summary-box{background:var(--bg-subtle);border-left:4px solid var(--primary);color:var(--secondary);line-height:1.8;margin-bottom:3rem}.card,.summary-box{padding:2rem;position:relative}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:1.5rem;overflow:visible;transition:box-shadow .3s ease,border-left .3s ease,transform .3s ease}.card-border,.skill-border{height:100%;inset:0;overflow:visible;pointer-events:none;position:absolute;width:100%;z-index:1}.card-border path,.skill-border path{fill:none;stroke:var(--primary);stroke-width:.5;vector-effect:non-scaling-stroke}.card:hover{border-left:3px solid var(--primary);box-shadow:var(--shadow-md);stroke-linecap:square}.card:last-child{margin-bottom:0}.card-header{align-items:start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.card-title{flex:1}.card-title h3{align-items:center;color:var(--primary);display:flex;font-size:1.375rem;font-weight:600;gap:.75rem;margin-bottom:.375rem}.project-icon{height:24px;stroke:var(--primary);width:24px}.card-subtitle{align-items:center;color:var(--tertiary);display:flex;font-size:.9375rem;gap:.5rem}.type-icon{height:16px;stroke:var(--tertiary);width:16px}.badge{align-items:center;background:var(--bg-card);border:1px solid var(--border-dark);border-radius:8px;color:var(--tertiary);display:inline-flex;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.375rem .875rem;white-space:nowrap}.calendar-icon{height:14px;stroke:var(--tertiary);width:14px}.card-description{color:var(--secondary);line-height:1.7;margin-bottom:1.5rem}.tech-stack{align-items:center;display:flex;flex-wrap:nowrap;gap:0;height:40px;transition:all .5s ease}.card.is-focused .tech-stack:not(.tech-stack-controlled),.card:hover .tech-stack:not(.tech-stack-controlled){flex-wrap:wrap;gap:.75rem;height:auto}.tech-chip{align-items:center;background:var(--bg-main);border:1px solid var(--border);border-radius:9999px;box-shadow:0 0 0 2px var(--bg-card);display:inline-flex;margin-left:-12px;padding:4px;position:relative;transition:all .5s ease}.tech-chip:first-child{margin-left:0}.card.is-focused .tech-stack:not(.tech-stack-controlled) .tech-chip,.card:hover .tech-stack:not(.tech-stack-controlled) .tech-chip{background:var(--bg-card);border-color:var(--border-dark);box-shadow:none;margin-left:0;padding-right:12px}.tech-icon{border-radius:50%;flex-shrink:0;height:28px;-o-object-fit:contain;object-fit:contain;width:28px}.tech-placeholder{align-items:center;background:var(--bg-subtle);color:var(--tertiary);display:flex;justify-content:center}.tech-placeholder svg{height:16px;width:16px}.tech-name{color:var(--primary);font-size:.8125rem;font-weight:500;margin-left:0;max-width:0;opacity:0;overflow:hidden;transition:max-width .4s ease,opacity .3s ease,margin-left .4s ease;white-space:nowrap}.card.is-focused .tech-stack:not(.tech-stack-controlled) .tech-name,.card:hover .tech-stack:not(.tech-stack-controlled) .tech-name{margin-left:.5rem;max-width:150px;opacity:1}.tech-hidden{border:1px solid transparent;margin-left:-38px;opacity:0;padding:4px;pointer-events:none;transform:scale(1)}.card.is-focused .tech-stack:not(.tech-stack-controlled) .tech-hidden,.card:hover .tech-stack:not(.tech-stack-controlled) .tech-hidden{border-color:var(--border-dark);margin-left:0;opacity:1;pointer-events:auto;transform:scale(1);width:auto}.tech-count{background:var(--bg-subtle);color:var(--tertiary);font-size:.75rem;font-weight:600;height:38px;justify-content:center;margin-left:-12px;padding:0;width:38px;z-index:0}.card.is-focused .tech-stack:not(.tech-stack-controlled) .tech-count,.card:hover .tech-stack:not(.tech-stack-controlled) .tech-count{border:none;margin:0;opacity:0;padding:0;transform:scale(0);width:0}.tech-tag{background:var(--bg-subtle);border:1px solid var(--border);border-radius:8px;color:var(--secondary);font-family:inherit;font-size:.8125rem;padding:.5rem .875rem;transition:all .2s}.tech-tag:hover{background:var(--bg-card);border-color:var(--border-dark)}.card-footer{border-top:1px solid var(--border);display:flex;gap:1rem;padding-top:1rem}.card-link{align-items:center;border:1px solid var(--border);border-radius:8px;color:var(--primary);display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s}.card-link:hover{background:var(--bg-main);border-color:var(--primary)}.link-icon{height:16px;stroke:var(--primary);width:16px}.experience-card{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:12px;margin-bottom:1.5rem;padding:2rem;transition:all .2s}.experience-card:hover{box-shadow:var(--shadow-sm)}.experience-card:last-child{margin-bottom:0}.experience-header{margin-bottom:1rem}.experience-header h3{align-items:center;color:var(--primary);display:flex;font-size:1.25rem;font-weight:600;gap:.75rem;margin-bottom:.5rem}.briefcase-icon{height:20px;stroke:var(--primary);width:20px}.experience-meta{color:var(--tertiary);display:flex;font-size:.875rem;gap:1.5rem;margin-bottom:.5rem}.experience-company{font-weight:500}.experience-company,.experience-period{align-items:center;display:flex;gap:.5rem}.experience-period{color:var(--tertiary)}.meta-icon{height:14px;stroke:currentColor;width:14px}.experience-description{color:var(--secondary);line-height:1.7}.skills-container{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.skill-box{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:visible;padding:1.75rem;position:relative;transition:all .2s}.skill-box:hover{border-color:var(--border-dark);box-shadow:var(--shadow-md)}.skill-box h3{align-items:center;border-bottom:2px solid var(--border);color:var(--primary);display:flex;font-size:.875rem;font-weight:600;gap:.5rem;letter-spacing:.05em;margin-bottom:1.25rem;padding-bottom:.75rem;text-transform:uppercase}.skill-icon{height:18px;stroke:var(--primary);width:18px}.skill-box ul{list-style:none}.skill-box li{align-items:center;color:var(--secondary);display:flex;font-size:.9375rem;gap:.5rem;margin-bottom:.75rem;padding-left:0;position:relative;transition:color .2s}.skill-item-icon{border-radius:4px;height:16px;width:16px}.skill-box li:hover{color:var(--primary)}footer{background:var(--bg-subtle);border-top:1px solid var(--border);color:var(--tertiary);font-size:.875rem;justify-content:space-between;padding:2rem 3rem}.footer-info,footer{align-items:center;display:flex}.footer-info{gap:.5rem}.footer-icon{height:16px;stroke:var(--tertiary);width:16px}@media(max-width:768px){body{padding:0}.container{border:1px solid var(--border);box-shadow:var(--shadow-sm)}footer,header,main{padding:2rem 1.5rem}.language-switcher{justify-content:flex-end;position:absolute;right:.75rem;top:.75rem}.lang-btn{font-size:.7rem;padding:5px 10px}.goog-te-combo{font-size:.75rem!important;padding:5px 8px!important}.profile-img{height:80px;width:80px}.header-content{align-items:center;flex-direction:column;text-align:center}.profile-group{flex-direction:column;gap:1rem}.header-intro{max-width:100%;text-align:center}.headline{font-size:1.5rem}.intro-text{font-size:.9375rem}.header-text{align-items:center;gap:.5rem;height:auto;justify-content:center}.header-text h1{font-size:1.5rem}.subtitle{font-size:1rem}.header-contacts{justify-content:center}.contact-chip{font-size:.8rem;height:32px;padding:.4rem .5rem}.contact-icon{height:14px;width:14px}.section-header h2{font-size:1.375rem}.card-header{flex-direction:column}.badge{align-self:flex-start}.experience-meta{flex-direction:column;gap:.5rem}footer{flex-direction:column;gap:1rem;text-align:center}}@media(max-width:480px){footer,header,main{padding:1.5rem 1rem}.language-switcher{gap:.35rem;padding:.75rem 1rem 0}.lang-btn{font-size:.65rem;padding:4px 8px}.goog-te-combo{font-size:.7rem!important;padding:4px 6px!important}.profile-img{height:90px;width:90px}.header-text h1{font-size:1.25rem}.subtitle{font-size:.875rem}.section-header h2{font-size:1.25rem}.card-title h3{font-size:1.125rem}.card,.experience-card,.skill-box,.summary-box{padding:1.25rem}}.blog-article{background:var(--bg-card);border-radius:12px;margin-bottom:2rem;padding:2rem}.blog-header{margin-bottom:2rem;padding-bottom:1.5rem}.blog-header h1{color:var(--primary);font-size:2rem;font-weight:700;line-height:1.3;margin-bottom:1rem}.blog-meta{color:var(--tertiary);flex-wrap:wrap;font-size:.875rem;gap:1rem}.blog-meta,.blog-meta-item{align-items:center;display:flex}.blog-meta-item{gap:.375rem}.blog-meta .separator{color:var(--border)}.blog-content{color:var(--secondary);font-size:1.0625rem;line-height:1.85}.blog-content h2{border-bottom:none;color:var(--primary);font-size:1.5rem;font-weight:700;margin-bottom:1rem;margin-top:2.5rem;padding-bottom:.5rem}.blog-content h3{color:var(--primary);font-size:1.25rem;font-weight:600;margin-bottom:.75rem;margin-top:2rem}.blog-content h4{color:var(--secondary);font-size:1.125rem;font-weight:600;margin-bottom:.5rem;margin-top:1.5rem}.blog-content p{margin-bottom:1.25rem}.blog-content a{color:var(--primary);text-decoration:underline;text-decoration-color:var(--border-dark);text-underline-offset:3px;transition:text-decoration-color .2s ease}.blog-content a:hover{text-decoration-color:var(--primary)}.blog-content strong{color:var(--primary);font-weight:600}.blog-content h2 a,.blog-content h2 a:hover,.blog-content h3 a,.blog-content h3 a:hover,.blog-content h4 a,.blog-content h4 a:hover{border:none;text-decoration:none}.blog-content ul{list-style-type:disc}.blog-content ol,.blog-content ul{margin-bottom:1.25rem;padding-left:1.5rem}.blog-content ol{list-style-type:decimal}.blog-content li{margin-bottom:.5rem}.blog-content li::marker{color:var(--tertiary)}.blog-content code{background:var(--bg-subtle);border-radius:4px;color:var(--primary);font-family:JetBrains Mono,Fira Code,SF Mono,Consolas,monospace;font-size:.875em;padding:.2em .4em}.blog-content pre{background:var(--bg-subtle);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-sm);font-size:.875rem;line-height:1.7;margin-bottom:1.5rem;overflow-x:auto;padding:1.25rem}.blog-content pre code{background:transparent;color:inherit;display:block;font-size:inherit;padding:0}[data-theme=dark] .blog-content pre{background-color:var(--shiki-dark-bg)!important}[data-theme=dark] .blog-content pre span{color:var(--shiki-dark)!important;font-style:var(--shiki-dark-font-style)!important;font-weight:var(--shiki-dark-font-weight)!important;-webkit-text-decoration:var(--shiki-dark-text-decoration)!important;text-decoration:var(--shiki-dark-text-decoration)!important}.blog-content blockquote{border-left:3px solid var(--primary);color:var(--secondary);font-style:italic;margin:1.5rem 0;padding-left:1.25rem}.blog-content blockquote p{margin-bottom:0}.blog-content img{border-radius:8px;box-shadow:var(--shadow-md);height:auto;margin:1.5rem 0;max-width:100%}.blog-content hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.blog-content table{border-collapse:collapse;font-size:.9375rem;margin:1.5rem 0;width:100%}.blog-content td,.blog-content th{border:1px solid var(--border);padding:.75rem 1rem;text-align:left}.blog-content th{color:var(--primary);font-weight:600}.blog-content th,.blog-content tr:nth-child(2n){background:var(--bg-subtle)}.blog-tags,.blog-tags-wrapper{border-top:1px solid var(--border);margin-top:2rem;padding-top:1.5rem}.blog-tags{display:flex;flex-wrap:wrap;gap:.5rem}.blog-tag{background:var(--bg-subtle);border-radius:6px;color:var(--secondary);font-size:.8125rem;font-weight:500;padding:.375rem .75rem;transition:all .2s ease}.blog-tag:hover{background:var(--border);color:var(--primary)}.blog-layout{display:grid;gap:3rem;grid-template-columns:1fr 250px}.blog-main{min-width:0}.blog-sidebar{position:relative}@media(max-width:1024px){.blog-layout{gap:2rem;grid-template-columns:1fr}.blog-sidebar{display:none}}@media(max-width:768px){.blog-article{padding:1.5rem}.blog-header h1{font-size:1.625rem}.blog-content{font-size:1rem}.blog-content h2{font-size:1.375rem}.blog-content h3{font-size:1.125rem}.blog-content pre{font-size:.8125rem;padding:1rem}}
