:root{--primario:#8d6e63;--secundario:#f5f5f5;--acento:#d4a373;--texto:#333;--shadow:0 10px 30px rgba(0,0,0,0.1);--transition:all 0.3s ease;--font-display:'Playfair Display',Georgia,serif;--font-body:'Montserrat','Segoe UI',system-ui,-apple-system,sans-serif;--font-serif:'Lora','Georgia',serif;--glow:#d4a373;--dark-glow:#8d6e63}*{scroll-behavior:smooth;box-sizing:border-box}html{overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);margin:0;color:var(--texto);background-color:var(--secundario);line-height:1.7;position:relative;overflow-x:hidden}body::before{content:'';position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 50%, rgba(212,163,115,.03) 0%, transparent 50%),radial-gradient(circle at 80% 80%, rgba(141,110,99,.03) 0%, transparent 50%);pointer-events:none;z-index:-1}.hero{background:linear-gradient(135deg,rgba(0,0,0,.3),rgba(0,0,0,.5)),linear-gradient(180deg,rgba(0,0,0,.2) 0%,transparent 40%,transparent 60%,rgba(0,0,0,.35) 100%),url('./imagenes/Pasteis.png') no-repeat center center/cover !important;height:clamp(50vh,100vh,90vh);display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:#fff;position:relative;overflow:visible;background-attachment:fixed;perspective:1200px;clip-path:inset(0 clamp(2%, 4%, 6%) 0 clamp(2%, 4%, 6%) round clamp(100px, 15vw, 200px));padding:clamp(20px,5vw,40px) 10px;box-shadow:inset 0 0 80px rgba(0,0,0,.4),inset 0 0 40px rgba(212,163,115,.15)}@media(max-width:768px){.hero{background-attachment:scroll}}.hero::before{content:'';position:absolute;top:-8px;left:-8px;right:-8px;bottom:-8px;border-radius:clamp(110px, 16vw, 210px);z-index:-1;pointer-events:none;animation:glowFrame 3s ease-in-out infinite;filter:blur(clamp(10px, 3vw, 20px));opacity:0.8}.hero::after{content:'';position:absolute;top:0;left:-100%;width:200%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);animation:shine 5s infinite;pointer-events:none;z-index:2}.hero-content{position:relative;z-index:1;max-width:900px;padding:clamp(20px,5vw,40px);animation:fadeInUp 0.8s cubic-bezier(0.34,1.56,0.64,1);background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,transparent 50%,rgba(0,0,0,.15) 100%);border-radius:clamp(100px, 15vw, 200px);box-shadow:inset 0 0 60px rgba(0,0,0,.3),0 0 60px rgba(212,163,115,.2)}.hero h1{font-family:var(--font-display);font-size:clamp(2.2rem,7vw,5.5rem);margin:0;letter-spacing:clamp(3px,1vw,8px);text-transform:uppercase;color:#fff;padding:0 20px;font-weight:900;text-shadow:0 8px 16px rgba(0,0,0,.9),0 4px 8px rgba(0,0,0,.8),2px 2px 4px rgba(0,0,0,.7),0 0 40px rgba(212,163,115,.6),0 0 20px rgba(212,163,115,.3),3px 3px 6px rgba(0,0,0,.6);animation:titleGlowElite 3.5s ease-in-out infinite alternate,floatTitle 4s ease-in-out infinite;word-break:break-word;line-height:1.1;filter:drop-shadow(0 0 25px rgba(255,215,0,.4)) drop-shadow(0 4px 8px rgba(0,0,0,.8))}.hero-subtitle{font-size:clamp(1rem,3.5vw,1.8rem);font-style:italic;margin:15px 0;color:#ffd700;text-shadow:0 4px 12px rgba(0,0,0,.8),0 2px 6px rgba(0,0,0,.6),0 0 20px rgba(255,215,0,.5),0 0 10px rgba(212,163,115,.4);animation:fadeInUp 1s ease-out 0.2s both;font-weight:600;letter-spacing:1px;font-family:var(--font-serif)}.hero-description{font-size:clamp(0.95rem,2vw,1.2rem);margin:15px 0;color:#fff;text-shadow:0 4px 10px rgba(0,0,0,.7),0 2px 5px rgba(0,0,0,.5),0 0 15px rgba(212,163,115,.2);animation:fadeInUp 1s ease-out 0.4s both;line-height:1.8;letter-spacing:0.5px;font-family:var(--font-body);font-weight:500}.hero-cta{display:flex;gap:clamp(10px,2vw,20px);justify-content:center;flex-wrap:wrap;margin-top:30px;animation:fadeInUp 1s ease-out 0.6s both}nav{background:linear-gradient(135deg,#fff,#f9f7f4);padding:clamp(0.75rem,2vw,1.2rem);position:sticky;top:0;display:flex;justify-content:center;flex-wrap:wrap;gap:clamp(0.5rem,2vw,1.5rem);box-shadow:0 8px 32px rgba(0,0,0,0.12);z-index:1000;backdrop-filter:blur(12px);animation:slideDown 0.5s ease-out;border-bottom:2px solid rgba(212,163,115,.3);overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}nav a{margin:0;text-decoration:none;color:var(--primario);font-weight:700;text-transform:uppercase;font-size:clamp(0.75rem,2vw,1rem);position:relative;padding:0.5rem clamp(0.4rem,1vw,0.8rem);transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);white-space:nowrap;letter-spacing:1px;font-family:var(--font-body);display:inline-flex;align-items:center;min-height:44px}nav a::after{content:'';position:absolute;bottom:0;left:50%;width:0;height:3px;background:linear-gradient(90deg,var(--acento),var(--primario));transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);box-shadow:0 0 15px rgba(212,163,115,.7);transform:translateX(-50%)}nav a:hover{color:var(--acento);text-shadow:0 0 10px rgba(212,163,115,.5)}nav a:hover::after{width:100%;transform:translateX(0)}.section{padding:clamp(40px,8vw,80px) clamp(15px,5vw,40px);max-width:1000px;margin:auto;text-align:center;width:100%;opacity:0;animation:fadeIn 0.8s ease-out forwards;position:relative}.section:nth-of-type(even){animation-delay:0.2s}[data-bg-image]{background-size:cover;background-position:center;background-attachment:fixed;position:relative}[data-bg-image]::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(0,0,0,0.55),rgba(0,0,0,0.45));z-index:1;pointer-events:none}[data-bg-image]>*{position:relative;z-index:2}.section h2{font-family:var(--font-display);font-size:clamp(2rem,5.5vw,3.5rem);color:var(--primario);margin:clamp(15px,2vw,25px) 0 15px;position:relative;display:inline-block;animation:scaleInTitle 0.6s cubic-bezier(0.34,1.56,0.64,1);word-break:break-word;font-weight:900;letter-spacing:1px;line-height:1.2;text-shadow:0 2px 10px rgba(212,163,115,.2)}.section h2::after{content:'';display:block;width:clamp(60px,80px,120px);height:4px;background:linear-gradient(90deg,var(--acento),var(--primario));margin:20px auto;animation:expandWidth 0.8s ease-out,glowPulse 2s ease-in-out infinite;box-shadow:0 0 30px rgba(212,163,115,.8)}.section p{font-size:clamp(1rem,2vw,1.2rem);line-height:1.9;color:#555;letter-spacing:0.4px;font-family:var(--font-serif);font-weight:500}.section-subtitle{font-size:clamp(0.9rem,2.2vw,1.1rem);color:#999;margin-bottom:clamp(20px,3vw,30px);font-style:italic}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(clamp(200px,50vw,280px),1fr));gap:clamp(15px,3vw,30px);margin-top:clamp(20px,3vw,40px)}@media(max-width:768px){.grid{grid-template-columns:1fr;gap:clamp(15px,2vw,20px)}}.card{background:rgba(255,255,255,.95);backdrop-filter:blur(10px);padding:clamp(20px,3vw,30px);border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,0.1);word-wrap:break-word;overflow:hidden;transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);position:relative;perspective:1000px;border:1px solid rgba(212,163,115,.2)}.card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--acento),var(--primario));transform:scaleX(0);transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1);box-shadow:0 0 20px rgba(212,163,115,1)}.card::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 50%), rgba(212,163,115,.15), transparent 50%);opacity:0;transition:opacity 0.3s}.card:hover::before{transform:scaleX(1)}.card:hover::after{opacity:1}.card:hover{transform:translateY(-15px) rotateX(5deg) scale(1.02);box-shadow:0 25px 50px rgba(0,0,0,0.15),inset 0 100px 100px rgba(212,163,115,.08),0 0 40px rgba(212,163,115,.3)}.card h3{color:var(--primario);font-family:var(--font-display);font-size:clamp(1.35rem,3.5vw,2rem);margin:clamp(12px,2vw,18px) 0;line-height:1.3;font-weight:900;letter-spacing:0.5px}.card p{font-size:clamp(0.95rem,1.9vw,1.1rem);color:#666;line-height:1.8;letter-spacing:0.2px}footer{background:linear-gradient(135deg,#0f0f0f,#1f1f1f);color:#fff;padding:clamp(40px,5vw,60px) clamp(15px,5vw,40px) 20px;text-align:center;position:relative;overflow:hidden}footer::before{content:'';position:absolute;top:0;left:-100%;width:200%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);animation:shimmer 4s infinite}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:clamp(20px,3vw,40px);max-width:1000px;margin:0 auto clamp(20px,3vw,40px);text-align:left;animation:fadeIn 0.8s ease-out}@media(max-width:600px){.footer-content{text-align:center}}.footer-section{position:relative;padding-left:0}.footer-section h4{color:var(--acento);font-family:var(--font-display);margin-bottom:clamp(12px,2vw,18px);font-size:clamp(1.25rem,2.8vw,1.5rem);position:relative;display:inline-block;font-weight:900;letter-spacing:1px;text-shadow:0 0 15px rgba(212,163,115,.4)}.footer-section h4::after{content:'';display:block;width:40px;height:2px;background:var(--acento);margin-top:8px;animation:expandWidth 0.6s ease-out}.footer-section p{margin:0;font-size:clamp(0.85rem,1.6vw,0.95rem);color:#ccc;line-height:1.6}.footer-section ul{list-style:none;padding:0;margin:0}.footer-section ul li{margin:clamp(5px,1vw,8px) 0}.footer-section a{color:#ccc;text-decoration:none;transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);position:relative;font-size:clamp(0.85rem,1.6vw,0.95rem);font-family:var(--font-body)}.footer-section a::before{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--acento);transition:width 0.3s}.footer-section a:hover{color:var(--acento);transform:translateX(8px);text-shadow:0 0 10px rgba(212,163,115,.6)}.footer-section a:hover::before{width:100%;box-shadow:0 0 15px rgba(212,163,115,.8)}.social-links{display:flex;gap:clamp(15px,3vw,25px);flex-wrap:wrap;justify-content:center;align-items:center;margin-top:clamp(15px,2vw,20px)}.social-links a{display:inline-flex;align-items:center;justify-content:center;width:clamp(60px,10vw,80px);height:clamp(60px,10vw,80px);border-radius:50%;font-size:clamp(1.8rem,4vw,2.5rem);text-decoration:none;transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);position:relative;overflow:hidden;box-shadow:0 4px 15px rgba(0,0,0,0.2);border:2px solid transparent;min-width:48px;min-height:48px;-webkit-tap-highlight-color:transparent}.social-links a::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(45deg,rgba(255,255,255,0.3),transparent,rgba(255,255,255,0.3));transition:left 0.5s ease;z-index:0}.social-links a>*{position:relative;z-index:1}.social-links a.social-instagram{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);box-shadow:0 4px 15px rgba(224,148,51,0.3)}.social-links a.social-instagram:hover{transform:scale(1.25) rotateZ(12deg) translateY(-5px);box-shadow:0 15px 45px rgba(224,148,51,0.8),inset 0 0 40px rgba(255,255,255,0.3),0 0 30px rgba(212,163,115,.4);border-color:rgba(255,255,255,0.6)}.social-links a.social-instagram:hover::before{left:100%}.social-links a.social-facebook{background:linear-gradient(135deg,#1877f2,#0a66c2);color:#fff;font-weight:bold;font-size:clamp(1.6rem,3.8vw,2.3rem);font-family:Arial,sans-serif;box-shadow:0 4px 15px rgba(24,119,242,0.3)}.social-links a.social-facebook:hover{transform:scale(1.25) rotateZ(-12deg) translateY(-5px);box-shadow:0 15px 45px rgba(24,119,242,0.8),inset 0 0 40px rgba(255,255,255,0.2),0 0 30px rgba(212,163,115,.4);border-color:rgba(255,255,255,0.5)}.social-links a.social-facebook:hover::before{left:100%}@media(max-width:600px){.social-links{gap:clamp(12px,2vw,18px)}.social-links a{width:clamp(55px,12vw,70px);height:clamp(55px,12vw,70px);font-size:clamp(1.6rem,3.5vw,2.2rem);box-shadow:0 2px 10px rgba(0,0,0,0.15)}.social-links a:hover{transform:scale(1.15) rotateZ(8deg)}}.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:clamp(15px,2vw,20px);font-size:clamp(0.8rem,1.5vw,0.9rem);color:#999}.btn{background:linear-gradient(135deg,var(--acento),#c99561);color:#fff;padding:clamp(10px,1.8vw,14px) clamp(20px,3vw,35px);text-decoration:none;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;margin:clamp(8px,1.5vw,10px) clamp(5px,1vw,8px);font-size:clamp(0.85rem,1.8vw,1rem);transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);border:none;cursor:pointer;font-weight:700;box-shadow:0 8px 25px rgba(212,163,115,0.4),0 0 20px rgba(212,163,115,0.2);position:relative;overflow:hidden;white-space:nowrap;font-family:var(--font-body);letter-spacing:0.5px;text-transform:uppercase;min-height:44px}.btn::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,0.3);transform:translate(-50%, -50%);transition:width 0.6s, height 0.6s}.btn:active::before{width:300px;height:300px}.btn-primary{background:linear-gradient(135deg,var(--acento),#c99561)}.btn-primary:hover{background:linear-gradient(135deg,#c99561,#b8844a);transform:translateY(-5px) scale(1.05);box-shadow:0 15px 40px rgba(212,163,115,0.8),0 0 30px rgba(212,163,115,.5);text-shadow:0 0 20px rgba(0,0,0,0.3)}@media(hover:none){.btn-primary:active{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 20px rgba(212,163,115,0.5)}}
.btn-secondary{background:transparent;border:2px solid #fff;color:#fff}.btn-secondary:hover{background:#fff;color:var(--primario);transform:translateY(-3px);box-shadow:0 8px 25px rgba(255,255,255,0.3)}@media(hover:none){.btn-secondary:active{transform:translateY(-1px);background:rgba(255,255,255,0.95)}}#historia{background:linear-gradient(135deg,rgba(141,110,99,.08),rgba(212,163,115,.08));position:relative}#historia::before{content:'';position:absolute;top:-50%;right:-10%;width:400px;height:400px;background:radial-gradient(circle, rgba(212,163,115,.1) 0%, transparent 70%);border-radius:50%;pointer-events:none;animation:float 6s ease-in-out infinite}.historia-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(30px,4vw,40px);margin-top:clamp(20px,3vw,40px);text-align:left;position:relative;z-index:1}@media(max-width:768px){.historia-content{grid-template-columns:1fr;gap:clamp(20px,3vw,30px)}}.historia-content p{font-size:clamp(0.95rem,1.8vw,1.05rem);line-height:1.8;animation:fadeInLeft 0.8s ease-out forwards;opacity:0}.historia-content p:nth-child(odd){animation-delay:0.2s}.historia-content p:nth-child(even){animation-delay:0.4s}.historia-content strong{color:var(--primario);font-family:var(--font-display);font-size:clamp(1.3rem,2.5vw,1.7rem);display:block;margin-bottom:10px;margin-top:clamp(18px,2vw,25px);text-shadow:0 0 25px rgba(212,163,115,.4);font-weight:900;letter-spacing:1px}.especialidad-card{position:relative;transition:all 0.5s cubic-bezier(0.34,1.56,0.64,1);background:#fff;transform-style:preserve-3d;border-radius:16px;padding:clamp(20px,3vw,30px);box-shadow:0 8px 32px rgba(0,0,0,0.1)}.especialidad-card:hover{transform:translateY(-20px) scale(1.08) rotateX(8deg);box-shadow:0 30px 60px rgba(0,0,0,0.25),0 0 50px rgba(212,163,115,0.4)}.especialidad-icon{font-size:clamp(2rem,5vw,4rem);margin-bottom:clamp(15px,2vw,20px);display:block;line-height:1;animation:bounce 2s infinite;filter:drop-shadow(0 4px 8px rgba(212,163,115,0.3))}.especialidad-card h3{margin:clamp(12px,2vw,18px) 0;color:var(--primario);text-shadow:0 0 15px rgba(212,163,115,.3);font-family:var(--font-display);font-size:clamp(1.4rem,3vw,1.8rem);font-weight:900;line-height:1.3;letter-spacing:0.5px}.especialidad-card p{font-size:clamp(0.9rem,1.8vw,1.05rem);line-height:1.8;color:#666;letter-spacing:0.2px}.contacto-section{background:linear-gradient(135deg,rgba(212,163,115,.05),rgba(141,110,99,.05));position:relative}.contacto-section::after{content:'';position:absolute;bottom:0;left:0;right:0;height:100px;background:linear-gradient(180deg,transparent,rgba(212,163,115,.1));pointer-events:none}.contacto-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(clamp(220px,50vw,280px),1fr));gap:clamp(15px,3vw,30px);margin-top:clamp(20px,3vw,40px);position:relative;z-index:1}@media(max-width:600px){.contacto-grid{grid-template-columns:1fr}}.contacto-card{background:rgba(255,255,255,.95);backdrop-filter:blur(12px);padding:clamp(20px,3vw,40px) clamp(15px,3vw,30px);border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,0.1);transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);text-align:center;position:relative;overflow:hidden;border:1px solid rgba(212,163,115,.15)}.contacto-card::before{content:'';position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle, rgba(212,163,115,.1) 0%, transparent 70%);transition:all 0.5s;opacity:0}.contacto-card:hover::before{opacity:1;top:-30%;right:-30%}.contacto-card:hover{transform:translateY(-15px) scale(1.05);box-shadow:0 25px 50px rgba(0,0,0,0.2),inset 0 1px 0 rgba(255,255,255,.8),0 0 40px rgba(212,163,115,.3)}.contacto-icon{font-size:clamp(2.5rem,6vw,3.5rem);margin-bottom:clamp(10px,2vw,15px);display:inline-block;animation:popIn 0.6s cubic-bezier(0.68,.55,.265,1.55)}.contacto-card h3{color:var(--primario);margin:clamp(12px,2vw,18px) 0;position:relative;z-index:1;font-family:var(--font-display);font-size:clamp(1.3rem,3vw,1.7rem);font-weight:900;line-height:1.3;letter-spacing:0.5px}.contacto-card p{font-size:clamp(0.95rem,1.9vw,1.1rem);line-height:1.8;letter-spacing:0.2px}.contacto-card a{color:var(--acento);text-decoration:none;font-weight:700;transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);position:relative;font-family:var(--font-body)}.contacto-card a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--acento);transition:width 0.3s;box-shadow:0 0 10px rgba(212,163,115,.6)}.contacto-card a:hover{color:var(--primario);transform:translateX(5px);text-shadow:0 0 15px rgba(212,163,115,.7)}.contacto-card a:hover::after{width:100%;box-shadow:0 0 20px rgba(212,163,115,.8)}@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}@keyframes slideDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}@keyframes scaleInTitle{from{opacity:0;transform:scale(0.5)}to{opacity:1;transform:scale(1)}}@keyframes expandWidth{from{width:0}to{width:100%}}@keyframes shine{from{left:-100%}to{left:100%}}@keyframes shimmer{from{left:-100%}to{left:100%}}@keyframes float{0%,100%{transform:translateY(0px)}50%{transform:translateY(-20px)}}@keyframes titleGlowElite{from{text-shadow:0 8px 16px rgba(0,0,0,.9),0 4px 8px rgba(0,0,0,.8),2px 2px 4px rgba(0,0,0,.7),0 0 40px rgba(255,215,0,.3),0 0 20px rgba(212,163,115,.2),3px 3px 6px rgba(0,0,0,.6)}to{text-shadow:0 8px 16px rgba(0,0,0,.9),0 4px 8px rgba(0,0,0,.8),2px 2px 4px rgba(0,0,0,.7),0 0 60px rgba(255,215,0,.6),0 0 40px rgba(212,163,115,.5),3px 3px 6px rgba(0,0,0,.6)}}@keyframes floatTitle{0%,100%{transform:translateY(0px)}50%{transform:translateY(-10px)}}@keyframes glowFrame{0%,100%{opacity:0.7;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes glowPulse{0%,100%{box-shadow:0 0 20px rgba(212,163,115,.5),0 0 40px rgba(212,163,115,.2)}50%{box-shadow:0 0 40px rgba(212,163,115,.8),0 0 60px rgba(212,163,115,.4)}}@keyframes gradientShift{0%,100%{opacity:0.5}50%{opacity:0.8}}@keyframes popIn{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}#galeria{padding:clamp(20px,4vw,30px) clamp(15px,5vw,40px) !important}.carousel-wrapper{position:relative;width:100%;margin:clamp(15px,2vw,30px) auto}.carousel-container{position:relative;max-width:100%;margin:0 auto;overflow:hidden;width:100%;box-sizing:border-box;border-radius:20px;box-shadow:0 15px 50px rgba(0,0,0,0.25),0 0 30px rgba(212,163,115,.3)}.carousel-track{display:flex;transition:transform 0.6s cubic-bezier(0.34,1.56,0.64,1);will-change:transform;background:#000}.carousel-slide{min-width:100%;user-select:none;border:0;height:clamp(250px,60vw,439px);aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;position:relative;background:#000}.carousel-slide.active .carousel-image{animation:zoomIn 0.6s ease-out}.carousel-image{width:100%;height:100%;object-fit:cover;transition:all 0.3s ease;cursor:pointer}.carousel-slide:hover .carousel-image{transform:scale(1.05)}.slide-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,0.9));color:#fff;padding:clamp(15px,3vw,25px);font-size:clamp(1rem,2.2vw,1.3rem);font-weight:700;transform:translateY(100%);transition:transform 0.3s ease;z-index:5;font-family:var(--font-body);letter-spacing:0.5px;text-transform:uppercase;text-shadow:0 2px 8px rgba(0,0,0,.6)}.carousel-slide:hover .slide-caption{transform:translateY(0)}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.5);color:#fff;border:0;padding:clamp(8px,1.5vw,14px) clamp(10px,2vw,16px);cursor:pointer;font-size:clamp(1rem,2vw,1.4rem);z-index:10;border-radius:50%;transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);box-shadow:0 8px 25px rgba(0,0,0,0.5),0 0 20px rgba(212,163,115,.3);user-select:none;backdrop-filter:blur(8px);font-weight:bold;border:2px solid rgba(212,163,115,.3);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.carousel-btn:hover{background:rgba(0,0,0,0.85);transform:translateY(-50%) scale(1.3);box-shadow:0 12px 40px rgba(212,163,115,1),0 0 30px rgba(212,163,115,.7),inset 0 0 20px rgba(212,163,115,.3);color:#ffd700;border-color:rgba(212,163,115,.8)}.carousel-btn:active{transform:translateY(-50%) scale(0.95)}.carousel-btn.prev{left:clamp(8px,2vw,20px)}.carousel-btn.next{right:clamp(8px,2vw,20px)}.carousel-info{text-align:center;margin-top:clamp(15px,2vw,20px)}.slide-counter{display:inline-block;background:linear-gradient(135deg,var(--primario),var(--acento));color:#fff;padding:clamp(8px,1.2vw,12px) clamp(14px,2.2vw,20px);border-radius:25px;font-size:clamp(0.9rem,1.8vw,1.1rem);font-weight:700;box-shadow:0 8px 25px rgba(141,110,99,0.4),0 0 20px rgba(212,163,115,.3);font-family:var(--font-body);letter-spacing:0.5px}.carousel-dots-container{display:flex;gap:clamp(6px,1.5vw,10px);justify-content:center;margin-top:clamp(15px,2vw,20px);flex-wrap:wrap}@media(max-width:480px){.carousel-btn{padding:6px 10px;font-size:1rem}.carousel-btn.prev{left:8px}.carousel-btn.next{right:8px}}.lightbox-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.95);z-index:2000;display:none;align-items:center;justify-content:center;animation:fadeIn 0.3s ease}.lightbox-modal.active{display:flex}.lightbox-content{position:relative;width:90%;height:90vh;max-width:1200px;display:flex;align-items:center;justify-content:center;animation:slideUp 0.4s cubic-bezier(0.34,1.56,0.64,1)}.lightbox-image{max-width:100%;max-height:85%;object-fit:contain;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,0.5)}.lightbox-close{position:absolute;top:20px;right:30px;background:rgba(255,255,255,0.1);color:#fff;border:2px solid rgba(255,255,255,0.3);width:50px;height:50px;border-radius:50%;font-size:2rem;cursor:pointer;transition:all 0.3s;z-index:10;display:flex;align-items:center;justify-content:center;padding:0}.lightbox-close:hover{background:rgba(255,255,255,0.2);border-color:#fff;transform:rotate(90deg)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(212,163,115,0.7);color:#fff;border:0;padding:clamp(12px,2vw,18px);font-size:clamp(1.2rem,3vw,2rem);cursor:pointer;z-index:10;border-radius:8px;transition:all 0.3s;font-weight:bold}.lightbox-nav:hover{background:rgba(212,163,115,0.95);transform:translateY(-50%) scale(1.15)}.lightbox-prev{left:20px}.lightbox-next{right:20px}.lightbox-caption{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:#fff;font-size:clamp(0.9rem,2vw,1.1rem);background:rgba(0,0,0,0.6);padding:clamp(10px,1.5vw,15px) clamp(15px,2vw,20px);border-radius:8px;backdrop-filter:blur(4px);max-width:80%;text-align:center;font-weight:500}@keyframes zoomIn{from{transform:scale(1.1);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideUp{from{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}#social{display:flex;flex-direction:column;align-items:center}#social>div{width:100%;display:flex;justify-content:center;flex-direction:column;align-items:center}#social .instagram-media,#social .fb-page{margin:0 auto !important}#social iframe{margin-left:auto;margin-right:auto}.facebook-reel-container{position:relative;width:100%;max-width:560px;margin:clamp(15px,2vw,20px) auto;cursor:pointer;display:block;border-radius:12px;overflow:hidden;transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);box-shadow:0 8px 25px rgba(0,0,0,0.1)}.reel-thumbnail{width:100%;height:auto;display:block;border-radius:12px;transition:all 0.4s ease;box-shadow:inset 0 0 20px rgba(0,0,0,0.2)}.facebook-reel-container:hover .reel-thumbnail{filter:brightness(0.9) contrast(1.1);transform:scale(1.05)}.facebook-reel-container:hover{transform:scale(1.03) translateY(-5px);box-shadow:0 15px 40px rgba(0,0,0,0.2),0 0 30px rgba(212,163,115,0.5)}.play-button{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:clamp(60px,12vw,80px);height:clamp(60px,12vw,80px);background:#fff;border:0;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:0;transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);z-index:10;box-shadow:0 12px 30px rgba(0,0,0,.5),0 0 30px rgba(212,163,115,.5);animation:pulse 2.5s infinite;border:3px solid rgba(212,163,115,.4)}.play-button::before{content:'';width:0;height:0;border-left:clamp(20px,4vw,28px) solid #1877f2;border-top:clamp(12px,3vw,18px) solid transparent;border-bottom:clamp(12px,3vw,18px) solid transparent;transition:all 0.3s}.play-button:hover{background:#f5f5f5;transform:translate(-50%,-50%) scale(1.35);box-shadow:0 18px 45px rgba(0,0,0,.6),0 0 40px rgba(24,119,242,.8),inset 0 0 20px rgba(212,163,115,.3);border-color:rgba(212,163,115,.8)}.play-button:hover::before{border-left-color:#125bd4}.facebook-reel-iframe{width:100%;max-width:560px;height:auto;min-height:315px;margin:clamp(15px,2vw,20px) auto;border-radius:12px;display:block;box-shadow:0 10px 30px rgba(0,0,0,0.15)}@keyframes pulse{0%,100%{box-shadow:0 12px 30px rgba(0,0,0,.5),0 0 0 0 rgba(24,119,242,0.8)}50%{box-shadow:0 12px 30px rgba(0,0,0,.5),0 0 0 25px rgba(24,119,242,0)}}.carousel-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:rgba(141,110,99,0.3);margin:0 clamp(6px,1vw,8px);cursor:pointer;transition:all 0.3s ease;user-select:none}@media(max-width:480px){.carousel-dot{width:8px;height:8px}}/* NUEVOS EFECTOS VISUALES DE ALTO IMPACTO */

/* Wave effect border */
@keyframes wave {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

@keyframes waveBorder {
  0%, 100% { background-position: 0 0; }
  50% { background-position: 50px 50px; }
}

/* Efecto de texto animado */
@keyframes flicker {
  0%, 19%, 21%, 23%, 25%, 54%, 56%, 100% {
    text-shadow: 0 0 10px rgba(212, 163, 115, 0.5),
                 0 0 20px rgba(212, 163, 115, 0.3);
  }
  20%, 24%, 55% {
    text-shadow: 0 0 30px rgba(212, 163, 115, 1),
                 0 0 40px rgba(212, 163, 115, 0.6);
  }
}

/* Rainbow gradient animation */
@keyframes rainbowShift {
  0% { background-position: 0% center; }
  100% { background-position: 200% center; }
}

/* Spin animation para iconos */
@keyframes spinSlow {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* Pulse mejorado */
@keyframes pulseLarge {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.1); }
}

/* Efecto de resplandor que va y viene */
@keyframes glowWave {
  0%, 100% { 
    box-shadow: 0 0 5px rgba(212, 163, 115, 0.5);
  }
  50% { 
    box-shadow: 0 0 25px rgba(212, 163, 115, 0.9),
                0 0 40px rgba(212, 163, 115, 0.5);
  }
}

.section {
  position: relative;
}

/* Línea decorativa animada */
.section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, #d4a373, transparent);
  animation: expandWidth 2s ease-in-out infinite;
}

.card p {
  font-family: var(--font-serif);
  font-weight: 500;
}

/* Estilo especial para testimonios */
.testimonial {
  border-left: 4px solid var(--acento);
  padding-left: 20px;
  font-style: italic;
  color: #666;
}

/* OPTIMIZACIONES PARA DISPOSITIVOS TACTILES Y MÓVILES */

/* Detectar si el dispositivo soporta hover */
@media(hover:none) and (pointer:coarse){
  /* Deshabilitar efectos hover en touch devices y usar active en su lugar */
  .carousel-btn:hover{
    transform:translateY(-50%) scale(1.2);
    box-shadow:0 8px 30px rgba(0,0,0,0.5),0 0 20px rgba(212,163,115,.5);
  }
  
  .card:active{
    transform:translateY(-8px) scale(1.01);
    box-shadow:0 15px 40px rgba(0,0,0,0.1),0 0 30px rgba(212,163,115,.2);
  }
  
  /* Mejorar visibilidad de presión en elementos interactivos */
  a{
    -webkit-tap-highlight-color:rgba(212,163,115,0.2);
  }
  
  button{
    -webkit-tap-highlight-color:rgba(212,163,115,0.2);
  }
}

/* Mejorar viewport para mobile */
@media(max-width:480px){
  /* Aumentar área de touch para enlaces pequeños */
  a:not(.btn){
    padding:8px 4px;
    min-height:44px;
    display:inline-flex;
    align-items:center;
  }
  
  /* Mejorar accesibilidad en formularios y inputs */
  input,textarea,select{
    font-size:16px !important;
    min-height:44px;
    padding:12px;
    border-radius:8px;
  }
  
  /* Mejoras en scroll momentum */
  .carousel-container,
  nav,
  .contacto-grid{
    -webkit-overflow-scrolling:touch;
  }
}

/* Asegurar buena legibilidad en pantallas pequeñas */
@media(max-width:380px){
  body{
    font-size:clamp(13px, 3vw, 16px);
  }
  
  /* Mejorar espaciado en elementos muy pequeños */
  .section h2::after{
    width:clamp(40px,60px,100px);
  }
}

/* Prevenir zoom accidental en inputs */
@media(max-width:480px){
  input[type="text"],
  input[type="email"],
  input[type="phone"],
  textarea{
    font-size:16px !important;
  }
}.carousel-dot:hover{background:rgba(141,110,99,0.6);transform:scale(1.2)}@media(max-width:1024px){.section{padding:clamp(35px,8vw,75px) clamp(15px,5vw,45px)}}@media(max-width:768px){.hero{height:clamp(50vh,80vh,90vh);background-attachment:scroll;clip-path:inset(0 2% 0 2% round 80px)}.hero-content{padding:clamp(25px,5vw,45px)}.hero-cta{flex-direction:column;align-items:center;gap:clamp(10px,2vw,15px)}.btn{width:100%;max-width:300px;min-height:48px;display:flex;align-items:center;justify-content:center}nav{padding:clamp(0.5rem,1.5vw,1rem);gap:clamp(0.4rem,1.5vw,1rem)}nav a{padding:0.5rem clamp(0.3rem,0.8vw,0.5rem);font-size:clamp(0.7rem,1.6vw,0.95rem);min-height:44px;display:flex;align-items:center}.section{padding:clamp(30px,6vw,50px) clamp(15px,4vw,20px)}.section h2{font-size:clamp(1.6rem,4.5vw,2.8rem)}.footer-content{gap:clamp(15px,2vw,25px)}.contacto-grid{gap:clamp(15px,2vw,20px)}.especialidad-card:hover{transform:translateY(-8px) scale(1.02)}.carousel-btn{padding:clamp(10px,2vw,14px) clamp(12px,2.5vw,16px);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}}@media(max-width:600px){.hero{height:clamp(45vh,75vh,85vh);clip-path:inset(0 1.5% 0 1.5% round 60px)}.hero-content{padding:clamp(25px,6vw,45px)}.section{padding:clamp(28px,5.5vw,40px) clamp(12px,4vw,18px)}.section h2{font-size:clamp(1.5rem,4vw,2.3rem)}.grid{gap:clamp(12px,2vw,15px)}.footer-content{grid-template-columns:1fr}.card{padding:clamp(18px,2.5vw,25px)}.card h3{font-size:clamp(1.2rem,3vw,1.75rem)}.card p{font-size:clamp(0.9rem,1.8vw,1.05rem)}.carousel-slide{height:clamp(220px,55vw,360px)}}@media(max-width:480px){.hero{height:clamp(45vh,65vh,75vh);padding:15px;clip-path:inset(0 1% 0 1% round 40px)}.hero::before{top:-5px;left:-5px;right:-5px;bottom:-5px;width:auto;height:auto}.hero-content{padding:clamp(30px,8vw,50px)}.hero h1{font-size:clamp(1.8rem,6vw,3rem);letter-spacing:clamp(1px,0.5vw,3px)}.hero-subtitle{font-size:clamp(0.95rem,3.5vw,1.2rem);margin:10px 0}.hero-description{font-size:clamp(0.85rem,2vw,0.95rem);line-height:1.6;margin:10px 0}.hero-cta{flex-direction:column;gap:12px}.btn{width:100%;max-width:85%;font-size:clamp(0.8rem,1.8vw,0.95rem);padding:clamp(12px,2vw,14px) clamp(18px,3vw,24px);min-height:48px;border-radius:10px}.btn:hover{transform:translateY(-3px)}.section{padding:clamp(24px,5vw,35px) clamp(14px,4vw,18px);max-width:100%}.section h2{font-size:clamp(1.4rem,4.2vw,2.1rem);margin:clamp(12px,2vw,18px) 0 12px}.section p{font-size:clamp(0.95rem,2vw,1.08rem)}.grid{grid-template-columns:1fr;gap:clamp(14px,3vw,18px);margin-top:clamp(18px,2.5vw,28px)}.card{padding:clamp(18px,3vw,24px);border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,0.08)}.card h3{font-size:clamp(1.2rem,3.2vw,1.6rem);margin:clamp(10px,1.5vw,15px) 0}.card p{font-size:clamp(0.92rem,1.9vw,1.05rem)}.card:hover{transform:translateY(-10px)}.contacto-grid{grid-template-columns:1fr;gap:clamp(14px,3vw,18px)}.contacto-card{padding:clamp(18px,3vw,28px) clamp(14px,3vw,18px);border-radius:12px}.contacto-icon{font-size:clamp(2.2rem,5.5vw,3rem)}.contacto-card h3{font-size:clamp(1.25rem,3.2vw,1.6rem)}.footer-content{grid-template-columns:1fr;gap:clamp(20px,4vw,28px);text-align:center}.footer-section{text-align:center}.footer-section h4{font-size:clamp(1.15rem,3vw,1.4rem)}.footer-section p,.footer-section a{font-size:clamp(0.85rem,1.8vw,0.95rem)}.footer-section ul li{margin:clamp(6px,1.5vw,10px) 0}nav{padding:clamp(0.5rem,1.2vw,0.75rem);gap:clamp(0.2rem,0.8vw,0.5rem);overflow-x:auto;-webkit-overflow-scrolling:touch}nav a{padding:clamp(0.4rem,0.8vw,0.5rem) clamp(0.5rem,1vw,0.8rem);font-size:clamp(0.7rem,1.4vw,0.85rem);min-height:42px}.carousel-slide{height:clamp(200px,50vw,320px)}.carousel-container{margin:clamp(12px,2vw,18px) auto;border-radius:16px}.carousel-btn{padding:clamp(8px,1.5vw,12px) clamp(10px,2vw,14px);font-size:clamp(0.9rem,2vw,1.2rem);min-width:40px;min-height:40px}.carousel-btn.prev{left:clamp(6px,1.5vw,12px)}.carousel-btn.next{right:clamp(6px,1.5vw,12px)}.slide-caption{padding:clamp(12px,2vw,18px);font-size:clamp(0.9rem,2vw,1.1rem)}.especialidad-card{padding:clamp(16px,2.5vw,22px);border-radius:12px}.especialidad-card:hover{transform:translateY(-8px) scale(1.01)}.especialidad-icon{font-size:clamp(2rem,4.5vw,2.8rem)}.especialidad-card h3{font-size:clamp(1.2rem,2.8vw,1.5rem)}.especialidad-card p{font-size:clamp(0.9rem,1.8vw,1rem)}.social-links{gap:clamp(10px,2vw,16px)}.social-links a{width:clamp(48px,11vw,65px);height:clamp(48px,11vw,65px);font-size:clamp(1.4rem,3.2vw,2rem)}.social-links a:hover{transform:scale(1.12) rotateZ(6deg)}.lightbox-content{width:95%;height:95vh}.lightbox-close{width:44px;height:44px;top:10px;right:15px;font-size:1.8rem}.lightbox-nav{padding:clamp(10px,1.5vw,14px);font-size:clamp(1rem,2.5vw,1.8rem)}}

