:root{--bg: #e3e1da;--bg-sidebar: #d8d5cc;--bg-card: #ffffff;--bg-elevated: #f5f3ed;--bg-stack: #dfe5e5;--bg-projects: #ebe5dc;--bg-personal: #dce8e2;--bg-location: #ebe6db;--text: #525252;--text-muted: #7a7a7a;--text-subtle: #9a9a9a;--text-on-dark: #f5f3ed;--primary: #B22222;--primary-hover: #8a1818;--secondary: #5E3131;--accent: #22B39D;--border: #c5c2b9;--border-strong: #525252;--border-accent: #B22222;--space-xs: 8px;--space-sm: 16px;--space-md: 24px;--space-lg: 48px;--space-xl: 80px;--space-2xl: 96px;--fs-xs: 11px;--fs-sm: 13px;--fs-base: 14px;--fs-md: 16px;--fs-lg: 18px;--fs-xl: 22px;--fs-2xl: 32px;--fs-3xl: 44px;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace;--font-sans: "Atkinson Hyperlegible", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background:#c5c2b9;color:var(--text);font-size:var(--fs-base);line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-mono);font-weight:600;letter-spacing:-.02em;text-wrap:balance}p,li,td,dd{font-family:var(--font-sans)}.cursor,.section-tag,code,pre,kbd,samp{font-family:var(--font-mono)}.app{display:grid;grid-template-columns:1fr;width:100%;margin:0 auto;min-height:100vh;background:var(--bg);border-left:1px solid var(--border-strong);border-right:1px solid var(--border-strong)}@media(min-width:576px){.app{max-width:540px}}@media(min-width:768px){.app{max-width:720px}}@media(min-width:1024px){.app{grid-template-columns:280px 1fr;max-width:960px}}@media(min-width:1280px){.app{max-width:1200px}}@media(min-width:1440px){.app{max-width:1360px}}@media(min-width:1920px){.app{max-width:1600px}}.container{width:100%;max-width:1100px;margin:0 auto;padding-left:var(--space-md);padding-right:var(--space-md)}.container-sm{max-width:640px}.container-md{max-width:760px}.container-lg{max-width:920px}@media(min-width:1024px){.container{padding-left:var(--space-lg);padding-right:var(--space-lg)}}aside{background:var(--bg-sidebar);border-bottom:1px solid var(--border-strong);padding:var(--space-md);position:sticky;top:0;z-index:100}@media(min-width:1024px){aside{border-bottom:none;border-right:1px solid var(--border-strong);padding:32px 24px;height:100vh;display:flex;flex-direction:column;overflow-y:auto}}aside .logo{font-size:var(--fs-md);font-weight:700;margin-bottom:var(--space-xs);letter-spacing:-.01em;color:var(--text);cursor:default;user-select:none}.logo .cursor{color:var(--primary);margin-right:4px;font-weight:700;animation:blink-cursor 1.2s infinite step-end}@keyframes blink-cursor{0%,50%{opacity:1}51%,to{opacity:0}}aside .tagline{font-size:var(--fs-xs);color:var(--text-muted);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px dashed var(--border)}@media(max-width:1023px){aside .tagline{display:none}}aside nav{display:flex;flex-direction:row;flex-wrap:wrap;gap:4px;margin-bottom:0}@media(min-width:1024px){aside nav{flex-direction:column;gap:2px;margin-bottom:auto}}aside nav a{color:var(--text);text-decoration:none;padding:8px 12px;font-size:var(--fs-sm);transition:all .15s ease;display:flex;align-items:center;gap:var(--space-xs);border-left:2px solid transparent;border-radius:2px;min-height:36px}@media(min-width:1024px){aside nav a{border-radius:0}}aside nav a:hover{background:var(--bg);border-left-color:var(--accent);color:var(--primary)}aside nav a .num{color:var(--text-subtle);font-size:10px;width:20px}aside nav a.active{background:var(--primary);border-left-color:var(--primary);color:var(--text-on-dark);font-weight:600}aside nav a.active .num{color:var(--text-on-dark);opacity:.7}aside .status{display:none}@media(min-width:1024px){aside .status{display:block;margin-top:var(--space-md);padding:var(--space-sm);background:var(--primary);color:var(--text-on-dark);font-size:var(--fs-xs);border:1px solid var(--primary-hover)}}aside .status .label{color:var(--text-on-dark);font-weight:700;letter-spacing:.05em;margin-bottom:4px;opacity:.9}aside .status .value{color:var(--text-on-dark);font-size:12px;font-weight:600}aside .status .dot{display:inline-block;width:6px;height:6px;background:var(--accent);margin-right:6px;animation:blink 2s infinite}@keyframes blink{0%,60%,to{opacity:1}70%,90%{opacity:.3}}main{padding:0;min-width:0}section{padding:var(--space-xl) 0;border-bottom:1px solid var(--border)}@media(min-width:1024px){section{padding:var(--space-2xl) 0}}section:last-child{border-bottom:none}#home,#about,#contact{background:var(--bg)}#stack{background:var(--bg-stack)}#projects{background:var(--bg-projects)}#personal{background:var(--bg-personal)}#location{background:var(--bg-location)}.section-tag{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--fs-xs);color:var(--text-muted);letter-spacing:.08em;margin-bottom:var(--space-md)}.section-tag:before{content:"";width:24px;height:1px;background:var(--primary)}section h2{font-size:clamp(24px,4vw,var(--fs-2xl));font-weight:700;letter-spacing:-.02em;margin-bottom:var(--space-sm);line-height:1.15}section .lead{font-size:var(--fs-md);color:var(--text-muted);margin-bottom:var(--space-lg);max-width:60ch;line-height:1.7}.hero{padding:var(--space-xl) 0 var(--space-lg);border-bottom:4px solid var(--primary)}@media(min-width:1024px){.hero{padding:var(--space-2xl) 0 var(--space-xl)}}.hero .avatar-row{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.avatar{width:56px;height:56px;background:var(--bg-card);border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;color:var(--secondary);font-size:20px;flex-shrink:0}@media(min-width:1024px){.avatar{width:64px;height:64px;font-size:24px}}.hero .intro{font-size:var(--fs-sm);color:var(--text-muted)}.hero h1{font-size:clamp(28px,5vw,var(--fs-3xl));font-weight:700;line-height:1.1;letter-spacing:-.025em;margin-bottom:var(--space-md)}.hero h1 .accent{color:var(--primary)}.hero .subtitle{font-size:var(--fs-md);color:var(--text);margin-bottom:var(--space-md);max-width:60ch}.meta-row{display:flex;flex-wrap:wrap;gap:var(--space-sm) var(--space-md);padding:var(--space-sm) 0;border-top:1px dashed var(--border);border-bottom:1px dashed var(--border);margin-bottom:var(--space-md);font-size:var(--fs-xs)}.meta-row .item .label{color:var(--text-muted);margin-right:4px}.meta-row .item .value{color:var(--text);font-weight:600}.meta-row .item .value.hot{color:var(--primary)}.cta-row{display:flex;gap:var(--space-sm);flex-wrap:wrap}.btn{padding:12px 20px;font-family:var(--font-mono);font-size:var(--fs-sm);font-weight:600;text-decoration:none;transition:all .15s ease;border:1px solid var(--border-strong);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);letter-spacing:.02em;min-height:44px;flex:0 0 auto}.btn-primary{background:var(--primary);color:var(--text-on-dark);border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-ghost{background:transparent;color:var(--text)}.btn-ghost:hover{background:var(--bg-card);color:var(--primary)}.btn .arrow{color:var(--accent)}.stack-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--border-strong);border:1px solid var(--border-strong)}@media(min-width:480px){.stack-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.stack-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.stack-grid{grid-template-columns:repeat(4,1fr)}}.stack-item{background:var(--bg-card);padding:var(--space-md);transition:background .15s ease}.stack-item:hover{background:var(--bg-elevated)}.stack-item .name{font-size:var(--fs-sm);font-weight:700;margin-bottom:4px}.stack-item .name .v{color:var(--accent);font-weight:500;font-size:11px}.stack-item .desc{font-size:12px;color:var(--text-muted);line-height:1.6}.project-list{display:flex;flex-direction:column;gap:var(--space-sm)}.project{display:grid;grid-template-columns:1fr;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-card);border-top:4px solid var(--primary);border-left:1px solid var(--border-strong);border-right:1px solid var(--border-strong);border-bottom:1px solid var(--border-strong);transition:all .15s ease}@media(min-width:768px){.project{grid-template-columns:60px 1fr;gap:var(--space-md)}}@media(min-width:1024px){.project{grid-template-columns:80px 1fr 200px}}.project:hover{background:var(--bg-elevated);transform:translateY(-2px)}.project .num{font-size:var(--fs-xs);color:var(--text-subtle);letter-spacing:.05em;grid-column:1}.project .num:before{content:"P_";color:var(--text-muted)}.project .num span{color:var(--primary);font-weight:700;font-size:var(--fs-sm)}@media(min-width:768px){.project .num{padding-top:4px}}.project .title{font-size:var(--fs-md);font-weight:700;margin-bottom:4px}.project .subtitle{font-size:var(--fs-sm);color:var(--text-muted);margin-bottom:var(--space-sm)}.project .desc{font-size:var(--fs-sm);color:var(--text);line-height:1.6}.project .badges{display:flex;flex-wrap:wrap;gap:4px;align-items:flex-start;grid-column:1 / -1}@media(min-width:1024px){.project .badges{flex-direction:column;align-items:flex-end;grid-column:auto}}.badge{font-size:10px;font-weight:600;padding:3px 8px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);letter-spacing:.02em}.badge.p{border-color:var(--primary);color:var(--primary);background:#b222220f}.badge.a{border-color:var(--accent);color:var(--accent);background:#22b39d0f}.project .link{grid-column:1 / -1;font-size:var(--fs-sm);color:var(--primary);text-decoration:none;font-weight:600;margin-top:var(--space-xs);display:inline-block}@media(min-width:768px){.project .link{grid-column:2}}.project .link:hover{color:var(--primary-hover)}.project .link:after{content:" →";color:var(--accent)}.about-grid{display:grid;grid-template-columns:1fr;gap:var(--space-lg)}@media(min-width:768px){.about-grid{grid-template-columns:1.2fr 1fr;gap:var(--space-lg)}}.about-text p{margin-bottom:var(--space-sm);font-size:var(--fs-base);line-height:1.8}.about-facts{background:var(--bg-card);border:1px solid var(--border-strong);padding:var(--space-md)}.about-facts h3{font-size:var(--fs-xs);color:var(--text-muted);letter-spacing:.08em;margin-bottom:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px dashed var(--border)}.about-facts dl{display:grid;grid-template-columns:auto 1fr;gap:8px var(--space-sm);font-size:12px}.about-facts dt{color:var(--text-muted)}.about-facts dd{color:var(--text);font-weight:600}.personal-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md)}@media(min-width:768px){.personal-grid{grid-template-columns:1fr 1fr;gap:var(--space-lg)}}.person-card{background:var(--bg-card);border:1px solid var(--border-strong);padding:var(--space-md)}@media(min-width:768px){.person-card{padding:var(--space-lg)}}.person-card .label{font-size:var(--fs-xs);color:var(--accent);letter-spacing:.08em;margin-bottom:var(--space-xs);font-weight:700}.person-card .name{font-size:var(--fs-xl);font-weight:700;margin-bottom:4px}.person-card .role{font-size:12px;color:var(--accent);margin-bottom:var(--space-sm)}.person-card p{font-size:var(--fs-sm);line-height:1.7}.location-row{display:grid;grid-template-columns:1fr;gap:var(--space-md);margin-top:var(--space-md)}@media(min-width:768px){.location-row{grid-template-columns:1fr 1fr;gap:var(--space-lg)}}.map-container{border:1px solid var(--border-strong);height:280px;background:var(--bg-card);position:relative}@media(min-width:768px){.map-container{height:320px}}#map{height:100%;width:100%}.location-info .city{font-size:24px;font-weight:700;margin-bottom:4px}@media(min-width:768px){.location-info .city{font-size:28px}}.location-info .country{font-size:var(--fs-sm);color:var(--text-muted);margin-bottom:var(--space-sm)}.location-info p{font-size:var(--fs-sm);line-height:1.7;margin-bottom:var(--space-sm)}.location-info .coord{font-size:var(--fs-xs);color:var(--accent);padding-top:var(--space-sm);border-top:1px dashed var(--border)}.contact-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--border-strong);border:1px solid var(--border-strong)}@media(min-width:480px){.contact-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.contact-grid{grid-template-columns:repeat(4,1fr)}}.contact-card{background:var(--bg-card);padding:var(--space-sm) var(--space-md);text-decoration:none;color:var(--text);transition:all .15s ease;min-height:64px;display:flex;flex-direction:column;justify-content:center}.contact-card:hover{background:var(--primary);color:var(--text-on-dark)}.contact-card:hover .label{color:#f5f3edcc}.contact-card .label{font-size:var(--fs-xs);color:var(--text-muted);letter-spacing:.08em;margin-bottom:4px}.contact-card .value{font-size:var(--fs-sm);font-weight:600;word-break:break-all}@media(min-width:480px){.contact-card .value{word-break:normal}}.contact-card .value .arrow{color:var(--accent)}footer{padding:var(--space-md) 0;border-top:1px solid var(--border-strong);font-size:var(--fs-xs);color:var(--text-muted);display:flex;flex-direction:column;gap:var(--space-xs);background:var(--bg-sidebar)}@media(min-width:768px){footer{flex-direction:row;justify-content:space-between;align-items:center}}footer .left{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center}footer .right{color:var(--text-subtle)}footer a{color:var(--text);text-decoration:none}footer a:hover{color:var(--primary)}.leaflet-tile{filter:sepia(.4) hue-rotate(-10deg) saturate(.7)}.leaflet-popup-content-wrapper{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:0;box-shadow:none;font-family:var(--font-mono)}.leaflet-popup-tip{background:var(--bg-card);border:1px solid var(--border-strong)}.leaflet-popup-content{font-size:12px;color:var(--text);padding:8px 12px}@media(max-width:480px){:root{--space-xl: 56px;--space-lg: 32px;--space-md: 16px}aside{padding:12px 16px}aside nav a{padding:6px 10px;font-size:12px}aside nav a .num{width:16px;font-size:9px}}.skip-link{position:absolute;left:-999px;width:1px;height:1px;overflow:hidden}.skip-link:focus{left:var(--space-sm);top:var(--space-sm);width:auto;height:auto;background:var(--primary);color:var(--text-on-dark);padding:var(--space-sm);z-index:9999}@media(prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important;scroll-behavior:auto!important}}
