:root{--radius:10px;--transition:.2s ease}:root[data-theme=light]{--bg:#fff;--bg-surface:#f7f7f8;--hover:#f3f4f6;--text:#111;--text-muted:#6b7280;--accent:#4f46e5;--accent-hover:#4338ca;--border:#e5e7eb;--danger:#dc2626;--danger-hover:#b91c1c}:root[data-theme=dark]{--bg:#18181b;--bg-surface:#27272a;--hover:#2f2f34;--text:#f4f4f5;--text-muted:#a1a1aa;--accent:#818cf8;--accent-hover:#6366f1;--border:#3f3f46;--danger:#f87171;--danger-hover:#ef4444}header{border-bottom:1px solid var(--border);background:var(--bg);z-index:1000;justify-content:space-between;align-items:center;padding:16px 32px;display:flex;position:sticky;top:0}header h1{color:var(--text);margin:0;font-size:1.5rem;font-weight:600}header a{color:var(--text);margin-left:24px;font-weight:500;text-decoration:none;position:relative}header a:after{content:"";background:var(--accent);width:0%;height:2px;transition:width .2s;position:absolute;bottom:-3px;left:0}header a:hover:after{width:100%}.lp-theme-toggle{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;padding:8px 14px;font-size:.9rem;transition:all .2s}.lp-theme-toggle:hover{background:var(--hover)}.lp-theme-dropdown{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);z-index:100;flex-direction:column;min-width:140px;margin-top:8px;padding:6px;display:flex;position:absolute;right:0}.lp-theme-option{text-align:left;cursor:pointer;color:var(--text);background:0 0;border:none;border-radius:6px;padding:8px 10px;font-size:.9rem;transition:background .2s}.lp-theme-option:hover{background:var(--hover)}.lp-theme-option.active{color:var(--accent);background:0 0;font-weight:600}@media (width<=600px){header{padding:12px 16px}header h1{font-size:1.2rem}}.particle-wrapper{background:var(--bg);width:100vw;height:100vh;position:relative;overflow:hidden}.particle-canvas{display:block}.particle-controls{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);flex-wrap:wrap;align-items:center;gap:16px;padding:10px 18px;font-family:sans-serif;font-size:13px;display:flex;position:fixed;bottom:16px;left:50%;transform:translate(-50%)}.particle-controls label{color:var(--text-muted);align-items:center;gap:8px;display:flex}.particle-controls input[type=range]{accent-color:var(--accent);cursor:pointer}.particle-controls button{border-radius:var(--radius);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:background var(--transition), color var(--transition);background:0 0;padding:4px 12px}.particle-controls button:hover{background:var(--hover);color:var(--accent-hover)}.ph-header{border-bottom:1px solid var(--border);background:var(--bg);z-index:10;justify-content:space-between;align-items:center;padding:1.25rem 2rem;font-family:system-ui,sans-serif;display:flex;position:sticky;top:0}.ph-logo{color:var(--accent);font-size:1rem;font-weight:700;text-decoration:none}.ph-nav{align-items:center;gap:2rem;display:flex}.ph-home-link{color:var(--text-muted);font-size:.85rem;text-decoration:none;transition:color .15s}.ph-home-link:hover{color:var(--text)}.ph-theme-picker{position:relative}.ph-theme-toggle{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:.35rem .75rem;font-size:.8rem;transition:color .15s,border-color .15s}.ph-theme-toggle:hover{color:var(--text);border-color:var(--text-muted)}.ph-theme-dropdown{background:var(--bg-surface);border:1px solid var(--border);z-index:20;border-radius:6px;min-width:120px;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden}.ph-theme-option{width:100%;color:var(--text-muted);text-align:left;cursor:pointer;background:0 0;border:none;padding:.5rem 1rem;font-size:.82rem;transition:background .1s,color .1s;display:block}.ph-theme-option:hover{background:var(--border);color:var(--text)}.ph-theme-option.active{color:var(--accent)}@media (width<=600px){.ph-nav{gap:1rem}.ph-home-link{display:none}}.pf-footer{border-top:1px solid var(--border);background:var(--bg);justify-content:space-between;align-items:center;padding:1.25rem 2rem;font-family:system-ui,sans-serif;display:flex}.pf-footer-copy{color:var(--text-muted);font-size:.8rem}.pf-footer-links{gap:1.5rem;display:flex}.pf-footer-link{color:var(--text-muted);font-size:.8rem;text-decoration:none;transition:color .15s}.pf-footer-link:hover{color:var(--text)}@media (width<=600px){.pf-footer{text-align:center;flex-direction:column;gap:.75rem}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}.lp-root{background:var(--bg);color:var(--text);min-height:100vh;font-family:system-ui,sans-serif;font-size:15px;line-height:1.65}.lp-nav{border-bottom:1px solid var(--border);background:var(--bg);z-index:10;justify-content:space-between;align-items:center;padding:1.25rem clamp(1.5rem,5vw,4rem);display:flex;position:sticky;top:0}.lp-logo{color:var(--accent);font-weight:700}.lp-nav-links{gap:2rem;display:flex}.lp-nav-links a{color:var(--text-muted);font-size:.85rem;text-decoration:none;transition:color .15s}.lp-nav-links a:hover{color:var(--text)}.lp-hero,.lp-section{max-width:min(1200px,92vw);margin:0 auto;padding:2.5rem clamp(1rem,3vw,2rem)}.lp-hero{padding-top:3rem;padding-bottom:2rem}.lp-alt{background:var(--bg-surface);max-width:100%}.lp-alt>*{max-width:min(1200px,92vw);margin-inline:auto;padding-inline:clamp(1rem,3vw,2rem)}.lp-section h2{letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:1.25rem;font-size:.75rem}.lp-eyebrow{color:var(--text-muted);margin-bottom:.5rem;font-size:.8rem}.lp-hero h1{letter-spacing:-.02em;margin-bottom:.75rem;font-size:clamp(2.5rem,7vw,4.5rem);font-weight:700;line-height:1.05}.lp-role{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.lp-hero-actions{flex-wrap:wrap;gap:1rem;display:flex}.lp-btn{background:var(--accent);color:var(--bg);border-radius:6px;padding:.6rem 1.25rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:background .15s;display:inline-block}.lp-btn:hover{background:var(--accent-hover)}.lp-btn-ghost{color:var(--text);border:1px solid var(--border);background:0 0}.lp-btn-ghost:hover{border-color:var(--text-muted);background:0 0}.lp-btn-sm{margin-top:.75rem;padding:.4rem .9rem;font-size:.8rem}.lp-section#about{padding-top:1.5rem;padding-bottom:1.5rem}.lp-section#about p{color:var(--text-muted);max-width:100%;line-height:1.8}.lp-section#about p+p{margin-top:1rem}.lp-skills{flex-wrap:wrap;gap:.6rem;display:flex}.lp-chip{border:1px solid var(--border);border-radius:6px;align-items:center;gap:.5rem;padding:.4rem .85rem;font-size:.82rem;display:flex}.lp-chip-tag{color:var(--text-muted);font-size:.72rem}.lp-projects{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.lp-card{border:1px solid var(--border);background:var(--bg-surface);border-radius:6px;flex-direction:column;gap:.6rem;padding:1.5rem;display:flex}.lp-card-featured{border-color:var(--accent)}.lp-card-top{justify-content:space-between;align-items:center;display:flex}.lp-badge{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-size:.7rem}.lp-card-gh{color:var(--text-muted);font-size:.78rem;text-decoration:none}.lp-card-gh:hover{color:var(--text)}.lp-card h3{font-size:1.05rem;font-weight:700}.lp-card p{color:var(--text-muted);flex:1;font-size:.85rem;line-height:1.7}.lp-stack{flex-wrap:wrap;gap:.4rem;display:flex}.lp-stack span{border:1px solid var(--border);color:var(--text-muted);border-radius:4px;padding:.2rem .5rem;font-size:.72rem}.lp-section#contact>p{color:var(--text-muted);margin-bottom:1.5rem}.lp-contact{flex-wrap:wrap;gap:1.25rem;display:flex}.lp-contact a{color:var(--text);border-bottom:1px solid var(--border);padding-bottom:1px;text-decoration:none;transition:border-color .15s}.lp-contact a:hover{border-color:var(--accent)}.lp-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);padding:2rem;font-size:.75rem}.lp-theme-picker{position:relative}.lp-theme-toggle{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:.35rem .75rem;font-size:.8rem;transition:color .15s,border-color .15s}.lp-theme-toggle:hover{color:var(--text);border-color:var(--text-muted)}.lp-theme-dropdown{background:var(--bg-surface);border:1px solid var(--border);z-index:20;border-radius:6px;min-width:120px;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden}.lp-theme-option{width:100%;color:var(--text-muted);text-align:left;cursor:pointer;background:0 0;border:none;padding:.5rem 1rem;font-size:.82rem;transition:background .1s,color .1s;display:block}.lp-theme-option:hover{background:var(--border);color:var(--text)}.lp-theme-option.active{color:var(--accent)}@media (width<=600px){.lp-nav-links{display:none}.lp-card-featured{grid-column:auto}.lp-projects{grid-template-columns:1fr}.lp-hero{padding-top:2rem}}.pyboard{background:var(--bg);min-height:100vh;color:var(--text);padding:3rem 2rem}.pyboard-content{max-width:800px;margin:0 auto}.pyboard h1{color:var(--accent);margin-bottom:1rem;font-size:2.5rem}.pyboard p{color:var(--text-muted);line-height:1.7}.pyboard-placeholder{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;margin-top:2rem;padding:1.5rem}
