@import url("https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--teal:#378ADD;--teal-text:#185FA5;--teal-light:#EFF6FF;--teal-mid:#60A5FA;--teal-dark:#042C53;--ink:#0F172A;--ink-soft:#1E3A5F;--muted:#4B5B6A;--border:rgba(55,138,221,0.15);--surface:#F4F8FE;--white:#FFFFFF;--nav-bg:rgba(255,255,255,0.95);--ink-border:rgba(15,23,42,0.25);--brand-glow-soft:rgba(55,138,221,0.12);--brand-glow:rgba(55,138,221,0.2);--brand-glow-faint:rgba(55,138,221,0.15);--brand-shadow:rgba(55,138,221,0.1);--white-soft:rgba(255,255,255,0.7);--white-faint:rgba(255,255,255,0.1);--white-border:rgba(255,255,255,0.2);--linkedin:#0A66C2;--linkedin-border:rgba(10,102,194,0.3);--category-sql-bg:var(--teal-light);--category-python-bg:#E8F3FF;--category-powerbi-bg:#FFF7DF;--category-excel-bg:#EAF7EF;--category-pipeline-bg:#F1EFFF;--category-sql:#185FA5;--category-python:var(--teal-dark);--category-powerbi:#854F0B;--category-excel:#185FA5;--category-pipeline:#5D3FD3}html{scroll-behavior:smooth}body{font-family:DM Sans,sans-serif;background:var(--surface);color:var(--ink);line-height:1.6;min-height:100vh}a{color:inherit}nav{position:-webkit-sticky;position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:.9rem 3rem;background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.nav-logo{font-family:"DM Serif Display",serif;font-size:1.15rem;color:var(--teal-dark)}.nav-links{display:flex;gap:2rem;align-items:center}.nav-links a{font-size:.82rem;font-weight:500;color:var(--muted);text-decoration:none;letter-spacing:.05em;text-transform:uppercase;transition:color .2s}.nav-links a:hover{color:var(--teal)}.quick-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem;flex-wrap:wrap}.qb-btn{display:inline-flex;align-items:center;gap:7px;padding:.5rem 1.1rem;border-radius:100px;font-size:.8rem;font-weight:500;text-decoration:none;border:1.5px solid;transition:all .2s;cursor:pointer}.qb-github{color:var(--ink);border-color:var(--ink-border);background:var(--white)}.qb-github:hover{background:var(--ink);color:var(--white);border-color:var(--ink)}.qb-linkedin{color:var(--linkedin);border-color:var(--linkedin-border);background:var(--white)}.qb-linkedin:hover{background:var(--linkedin);color:var(--white);border-color:var(--linkedin)}.qb-resume{color:var(--teal-dark);border-color:var(--teal);background:var(--teal-light)}.qb-resume:hover{background:var(--teal);color:var(--white)}.qb-btn svg{width:15px;height:15px;flex-shrink:0}.hero{min-height:92vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:4rem 3rem;grid-gap:4rem;gap:4rem;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:-100px;right:-150px;width:600px;height:600px;background:radial-gradient(circle,var(--brand-glow-soft) 0,transparent 70%);border-radius:50%;pointer-events:none}.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--teal-light);color:var(--teal-dark);font-size:.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:1.2rem}.hero-eyebrow:before{content:"";width:6px;height:6px;background:var(--teal);border-radius:50%;display:inline-block}.hero h1{font-family:"DM Serif Display",serif;font-size:clamp(2.6rem,4.5vw,4rem);line-height:1.08;color:var(--ink);margin-bottom:1.2rem}.hero h1 em{font-style:italic;color:var(--teal)}.hero-desc{font-size:1rem;color:var(--ink-soft);line-height:1.75;margin-bottom:1.6rem;max-width:480px}.hero-visual{display:flex;flex-direction:column;gap:1rem}.stat-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem}.stat-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:1.4rem;transition:transform .2s;position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--teal-mid));opacity:0;transition:opacity .2s}.stat-card:hover{transform:translateY(-3px)}.stat-card:hover:after{opacity:1}.stat-card .num{font-family:"DM Serif Display",serif;font-size:2.2rem;color:var(--teal-dark)}.stat-card .label{font-size:.75rem;color:var(--muted);margin-top:2px}.stat-card-wide{background:var(--teal-dark);color:var(--white);border-radius:16px;padding:1.4rem;display:flex;align-items:center;justify-content:space-between}.stat-card-wide .title{font-size:.82rem;font-weight:500;opacity:.75}.stat-card-wide .highlight{font-family:"DM Serif Display",serif;font-size:1.5rem;color:var(--teal-mid)}.stat-card-meta{font-size:.76rem;opacity:.6;margin-top:2px}.stat-card-wide svg{color:var(--teal-mid)}.skills-preview{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:1.4rem}.sp-title{font-size:.72rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:1rem}.skill-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.skill-bar-row:last-child{margin-bottom:0}.skill-bar-name{font-size:.78rem;color:var(--ink-soft);min-width:72px}.skill-bar-track{flex:1 1;height:6px;background:var(--teal-light);border-radius:100px;overflow:hidden}.skill-bar-fill{height:100%;border-radius:100px;background:linear-gradient(90deg,var(--teal),var(--teal-mid))}section{padding:5rem 3rem}section:nth-child(2n){background:var(--white)}.section-label{display:inline-block;font-size:.7rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin-bottom:.5rem}.section-title{font-family:"DM Serif Display",serif;font-size:clamp(1.9rem,3vw,2.6rem);color:var(--ink);margin-bottom:.8rem}.section-subtitle{font-size:.95rem;color:var(--muted);max-width:560px;line-height:1.7;margin-bottom:2.5rem}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--teal),var(--teal-light));border-radius:100px}.tl-item{position:relative;margin-bottom:2.5rem}.tl-dot{position:absolute;left:-2.4rem;top:4px;width:12px;height:12px;border-radius:50%;background:var(--teal);border:2px solid var(--surface);box-shadow:0 0 0 3px var(--brand-glow)}.tl-period{font-size:.73rem;font-weight:500;color:var(--teal);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.3rem}.tl-role{font-size:1.05rem;font-weight:500;color:var(--ink)}.tl-company{font-size:.88rem;color:var(--muted);margin-bottom:.7rem}.tl-points{list-style:none}.tl-points li{font-size:.88rem;color:var(--ink-soft);padding:4px 0 4px 1.2rem;position:relative}.tl-points li:before{content:"->";position:absolute;left:0;color:var(--teal-mid);font-size:.8rem}.projects-cat-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-auto-flow:dense;grid-auto-rows:minmax(220px,auto);grid-gap:1.5rem;gap:1.5rem;align-items:stretch;max-width:1320px}.cat-card{background:var(--white);border:1px solid var(--border);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;height:100%;transition:transform .2s,box-shadow .2s}.cat-card-sql{grid-column:span 4}.cat-card-python{grid-column:span 5;grid-row:span 2}.cat-card-pipeline,.cat-card-powerbi{grid-column:span 3}.cat-card-excel{grid-column:span 4}.cat-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px var(--brand-shadow)}.cat-header{padding:1.3rem 1.5rem 0;display:flex;align-items:flex-start;gap:12px}.cat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cat-icon svg{width:20px;height:20px}.cat-icon.sql{background:var(--category-sql-bg);color:var(--category-sql)}.cat-icon.python{background:var(--category-python-bg);color:var(--category-python)}.cat-icon.powerbi{background:var(--category-powerbi-bg);color:var(--category-powerbi)}.cat-icon.excel{background:var(--category-excel-bg);color:var(--category-excel)}.cat-icon.pipeline{background:var(--category-pipeline-bg);color:var(--category-pipeline)}.cat-name{font-size:1rem;font-weight:500;line-height:1.25;color:var(--ink)}.cat-sub{font-size:.75rem;line-height:1.35;color:var(--muted)}.cat-body{padding:1rem 1.5rem 1.5rem;flex:1 1}.proj-item{padding:.75rem 0;border-bottom:1px solid var(--border)}.proj-item:last-child{border-bottom:none;padding-bottom:0}.proj-title{display:inline-block;font-size:.88rem;font-weight:500;color:var(--ink);margin-bottom:.25rem;text-decoration:none}.proj-title:hover{color:var(--teal);text-decoration:underline}.proj-desc{font-size:.8rem;color:var(--ink-soft);line-height:1.55}.proj-metric{display:inline-block;margin-top:.4rem;font-size:.73rem;font-weight:500;color:var(--teal-dark);background:var(--teal-light);padding:2px 10px;border-radius:100px}.cat-footer{padding:.9rem 1.5rem;border-top:1px solid var(--border);background:var(--surface);margin-top:auto}.cat-link{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:500;color:var(--teal);text-decoration:none}.cat-link:hover{text-decoration:underline}.cat-link svg{width:13px;height:13px}.skills-full-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1.5rem;gap:1.5rem}.skill-group{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1.4rem}.skill-group h4{font-size:.75rem;font-weight:500;color:var(--teal);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem}.skill-chips{display:flex;flex-wrap:wrap;gap:6px}.chip{font-size:.78rem;padding:4px 12px;border-radius:8px;background:var(--white);border:1px solid var(--border);color:var(--ink-soft)}.contact-strip{background:var(--teal-dark);color:var(--white);border-radius:20px;padding:3rem;text-align:center;margin:0 3rem 4rem;position:relative;overflow:hidden}.contact-strip:before{content:"";position:absolute;top:-80px;right:-80px;width:300px;height:300px;border:1px solid var(--brand-glow);border-radius:50%}.contact-strip:after{content:"";position:absolute;bottom:-60px;left:-60px;width:220px;height:220px;border:1px solid var(--brand-glow-faint);border-radius:50%}.contact-strip h2{font-family:"DM Serif Display",serif;font-size:2rem;margin-bottom:.5rem}.contact-strip p{color:var(--white-soft);margin-bottom:2rem}.contact-links{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;position:relative;z-index:1}.contact-link{display:inline-flex;align-items:center;gap:8px;padding:.65rem 1.3rem;border-radius:100px;background:var(--white-faint);color:var(--white);font-size:.83rem;font-weight:400;text-decoration:none;border:1px solid var(--white-border);transition:background .2s}.contact-link:hover{background:var(--white-border)}.contact-link svg{width:15px;height:15px;flex-shrink:0}footer{text-align:center;padding:1.5rem;font-size:.75rem;color:var(--muted)}@media (max-width:768px){nav{padding:.9rem 1.5rem}.nav-links{gap:1rem}.hero{grid-template-columns:1fr;padding:3rem 1.5rem;gap:2.5rem}section{padding:3.5rem 1.5rem}.contact-strip{margin:0 1.5rem 3rem;padding:2rem 1.5rem}}@media (max-width:1024px){.projects-cat-grid{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:auto}.cat-card-excel,.cat-card-pipeline,.cat-card-powerbi,.cat-card-python,.cat-card-sql{grid-column:span 1;grid-row:auto}}@media (max-width:560px){nav{flex-direction:column;gap:.75rem}.nav-links{flex-wrap:wrap;justify-content:center}.projects-cat-grid{grid-template-columns:1fr}}