:root[data-theme=light]{--bg: #ffffff;--text: #000000;--border: #000000;--text-muted: #666666}:root[data-theme=dark]{--bg: #000000;--text: #ffffff;--border: #ffffff;--text-muted: #999999}:root[data-side=tech]{--font-heading: "JetBrains Mono", "Courier New", monospace;--font-body: "Inter", -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--accent: #0066ff;--radius: 2px}:root[data-side=creative]{--font-heading: "Playfair Display", Georgia, serif;--font-body: "Lora", Georgia, serif;--font-mono: "Courier New", monospace;--accent: #8B4513;--radius: 8px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background-color:var(--bg);color:var(--text);transition:background-color .3s ease,color .3s ease;min-height:100vh}.theme-toggle{background:none;border:none;color:var(--text);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:opacity .2s ease}.theme-toggle:hover{opacity:.7}.social-links{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center}.social-link{text-decoration:none;transition:opacity .2s ease;display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:50%}:root[data-theme=dark] .social-link{background-color:#fff;color:#000}:root[data-theme=dark] .social-link svg{fill:#000}:root[data-theme=light] .social-link{background-color:transparent;color:var(--text)}:root[data-theme=light] .social-link svg{fill:var(--text)}.social-link:hover{opacity:.7}.profile-card{display:flex;flex-direction:column;align-items:center;gap:1.25rem;width:100%}.two-col-section{display:flex;flex-direction:column;gap:.5rem}.two-col-row{display:flex;align-items:baseline;gap:1.5rem}.two-col-label{font-family:var(--font-mono);font-size:.8rem;min-width:8.5rem;text-align:right;flex-shrink:0}.two-col-label--bold{font-weight:700}.two-col-label--muted{color:var(--text-muted)}.two-col-content{font-size:.8rem;color:var(--text-muted)}.two-col-link{text-decoration:none;color:var(--text);transition:opacity .2s ease}.two-col-link:hover{opacity:.6}.two-col-spacer{height:1.5rem}.placeholder-page{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:50vh;font-family:var(--font-mono)}.placeholder-page h1{font-size:1.5rem;font-weight:400}.placeholder-page p{color:var(--text-muted);font-size:.875rem}@media (max-width: 768px){.social-links{gap:1.5rem}.social-link{width:2.5rem;height:2.5rem}}[data-side=tech] .tech-layout{min-height:100vh;display:flex;flex-direction:column}[data-side=tech] .tech-header{display:flex;justify-content:center;align-items:center;gap:2rem;padding:1.5rem 2rem;font-family:var(--font-mono)}[data-side=tech] .tech-nav{display:flex;gap:2rem}[data-side=tech] .tech-nav a{color:var(--text);text-decoration:none;font-size:.875rem;letter-spacing:.05em;transition:opacity .2s ease}[data-side=tech] .tech-nav a:hover,[data-side=tech] .tech-nav a.active{opacity:.6}[data-side=tech] .tech-main{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:2rem}.tech-home{display:flex;flex-direction:column;align-items:center;gap:5rem;width:100%;max-width:800px;padding:2rem 0 4rem}.profile-picture{width:130px;height:130px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.profile-name{font-family:var(--font-heading);font-size:1.75rem;font-weight:400;letter-spacing:.05em}.micro-cv-icons{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.micro-cv-icon{width:20px;height:20px;opacity:.7;transition:opacity .2s ease;display:flex;align-items:center;justify-content:center}.micro-cv-icon--wide{width:36px}.micro-cv-icon:hover{opacity:1}.micro-cv-icon svg{width:100%;height:100%;fill:var(--text)}.cv-page{width:100%;max-width:800px;padding:2rem 0 4rem}.cv-page-title{font-family:var(--font-heading);font-size:1.75rem;font-weight:400;letter-spacing:.05em;margin-bottom:3rem}.cv-subtitle{font-family:var(--font-mono);font-size:.85rem;color:var(--text-muted);text-align:center;margin-bottom:3rem;font-style:italic}.cv-notes-toggle{display:block;margin:0 auto 3rem;background:transparent;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.08em;padding:.5rem 1.25rem;cursor:pointer;transition:color .2s ease,border-color .2s ease}.cv-notes-toggle:hover{color:var(--text)}.cv-notes-toggle[aria-pressed=true]{color:var(--text);border-color:var(--text)}.cv-role--with-notes{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.cv-notes-column{padding-left:1rem;border-left:1px solid var(--border)}.cv-note{margin-bottom:1rem;font-family:var(--font-mono);font-style:italic;font-size:.85rem;line-height:1.6;color:var(--text-muted)}.cv-note:last-child{margin-bottom:0}.cv-note-title{color:var(--text);font-weight:400}.cv-notes-mobile{display:none}.cv-notes-group{margin-bottom:2rem}.cv-notes-group-label{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}.cv-page--notes-visible{max-width:1000px}.cv-role{margin-bottom:2rem}.cv-role-header{margin-bottom:.75rem}.cv-role-title{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;letter-spacing:.02em}.cv-role-meta{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.cv-summary{font-size:.9rem;line-height:1.6;color:var(--text-muted)}.cv-section-divider{border:none;border-top:1px solid var(--border);opacity:.2;margin:2.5rem 0}.cv-education{margin-top:1rem}.cv-education-entry{margin-bottom:1rem}.cv-education-degree{font-size:.9rem;font-weight:700}.cv-education-meta{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);margin-top:.15rem}.blog-page{width:100%;max-width:800px;padding:2rem 0 4rem}.blog-page-title{font-family:var(--font-heading);font-size:1.75rem;font-weight:400;letter-spacing:.05em;margin-bottom:2.5rem}.blog-loading{font-family:var(--font-mono);font-size:.875rem;color:var(--text-muted)}.blog-list{display:flex;flex-direction:column;gap:1.5rem}.blog-card{transition:opacity .2s ease}.blog-card:hover{opacity:.8}.blog-card-link{display:block;padding:1.5rem;text-decoration:none;color:var(--text)}.blog-card-title{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;margin-bottom:.5rem}.blog-card-description{font-size:.875rem;line-height:1.6;color:var(--text-muted);margin-bottom:.75rem}.blog-card-meta{display:flex;gap:1rem;align-items:center;font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}.blog-card-source{font-style:italic}.blog-post-page{width:100%;max-width:800px;padding:2rem 0 4rem}.blog-back-link{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);text-decoration:none;transition:opacity .2s ease}.blog-back-link:hover{opacity:.6}.blog-post{margin-top:2rem}.blog-post-header{margin-bottom:2.5rem}.blog-post-title{font-family:var(--font-heading);font-size:1.75rem;font-weight:400;letter-spacing:.03em;margin-bottom:.75rem}.blog-post-meta{display:flex;gap:1rem;align-items:center;font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted)}.blog-post-content{font-size:.95rem;line-height:1.8}.blog-post-content h2{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;margin:2rem 0 1rem}.blog-post-content h3{font-family:var(--font-heading);font-size:1.05rem;font-weight:700;margin:1.5rem 0 .75rem}.blog-post-content p{margin-bottom:1rem}.blog-post-content ul,.blog-post-content ol{padding-left:1.5rem;margin-bottom:1rem}.blog-post-content li{margin-bottom:.5rem;line-height:1.6}.blog-post-content strong{font-weight:700}.blog-post-content code{font-family:var(--font-mono);font-size:.85em;background:var(--text);color:var(--bg);padding:.15em .4em;border-radius:3px}.blog-post-content pre{background:var(--text);color:var(--bg);padding:1.25rem;border-radius:var(--radius);overflow-x:auto;margin-bottom:1.5rem;font-size:.85rem;line-height:1.5}.blog-post-content pre code{background:none;color:inherit;padding:0;border-radius:0}.blog-post-content a{color:var(--accent);text-decoration:underline}.blog-post-content img{max-width:100%;height:auto;border-radius:var(--radius);margin:1rem 0}@media (max-width: 768px){[data-side=tech] .tech-header{padding:1rem 1.5rem}[data-side=tech] .tech-nav{gap:1.25rem}.profile-picture{width:120px;height:120px}.profile-name{font-size:1.35rem}.two-col-row{flex-direction:column;gap:.25rem}.two-col-label{text-align:left;min-width:auto}.cv-page--notes-visible{max-width:800px}.cv-role--with-notes{display:block}.cv-notes-column{display:none}.cv-notes-mobile{display:block}.cv-page--notes-visible .cv-role,.cv-page--notes-visible .cv-section-divider,.cv-page--notes-visible .cv-education{display:none}}
