:root{--bg: #0f1117;--bg-soft: #13161f;--surface: #161b26;--surface-soft: #1c2230;--text: #e6e8ee;--muted: #8b93a7;--primary: #3b82f6;--primary-2: #60a5fa;--accent: #3b82f6;--border: #2a3142;--shadow: 0 4px 24px rgba(0, 0, 0, .28)}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body{margin:0;padding:0;font-family:Inter,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-2);text-decoration:underline}.container{width:min(980px,92vw);margin:0 auto}.hero{padding:1rem 0 4.25rem;border-bottom:1px solid var(--border);position:relative}.nav{display:flex;justify-content:space-between;align-items:center;gap:1rem;position:sticky;top:.8rem;z-index:10;padding:.7rem .95rem;margin-top:.35rem;border:1px solid var(--border);border-radius:10px;background:#0f1117d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow)}.nav-actions{display:flex;align-items:center;gap:.75rem}.nav ul{display:flex;gap:1rem;list-style:none;padding:0;margin:0}.nav a{color:var(--muted);font-weight:500;font-size:.92rem}.nav a:hover{color:var(--text);text-decoration:none}.brand{letter-spacing:-.01em;font-weight:600;font-size:.95rem;color:var(--text)}.hero-content{margin-top:4rem}.hero-layout{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:1.4rem;align-items:center}.hero-copy{min-width:0}#hero-description{white-space:pre-line;color:var(--muted)}.hero-content h1{font-size:clamp(2rem,4.2vw,3rem);font-weight:700;margin:.3rem 0 1rem;letter-spacing:-.03em;line-height:1.12;text-wrap:balance;color:var(--text)}.eyebrow{color:var(--primary);margin:0;font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.75rem}.hero-actions{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:1.5rem}.hero-photo-card{justify-self:start;width:min(220px,100%);padding:0;border-radius:12px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);overflow:hidden}.hero-photo{display:block;width:100%;aspect-ratio:6 / 7;object-fit:cover;object-position:center 12%;border-radius:0;background:var(--surface-soft)}.main-grid{display:grid;gap:1.2rem;padding:2rem 0 3rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.35rem;box-shadow:var(--shadow)}.card h2,.card h3{font-weight:600;letter-spacing:-.02em}.card h2{margin-top:0;font-size:1.25rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.9rem;margin-top:1rem}.featured-grid{display:grid;grid-template-columns:1fr;gap:.9rem;margin-top:1rem}.featured-item{border:1px solid var(--border);background:var(--surface-soft);border-radius:10px;padding:1.05rem}.featured-item h3{margin:0;font-size:1.05rem;font-weight:600}.featured-title-row{display:flex;align-items:center;gap:.75rem}.featured-item p{margin-top:.7rem}.featured-detail-block{margin-top:1.5rem;padding-top:1.1rem;border-top:1px solid var(--border)}.featured-subheading{margin:0 0 .65rem;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.featured-edit-slot{color:var(--text);line-height:1.75;white-space:pre-line;font-size:.95rem}.featured-shot-slot{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.6rem}.shot-placeholder{min-height:120px;border-radius:8px;border:1px dashed var(--border);background:var(--bg-soft);color:var(--muted);font-weight:500;font-size:.88rem;display:flex;align-items:center;justify-content:center;text-align:center;padding:.65rem}.shot-placeholder-icon{min-height:84px;max-width:140px;aspect-ratio:1 / 1;justify-self:start;border-style:solid}.featured-top-icon{margin-bottom:0;flex:0 0 auto}.featured-shot-slot img{width:100%;border-radius:8px;object-fit:cover;border:1px solid var(--border)}.can-zoom{cursor:zoom-in;transition:opacity .18s ease}.can-zoom:hover{opacity:.92}body.lightbox-open{overflow:hidden}.image-lightbox{position:fixed;inset:0;z-index:999;display:grid;place-items:center;padding:2rem 1rem;background:#0a0c12eb;opacity:0;visibility:hidden;transition:opacity .22s ease,visibility .22s ease}.image-lightbox.is-open{opacity:1;visibility:visible}.lightbox-image{max-width:min(1100px,94vw);max-height:78vh;border-radius:8px;border:1px solid var(--border);box-shadow:0 16px 40px #00000073;transform:scale(.97);transition:transform .22s ease}.image-lightbox.is-open .lightbox-image{transform:scale(1)}.lightbox-caption{margin:.8rem 0 0;color:var(--muted);text-align:center;max-width:min(1100px,94vw)}.lightbox-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:1.4rem;line-height:1;cursor:pointer}.lightbox-close:hover{background:var(--surface-soft)}.project-item{border:1px solid var(--border);background:var(--surface-soft);border-radius:10px;padding:1.05rem;transition:border-color .18s ease,background .18s ease}.project-item:hover,.project-item:focus-within{border-color:color-mix(in srgb,var(--primary) 45%,var(--border) 55%);background:var(--surface)}.project-item h3{margin:0;font-size:1.02rem;font-weight:600;letter-spacing:-.01em}.project-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.9rem}.tech-list{color:var(--muted);font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;margin-top:.75rem}.muted{color:var(--muted)}.btn{border:1px solid var(--border);color:var(--text);background:transparent;padding:.55rem .9rem;border-radius:8px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;min-height:38px;font-size:.9rem;font-weight:500;transition:border-color .14s ease,background .14s ease,color .14s ease}.btn:hover{border-color:color-mix(in srgb,var(--primary) 50%,var(--border) 50%);background:#3b82f614;text-decoration:none;color:var(--text)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}.btn-primary:hover{background:var(--primary-2);border-color:var(--primary-2);color:#fff}.btn-lang{min-width:56px;padding:.5rem .7rem;font-weight:600}.skill-list{display:flex;flex-wrap:wrap;gap:.45rem;list-style:none;padding-left:0;margin-top:.55rem}.skill-list li{border:1px solid var(--border);background:var(--bg-soft);border-radius:6px;padding:.35rem .62rem;font-size:.86rem;color:var(--text)}.learning-highlight{margin:1rem 0 1.2rem;padding:1rem;border:1px solid var(--border);border-radius:10px;background:var(--bg-soft)}.learning-highlight h3{margin:0 0 .8rem;color:var(--text);font-size:1rem;font-weight:600}.learning-list{margin-top:0}.learning-list li{background:var(--surface);border-color:var(--border);color:var(--text);font-weight:500}.reveal{opacity:0;transform:translateY(16px);transition:opacity .48s ease,transform .48s ease;transition-delay:var(--reveal-delay, 0ms)}.reveal.is-visible{opacity:1;transform:translateY(0)}.footer{padding-bottom:2rem;color:var(--muted);font-size:.9rem}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.project-item{transition:none}.reveal{opacity:1;transform:none;transition:none}}@media(max-width:780px){.hero-layout{grid-template-columns:1fr}.hero-photo-card{justify-self:start;width:min(220px,72vw);order:-1}}@media(max-width:720px){.nav{flex-direction:column;align-items:flex-start;position:static}.nav-actions{width:100%;justify-content:space-between;align-items:flex-start;gap:.6rem}.nav ul{flex-wrap:wrap;margin-top:0}.hero-content{margin-top:2.1rem}.hero-content h1{font-size:clamp(1.7rem,7vw,2.5rem)}}
