@import"https://fonts.googleapis.com/css2?family=Newsreader:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Inter:wght@400;500;600&display=swap";:root{--bg: #ffffff;--bg-alt: #f5f5f5;--text: #353535;--text-muted: #284b63;--text-light: #d9d9d9;--accent: #3c6e71;--accent-dark: #284b63;--accent-light: #d9d9d9;--border: #d9d9d9;--border-dark: #3c6e71}[data-theme=dark]{--bg: #1e1e1e;--bg-alt: #2a2a2a;--text: #e8e8e8;--text-muted: #b0b0b0;--text-light: #888888;--accent: #5ab3b8;--accent-dark: #7ac5c9;--accent-light: #3d7a7f;--border: #404040;--border-dark: #5a5a5a}*{margin:0;padding:0;box-sizing:border-box}html{background:var(--bg);scroll-behavior:smooth}body{font-family:Newsreader,serif;background:var(--bg);color:var(--text);line-height:1.7;font-size:18px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background .3s,color .3s}#root{width:100%;min-height:100vh}.page-container{min-height:100vh;width:100%;background:var(--bg);color:var(--text);font-family:Newsreader,serif;position:relative;overflow-x:hidden}.nav{position:fixed;top:0;left:0;right:0;padding:24px 0;background:var(--bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;border-bottom:1px solid transparent;transition:border-color .3s}.nav-inner{max-width:1000px;margin:0 auto;padding:0 16px;display:flex;justify-content:space-between;align-items:center}.nav.scrolled{border-color:var(--border)}.nav-logo{font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);text-decoration:none;transition:color .3s}.nav-logo:hover{color:var(--accent-dark)}.nav-links{display:flex;gap:36px}.nav-link{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-muted);text-decoration:none;transition:color .3s;position:relative}.nav-link:hover,.nav-link.active{color:var(--accent-dark)}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--accent);transition:width .3s}.nav-link:hover:after,.nav-link.active:after{width:100%}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:101}.hamburger span{width:24px;height:2px;background:var(--text-muted);transition:all .3s ease;border-radius:2px}.hamburger span.active:nth-child(1){transform:rotate(45deg) translate(7px,7px)}.hamburger span.active:nth-child(2){opacity:0}.hamburger span.active:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}.container{max-width:1000px;margin:0 auto;padding:0 16px}.hero-section{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:120px 0 80px;position:relative}.hero-content{max-width:1000px;margin:0 auto;padding:0 16px}.wave{font-size:3.5rem;margin-bottom:32px;display:inline-block;animation:wave 2.5s ease-in-out infinite;transform-origin:70% 70%}@keyframes wave{0%,to{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}60%{transform:rotate(0)}}.greeting{font-size:3rem;font-weight:400;line-height:1.25;margin-bottom:40px}.greeting .name{font-weight:400;color:var(--accent-dark)}.intro-text{font-size:1.4rem;color:var(--text);margin-bottom:28px;line-height:1.8}.intro-text em{font-style:italic;color:var(--accent-dark)}.intro-text a{color:var(--accent-dark);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;transition:all .3s}.intro-text a:hover{color:var(--text);text-decoration-color:var(--accent)}.divider{width:60px;height:2px;background:var(--accent);margin:50px 0}.divider.center{margin:50px auto}.quick-stats{display:flex;gap:50px;margin-bottom:50px}.stat{text-align:center}.stat-value{font-size:2.5rem;font-weight:500;color:var(--accent-dark);line-height:1;margin-bottom:8px}.stat-label{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px}.cta-group{display:flex;gap:16px;margin-bottom:60px}.btn{font-family:Inter,sans-serif;padding:16px 32px;font-size:.9rem;text-decoration:none;border-radius:6px;transition:all .3s;display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 10px 30px #d4a57440}.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--border-dark)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent-dark)}.social-strip{display:flex;gap:24px}.social-link{width:44px;height:44px;background:var(--bg);border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);text-decoration:none;transition:all .3s}.social-link:hover{background:var(--bg-alt);border-color:var(--accent);color:var(--accent-dark);transform:translateY(-2px);box-shadow:0 8px 20px #00000014}.social-link svg{width:20px;height:20px;flex-shrink:0}.social-link span{display:none}.scroll-indicator{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-light);letter-spacing:2px;text-transform:uppercase;animation:bounce 2s ease-in-out infinite}.scroll-indicator:after{content:"↓";font-size:1rem}@keyframes bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(8px)}}.section{padding:120px 0}.section.alt{background:var(--bg-alt)}.section-content{max-width:1000px;margin:0 auto;padding:0 16px}.section-label{font-family:Inter,sans-serif;font-size:.7rem;text-transform:uppercase;letter-spacing:3px;color:var(--accent-dark);margin-bottom:20px}.section-title{font-size:2.5rem;font-weight:400;margin-bottom:32px;line-height:1.2}.section-title em{font-style:italic;color:var(--accent-dark)}.section-intro{font-size:1.2rem;color:var(--text-muted);max-width:600px;line-height:1.8;margin-bottom:60px}.about-section{padding:120px 0;background:var(--bg);overflow:visible}.about-content{display:grid;grid-template-columns:320px 1fr;gap:60px;align-items:start}.about-image{position:relative}.about-photo{position:relative;width:100%;overflow:visible}.about-photo img{width:160%;max-width:none;height:auto;object-fit:contain;position:relative;z-index:2;margin-left:-30%}.about-location{margin-top:40px;font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-muted);display:flex;align-items:center;gap:8px}.about-text p{font-size:1.15rem;margin-bottom:24px;line-height:1.9}.about-text p:last-child{margin-bottom:0}.about-text em{font-style:italic;color:var(--accent-dark)}.experience-section{padding:120px 0;background:var(--bg-alt)}.experience-list{display:flex;flex-direction:column;gap:60px}.experience-item{display:grid;grid-template-columns:180px 1fr;gap:40px}.experience-date{font-family:Inter,sans-serif;font-size:.8rem;color:var(--accent-dark);letter-spacing:1px;padding-top:6px}.experience-content h3{font-size:1.5rem;font-weight:500;margin-bottom:8px}.experience-company{font-size:1rem;color:var(--text-muted);margin-bottom:20px}.experience-description{font-size:1.05rem;color:var(--text);line-height:1.8;margin-bottom:20px}.experience-list-items{list-style:none;padding:0;margin:0 0 20px}.experience-list-items li{font-size:1rem;color:var(--text);line-height:1.8;margin-bottom:12px;padding-left:20px;position:relative}.experience-list-items li:before{content:"—";position:absolute;left:0;color:var(--accent)}.experience-tags{display:flex;flex-wrap:wrap;gap:10px}.experience-tag{font-family:Inter,sans-serif;font-size:.75rem;padding:8px 14px;background:var(--bg);border:1px solid var(--border);color:var(--text-muted);border-radius:4px}.skills-section{padding:120px 0;background:var(--bg)}.skills-intro{font-size:1.3rem;line-height:1.8;margin-bottom:60px;max-width:650px}.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px}.skill-group{padding:36px;background:var(--bg);border:1px solid var(--border);border-radius:8px;transition:all .3s}.skill-group:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 10px 40px #0000000d}.skill-group-title{font-size:1.1rem;font-weight:500;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border);color:var(--accent-dark)}.skill-list{list-style:none;padding:0;margin:0}.skill-list li{font-size:1rem;padding:10px 0;border-bottom:1px solid var(--border);color:var(--text);display:flex;align-items:center;gap:10px}.skill-list li:last-child{border-bottom:none}.skill-list li:before{content:"—";color:var(--accent);font-weight:300}.horizontal-categories{display:flex;flex-direction:column;gap:0}.horizontal-row{display:grid;grid-template-columns:180px 1fr;gap:40px;padding:24px 0;border-bottom:1px solid var(--border);align-items:center}.horizontal-row:last-child{border-bottom:none}.horizontal-category{font-family:Inter,sans-serif;font-size:.7rem;text-transform:uppercase;letter-spacing:2px;color:var(--accent-dark);font-weight:600}.horizontal-skills{font-size:1.05rem;color:var(--text)}.horizontal-skills span{color:var(--text-light);margin:0 12px}@media(max-width:768px){.horizontal-row{grid-template-columns:1fr;gap:12px}}.certifications-section{padding:120px 0;background:var(--bg-alt)}.cert-intro{font-size:1.2rem;line-height:1.8;margin-bottom:50px}.cert-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.cert-card{padding:32px;background:var(--bg);border:1px solid var(--border);border-radius:8px;transition:all .3s}.cert-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 10px 40px #0000000d}.cert-year{font-family:Inter,sans-serif;font-size:.7rem;text-transform:uppercase;letter-spacing:2px;color:var(--accent-dark);margin-bottom:12px}.cert-name{font-size:1.2rem;font-weight:500;margin-bottom:8px}.cert-issuer{font-size:.95rem;color:var(--text-muted)}.cert-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-family:Inter,sans-serif;font-size:.8rem;color:var(--accent-dark);text-decoration:none;transition:gap .3s}.cert-link:hover{gap:10px}.projects-section{padding:120px 0;background:var(--bg)}.projects-intro{font-size:1.3rem;line-height:1.8;margin-bottom:60px}.projects-note{font-size:1rem;color:var(--text-muted);line-height:1.6;margin-top:-40px;margin-bottom:60px;font-style:normal}.project-filters{display:flex;gap:12px;margin-bottom:40px;flex-wrap:wrap}.filter-btn{font-family:Inter,sans-serif;font-size:.9rem;padding:10px 24px;border:1px solid var(--border);border-radius:5px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .3s}.filter-btn:hover{border-color:var(--accent);color:var(--accent-dark)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px}.project-card{border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:all .3s;background:var(--bg)}.project-card:hover{border-color:var(--accent);transform:translateY(-8px);box-shadow:0 20px 60px #00000014}.project-image{height:220px;background:linear-gradient(135deg,var(--bg-alt),var(--border));display:flex;align-items:center;justify-content:center;overflow:hidden}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s}.project-card:hover .project-image img{transform:scale(1.05)}.project-image iframe{width:100%;height:100%;border:none}.project-card.dashboard-only .project-image{height:350px}.project-image .placeholder-icon{font-size:4rem;color:var(--accent)}.project-content{padding:28px}.project-type{font-family:Inter,sans-serif;font-size:.7rem;text-transform:uppercase;letter-spacing:2px;color:var(--accent-dark);margin-bottom:12px}.project-title{font-size:1.3rem;font-weight:500;margin-bottom:12px}.project-description{font-size:1rem;color:var(--text-muted);line-height:1.7;margin-bottom:20px}.project-link{font-family:Inter,sans-serif;font-size:.85rem;color:var(--accent-dark);text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:gap .3s}.project-link:hover{gap:10px}.project-link svg{width:16px;height:16px}.floating-pills{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px;margin-bottom:50px}.pill{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:1px solid var(--border);border-radius:5px;font-family:Inter,sans-serif;font-size:.85rem;text-decoration:none;transition:all .3s}.pill.tableau{background:#1d4e8914;border-color:#1d4e8933;color:#1d4e89}.pill.tableau:hover{background:#1d4e8926;border-color:#1d4e8966;transform:translateY(-2px)}.pill.github{background:#24292e14;border-color:#24292e33;color:#24292e}.pill.github:hover{background:#24292e26;border-color:#24292e66;transform:translateY(-2px)}[data-theme=dark] .pill.tableau{background:#529cca26;border-color:#529cca4d;color:#73b3e7}[data-theme=dark] .pill.tableau:hover{background:#529cca40;border-color:#529cca80;transform:translateY(-2px)}[data-theme=dark] .pill.github{background:#ffffff1a;border-color:#fff3;color:#e0e0e0}[data-theme=dark] .pill.github:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px)}.pill svg{width:16px;height:16px}.contact-section{padding:120px 0;background:var(--bg-alt)}.contact-content{text-align:center;max-width:600px;margin:0 auto}.contact-title{font-size:2.5rem;font-weight:400;margin-bottom:24px}.contact-title em{font-style:italic;color:var(--accent-dark)}.contact-text{font-size:1.2rem;color:var(--text-muted);line-height:1.8;margin-bottom:40px}.contact-email{font-size:1.5rem;color:var(--accent-dark);text-decoration:none;border-bottom:2px solid var(--accent-light);padding-bottom:4px;transition:all .3s}.contact-email:hover{border-color:var(--accent-dark)}.contact-social{display:flex;justify-content:center;gap:20px;margin-top:50px}.contact-social a{width:50px;height:50px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);text-decoration:none;transition:all .3s}.contact-social a:hover{border-color:var(--accent);color:var(--accent-dark);transform:translateY(-4px)}.contact-social a svg{width:20px;height:20px}.footer{padding:40px 0;border-top:1px solid var(--border);text-align:center;background:var(--bg)}.footer-text{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-muted)}.footer-text span{color:var(--accent)}@media(max-width:1200px){.skills-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.nav{padding:20px 24px}.hamburger{display:flex}.nav-links{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:var(--bg);flex-direction:column;padding:100px 40px 40px;gap:32px;box-shadow:-5px 0 25px #0000001a;transition:right .4s ease;z-index:100;border-left:1px solid var(--border)}.nav-links.mobile-open{right:0}.nav-link{font-size:1.1rem;padding:12px 0}.nav-link:after{display:none}.theme-toggle{margin-top:20px}.hero-content,.section-content{padding:0 24px}.greeting{font-size:2.2rem}.intro-text{font-size:1.2rem}.quick-stats{gap:30px}.about-content{grid-template-columns:1fr}.about-image{position:static;max-width:250px;margin:0 auto 40px}.experience-item{grid-template-columns:1fr;gap:16px}.skills-grid,.cert-grid,.projects-grid{grid-template-columns:1fr}.section{padding:80px 0}.section-title{font-size:2rem}.cta-group{flex-direction:column}.btn{justify-content:center}}@media(max-width:600px){.wave{font-size:2.5rem}.greeting{font-size:1.8rem}.quick-stats{flex-direction:column;gap:24px;align-items:flex-start}.stat{text-align:left}.social-strip{flex-wrap:wrap}.scroll-indicator{display:none}}.theme-toggle{background:var(--bg-alt);border:1px solid var(--border);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:var(--text-muted);font-size:1.2rem}.theme-toggle:hover{border-color:var(--accent);color:var(--accent-dark)}.theme-toggle svg{width:18px;height:18px}
