@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,600;0,700;1,600&display=swap";:root{--color-bg: #ffffff;--color-bg-soft: #f8f9fa;--color-bg-muted: #f2f3f5;--color-surface: #ffffff;--color-border: #e4e6ea;--color-border-soft: #eef0f3;--color-text: #111827;--color-text-muted: #6b7280;--color-text-light: #9ca3af;--color-accent: #111827;--color-accent-soft: #f3f4f6;--color-link: #111827;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-serif: "Playfair Display", Georgia, serif;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--radius-full: 9999px;--shadow-xs: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 2px 8px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);--shadow-lg: 0 8px 32px rgba(0,0,0,.1), 0 4px 12px rgba(0,0,0,.05);--shadow-xl: 0 16px 48px rgba(0,0,0,.12), 0 6px 18px rgba(0,0,0,.06);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.25, .46, .45, .94)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}ul{list-style:none}.container{width:100%;max-width:1120px;margin:0 auto;padding:0 var(--space-6)}.section{padding:var(--space-10) 0}.section-sm{padding:var(--space-16) 0}.display-xl{font-size:clamp(2.8rem,6vw,4.5rem);font-family:var(--font-serif);font-weight:700;line-height:1.08;letter-spacing:-.02em}.display-lg{font-size:clamp(2rem,4vw,3rem);font-family:var(--font-serif);font-weight:600;line-height:1.15;letter-spacing:-.02em}.display-md{font-size:clamp(1.5rem,3vw,2rem);font-family:var(--font-serif);font-weight:600;line-height:1.2}.text-label{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted)}.text-body{font-size:1rem;line-height:1.7;color:var(--color-text-muted)}.text-body-sm{font-size:.875rem;line-height:1.6;color:var(--color-text-muted)}.tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--color-bg-muted);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:.75rem;font-weight:500;color:var(--color-text-muted)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);transition:box-shadow var(--transition-base),transform var(--transition-base),border-color var(--transition-base)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--color-accent)}.divider{height:1px;background:var(--color-border);border:none;margin:0}.navbar-wrap{position:fixed;top:0;left:0;right:0;z-index:100;background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);transition:all var(--transition-base)}.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:64px}.nav-logo{font-family:var(--font-serif);font-size:1.25rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.nav-logo span{display:inline-block;width:6px;height:6px;background:var(--color-text);border-radius:50%;margin-left:2px;vertical-align:super}.nav-links{display:flex;align-items:center;gap:var(--space-8)}.nav-links a{font-size:.875rem;font-weight:500;color:var(--color-text-muted);transition:color var(--transition-fast);position:relative}.nav-links a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1.5px;background:var(--color-text);transition:width var(--transition-base)}.nav-links a:hover,.nav-links a.active{color:var(--color-text)}.nav-links a:hover:after,.nav-links a.active:after{width:100%}.nav-cta{display:inline-flex;align-items:center;gap:var(--space-2);padding:.5rem 1.25rem;background:var(--color-text);color:#fff;border-radius:var(--radius-full);font-size:.875rem;font-weight:500;transition:all var(--transition-base);border:1.5px solid var(--color-text)}.nav-cta:hover{background:transparent;color:var(--color-text)}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px;cursor:pointer}.hamburger span{display:block;width:22px;height:1.5px;background:var(--color-text);border-radius:2px;transition:all var(--transition-base)}.hero{padding-top:calc(64px + var(--space-20));padding-bottom:var(--space-20);min-height:100vh;display:flex;align-items:center}.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center}.hero-eyebrow{display:inline-flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-6);padding:var(--space-2) var(--space-4);background:var(--color-bg-muted);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:.8rem;font-weight:500;color:var(--color-text-muted)}.hero-eyebrow .dot{width:6px;height:6px;background:#22c55e;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.hero-title{margin-bottom:var(--space-6);color:var(--color-text)}.hero-title em{font-style:italic;color:var(--color-text-muted)}.hero-desc{font-size:1.05rem;line-height:1.75;color:var(--color-text-muted);margin-bottom:var(--space-10);max-width:440px}.hero-actions{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}.hero-photo-wrap{position:relative}.hero-photo{width:100%;aspect-ratio:4/5;max-width:380px;margin-left:auto;border-radius:var(--radius-xl);overflow:hidden;background:var(--color-bg-muted);border:1px solid var(--color-border)}.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}.hero-badge{position:absolute;bottom:var(--space-6);left:-var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:var(--space-3);white-space:nowrap}.hero-badge-icon{width:36px;height:36px;background:var(--color-bg-muted);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.1rem}.hero-scroll{margin-top:var(--space-20);display:flex;align-items:center;gap:var(--space-3);color:var(--color-text-muted);font-size:.8rem;font-weight:500;letter-spacing:.05em}.hero-scroll-line{width:40px;height:1px;background:var(--color-border)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:.75rem 1.75rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:600;font-family:var(--font-sans);transition:all var(--transition-base);cursor:pointer;border:1.5px solid transparent;white-space:nowrap}.btn-primary{background:var(--color-text);color:#fff;border-color:var(--color-text)}.btn-primary:hover{background:#374151;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:transparent;color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover{border-color:var(--color-text);transform:translateY(-1px)}.btn-sm{padding:.5rem 1.2rem;font-size:.8rem}.stats-strip{padding:var(--space-12) 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);background:var(--color-bg-soft)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-8)}.stat-item{text-align:center;padding:var(--space-4)}.stat-number{font-family:var(--font-serif);font-size:2.5rem;font-weight:700;color:var(--color-text);line-height:1;margin-bottom:var(--space-2)}.stat-label{font-size:.8rem;color:var(--color-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.08em}.section-header{margin-bottom:var(--space-16)}.section-header-row{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-8);margin-bottom:var(--space-16)}.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.skill-card{padding:var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-surface);transition:all var(--transition-slow);cursor:default}.skill-card:hover{border-color:var(--color-text);box-shadow:var(--shadow-md);transform:translateY(-4px)}.skill-icon{width:44px;height:44px;background:var(--color-bg-muted);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);font-size:1.3rem;transition:background var(--transition-base)}.skill-card:hover .skill-icon{background:var(--color-text);color:#fff}.skill-title{font-size:.95rem;font-weight:600;margin-bottom:var(--space-2);color:var(--color-text)}.skill-desc{font-size:.82rem;line-height:1.6;color:var(--color-text-muted)}.projects-list{display:flex;flex-direction:column;gap:0}.project-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);align-items:center;padding:var(--space-12) 0;border-bottom:1px solid var(--color-border);transition:all var(--transition-base)}.project-row:first-child{border-top:1px solid var(--color-border)}.project-row:hover .project-number{color:var(--color-text)}.project-number{font-family:var(--font-serif);font-size:.8rem;color:var(--color-text-light);margin-bottom:var(--space-3);transition:color var(--transition-base)}.project-title{font-family:var(--font-serif);font-size:1.5rem;font-weight:600;margin-bottom:var(--space-3);color:var(--color-text)}.project-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-4)}.project-img{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:16/10;background:var(--color-bg-muted)}.project-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.project-row:hover .project-img img{transform:scale(1.03)}.project-link{display:inline-flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);font-size:.85rem;font-weight:600;color:var(--color-text);border-bottom:1.5px solid var(--color-text);padding-bottom:1px;transition:opacity var(--transition-fast)}.project-link:hover{opacity:.6}.about-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--space-16);align-items:start}.about-photo{border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:3/4;background:var(--color-bg-muted);border:1px solid var(--color-border);position:sticky;top:80px}.about-photo img{width:100%;height:100%;object-fit:cover;object-position:top}.about-body p{font-size:1rem;line-height:1.8;color:var(--color-text-muted);margin-bottom:var(--space-4)}.about-body p:last-of-type{margin-bottom:0}.timeline{display:flex;flex-direction:column;gap:0;margin-top:var(--space-8)}.timeline-item{display:grid;grid-template-columns:90px 1fr;gap:var(--space-6);padding:var(--space-6) 0;border-bottom:1px solid var(--color-border-soft)}.timeline-item:last-child{border-bottom:none}.timeline-date{font-size:.75rem;font-weight:600;color:var(--color-text-light);padding-top:3px;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.timeline-title{font-size:.95rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-1)}.timeline-sub{font-size:.8rem;color:var(--color-text-muted)}.stack-grid{display:flex;flex-wrap:wrap;gap:var(--space-3)}.stack-pill{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-bg-soft);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:.82rem;font-weight:500;color:var(--color-text);transition:all var(--transition-base)}.stack-pill:hover{background:var(--color-text);color:#fff;border-color:var(--color-text);transform:translateY(-1px)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-12);align-items:start}.contact-info-item{display:flex;gap:var(--space-4);padding:var(--space-5) 0;border-bottom:1px solid var(--color-border-soft)}.contact-info-item:last-child{border-bottom:none}.contact-icon{width:40px;height:40px;background:var(--color-bg-muted);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--color-text-muted);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.06em}.form-input{width:100%;padding:.75rem 1rem;background:var(--color-bg-soft);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:.9rem;font-family:var(--font-sans);color:var(--color-text);transition:all var(--transition-fast);outline:none}.form-input:focus{background:var(--color-surface);border-color:var(--color-text);box-shadow:0 0 0 3px #1118270f}.form-input::placeholder{color:var(--color-text-light)}textarea.form-input{resize:vertical;min-height:130px}.social-links{display:flex;gap:var(--space-3)}.social-link{width:40px;height:40px;background:var(--color-bg-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:1rem;transition:all var(--transition-base)}.social-link:hover{background:var(--color-text);border-color:var(--color-text);color:#fff;transform:translateY(-2px)}.footer{padding:var(--space-12) 0;border-top:1px solid var(--color-border);background:var(--color-bg-soft)}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);flex-wrap:wrap}.footer-copy{font-size:.82rem;color:var(--color-text-muted)}.footer-links{display:flex;gap:var(--space-6)}.footer-links a{font-size:.82rem;color:var(--color-text-muted);transition:color var(--transition-fast)}.footer-links a:hover{color:var(--color-text)}.cta-section{background:var(--color-text);border-radius:var(--radius-xl);padding:var(--space-16) var(--space-12);text-align:center;margin:var(--space-16) 0}.cta-section h2{color:#fff;margin-bottom:var(--space-4)}.cta-section p{color:#fff9;margin-bottom:var(--space-8);font-size:1rem}.btn-cta{background:#fff;color:var(--color-text);border:none;padding:.9rem 2.5rem;border-radius:var(--radius-full);font-size:.9rem;font-weight:700;transition:all var(--transition-base)}.btn-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.page-header{padding-top:calc(64px + var(--space-16));padding-bottom:var(--space-12);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-16)}@media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:var(--space-10)}.hero-photo{max-width:280px}.about-grid{grid-template-columns:1fr}.about-photo{position:static;aspect-ratio:4/3;max-width:360px}.contact-grid{grid-template-columns:1fr}.skills-grid{grid-template-columns:1fr 1fr}.stats-grid{grid-template-columns:1fr 1fr;gap:var(--space-4)}.project-row{grid-template-columns:1fr}.project-row:nth-child(2n) .project-content{order:1}.project-row:nth-child(2n) .project-img{order:2}.nav-links{display:none}.hamburger{display:flex}.section-header-row{flex-direction:column;align-items:flex-start}}@media(max-width:600px){.skills-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.hero-actions{flex-direction:column;align-items:flex-start}.cta-section{padding:var(--space-10) var(--space-6)}.footer-inner{flex-direction:column;text-align:center}}.mobile-menu{display:none;position:fixed;top:64px;right:0;bottom:0;left:0;background:#fffffffa;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:99;padding:var(--space-8) var(--space-6);flex-direction:column;gap:var(--space-1);border-top:1px solid var(--color-border)}.mobile-menu.open{display:flex}.mobile-menu a{padding:var(--space-4) 0;font-size:1.25rem;font-weight:500;color:var(--color-text-muted);border-bottom:1px solid var(--color-border-soft);display:block}.mobile-menu a:hover{color:var(--color-text)}.scroll-top{position:fixed;bottom:var(--space-8);right:var(--space-8);width:44px;height:44px;background:var(--color-text);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;pointer-events:none;transform:translateY(8px);transition:all var(--transition-base);border:none;box-shadow:var(--shadow-md);z-index:90}.scroll-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.scroll-top:hover{background:#374151}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-6)}.blog-card{border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden;background:var(--color-surface);transition:all var(--transition-slow);cursor:pointer}.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.blog-card-img{aspect-ratio:16/9;background:var(--color-bg-muted);overflow:hidden}.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.blog-card:hover .blog-card-img img{transform:scale(1.04)}.blog-card-body{padding:var(--space-5) var(--space-6)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mt-12{margin-top:var(--space-12)}.mt-16{margin-top:var(--space-16)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.w-full{width:100%}.text-center{text-align:center}
