*,:before,:after{box-sizing:border-box}html,body{min-height:100vh;margin:0;padding:0}:root{--bg:#fdf6e3;--bg-card:#fff;--bg-card-hover:#fff8ee;--border:#e8d5b0;--text:#1a2744;--text-muted:#6b7280;--accent:#3468c0;--accent-dim:#3468c01a;--accent-hover:#2555a8;--orange:#ff9843;--orange-dim:#ff984321;--cream:#ffdd95;--periwinkle:#86a7fc;--radius:10px;--max-w:1100px;--nav-h:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--bg);color:var(--text);min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;display:block}#root{text-align:left;max-width:100%;padding:0}a{color:inherit;text-decoration:none}.nav{height:var(--nav-h);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:100;background:#fdf6e3e0;justify-content:space-between;align-items:center;padding:0 2rem;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{color:var(--accent);letter-spacing:-.02em;font-size:1.2rem;font-weight:700}.nav-links{color:var(--text-muted);align-items:center;gap:2rem;font-size:.9rem;display:flex}.nav-links a:hover{color:var(--text);transition:color .2s}.nav-linkedin{font-weight:500;color:var(--accent)!important}.app{flex-direction:column;min-height:100vh;display:flex}main{padding-top:var(--nav-h);flex:1}.hero{min-height:calc(100vh - var(--nav-h));max-width:var(--max-w);flex-direction:column;justify-content:center;align-items:flex-start;margin:0 auto;padding:6rem 2rem 4rem;display:flex;position:relative}.hero-greeting{color:var(--accent);letter-spacing:.05em;margin-bottom:.5rem;font-size:1.1rem;font-weight:500}.hero-cursor{background:var(--accent);vertical-align:text-bottom;width:2px;height:.85em;margin-left:2px;animation:.75s step-end infinite cursor-blink;display:inline-block}@keyframes cursor-blink{50%{opacity:0}}.hero-name{letter-spacing:-.03em;color:var(--text);margin-bottom:.75rem;font-size:clamp(2.8rem,7vw,5rem);font-weight:800;line-height:1.05}.hero-tagline{color:var(--text-muted);margin-bottom:1.5rem;font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:400}.hero-bio{max-width:560px;color:var(--text-muted);margin-bottom:2.5rem;font-size:1rem;line-height:1.75}.hero-cta{flex-wrap:wrap;gap:1rem;display:flex}.hero-scroll-hint{color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;align-items:center;gap:.75rem;font-size:.75rem;display:flex;position:absolute;bottom:2.5rem;left:2rem}.scroll-line{background:var(--text-muted);width:40px;height:1px}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:.4rem;padding:.65rem 1.4rem;font-size:.9rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-secondary{color:var(--text);border-color:var(--border);background:0 0}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-outline{color:var(--accent);border-color:var(--accent);background:0 0;padding:.5rem 1.1rem;font-size:.85rem}.btn-outline:hover{background:var(--accent-dim)}.section{max-width:var(--max-w);border-top:1px solid var(--border);margin:0 auto;padding:6rem 2rem}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:3rem;display:flex}.section-title{letter-spacing:-.02em;color:var(--text);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700}.resume-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.resume-heading{text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:1rem;font-size:.8rem;font-weight:600}.resume-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;padding:1.25rem 1.5rem;transition:border-color .2s}.resume-card:hover{border-color:var(--accent)}.resume-card-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem;display:flex}.resume-role{color:var(--text);font-size:.95rem;font-weight:600}.resume-minor{color:var(--text);font-size:.85rem;font-weight:300}.resume-company{color:var(--text-muted);margin-top:.15rem;font-size:.85rem}.resume-period{color:var(--text-muted);white-space:nowrap;padding-top:.1rem;font-size:.78rem}.resume-bullets{flex-direction:column;gap:.4rem;list-style:none;display:flex}.resume-bullets li{color:var(--text-muted);padding-left:1rem;font-size:.85rem;position:relative}.resume-bullets li:before{content:"›";color:var(--orange);position:absolute;left:0}.skills-group{margin-bottom:1rem}.skills-category{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.45rem;font-size:.75rem;font-weight:600}.skills-grid{flex-wrap:wrap;gap:.5rem;display:flex}.skill-tag{color:#2b4fa8;background:#86a7fc26;border:1px solid #ff984359;border-radius:6px;padding:.3rem .75rem;font-size:.8rem;font-weight:500}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;justify-content:space-between;gap:1.25rem;padding:1.5rem;transition:border-color .2s,transform .2s;display:flex}.project-card:hover{border-color:var(--accent);transform:translateY(-3px)}.project-title{color:var(--text);margin-bottom:.5rem;font-size:1rem;font-weight:600}.project-desc{color:var(--text-muted);font-size:.875rem;line-height:1.65}.project-tech{flex-wrap:wrap;gap:.4rem;margin-top:.75rem;display:flex}.tech-tag{color:#2b4fa8;background:#86a7fc26;border-radius:4px;padding:.2rem .55rem;font-size:.75rem;font-weight:500}.project-links{gap:1rem;display:flex}.project-link{color:var(--text-muted);font-size:.82rem;font-weight:500;transition:color .2s}.project-link:hover{color:var(--accent)}.chat-window{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;height:480px;display:flex;overflow:hidden}.chat-messages{scroll-behavior:smooth;flex-direction:column;flex:1;gap:1rem;padding:1.5rem;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-track{background:0 0}.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.chat-row{align-items:flex-end;gap:.6rem;display:flex}.chat-row--user{flex-direction:row-reverse}.chat-avatar{background:var(--accent-dim);border:1px solid var(--border);width:32px;height:32px;color:var(--accent);letter-spacing:.03em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.6rem;font-weight:700;display:flex}.chat-bubble{border-radius:16px;max-width:72%;padding:.7rem 1rem;font-size:.9rem;line-height:1.6}.chat-bubble--bot{background:var(--bg-card-hover);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}.chat-bubble--user{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.chat-input-bar{border-top:1px solid var(--border);background:var(--bg-card);align-items:center;gap:.5rem;padding:.85rem 1rem;display:flex}.chat-input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:24px;outline:none;flex:1;padding:.6rem 1.1rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.chat-input::placeholder{color:var(--text-muted)}.chat-input:focus{border-color:var(--accent)}.chat-send-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:background .2s,opacity .2s;display:flex}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.4;cursor:default}.contact-section{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;padding-bottom:8rem;display:flex}.contact-sub{max-width:480px;color:var(--text-muted);font-size:.95rem;line-height:1.7}.contact-links{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.footer{text-align:center;border-top:1px solid var(--border);color:var(--text-muted);padding:1.5rem 2rem;font-size:.8rem}@media (width<=768px){.nav-links{gap:1.25rem;font-size:.85rem}.hero{padding:4rem 1.5rem 3rem}.hero-scroll-hint{display:none}.section{padding:4rem 1.5rem}.section-header{margin-bottom:2rem}.resume-grid{grid-template-columns:1fr}.resume-card-header{flex-direction:column;gap:.2rem}.resume-period{align-self:flex-start}.chat-window{height:400px}}@media (width<=480px){.nav{padding:0 1rem}.nav-links{gap:.85rem}.nav-links a:not(.nav-linkedin):not(:last-child){display:none}.hero{text-align:center;align-items:center;padding:3rem 1rem 2rem}.hero-bio{max-width:100%}.hero-cta{flex-direction:column;width:100%}.hero-cta .btn{justify-content:center;width:100%}.section{padding:3rem 1rem}.section-header{flex-direction:column;align-items:flex-start;gap:.75rem}.projects-grid{grid-template-columns:1fr}.chat-window{height:360px}.chat-bubble{max-width:85%}.contact-links{flex-direction:column;align-items:center;width:100%}.contact-links .btn{justify-content:center;width:100%}}
