*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-width:320px;min-height:100vh}@media(min-width:1024px){body{background:linear-gradient(135deg,#667eea,#764ba2);padding:0}}#root{min-height:100vh}a{color:inherit;text-decoration:none;transition:opacity .2s}a:hover{opacity:.8}button{font-family:inherit}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}.vcard-app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-background)}@media(min-width:768px){.vcard-app{max-width:100%}}@media(min-width:1024px){.vcard-app{max-width:800px;margin:2rem auto;box-shadow:0 10px 40px #00000026;border-radius:24px;overflow:hidden}}.vcard-header{position:sticky;top:0;z-index:100;background:linear-gradient(to bottom,#f8fafc,#004a73);padding-bottom:1rem}@media(min-width:1024px){.vcard-header{border-radius:24px 24px 0 0}}.banner{background-color:var(--color-accent);height:140px;display:flex;align-items:center;justify-content:center;color:var(--color-textLight);font-size:1rem;border-bottom:2px solid var(--color-border)}.banner-image{padding:0;overflow:hidden;background-color:#fff}.banner-img{width:100%;height:100%;object-fit:cover;object-position:left center;display:block}.profile-photo-container{display:flex;justify-content:center;margin-top:-60px;position:relative;z-index:10}.profile-photo{width:100px;height:100px;border-radius:8px;border:4px solid var(--color-active);object-fit:cover;background-color:var(--color-accent);box-shadow:0 2px 8px #0000001a}.user-name{text-align:center;margin-top:.5rem;padding:.5rem 1rem}.user-name h2{margin:0;font-size:1.5rem;color:#000;font-weight:600}.social-icons{display:flex;justify-content:center;align-items:center;gap:.8rem;padding:.8rem 1rem;background-color:transparent;margin:.5rem 1rem;border-radius:4px}.social-divider{width:1px;height:40px;background-color:#0003;margin:0 .5rem}.social-icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px #0000001a}.social-icon:hover{transform:translateY(-3px);box-shadow:0 4px 8px #0003}.social-svg{width:24px;height:24px}.download-vcard-container{display:flex;flex-direction:column;align-items:center;gap:.3rem}.download-vcard{width:56px;height:56px;background-color:#fff;color:#00a3ad;box-shadow:0 3px 6px #00000026;display:flex;align-items:center;justify-content:center}.download-vcard i{font-size:28px;color:#00a3ad}.download-vcard:hover i{font-size:28px;color:#fff}.download-vcard:hover{background-color:#008c95;filter:brightness(1.1);transform:translateY(-4px);box-shadow:0 6px 12px #00000040}.download-label{font-size:.75rem;color:#00a3ad;font-weight:600;text-align:center;white-space:nowrap}.download-vcard .social-svg{width:28px;height:28px}.social-facebook{background-color:#3b5998;color:#fff}.social-twitter{background-color:#55acee;color:#fff}.social-tiktok{background-color:#000;color:#fff}.social-instagram{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff}.social-linkedin{background-color:#0077b5;color:#fff}.social-whatsapp{background-color:#25d366;color:#fff}@media(min-width:768px){.banner{height:180px;font-size:1.2rem}.banner-img{object-fit:cover;object-position:center}.profile-photo{width:120px;height:120px}.profile-photo-container{margin-top:-80px}.user-name h2{font-size:1.8rem}.social-icons{gap:1rem}.social-icon{width:45px;height:45px;font-size:1rem}}.dynamic-content{background:linear-gradient(to bottom,#004a73 0% 100%);min-height:400px;padding:1.5rem 1.5rem 6rem;position:relative;overflow:hidden;flex:1}.dynamic-content:before{content:"";position:absolute;top:-50px;right:-50px;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%;z-index:0}.dynamic-content:after{content:"";position:absolute;bottom:-80px;left:-80px;width:250px;height:250px;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);border-radius:50%;z-index:0}.info-content{display:flex;flex-direction:column;gap:1.5rem;position:relative;z-index:1}.info-section,.contact-section{position:relative;z-index:1}.info-section h3,.contact-section h3{font-size:.9rem;color:var(--color-textSecondary);margin:0 0 1rem;font-weight:600;letter-spacing:.5px}.info-section p{color:var(--color-textPrimary);line-height:1.6;margin:0;white-space:pre-line}.read-more-btn{background:none;border:none;color:#006eb3;font-size:.9rem;font-weight:600;cursor:pointer;padding:.5rem 0;margin-top:.5rem;transition:opacity .2s;display:inline-flex;align-items:center;gap:.3rem}.read-more-btn:hover{opacity:.7}.read-more-btn:after{content:"→";transition:transform .2s}.read-more-btn:hover:after{transform:translate(4px)}.contact-list{display:flex;flex-direction:column;gap:.8rem}.contact-item{display:flex;align-items:center;gap:1rem;background-color:transparent;padding:1rem 0;border-bottom:1px solid var(--color-border);transition:opacity .2s}.contact-item:last-child{border-bottom:none}.contact-item:hover{opacity:.8}.contact-icon{font-size:1.5rem;min-width:40px;text-align:center}.contact-icon-wrapper{font-size:1.5rem;min-width:40px;text-align:center;display:flex;align-items:center;justify-content:center;color:#00a3ad}.contact-icon-wrapper i{font-size:1.5rem}.contact-icon-img{width:32px;height:32px;object-fit:contain;min-width:40px}.contact-info{display:flex;flex-direction:column;gap:.2rem;flex:1}.contact-label{font-size:.8rem;color:var(--color-textLight);font-weight:500}.contact-value{color:var(--color-textPrimary);font-size:.95rem;text-decoration:none;font-weight:500}.contact-value:hover{opacity:.7}.map-container{margin-top:1.5rem;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px #0000004d}.map-container iframe{display:block}.servicios-content,.portafolio-content,.otros-content{color:var(--color-textPrimary)}.servicios-content h3,.portafolio-content h3,.otros-content h3{font-size:1.2rem;margin:0 0 1.5rem;color:var(--color-textSecondary)}.servicios-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;position:relative;z-index:1}.servicio-card{background-color:#ffffff0d;padding:2rem 1.5rem;border-radius:12px;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center;text-align:center;transition:transform .2s,box-shadow .2s}.servicio-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000004d}.servicio-icon{font-size:3rem;color:#00a3ad;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center}.servicio-icon i{font-size:3rem}.servicio-card h4{margin:0 0 1rem;color:var(--color-textPrimary);font-size:1.2rem;font-weight:600}.servicio-description{margin:0 0 1.5rem;color:var(--color-textSecondary);font-size:.95rem;line-height:1.6}.portfolio-button{background-color:#654ea3;color:#fff;border:none;padding:.8rem 2rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;transition:background-color .2s,transform .2s}.portfolio-button:hover{background-color:#533d85;transform:scale(1.05)}.portfolio-button:active{transform:scale(.98)}@media(min-width:768px){.dynamic-content{padding:2rem 3rem;min-height:500px}.info-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.contact-item{padding:1.2rem}.servicios-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.servicio-card{padding:2.5rem 2rem}}@media(min-width:1024px){.dynamic-content{max-width:1200px;margin:0 auto}}.background-shapes{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;pointer-events:none;z-index:0}.shape{position:absolute;color:#ffffff0d}.shape-1{width:250px;height:250px;top:-80px;right:-80px}.shape-2{width:350px;height:350px;bottom:-100px;left:-100px}.shape-3{width:180px;height:180px;top:50px;left:-60px}.shape-4{width:300px;height:200px;top:-50px;right:20%;transform:rotate(15deg)}.shape-5{width:120px;height:120px;bottom:80px;right:30px}@media(min-width:768px){.shape-1{width:350px;height:350px;top:-120px;right:-120px}.shape-2{width:450px;height:450px;bottom:-150px;left:-150px}.shape-3{width:220px;height:220px;top:80px;left:-80px}.shape-4{width:400px;height:250px;top:-80px}.shape-5{width:150px;height:150px;bottom:120px;right:50px}}.modal-overlay{position:fixed;inset:0;background-color:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:#004a73;border-radius:16px;padding:2rem;max-width:90vw;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:1rem;right:1rem;background-color:#ffffff1a;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-textPrimary);font-size:1.5rem;transition:background-color .2s}.modal-close:hover{background-color:#fff3}.modal-title{color:var(--color-textPrimary);margin:0 0 1.5rem;font-size:1.5rem;text-align:center}.modal-gallery{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.gallery-image-container{flex:1;position:relative;border-radius:12px;overflow:hidden;background-color:#0003;display:flex;align-items:center;justify-content:center;min-height:300px;max-height:70vh}.gallery-image{width:100%;height:100%;display:block;object-fit:contain;max-height:70vh}.gallery-counter{position:absolute;bottom:1rem;right:1rem;background-color:#000000b3;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.gallery-nav{background-color:#ffffff1a;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-textPrimary);font-size:1.5rem;transition:background-color .2s;flex-shrink:0}.gallery-nav:hover{background-color:#fff3}.gallery-thumbnails{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.thumbnail{width:80px;height:60px;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .2s;opacity:.6}.thumbnail:hover{opacity:.8}.thumbnail.active{border-color:#00a3ad;opacity:1}.thumbnail img{width:100%;height:100%;object-fit:cover;display:block}@media(max-width:768px){.modal-content{padding:1.5rem}.modal-gallery{flex-direction:column}.gallery-nav{width:36px;height:36px}.gallery-nav.prev,.gallery-nav.next{position:absolute;top:50%;transform:translateY(-50%);z-index:10}.gallery-nav.prev{left:.5rem}.gallery-nav.next{right:.5rem}.thumbnail{width:60px;height:45px}}.tab-navigation{background:linear-gradient(to top,#004a73,#005a8a);padding:.5rem;position:sticky;bottom:0;box-shadow:0 -2px 10px #0000004d;z-index:100}@media(min-width:1024px){.tab-navigation{border-radius:0 0 24px 24px;overflow:hidden}}.tabs-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem;max-width:1200px;margin:0 auto}.tabs-container[data-tab-count="1"]{grid-template-columns:1fr;max-width:300px}.tabs-container[data-tab-count="2"]{grid-template-columns:repeat(2,1fr);max-width:400px}.tabs-container[data-tab-count="3"]{grid-template-columns:repeat(3,1fr);max-width:600px}.tabs-container[data-tab-count="4"]{grid-template-columns:repeat(4,1fr)}@media(min-width:1024px){.tabs-container{max-width:100%;gap:.3rem}.tabs-container[data-tab-count="1"]{max-width:250px}.tabs-container[data-tab-count="2"]{max-width:400px}.tabs-container[data-tab-count="3"]{max-width:550px}}.tab-button{background-color:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#cbd5e1;padding:.8rem .5rem;font-size:.85rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .3s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(min-width:1024px){.tab-button{padding:1rem .3rem;font-size:.7rem}}.tab-button:hover{background-color:#ffffff1a;border-color:#fff3}.tab-button.active{background-color:#654ea3;color:#fff;font-weight:600;border-color:#654ea3;box-shadow:0 2px 8px #654ea366}@media(min-width:768px){.tab-navigation{padding:.8rem 1rem}.tabs-container{gap:1rem}.tab-button{padding:1rem 1.5rem;font-size:1rem}}@media(min-width:1024px){.tabs-container{grid-template-columns:repeat(4,minmax(150px,200px));justify-content:center}}
