:root{--color-primary:#19a579;--color-primary-dark:#568575;--color-white:#ffffff;--color-black:#000000;--color-gray:#dddddd;--color-background:#f8f9fa;--color-background-alt:#ffffff;--color-background-hero:#f1f5f9;--color-text:#1a1a1a;--color-text-inverse:#f1f5f9;--color-text-muted:#dddddd;--color-muted:#979797;--color-link:#047857;--base-size:16px;--radius:12px;--shadow-sm:0 4px 6px rgba(0, 0, 0, .1);--shadow-md:0 8px 32px rgba(0, 0, 0, .1);--shadow-lg:0 12px 48px rgba(0, 0, 0, .15);--divider:rgba(0, 0, 0, .1)}.dark{--color-background:#121212;--color-background-alt:#1c1c1c;--color-background-hero:#141414;--color-text:#f1f5f9;--color-text-inverse:#1a1a1a;--color-text-muted:#dddddd;--color-link:#10b981}*{box-sizing:border-box}html,body{height:100%}body{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:var(--base-size);line-height:1.6;background:var(--color-background);color:var(--color-text)}.container{max-width:1200px;padding:0 16px}a{color:inherit;text-decoration:none}.no-style{all:unset;display:contents}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;height:48px;border-radius:var(--radius);border:none;cursor:pointer;font-weight:700;color:var(--color-white);background:linear-gradient(90deg,var(--color-primary),var(--color-primary-dark));box-shadow:0 6px 18px color-mix(in srgb,var(--color-primary) 18%,transparent),0 2px 6px rgba(0,0,0,6%);transition:transform .14s ease,box-shadow .14s ease,opacity .12s ease}.btn-primary:hover{box-shadow:0 10px 28px color-mix(in srgb,var(--color-primary) 22%,transparent),0 3px 8px rgba(0,0,0,8%)}.btn-primary:active{transform:translateY(-1px)scale(.995);box-shadow:0 6px 14px color-mix(in srgb,var(--color-primary) 16%,transparent),0 2px 6px rgba(0,0,0,6%)}.fade-in{animation:fadeIn .8s ease-in}@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}#theme-switch{height:2.3rem;width:2.3rem;padding:0;border:none;border-radius:50%;background-color:transparent;display:flex;justify-content:center;align-items:center;appearance:none}.light-icon{display:inline}.dark-icon{display:none}.dark .light-icon{display:none}.dark .dark-icon{display:inline}nav{position:fixed;inset:0 auto auto 0;right:0;top:0;z-index:1000;background:var(--color-background-alt);backdrop-filter:blur(10px);border-bottom:1px solid var(--divider);padding:12px 16px}.nav-inner{display:flex;justify-content:space-between;align-items:center}.brand{font-weight:700;letter-spacing:-.01em}.nav-links{display:flex;align-items:center;gap:24px}.nav-links a{font-size:.9rem;transition:color .3s ease}.nav-links a:hover{color:var(--color-primary-dark)}.footer{background-color:var(--color-background);color:var(--color-text);padding:4rem 0;width:100%;position:relative;bottom:0}.footer p{font-size:calc(var(--base-size) * 1.2);font-weight:300;margin-bottom:1rem}.footer .social-links-container{display:flex;justify-content:center;gap:1rem}.footer .social-links-container img{width:40px;transition:transform .3s ease-in-out}.footer .social-links-container img:hover{transform:scale(1.1)}header.hero{background:linear-gradient(135deg,var(--color-background-alt) 0%,var(--color-background-hero) 100%);padding:100px 16px 60px;text-align:center;position:relative;overflow:hidden;border-bottom:1px solid var(--divider)}body.dark header.hero{background:linear-gradient(135deg,var(--color-background-alt) 0%,var(--color-background-hero) 100%)}.floating-shape{position:absolute;border-radius:50%;pointer-events:none}.float-a{top:20%;left:10%;width:60px;height:60px;background:linear-gradient(45deg,color-mix(in srgb,var(--color-primary) 40%,transparent),color-mix(in srgb,var(--color-primary-dark) 40%,transparent));animation:float 6s ease-in-out infinite}.float-b{top:60%;right:15%;width:40px;height:40px;border-radius:30%;background:linear-gradient(45deg,color-mix(in srgb,var(--color-primary-dark) 30%,transparent),color-mix(in srgb,var(--color-primary) 30%,transparent));animation:float 8s ease-in-out infinite reverse}.float-c{bottom:30%;left:20%;width:80px;height:80px;border-radius:40%;background:linear-gradient(45deg,color-mix(in srgb,var(--color-primary) 20%,transparent),color-mix(in srgb,var(--color-primary-dark) 20%,transparent));animation:float 10s ease-in-out infinite}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}.avatar-wrap{position:relative;display:inline-block;margin-bottom:32px}.avatar{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));margin:0 auto;display:flex;align-items:center;justify-content:center;font-size:calc(var(--base-size) * 3);color:#fff;font-weight:700;position:relative;box-shadow:0 20px 40px rgba(0,0,0,.2)}.avatar-ring{position:absolute;inset:-8px;border:2px solid color-mix(in srgb,var(--color-primary) 40%,transparent);border-radius:50%;border-top-color:var(--color-primary);animation:spin 20s linear infinite}@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}.geom-square{position:absolute;top:-5px;right:8px;width:16px;height:16px;background:var(--color-primary);border-radius:var(--radius);transform:rotate(45deg)}.geom-dot{position:absolute;bottom:8px;left:4px;width:12px;height:12px;background:var(--color-primary-dark);border-radius:50%}.hero-title{font-size:calc(var(--base-size) * 2.5);font-weight:800;letter-spacing:-.02em;line-height:1.1;margin:0}.hero-divider{width:50px;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-dark));margin:12px auto;border-radius:var(--radius)}.hero-tag{font-size:calc(var(--base-size) * 1.2);color:var(--color-primary-dark);margin:0 0 24px;font-weight:500;letter-spacing:.01em}.tech-stack{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:24px}.pill{background:color-mix(in srgb,var(--color-primary-dark) 10%,transparent);color:var(--color-text);padding:6px 12px;border-radius:var(--radius);font-size:.8rem;font-weight:500;backdrop-filter:blur(10px)}section{padding:60px 16px}.section-title{font-size:calc(var(--base-size) * 1.8);font-weight:700;margin:0 0 20px;position:relative}.section-title .underline{position:absolute;bottom:-6px;left:0;width:30px;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-dark));border-radius:var(--radius)}.section-title .underline.center{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:60px;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-dark));border-radius:var(--radius)}.about-grid{display:grid;grid-template-columns:1fr;gap:5rem;align-items:start;margin:0 auto}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px}.stat{text-align:center;padding:16px;background:color-mix(in srgb,var(--color-primary-dark) 2%,transparent);border-radius:var(--radius);backdrop-filter:blur(10px)}.stat .val{font-size:calc(var(--base-size) * 1.5);font-weight:700;color:var(--color-primary-dark);margin-bottom:6px}.stat .lbl{font-size:.8rem;color:var(--color-primary-dark);font-weight:500}.skills h3{font-size:calc(var(--base-size) * 1.3);font-weight:600;margin:0 0 24px}.skill{margin-bottom:20px}.skill-head{display:flex;justify-content:space-between;margin-bottom:6px}.skill-name{font-size:.9rem;font-weight:500}.skill-percentage{font-size:.8rem;color:var(--color-primary);font-weight:600}.skill-track{width:100%;height:8px;background:color-mix(in srgb,var(--color-text) 10%,transparent);border-radius:var(--radius);overflow:hidden}body.dark .skill-track{background:rgba(255,255,255,.1)}.skill-bar{width:0;height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-dark));border-radius:var(--radius);transition:width 2s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px color-mix(in srgb,var(--color-primary) 40%,transparent);position:relative;overflow:hidden}.skill-bar::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 2s ease-in-out infinite}@keyframes shimmer{0%{left:-100%}100%{left:100%}}.logo-carousel{width:100%;overflow:hidden;background-color:transparent;padding:20px 0;position:relative;z-index:2;pointer-events:none}.carousel-container{position:relative;overflow:hidden}.carousel-track{display:flex;width:max-content;animation:scrollCarousel 60s linear infinite;transition:transform .5s ease}.carousel-container::before,.carousel-container::after{content:"";position:absolute;top:0;width:100px;height:100%;pointer-events:none;z-index:2}.carousel-container::before{left:0;background:linear-gradient(to right,var(--color-background) 0%,transparent 100%)}.carousel-container::after{right:0;background:linear-gradient(to left,var(--color-background) 0%,transparent 100%)}.logo-carousel:hover .carousel-track{animation-play-state:paused}.carousel-card{background-color:color-mix(in srgb,var(--color-primary-dark) 2%,transparent);border-radius:var(--radius);box-shadow:0 4px 6px rgba(0,0,0,.2);padding:30px;margin-right:40px;display:flex;flex-direction:column;justify-content:center;align-items:center;width:10rem;height:12rem;transition:transform .3s ease;pointer-events:all}.carousel-card:hover{transform:scale(1.1)}.carousel-logo{width:80%;height:auto;object-fit:contain;display:block;margin:0 auto}.carousel-text{margin-top:2rem;font-size:1.1rem;color:var(--color-text);text-align:center;font-weight:600}.carousel-link{text-decoration:none}.carousel-card:hover .carousel-logo{transform:scale(1.1)}@keyframes scrollCarousel{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}#services{background:var(--color-background-alt)}#services .section-title{margin-bottom:3rem}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}.services-grid h3{font-size:calc(var(--base-size) * 1.3);font-weight:600;margin:0 0 24px}.service-card{background:var(--color-background);padding:24px;border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform .3s ease,box-shadow .3s ease}.service-card:hover{transform:translateY(-8px);box-shadow:0 12px 24px rgba(0,0,0,.15)}.service-icon{width:50px;height:50px;border-radius:var(--radius);background:color-mix(in srgb,var(--color-primary) 70%,transparent);display:flex;align-items:center;justify-content:center;margin-bottom:20px;fill:currentColor}#contact .section-title{margin-bottom:3rem}.contact-form{flex:1;min-width:300px;max-width:720px;display:flex;flex-direction:column;gap:12px;pointer-events:auto}.contact-form .form-group{width:100%}.form-success-message{color:var(--color-text);background-color:color-mix(in srgb,var(--color-primary) 15%,transparent);opacity:.95;padding:12px 18px;border-radius:var(--radius);box-shadow:0 4px 12px rgba(0,0,0,.1);margin-top:12px}.contact-form input[type=text],.contact-form input[type=email],.contact-form textarea{width:100%;padding:12px 14px;border-radius:calc(var(--radius)/2);border:1px solid rgba(0,0,0,6%);background:var(--color-background-alt);color:var(--color-text);font-size:.95rem;outline:none;transition:box-shadow .18s ease,border-color .18s ease,transform .08s ease;box-shadow:0 1px rgba(0,0,0,2%);resize:vertical}.contact-form input.form-control:focus,.contact-form textarea.form-control:focus{background:var(--color-background-alt);box-shadow:0 0 0 .2rem color-mix(in srgb,var(--color-primary) 20%,transparent);color:var(--color-text)}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--color-muted);font-weight:400;opacity:.9}.contact-form input:focus,.contact-form textarea:focus{border-color:color-mix(in srgb,var(--color-primary) 60%,transparent);box-shadow:0 8px 24px color-mix(in srgb,var(--color-primary) 10%,transparent)}@media(max-width:768px){.hero .avatar{width:100px;height:100px;font-size:2.5rem}.hero-title{font-size:2rem}.hero-tag{font-size:1.1rem}.tech-stack{gap:6px}.about-grid{grid-template-columns:1fr !important;gap:32px !important}.stats-grid{grid-template-columns:1fr !important;gap:12px !important}.services-grid{grid-template-columns:1fr !important;gap:20px !important}}@media(min-width:769px) and (max-width:1024px){.about-grid{grid-template-columns:1fr !important;gap:48px !important}.services-grid{grid-template-columns:repeat(2,1fr) !important}}@media(min-width:1025px){.about-grid{grid-template-columns:1fr 1fr !important}.services-grid{grid-template-columns:repeat(3,1fr) !important}}