:root{--bg:#0b0f17;--bg-2:#0e131d;--line:rgba(148,163,184,.12);--line-strong:rgba(148,163,184,.22);--slate:#94a3b8;--slate-dim:#64748b;--slate-light:#cbd5e1;--white:#e8edf4;--accent:#5eead4;--accent-tint:rgba(94,234,212,.1);--accent-line:rgba(94,234,212,.3);--mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;--sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{background:var(--bg);color:var(--slate);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;letter-spacing:-.01em;min-height:100vh;overflow-x:hidden}#glow{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(560px circle at var(--mx,50%) var(--my,0%),rgba(94,234,212,.07),transparent 75%);transition:background .15s ease}a{color:inherit;text-decoration:none}::selection{background:#5eead440;color:#fff}.shell{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:0 40px}@media (min-width:1100px){.shell{display:grid;grid-template-columns:42% 58%;gap:32px;min-height:100vh}}.left{padding:96px 0}@media (min-width:1100px){.left{position:sticky;top:0;height:100vh;padding:104px 0 64px;display:flex;flex-direction:column;justify-content:space-between}}.intro .kicker{font-family:var(--mono);font-size:13px;color:var(--accent);letter-spacing:.04em;margin-bottom:20px}.intro h1{font-size:clamp(38px,5.4vw,52px);font-weight:800;line-height:1.05;letter-spacing:-.03em;color:var(--white)}.intro h2{font-size:clamp(17px,2.2vw,21px);font-weight:600;color:var(--slate-light);margin-top:14px;letter-spacing:-.01em}.intro p{margin-top:20px;max-width:30ch;font-size:15.5px;color:var(--slate)}nav.side{margin-top:46px}@media (max-width:1099px){nav.side{display:none}}nav.side ul{list-style:none}nav.side a{display:inline-flex;align-items:center;gap:16px;padding:10px 0;font-family:var(--mono);font-size:12.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-dim);transition:color .2s}nav.side a .bar{width:32px;height:1.5px;background:var(--slate-dim);transition:all .2s}nav.side a:hover,nav.side a.active{color:var(--white)}nav.side a:hover .bar,nav.side a.active .bar{width:64px;background:var(--accent)}.left-foot{margin-top:48px}.socials{display:flex;gap:20px;align-items:center;margin-bottom:22px}.socials a{color:var(--slate);transition:color .2s,transform .2s}.socials a:hover{color:var(--accent);transform:translateY(-2px)}.socials svg{width:22px;height:22px;display:block}.dl{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:13px;font-weight:600;color:var(--accent);border:1px solid var(--accent-line);border-radius:8px;padding:11px 16px;transition:.2s}.dl:hover{background:var(--accent-tint);box-shadow:0 0 0 1px var(--accent-line)}.right{padding:96px 0 80px}@media (min-width:1100px){.right{padding:104px 0 96px}}section{margin-bottom:104px;scroll-margin-top:80px}section:last-of-type{margin-bottom:48px}.sec-label{display:none}@media (max-width:1099px){.sec-label{display:block;position:sticky;top:0;z-index:5;margin:0 -40px 28px;padding:14px 40px;background:#0b0f17d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--white)}}.about p{color:var(--slate);margin-bottom:18px;font-size:16px}.about p:last-child{margin-bottom:0}.about strong{color:var(--slate-light);font-weight:600}.about .hl{color:var(--accent);font-weight:600}.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin:34px 0 6px}.metrics .m{background:var(--bg-2);padding:20px 18px}.metrics .m .n{font-family:var(--mono);font-size:23px;font-weight:600;color:var(--white);letter-spacing:-.02em}.metrics .m .n span{color:var(--accent)}.metrics .m .l{font-size:12.5px;color:var(--slate-dim);margin-top:6px;line-height:1.35}.role{display:grid;grid-template-columns:140px 1fr;gap:24px;padding:22px;margin:0 -22px;border:1px solid transparent;border-radius:14px;transition:background .2s,border-color .2s,transform .2s}.role:hover{background:#94a3b80a;border-color:var(--line);transform:translateY(-2px)}.role+.role{margin-top:6px}.role .period{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--slate-dim);letter-spacing:.03em;padding-top:5px;line-height:1.5}.role h3{font-size:16.5px;font-weight:600;color:var(--white);letter-spacing:-.01em}.role h3 .co{color:var(--accent)}.role .where{font-size:13px;color:var(--slate-dim);margin-top:3px;font-family:var(--mono)}.role ul{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:9px}.role li{position:relative;padding-left:22px;font-size:14.5px;color:var(--slate)}.role li:before{content:"▹";position:absolute;left:0;top:0;color:var(--accent);font-size:13px}.role li b{color:var(--slate-light);font-weight:600}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.chips span{font-family:var(--mono);font-size:11.5px;color:var(--accent);background:var(--accent-tint);padding:5px 10px;border-radius:999px;letter-spacing:.01em}@media (max-width:560px){.role{grid-template-columns:1fr;gap:6px}.role .period{padding-top:0}}.skills{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width:560px){.skills{grid-template-columns:1fr}}.card{border:1px solid var(--line);border-radius:14px;padding:22px;background:var(--bg-2);transition:border-color .2s,transform .2s}.card:hover{border-color:var(--accent-line);transform:translateY(-2px)}.card h4{font-family:var(--mono);font-size:12.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}.card .row{display:flex;flex-wrap:wrap;gap:8px}.card .row span{font-size:13px;color:var(--slate-light);background:#94a3b812;border:1px solid var(--line);padding:5px 11px;border-radius:8px;transition:.2s}.card:hover .row span{border-color:var(--line-strong)}.contact h3{font-size:clamp(26px,4vw,34px);font-weight:800;color:var(--white);letter-spacing:-.02em;margin-bottom:16px}.contact p{font-size:16px;color:var(--slate);max-width:48ch;margin-bottom:30px}.contact-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:13.5px;font-weight:600;padding:13px 22px;border-radius:10px;transition:.2s;cursor:pointer;border:1px solid var(--accent-line)}.btn.solid{background:var(--accent);color:#04201b;border-color:var(--accent)}.btn.solid:hover{transform:translateY(-2px);box-shadow:0 10px 30px #5eead438}.btn.line{color:var(--accent)}.btn.line:hover{background:var(--accent-tint)}.btn:disabled{opacity:.6;cursor:default;transform:none;box-shadow:none}form{border-top:1px solid var(--line);padding-top:28px;max-width:460px}.fld{margin-bottom:16px}.fld label{display:block;font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--slate-dim);margin-bottom:7px}.fld input,.fld textarea{width:100%;background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:11px 13px;color:var(--white);font-family:var(--sans);font-size:14px;transition:border-color .2s}.fld input:focus,.fld textarea:focus{outline:none;border-color:var(--accent)}.fld textarea{min-height:92px;resize:vertical}.note{font-size:12px;color:var(--slate-dim);margin-top:12px}.note a{color:var(--accent)}footer{font-family:var(--mono);font-size:12.5px;color:var(--slate-dim);line-height:1.7;margin-top:64px}footer a{color:var(--slate)}footer a:hover{color:var(--accent)}.rv{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}.rv.in{opacity:1;transform:none}@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}.card .row span{display:inline-flex;align-items:center;gap:7px}.card .row .ic{width:15px;height:15px;flex:0 0 auto;filter:grayscale(1);opacity:.7;transition:filter .25s,opacity .25s}.card .row span:hover .ic,.card:hover .row .ic{filter:none;opacity:1}.card .row .ic.mono{filter:brightness(0) invert(.6)}.card .row span:hover .ic.mono,.card:hover .row .ic.mono{filter:brightness(0) invert(1)}
