@import"https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0c0d0f;--surface: #141619;--surface-2: #1a1c21;--border: #252729;--accent: #f97316;--text: #e2e4e8;--muted: #6b7280;--mono: "JetBrains Mono", "Courier New", monospace;--sans: "Inter", system-ui, -apple-system, sans-serif}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--sans);background-color:var(--bg);background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:48px 48px;color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:-15%;right:-5%;width:700px;height:700px;background:radial-gradient(circle,rgba(249,115,22,.07) 0%,transparent 65%);pointer-events:none;z-index:0}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}section{padding:7rem 5vw;max-width:1200px;margin:0 auto;scroll-margin-top:80px}.section-divider{width:calc(100% - 10vw);max-width:1200px;height:1px;background:var(--border);margin:0 auto}.mono-label{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}.section-heading{margin-bottom:3.5rem}.section-heading .mono-label{display:block;margin-bottom:.6rem}.section-heading h2{font-size:clamp(1.9rem,3.5vw,2.8rem);font-weight:700;letter-spacing:-.025em;line-height:1.1;color:var(--text)}.section-heading p{color:var(--muted);margin-top:.5rem;font-size:1rem;line-height:1.6;max-width:560px}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}.hero-label{animation:fadeUp .55s ease .1s both}.hero-name{animation:fadeUp .55s ease .25s both}.hero-divider,.hero-meta{animation:fadeUp .55s ease .4s both}.hero-actions{animation:fadeUp .55s ease .55s both}.hero-scroll{animation:fadeUp .55s ease .7s both}.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.reveal.visible{opacity:1;transform:none}.delay-1{transition-delay:.08s}.delay-2{transition-delay:.16s}.delay-3{transition-delay:.24s}.site-header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1rem 5vw;background:#0c0d0fe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.logo{font-family:var(--mono);font-size:.95rem;font-weight:500;color:var(--accent);letter-spacing:.04em}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a{font-size:.875rem;font-weight:500;color:var(--muted);position:relative;transition:color .2s;padding-bottom:2px}.nav-links a:after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--accent);transition:width .25s ease}.nav-links a:hover{color:var(--text)}.nav-links a:hover:after{width:100%}.header-actions{display:flex;align-items:center;gap:.75rem}.mobile-menu{display:none;position:relative}.mobile-menu summary{list-style:none;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--muted);padding:.4rem .85rem;border:1px solid var(--border);border-radius:4px}.mobile-menu summary::-webkit-details-marker{display:none}.mobile-links{position:absolute;right:0;top:130%;min-width:160px;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:.6rem;display:grid;gap:.1rem;box-shadow:0 20px 48px #0009}.mobile-links a{font-size:.875rem;color:var(--muted);padding:.5rem .75rem;border-radius:4px;transition:color .2s,background .2s}.mobile-links a:hover{color:var(--text);background:var(--surface-2)}.btn-primary{display:inline-flex;align-items:center;background:var(--accent);color:#0c0d0f;font-weight:600;font-size:.875rem;padding:.75rem 1.75rem;border-radius:4px;border:none;cursor:pointer;text-decoration:none;transition:background .2s,transform .15s;letter-spacing:.01em}.btn-primary:hover{background:#fb923c;transform:translateY(-1px)}.btn-outline{display:inline-flex;align-items:center;background:transparent;color:var(--text);font-weight:500;font-size:.875rem;padding:.75rem 1.75rem;border-radius:4px;border:1px solid var(--border);cursor:pointer;text-decoration:none;transition:border-color .2s,color .2s}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.ghost-btn{font-family:var(--mono);font-size:.72rem;font-weight:500;color:var(--muted);padding:.5rem 1rem;border:1px solid var(--border);border-radius:4px;text-decoration:none;letter-spacing:.04em;transition:color .2s,border-color .2s}.ghost-btn:hover{color:var(--accent);border-color:#f9731680}.hero{min-height:100vh;max-width:100%;padding:0 5vw;display:flex;flex-direction:column;justify-content:center;position:relative}.hero-content{padding-top:80px;max-width:1200px;margin:0 auto;width:100%}.hero-label{margin-bottom:2.5rem}.hero-name{font-size:clamp(4.5rem,11vw,10rem);font-weight:800;line-height:.88;letter-spacing:-.035em;color:var(--text);margin-bottom:2.25rem}.hero-divider{width:3rem;height:2px;background:var(--accent);margin-bottom:1.5rem}.hero-meta{display:flex;flex-direction:column;gap:.4rem;margin-bottom:2.75rem}.hero-role{font-size:clamp(1rem,2vw,1.25rem);font-weight:500;color:var(--text)}.hero-side{font-size:clamp(.9rem,1.6vw,1.1rem);color:var(--muted)}.hero-side strong{color:var(--accent);font-weight:500}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}.hero-scroll{position:absolute;bottom:2.5rem;left:5vw;display:flex;align-items:center;gap:.75rem;font-family:var(--mono);font-size:.68rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}.hero-scroll:before{content:"";display:block;width:20px;height:1px;background:var(--muted)}.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:5rem;align-items:center}.about-text p{color:var(--muted);line-height:1.8;font-size:1rem;margin-bottom:1.25rem}.about-text p:last-of-type{margin-bottom:0}.about-text strong{color:var(--text);font-weight:600}.about-hobbies{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.5rem}.hobby-tag{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);border:1px solid rgba(249,115,22,.28);background:#f973160d;padding:.3rem .7rem;border-radius:2px}.about-photo-wrap{position:relative}.about-photo-wrap img{border-radius:4px;width:100%;filter:grayscale(20%);transition:filter .4s}.about-photo-wrap img:hover{filter:grayscale(0)}.about-photo-wrap:after{content:"";position:absolute;top:14px;left:14px;right:-14px;bottom:-14px;border:1px solid rgba(249,115,22,.28);border-radius:4px;z-index:-1;pointer-events:none}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:0;top:8px;bottom:0;width:1px;background:var(--border)}.timeline-item{position:relative;padding-bottom:3.5rem}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:-2.375rem;top:.4rem;width:10px;height:10px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);box-shadow:0 0 0 2px var(--accent)}.timeline-period{font-family:var(--mono);font-size:.68rem;color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.4rem}.timeline-role{font-size:1.15rem;font-weight:600;color:var(--text);line-height:1.3;margin-bottom:.2rem}.timeline-company{font-size:.9rem;color:var(--muted);font-style:italic;margin-bottom:1rem}.timeline-bullets{list-style:none;display:flex;flex-direction:column;gap:.55rem}.timeline-bullets li{font-size:.9rem;color:var(--muted);line-height:1.65;padding-left:1.2rem;position:relative}.timeline-bullets li:before{content:"›";position:absolute;left:0;color:var(--accent);font-size:1.1rem;line-height:1.4}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:1.75rem;position:relative;overflow:hidden;display:flex;flex-direction:column;transition:border-color .25s,transform .2s}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.project-card:hover{border-color:#f9731647;transform:translateY(-2px)}.project-card:hover:before{transform:scaleX(1)}.project-card.featured{grid-column:span 2;display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:start}.project-card.featured .project-body{display:flex;flex-direction:column}.project-name{font-size:1.05rem;font-weight:600;color:var(--text);margin-bottom:.6rem;line-height:1.3}.project-desc{font-size:.875rem;color:var(--muted);line-height:1.7;margin-bottom:1rem;flex:1}.project-bullets{list-style:none;display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.25rem}.project-bullets li{font-size:.85rem;color:var(--muted);line-height:1.55;padding-left:1.1rem;position:relative}.project-bullets li:before{content:"→";position:absolute;left:0;color:var(--accent);font-size:.72rem;top:.15em}.project-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-top:auto}.project-tags{display:flex;flex-wrap:wrap;gap:.35rem}.tech-tag{font-family:var(--mono);font-size:.66rem;color:var(--muted);background:var(--surface-2);padding:.2rem .6rem;border-radius:2px}.project-links{display:flex;flex-wrap:wrap;gap:1rem}.project-link{font-family:var(--mono);font-size:.72rem;color:var(--accent);border-bottom:1px solid rgba(249,115,22,.3);padding-bottom:1px;white-space:nowrap;transition:border-color .2s}.project-link:hover{border-color:var(--accent)}.phone-mock{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:.6rem;width:140px;flex-shrink:0}.phone-mock--lg{width:220px}.phone-mock img{border-radius:8px;width:100%;object-fit:contain}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.875rem}.skill-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:1.25rem .75rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.7rem;transition:border-color .25s,background .25s}.skill-card:hover{border-color:#f9731647;background:var(--surface-2)}.skill-card img{width:44px;height:44px;object-fit:contain;filter:grayscale(25%);transition:filter .2s}.skill-card:hover img{filter:grayscale(0)}.skill-card span{font-family:var(--mono);font-size:.7rem;color:var(--muted);font-weight:500}.contact-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;align-items:start}.contact-info h3{font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:.75rem}.contact-info p{color:var(--muted);line-height:1.7;font-size:.9rem;margin-bottom:1.5rem}.contact-links{display:flex;flex-direction:column;gap:.6rem}.contact-link{font-family:var(--mono);font-size:.78rem;color:var(--muted);display:flex;align-items:center;gap:.5rem;transition:color .2s}.contact-link:hover{color:var(--accent)}.contact-form{display:grid;gap:1.1rem;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:2rem}.contact-form label{display:grid;gap:.4rem;font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.contact-form input,.contact-form textarea{background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:.75rem .9rem;border-radius:4px;font-family:var(--sans);font-size:.9rem;width:100%;transition:border-color .2s}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:#f9731699}.contact-form textarea{min-height:120px;resize:vertical}.footer{padding:2.25rem 5vw;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem}.footer-copy{font-family:var(--mono);font-size:.72rem;color:var(--muted);letter-spacing:.04em}.footer-links{display:flex;gap:1.5rem}.footer-links a{font-family:var(--mono);font-size:.72rem;color:var(--muted);transition:color .2s}.footer-links a:hover{color:var(--accent)}@media (max-width: 900px){.nav-links{display:none}.mobile-menu{display:block}.about-grid{grid-template-columns:1fr;gap:2.5rem}.about-photo-wrap:after{display:none}.projects-grid{grid-template-columns:1fr}.project-card.featured{grid-column:span 1;grid-template-columns:1fr}.phone-mock{width:120px;margin:0 auto}.contact-layout{grid-template-columns:1fr;gap:2.5rem}}@media (max-width: 600px){section{padding:5rem 5vw}.footer{flex-direction:column;text-align:center;gap:1rem}.hero-actions{flex-direction:column;align-items:flex-start}.btn-primary,.btn-outline{width:100%;justify-content:center}}
