*,:before,:after{--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: rgb(59 130 246 / .5);--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: }::backdrop{--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: rgb(59 130 246 / .5);--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: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family: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;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color: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:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-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,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[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}.invisible{visibility:hidden}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.top-3{top:.75rem}.top-5{top:1.25rem}.-mx-4{margin-left:-1rem;margin-right:-1rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mb-10{margin-bottom:2.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.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}.list-disc{list-style-type:disc}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.border-t{border-top-width:1px}.border-blue-200{--tw-border-opacity: 1;border-color:rgb(191 219 254 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.p-6{padding:1.5rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pl-5{padding-left:1.25rem}.pt-8{padding-top:2rem}.text-center{text-align:center}.text-right{text-align:right}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}.text-blue-700{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{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-duration:.15s}.\[culture\:JP\]{culture:JP}:root{--bg: #FAFAF7;--bg-alt: #F3F3EF;--ink: #0E0E0C;--ink-2: #3A3A36;--ink-3: #7A7A72;--rule: #E2E2DC;--accent: oklch(.52 .18 252);--accent-light: oklch(.92 .06 252);--accent-dim: oklch(.52 .18 252 / .12);--font-display: "Playfair Display", Georgia, serif;--font-body: "DM Sans", Helvetica, sans-serif;--font-mono: "DM Mono", "Courier New", monospace;--max-w: 1100px;--nav-h: 64px;--radius: 4px;--transition: .22s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg: #0D0D0B;--bg-alt: #161614;--ink: #EEEEE8;--ink-2: #CCCCC4;--ink-3: #888880;--rule: #2A2A26;--accent: oklch(.62 .18 252);--accent-light: oklch(.22 .08 252);--accent-dim: oklch(.62 .18 252 / .15)}[data-theme=dark] .terminal{background:#0a0a08;border-color:#2a2a26}[data-theme=dark] .terminal__bar{background:#161614}[data-theme=dark] .stat,[data-theme=dark] .skill-group,[data-theme=dark] .project-card,[data-theme=dark] .cert-card,[data-theme=dark] .blog-preview-card{background:var(--bg)}[data-theme=dark] .project-card:hover,[data-theme=dark] .blog-preview-card:hover{background:var(--bg-alt)}[data-theme=dark] .form-input,[data-theme=dark] .form-select,[data-theme=dark] .form-textarea{background:var(--bg-alt);color:var(--ink);border-color:var(--rule)}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--rule);background:transparent;color:var(--ink-2);cursor:pointer;transition:border-color var(--transition),color var(--transition),background var(--transition);flex-shrink:0}.theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.theme-toggle svg{width:16px;height:16px;display:block}.theme-toggle .icon-moon{display:block}.theme-toggle .icon-sun,[data-theme=dark] .theme-toggle .icon-moon{display:none}[data-theme=dark] .theme-toggle .icon-sun{display:block}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:16px;line-height:1.7}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit}.container{max-width:var(--max-w);margin:0 auto;padding:0 32px}.section{padding:96px 0}.section--alt{background:var(--bg-alt)}.section-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;display:block}.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.15;color:var(--ink);margin-bottom:48px}.section-title em{font-style:italic;color:var(--accent)}.rule{width:40px;height:2px;background:var(--accent);margin-bottom:32px}.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}.btn{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:11px 24px;border-radius:var(--radius);transition:all var(--transition);border:1.5px solid transparent;font-family:var(--font-body)}.btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn--primary:hover{background:#005398;background:oklch(.44 .18 252);border-color:#005398;border-color:oklch(.44 .18 252)}.btn--ghost{background:transparent;color:var(--ink);border-color:var(--rule)}.btn--ghost:hover{border-color:var(--ink-2)}.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);background:#0d0d0bf5;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.07);z-index:100;display:flex;align-items:center}.nav__inner{max-width:var(--max-w);margin:0 auto;padding:0 32px;width:100%;display:flex;align-items:center;justify-content:space-between}.nav__logo{font-family:var(--font-mono);font-size:13px;font-weight:500;color:#eeeee8;letter-spacing:.04em;display:inline-flex;align-items:center;gap:8px}.nav__logo svg{color:var(--accent)}.nav__logo span{color:var(--accent)}.nav__links{display:flex;gap:32px;align-items:center;list-style:none;margin:0;padding:0}.nav__links a{font-size:13px;font-weight:500;color:#eeeee8b3;letter-spacing:.02em;transition:color var(--transition);position:relative}.nav__links a:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform var(--transition)}.nav__links a:hover,.nav__links a.active{color:#fff}.nav__links a:hover:after,.nav__links a.active:after{transform:scaleX(1)}.nav__cta{font-size:12px!important;font-weight:600!important;letter-spacing:.06em!important;text-transform:uppercase;color:var(--accent)!important;border:1.5px solid var(--accent);padding:6px 16px;border-radius:var(--radius);transition:background var(--transition),color var(--transition)!important}.nav__cta:after{display:none!important}.nav__cta:hover{background:var(--accent);color:#fff!important}.nav__mobile-actions{display:none;align-items:center;gap:12px}.nav__hamburger{display:flex;flex-direction:column;gap:5px;background:none;border:none;padding:4px}.nav__hamburger span{display:block;width:22px;height:1.5px;background:#eeeee8}.nav__mobile{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:#0d0d0bfa;border-bottom:1px solid rgba(255,255,255,.07);padding:24px 32px;flex-direction:column;gap:16px;z-index:99}.nav__mobile.open{display:flex}.nav__mobile a{font-size:14px;font-weight:500;color:#eeeee8b3;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.07)}.nav__mobile a:hover{color:#fff}.nav .theme-toggle{border-color:#fff3;color:#eeeee8b3}.nav .theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding-top:var(--nav-h);position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 39px,var(--rule) 39px,var(--rule) 40px),repeating-linear-gradient(90deg,transparent,transparent 79px,var(--rule) 79px,var(--rule) 80px);opacity:.35;pointer-events:none}.hero__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}.hero__eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;display:block}.hero__name{font-family:var(--font-display);font-size:clamp(3rem,6vw,5.5rem);font-weight:900;line-height:1;letter-spacing:-.02em;margin-bottom:16px}.hero__name em{font-style:italic;color:var(--accent)}.hero__role{font-family:var(--font-display);font-size:clamp(1.1rem,2vw,1.4rem);font-weight:400;font-style:italic;color:var(--ink-2);margin-bottom:28px}.hero__bio{font-size:15px;line-height:1.75;color:var(--ink-2);max-width:480px;margin-bottom:36px}.hero__links{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.terminal{background:#0e0e0c;border-radius:8px;overflow:hidden;box-shadow:0 32px 80px #0e0e0c33}.terminal__bar{background:#1a1a18;padding:12px 16px;display:flex;align-items:center;gap:8px}.terminal__dot{width:12px;height:12px;border-radius:50%}.terminal__dot:nth-child(1){background:#ff5f57}.terminal__dot:nth-child(2){background:#febc2e}.terminal__dot:nth-child(3){background:#28c840}.terminal__title{font-family:var(--font-mono);font-size:11px;color:#555;margin-left:8px}.terminal__body{padding:24px;font-family:var(--font-mono);font-size:13px;line-height:1.8;min-height:280px}.terminal__line{display:block}.terminal__prompt{color:#31aa40}.terminal__cmd{color:#e8e8e0}.terminal__out{color:#7a7a72;padding-left:18px}.terminal__out--accent{color:#6cb2ff;color:oklch(.75 .15 252);padding-left:18px}.terminal__out--green{color:#5bbe62;padding-left:18px}.terminal__cursor{display:inline-block;width:8px;height:14px;background:var(--accent);animation:blink 1.1s step-end infinite;vertical-align:text-bottom}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.about__text p{font-size:15px;line-height:1.85;color:var(--ink-2);margin-bottom:20px}.about__text p strong{color:var(--ink);font-weight:600}.about__social{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap}.about__social-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--rule);padding:6px 12px;border-radius:var(--radius);transition:border-color var(--transition),color var(--transition)}.about__social-link:hover{border-color:var(--accent);color:var(--accent)}.about__stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden}.stat{background:var(--bg);padding:28px 24px}.stat__num{font-family:var(--font-display);font-size:2.8rem;font-weight:700;color:var(--ink);line-height:1;margin-bottom:6px}.stat__num em{font-style:italic;color:var(--accent)}.stat__label{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}.skills__groups{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden}.skill-group{background:var(--bg);padding:36px 28px}.skill-group__title{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid var(--rule)}.skill-item{margin-bottom:20px}.skill-item:last-child{margin-bottom:0}.skill-item__name{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:4px}.skill-item__tools{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);line-height:1.6;white-space:pre-line}.skill-item__value{font-size:12px;color:var(--ink-2);margin-top:4px;line-height:1.5}.projects__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden;margin-bottom:32px}.project-card{background:var(--bg);padding:36px 32px;transition:background var(--transition);position:relative}.project-card:hover{background:#f0f6fc}.project-card__num{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);margin-bottom:16px;letter-spacing:.1em}.project-card__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;line-height:1.25;margin-bottom:12px;color:var(--ink)}.project-card__desc{font-size:14px;line-height:1.75;color:var(--ink-2)}.project-card__arrow{position:absolute;top:36px;right:32px;font-size:18px;color:var(--rule);transition:color var(--transition),transform var(--transition)}.project-card:hover .project-card__arrow{color:var(--accent);transform:translate(3px,-3px)}.timeline{position:relative;padding-left:32px}.timeline:before{content:"";position:absolute;left:0;top:8px;bottom:0;width:1px;background:var(--rule)}.timeline-item{position:relative;margin-bottom:52px}.timeline-item:last-child{margin-bottom:0}.timeline-item:before{content:"";position:absolute;left:-36px;top:6px;width:8px;height:8px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);box-shadow:0 0 0 1px var(--accent)}.timeline-item__date{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--accent);margin-bottom:6px;text-transform:uppercase}.timeline-item__role{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:4px;color:var(--ink)}.timeline-item__company{font-size:13px;font-weight:600;color:var(--ink-3);margin-bottom:12px}.timeline-item__desc{font-size:14px;line-height:1.75;color:var(--ink-2)}.timeline-item__summary{font-size:14px;line-height:1.75;color:var(--ink-2);font-style:italic;margin-bottom:14px}.timeline-item__bullets{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.timeline-item__bullets li{font-size:13.5px;line-height:1.7;color:var(--ink-2);padding-left:14px;position:relative}.timeline-item__bullets li:before{content:"—";position:absolute;left:0;color:var(--accent);font-family:var(--font-mono);font-size:11px;top:3px}.timeline-item__bullets li strong{color:var(--ink);font-weight:600}.exp-edu__grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}.exp-edu__subhead{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:32px;padding-bottom:12px;border-bottom:1px solid var(--rule)}.edu__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden}.edu-card{background:var(--bg);padding:28px 24px}.edu-card__school{font-family:var(--font-display);font-size:1rem;font-weight:700;margin-bottom:6px;color:var(--ink)}.edu-card__degree{font-size:14px;color:var(--ink-2);margin-bottom:4px}.edu-card__period{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em}.certs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden}.cert-card{background:var(--bg);padding:28px 24px;display:flex;align-items:flex-start;gap:14px}.cert-card__icon{width:36px;height:36px;background:var(--accent-dim);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-mono);font-size:13px;color:var(--accent);font-weight:500}.cert-card__title{font-size:14px;font-weight:600;line-height:1.35;color:var(--ink)}.blog-preview__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden;margin-bottom:32px}.blog-preview-card{background:var(--bg);padding:32px 28px;transition:background var(--transition);cursor:pointer;display:block}.blog-preview-card:hover{background:#f0f6fc}.blog-preview-card__meta{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}.blog-preview-card__tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);padding:2px 7px;border-radius:2px}.blog-preview-card__date{font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}.blog-preview-card__title{font-family:var(--font-display);font-size:1.05rem;font-weight:700;line-height:1.3;margin-bottom:10px;color:var(--ink)}.blog-preview-card__excerpt{font-size:13px;line-height:1.7;color:var(--ink-2);margin-bottom:16px}.blog-preview-card__read{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);transition:color var(--transition)}.blog-preview-card:hover .blog-preview-card__read{color:var(--accent)}.blog-preview-card__read:after{content:" →"}.contact__grid{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:start}.contact__info p{font-size:15px;line-height:1.8;color:var(--ink-2);margin-bottom:36px}.contact__links{display:flex;flex-direction:column;gap:12px}.contact__link{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--ink-2);transition:color var(--transition)}.contact__link:hover{color:var(--accent)}.contact__link-icon{width:36px;height:36px;background:var(--bg-alt);border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:12px;color:var(--accent);flex-shrink:0;border:1px solid var(--rule);transition:border-color var(--transition),background var(--transition)}.contact__link:hover .contact__link-icon{border-color:var(--accent);background:var(--accent-dim)}.contact__avail{margin-top:48px;padding:24px;background:var(--bg-alt);border:1px solid var(--rule);border-radius:var(--radius)}.contact__avail-dot{width:8px;height:8px;border-radius:50%;background:#31aa40;flex-shrink:0;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}.form-input,.form-textarea,.form-select{background:var(--bg);border:1px solid var(--rule);border-radius:var(--radius);padding:12px 16px;font-family:var(--font-body);font-size:14px;color:var(--ink);transition:border-color var(--transition);outline:none;width:100%}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--accent)}.form-textarea{min-height:140px;resize:vertical}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:var(--ink-3)}.form-input::placeholder,.form-textarea::placeholder{color:var(--ink-3)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%237A7A72'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.form-error{font-family:var(--font-mono);font-size:11px;color:#c53637;margin-top:2px;min-height:14px;display:block}.form-input.error,.form-textarea.error{border-color:#c53637}.form-feedback{padding:14px 18px;border-radius:var(--radius);font-size:13px;font-family:var(--font-mono)}.form-feedback--success{background:#dbf3db;color:#00480e;color:oklch(.35 .14 145);border:1px solid oklch(.75 .12 145)}.site-footer{padding:48px 0;border-top:1px solid var(--rule)}.site-footer__inner{display:flex;align-items:center;justify-content:space-between}.site-footer__brand{font-family:var(--font-mono);font-size:13px;color:var(--ink-3)}.site-footer__brand span{color:var(--accent)}.site-footer__copy{font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}.pill{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);padding:3px 8px;border-radius:2px}.view-all{font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--accent);padding-bottom:1px;transition:opacity var(--transition)}.view-all:hover{opacity:.7}.proj-detail-grid{display:grid;grid-template-columns:280px 1fr;gap:64px;align-items:start}.proj-detail-left{position:sticky;top:calc(var(--nav-h) + 24px)}.proj-detail-bullets{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}.proj-detail-bullets li{font-size:14.5px;line-height:1.75;color:var(--ink-2);padding-left:20px;position:relative}.proj-detail-bullets li:before{content:"—";position:absolute;left:0;color:var(--accent);font-family:var(--font-mono);font-size:11px;top:4px}@media(max-width:900px){.nav__links{display:none}.nav__mobile-actions{display:flex}.hero__grid,.about__grid,.contact__grid{grid-template-columns:1fr;gap:48px}.skills__groups,.projects__grid{grid-template-columns:1fr}.certs__grid{grid-template-columns:repeat(2,1fr)}.blog-preview__grid,.edu__grid{grid-template-columns:1fr}.exp-edu__grid{grid-template-columns:1fr;gap:40px}.proj-detail-grid{grid-template-columns:1fr;gap:24px}.proj-detail-left{position:static}.hero__name{font-size:3rem}.section{padding:64px 0}.container{padding:0 20px}.form-row{grid-template-columns:1fr}.site-footer__inner{flex-direction:column;gap:8px;text-align:center}}@media(max-width:600px){.certs__grid{grid-template-columns:1fr}}.card-hover{transition:transform .15s ease,box-shadow .15s ease}.card-hover:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.hover\:text-gray-800:hover{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.hover\:underline:hover{text-decoration-line:underline}.dark\:border-blue-800:is(.dark *){--tw-border-opacity: 1;border-color:rgb(30 64 175 / var(--tw-border-opacity, 1))}.dark\:bg-blue-900\/20:is(.dark *){background-color:#1e3a8a33}.dark\:text-blue-300:is(.dark *){--tw-text-opacity: 1;color:rgb(147 197 253 / var(--tw-text-opacity, 1))}@media(min-width:768px){.md\:w-1\/3{width:33.333333%}.md\:w-2\/3{width:66.666667%}.md\:flex-row{flex-direction:row}.md\:text-4xl{font-size:2.25rem;line-height:2.5rem}}body{font-family:var(--font-body, "DM Sans", Helvetica, sans-serif)}.blog-container{max-width:1200px;margin:0 auto;padding:calc(var(--nav-h, 64px) + 2rem) 1.5rem 2rem}.post-meta{font-family:var(--font-mono);font-size:.82rem;color:var(--ink-3);margin-bottom:.4rem}.back-link{display:inline-flex;align-items:center;gap:.4rem;margin-bottom:2rem;font-size:.9rem;text-decoration:none;color:var(--ink-3);transition:color .15s}.back-link:hover{color:var(--accent)}.tag{background:var(--accent-dim);border:1px solid var(--accent);border-radius:4px;padding:.2rem .6rem;font-size:.75rem;color:var(--accent);font-family:var(--font-mono);letter-spacing:.04em}.post-content{line-height:1.8;font-size:1rem;color:var(--ink-2)}.post-content h1,.post-content h2,.post-content h3,.post-content h4,.post-content h5,.post-content h6{font-family:var(--font-display);font-weight:700;line-height:1.3;color:var(--ink)}.post-content h1{font-size:2rem;margin:2.5rem 0 1rem}.post-content h2{font-size:1.55rem;margin:2.5rem 0 .75rem}.post-content h3{font-size:1.25rem;margin:2rem 0 .5rem}.post-content h4{font-size:1.05rem;margin:1.5rem 0 .4rem}.post-content p{margin:0 0 1.25rem}.post-content ul,.post-content ol{margin:.25rem 0 1.25rem;padding-left:1.75rem}.post-content ul{list-style-type:disc}.post-content ol{list-style-type:decimal}.post-content li{margin-bottom:.35rem;line-height:1.75}.post-content li>ul,.post-content li>ol{margin-top:.25rem;margin-bottom:.25rem}.post-content strong{font-weight:700;color:var(--accent)}.post-content em{font-style:italic}.post-content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.post-content a:hover{opacity:.8}.post-content hr{border:none;border-top:1px solid var(--rule);margin:2.5rem 0}.post-content table{width:100%;border-collapse:collapse;margin:1.75rem 0;font-size:.9rem}.post-content th,.post-content td{border:1px solid var(--rule);padding:.6rem 1rem;text-align:left;vertical-align:top;color:var(--ink-2)}.post-content thead tr{background:var(--bg-alt)}.post-content thead th{font-weight:600;color:var(--ink)}.post-content tbody tr:nth-child(2n){background:var(--bg-alt)}.post-content pre{position:relative;border-radius:10px;overflow:hidden;font-size:.9rem;line-height:1.6;margin:1.5rem 0;box-shadow:0 4px 16px #00000040;border:1px solid transparent}[data-theme=dark] .post-content pre{border-color:#ffffff14;box-shadow:0 4px 24px #0009}.post-content pre code.hljs{border-radius:10px;padding:1.4rem 1.5rem;display:block;overflow-x:auto;font-family:var(--font-mono);font-size:.855rem}.post-content code:not(.hljs){background:var(--accent-dim);color:var(--accent);padding:.15rem .5rem;border-radius:4px;font-size:.875em;font-family:var(--font-mono);border:1px solid var(--accent-light)}.post-content img{max-width:100%;border-radius:8px;margin:1.5rem 0}[data-theme=dark] .post-content img:not(.img-keep-dark){padding:.75rem;box-shadow:0 0 0 1px var(--rule);background:var(--bg-alt)}[data-theme=dark] .post-content img[src$=".png"]:not(.img-keep-dark),[data-theme=dark] .post-content img[src$=".PNG"]:not(.img-keep-dark){background:#fff}.post-content blockquote{border-left:4px solid var(--accent);background:var(--accent-dim);margin:1.75rem 0;padding:.85rem 1.25rem;border-radius:0 8px 8px 0;color:var(--ink-2);font-style:italic}.post-content details{margin:2rem 0 0;border-radius:8px}.post-content details>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:.5rem;-webkit-user-select:none;-moz-user-select:none;user-select:none}.post-content details>summary::-webkit-details-marker{display:none}.post-content details>summary h2:before{content:"▶";display:inline-block;font-size:.7em;margin-right:.5rem;transition:transform .2s ease;color:var(--accent);vertical-align:middle}.post-content details[open]>summary h2:before{transform:rotate(90deg)}.post-content details>summary h2{margin:0}.post-content .details-content{padding-left:.25rem}.copy-btn{position:absolute;top:.6rem;right:.6rem;background:#ffffff1f;color:#e2e8f0;border:1px solid rgba(255,255,255,.2);border-radius:5px;padding:.2rem .6rem;font-size:.72rem;font-family:inherit;cursor:pointer;transition:background .15s;z-index:2}.copy-btn:hover{background:#ffffff38}.reading-progress-bar{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--accent),#7c3aed);z-index:1000;transition:width .1s linear;border-radius:0 2px 2px 0}.blog-post-layout{display:flex;gap:2.5rem;align-items:flex-start}.blog-post-main{flex:1;min-width:0}.blog-toc-sidebar{width:220px;flex-shrink:0;position:sticky;top:calc(var(--nav-h, 64px) + 1.5rem);max-height:calc(100vh - var(--nav-h, 64px) - 3rem);overflow-y:auto}.blog-toc-inner{border-left:2px solid var(--rule);padding-left:1rem}.blog-toc-title{font-family:var(--font-mono);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin:0 0 .75rem}.blog-toc-link{display:block;font-size:.8rem;line-height:1.5;color:var(--ink-3);text-decoration:none;transition:color .15s;border-left:2px solid transparent;margin-left:-1.125rem;padding:.2rem 0 .2rem 1rem}.blog-toc-link:hover{color:var(--accent)}.blog-toc-link.toc-active{color:var(--accent);border-left-color:var(--accent);font-weight:600}.blog-toc-link.toc-h3{padding-left:1.75rem;font-size:.75rem}@media(max-width:1100px){.blog-toc-sidebar{display:none}}.pagination{display:flex;align-items:center;justify-content:center;gap:.35rem;flex-wrap:wrap;padding:2rem 0 1rem}.page-btn{min-width:2.2rem;height:2.2rem;padding:0 .6rem;border:1px solid var(--rule);border-radius:6px;background:var(--bg);color:var(--ink-2);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s;line-height:1}.page-btn:hover:not([disabled]){background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.page-btn.page-active{background:var(--accent);border-color:var(--accent);color:#fff;cursor:default}.page-btn[disabled]{opacity:.4;cursor:not-allowed}.page-btn.page-nav{padding:0 .75rem;font-size:.8rem}.page-ellipsis{min-width:2.2rem;height:2.2rem;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-3);font-size:.9rem}.blog-index-list{list-style:none;padding:0;margin:0 0 2rem}.blog-index-item{padding:32px 0;border-bottom:1px solid var(--rule)}.blog-index-item:first-child{padding-top:0}.blog-index-item__meta{display:flex;align-items:center;gap:10px;margin-bottom:8px}.blog-index-item__date{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--ink-3);text-transform:uppercase}.blog-index-item__title{display:block;font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--ink);text-decoration:none;line-height:1.3;margin-bottom:8px;transition:color .15s}.blog-index-item__title:hover{color:var(--accent)}.blog-index-item__desc{font-size:.9rem;color:var(--ink-2);line-height:1.6;margin:0}.blog-controls{margin-bottom:2rem;display:flex;flex-direction:column;gap:.85rem}.blog-search{width:100%;padding:.6rem 1rem;border:1px solid var(--rule);border-radius:8px;font-size:.95rem;font-family:inherit;background:var(--bg);color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.blog-search:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.blog-search::-moz-placeholder{color:var(--ink-3)}.blog-search::placeholder{color:var(--ink-3)}.tag-filter-bar{display:flex;flex-wrap:wrap;gap:.45rem}.tag-pill{padding:.25rem .75rem;border-radius:999px;border:1px solid var(--rule);background:transparent;font-size:.78rem;font-family:var(--font-mono);color:var(--ink-2);cursor:pointer;transition:background .15s,color .15s,border-color .15s;line-height:1.6}.tag-pill:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.tag-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.no-results{padding:2rem 0;color:var(--ink-3);font-size:.95rem}.section-heading{position:relative;padding-bottom:.6rem}.section-heading:after{content:"";position:absolute;left:0;bottom:0;width:36px;height:3px;background:var(--accent);border-radius:2px}@media(max-width:768px){.blog-container{padding:1.5rem .75rem;overflow-x:hidden}.post-content h1{font-size:1.55rem}.post-content h2{font-size:1.3rem}.post-content h3{font-size:1.1rem}.post-content div{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;box-sizing:border-box}.post-content table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}}@media(max-width:480px){.blog-container{padding:1rem .5rem;overflow-x:hidden}.post-content div[style*=grid-template-columns]{grid-template-columns:1fr!important}}
