@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500&family=DM+Mono:wght@400;500&display=swap";
:root{--bg:#0c0c0d;--surface:#141415;--surface-2:#1c1c1e;--border:#ffffff14;--border-em:#ffffff26;--text:#f0ede8;--text-2:#9b9690;--text-3:#5a5752;--accent:#5b8ef0;--accent-dim:#2d5ab8;--success:#4ea87a;--danger:#d95f52;--radius-sm:6px;--radius:10px;--radius-lg:16px;--max-w:860px;--font:"DM Sans", system-ui, sans-serif;--mono:"DM Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg);color:var(--text);font-family:var(--font);flex-direction:column;min-height:100vh;font-weight:300;line-height:1.65;display:flex}.site-footer{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:auto;padding:1.25rem 1.5rem;display:flex}.site-footer-copy{font-family:var(--mono);color:var(--text-3);font-size:.75rem}.site-footer-links{align-items:center;gap:1.25rem;display:flex}.site-footer-link{font-family:var(--mono);color:var(--text-3);font-size:.75rem;text-decoration:none;transition:color .15s}.site-footer-link:hover{color:var(--text)}.nav{z-index:100;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);background:#0c0c0dd9;align-items:center;gap:2rem;height:56px;padding:0 1.5rem;display:flex;position:sticky;top:0}.nav-brand{font-family:var(--mono);color:var(--text);letter-spacing:.04em;font-size:.85rem;text-decoration:none}.nav-desktop-links{align-items:center;gap:2rem;display:flex}.nav-link{color:var(--text-2);letter-spacing:.02em;font-size:.82rem;text-decoration:none;transition:color .15s}.nav-link:hover,.nav-link.active{color:var(--text)}.nav-hamburger{cursor:pointer;color:var(--text-2);background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;transition:color .15s;display:none}.nav-hamburger:hover{color:var(--text)}.nav-mobile-menu{background:var(--bg);border-top:1px solid var(--border);z-index:99;flex-direction:column;padding:1.5rem 1.25rem;display:flex;position:fixed;inset:56px 0 0;overflow-y:auto}.nav-mobile-link{color:var(--text-2);border-bottom:1px solid var(--border);padding:.9rem 0;font-size:1rem;text-decoration:none;transition:color .15s;display:block}.nav-mobile-link:hover,.nav-mobile-link.active{color:var(--text);text-decoration:none}.user-menu{align-items:center;gap:10px;display:flex}.user-avatar{border:1.5px solid var(--border-em);object-fit:cover;border-radius:50%;width:30px;height:30px}.user-avatar-fallback{background:var(--surface-2);border:1.5px solid var(--border-em);width:30px;height:30px;font-family:var(--mono);color:var(--accent);border-radius:50%;justify-content:center;align-items:center;font-size:.7rem;display:flex}.user-name{color:var(--text-2);font-size:.8rem}.btn{font-family:var(--mono);letter-spacing:.04em;border-radius:var(--radius-sm);border:1px solid var(--border-em);color:var(--text-2);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:.38rem .85rem;font-size:.75rem;text-decoration:none;transition:all .15s;display:inline-flex}.btn:hover{color:var(--text);border-color:#ffffff40}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:500}.btn-primary:hover{color:#fff;background:#6e9ff5;border-color:#6e9ff5}.btn-ghost{border-color:#0000}.btn-ghost:hover{background:var(--surface-2);border-color:var(--border)}.page{width:100%;max-width:var(--max-w);margin:0 auto;padding:4rem 1.5rem 6rem}.page-sm{max-width:600px}h1{letter-spacing:-.02em;color:var(--text);margin-bottom:1rem;font-size:clamp(2rem,5vw,3rem);font-weight:300;line-height:1.15}h2{color:var(--text);margin-top:2.5rem;margin-bottom:.6rem;font-size:1.3rem;font-weight:400}h3{color:var(--text);margin-bottom:.3rem;font-size:1rem;font-weight:500}p{color:var(--text-2);margin-bottom:1rem;font-size:.95rem}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.hero{padding:6rem 0 4rem}.hero h1{margin-bottom:.5rem}.hero-sub{color:var(--text-2);max-width:540px;margin-bottom:2rem;font-size:1rem}.hero-actions{flex-wrap:wrap;gap:.75rem;display:flex}.hero-badge{font-family:var(--mono);letter-spacing:.06em;background:var(--surface-2);border:1px solid var(--border);color:var(--text-3);border-radius:999px;align-items:center;gap:6px;margin-bottom:1.5rem;padding:.25rem .65rem;font-size:.72rem;display:inline-flex}.hero-badge span{background:var(--success);border-radius:50%;width:6px;height:6px}.divider{border:none;border-top:1px solid var(--border);margin:3rem 0}.cv-page{max-width:820px;padding-top:2.5rem}.cv-cols{grid-template-columns:220px 1fr;display:grid}.cv-sidebar{background:var(--surface);border-right:1px solid var(--border-em);flex-direction:column;gap:2rem;padding:2.25rem 1.5rem;display:flex}.cv-sidebar-name{letter-spacing:-.01em;color:var(--text);margin:0 0 .3rem;font-size:1.3rem;font-weight:600;line-height:1.2}.cv-sidebar-title{color:var(--accent);margin:0;font-size:.82rem;font-weight:400}.cv-sidebar-section{flex-direction:column;gap:.75rem;display:flex}.cv-sidebar-label{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);border-bottom:1px solid var(--border);margin:0;padding-bottom:.4rem;font-size:.62rem}.cv-sidebar-contact{flex-direction:column;gap:.6rem;display:flex}.cv-sidebar-contact-item{flex-direction:column;gap:.1rem;display:flex}.cv-contact-meta{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);font-size:.6rem}.cv-sidebar-contact-item span,.cv-sidebar-contact-item a{font-family:var(--mono);color:var(--text-2);word-break:break-all;font-size:.72rem;text-decoration:none}.cv-sidebar-contact-item a:hover{color:var(--accent);transition:color .15s}.cv-sidebar-skills{flex-direction:column;gap:.35rem;display:flex}.cv-sidebar-skill{color:var(--text-2);padding-left:.9rem;font-size:.82rem;position:relative}.cv-sidebar-skill:before{content:"–";color:var(--text-3);position:absolute;left:0}.cv-sidebar-langs{flex-direction:column;gap:.55rem;display:flex}.cv-sidebar-lang-name{color:var(--text);font-size:.85rem;display:block}.cv-sidebar-lang-level{color:var(--text-3);font-size:.72rem;display:block}.cv-main{flex-direction:column;gap:0;padding:2.25rem 2rem;display:flex}.cv-section{margin-bottom:2.25rem}.cv-section:last-child{margin-bottom:0}.cv-section-label{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);border-bottom:1px solid var(--border);margin:0 0 1rem;padding-bottom:.4rem;font-size:.65rem}.cv-entries{padding-left:1.5rem;position:relative}.cv-entries:before{content:"";background:var(--border-em);width:1px;position:absolute;top:calc(.38em + 3px);bottom:0;left:0}.cv-entry{grid-template-columns:1fr auto;gap:.2rem 1rem;margin-bottom:1.4rem;display:grid;position:relative}.cv-entry:last-child{margin-bottom:0}.cv-entry:before{content:"";background:var(--text-3);border-radius:50%;width:6px;height:6px;position:absolute;top:.38em;left:calc(-1.5rem - 3px)}.cv-entry-title{color:var(--text);font-size:.92rem;font-weight:500}.cv-entry-sub{color:var(--text-2);font-size:.83rem}.cv-entry-date{font-family:var(--mono);color:var(--text-3);text-align:right;white-space:nowrap;font-size:.72rem}.cv-entry-desc{color:var(--text-2);grid-column:1/-1;margin-top:.2rem;font-size:.85rem;line-height:1.6}@media (max-width:640px){.cv-cols{grid-template-columns:1fr}.cv-sidebar{border-right:none;border-bottom:1px solid var(--border-em)}}.strip-day-labels{display:flex}@media (max-width:640px){.strip-day-labels{display:none}}.dots-mobile{display:flex}.dots-desktop{display:none}@media (min-width:641px){.dots-mobile{display:none}.dots-desktop{display:flex}}.cv-skills{flex-wrap:wrap;gap:.5rem;display:flex}.cv-skill{font-family:var(--mono);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);padding:.2rem .6rem;font-size:.75rem}.apps-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.app-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:.75rem;padding:1.25rem;text-decoration:none;transition:border-color .15s,background .15s;display:flex}.app-card:hover{border-color:var(--border-em);background:var(--surface-2);text-decoration:none}.app-icon{border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);width:44px;height:44px;font-family:var(--mono);color:var(--accent);justify-content:center;align-items:center;font-size:1.1rem;font-weight:500;display:flex;overflow:hidden}.app-icon img{object-fit:contain;width:100%;height:100%}.app-name{color:var(--text);font-size:.9rem;font-weight:500}.app-desc{color:var(--text-3);flex:1;font-size:.8rem;line-height:1.5}.app-launch{font-family:var(--mono);color:var(--accent);align-items:center;gap:4px;margin-top:auto;font-size:.72rem;display:inline-flex}.apps-empty{color:var(--text-3);padding:2rem 0;font-size:.9rem}.contact-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}@media (max-width:600px){.contact-grid{grid-template-columns:1fr}}.contact-links{flex-direction:column;gap:1rem;display:flex}.contact-link-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:.75rem;padding:.85rem 1rem;text-decoration:none;transition:border-color .15s;display:flex}.contact-link-item:hover{border-color:var(--border-em);text-decoration:none}.contact-link-icon{border-radius:var(--radius-sm);background:var(--surface-2);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;display:flex}.contact-link-label{color:var(--text-3);font-size:.78rem}.contact-link-value{color:var(--text);font-size:.9rem;font-weight:400}.contact-form{flex-direction:column;gap:1rem;display:flex}.field{flex-direction:column;gap:.35rem;display:flex}.field label{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);font-size:.72rem}.field input,.field textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);resize:vertical;padding:.6rem .85rem;font-size:.9rem;font-weight:300;transition:border-color .15s}.field input:focus,.field textarea:focus{border-color:var(--accent-dim);outline:none}.field textarea{min-height:120px}.auth-wrap{justify-content:center;align-items:center;min-height:calc(100vh - 56px);padding:2rem 1rem;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;width:100%;max-width:380px;padding:2.5rem}.auth-card h1{margin-bottom:.4rem;font-size:1.4rem}.auth-card p{color:var(--text-3);margin-bottom:2rem;font-size:.85rem}.protected-bar{background:var(--surface);border:1px solid var(--border);border-left:2px solid var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-family:var(--mono);color:var(--text-3);align-items:center;gap:.6rem;margin-bottom:2rem;padding:.6rem 1rem;font-size:.78rem;display:flex}.protected-bar strong{color:var(--text-2)}.page-head{margin-bottom:2.5rem}.page-head h1{margin-bottom:.3rem;font-size:1.8rem}.page-head p{color:var(--text-3);margin:0;font-size:.88rem}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;display:grid}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:.85rem;padding:1.5rem;transition:border-color .15s;display:flex}.project-card:hover{border-color:var(--border-em)}.project-card-header{justify-content:space-between;align-items:baseline;gap:1rem;display:flex}.project-name{color:var(--text);margin:0;font-size:1.05rem;font-weight:500}.project-status{font-family:var(--mono);letter-spacing:.04em;white-space:nowrap;font-size:.72rem}.project-desc{color:var(--text-2);flex:1;margin:0;font-size:.9rem;line-height:1.65}.project-footer{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;margin-top:auto;display:flex}.project-tags{flex-wrap:wrap;gap:.4rem;display:flex}.project-link{font-family:var(--mono);color:var(--accent);white-space:nowrap;flex-shrink:0;font-size:.75rem;text-decoration:none}.project-link:hover{text-decoration:underline}.project-specs{flex-direction:column;gap:0;display:flex}.project-spec-row{border-bottom:1px solid var(--border);align-items:baseline;gap:1rem;padding:.6rem 0;display:flex}.project-spec-row:last-child{border-bottom:none}.project-spec-label{font-family:var(--mono);color:var(--text-3);letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;width:120px;font-size:.75rem;overflow:hidden}.project-spec-value{color:var(--text);flex:1;font-size:.9rem}.project-spec-link{color:var(--accent);text-decoration:none}.project-spec-link:hover{text-decoration:underline}.project-image-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;display:grid}.project-image-thumb{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;aspect-ratio:4/3;padding:0;transition:border-color .15s;overflow:hidden}.project-image-thumb:hover{border-color:var(--border-em)}.project-image-thumb img{object-fit:cover;width:100%;height:100%;display:block}.project-lightbox{z-index:200;background:#000000e0;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.project-lightbox-content{flex-direction:column;align-items:center;gap:.75rem;display:flex}.project-lightbox-content img{object-fit:contain;border-radius:var(--radius);max-width:100%;max-height:80vh}.project-lightbox-caption{color:var(--text-3);text-align:center;max-width:480px;font-size:.82rem}.project-lightbox-close{color:var(--text-2);cursor:pointer;background:0 0;border:none;font-size:1.4rem;line-height:1;position:absolute;top:1rem;right:1.25rem}.project-lightbox-close:hover{color:var(--text)}.project-lightbox-prev,.project-lightbox-next{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;padding:.25rem .6rem;font-size:1.75rem;line-height:1;transition:background .15s;position:absolute;top:50%;transform:translateY(-50%)}.project-lightbox-prev:hover,.project-lightbox-next:hover{background:var(--surface)}.project-lightbox-prev{left:1rem}.project-lightbox-next{right:1rem}@media (max-width:640px){.nav{gap:0;padding:0 1rem}.nav-desktop-links{display:none}.nav-desktop-only{display:none!important}.nav-hamburger{min-width:44px;min-height:44px;padding:.75rem;display:flex}.nav-mobile-link{align-items:center;min-height:44px;padding:1rem 0;display:flex}.user-name{display:none}.hero{padding:2.5rem 0 2rem}.page{padding:2rem 1rem 4rem}.cv-entry{grid-template-columns:1fr;gap:.15rem}.cv-entry-date{text-align:left}.auth-card{padding:2rem 1.25rem}.contact-grid{gap:2.5rem}.project-lightbox-close{padding:.75rem 1rem;font-size:1.6rem}.project-lightbox-prev,.project-lightbox-next{min-width:44px;min-height:44px;padding:.75rem;font-size:2rem}}
