:root{--bg:#001e2b;--bg-card:#0d2535;--bg-card-alt:#123;--border:#1e3a4a;--border-light:#2a4a5a;--green:#00ed64;--green-dim:#00ed641f;--green-glow:#00ed6414;--text:#8faab8;--text-muted:#4d6e80;--text-head:#e8f4f8;--shadow-card:0 4px 24px #0006, 0 0 0 1px #00ed640a;--shadow-hover:0 8px 40px #00000080, 0 0 0 1px #00ed6414;--font-serif:"Playfair Display", Georgia, serif;--font-sans:"DM Sans", system-ui, sans-serif;--font-mono:"Space Mono", ui-monospace, Consolas, monospace;--radius-card:16px;--radius-pill:100px;--transition:.22s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.6;overflow-x:hidden}#root{flex-direction:column;min-height:100svh;display:flex}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}.squiggly-bg{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.squiggly-svg{width:100%;height:100%;position:absolute;inset:0}.squig-group-a{will-change:transform;animation:32s ease-in-out infinite alternate driftA}.squig-group-b{will-change:transform;animation:42s ease-in-out infinite alternate driftB}@keyframes driftA{0%{transform:translate(-55px)}to{transform:translate(55px,-22px)}}@keyframes driftB{0%{transform:translate(35px,12px)}to{transform:translate(-65px,-12px)}}.portfolio{z-index:1;flex-direction:column;flex:1;display:flex;position:relative}.hero-section{min-height:100svh;position:relative;overflow:hidden}.hero-bg{z-index:0;position:absolute;inset:0}.hero-bg-base{background:var(--bg);position:absolute;inset:0}.hero-bg-right{clip-path:polygon(58% 0,100% 0,100% 100%,43% 100%);background:#021824;position:absolute;inset:0}.hero-diag-svg{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;inset:0}.hero-inner{z-index:2;grid-template-columns:1fr 1fr;align-items:center;width:100%;max-width:1280px;min-height:100svh;margin:0 auto;padding:80px 60px;display:grid;position:relative}.hero-image-col{justify-content:center;align-items:center;padding-right:60px;display:flex}.hero-image-wrapper{display:inline-block;position:relative}.hero-image-glow{z-index:0;filter:blur(20px);will-change:opacity;background:radial-gradient(#00ed6424 0%,#0000 70%);border-radius:50%;animation:4s ease-in-out infinite alternate glowPulse;position:absolute;inset:-28px}@keyframes glowPulse{0%{opacity:.5}to{opacity:1}}.hero-image{z-index:1;object-fit:cover;border-radius:36px;width:320px;height:320px;position:relative;box-shadow:0 0 0 1px #00ed6426,0 24px 64px #0009,0 8px 32px #00ed6414}.hero-content-col{align-items:center;padding-left:60px;display:flex}.hero-content{flex-direction:column;gap:20px;max-width:480px;padding-left:32px;display:flex}.hero-name{font-family:var(--font-serif);color:var(--text-head);letter-spacing:-2px;font-size:clamp(52px,6vw,88px);font-weight:500;line-height:1}.hero-tagline{color:var(--text);max-width:380px;font-size:18px;font-weight:300;line-height:1.6}.hero-links{flex-wrap:wrap;gap:12px;margin-top:4px;display:flex}.hero-social-link{border:1px solid var(--border-light);border-radius:var(--radius-pill);color:var(--text);transition:border-color var(--transition), color var(--transition), background var(--transition);align-items:center;gap:8px;padding:8px 16px;font-size:14px;font-weight:400;display:inline-flex}.hero-social-link svg{flex-shrink:0;width:16px;height:16px}.hero-social-link:hover{border-color:var(--green);color:var(--green);background:var(--green-dim)}.btn-cv{border-radius:var(--radius-pill);background:var(--green);color:#001e2b;letter-spacing:.3px;transition:transform var(--transition), box-shadow var(--transition);align-self:flex-start;align-items:center;gap:8px;margin-top:4px;padding:14px 28px;font-size:15px;font-weight:500;display:inline-flex}.btn-cv:hover{transform:scale(1.04);box-shadow:0 0 32px #00ed6459}.btn-cv svg{flex-shrink:0}.section{z-index:1;padding:100px 60px;position:relative}.section-inner{width:100%;max-width:1280px;margin:0 auto}.section-header{margin-bottom:56px}.section-tag{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:3px;color:var(--green);margin-bottom:16px;padding-left:4px;font-size:11px;display:inline-block}.portfolio-tag{padding-left:12px}.section-title{font-family:var(--font-serif);color:var(--text-head);letter-spacing:-1px;font-size:clamp(32px,4vw,52px);font-weight:500;line-height:1.1}.skills-section{border-top:1px solid var(--border)}.skills-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.skill-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);cursor:default;flex-direction:column;gap:12px;padding:32px;display:flex}.skill-card:hover{box-shadow:var(--shadow-hover);border-color:var(--border-light);transform:translateY(-4px)}.card-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:3px;color:var(--green);font-size:10px}.card-title{color:var(--text-head);font-size:20px;font-weight:500;line-height:1.2}.card-desc{color:var(--text);flex:1;font-size:14px;line-height:1.65}.tech-stack{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.tech-tag{font-size:12px;font-family:var(--font-mono);color:#6ec99a;letter-spacing:.5px;background:#00ed6412;border:1px solid #00ed6426;border-radius:6px;padding:4px 10px}.background-grid{grid-template-columns:1fr 1fr;gap:48px;display:grid}.background-col-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:3px;color:var(--text-muted);margin-bottom:28px;font-size:11px}.timeline{flex-direction:column;display:flex;position:relative}.timeline:before{content:"";background:var(--border);width:1px;position:absolute;top:12px;bottom:12px;left:3px}.timeline-item{grid-template-columns:12px 1fr;gap:16px;margin-bottom:32px;display:grid;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-marker{z-index:1;justify-content:center;align-items:flex-start;margin-left:-5.5px;padding-top:4px;display:flex;position:relative}.timeline-marker:before{content:"";background:var(--green);border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 8px #00ed6466}.timeline-content{flex-direction:column;gap:4px;display:flex}.timeline-period{font-family:var(--font-mono);color:var(--green);letter-spacing:1px;font-size:11px}.timeline-title{color:var(--text-head);margin:0;font-size:15px;font-weight:500;line-height:1.3}.timeline-org{color:var(--text-muted);margin:0;font-size:13px}.timeline-location{color:var(--text-muted);opacity:.7}.timeline-bullets{flex-direction:column;gap:4px;margin:6px 0 0;padding-left:16px;display:flex}.timeline-bullets li{color:var(--text);font-size:13px;line-height:1.5;list-style:outside}.projects-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.project-card{background:var(--bg-card-alt);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);flex-direction:column;display:flex;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-hover);border-color:var(--border-light);transform:translateY(-5px)}.project-card--coming-soon{opacity:.45;filter:grayscale();pointer-events:none}.coming-soon-badge{color:#9ca3af;letter-spacing:.08em;text-transform:uppercase;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2;background:#1e1e1ed9;border:1px solid #ffffff1a;border-radius:999px;padding:4px 10px;font-size:.7rem;font-weight:600;position:absolute;top:12px;left:12px}.project-img{background:#0a1e2c;flex-shrink:0;width:100%;height:200px;position:relative;overflow:hidden}.project-img img{object-fit:cover;width:100%;height:100%;transition:transform .4s;display:block}.project-card:hover .project-img img{transform:scale(1.04)}.project-img-placeholder{width:100%;height:100%}.project-card-body{flex-direction:column;flex:1;gap:14px;padding:28px;display:flex}.project-name{font-family:var(--font-serif);color:var(--text-head);letter-spacing:-.5px;font-size:22px;font-weight:500}.project-desc{color:var(--text);flex:1;font-size:14px;line-height:1.7}.btn-project{border-radius:var(--radius-pill);border:1px solid var(--border-light);color:var(--text);transition:border-color var(--transition), color var(--transition), background var(--transition), transform var(--transition);align-self:flex-start;align-items:center;gap:6px;margin-top:4px;padding:10px 20px;font-size:13px;font-weight:500;display:inline-flex}.btn-project:hover{border-color:var(--green);color:var(--green);background:var(--green-dim);transform:scale(1.03)}.btn-project svg{flex-shrink:0}.portfolio-footer{z-index:1;border-top:1px solid var(--border);text-align:center;color:var(--text-muted);padding:40px 60px;font-size:13px;position:relative}.portfolio-footer .accent{color:var(--green)}@media (width<=1024px){.hero-inner{grid-template-rows:auto auto;grid-template-columns:1fr;align-content:center;gap:48px;padding:80px 32px 60px}.hero-image-col{justify-content:center;padding-right:0}.hero-image{border-radius:24px;width:220px;height:220px}.hero-content-col{padding-left:0}.hero-bg-right,.hero-diag-svg{display:none}.skills-grid,.projects-grid{grid-template-columns:1fr 1fr}.background-grid{grid-template-columns:1fr;gap:40px}.section{padding:72px 32px}}@media (width<=640px){.hero-inner{padding:60px 24px 48px}.hero-image{width:180px;height:180px}.hero-name{letter-spacing:-1.5px}.skills-grid,.projects-grid{grid-template-columns:1fr}.section{padding:56px 24px}.portfolio-footer{padding:32px 24px}.hero-links{gap:8px}}
