:root{--bg: #0f172a;--bg-alt: #111827;--card: #1e293b;--text: #f8fafc;--muted: #94a3b8;--accent: #38bdf8;--accent-hover: #0ea5e9;--border: #334155;--shadow: 0 10px 30px rgba(2, 6, 23, .45);--shadow-lg: 0 24px 60px rgba(2, 6, 23, .55);--maxw: 1120px;--r: 16px}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}h1,h2,h3,h4{font-family:Inter,sans-serif;line-height:1.12;letter-spacing:-.02em;text-wrap:balance;font-weight:800}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}::selection{background:var(--accent);color:#04121f}[id]{scroll-margin-top:96px}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}.section{padding:clamp(72px,10vw,128px) 0;position:relative}.section-alt{background:var(--bg-alt)}.section-tight{padding:clamp(56px,7vw,92px) 0}.kicker{display:inline-flex;align-items:center;gap:10px;font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}.kicker:before{content:"";width:26px;height:2px;border-radius:2px;background:var(--accent)}.accent-text{color:var(--accent)}.nav{position:fixed;top:16px;left:0;right:0;margin:0 auto;z-index:50;width:calc(100% - 32px);max-width:var(--maxw);display:flex;align-items:center;justify-content:space-between;padding:10px 10px 10px 22px;border-radius:999px;background:#0f172ab8;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--border);transition:box-shadow .3s,background .3s}.nav.scrolled{box-shadow:var(--shadow);background:#0f172ae6}.brand{font-weight:800;font-size:1.05rem;letter-spacing:-.02em;white-space:nowrap}.brand .dot{color:var(--accent)}.nav-links{display:flex;gap:2px}.nav-links a{font-size:.9rem;font-weight:500;color:var(--muted);padding:8px 14px;border-radius:999px;transition:color .2s,background .2s}.nav-links a:hover{color:var(--text)}.nav-links a.active{color:var(--accent);background:#38bdf81a}.nav-right{display:flex;align-items:center;gap:8px}.nav-cta{font-size:.88rem;font-weight:600;color:#04121f;padding:9px 18px;border-radius:999px;background:var(--accent);transition:background .2s,transform .2s;white-space:nowrap}.nav-cta:hover{background:var(--accent-hover);transform:translateY(-1px)}.nav-burger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:50%;background:var(--card);border:1px solid var(--border)}.nav-burger span{display:block;width:18px;height:2px;border-radius:2px;background:var(--text);transition:transform .3s,opacity .2s}.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-burger.open span:nth-child(2){opacity:0}.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{position:absolute;top:calc(100% + 10px);left:0;right:0;display:flex;flex-direction:column;gap:4px;padding:12px;background:#0f172af5;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-lg)}.mobile-menu a{padding:13px 16px;border-radius:12px;color:var(--text);font-weight:500;transition:background .2s}.mobile-menu a:hover,.mobile-menu a.active{background:var(--card);color:var(--accent)}.mobile-menu .mobile-cta{background:var(--accent);color:#04121f;text-align:center;font-weight:600;margin-top:6px}@media (min-width: 861px){.mobile-menu{display:none!important}}.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:120px 0 72px;position:relative}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(60% 50% at 75% 20%,rgba(56,189,248,.1),transparent 70%)}.hero-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:56px;align-items:center;width:100%;position:relative;z-index:1}.badge{display:inline-flex;align-items:center;gap:9px;padding:7px 15px;border-radius:999px;background:var(--card);border:1px solid var(--border);font-size:.82rem;color:var(--muted);margin-bottom:24px}.badge .pulse{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 #22c55e99;animation:pulse 2.2s infinite}@keyframes pulse{0%{box-shadow:0 0 #22c55e80}70%{box-shadow:0 0 0 8px #22c55e00}to{box-shadow:0 0 #22c55e00}}.hero h1{font-size:clamp(2.6rem,6.5vw,4.6rem);font-weight:800}.hero h1 .sub{display:block;color:var(--muted);font-weight:600;font-size:clamp(1.3rem,3vw,1.9rem);margin-top:10px}.hero .lead{color:var(--muted);font-size:1.1rem;max-width:480px;margin:22px 0 32px}.hero-cta{display:flex;gap:12px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:9px;padding:12px 22px;border-radius:12px;font-weight:600;font-size:.95rem;border:1px solid transparent;transition:transform .2s,background .2s,border-color .2s,color .2s}.btn-primary{background:var(--accent);color:#04121f}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px)}.btn-ghost{background:transparent;border-color:var(--border);color:var(--text)}.btn-ghost:hover{transform:translateY(-2px);border-color:var(--accent);color:var(--accent)}.btn svg{flex-shrink:0}.hero-photo{position:relative;width:100%;max-width:400px;margin-left:auto;aspect-ratio:4 / 5;border-radius:22px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-lg);background:var(--card)}.hero-photo:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;border-radius:22px;box-shadow:inset 0 0 0 1px #38bdf826}.hero-photo:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;background:linear-gradient(to top,rgba(15,23,42,.5),transparent 45%)}.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:50% 18%;display:block}.hero-photo-fallback{width:100%;height:100%;display:grid;place-items:center;font-size:5rem;font-weight:800;color:var(--accent);background:radial-gradient(80% 70% at 50% 25%,rgba(56,189,248,.18),transparent 70%),var(--card)}.heading{margin-bottom:52px;max-width:640px}.heading h2{font-size:clamp(1.9rem,4vw,2.7rem);font-weight:800;margin:14px 0 0}.heading p{color:var(--muted);margin-top:14px;font-size:1.05rem}.about{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:start}.about-body p{color:var(--muted);margin-bottom:18px;font-size:1.05rem}.about-body strong{color:var(--text);font-weight:600}.stats{display:grid;grid-template-columns:1fr 1fr;gap:14px}.stat{padding:22px;border-radius:var(--r);background:var(--card);border:1px solid var(--border);transition:transform .25s,border-color .25s}.stat:hover{transform:translateY(-3px);border-color:var(--accent)}.stat .n{font-size:2.1rem;font-weight:800;color:var(--accent)}.stat .l{color:var(--muted);font-size:.85rem;margin-top:4px}.skill-cats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.skill-cat{padding:24px;border-radius:var(--r);background:var(--card);border:1px solid var(--border);transition:transform .3s,border-color .3s}.skill-cat:hover{transform:translateY(-4px);border-color:var(--accent)}.skill-cat-head{display:flex;align-items:center;gap:12px;margin-bottom:18px}.skill-cat-head h3{font-size:1.1rem;font-weight:700}.skill-cat .ico{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:#38bdf81f;color:var(--accent);border:1px solid rgba(56,189,248,.25);flex-shrink:0}.chips{display:flex;flex-wrap:wrap;gap:8px}.chips span{font-size:.82rem;color:var(--muted);padding:6px 12px;border-radius:8px;background:var(--bg-alt);border:1px solid var(--border)}.projects{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,340px),1fr));gap:20px;align-items:stretch}.project-card{display:flex;flex-direction:column;padding:28px;border-radius:var(--r);background:var(--card);border:1px solid var(--border);transition:transform .3s,border-color .3s,box-shadow .3s}.project-card:hover{transform:translateY(-5px);border-color:var(--accent);box-shadow:var(--shadow)}.project-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.project-tag{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:#38bdf81a;border:1px solid rgba(56,189,248,.25);padding:5px 11px;border-radius:999px}.project-card h3{font-size:1.4rem;font-weight:700;margin-bottom:6px}.project-ctx{color:var(--muted);font-size:.85rem;margin-bottom:14px}.project-desc{color:var(--muted);font-size:.97rem;margin-bottom:18px}.bullets{list-style:none;display:grid;gap:9px;margin-bottom:20px}.bullets li{position:relative;padding-left:22px;color:var(--muted);font-size:.92rem}.bullets li:before{content:"";position:absolute;left:2px;top:9px;width:6px;height:6px;border-radius:50%;background:var(--accent)}.tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.tags span{font-size:.78rem;color:var(--muted);padding:5px 11px;border-radius:8px;background:var(--bg-alt);border:1px solid var(--border)}.project-links{display:flex;gap:10px;margin-top:auto;flex-wrap:wrap}.project-links a{display:inline-flex;align-items:center;gap:7px;font-size:.88rem;font-weight:600;color:var(--text);padding:9px 15px;border-radius:10px;border:1px solid var(--border);transition:border-color .2s,color .2s,background .2s}.project-links a:hover{border-color:var(--accent);color:var(--accent)}.project-links a.primary{background:#38bdf81a;border-color:#38bdf84d;color:var(--accent)}.timeline{position:relative;display:grid;gap:20px;padding-left:10px}.timeline:before{content:"";position:absolute;left:9px;top:12px;bottom:12px;width:2px;background:linear-gradient(var(--accent),var(--border) 70%);opacity:.5}.tl-item{position:relative;padding-left:40px}.tl-dot{position:absolute;left:-9px;top:26px;width:18px;height:18px;border-radius:50%;background:var(--bg-alt);border:3px solid var(--accent);z-index:1}.tl-dot.current{background:var(--accent);box-shadow:0 0 0 5px #38bdf82e;animation:dotPulse 2.4s ease-in-out infinite}@keyframes dotPulse{0%,to{box-shadow:0 0 0 5px #38bdf82e}50%{box-shadow:0 0 0 9px #38bdf80f}}.tl-card{padding:24px;border-radius:var(--r);background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);transition:transform .3s,border-color .3s}.tl-card:hover{transform:translate(4px);border-color:var(--accent)}.tl-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:14px;flex-wrap:wrap}.tl-headtext{flex:1;min-width:0}.tl-headtext h3{font-size:1.18rem;font-weight:700;line-height:1.25}.tl-company{display:inline-flex;align-items:center;gap:10px;color:var(--accent);font-weight:600;font-size:.92rem;margin-top:2px}.tl-live{font-style:normal;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#22c55e;background:#22c55e1f;border:1px solid rgba(34,197,94,.3);padding:2px 9px;border-radius:999px}.tl-period{color:var(--muted);font-size:.85rem;font-weight:500;white-space:nowrap}.tl-meta{color:var(--muted);font-size:.85rem;margin:0 0 16px;opacity:.85}.tl-card .bullets{margin-bottom:0}@media (max-width: 620px){.tl-period{width:100%;margin-top:-4px}}.edu-card{display:flex;align-items:center;gap:22px;padding:28px;border-radius:var(--r);background:var(--card);border:1px solid var(--border);transition:transform .3s,border-color .3s}.edu-card:hover{transform:translateY(-3px);border-color:var(--accent)}.edu-icon{width:64px;height:64px;border-radius:16px;display:grid;place-items:center;background:#38bdf81f;border:1px solid rgba(56,189,248,.25);color:var(--accent);flex-shrink:0}.edu-body{flex:1}.edu-body h3{font-size:1.25rem;font-weight:700}.edu-school{color:var(--accent);font-weight:600;font-size:.95rem;margin:4px 0 8px}.edu-desc{color:var(--muted);font-size:.95rem}.edu-year{font-weight:800;font-size:1.3rem;color:var(--muted)}.cert-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,360px),1fr));gap:16px}.cert-card{display:flex;align-items:flex-start;gap:18px;padding:26px;border-radius:var(--r);background:var(--card);border:1px solid var(--border);transition:transform .3s,border-color .3s}.cert-card:hover{transform:translateY(-4px);border-color:var(--accent)}.cert-badge{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:#38bdf81f;border:1px solid rgba(56,189,248,.25);color:var(--accent);flex-shrink:0}.cert-body{flex:1}.cert-card h3{font-size:1.12rem;font-weight:700;line-height:1.3}.cert-issuer{color:var(--accent);font-weight:600;font-size:.92rem;margin-top:6px}.cert-meta{color:var(--muted);font-size:.85rem;margin:4px 0 14px}.cert-card .tags{margin-bottom:0}.contact-box{text-align:center;padding:clamp(44px,7vw,80px) 32px;border-radius:24px;background:var(--card);border:1px solid var(--border)}.contact-box h2{font-size:clamp(2rem,5vw,3.2rem);font-weight:800}.contact-box .lead{color:var(--muted);max-width:460px;margin:16px auto 30px;font-size:1.08rem}.contact-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.contact-meta{display:flex;gap:24px;justify-content:center;margin-top:28px;flex-wrap:wrap;color:var(--muted);font-size:.92rem}.contact-meta span{display:inline-flex;align-items:center;gap:8px}.contact-meta svg{color:var(--accent);flex-shrink:0}.footer{border-top:1px solid var(--border);padding:34px 0}.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;color:var(--muted);font-size:.9rem}.footer-links{display:flex;gap:18px;flex-wrap:wrap}.footer-links a{color:var(--muted);transition:color .2s}.footer-links a:hover{color:var(--accent)}.footer-copy{color:var(--muted);opacity:.7}@media (max-width: 980px){.skill-cats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 860px){.hero{min-height:auto;padding-bottom:48px}.hero-grid{grid-template-columns:1fr;gap:40px}.terminal{max-width:480px}.about,.skill-cats{grid-template-columns:1fr}.nav-links,.nav-cta{display:none}.nav-burger{display:flex}.edu-card{flex-wrap:wrap}.edu-year{width:100%}.tl-top{flex-direction:column;gap:4px}}@media (max-width: 480px){.wrap{padding:0 18px}.nav{padding:9px 9px 9px 18px}.term-body{font-size:.74rem;padding:16px 16px 20px}.contact-meta{flex-direction:column;align-items:center;gap:10px}.stats{grid-template-columns:1fr 1fr}.hero-cta{width:100%}.hero-cta .btn{flex:1 1 calc(50% - 6px);justify-content:center}.contact-actions .btn{flex:1 1 auto;justify-content:center}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important}}
