*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--white: #ffffff;--ink: #111111;--ink-mid: #333333;--ink-soft: #666666;--ink-muted: #999999;--rule: #e8e8e8;--rule-light: #f2f2f2;--accent-bg: #f7f7f7;--blue-tint: #f0f4ff;--blue-soft: #dce6ff;--max: 1120px;--mono: "DM Mono", monospace;--sans: "DM Sans", -apple-system, Helvetica, sans-serif;--nav-h: 60px}html{scroll-behavior:smooth}body{background:var(--white);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}.nav{position:fixed;top:0;left:0;right:0;z-index:200;background:#fffffff0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--rule);transform:translateY(-110%);opacity:0;transition:transform .32s cubic-bezier(.4,0,.2,1),opacity .32s ease}.nav.visible{transform:translateY(0);opacity:1}.nav-inner{max-width:var(--max);margin:0 auto;padding:0 40px;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:var(--mono);font-size:13px;letter-spacing:.04em;color:var(--ink);text-decoration:none;flex-shrink:0}.nav-links{display:flex;gap:36px;list-style:none}.nav-links a{font-size:13px;font-weight:500;color:var(--ink-muted);text-decoration:none;letter-spacing:.02em;position:relative;padding-bottom:3px;transition:color .2s}.nav-links a:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .22s ease}.nav-links a:hover{color:var(--ink)}.nav-links a:hover:after{transform:scaleX(1)}.nav-links a.active{color:var(--ink);font-weight:600}.nav-links a.active:after{transform:scaleX(1)}.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:38px;height:38px;background:none;border:none;cursor:pointer;padding:5px;border-radius:4px;transition:background .15s}.nav-burger:hover{background:var(--rule-light)}.nav-burger span{display:block;height:1.5px;background:var(--ink);border-radius:2px;transition:transform .26s ease,opacity .2s}.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.nav-drawer{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:#fffffffa;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--rule);padding:16px 24px 24px;z-index:190;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .22s ease,transform .22s ease}.nav-drawer.open{opacity:1;transform:translateY(0);pointer-events:all}.nav-drawer ul{list-style:none}.nav-drawer ul li a{display:block;padding:14px 0;border-bottom:1px solid var(--rule-light);font-size:15px;font-weight:500;color:var(--ink-mid);text-decoration:none;transition:color .15s}.nav-drawer ul li:last-child a{border-bottom:none}.nav-drawer ul li a:hover,.nav-drawer ul li a.active{color:var(--ink)}.wrap{max-width:var(--max);margin:0 auto;padding:0 40px}section{padding:60px 0}section+section{border-top:1px solid var(--rule)}.section-label{font-family:var(--mono);font-size:16px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);margin-bottom:24px}#hero{padding-top:120px;padding-bottom:120px}.hero-kicker{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:28px;display:flex;align-items:center;gap:10px}.hero-kicker:before{content:"";display:inline-block;width:24px;height:1px;background:var(--ink-muted)}.hero-heading{font-size:clamp(38px,6vw,72px);font-weight:600;line-height:1.08;letter-spacing:-.03em;color:var(--ink);margin-bottom:28px;max-width:820px}.hero-heading em{font-style:italic;font-weight:300;color:var(--ink-mid)}.hero-sub{font-size:18px;color:var(--ink-soft);max-width:520px;line-height:1.65;margin-bottom:52px}.hero-cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap}.hero-stats{display:flex;gap:48px;flex-wrap:wrap;justify-content:center;margin-top:80px;padding-top:40px;border-top:1px solid var(--rule)}.stat-num{font-size:32px;font-weight:600;letter-spacing:-.03em;color:var(--ink)}.stat-label{font-size:12px;color:var(--ink-muted);margin-top:2px;letter-spacing:.02em}.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:4px;font-family:var(--sans);font-size:14px;font-weight:500;letter-spacing:.01em;text-decoration:none;cursor:pointer;border:none;transition:all .18s ease}.btn-primary{background:var(--ink);color:var(--white)}.btn-primary:hover{background:#222;transform:translateY(-1px)}.btn-secondary{background:transparent;color:var(--ink-mid);border:1px solid var(--rule)}.btn-secondary:hover{border-color:#bbb;color:var(--ink);transform:translateY(-1px)}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.about-text p{font-size:17px;color:var(--ink-mid);line-height:1.75;margin-bottom:20px}.about-text p:last-child{margin-bottom:0}.about-text strong{color:var(--ink);font-weight:500}.meta-row{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--rule-light);font-size:14px;gap:16px}.meta-row:last-child{border-bottom:none}.meta-key{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);flex-shrink:0}.meta-val{color:var(--ink-mid);text-align:right}.meta-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#4caf78;margin-right:7px}.skills-groups{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}.skill-group-title{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:16px}.skill-tags{display:flex;flex-wrap:wrap;gap:8px}.tag{display:inline-block;padding:6px 13px;border:1px solid var(--rule);border-radius:3px;font-size:13px;color:var(--ink-mid);background:var(--white);transition:all .15s}.tag:hover{border-color:#bbb;color:var(--ink);background:var(--accent-bg)}.tag.featured{background:var(--blue-tint);border-color:var(--blue-soft);color:#3a5bd9}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.project-card{border:1px solid var(--rule);border-radius:6px;padding:32px;background:var(--white);display:flex;flex-direction:column;transition:box-shadow .22s ease,transform .22s ease,border-color .22s}.project-card:hover{box-shadow:0 8px 32px #00000012;transform:translateY(-3px);border-color:#ddd}.project-card.featured-card{grid-column:span 2;background:var(--accent-bg)}.project-num{font-family:var(--mono);font-size:11px;color:var(--ink-muted);letter-spacing:.08em;margin-bottom:28px}.project-title{font-size:19px;font-weight:600;letter-spacing:-.02em;color:var(--ink);margin-bottom:12px}.project-desc{font-size:14px;color:var(--ink-soft);line-height:1.65;margin-bottom:28px;flex:1}.project-desc ul{list-style:none;padding:0;margin:0}.project-desc li{position:relative;padding-left:16px;margin-bottom:8px}.project-desc li:last-child{margin-bottom:0}.project-desc li:before{content:"•";position:absolute;left:0;color:var(--ink-muted)}.project-stack{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}.stack-pill{font-family:var(--mono);font-size:11px;color:var(--ink-muted);background:var(--rule-light);border-radius:2px;padding:4px 8px}.project-links{display:flex;gap:20px;padding-top:20px;border-top:1px solid var(--rule);margin-top:auto}.project-link{font-size:12px;font-weight:500;color:var(--ink-mid);text-decoration:none;display:flex;align-items:center;gap:5px;transition:color .15s}.project-link:hover{color:var(--ink)}.project-link svg{transition:transform .15s}.project-link:hover svg{transform:translate(2px,-2px)}.exp-item{display:grid;grid-template-columns:200px 1fr;gap:40px;padding:36px 0;border-bottom:1px solid var(--rule-light);align-items:start}.exp-item:last-child{border-bottom:none}.exp-period{font-family:var(--mono);font-size:12px;color:var(--ink-muted);margin-bottom:6px}.exp-company{font-size:14px;font-weight:500;color:var(--ink-soft)}.exp-role{font-size:18px;font-weight:600;letter-spacing:-.02em;color:var(--ink);margin-bottom:10px}.exp-desc{font-size:14px;color:var(--ink-soft);line-height:1.7;margin-bottom:14px}.exp-desc ul{list-style:none;padding:0;margin:0}.exp-desc li{position:relative;padding-left:16px;margin-bottom:8px}.exp-desc li:last-child{margin-bottom:0}.exp-desc li:before{content:"•";position:absolute;left:0;color:var(--ink-muted)}.exp-tags{display:flex;flex-wrap:wrap;gap:6px}.exp-tag{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted);border:1px solid var(--rule);padding:3px 8px;border-radius:2px}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.contact-heading{font-size:clamp(28px,4vw,48px);font-weight:600;letter-spacing:-.03em;line-height:1.1;color:var(--ink);margin-bottom:20px}.contact-sub{font-size:16px;color:var(--ink-soft);line-height:1.65;margin-bottom:40px}.contact-link-row{display:flex;align-items:center;justify-content:space-between;padding:18px 0;border-bottom:1px solid var(--rule-light);text-decoration:none;color:var(--ink-mid);transition:color .15s;gap:12px}.contact-link-row:first-child{border-top:1px solid var(--rule-light)}.contact-link-row:hover{color:var(--ink)}.contact-link-row:hover .contact-arrow{transform:translate(3px,-3px)}.contact-link-label{font-size:15px;font-weight:500;flex-shrink:0}.contact-link-value{font-size:13px;color:var(--ink-muted);font-family:var(--mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-arrow{color:var(--ink-muted);transition:transform .15s;flex-shrink:0}.form-group{margin-bottom:18px}.form-label{display:block;font-size:11px;font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:8px}.form-input,.form-textarea{width:100%;padding:12px 16px;border:1px solid var(--rule);border-radius:4px;background:var(--white);font-family:var(--sans);font-size:14px;color:var(--ink);outline:none;transition:border-color .18s;resize:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}.form-input:focus,.form-textarea:focus{border-color:#aaa}.form-textarea{height:110px}.form-submit{width:100%;margin-top:4px}footer{padding:36px 0;border-top:1px solid var(--rule)}.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.footer-copy{font-family:var(--mono);font-size:11px;color:var(--ink-muted);letter-spacing:.04em}.footer-back{font-size:12px;color:var(--ink-muted);text-decoration:none;display:flex;align-items:center;gap:6px;transition:color .15s}.footer-back:hover{color:var(--ink)}.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease}.reveal.in-view{opacity:1;transform:translateY(0)}@media (max-width: 900px){.wrap,.nav-inner{padding:0 28px}section{padding:72px 0}.nav-links{display:none}.nav-burger{display:flex}.nav-drawer{display:block}.about-grid{grid-template-columns:1fr;gap:48px}.skills-groups{grid-template-columns:1fr 1fr;gap:28px}.projects-grid{grid-template-columns:1fr 1fr}.project-card.featured-card{grid-column:span 2}.exp-item{grid-template-columns:1fr;gap:4px}.contact-grid{grid-template-columns:1fr;gap:52px}.hero-stats{gap:28px}}@media (max-width: 600px){.wrap,.nav-inner{padding:0 20px}section{padding:56px 0}#hero{padding-top:72px;padding-bottom:80px}.hero-sub{font-size:16px}.hero-cta{flex-direction:column;align-items:stretch}.btn{width:100%;justify-content:center}.hero-stats{gap:18px}.stat-num{font-size:26px}.projects-grid{grid-template-columns:1fr}.project-card.featured-card{grid-column:span 1}.skills-groups{grid-template-columns:1fr;gap:28px}.section-label{margin-bottom:28px}.contact-link-value{display:none}}
