*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #C96B4F;--primary-dark: #A85640;--secondary-color: #D47B5C;--gold: #E8D4A8;--gold-light: #F5ECD8;--gold-dark: #C9B896;--text-color: #3D2C24;--text-light: #6B5B52;--bg-light: #FDF8F0;--bg-warm: #FAF3E8;--border-color: #E8DFD4;--shadow: 0 4px 6px -1px rgba(61, 44, 36, .08), 0 2px 4px -1px rgba(61, 44, 36, .04);--shadow-lg: 0 10px 15px -3px rgba(61, 44, 36, .1), 0 4px 6px -2px rgba(61, 44, 36, .05);--shadow-warm: 0 8px 24px rgba(201, 107, 79, .15)}html,body{height:100%}body{font-family:Lato,sans-serif;font-size:16px;line-height:1.6;color:var(--text-color);background-color:#fff;overflow-x:hidden;display:flex;flex-direction:column}#root{display:flex;flex-direction:column;min-height:100vh}main{flex:1}h1,h2,h3,h4,h5,h6{font-weight:700}.container{max-width:1200px;margin:0 auto;padding:0 20px}.navbar{position:fixed;top:0;width:100%;background-color:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--border-color);z-index:1000;transition:all .3s ease}.nav-container{max-width:1200px;margin:0 auto;padding:1rem 20px;display:flex;justify-content:space-between;align-items:center}.nav-logo h2{color:var(--primary-color);font-size:1.5rem}.nav-menu{display:flex;list-style:none;gap:2rem}.nav-link{text-decoration:none;color:var(--text-color);font-weight:500;transition:color .3s ease;position:relative;cursor:pointer;display:inline-block}.nav-logo a{text-decoration:none}.nav-link:hover,.nav-link.active{color:var(--primary-color)}.nav-link.active:after{content:"";position:absolute;bottom:-5px;left:0;width:100%;height:2px;background-color:var(--primary-color)}.hamburger{display:none;flex-direction:column;cursor:pointer;gap:5px}.bar{width:25px;height:3px;background-color:var(--text-color);transition:all .3s ease;border-radius:3px}.section{padding:100px 0;display:block;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.section-title{font-size:2.5rem;margin-bottom:3rem;text-align:center;color:var(--text-color);position:relative;display:inline-block;width:100%}.section-title:after{content:"";position:absolute;bottom:-.75rem;left:50%;transform:translate(-50%);width:60px;height:3px;background-color:var(--primary-color);border-radius:2px}.home{padding:120px 0 100px}.home-content{text-align:center;max-width:800px;margin:0 auto}.home-text{animation:fadeInLeft .8s ease}.home-title{font-size:3.5rem;margin-bottom:1rem;color:var(--text-color);line-height:1.2}.home-title-secondary{font-size:.75em}.home-subtitle{font-size:1.5rem;color:var(--primary-color);margin-bottom:1.5rem;font-weight:600}.home-description{font-size:1.1rem;color:var(--text-light);margin-bottom:2rem;line-height:1.8}.home-buttons{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.btn{padding:12px 30px;border-radius:8px;text-decoration:none;font-weight:600;transition:all .3s ease;display:inline-block;cursor:pointer;border:none}.btn-primary{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;box-shadow:0 4px 12px #c96b4f40}.btn-primary:hover{background:linear-gradient(135deg,var(--secondary-color) 0%,var(--primary-color) 100%);transform:translateY(-2px);box-shadow:0 6px 16px #c96b4f59}.btn-secondary{background-color:transparent;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-secondary:hover{background-color:var(--primary-color);color:#fff;transform:translateY(-2px)}.profile-content{display:grid;grid-template-columns:350px 1fr;gap:3rem}.profile-card{background:linear-gradient(180deg,var(--bg-light) 0%,var(--bg-warm) 100%);border-radius:16px;padding:2rem;box-shadow:var(--shadow);height:fit-content;border:1px solid var(--border-color)}.profile-header{text-align:center;margin-bottom:2rem}.profile-avatar{width:150px;height:150px;margin:0 auto 1rem;border-radius:50%;background:linear-gradient(135deg,var(--primary-color) 0%,var(--gold) 100%);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-warm);border:3px solid var(--gold-light)}.profile-avatar img,.profile-avatar .image-skeleton-wrapper img{width:100%;height:100%;object-fit:cover;border-radius:50%}.profile-card h3{font-size:1.5rem;margin-bottom:.5rem}.profile-role{color:var(--primary-color);font-weight:600}.profile-details{margin-top:2rem}.detail-item{margin-bottom:1rem;color:var(--text-light)}.detail-item strong{color:var(--text-color);display:block;margin-bottom:.25rem}.profile-info h3{margin-top:2rem;margin-bottom:1rem;color:var(--text-color)}.profile-info h3:first-child{margin-top:0}.profile-info p{color:var(--text-light);margin-bottom:1.5rem;line-height:1.8}.skill-section{margin-bottom:1.5rem}.skill-section:last-child{margin-bottom:2rem}.skill-section-header{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-light);margin-bottom:.6rem}.skills{display:flex;flex-wrap:wrap;gap:.75rem}.skill-tag{background:linear-gradient(135deg,var(--primary-color) 0%,var(--gold-dark) 100%);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;box-shadow:0 2px 4px #c96b4f33}.experience-item{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.experience-item:last-child{margin-bottom:0;border-bottom:none}.experience-item h4{color:var(--text-color);margin-bottom:.5rem}.company{color:var(--primary-color);font-weight:600;margin-bottom:.5rem}.experience-item p{color:var(--text-light);margin:0}.articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem}.article-card{background:var(--bg-light);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;opacity:0;transform:translateY(20px);animation:fadeInUp .6s ease forwards;text-decoration:none;color:inherit;display:flex;flex-direction:column;cursor:pointer;border:1px solid var(--border-color)}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.article-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-warm);border-color:var(--gold)}.article-image{width:100%;height:200px;overflow:hidden}.article-image img{width:100%;height:100%;object-fit:cover}.image-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--primary-color) 0%,var(--gold) 100%);opacity:.85}.image-skeleton-wrapper{position:relative;width:100%;height:100%}.image-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,var(--bg-warm) 0%,var(--gold-light) 50%,var(--bg-warm) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:inherit;z-index:1}.profile-avatar .image-skeleton{border-radius:50%}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.image-skeleton-wrapper img{transition:opacity .3s ease;position:relative;z-index:2;width:100%;height:100%;object-fit:cover}.image-skeleton-wrapper img.image-loading{display:none}.image-skeleton-wrapper img.image-loaded{display:block}.article-content{padding:1.5rem;display:flex;flex-direction:column;flex:1}.article-date{font-size:.85rem;color:var(--text-light)}.article-content h3{margin:.5rem 0 1rem;color:var(--text-color);font-size:1.25rem}.article-content p{color:var(--text-light);margin-bottom:1rem;line-height:1.6}.article-link{color:var(--primary-color);text-decoration:none;font-weight:600;transition:color .3s ease;margin-top:auto}.article-card:hover .article-link{color:var(--secondary-color)}.article-detail{padding:120px 0 60px}.not-found{padding:150px 0 120px;display:flex;align-items:center;justify-content:center}.not-found-content{text-align:center;max-width:500px;margin:0 auto}.not-found-title{font-size:2.5rem;color:var(--text-color);margin-bottom:1rem;font-weight:700}.not-found-message{font-size:1.1rem;color:var(--text-light);margin-bottom:2rem;line-height:1.6}@media(max-width:768px){.not-found-title{font-size:2rem}.not-found-message{font-size:1rem}}@media(max-width:480px){.section.not-found{padding:130px 0 100px}.not-found-title{font-size:1.75rem}.not-found-message{font-size:.95rem}}.back-link{color:var(--primary-color);text-decoration:none;font-weight:600;transition:color .3s ease}.back-link:hover{color:var(--secondary-color)}.back-link-wrapper{display:flex;justify-content:center;margin-top:3rem}.recent-posts{margin-top:4rem;padding-top:3rem;border-top:2px solid var(--border-color)}.recent-posts-title{font-size:2rem;margin-bottom:2rem;color:var(--text-color);text-align:center}.recent-posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;margin-bottom:2rem}.recent-post-card{background:var(--bg-light);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);transition:transform .3s ease,box-shadow .3s ease;text-decoration:none;color:inherit;display:flex;flex-direction:column;cursor:pointer}.recent-post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.recent-post-image{width:100%;height:180px;overflow:hidden}.recent-post-image img{width:100%;height:100%;object-fit:cover}.recent-post-content{padding:1.25rem;display:flex;flex-direction:column;flex:1}.recent-post-date{font-size:.85rem;color:var(--text-light)}.recent-post-content h3{margin:.5rem 0 .75rem;color:var(--text-color);font-size:1.1rem;line-height:1.4}.recent-post-content p{color:var(--text-light);font-size:.9rem;line-height:1.5;margin:0 0 .75rem;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.recent-post-link{color:var(--primary-color);font-weight:600;font-size:.9rem;display:inline-block;margin-top:auto;transition:color .3s ease}.recent-post-card:hover .recent-post-link{color:var(--secondary-color)}@media(max-width:768px){.recent-posts-title{font-size:1.75rem}.recent-posts-grid{grid-template-columns:1fr}}@media(max-width:480px){.recent-posts{margin-top:3rem;padding-top:2rem}.recent-posts-title{font-size:1.5rem}.recent-post-content h3{font-size:1rem}.recent-post-content p{font-size:.875rem}}.article-detail-content{max-width:800px;margin:0 auto}.article-detail-header{margin-bottom:2rem}.article-detail-title{font-size:2.5rem;margin:1rem 0;color:var(--text-color);line-height:1.2}.article-detail-image{width:100%;margin-bottom:2rem;border-radius:12px;overflow:hidden}.article-detail-image img{width:100%;height:auto;display:block}.article-detail-body{line-height:1.8}.article-description{font-size:1.2rem;color:var(--text-light);margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid var(--border-color)}.article-body{font-size:1.1rem;color:var(--text-color)}.article-body h2{font-size:2rem;margin:2rem 0 1rem;color:var(--text-color)}.article-body h3{font-size:1.5rem;margin:1.5rem 0 .75rem;color:var(--text-color)}.article-body p{margin-bottom:.75rem;line-height:1.8}.article-body ul,.article-body ol{margin:1.5rem 0;padding-left:2rem}.article-body li{margin-bottom:.75rem;line-height:1.8}@media(max-width:768px){.article-detail-title{font-size:2rem}.article-body{font-size:1rem}.article-body h2{font-size:1.75rem}.article-body h3{font-size:1.25rem}}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.gallery-item{position:relative;border-radius:12px;overflow:hidden;box-shadow:var(--shadow);opacity:0;transform:translateY(20px);animation:fadeInUp .6s ease forwards}.gallery-image{width:100%;height:300px;overflow:hidden}.gallery-image img{width:100%;height:100%;object-fit:cover}.gallery-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(61,44,36,.9),transparent);color:#fff;padding:1.25rem 1.5rem}.services-grid{display:flex;flex-direction:column;gap:2rem;max-width:800px;margin:0 auto}.service-card{background:var(--bg-light);border-radius:16px;padding:2.5rem;box-shadow:var(--shadow);opacity:0;transform:translateY(20px);animation:fadeInUp .6s ease forwards;border:1px solid var(--border-color)}.service-icon{font-size:2.5rem;text-align:center;display:flex;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1.5rem;background:linear-gradient(135deg,var(--primary-color) 0%,var(--gold) 100%);border-radius:50%;box-shadow:var(--shadow-warm);line-height:1}.service-title{font-size:1.5rem;margin-bottom:1rem;color:var(--text-color);text-align:center}.service-description{color:var(--text-light);line-height:1.7;margin-bottom:1.5rem;text-align:center}.service-features{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem 1.5rem}.service-features li{padding:.6rem 0;display:flex;align-items:flex-start;gap:.5rem;color:var(--text-color);font-size:.95rem}.service-features li:before{content:"✓";flex-shrink:0;color:var(--primary-color);font-weight:700;font-size:1.1rem;line-height:1.4}.services-contact{margin-top:4rem;padding:3rem 2rem;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 50%,var(--gold-dark) 100%);border-radius:16px;text-align:center;box-shadow:var(--shadow-warm)}.services-contact-content h3{color:#fff;font-size:2rem;margin-bottom:1rem}.services-contact-content p{color:#fffffff2;font-size:1.125rem;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}.btn-whatsapp{display:inline-flex;align-items:center;gap:.75rem;padding:14px 32px;background-color:#25d366;color:#fff;border-radius:8px;text-decoration:none;font-weight:600;font-size:1.125rem;transition:all .3s ease;box-shadow:0 4px 6px #0003}.btn-whatsapp:hover{background-color:#20ba5a;transform:translateY(-2px);box-shadow:0 6px 12px #0000004d}.btn-whatsapp .whatsapp-icon{width:24px;height:24px;filter:brightness(0) invert(1)}.footer{background:linear-gradient(135deg,var(--text-color) 0%,#2A1F1A 100%);color:#fff;padding:3rem 0 1.5rem;text-align:left}.footer .container{display:flex;flex-direction:column;gap:2rem}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.footer-section{display:flex;flex-direction:column;gap:.75rem}.footer-section h3{color:#fff;font-size:1.2rem;font-weight:600;margin:0 0 .5rem;border-bottom:2px solid var(--primary-color);padding-bottom:.5rem;display:inline-block}.footer-section p{color:#ffffffe6;line-height:1.6;margin:0}.map-container{position:relative;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0003;min-height:250px}.map-loading{position:absolute;inset:0;background-color:#ffffffe6;z-index:10;border-radius:8px}.map-loading .section,.map-loading .container{height:100%;padding:0;margin:0}.map-loading .spinner-container{min-height:100%;margin:0}.map-container iframe{display:block;border:0;border-radius:8px}.contact-link{color:#ffffffe6;text-decoration:none;transition:color .3s ease}.contact-link:hover{color:var(--primary-color)}.social-links{display:flex;gap:1.5rem;margin-top:.5rem;flex-wrap:wrap}.social-link{color:#fff;text-decoration:none;transition:color .3s ease}.social-link:hover{color:var(--primary-color)}.footer-bottom{border-top:1px solid rgba(255,255,255,.2);padding-top:1.5rem;text-align:center}.footer-bottom p{color:#fffc;margin:0}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@media(max-width:768px){.hamburger{display:flex}.nav-menu{position:fixed;left:-100%;top:70px;flex-direction:column;background-color:#fffffffa;width:100%;text-align:left;transition:left .3s ease;box-shadow:var(--shadow-lg);padding:2rem 0;gap:0}.nav-menu.active{left:0}.nav-item{margin:1rem 0;padding-left:2rem}.hamburger.active .bar:nth-child(2){opacity:0}.hamburger.active .bar:nth-child(1){transform:translateY(8px) rotate(45deg)}.hamburger.active .bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}.section-title{font-size:2rem}.home-title{font-size:2.5rem}.home-title-secondary{font-size:.75em}.home-subtitle{font-size:1.25rem}.profile-content,.articles-grid,.gallery-grid{grid-template-columns:1fr}.services-grid{max-width:100%}.service-features{grid-template-columns:repeat(2,1fr)}.services-contact{padding:2rem 1.5rem}.services-contact-content h3{font-size:1.75rem}.services-contact-content p{font-size:1rem}.service-card{padding:1.5rem}.service-title{font-size:1.25rem}.service-description{font-size:.95rem}.service-icon{width:70px;height:70px;font-size:2rem}}@media(max-width:480px){.home-title{font-size:2rem}.home-title-secondary{font-size:.75em}.section-title{font-size:1.75rem}.container{padding:0 15px}.section{padding:80px 0}.section.home{padding:100px 0 80px}.service-card{padding:1.25rem}.service-title{font-size:1.125rem}.service-features{grid-template-columns:1fr}.services-contact{padding:1.5rem 1rem}.services-contact-content h3{font-size:1.5rem}.btn{padding:12px 22px;font-size:.95rem;min-height:44px;min-width:44px}.article-detail-title{font-size:1.75rem}.section.article-detail{padding:100px 0 40px}.article-date,.skill-tag{font-size:.875rem}.profile-info p{font-size:1rem}.article-body h2{font-size:1.5rem}.nav-link{padding:.75rem 0;min-height:44px;display:inline-flex;align-items:center}.article-body ul,.article-body ol{padding-left:1.5rem}.home-description{font-size:1rem;line-height:1.7}.article-description{font-size:1rem;line-height:1.6}}.whatsapp-float{position:fixed;bottom:12px;right:20px;width:50px;height:50px;background-color:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #25d36626;z-index:1000;transition:transform .3s ease,box-shadow .3s ease;text-decoration:none}.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 4px 12px #25d36640}.whatsapp-float img{width:28px;height:28px;object-fit:contain}@media(max-width:768px){.footer-content{grid-template-columns:1fr;gap:1.5rem}.footer-section h3{font-size:1.1rem}.whatsapp-float{width:48px;height:48px;bottom:15px;right:15px}.whatsapp-float img{width:26px;height:26px}}@media(max-width:480px){.footer{padding-top:2rem}.footer-content{gap:1.25rem}.footer-section h3{font-size:1rem}.footer-section p{font-size:.9rem}.social-links{gap:1rem}.contact-link{display:inline-block;padding:.15rem 0}.whatsapp-float{width:46px;height:46px;bottom:15px;right:15px}.whatsapp-float img{width:24px;height:24px}}.spinner-container{display:flex;justify-content:center;align-items:center;min-height:400px;padding:2rem}.spinner{width:50px;height:50px;border:4px solid var(--gold-light);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
