*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#000000de;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%}.pdf-download-button{text-decoration:none}.pdf-download-btn{padding:10px 20px;background-color:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0003}.pdf-download-btn:hover:not(:disabled){background-color:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.pdf-download-btn:active:not(:disabled){transform:translateY(0)}.pdf-download-btn:disabled{opacity:.7;cursor:not-allowed}@media(max-width:768px){.pdf-download-btn{width:100%;padding:12px 20px;font-size:1rem}}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:3rem 2rem;text-align:center;box-shadow:0 4px 6px #0000001a}.header-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.5rem;position:relative}.header-actions{position:absolute;top:1rem;right:1rem;z-index:10}@media(max-width:768px){.header-actions{position:static;margin-top:1rem;width:100%;display:flex;justify-content:center}}.profile-image-container{width:150px;height:150px;border-radius:50%;overflow:hidden;border:4px solid white;box-shadow:0 4px 8px #0003;transition:transform .2s,box-shadow .2s}.profile-image-container:hover{transform:scale(1.05);box-shadow:0 6px 12px #0000004d}.profile-image-container:active{transform:scale(.95)}.profile-image{width:100%;height:100%;object-fit:cover}.header-text{display:flex;flex-direction:column;gap:.5rem}.name{font-size:2.5rem;font-weight:700;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.title{font-size:1.25rem;margin:0;opacity:.95;font-weight:300}@media(min-width:768px){.header-content{flex-direction:row;text-align:left;gap:2rem}.name{font-size:3rem}.title{font-size:1.5rem}}.section{padding:3rem 2rem}.container{max-width:1200px;margin:0 auto}.section-title{font-size:2rem;font-weight:700;margin-bottom:2rem;color:#333;border-bottom:3px solid #667eea;padding-bottom:.5rem;display:inline-block}.bio{font-size:1.1rem;line-height:1.8;color:#555;margin-bottom:2rem}.skills{margin-top:2rem}.skills-title{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:#333}.skills-list{display:flex;flex-wrap:wrap;gap:.75rem}.skill-item-wrapper{position:relative;display:inline-block}.skill-tag{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s;display:inline-block}.skill-tag:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.skill-remove-btn{position:absolute;top:-8px;right:-8px;background:#dc3545;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003;z-index:10}.skill-remove-btn:hover{background:#c82333;transform:scale(1.1)}.skill-add-btn{background:#28a745;color:#fff;border:none;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000001a}.skill-add-btn:hover{background:#218838;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.experience-list{display:flex;flex-direction:column;gap:2rem}.experience-item{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;border-left:4px solid #667eea}.experience-item:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.experience-header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.job-title{font-size:1.5rem;font-weight:700;color:#333;margin:0}.company{font-size:1.1rem;color:#667eea;font-weight:600}.experience-meta{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.period,.location{font-size:.9rem;color:#666;font-style:italic}.job-description{font-size:1rem;line-height:1.6;color:#555;margin-bottom:1rem}.responsibilities{list-style:none;padding:0;margin:0}.responsibilities li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#555;line-height:1.6}.responsibilities li:before{content:"▸";position:absolute;left:0;color:#667eea;font-weight:700}.experience-remove-btn{position:absolute;top:1rem;right:1rem;background:#dc3545;color:#fff;border:none;border-radius:50%;width:32px;height:32px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003;z-index:10;transition:all .2s}.experience-remove-btn:hover{background:#c82333;transform:scale(1.1)}.experience-add-btn{background:#28a745;color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0000001a;margin-top:1rem;width:100%}.experience-add-btn:hover{background:#218838;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.responsibility-item{position:relative;padding-right:2rem}.responsibility-remove-btn{position:absolute;right:0;top:.5rem;background:#dc3545;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.7;transition:all .2s}.responsibility-remove-btn:hover{opacity:1;transform:scale(1.1)}.responsibility-add-btn{background:#667eea;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;margin-top:.5rem;transition:all .2s}.responsibility-add-btn:hover{background:#5568d3}@media(min-width:768px){.experience-header{flex-direction:row;justify-content:space-between;align-items:center}}.projects-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.project-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;cursor:pointer}.project-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.project-image{position:relative;width:100%;height:180px;overflow:hidden;background:#f0f0f0}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.project-overlay{position:absolute;inset:0;background:#667eeae6;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}.project-card:hover .project-overlay{opacity:1}.project-card:hover .project-image img{transform:scale(1.1)}.view-details{color:#fff;font-size:1.1rem;font-weight:600;text-transform:uppercase;letter-spacing:1px}.project-content{padding:1.25rem}.project-title{font-size:1.25rem;font-weight:700;color:#333;margin:0 0 .75rem}.project-description{font-size:.95rem;line-height:1.6;color:#555;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;align-items:center}.tech-tag{background:#f0f0f0;color:#667eea;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.project-summary-indicator{margin-top:.5rem;padding-top:.75rem;border-top:1px solid #e9ecef}.summary-badge{display:inline-block;font-size:.8rem;color:#667eea;font-weight:500;padding:.25rem .5rem;background:#f0f0f0;border-radius:6px}.project-modal{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;overflow-y:auto;animation:fadeIn .2s}.project-modal .modal-content{position:relative;max-width:900px;width:100%;background:#fff;border-radius:12px;overflow:hidden;max-height:90vh;display:flex;flex-direction:column;animation:scaleIn .2s}.project-modal .modal-close{position:absolute;top:1rem;right:1rem;background:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#333;transition:all .2s;z-index:1001;box-shadow:0 2px 8px #0003}.project-modal .modal-close:hover{background:#667eea;color:#fff;transform:rotate(90deg)}.modal-title{font-size:2rem;font-weight:700;color:#333;margin:0 0 1rem}.modal-description{font-size:1.1rem;line-height:1.8;color:#555;margin-bottom:2rem}.modal-scope,.modal-impact{margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea}.modal-impact{border-left-color:#28a745;background:#f0f9f4}.modal-section-title{font-size:1.1rem;font-weight:600;color:#333;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.modal-section-title:before{content:"";width:4px;height:18px;background:#667eea;border-radius:2px}.modal-impact .modal-section-title:before{background:#28a745}.modal-list{list-style:none;padding:0;margin:0}.modal-list li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#555;line-height:1.6}.modal-list li:before{content:"▸";position:absolute;left:0;color:#667eea;font-weight:700}.modal-impact .modal-list li:before{color:#28a745}.modal-scope p,.modal-impact p{margin:0;color:#555;line-height:1.6}.modal-tech .tech-list{display:flex;flex-wrap:wrap;gap:.5rem}.modal-media{margin-bottom:1.5rem}.modal-media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-top:1rem}.modal-media-item{border-radius:8px;overflow:hidden;background:#f0f0f0}.modal-media-item img,.modal-media-item video{width:100%;height:auto;display:block}.media-caption{padding:.5rem;font-size:.85rem;color:#666;margin:0;text-align:center}.modal-links{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem}@media(min-width:768px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.projects-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.project-modal{padding:1rem}.modal-body{padding:1.5rem}.modal-title{font-size:1.5rem}}.portfolio{background:#f9f9f9}.portfolio-grid{display:grid;grid-template-columns:1fr;gap:2rem}.portfolio-item{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;cursor:pointer}.portfolio-item:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.portfolio-image{position:relative;width:100%;height:250px;overflow:hidden;background:#f0f0f0}.portfolio-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.portfolio-overlay{position:absolute;inset:0;background:#667eeae6;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}.portfolio-item:hover .portfolio-overlay{opacity:1}.portfolio-item:hover .portfolio-image img{transform:scale(1.1)}.view-details{color:#fff;font-size:1.2rem;font-weight:600;text-transform:uppercase;letter-spacing:1px}.portfolio-content{padding:1.5rem}.portfolio-title{font-size:1.5rem;font-weight:700;color:#333;margin:0 0 .5rem}.portfolio-category{display:inline-block;padding:.25rem .75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:.85rem;font-weight:500;margin-bottom:1rem}.portfolio-description{font-size:1rem;line-height:1.6;color:#555;margin-bottom:1rem}.portfolio-tech{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.tech-badge{background:#f0f0f0;color:#667eea;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.tech-more{color:#666;font-size:.85rem;font-weight:500}.portfolio-modal{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;overflow-y:auto;animation:fadeIn .2s}.portfolio-modal .modal-content{position:relative;max-width:900px;width:100%;background:#fff;border-radius:12px;overflow:hidden;max-height:90vh;display:flex;flex-direction:column;animation:scaleIn .2s}.portfolio-modal .modal-close{position:absolute;top:1rem;right:1rem;background:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#333;transition:all .2s;z-index:1001;box-shadow:0 2px 8px #0003}.portfolio-modal .modal-close:hover{background:#667eea;color:#fff;transform:rotate(90deg)}.modal-image{width:100%;height:300px;overflow:hidden;background:#f0f0f0}.modal-image img{width:100%;height:100%;object-fit:cover}.modal-body{padding:2rem;overflow-y:auto}.modal-title{font-size:2rem;font-weight:700;color:#333;margin:0 0 .5rem}.modal-category{display:inline-block;padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:.9rem;font-weight:500;margin-bottom:1.5rem}.modal-description{font-size:1.1rem;line-height:1.8;color:#555;margin-bottom:1.5rem}.modal-details{margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea}.modal-details ul{list-style:none;padding:0;margin:0}.modal-details li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#555;line-height:1.6}.modal-details li:before{content:"▸";position:absolute;left:0;color:#667eea;font-weight:700}.modal-details p{margin:0;color:#555;line-height:1.6}.modal-tech{margin-bottom:1.5rem}.modal-tech h4{font-size:1.1rem;font-weight:600;color:#333;margin:0 0 1rem}.tech-list{display:flex;flex-wrap:wrap;gap:.5rem}.modal-tech .tech-tag{background:#f0f0f0;color:#667eea;padding:.5rem 1rem;border-radius:12px;font-size:.9rem;font-weight:500}.modal-links{display:flex;gap:1rem;flex-wrap:wrap}.modal-link{color:#667eea;text-decoration:none;font-weight:600;padding:.75rem 1.5rem;border:2px solid #667eea;border-radius:6px;transition:all .2s;display:inline-block}.modal-link:hover{background:#667eea;color:#fff}@media(min-width:768px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.portfolio-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.portfolio-modal{padding:1rem}.modal-body{padding:1.5rem}.modal-title{font-size:1.5rem}}.socials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.social-link{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;background:#fff;border-radius:12px;text-decoration:none;color:#333;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.social-link:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026;color:#667eea}.social-icon{font-size:2rem}.social-platform{font-size:1rem;font-weight:600}.contact-options{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.contact-button{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 3rem;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;text-decoration:none;transition:transform .2s,box-shadow .2s;min-width:180px;box-shadow:0 4px 8px #0000001a}.contact-button.phone{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.contact-button.whatsapp{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff}.contact-button.email{background:linear-gradient(135deg,#ea4335,#c5221f);color:#fff}.contact-button:hover{transform:translateY(-4px);box-shadow:0 6px 16px #0003}.contact-icon{font-size:2.5rem}.contact-text{font-size:1.1rem}.media-gallery{background:#f9f9f9}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.gallery-filters{display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1rem;border:2px solid #667eea;background:#fff;color:#667eea;border-radius:20px;cursor:pointer;font-weight:500;transition:all .2s}.filter-btn:hover{background:#f0f0f0}.filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.gallery-item{position:relative;aspect-ratio:1;overflow:hidden;border-radius:12px;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;background:#f0f0f0}.gallery-item:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.gallery-image,.gallery-video{width:100%;height:100%;object-fit:cover}.gallery-video-thumbnail{position:relative;width:100%;height:100%}.play-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;border-radius:50%;width:60px;height:60px;display:flex;align-items:center;justify-content:center;transition:all .2s}.play-icon{color:#fff;font-size:1.5rem;margin-left:4px}.gallery-item:hover .play-overlay{background:#667eeae6;transform:translate(-50%,-50%) scale(1.1)}.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.5) 100%);opacity:0;transition:opacity .2s;display:flex;align-items:flex-end;justify-content:flex-end;padding:1rem}.gallery-item:hover .gallery-overlay{opacity:1}.overlay-content{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;width:100%}.media-type-badge{font-size:1.5rem;background:#ffffffe6;padding:.25rem .5rem;border-radius:6px}.linked-badge{background:#667eeae6;color:#fff;padding:.25rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.caption-preview{background:#000000b3;color:#fff;padding:.5rem;border-radius:6px;font-size:.85rem;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-media{text-align:center;color:#666;font-style:italic;padding:2rem}.media-modal{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;animation:scaleIn .2s}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.modal-close{position:absolute;top:-40px;right:0;background:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#333;transition:all .2s;z-index:1001}.modal-close:hover{background:#667eea;color:#fff;transform:rotate(90deg)}.modal-media{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px;box-shadow:0 4px 20px #00000080}.modal-caption{color:#fff;margin-top:1rem;text-align:center;font-size:.9rem;opacity:.8}.modal-link-info{margin-bottom:.5rem;padding:.5rem 1rem;background:#667eea33;border-radius:6px;border:1px solid rgba(102,126,234,.5)}.modal-link-info strong{color:#fff;font-size:1rem}@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.gallery-header{flex-direction:column;align-items:flex-start}.modal-content{max-width:95vw;max-height:95vh}}.App{min-height:100vh;background:#f5f5f5}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-container{color:#d32f2f}.error-container code{background:#f5f5f5;padding:.25rem .5rem;border-radius:4px;font-family:monospace}.footer{background:#333;color:#fff;text-align:center;padding:2rem;margin-top:3rem}.footer p{margin:0;font-size:.9rem}
