*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;color:#2c3e50;background-color:#f7f3ed;line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:1rem}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}a{color:#2c3e50;text-decoration:none;transition:color .2s ease}a:hover{color:#1a252f}img{max-width:100%;height:auto}button{font-family:inherit;cursor:pointer}.header{padding:2rem 0;background:#f7f3ed;border-bottom:1px solid rgba(44,62,80,.1)}.header__container{max-width:1200px;margin:0 auto;padding:0 1.5rem}@media(min-width:1024px){.header__container{padding:0 2rem}}.header__container{display:flex;flex-direction:column;align-items:center;gap:1rem}@media(min-width:640px){.header__container{flex-direction:row;justify-content:space-between;gap:1.5rem}}.header__name{font-size:1.5rem;font-weight:700;color:#2c3e50;margin:0}@media(min-width:768px){.header__name{font-size:1.875rem}}.header__nav{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.5rem 1rem}@media(min-width:640px){.header__nav{flex-wrap:nowrap;gap:1.5rem}}.header__link{color:#7f8c8d;font-weight:500;transition:color .2s ease}.header__link:hover{color:#e67e22}.header__link--icon{display:flex;align-items:center}.header__divider{width:1px;height:1rem;background-color:#2c3e5033}.hero{padding:4rem 0;background:linear-gradient(135deg,#faf8f4,#f9f5f1);position:relative;overflow:hidden}.hero:after{content:"";position:absolute;top:-50%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(230,126,34,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none}.hero__container{max-width:1200px;margin:0 auto;padding:0 1.5rem}@media(min-width:1024px){.hero__container{padding:0 2rem}}.hero__container{position:relative;z-index:1}.hero__content{max-width:750px}.hero__title{font-size:1.875rem;font-weight:800;color:#2c3e50;margin-bottom:2rem;line-height:1.2;position:relative;display:inline-block}.hero__title:after{content:"";position:absolute;bottom:-8px;left:0;width:80px;height:4px;background:linear-gradient(90deg,#e67e22,#d35400);border-radius:2px}@media(min-width:768px){.hero__title{font-size:3rem}}@media(min-width:1024px){.hero__title{font-size:3.5rem}}.hero__description{font-size:1.125rem;line-height:1.9;color:#7f8c8d;margin-bottom:1.5rem;margin-top:2rem}.hero__description:first-of-type{font-size:1.175rem;color:#727f80}.hero__description:last-child{margin-bottom:0;font-weight:500;color:#34495e}.about{padding:4rem 0;background-color:#f7f3ed}.about__container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.about__title{font-size:1.875rem;font-weight:800;color:#2c3e50;margin-bottom:3rem;text-align:center;position:relative;display:inline-block;width:100%}.about__title:after{content:"";position:absolute;bottom:-12px;left:50%;transform:translate(-50%);width:100px;height:4px;background:linear-gradient(90deg,#e67e22,#d35400);border-radius:2px}@media(min-width:768px){.about__title{font-size:2.75rem}}.about__content{display:flex;flex-direction:column;gap:3rem}.about__text{text-align:center;font-size:1.125rem;color:#7f8c8d;max-width:800px;margin:0 auto;line-height:1.8}.about__text p{margin:0}.about__pinball-card{background:#faf8f4;border-radius:1rem;padding:2rem;box-shadow:0 4px 6px -1px #0000001a;transition:box-shadow .2s ease}.about__pinball-card:hover{box-shadow:0 10px 15px -3px #0000001a}.about__pinball-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.about__pinball-header h3{margin:0;color:#2c3e50;font-size:1.125rem}.about__ifpa-link{color:#e67e22;font-size:.875rem;font-weight:500;transition:color .2s ease}.about__ifpa-link:hover{color:#d35400}.about__stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.5rem}.about__stat{text-align:center;padding:1rem;background:#f7f3ed;border-radius:.5rem;transition:background-color .2s ease}.about__stat:hover{background:#2c3e5008}.about__stat-label{font-size:.875rem;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-weight:600}.about__stat-value{font-size:1.25rem;font-weight:700;color:#2c3e50;margin-bottom:.5rem}.about__stat-change{font-size:.875rem;color:#7f8c8d;font-style:italic}.about__stat-detail{font-size:.875rem;color:#7f8c8d}.about__loading,.about__error{text-align:center;padding:3rem;color:#7f8c8d;font-style:italic}.about__error{color:#e67e22}@media(max-width:768px){.about{padding:3rem 0}.about__stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.about__stat-value{font-size:1.125rem}}@media(max-width:640px){.about__stats-grid{grid-template-columns:1fr}.about__pinball-header{flex-direction:column;align-items:flex-start}}.project-card{background:#fff;border-radius:1rem;padding:2rem;box-shadow:0 4px 6px #00000012,0 1px 3px #0000000f;border:1px solid rgba(0,0,0,.08);position:relative;overflow:hidden;transition:all .3s}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#e67e22,#d35400);opacity:0;transition:opacity .2s ease}.project-card:hover{box-shadow:0 12px 24px #0000001f,0 6px 12px #00000014;border-color:#e67e2233}.project-card:hover:before{opacity:1}.project-card__title{font-size:1.25rem;font-weight:700;color:#2c3e50;margin-bottom:1rem;line-height:1.3}.project-card__description{font-size:16px;line-height:1.7;color:#7f8c8d;margin-bottom:1.5rem}.project-card__tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.project-card__tech-tag{font-size:.875rem;padding:.4rem .9rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:.5rem;font-weight:600;letter-spacing:.3px;box-shadow:0 2px 4px #667eea4d}.project-card__tech-tag:nth-child(2){background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 2px 4px #f093fb4d}.project-card__tech-tag:nth-child(3){background:linear-gradient(135deg,#4facfe,#00f2fe);box-shadow:0 2px 4px #4facfe4d}.project-card__tech-tag:nth-child(4){background:linear-gradient(135deg,#43e97b,#38f9d7);box-shadow:0 2px 4px #43e97b4d}.project-card__tech-tag:nth-child(5){background:linear-gradient(135deg,#fa709a,#fee140);box-shadow:0 2px 4px #fa709a4d}.project-card__links{display:flex;gap:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.06)}.project-card__link{display:inline-flex;align-items:center;padding:.5rem 1.25rem;background:#e67e22;color:#fff;font-weight:600;font-size:.875rem;border-radius:.5rem;box-shadow:0 2px 4px #e67e224d;transition:all .2s ease}.project-card__link:hover{background:#d35400;transform:translateY(-2px);box-shadow:0 4px 8px #e67e2266}.project-card__link:last-child{background:#fff;color:#e67e22;border:2px solid #e67e22;box-shadow:none}.project-card__link:last-child:hover{background:#e67e22;color:#fff}.projects{padding:4rem 0;background:#f7f3ed}.projects__container{max-width:1200px;margin:0 auto;padding:0 1.5rem}@media(min-width:1024px){.projects__container{padding:0 2rem}}.projects__title{font-size:1.875rem;font-weight:800;color:#2c3e50;margin-bottom:3rem;text-align:center;position:relative;display:inline-block;width:100%}.projects__title:after{content:"";position:absolute;bottom:-12px;left:50%;transform:translate(-50%);width:100px;height:4px;background:linear-gradient(90deg,#e67e22,#d35400);border-radius:2px}@media(min-width:768px){.projects__title{font-size:2.75rem}}.projects__grid{display:grid;gap:3rem;grid-template-columns:1fr}@media(min-width:768px){.projects__grid{grid-template-columns:repeat(2,1fr);gap:2rem}}@media(min-width:1024px){.projects__grid{grid-template-columns:repeat(2,1fr);gap:2.5rem}}.contact{padding:4rem 0;background:#faf8f4}.contact__container{max-width:1200px;margin:0 auto;padding:0 1.5rem}@media(min-width:1024px){.contact__container{padding:0 2rem}}.contact__container{text-align:center}.contact__title{font-size:1.875rem;font-weight:800;color:#2c3e50;margin-bottom:3rem;text-align:center;position:relative;display:inline-block;width:100%}.contact__title:after{content:"";position:absolute;bottom:-12px;left:50%;transform:translate(-50%);width:100px;height:4px;background:linear-gradient(90deg,#e67e22,#d35400);border-radius:2px}@media(min-width:768px){.contact__title{font-size:2.75rem}}.contact__description{font-size:1.125rem;line-height:1.8;color:#7f8c8d;margin-bottom:3rem}.contact__links{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap}.contact__link{display:inline-flex;align-items:center;padding:.5rem 1.25rem;background:#e67e22;color:#fff;font-weight:600;font-size:.875rem;border-radius:.5rem;box-shadow:0 2px 4px #e67e224d;border:2px solid #e67e22;transition:all .2s ease}.contact__link:hover{background:#d35400;border-color:#d35400;transform:translateY(-2px);box-shadow:0 4px 8px #e67e2266}.contact__link--primary{background:#e67e22;color:#fff}.contact__link--primary:hover{background:#d35400;border-color:#d35400}.contact__link:not(.contact__link--primary):not(.contact__link--icon){background:#fff;color:#e67e22;border:2px solid #e67e22;box-shadow:none}.contact__link:not(.contact__link--primary):not(.contact__link--icon):hover{background:#e67e22;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #e67e2266}.contact__link--icon{background:transparent;border:none;box-shadow:none;padding:.5rem;color:#7f8c8d}.contact__link--icon:hover{background:transparent;color:#e67e22;transform:translateY(-2px);box-shadow:none}.footer{padding:2rem 0;background:#f7f3ed;border-top:1px solid rgba(44,62,80,.1)}.footer__container{max-width:1200px;margin:0 auto;padding:0 1.5rem}@media(min-width:1024px){.footer__container{padding:0 2rem}}.footer__container{text-align:center}.footer__text{color:#7f8c8d;font-size:.875rem;margin:0}
