:root{--bg: #0b1020;--bg-elevated: #141b34;--text: #f3f5ff;--muted: #b7c0db;--border: #2a355d;--primary: #7aa2ff;--primary-strong: #9db8ff;--shadow: 0 10px 30px rgba(0, 0, 0, .2)}:root[data-theme=light]{--bg: #f6f8ff;--bg-elevated: #ffffff;--text: #16203a;--muted: #52607d;--border: #dbe2f0;--primary: #345dff;--primary-strong: #2346cf;--shadow: 0 10px 25px rgba(31, 50, 96, .08)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%;font-family:Inter,system-ui,Arial,sans-serif;background:var(--bg);color:var(--text)}body{line-height:1.6}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-strong)}.container{width:min(1100px,calc(100% - 2rem));margin:0 auto}.app-shell{min-height:100vh;display:flex;flex-direction:column}.project-card{display:flex;flex-direction:column;gap:.75rem}.tag-list{row-gap:.5rem}.navbar{position:sticky;top:0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:color-mix(in oklab,var(--bg) 85%,transparent);border-bottom:1px solid var(--border);z-index:10}.nav-inner{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand{font-weight:800;font-size:1.1rem;color:var(--text)}.nav-links{display:flex;gap:1rem;flex-wrap:wrap}.nav-links a{color:var(--muted);font-weight:600}.nav-links a.active{color:var(--text)}.theme-toggle,.button{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);border-radius:999px;padding:.75rem 1rem;cursor:pointer;font:inherit}.button.primary{background:var(--primary);color:#fff;border-color:transparent}.button.secondary{background:transparent}main.container{flex:1;padding:3rem 0 4rem}.page-stack{display:grid;gap:2rem}.hero{padding:2rem 0 1rem}.hero h1,section h1{font-size:clamp(2rem,4vw,3.75rem);line-height:1.05;margin:0 0 1rem}.hero-text,.section-text{font-size:1.05rem;color:var(--muted);max-width:70ch}.section-paragraph{margin:0;color:var(--text);line-height:1.8;font-size:1rem}.eyebrow{color:var(--muted);font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:.82rem}.hero-actions,.tag-list,.contact-list{display:flex;flex-wrap:wrap;gap:.75rem}.card-links{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.clean-list{margin:0;padding-left:1.25rem}.grid{display:grid;gap:1rem}.grid.two{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.grid.three{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:22px;padding:1.25rem;box-shadow:var(--shadow)}.card h2,.card h3{margin-top:0}.card-top,.section-row{display:flex;justify-content:space-between;gap:1rem;align-items:center}.badge,.tag{display:inline-flex;align-items:center;border-radius:999px;border:1px solid var(--border);padding:.25rem .65rem;font-size:.82rem;color:var(--muted)}.inline-link{font-weight:700}.footer{border-top:1px solid var(--border);color:var(--muted);padding:1.25rem 0 2rem;text-align:center}@media(max-width:700px){.nav-inner{flex-direction:column;align-items:flex-start;padding:.75rem 0}}.contact-page{max-width:850px;margin:auto;padding:4rem 1.5rem}.contact-title{font-size:clamp(2.2rem,4vw,3.5rem);margin-bottom:.75rem}.contact-description{color:var(--muted);margin-bottom:2rem;max-width:60ch}.contact-card-list{display:grid;gap:1rem}.contact-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;text-decoration:none;background:var(--bg-elevated);border:1px solid var(--border);border-radius:18px;padding:1rem 1.1rem;box-shadow:var(--shadow);transition:transform .15s ease,border-color .15s ease}.contact-card:hover{transform:translateY(-2px);border-color:var(--primary)}.contact-card-left{display:flex;align-items:center;gap:.9rem}.contact-icon{width:24px;height:24px;flex-shrink:0;color:var(--text)}.contact-label{margin:0 0 .2rem;font-size:.85rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em}.contact-value{margin:0;color:var(--text);font-size:1rem;font-weight:600}.contact-item{display:flex;flex-direction:column;gap:.75rem}.copy-email-btn{align-self:flex-start}.copy-email-btn{border:1px solid var(--primary);background:var(--primary);color:#fff;border-radius:14px;padding:.85rem 1rem;font:inherit;font-weight:700;cursor:pointer;box-shadow:var(--shadow);transition:transform .15s ease,opacity .15s ease}.copy-email-btn:hover{transform:translateY(-1px);opacity:.95}.copy-email-btn:active{transform:translateY(0)}:root[data-theme=light] .copy-email-btn{color:#fff}.interactive-card{transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.interactive-card:hover{transform:translateY(-6px);border-color:var(--primary);box-shadow:0 18px 40px #00000038}.interactive-card:focus-visible{outline:2px solid var(--primary);outline-offset:3px}.project-header{margin-bottom:.75rem}.project-title-wrap{display:flex;align-items:flex-start;gap:.85rem}.project-title-block{flex:1}.project-preview-icon{width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--primary);flex-shrink:0}.github-link{display:inline-flex;align-items:center;gap:.55rem;text-decoration:none}.github-button{padding:.7rem .95rem;border-radius:12px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-weight:700;transition:transform .15s ease,border-color .15s ease,opacity .15s ease}.github-button:hover{transform:translateY(-1px);border-color:var(--primary);opacity:.96}.github-icon{width:18px;height:18px}.live-link{display:inline-flex;align-items:center;font-weight:700;text-decoration:none}
