@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Outfit:wght@600;700;800&display=swap";*,:before,:after{box-sizing:border-box}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;--theme-red:#ef4343;--theme-yellow:#facc14;--theme-green:#21c45d;--theme-black:#22262a;--theme-deep-black:#0b0d0e;--font-heading:"Outfit", sans-serif;--font-body:"Inter", sans-serif;--bg:#f9fafb;--text:#22262a;--muted-text:#6a737c;--surface:#fffc;--surface-solid:#fff;--surface-muted:#f4f5f6;--border:#2e33381a;--border-strong:#2e333833;--header-bg:var(--theme-deep-black);--header-text:#f9fafb;--link:#264d73;--focus:var(--theme-yellow);--accent:var(--theme-green);--nav-selected:var(--theme-green);--frm-bg:var(--theme-green);--frm-btn:var(--theme-deep-black);--frm-btn-hover:#1a9948;--glass-bg:#ffffffb3;--glass-border:#fff3;--glass-blur:blur(12px);--shadow-sm:0 2px 4px #0000000d;--shadow-md:0 8px 30px #0000001a}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}:root[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}:root[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#090a0b;--text:#e3e6e8;--muted-text:#a1a6aa;--surface:#1c1f22b3;--surface-solid:#1c1f22;--surface-muted:#292e32;--border:#ffffff1a;--border-strong:#fff3;--header-bg:#121417;--header-text:#f1f2f4;--link:#8cbff2;--glass-bg:#1c1f2299;--glass-border:#ffffff0d;--frm-btn:white}html,body,#root{height:100%}body,#root,.app-container{background-color:var(--bg);min-height:100vh;color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;flex-direction:column;margin:0;padding:0;line-height:1.6;display:flex}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2}main{flex:1}a{color:var(--link)}a:focus-visible{outline:3px solid var(--focus);outline-offset:3px}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.card-media{background-color:var(--theme-black);width:100%;padding-top:56.25%;position:relative;overflow:hidden}.card-media-img{object-fit:cover;width:100%;height:100%;transition:transform .5s;position:absolute;top:0;left:0}.card:hover .card-media-img{transform:scale(1.05)}.card-media-overlay{opacity:0;background-color:#171717cc;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.card:hover .card-media-overlay{opacity:1}.card-subtitle{color:var(--muted-text);margin:.25rem 0 0;font-size:.9rem}.card-body,.card-content{flex:1;padding:1rem 1.25rem}.card-footer{border-top:1px solid var(--border);background:var(--surface);color:var(--text);flex-direction:row;align-items:center;gap:.75rem;padding:.75rem 1.25rem;display:flex}.badge{background-color:color-mix(in srgb, var(--theme-green) 15%, transparent);color:var(--theme-green);border:1px solid var(--theme-green);border-radius:9999px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.tag{background-color:var(--surface-muted);color:var(--muted-text);border:1px solid var(--border);border-radius:.25rem;padding:.2rem .55rem;font-size:.78rem;display:inline-block}.badge-row,.tag-row{flex-wrap:wrap;gap:.4rem;margin-top:.75rem;display:flex}.btn{cursor:pointer;font-weight:600;font:inherit;border-radius:.5rem;width:fit-content;padding:.45rem 1rem;transition:all .2s}.btn-outline{border:1px solid var(--border);color:var(--text);background-color:#0000}.btn-outline:hover{background-color:var(--surface-muted)}.toggle-btn{border-color:var(--theme-green);color:var(--theme-green)}.toggle-btn:hover{background-color:color-mix(in srgb, var(--theme-green) 10%, transparent)}.like-btn.liked{color:var(--theme-red);border-color:var(--theme-red);background-color:color-mix(in srgb, var(--theme-red) 10%, transparent)}.project-card{height:100%}.project-desc{color:var(--muted-text);max-height:4.8em;line-height:1.6;transition:max-height .4s ease-in-out;overflow:hidden}.project-desc.expanded{max-height:1000px}.resume-card .card-body{font-size:.9rem}.resume-date{color:var(--muted-text);margin:0 0 .5rem;font-size:.82rem}.resume-summary{max-height:0;transition:max-height .35s;overflow:hidden}.resume-summary.expanded{max-height:600px}.resume-bullets{margin:.5rem 0 0;padding-left:1.2rem}.resume-section-label{color:var(--theme-green);border-bottom:1px solid var(--border);margin:2rem 0 .75rem;padding-bottom:.25rem;font-size:1.1rem}.skills-card,.resume-section-card{margin-bottom:1.5rem}.about-card .card-body.clamped{max-height:7rem;overflow:hidden;-webkit-mask-image:linear-gradient(#000 55%,#0000 100%);mask-image:linear-gradient(#000 55%,#0000 100%)}:root[data-theme=light] .badge{color:var(--theme-black)}.skip-link{z-index:999;background:var(--header-bg);color:var(--header-text);border-radius:.25rem;padding:.5rem 1rem;font-weight:600;text-decoration:none;position:absolute;left:-9999px}.skip-link:focus{outline:3px solid var(--focus);outline-offset:2px;top:.5rem;left:.5rem}header{background:linear-gradient(135deg, var(--header-bg) 0%, #171a1c 100%);color:var(--header-text);box-shadow:var(--shadow-sm);z-index:100;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);padding:1.5rem 2rem;position:sticky;top:0}footer{background:var(--header-bg);color:var(--header-text);text-align:center;flex-direction:column;align-items:center;gap:.75rem;margin-top:1rem;padding:1.5rem 1rem;display:flex}.footer-nav ul{justify-content:center;gap:1.5rem;margin:0;padding:0;list-style:none;display:flex}.footer-nav a{color:var(--header-text);opacity:.8;font-weight:500;text-decoration:none;transition:all .3s}.footer-nav a:hover{color:var(--theme-yellow);opacity:1;transform:translateY(-2px)}.social-media{border-top:1px solid var(--border-strong);width:100%;max-width:400px;padding-top:1rem}.page-title{background:linear-gradient(90deg, var(--theme-green), var(--theme-yellow), var(--theme-green));color:#0000;letter-spacing:-.02em;background-size:200%;-webkit-background-clip:text;background-clip:text;width:fit-content;font-weight:800;animation:8s linear infinite shine}@keyframes shine{to{background-position:200%}}h2.section-title{margin-bottom:2rem;font-size:2rem}h2.section-title:after{content:"";background:linear-gradient(90deg, var(--theme-green), var(--theme-yellow));border-radius:2px;width:60px;height:4px;margin-top:.75rem;display:block}nav ul{align-items:center;gap:1.5rem;margin:0;padding:0;list-style:none;display:flex}nav a{color:var(--header-text);opacity:.7;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .3s;position:relative}nav a:hover{opacity:1}nav a.active{opacity:1;color:var(--theme-yellow)}nav a.active:after{content:"";background-color:var(--theme-yellow);border-radius:2px;width:100%;height:2px;position:absolute;bottom:-4px;left:0}.page-section{max-width:1000px;margin:0 auto;padding:2rem 1.5rem}.cards-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;padding:1rem 0;display:grid}@media (width<=640px){.cards-grid{grid-template-columns:1fr}}.card{background:var(--surface);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--shadow-sm);border-radius:1.25rem;flex-direction:column;transition:all .4s cubic-bezier(.165,.84,.44,1);display:flex;overflow:hidden;transform:scale(.97)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--theme-green);z-index:10;transform:translateY(-5px)scale(1)}.card-header{background:var(--surface-muted);color:var(--text);border-bottom:1px solid var(--border);padding:1rem 1.25rem}.card-title{color:var(--text);margin:0;font-size:1.25rem}.view-link{color:var(--theme-yellow);border:2px solid var(--theme-yellow);border-radius:9999px;padding:.5rem 1rem;font-weight:600;text-decoration:none;transition:all .2s}.view-link:hover{background-color:var(--theme-yellow);color:var(--theme-black)}.home-hero{align-items:center;gap:2rem;display:flex}.home-hero .profile-img-container{flex-shrink:0}.profile-img{border-radius:.5rem;width:100%;max-width:280px;height:auto;margin:0;display:block}@media (width<=768px){.home-hero{text-align:center;flex-direction:column;align-items:center}.profile-img{max-width:350px;margin:0 auto 1rem}}.btn-primary,.btn-secondary,.btn-danger{cursor:pointer;font-weight:600;font-family:var(--font-heading);border:none;border-radius:999px;padding:.75rem 1.5rem;font-size:.9rem;transition:all .3s}.btn-primary{background:linear-gradient(135deg, var(--theme-green) 0%, #1a9948 100%);color:#fff;box-shadow:0 4px 12px #22c55e4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #22c55e66}.btn-secondary{background:var(--surface-muted);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-danger{background:var(--theme-red);color:#fff}.btn-danger:hover{opacity:.9;transform:scale(1.02)}.glass-form{background:var(--surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);border-radius:1.5rem;max-width:600px;margin:0 auto;padding:2.5rem}.form-field input,.form-field textarea{background:var(--bg);border:1px solid var(--border);border-radius:.75rem;width:100%;padding:.8rem 1rem;transition:all .3s}.form-field input:focus,.form-field textarea:focus{border-color:var(--theme-green);outline:none;box-shadow:0 0 0 4px #22c55e1a}.form-actions{gap:1rem;margin-top:2rem;display:flex}@media (width<=768px){header{padding:1rem}nav ul{flex-wrap:wrap;justify-content:center;gap:.75rem}.footer-nav ul{flex-direction:column;align-items:center;gap:1rem}}header{background:linear-gradient(to bottom, var(--header-bg) 65%, var(--bg) 100%);padding:1.5rem 2rem .75rem}.header-title-row{justify-content:space-between;align-items:center;display:flex}.theme-toggle{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;font-size:1.25rem;transition:transform .2s;display:flex}.theme-toggle:hover{transform:scale(1.1)}.api-card{color:var(--header-text);background-color:color-mix(in srgb, var(--surface) 10%, transparent);border:1px solid color-mix(in srgb, var(--header-text) 20%, transparent);border-radius:.5rem;flex-wrap:wrap;align-items:center;gap:.6rem;width:fit-content;max-width:100%;margin-top:.5rem;padding:.45rem .85rem;font-size:.85rem;display:flex}.api-card--quiet{opacity:.45;font-style:italic}.ac__sep{opacity:.5;-webkit-user-select:none;user-select:none}.ac__sep--divider{opacity:.3;margin:0 .2rem;font-size:.9rem}.ac__location strong{font-weight:600}.ac__hn{align-items:center;gap:.3rem;margin-left:auto;display:flex}.ac__hn-label{opacity:.75;white-space:nowrap;font-weight:600}.ac__hn-link{color:var(--theme-yellow);font-weight:500;text-decoration:none}.ac__hn-link:hover{text-decoration:underline}:root[data-theme=light] .api-card{color:var(--theme-black);border-color:color-mix(in srgb, var(--theme-black) 20%, transparent);background-color:#ffffffd9}:root[data-theme=light] .ac__hn-link{color:var(--theme-black)}:root[data-theme=dark] .api-card{color:var(--header-text)}.tool-badge{background-color:color-mix(in srgb, var(--tool-color,var(--theme-green)) 12%, var(--surface));border-color:color-mix(in srgb, var(--tool-color,var(--theme-green)) 35%, transparent);color:var(--text);align-items:center;gap:.3rem;display:inline-flex}.tool-badge__icon{object-fit:contain;width:13px;height:13px}.status-badge{border-radius:999px;margin-bottom:.5rem;padding:.15rem .55rem;font-size:.75rem;font-weight:600;display:inline-block}.status-badge--wip{color:#856404;background-color:#fff3cd;border:1px solid #ffc107}.resume-col-stack{flex-direction:column;gap:2rem;display:flex}.email-link{color:var(--theme-green);text-underline-offset:4px;font-weight:600;text-decoration:underline;transition:opacity .2s}.email-link:hover{opacity:.8}.copy-button{background:var(--surface-muted);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:.75rem;align-items:center;gap:.5rem;padding:.4rem .8rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex}.copy-button:hover{background:var(--border);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.copy-button:active{transform:translateY(0)}.copy-button.success{background:var(--theme-green);color:#fff;border-color:var(--theme-green);animation:.5s ease-out pulse}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.contact-form{max-width:600px}.contact-form .form-field{flex-direction:column;margin-bottom:1rem;display:flex}.contact-form label{margin-bottom:.25rem;font-weight:600}.contact-form input,.contact-form textarea{border:1px solid var(--border);background-color:var(--surface);color:var(--text);font:inherit;border-radius:.25rem;padding:.5rem;transition:border-color .2s}.contact-form input:focus,.contact-form textarea:focus{border-color:var(--theme-green);box-shadow:0 0 0 2px color-mix(in srgb, var(--theme-green) 25%, transparent);outline:none}:is(.contact-form input:has(+.error-message),.contact-form textarea:has(+.error-message)){border-color:var(--theme-red)}.contact-form textarea{resize:vertical;min-height:120px}.contact-form__submit{background-color:var(--frm-bg);color:var(--frm-btn);cursor:pointer;border:none;border-radius:999px;padding:.6rem 1.25rem;font-weight:600;transition:background-color .2s}.contact-form__submit:hover{background-color:var(--frm-btn-hover)}.contact-form__submit:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.5)}.error-message{color:var(--theme-red);margin-top:.25rem;font-size:.875rem}.success-banner{color:#0f5132;background-color:#d1e7dd;border:1px solid #badbcc;border-radius:.25rem;margin-bottom:1rem;padding:.625rem .875rem}
