@import"https://fonts.googleapis.com/css2?family=Source+Sans+3:wght@400;500;600;700&display=swap";:root{--bg: #f4f4f4;--surface: #ffffff;--ink: #232323;--muted: #5f5f5f;--line: #dddddd;--accent: #2563eb;--accent-soft: #edf3ff;--shadow: 0 10px 24px rgba(0, 0, 0, .06);--radius-lg: 14px;--radius-md: 10px;--radius-sm: 999px;--max: 1120px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:"Source Sans 3",sans-serif;color:var(--ink);background:var(--bg);min-height:100vh}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.page-shell{width:100%;margin:0 auto;padding:0 0 3rem}.site-nav{position:fixed;top:0;left:0;z-index:20;width:100%;display:flex;justify-content:space-between;align-items:center;padding:.8rem max(1rem,calc((100vw - var(--max)) / 2));background:#1f2227f2;border-bottom:1px solid rgba(255,255,255,.08);backdrop-filter:blur(12px)}.site-brand{display:inline-flex;align-items:center;transition:transform .18s ease,opacity .18s ease}.site-brand:hover{transform:translateY(-1px);opacity:.95}.site-brand img{height:28px;width:auto;object-fit:contain}.site-nav nav a,.button,h1,h2,h3{font-family:"Source Sans 3",sans-serif}.site-nav nav{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}.site-nav nav a{color:#fffc;font-size:.9rem;font-weight:500;transition:color .18s ease,transform .18s ease}.site-nav nav a:hover,.text-link:hover,.site-footer a:hover{color:#fff}.site-nav nav a:hover{transform:translateY(-1px)}.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;padding:5.5rem 1rem 3rem;text-align:center;background:radial-gradient(circle at top right,rgba(255,255,255,.08),transparent 28%),linear-gradient(180deg,#171c23b8,#171c23db),linear-gradient(135deg,#2a323d,#171b21)}.hero:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:42px 42px;opacity:.22}.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at center,transparent 0%,rgba(0,0,0,.18) 100%)}.hero-copy{position:relative;z-index:1;max-width:760px}.hero-brand{margin:0 0 .75rem;color:#fffc;font-size:1.05rem;font-weight:600}.section-eyebrow,.stack-card-label,.contact-label,.about-kicker{margin:0 0 .85rem;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:700}h1{margin:0;max-width:none;font-size:clamp(2.9rem,6vw,4.9rem);line-height:1.04;letter-spacing:-.02em;font-weight:700;color:#fff}.hero-subtitle,.section-copy,.project-heading p,.about-card p,.timeline-list,.contact-panel .section-copy{color:var(--muted);line-height:1.65;font-size:1.05rem}.hero-subtitle{max-width:60ch;margin:1.2rem 0 0;margin-inline:auto;color:#ffffffd1}.hero-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;margin:1.8rem 0 0}.button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.78rem 1.14rem;border-radius:var(--radius-sm);border:1px solid var(--line);transition:background .18s ease,border-color .18s ease,color .18s ease;font-size:.98rem;font-weight:600;cursor:pointer}.button-primary{color:#fff;background:var(--accent);border-color:var(--accent)}.button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0000001f}.button-secondary{background:#ffffff14;border-color:#ffffff38;color:#fff}.button-icon{font-size:1rem}.section{padding:5rem 0;scroll-margin-top:4.5rem}.section-light{background:var(--surface)}.section-muted{background:#f7f7f7}.section-dark-line{border-top:1px solid var(--line)}.section-inner{width:min(calc(100% - 2rem),var(--max));margin:0 auto}.section-inner-narrow{max-width:860px;text-align:center}.section-header{margin-bottom:2rem;text-align:center}.section-header-left{max-width:44rem;margin-left:0;text-align:left}.section-header-left h2,.section-header-left .section-copy{margin-inline:0}.section-header-left h2{width:100%;max-width:none;text-align:left}.section-header-left .section-copy{max-width:42rem;text-align:left}.section-header h2{margin:0 0 .8rem;max-width:15ch;margin-inline:auto;font-size:clamp(2rem,4vw,2.75rem);line-height:1.08;font-weight:700}.section-copy{max-width:66ch;margin:0 auto}.section h2{margin:0 0 1.1rem;text-align:center;font-size:clamp(2rem,4vw,2.6rem);color:var(--ink)}.section .section-header-left h2{text-align:left}.section-lead{max-width:72ch;margin:0 auto 1rem;color:var(--muted);line-height:1.7}.about-copy{max-width:72ch;margin:0 auto;color:var(--muted);line-height:1.7}.about-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:.65rem;margin-top:1.25rem}.mini-button{display:inline-flex;align-items:center;gap:.42rem;padding:.5rem .82rem;background:#2a2d31;color:#fff;border-radius:6px;font-size:.88rem;transition:transform .18s ease,background .18s ease}.mini-button:hover{transform:translateY(-1px);background:#202327}.mini-button-icon{font-size:.95rem}.mini-button-icon-image{width:.95rem;height:.95rem;object-fit:contain}.knowledge-layout{display:grid;grid-template-columns:1.1fr 1fr;gap:2.5rem;align-items:center}.knowledge-copy p,.knowledge-copy ul{color:var(--muted);line-height:1.7}.knowledge-icons{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.1rem}.tech-item{display:grid;justify-items:center;gap:.55rem;padding:1rem .4rem;border:none;background:transparent;border-radius:10px;transition:transform .18s ease,background .18s ease;cursor:pointer}.tech-item:hover{transform:translateY(-3px);background:#fafafa}.tech-item.is-spinning{animation:tech-flip .52s ease}.tech-item span{font-size:.86rem;color:var(--muted)}.tech-icon{font-size:2.2rem}.tech-icon-image{width:2.2rem;height:2.2rem;object-fit:contain}.projects-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem;align-items:start}.project-card{display:grid;gap:1rem;padding:0;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);overflow:hidden;box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease}.project-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px #00000014}.project-visual{position:relative;overflow:hidden;border-bottom:1px solid var(--line);background:var(--accent-soft);aspect-ratio:16 / 8.5}.project-visual img{width:100%;height:100%;object-fit:cover;transition:transform .22s ease,filter .22s ease}.project-overlay{position:absolute;inset:0;display:grid;place-items:center;background:#141a2375;color:#fff;font-weight:700;opacity:0;transition:opacity .22s ease}.project-card:hover .project-overlay,.project-card:focus-within .project-overlay{opacity:1}.project-card:hover .project-visual img,.project-card:focus-within .project-visual img{transform:scale(1.03);filter:brightness(.68)}.project-status{padding:.2rem .5rem;border-radius:var(--radius-sm);background:var(--accent-soft);border:1px solid var(--line);font-size:.72rem;letter-spacing:.04em}.project-body{display:grid;gap:.7rem;padding:.95rem 1rem 1rem}.project-title-row{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem}.project-heading h3,.about-card h3{margin:0 0 .45rem;font-size:1.22rem;font-weight:700}.project-heading p{margin:0;font-size:.96rem}.project-highlights,.timeline-list{margin:0;padding-left:1.1rem}.project-highlights li,.timeline-list li{margin-bottom:.42rem;font-size:.94rem}.project-icon-row{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center}.project-stack-icon{display:inline-flex;align-items:center;justify-content:center;width:1.85rem;height:1.85rem;border:1px solid #d9dfeb;border-radius:8px;background:#f8fbff}.project-stack-icon i{font-size:1.1rem}.project-stack-icon img{width:1.02rem;height:1.02rem;object-fit:contain}.project-stack-icon-fallback{background:#f5f7fb;color:#3e4e6c;font-size:.66rem;font-weight:700;letter-spacing:.01em}.project-stack-icon-fallback span{line-height:1}.tag-row{display:flex;flex-wrap:wrap;gap:.5rem}.tag{padding:.24rem .5rem;border:1px solid var(--line);border-radius:6px;background:#fafafa;color:#666;font-size:.76rem}.text-link{font-family:"Source Sans 3",sans-serif;color:var(--accent);font-weight:600}.about-layout,.contact-grid,.education-grid{display:grid;gap:1rem}.about-layout{grid-template-columns:repeat(2,minmax(0,1fr))}.about-card,.timeline-card{padding:1.5rem;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface)}.stack-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stack-card{padding:1.4rem;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface)}.contact-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem}.contact-card{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:.1rem .75rem;min-height:0;padding:.78rem .88rem;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.contact-card:hover{transform:translateY(-2px);border-color:#cfd8ea;box-shadow:0 8px 18px #0000000d}.contact-note{margin-top:.8rem;text-align:left}.contact-icon-wrap{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:999px;background:#f5f7fb;border:1px solid #dbe3f0}.contact-icon-wrap-mail{background:#edf4ff}.contact-icon-wrap-github{background:#f3f4f6}.contact-icon-wrap-linkedin{background:#eef6ff}.contact-icon-wrap-cv{background:#f4f7ff}.contact-card-copy{display:grid;gap:.08rem;min-width:0}.contact-icon{display:inline-flex;align-items:center;justify-content:center;width:1rem;height:1rem;color:var(--accent);font-size:.84rem;font-weight:700}.contact-icon-github{color:#171515;font-size:1rem}.contact-icon-cv{width:1.35rem;font-size:.72rem}.contact-icon-image{width:1rem;height:1rem;object-fit:contain}.contact-card strong{overflow-wrap:anywhere;font-size:.98rem}.section-contact .section-header-left{margin-bottom:1.4rem}.section-projects .section-header-left{margin-bottom:1.6rem}.section-contact .section-copy,.section-projects .section-copy{margin-bottom:0}.button-contact{color:#fff;background:#2a2d31;border-color:#2a2d31}.button-contact:hover{background:#1f2226;border-color:#1f2226}.education-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.education-card{padding:1rem .85rem;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);text-align:center}.education-card img{height:44px;margin:0 auto .8rem;object-fit:contain}.education-card h3{margin:0 0 .4rem;font-size:1.05rem}.education-card p,.education-card span{display:block;color:var(--muted);font-size:.9rem}.site-footer{width:min(calc(100% - 2rem),var(--max));margin:0 auto;display:flex;justify-content:space-between;gap:1rem;padding:1.5rem 0 0;border-top:1px solid var(--line);color:var(--muted)}.back-to-top{position:fixed;right:1.2rem;bottom:1.2rem;z-index:30;width:2.8rem;height:2.8rem;border:none;border-radius:999px;background:#2a2d31;color:#fff;box-shadow:0 12px 26px #0000002e;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .18s ease,transform .18s ease,background .18s ease;cursor:pointer}.back-to-top.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}.back-to-top:hover{background:#1f2226}@keyframes tech-flip{0%{transform:rotateY(0) scale(1)}50%{transform:rotateY(180deg) scale(1.06)}to{transform:rotateY(360deg) scale(1)}}@media(max-width:980px){.site-nav{padding-inline:1rem}.knowledge-layout,.about-layout,.contact-grid,.education-grid,.projects-grid{grid-template-columns:1fr}.knowledge-icons{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:720px){.site-nav{flex-direction:column;gap:.7rem;align-items:flex-start}.site-nav nav{gap:.75rem}.site-brand img{height:24px}.hero{min-height:92svh}h1{max-width:none;font-size:clamp(2.6rem,12vw,4rem)}.knowledge-icons{grid-template-columns:repeat(2,minmax(0,1fr))}.section-header-left,.contact-note{text-align:center}.section-header-left h2,.section-header-left .section-copy{margin-inline:auto}.site-footer{flex-direction:column}.back-to-top{right:.85rem;bottom:.85rem}}