@media(max-width:380px){.hero h1{font-size:clamp(1.6rem,5vw,2.6rem)}.hero-subtitle{font-size:clamp(0.9rem,2.8vw,1.1rem)}.hero-description{font-size:clamp(0.82rem,1.8vw,0.93rem)}.section h2{font-size:clamp(1.3rem,3.8vw,1.9rem)}.section p{font-size:clamp(0.92rem,1.8vw,1.05rem)}.btn{font-size:clamp(0.78rem,1.5vw,0.88rem);padding:clamp(10px,1.5vw,12px) clamp(14px,2vw,20px)}.section{padding:clamp(20px,4.5vw,30px) clamp(12px,3.5vw,16px)}.card h3{font-size:clamp(1.1rem,3vw,1.5rem)}.contacto-card{padding:clamp(16px,2.5vw,22px) clamp(12px,2.5vw,16px)}.nav a{font-size:clamp(0.65rem,1.2vw,0.8rem);padding:0.35rem clamp(0.4rem,0.8vw,0.6rem)}}

@media(max-width:320px){.hero h1{font-size:clamp(1.4rem,4vw,2.2rem);letter-spacing:clamp(1px,0.3vw,2px)}.hero-subtitle{font-size:clamp(0.85rem,2.5vw,1rem)}.hero-description{font-size:clamp(0.8rem,1.5vw,0.9rem)}.section{padding:clamp(18px,4vw,26px) clamp(10px,3vw,12px)}.section h2{font-size:clamp(1.25rem,3.5vw,1.8rem)}.section p{font-size:clamp(0.9rem,1.8vw,1.02rem)}.grid{gap:clamp(10px,2vw,12px)}.card{padding:clamp(14px,2vw,20px)}.card h3{font-size:clamp(1rem,2.8vw,1.4rem)}.card p{font-size:clamp(0.88rem,1.8vw,1rem)}.btn{width:90%;font-size:clamp(0.75rem,1.3vw,0.85rem);padding:clamp(10px,1.3vw,12px) clamp(12px,1.8vw,18px)}.nav a{font-size:clamp(0.6rem,1vw,0.75rem);padding:0.3rem clamp(0.3rem,0.6vw,0.4rem)}.contacto-grid{gap:clamp(10px,2vw,12px)}.contacto-card{padding:clamp(14px,2vw,20px) clamp(10px,2vw,14px)}.contacto-icon{font-size:clamp(1.8rem,4.5vw,2.5rem)}.carousel-slide{height:clamp(180px,45vw,280px)}.carousel-btn{font-size:clamp(0.8rem,1.8vw,1rem);padding:clamp(6px,1vw,10px)}.social-links a{width:clamp(44px,10vw,55px);height:clamp(44px,10vw,55px);font-size:clamp(1.2rem,2.8vw,1.8rem)}}
