:root{--bg: #07090a;--bg-2: #0c1110;--panel: #0e1413;--ink: #e9efea;--muted: #7e8e84;--muted-2: #566159;--green: #ef4444;--green-dim: #b91c1c;--red: #ff7a85;--line: rgba(239, 68, 68, .14);--line-soft: rgba(255, 255, 255, .06);--display: "Space Grotesk", system-ui, sans-serif;--body: "Inter", system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, monospace;--maxw: 1180px;--ease: cubic-bezier(.16, 1, .3, 1)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{font-family:var(--body);background:var(--bg);color:var(--ink);line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}::selection{background:var(--green);color:#1a0606}button{font-family:inherit}.bg-field{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;pointer-events:none;background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);background-size:64px 64px;-webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 0%,#000 30%,transparent 80%);mask-image:radial-gradient(ellipse 80% 70% at 50% 0%,#000 30%,transparent 80%)}.bg-vignette{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;pointer-events:none;background:radial-gradient(120% 80% at 50% -10%,rgba(239,68,68,.06),transparent 55%)}.glow{position:fixed;z-index:-1;top:0;left:0;width:560px;height:560px;border-radius:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(239,68,68,.13),transparent 62%);pointer-events:none;opacity:0;transition:opacity .5s ease}.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green);display:inline-flex;gap:.55em;align-items:center}.eyebrow:before{content:"//";color:var(--green-dim)}.section{position:relative;padding:120px 0}.section-head{margin-bottom:56px;max-width:640px}.section-head h2{font-family:var(--display);font-weight:600;font-size:clamp(1.9rem,4.5vw,3rem);letter-spacing:-.02em;line-height:1.05;margin-top:18px}.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:18px 28px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(180deg,#07090ad1,#07090a00);border-bottom:1px solid transparent;transition:border-color .3s ease,background .3s ease}.nav.scrolled{border-bottom-color:var(--line);background:#07090ae6}.nav .brand{font-family:var(--mono);font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.5em}.nav .brand .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 12px var(--green);animation:pulse 2.4s var(--ease) infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.8)}}.nav-links{display:flex;gap:28px;align-items:center}.nav-links a{font-family:var(--mono);font-size:.8rem;color:var(--muted);letter-spacing:.04em;position:relative;transition:color .25s ease}.nav-links a:hover{color:var(--ink)}.nav-links a:after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;background:var(--green);transition:width .3s var(--ease)}.nav-links a:hover:after{width:100%}.nav-cta{font-family:var(--mono);font-size:.8rem;color:var(--green)!important;border:1px solid var(--line);padding:8px 16px;border-radius:6px;transition:background .25s ease,border-color .25s ease}.nav-cta:hover{background:#ef444414;border-color:var(--green)}.nav-cta:after{display:none}.menu-btn{display:none}.hero{min-height:100vh;display:flex;align-items:center;padding-top:90px}.status{display:inline-flex;align-items:center;gap:.6em;font-family:var(--mono);font-size:.78rem;color:var(--muted);border:1px solid var(--line);border-radius:100px;padding:6px 14px}.status .live{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:pulse 2s infinite}.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(2.8rem,9vw,6.6rem);line-height:.98;letter-spacing:-.03em;margin:26px 0 22px}.hero h1 .accent{color:var(--green)}.lede{font-size:clamp(1.05rem,2.2vw,1.35rem);color:var(--muted);max-width:620px;line-height:1.55}.lede strong{color:var(--ink);font-weight:500}.hero-actions{display:flex;gap:16px;margin-top:38px;flex-wrap:wrap}.btn{font-family:var(--mono);font-size:.85rem;letter-spacing:.02em;padding:13px 24px;border-radius:8px;display:inline-flex;align-items:center;gap:.6em;cursor:pointer;border:0;transition:transform .25s var(--ease),background .25s ease,border-color .25s ease}.btn-primary{background:var(--green);color:#1a0606;font-weight:500}.btn-primary:hover{transform:translateY(-3px);background:#f56565}.btn-ghost{border:1px solid var(--line);color:var(--ink);background:transparent}.btn-ghost:hover{border-color:var(--green);background:#ef44440f;transform:translateY(-3px)}.hero-meta{display:flex;gap:40px;margin-top:64px;flex-wrap:wrap;font-family:var(--mono);font-size:.8rem;color:var(--muted-2);border-top:1px solid var(--line-soft);padding-top:28px}.hero-meta b{display:block;color:var(--ink);font-size:1.5rem;font-weight:600;font-family:var(--display);margin-bottom:2px}.decode{font-variant-ligatures:none}.about-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:start}.about-grid p{color:var(--muted);font-size:1.08rem;margin-bottom:20px;max-width:60ch}.about-grid p strong{color:var(--ink);font-weight:500}.about-card{border:1px solid var(--line);border-radius:14px;padding:26px;background:linear-gradient(180deg,var(--panel),var(--bg-2))}.about-card h3{font-family:var(--mono);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:18px}.about-card ul{list-style:none}.about-card li{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:.92rem}.about-card li:last-child{border-bottom:0}.about-card li span{color:var(--muted);font-family:var(--mono);font-size:.82rem}.stack-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.chip{border:1px solid var(--line-soft);border-radius:10px;padding:18px 16px;font-family:var(--mono);font-size:.9rem;color:var(--ink);background:var(--bg-2);transition:border-color .25s ease,transform .25s var(--ease),color .25s ease;display:flex;align-items:center;gap:.6em}.chip:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green-dim);transition:box-shadow .25s,background .25s}.chip:hover{border-color:var(--green);transform:translateY(-4px);color:#fff}.chip:hover:before{background:var(--green);box-shadow:0 0 10px var(--green)}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}.project{position:relative;border:1px solid var(--line-soft);border-radius:16px;padding:32px;background:linear-gradient(180deg,var(--panel),var(--bg-2));overflow:hidden;transition:border-color .3s ease,transform .3s var(--ease);transform-style:preserve-3d}.project:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;pointer-events:none;background:radial-gradient(400px circle at var(--mx, 50%) var(--my, 0%),rgba(239,68,68,.12),transparent 45%);opacity:0;transition:opacity .3s ease}.project:hover{border-color:var(--line)}.project:hover:after{opacity:1}.project .num{font-family:var(--mono);font-size:.78rem;color:var(--green-dim);letter-spacing:.1em}.project h3{font-family:var(--display);font-weight:600;font-size:1.55rem;letter-spacing:-.01em;margin:14px 0 12px}.project p{color:var(--muted);font-size:.98rem;margin-bottom:22px;white-space:pre-line}.tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px}.tag{font-family:var(--mono);font-size:.72rem;color:var(--muted);border:1px solid var(--line-soft);border-radius:100px;padding:4px 11px}.project .links{display:flex;gap:18px;font-family:var(--mono);font-size:.82rem}.project .links a{color:var(--green);display:inline-flex;align-items:center;gap:.4em}.project .links a:hover{text-decoration:underline}.timeline{border-left:1px solid var(--line);margin-left:8px}.t-item{position:relative;padding:0 0 44px 34px}.t-item:last-child{padding-bottom:0}.t-item:before{content:"";position:absolute;left:-5px;top:6px;width:9px;height:9px;border-radius:50%;background:var(--bg);border:2px solid var(--green)}.t-item .when{font-family:var(--mono);font-size:.78rem;color:var(--green);letter-spacing:.05em}.t-item h3{font-family:var(--display);font-weight:600;font-size:1.25rem;margin:6px 0 2px}.t-item .role{color:var(--muted);font-size:.92rem;margin-bottom:10px}.t-item p{color:var(--muted);font-size:.96rem;max-width:60ch;white-space:pre-line}.contact{text-align:center}.contact h2{font-family:var(--display);font-weight:700;letter-spacing:-.03em;line-height:1;font-size:clamp(2.4rem,8vw,5.5rem);margin:22px 0 26px}.contact h2 a{color:var(--green);border-bottom:2px solid transparent;transition:border-color .3s}.contact h2 a:hover{border-color:var(--green)}.contact p{color:var(--muted);max-width:480px;margin:0 auto 40px;font-size:1.05rem}.socials{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.socials a{font-family:var(--mono);font-size:.85rem;color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:11px 20px;transition:background .25s,border-color .25s,transform .25s var(--ease)}.socials a:hover{background:#ef444412;border-color:var(--green);transform:translateY(-3px)}footer{border-top:1px solid var(--line-soft);padding:30px 0;text-align:center;font-family:var(--mono);font-size:.78rem;color:var(--muted-2)}.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}.reveal.in{opacity:1;transform:none}.loading{min-height:100vh;display:grid;place-items:center;font-family:var(--mono);color:var(--muted);font-size:.9rem;letter-spacing:.1em}.admin{min-height:100vh;max-width:920px;margin:0 auto;padding:40px 24px 80px}.admin-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:34px;padding-bottom:20px;border-bottom:1px solid var(--line)}.admin-top h1{font-family:var(--display);font-size:1.5rem;font-weight:600}.admin-top .sub{font-family:var(--mono);font-size:.75rem;color:var(--muted)}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:30px}.tab{font-family:var(--mono);font-size:.8rem;color:var(--muted);background:var(--bg-2);border:1px solid var(--line-soft);border-radius:8px;padding:9px 16px;cursor:pointer;transition:.2s}.tab:hover{color:var(--ink);border-color:var(--line)}.tab.active{color:#1a0606;background:var(--green);border-color:var(--green)}.field{margin-bottom:18px}.field label{display:block;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}.field input,.field textarea{width:100%;background:var(--bg-2);border:1px solid var(--line-soft);border-radius:8px;color:var(--ink);font-family:var(--body);font-size:.95rem;padding:11px 13px;transition:border-color .2s}.field input:focus,.field textarea:focus{outline:none;border-color:var(--green)}.field textarea{resize:vertical;min-height:90px;line-height:1.5}.hint{font-family:var(--mono);font-size:.7rem;color:var(--muted-2);margin-top:6px}.card-block{border:1px solid var(--line-soft);border-radius:12px;padding:22px;margin-bottom:18px;background:var(--bg-2)}.card-block .row{display:flex;gap:14px}.card-block .row .field{flex:1}.admin-actions{display:flex;gap:12px;align-items:center;margin-top:10px}.toast{font-family:var(--mono);font-size:.78rem}.toast.ok{color:var(--green)}.toast.err{color:var(--red)}.btn-sm{font-family:var(--mono);font-size:.78rem;padding:9px 16px;border-radius:7px;cursor:pointer;border:1px solid var(--line);background:transparent;color:var(--ink);transition:.2s}.btn-sm:hover{border-color:var(--green)}.btn-danger{border-color:#ff5a5f66;color:var(--red)}.btn-danger:hover{background:#ff5a5f14;border-color:var(--red)}.login{min-height:100vh;display:grid;place-items:center;padding:24px}.login-box{width:100%;max-width:380px;border:1px solid var(--line);border-radius:16px;padding:34px;background:linear-gradient(180deg,var(--panel),var(--bg-2))}.login-box h1{font-family:var(--display);font-size:1.5rem;margin-bottom:6px}.login-box .sub{font-family:var(--mono);font-size:.78rem;color:var(--muted);margin-bottom:26px}@media (max-width:880px){.about-grid{grid-template-columns:1fr;gap:34px}.stack-grid{grid-template-columns:repeat(2,1fr)}.projects-grid{grid-template-columns:1fr}.section{padding:88px 0}.card-block .row{flex-direction:column;gap:0}.nav-links{position:fixed;inset:0 0 0 auto;width:min(82%,340px);flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;padding:90px 22px 28px;background:var(--bg-2);border-left:1px solid var(--line-soft);box-shadow:-24px 0 60px #00000059;transform:translate(100%);transition:transform .4s var(--ease);overflow-y:auto}.nav-links.open{transform:none}.nav-links a{font-size:1.02rem;color:var(--ink);padding:16px 8px;border-bottom:1px solid var(--line-soft);letter-spacing:.02em}.nav-links a:last-child{border-bottom:0}.nav-links a:after{display:none}.nav-links .nav-cta{margin-top:22px;padding:13px 18px;border:1px solid var(--line);border-radius:8px;text-align:center;color:var(--green)!important}.nav:has(.menu-btn.open){background:transparent;border-bottom-color:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.menu-btn{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:none;border:0;cursor:pointer;padding:0}.menu-btn span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transform-origin:center;transition:transform .3s var(--ease),opacity .2s var(--ease)}.menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.menu-btn.open span:nth-child(2){opacity:0}.menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:49;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:scrim-in .25s var(--ease)}@keyframes scrim-in{0%{opacity:0}to{opacity:1}}}.certs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}.cert{border:1px solid var(--line-soft);border-radius:12px;padding:22px;background:var(--bg-2);display:flex;flex-direction:column;gap:10px;transition:border-color .25s var(--ease),transform .25s var(--ease)}.cert:hover{border-color:var(--green);transform:translateY(-3px)}.cert-meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.cert h3{font-family:var(--display);font-size:1.05rem;font-weight:600;color:var(--ink);line-height:1.3}.cert p{color:var(--muted);font-size:.92rem;line-height:1.5;margin:0;white-space:pre-line}.cert a{margin-top:auto;font-family:var(--mono);font-size:.78rem;color:var(--green);align-self:flex-start}.cert a:hover{text-decoration:underline}.contact-form{max-width:560px;margin:48px auto 0;text-align:left;border:1px solid var(--line-soft);border-radius:14px;padding:26px;background:var(--bg-2);position:relative}.contact-form h3{font-family:var(--display);font-size:1.05rem;font-weight:600;margin-bottom:18px;color:var(--ink)}.contact-form label{display:block;margin-bottom:14px}.contact-form label>span{display:block;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}.contact-form input,.contact-form textarea{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:10px 12px;font:inherit;font-size:.92rem;transition:border-color .2s}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--green)}.contact-form textarea{resize:vertical;min-height:120px;line-height:1.5}.contact-form-row{display:flex;gap:14px}.contact-form-row label{flex:1}.contact-form-error{font-family:var(--mono);font-size:.78rem;color:var(--red);margin:6px 0 12px}.contact-form button[type=submit]{margin-top:6px}.contact-form--sent{text-align:center}.contact-form--sent h3{color:var(--green)}.contact-form--sent p{color:var(--muted);font-family:var(--mono);font-size:.85rem;margin-bottom:20px}@media (max-width:540px){.contact-form-row{flex-direction:column;gap:0}}.inquiry{border:1px solid var(--line-soft);border-radius:12px;padding:20px;margin-bottom:14px;background:var(--bg-2);transition:border-color .2s}.inquiry.unread{border-color:var(--green);box-shadow:0 0 0 1px var(--green) inset}.inquiry-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:10px}.inquiry-from{font-weight:600;color:var(--ink)}.inquiry-from a{color:var(--green);text-decoration:none;font-weight:500;font-family:var(--mono);font-size:.85rem;margin-left:6px}.inquiry-from a:hover{text-decoration:underline}.inquiry-when{font-family:var(--mono);font-size:.72rem;color:var(--muted)}.inquiry-message{white-space:pre-wrap;line-height:1.55;color:var(--ink);margin-bottom:14px}.tab .badge{display:inline-block;background:var(--green);color:#1a0606;font-family:var(--mono);font-size:.65rem;padding:2px 7px;border-radius:99px;margin-left:7px;vertical-align:middle;font-weight:600}.tab.active .badge{background:#1a0606;color:var(--green)}a:focus-visible,button:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:4px}@media (prefers-reduced-motion:reduce){*{animation:none!important;transition-duration:.01ms!important;scroll-behavior:auto}.reveal{opacity:1;transform:none}.glow{display:none}}
