/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@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-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}}}@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;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.start{inset-inline-start:var(--spacing)}.flex{display:flex}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.gap-4{gap:calc(var(--spacing) * 4)}.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,)}}:root{--bg:#f0f0ed;--bg2:#e8e8e4;--bg3:#ddddd8;--surface:#fff;--blue:#1a2e6e;--blue-mid:#2d4fa8;--blue-dim:#c8d2ee;--text:#141414;--muted:#7a7a74;--border:#d0d0ca;--font-head:"Syne", sans-serif;--font-mono:"DM Mono", monospace}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-head);line-height:1.6;overflow-x:hidden}nav{z-index:100;background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex;position:fixed;top:0;left:0;right:0}@media (width>=769px){nav{padding:1.25rem 3rem}}.lang-toggle{font-family:var(--font-mono);color:var(--muted);letter-spacing:.08em;border:1px solid var(--border);cursor:pointer;background:0 0;padding:.4rem .8rem;font-size:.7rem;transition:all .2s}.lang-toggle:hover{color:var(--blue);border-color:var(--blue)}.nav-logo{letter-spacing:.05em;color:var(--blue);font-size:1rem;font-weight:700;font-family:var(--font-mono)}.hamburger{cursor:pointer;z-index:101;background:0 0;border:none;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;padding:4px;display:flex}.hamburger span{background:var(--text);width:100%;height:2px;transition:all .3s;display:block}.hamburger.active span:first-child{transform:rotate(45deg)translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}@media (width>=769px){.hamburger{display:none}}.nav-links{list-style:none;display:none}@media (width>=769px){.nav-links{gap:2.5rem;display:flex}}.nav-links.active{background:var(--surface);z-index:100;flex-direction:column;gap:0;width:85%;max-width:320px;padding:5rem 1.5rem 2rem;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(0);box-shadow:-8px 0 30px #00000026}.nav-links a{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:.5rem 0;font-size:.78rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-links.active a{border-bottom:1px solid var(--border);padding:1rem 0;font-size:1.1rem;display:block}.nav-links.active a:last-child{border-bottom:none}.nav-links a:hover{color:var(--blue)}.mobile-overlay{z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:none;position:fixed;inset:0}@media (width<=768px){.mobile-overlay.active{display:block}}#home{flex-direction:column;justify-content:center;min-height:100vh;padding:5rem 1.25rem 2rem;display:flex;position:relative;overflow:hidden}@media (width>=769px){#home{padding:6rem 3rem 3rem}}.hero-grid-bg{background-image:linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);opacity:.6;pointer-events:none;background-size:60px 60px;position:absolute;inset:0}.hero-glow{pointer-events:none;background:radial-gradient(circle,#1a2e6e12 0%,#0000 70%);width:700px;height:700px;position:absolute;top:0%;right:-10%}.hero-tag{font-family:var(--font-mono);color:var(--blue-mid);letter-spacing:.1em;opacity:0;margin-bottom:1.5rem;font-size:.78rem;animation:.6s .2s forwards fadeUp}.hero-name{letter-spacing:-.03em;color:var(--text);opacity:0;font-size:clamp(2.5rem,10vw,8rem);font-weight:800;line-height:1;animation:.7s .4s forwards fadeUp}.hero-name span{color:var(--blue)}.hero-role{font-family:var(--font-mono);color:var(--blue);letter-spacing:.05em;opacity:0;margin-top:1rem;font-size:clamp(.8rem,1.5vw,.95rem);font-weight:400;animation:.7s .6s forwards fadeUp}.about-content{margin-top:1.5rem}.about-text{color:var(--muted);max-width:700px;margin-bottom:1rem;font-size:.95rem;line-height:1.9}.about-text:last-child{margin-bottom:0}.hero-cta{opacity:0;flex-wrap:wrap;gap:1rem;margin-top:2rem;animation:.7s .8s forwards fadeUp;display:flex}.btn-primary{background:var(--blue);color:#fff;font-family:var(--font-head);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;padding:.85rem 2rem;font-size:.82rem;font-weight:700;text-decoration:none;transition:background .2s,transform .15s}.btn-primary:hover{background:var(--blue-mid);transform:translateY(-2px)}.btn-outline{color:var(--text);font-family:var(--font-head);letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--border);cursor:pointer;background:0 0;padding:.85rem 2rem;font-size:.82rem;font-weight:600;text-decoration:none;transition:border-color .2s,color .2s,transform .15s}.btn-outline:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}.hero-scroll{font-family:var(--font-mono);color:var(--muted);letter-spacing:.1em;opacity:0;align-items:center;gap:.75rem;font-size:.68rem;animation:.7s 1.2s forwards fadeUp;display:flex;position:absolute;bottom:1.5rem;left:1.25rem}@media (width>=769px){.hero-scroll{bottom:2.5rem;left:3rem}}.scroll-line{background:var(--muted);width:48px;height:1px}section{max-width:1200px;margin:0 auto;padding:3rem 1.25rem}@media (width>=769px){section{padding:4rem 3rem}}.section-label{font-family:var(--font-mono);color:var(--blue-mid);letter-spacing:.15em;text-transform:uppercase;align-items:center;gap:1rem;margin-bottom:1rem;font-size:.7rem;display:flex}.section-label:after{content:"";background:var(--blue-dim);flex:0 0 40px;height:1px}.section-title{letter-spacing:-.02em;color:var(--text);margin-bottom:1.5rem;font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.1}.about-grid{grid-template-columns:1fr;align-items:start;gap:2rem;margin-top:2rem;display:grid}@media (width>=769px){.about-grid{grid-template-columns:1fr 1fr;gap:3rem}}.about-text p{color:var(--muted);margin-bottom:1.25rem;font-size:.97rem;line-height:1.9}.about-text p strong{color:var(--text);font-weight:600}.about-stats{background:var(--border);grid-template-columns:1fr 1fr;gap:1px;display:grid}.stat-item{background:var(--surface);padding:1.75rem}.stat-num{color:var(--blue);font-size:2.2rem;font-weight:800}.stat-label{font-family:var(--font-mono);color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:.5rem;font-size:.68rem;display:block}.experience-list{background:var(--bg);grid-template-columns:1fr;gap:1px;margin-top:2rem;display:grid}@media (width<=768px){.experience-list{gap:1rem}}@media (width>=600px){.experience-list{grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}}.experience-item{background:var(--surface);padding:1.5rem;transition:background .2s;position:relative;overflow:hidden}.experience-item:before{content:"";background:var(--blue);transform-origin:0;height:3px;transition:transform .3s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.experience-item:hover{background:var(--bg)}.experience-item:hover:before{transform:scaleX(1)}.experience-header{flex-direction:column;gap:.25rem;margin-bottom:1rem;display:flex}@media (width>=600px){.experience-header{flex-direction:row;justify-content:space-between;align-items:baseline}}.experience-company{color:var(--text);letter-spacing:-.01em;font-size:1.15rem;font-weight:700}.experience-period{font-family:var(--font-mono);color:var(--muted);letter-spacing:.1em;font-size:.65rem}.experience-role{color:var(--blue);margin-bottom:1rem;font-size:.95rem;font-weight:600}.experience-description{color:var(--muted);margin-bottom:1.5rem;font-size:.87rem;line-height:1.7}.experience-technologies{flex-wrap:wrap;gap:.4rem;display:flex}#skills{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);max-width:100%}#skills>.inner{max-width:1100px;margin:0 auto;padding:0}.skills-grid{background:var(--border);grid-template-columns:1fr;gap:1px;margin-top:2rem;display:grid}@media (width<=768px){#skills>.inner{flex-direction:column;justify-content:center;min-height:80vh;padding:2rem 1.5rem;display:flex}.skills-grid{margin-top:1.5rem}}@media (width>=600px){.skills-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}.skill-group{background:var(--surface);padding:1.5rem}.skill-group-title{font-family:var(--font-mono);color:var(--blue-mid);letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.25rem;font-size:.68rem}.skill-tags{flex-wrap:wrap;gap:.5rem;display:flex}.skill-tag{font-family:var(--font-mono);color:var(--text);background:var(--bg2);border:1px solid var(--border);padding:.4rem .75rem;font-size:.73rem;transition:border-color .2s,color .2s,background .2s}.skill-tag:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-dim)}.projects-grid{background:var(--bg);grid-template-columns:1fr;gap:1px;margin-top:2rem;display:grid}@media (width<=768px){.projects-grid{gap:1rem}}@media (width>=600px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}.project-card{background:var(--surface);padding:1.5rem;transition:background .2s;position:relative;overflow:hidden}.project-card:before{content:"";background:var(--blue);transform-origin:0;height:3px;transition:transform .3s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.project-card:hover{background:var(--bg)}.project-card:hover:before{transform:scaleX(1)}.project-num{font-family:var(--font-mono);color:var(--muted);letter-spacing:.1em;margin-bottom:1.25rem;font-size:.65rem}.project-name{color:var(--text);letter-spacing:-.01em;margin-bottom:.75rem;font-size:1.15rem;font-weight:700}.project-desc{color:var(--muted);margin-bottom:1.5rem;font-size:.87rem;line-height:1.7}.project-tech{flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem;display:flex}.tech-badge{font-family:var(--font-mono);color:var(--blue);background:var(--blue-dim);border:1px solid #1a2e6e26;padding:.25rem .6rem;font-size:.65rem}.project-link{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;border-radius:2px;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.68rem;text-decoration:none;transition:all .2s;display:inline-flex}.project-link.github{color:var(--text);border:1px solid var(--border);background:0 0}.project-link.github:hover{border-color:var(--blue);color:var(--blue)}.project-link.demo{color:#fff;background:var(--blue);border:1px solid var(--blue)}.project-link.demo:hover{background:var(--blue-mid);border-color:var(--blue-mid)}.project-link.demo:after{content:"↗"}.contact-intro{color:var(--muted);max-width:500px;margin-bottom:2.5rem;font-size:1rem;line-height:1.8}.contact-cards{background:var(--border);flex-direction:column;gap:1px;max-width:600px;display:flex}.contact-card{background:var(--surface);align-items:center;gap:1.5rem;padding:1.5rem;text-decoration:none;transition:background .2s;display:flex}.contact-card:hover{background:var(--bg)}.contact-card-icon{background:var(--blue-dim);width:48px;height:48px;font-family:var(--font-mono);color:var(--blue);border:1px solid #1a2e6e26;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:500;display:flex}.contact-card-content{flex-direction:column;flex:1;gap:.25rem;display:flex}.contact-card-label{font-family:var(--font-mono);color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-size:.62rem}.contact-card-value{color:var(--text);word-break:break-word;font-size:.95rem;font-weight:500}.contact-card-arrow{font-family:var(--font-mono);color:var(--muted);font-size:1.2rem;transition:color .2s,transform .2s}.contact-card:hover .contact-card-arrow{color:var(--blue);transform:translate(4px)}.project-image{object-fit:cover;border-radius:2px;width:100%;height:180px;margin-bottom:1.5rem;transition:transform .3s}.project-card:hover .project-image{transform:scale(1.02)}.contact-inner{grid-template-columns:1fr;align-items:start;gap:2rem;margin-top:2rem;display:grid}@media (width>=769px){.contact-inner{grid-template-columns:1fr 1fr;gap:4rem}}.contact-text p{color:var(--muted);margin-bottom:1.5rem;font-size:.95rem;line-height:1.9}.contact-links{flex-direction:column;gap:.75rem;display:flex}.contact-item{background:var(--surface);border:1px solid var(--border);align-items:center;gap:1rem;padding:1rem;text-decoration:none;transition:border-color .2s,background .2s;display:flex}.contact-item:hover{border-color:var(--blue);background:var(--bg2)}.contact-item-label{font-family:var(--font-mono);color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.2rem;font-size:.62rem;display:block}.contact-item-value{color:var(--text);font-size:.88rem;font-weight:500}.contact-icon{background:var(--blue-dim);width:36px;height:36px;font-size:.85rem;font-family:var(--font-mono);color:var(--blue);border:1px solid #1a2e6e26;flex-shrink:0;justify-content:center;align-items:center;font-weight:500;display:flex}.contact-form{flex-direction:column;gap:1rem;display:flex}.form-row{grid-template-columns:1fr;gap:1rem;display:grid}@media (width>=600px){.form-row{grid-template-columns:1fr 1fr}}.form-field{flex-direction:column;gap:.4rem;display:flex}.form-label{font-family:var(--font-mono);color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-size:.62rem}.form-input,.form-textarea{background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:var(--font-head);resize:vertical;outline:none;padding:.75rem 1rem;font-size:.9rem;transition:border-color .2s}.form-input:focus,.form-textarea:focus{border-color:var(--blue)}.form-textarea{min-height:120px}footer{border-top:1px solid var(--border);background:var(--surface);max-width:1200px;margin:0 auto;padding:1.5rem 1.25rem}@media (width>=769px){footer{padding:1rem 3rem}}.footer-bottom{border-top:1px solid var(--border);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;margin-top:2rem;padding-top:1.5rem;display:flex}@media (width<=768px){footer{padding:2rem 1.5rem}.footer-brand{padding:1rem 0}.footer-links-group{border-top:1px solid var(--border);padding:1rem 0}.footer-links-group:first-of-type{border-top:none;padding-top:0}}@media (width>=769px){.footer-bottom{text-align:left;grid-template-columns:1.5fr 1fr 1fr;justify-content:space-between;align-items:start;gap:2rem;margin-top:4rem;padding-top:2rem;display:grid}}.footer-brand{flex-direction:column;align-items:center;gap:.5rem;display:flex}@media (width>=769px){.footer-brand{align-items:flex-start}}.footer-links-group{flex-direction:column;align-items:center;gap:1rem;display:flex}@media (width>=769px){.footer-links-group{align-items:flex-start}}.footer-logo{font-family:var(--font-mono);color:var(--blue);letter-spacing:.05em;font-size:1.5rem;font-weight:700}.footer-tagline{font-family:var(--font-mono);color:var(--muted);letter-spacing:.05em;font-size:.72rem}.footer-nav-label{font-family:var(--font-mono);color:var(--muted);letter-spacing:.15em;text-transform:uppercase;font-size:.62rem}.footer-nav-links{flex-direction:column;gap:.6rem;display:flex}.footer-nav-links a{color:var(--text);font-size:.85rem;text-decoration:none;transition:color .2s}.footer-nav-links a:hover{color:var(--blue)}.footer-copyright{border-top:1px solid var(--border);justify-content:center;padding-top:2rem;display:flex}.footer-copyright p{font-family:var(--font-mono);color:var(--muted);letter-spacing:.08em;font-size:.65rem}footer>.section-label{justify-content:center}footer>.section-label:after{display:none}footer>.section-label{margin-bottom:.25rem;font-size:.6rem}footer>.contact-inner{margin-top:1rem}footer>.contact-inner>.contact-text>p{max-width:500px;margin:0 auto 1.5rem}footer>.contact-inner>.contact-text>.contact-links{align-items:center}footer p{font-family:var(--font-mono);color:var(--muted);letter-spacing:.08em;font-size:.68rem}.footer-links{gap:1.5rem;display:flex}.footer-links a{font-family:var(--font-mono);color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:.68rem;text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--blue)}.flex{display:flex}.gap-4{gap:1rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@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-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}
