*{margin:0;padding:0;box-sizing:border-box}.cursor-bubble{position:fixed;width:32px;height:32px;border-radius:50%;background:#ffffff24;backdrop-filter:blur(26px) saturate(220%) brightness(1.15);-webkit-backdrop-filter:blur(26px) saturate(220%) brightness(1.15);border:1px solid rgba(255,255,255,.35);box-shadow:0 10px 26px #00000024,inset 0 1px #ffffffa6,inset 0 -1px #ffffff2e,0 0 26px #ffffff24;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:opacity .3s ease,transform .1s ease-out;will-change:transform;max-width:32px;max-height:32px;opacity:.18}@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){.cursor-bubble{background:#00000014;border:1px solid rgba(0,0,0,.18);box-shadow:0 8px 24px #0000002e,inset 0 1px #ffffff59}}@media (forced-colors: active){.cursor-bubble{forced-color-adjust:none;background:CanvasText;border:1px solid CanvasText;box-shadow:none;opacity:.35}}@media (hover: none) or (pointer: coarse){.cursor-bubble{display:none}}:root{--primary-color: #000000;--secondary-color: #333333;--text-color: #000000;--light-text: #666666;--background: #ffffff;--section-bg: #ffffff;--transition: all .3s ease}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:var(--text-color);background:var(--background)}@media (hover: hover) and (pointer: fine){body,*{cursor:none}}header{position:fixed;width:calc(100% - 40px);max-width:1200px;left:50%;transform:translate(-50%);top:-200px;z-index:1000;background:#ffffff26;backdrop-filter:blur(20px) saturate(180%) brightness(1.1);-webkit-backdrop-filter:blur(20px) saturate(180%) brightness(1.1);box-shadow:0 8px 32px #0000001a,inset 0 1px #fff9,inset 0 -1px #fff3;border-radius:25px;border:1px solid rgba(255,255,255,.3);transition:top .4s cubic-bezier(.25,.46,.45,.94);margin:20px;opacity:0;pointer-events:none;overflow:hidden}header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ffffff1a,#ffffff0d,#ffffff1a);border-radius:25px;pointer-events:none;z-index:0;opacity:1}header.visible{top:20px!important;opacity:1!important;pointer-events:auto!important;animation:slideDown .4s cubic-bezier(.25,.46,.45,.94)}@keyframes slideDown{0%{transform:translate(-50%) translateY(-100%)}to{transform:translate(-50%) translateY(0)}}.nav-content{padding:.8rem 2rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;position:relative;z-index:1}.logo a{font-size:1.5rem;font-weight:600;color:var(--text-color);text-decoration:none;position:relative;z-index:2}.nav-links{display:flex;list-style:none;gap:2rem}.nav-links a{text-decoration:none;color:var(--text-color);font-weight:500;transition:var(--transition)}.nav-links a:hover{color:var(--primary-color)}.nav-buttons{display:flex;align-items:center;gap:1rem}.photos-btn,.resume-btn{text-decoration:none;padding:.5rem 1rem;background:#fff3;backdrop-filter:blur(10px) saturate(180%);-webkit-backdrop-filter:blur(10px) saturate(180%);color:var(--text-color);border-radius:.5rem;font-weight:500;transition:var(--transition);border:1px solid rgba(255,255,255,.3);position:relative;z-index:2;box-shadow:inset 0 1px #ffffff80,inset 0 -1px #fff3,0 2px 8px #00000014}.photos-btn:hover,.resume-btn:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:inset 0 1px #fff9,inset 0 -1px #ffffff4d,0 4px 16px #0000001f;border-color:#fff6}.hamburger{display:none;flex-direction:column;gap:6px;cursor:pointer}.hamburger span{width:25px;height:2px;background:var(--text-color);transition:var(--transition)}.hero{height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:0 2rem;background:#fff}.hero-content h1{font-size:3.5rem;margin-bottom:1rem}.highlight{color:var(--primary-color)}.subtitle{font-size:1.5rem;color:var(--light-text);margin-bottom:2rem}.btn{display:inline-block;padding:.8rem 1.5rem;border-radius:.5rem;text-decoration:none;font-weight:500;transition:var(--transition);margin:.5rem}.btn.primary,.btn.secondary{background:transparent;color:var(--text-color);border:2px solid transparent}.hero:hover .btn.primary,.hero:hover .btn.secondary{background:#ffffffe6;color:var(--text-color);border:2px solid rgba(0,0,0,.1)}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.btn.small{padding:.5rem 1rem;font-size:.9rem;background:#fff3;backdrop-filter:blur(10px) saturate(180%);-webkit-backdrop-filter:blur(10px) saturate(180%);border:1px solid rgba(255,255,255,.3);box-shadow:inset 0 1px #ffffff80,inset 0 -1px #fff3,0 2px 8px #00000014}.btn.small:hover{background:#ffffff4d;box-shadow:inset 0 1px #fff9,inset 0 -1px #ffffff4d,0 4px 16px #0000001f;border-color:#fff6}section{padding:5rem 2rem}section h2{text-align:center;font-size:2.5rem;margin-bottom:3rem}.about{background:var(--section-bg)}.about-content{max-width:1200px;margin:0 auto}.about-layout{display:grid;grid-template-columns:1fr minmax(220px,340px);gap:3rem;align-items:center}.about-copy h2{text-align:left;margin-bottom:.65rem}.about-text{text-align:justify;text-align-last:left;hyphens:auto;-webkit-hyphens:auto;hyphenate-limit-chars:6 3 3}.about-text p{margin-bottom:1rem;font-size:1.1rem;text-wrap:pretty}.about-photo{justify-self:end}.about-photo img{display:block;width:100%;max-width:340px;height:auto;border-radius:1rem;box-shadow:0 8px 24px #00000014}.project-grid{column-count:2;column-gap:18px;max-width:1200px;margin:0 auto}@media (max-width: 900px){.project-grid{column-count:1}}.project-card{background:#ffffff26;backdrop-filter:blur(20px) saturate(180%) brightness(1.1);-webkit-backdrop-filter:blur(20px) saturate(180%) brightness(1.1);border-radius:2rem;overflow:hidden;box-shadow:0 8px 32px #0000001a,inset 0 1px #fff9,inset 0 -1px #fff3;border:1px solid rgba(255,255,255,.3);transition:all .4s cubic-bezier(.25,.46,.45,.94);position:relative;display:inline-flex;flex-direction:column;height:auto;break-inside:avoid;margin-bottom:18px;width:100%}.project-card.featured{column-span:all;-webkit-column-span:all}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ffffff1a,#ffffff0d,#ffffff1a);border-radius:2rem;pointer-events:none;z-index:0;opacity:1;transition:border-radius .4s cubic-bezier(.25,.46,.45,.94)}.project-card:hover{transform:translateY(-5px);border-radius:1rem;box-shadow:0 12px 40px #00000026,inset 0 1px #ffffffb3,inset 0 -1px #ffffff4d;border-color:#fff6}.project-card:hover:before{border-radius:1rem}.project-image{width:100%;background:#f8f9fa4d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:block;padding:1rem;position:relative;z-index:1;flex-shrink:0}.project-image img{width:100%;max-width:100%;height:auto;max-height:none;object-fit:unset;border-radius:.5rem;display:block}.project-info{padding:1.5rem;position:relative;z-index:1;display:flex;flex-direction:column;flex-grow:1;min-height:0}.project-info h3{margin-bottom:0;transition:var(--transition)}.project-info p{opacity:0;max-height:0;overflow:hidden;margin:0;padding:0;transition:opacity .4s cubic-bezier(.25,.46,.45,.94),max-height .4s cubic-bezier(.25,.46,.45,.94),margin .4s cubic-bezier(.25,.46,.45,.94),padding .4s cubic-bezier(.25,.46,.45,.94)}.project-card:hover .project-info p{opacity:1;max-height:200px;margin-top:1rem;margin-bottom:1rem}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto;margin-bottom:0;padding-top:1.5rem}.tech-tag{background:#fff3;backdrop-filter:blur(10px) saturate(180%);-webkit-backdrop-filter:blur(10px) saturate(180%);color:var(--primary-color);padding:.25rem .75rem;border-radius:1rem;font-size:.85rem;font-weight:500;border:1px solid rgba(255,255,255,.3);transition:var(--transition);box-shadow:inset 0 1px #ffffff80,inset 0 -1px #fff3,0 2px 4px #0000000d}.tech-tag:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:inset 0 1px #fff9,inset 0 -1px #ffffff4d,0 4px 8px #0000001a;border-color:#fff6}.project-links{margin-top:0;padding-top:0;display:flex;gap:1rem;opacity:0;max-height:0;overflow:hidden;transition:opacity .4s cubic-bezier(.25,.46,.45,.94),max-height .4s cubic-bezier(.25,.46,.45,.94),margin-top .4s cubic-bezier(.25,.46,.45,.94),padding-top .4s cubic-bezier(.25,.46,.45,.94)}.project-card:hover .project-links{opacity:1;max-height:100px;margin-top:1rem}.skills{background:var(--section-bg)}.skills-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:1.25rem;max-width:720px;margin:0 auto}.skill-category{padding-top:.75rem}.skill-category+.skill-category{border-top:1px solid rgba(0,0,0,.08);padding-top:1.25rem}.skill-category-header{margin-bottom:.85rem}.skill-category-label{display:inline-block;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--light-text)}.skill-pill-wrap{display:flex;flex-wrap:wrap;gap:10px}.skill-pill{background:#fff3;backdrop-filter:blur(10px) saturate(180%);-webkit-backdrop-filter:blur(10px) saturate(180%);border:1px solid rgba(0,0,0,.1);border-radius:9999px;color:var(--text-color);display:inline-flex;align-items:center;justify-content:center;box-shadow:inset 0 1px #fff9,inset 0 -1px #fff3,0 2px 8px #0000000f;transition:background .15s ease,transform .15s ease,box-shadow .15s ease;-webkit-user-select:none;user-select:none}.skill-pill--sm{padding:.45rem .85rem;font-size:.95rem}.skill-pill--lg{padding:.55rem 1rem;font-size:1.05rem}.skill-pill:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:inset 0 1px #ffffffb3,inset 0 -1px #ffffff4d,0 6px 16px #0000001a}.contact{padding-top:6.5rem;padding-bottom:6.5rem}.contact-subtitle{text-align:center;color:var(--light-text);margin-top:-2rem;margin-bottom:2.5rem;font-size:1.1rem}.contact-content{max-width:900px;margin:0 auto}.contact-cards{display:flex;justify-content:center;gap:18px;flex-wrap:wrap}.contact-card{text-decoration:none;color:var(--text-color);width:min(240px,100%);padding:1.5rem 1.25rem;border-radius:1.25rem;background:#fff3;backdrop-filter:blur(14px) saturate(180%);-webkit-backdrop-filter:blur(14px) saturate(180%);border:1px solid rgba(0,0,0,.1);box-shadow:inset 0 1px #fff9,inset 0 -1px #fff3,0 8px 32px #00000014;display:flex;flex-direction:column;align-items:center;gap:.65rem;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.contact-card i{font-size:2.25rem;color:var(--primary-color)}.contact-card-label{font-weight:600}.contact-card-subtext{color:var(--light-text);font-size:.95rem}.contact-card:hover{transform:translateY(-4px) scale(1.03);background:#ffffff42;box-shadow:inset 0 1px #ffffffb3,inset 0 -1px #ffffff4d,0 14px 44px #00000024}.site-footer{background:var(--background);color:var(--text-color);padding:0 2rem}.footer-divider{height:1px;background:#00000014;max-width:1200px;margin:0 auto}.footer-content{max-width:1200px;margin:0 auto;padding:3.5rem 0;display:flex;justify-content:space-between;align-items:flex-start;gap:3rem}.footer-wordmark{font-weight:600}.footer-copyright{margin-top:.35rem;font-size:.9rem;color:var(--light-text);opacity:.5}.footer-right{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem}.footer-label{font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--light-text);opacity:.5}.footer-links{display:flex;flex-direction:column;gap:.5rem}.footer-links a{color:var(--text-color);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;opacity:.7;font-weight:400;transition:opacity .15s ease,color .15s ease}.footer-links a:hover{opacity:1;color:var(--primary-color)}@media (max-width: 768px){.nav-links,.nav-buttons{display:none}.hamburger{display:flex}.hero-content h1{font-size:2.5rem}.subtitle{font-size:1.2rem}section{padding:3rem 1rem}.about-layout{grid-template-columns:1fr;gap:2rem}.about-photo{justify-self:center}.about-photo img{max-width:280px}.footer-content{flex-direction:column;gap:1.5rem}.footer-right{align-items:flex-start}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-content,.about-content,.project-card{animation:fadeIn 1s ease-out}#typing-cursor{display:inline-block;width:.5em;height:1em;background:#000;margin-left:.1em;vertical-align:middle;animation:blink-cursor .8s steps(1) infinite;border-radius:2px}@keyframes blink-cursor{0%,50%{opacity:1}51%,to{opacity:0}}
