﻿/* styles.css */

/* styles.css — CreaSalut */
:root{
  --primary:#4A5E45;
  --primary-dark:#2E3D2B;
  --green:#4A5E45;
  --green-light:#6B7F66;
  --green-pale:rgba(74,94,69,0.09);
  --beige:#F5F0E8;
  --beige-warm:#EEE5D5;
  --beige-dark:#EDE5D8;
  --cream:#FDFAF6;
  --sand:#C5B99A;
  --sand-subtle:rgba(197,185,154,0.32);
  --text:#2A2420;
  --muted:#7A7068;
  --white:#ffffff;
  --shadow-sm:0 2px 16px rgba(74,94,69,0.08);
  --shadow:0 8px 36px rgba(74,94,69,0.12);
  --shadow-lg:0 24px 64px rgba(74,94,69,0.16);
  --shadow-card:0 4px 24px rgba(74,94,69,0.09),0 1px 4px rgba(74,94,69,0.05);
  --shadow-card-hover:0 20px 56px rgba(74,94,69,0.15),0 4px 12px rgba(74,94,69,0.08);
  --radius:20px;
  --radius-sm:12px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;color:var(--text);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased;}
img{width:100%;display:block;object-fit:cover;}
a{text-decoration:none;color:inherit;}
.container{width:min(1160px,92%);margin:auto;}

/* TYPOGRAPHY */
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;line-height:1.1;}
h1{font-size:clamp(2.2rem,7vw,6.2rem);font-weight:400;letter-spacing:-0.02em;}
h2{font-size:clamp(2.3rem,4.5vw,3.6rem);font-weight:400;color:var(--primary);letter-spacing:-0.01em;}
h3{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:400;color:var(--primary);letter-spacing:-0.01em;}
h4{font-size:1.15rem;font-weight:500;letter-spacing:0.01em;}
em{font-style:italic;color:var(--green);}
p{color:var(--muted);line-height:1.75;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;border-radius:999px;font-family:'DM Sans',sans-serif;font-weight:500;font-size:.88rem;cursor:pointer;border:none;transition:all .3s ease;letter-spacing:0.03em;text-transform:uppercase;}
.btn-wa{background:#25D366;color:#fff;}
.btn-wa:hover{background:#1ebd5b;transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,211,102,0.3);}
.btn-wa svg{width:20px;height:20px;}
.btn-dark{background:var(--primary);color:#fff;}
.btn-dark:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 10px 32px rgba(74,94,69,0.28);}
.btn-outline{border:2px solid rgba(255,255,255,0.7);color:#fff;background:transparent;}
.btn-outline:hover{background:rgba(255,255,255,0.12);}
.btn-outline--light{border-color:rgba(255,255,255,0.5);}
.btn-full{width:100%;justify-content:center;}

/* LABELS */
.section-label{display:inline-flex;align-items:center;gap:10px;font-size:.72rem;font-weight:600;letter-spacing:3.5px;text-transform:uppercase;color:var(--green);margin-bottom:18px;}
.section-label::before{content:"";width:20px;height:1.5px;background:currentColor;border-radius:2px;flex-shrink:0;}
.section-label--light{color:rgba(255,255,255,0.65);}
.section-label--light::before{background:rgba(255,255,255,0.65);}

/* SECTION HEADER */
.section-header{margin-bottom:60px;}
.section-header h2{margin-bottom:16px;}
.section-header p{max-width:520px;}
.section-header--light h2,.section-header--light p{color:#fff;}

/* REVEAL ANIMATION */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.fade-up{animation:fadeUp .9s ease forwards;}
@keyframes fadeUp{from{opacity:0;transform:translateY(40px);}to{opacity:1;transform:translateY(0);}}

/* ======================== HEADER ======================== */
.header{position:sticky;top:0;z-index:1000;background:rgba(253,250,246,0.95);backdrop-filter:blur(12px);border-bottom:1px solid rgba(74,55,40,0.08);transition:box-shadow .3s;}
.header.scrolled{box-shadow:0 1px 0 rgba(74,94,69,0.10);background:rgba(253,250,246,0.98);}
.navbar{display:flex;justify-content:space-between;align-items:center;padding:12px 0;min-height:68px;}
.logo{display:flex;align-items:center;gap:12px;}
.logo-mark{width:38px;height:38px;flex-shrink:0;}
.logo-mark svg{width:100%;height:100%;}
.logo-text{display:flex;flex-direction:column;line-height:1.2;}
.logo-name{font-family:'Cormorant Garamond',serif;font-size:1.6rem;color:var(--primary);font-weight:500;}
.logo-sub{font-size:.72rem;color:var(--muted);letter-spacing:.5px;}
.logo-img{height:52px;width:auto;display:block;}
.footer-logo-img{height:68px;width:auto;display:block;filter:brightness(1.1);margin-bottom:20px;}
.nav-menu{display:flex;gap:28px;}
.nav-menu a{font-size:.88rem;font-weight:400;color:var(--text);position:relative;padding-bottom:3px;letter-spacing:0.2px;transition:color .25s ease;}
.nav-menu a::after{content:"";position:absolute;left:50%;bottom:-1px;width:0;height:1.5px;background:var(--green);border-radius:2px;transition:all .3s cubic-bezier(0.25,0.46,0.45,0.94);transform:translateX(-50%);}
.nav-menu a:hover{color:var(--green);}
.nav-menu a:hover::after{width:100%;}
.header-actions{display:flex;align-items:center;gap:12px;}
.btn-wa-header{display:inline-flex;align-items:center;gap:8px;padding:9px 20px;border-radius:999px;background:#25D366;color:#fff;font-size:.82rem;font-weight:600;letter-spacing:0.2px;transition:all .3s cubic-bezier(0.25,0.46,0.45,0.94);box-shadow:0 2px 12px rgba(37,211,102,0.25);}
.btn-wa-header:hover{background:#1ebd5b;transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,211,102,0.4);}
.btn-wa-header svg{width:16px;height:16px;}
.mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;}
.mobile-toggle span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:.3s;}
.mobile-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.mobile-toggle.open span:nth-child(2){opacity:0;}
.mobile-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* ======================== HERO ======================== */
.hero{background:var(--beige);padding:60px 0;min-height:88vh;display:flex;align-items:center;}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.hero-content{max-width:560px;}
.hero-label{display:inline-block;font-size:.78rem;letter-spacing:2px;text-transform:uppercase;color:var(--green);margin-bottom:20px;font-weight:600;}
.hero-content h1{color:var(--primary);margin-bottom:22px;}
.hero-content h1 em{color:var(--green);font-style:italic;}
.hero-content p{color:var(--text);font-size:1.05rem;margin-bottom:36px;max-width:480px;line-height:1.75;}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.hero-image-wrap{position:relative;border-radius:40% 60% 60% 40% / 50% 50% 50% 50%;overflow:hidden;aspect-ratio:4/5;box-shadow:0 32px 80px rgba(74,94,69,0.18);}
.hero-img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.btn-outline-dark{background:transparent;border:2px solid var(--primary);color:var(--primary);padding:13px 28px;border-radius:999px;font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;transition:all .3s;}
.btn-outline-dark:hover{background:var(--primary);color:#fff;}
@media(max-width:768px){
  .hero{padding:40px 0;min-height:auto;}
  .hero-inner{grid-template-columns:1fr;gap:36px;}
  .hero-image-wrap{aspect-ratio:4/3;border-radius:24px;}
  .hero-btns{flex-direction:column;width:100%;}
  .hero-btns .btn,.btn-outline-dark{width:100%;justify-content:center;}
}

/* ======================== ABOUT ======================== */
.about{padding:120px 0;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;margin-bottom:60px;}
.about-images{position:relative;}
.about-img-main{border-radius:var(--radius);height:520px;box-shadow:var(--shadow-lg);}
.about-img-float{position:absolute;bottom:-30px;right:-30px;width:200px;border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-lg);border:5px solid var(--cream);}
.about-img-float img{height:160px;}
.about-content h2{margin-bottom:20px;}
.about-lead{font-size:1.1rem;color:var(--text);margin-bottom:16px;font-weight:400;}
.about-content > p{margin-bottom:36px;}
.values-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.value-item{display:flex;gap:14px;align-items:flex-start;}
.value-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px;}
.value-item h4{font-family:'DM Sans',sans-serif;font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:4px;}
.value-item p{font-size:.85rem;margin:0;}
.mv-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:80px;}
.mv-card{background:var(--beige);border-radius:20px;padding:48px 40px;border:none;box-shadow:none;transition:none;display:flex;flex-direction:column;justify-content:space-between;min-height:200px;}
.mv-card:first-child{background:var(--beige-dark);}
.mv-card:not(.mv-card--accent):hover{box-shadow:none;}
.mv-card--accent{background:var(--primary) !important;}
.mv-card--accent .mv-label{color:var(--sand) !important;}
.mv-card--accent p{color:rgba(255,255,255,0.85) !important;}
.mv-label{display:block;font-size:.75rem;letter-spacing:3px;text-transform:uppercase;color:var(--green);margin-bottom:20px;font-weight:700;}
.mv-card p{margin:0;line-height:1.7;}

/* ======================== SERVICES ======================== */
.services{padding:120px 0;background:linear-gradient(160deg,#EDE5D8 0%,#E5DAC8 100%);}
.services .section-header{text-align:center;}
.services .section-header p{margin:0 auto;}
.services-main-heading{font-family:'Cormorant Garamond',serif;font-size:clamp(2.4rem,4vw,3.2rem);font-weight:400;color:var(--primary);margin-bottom:12px;line-height:1.1;letter-spacing:-0.01em;}
.services .section-header .section-label{margin-top:2px;margin-bottom:0;}
.services-list{display:flex;flex-direction:column;gap:80px;}
.service-item{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.service-item--reverse{direction:rtl;}
.service-item--reverse > *{direction:ltr;}
.service-img-wrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}
.service-img-wrap img{height:420px;transition:transform .6s ease;}
.service-img-wrap:hover img{transform:scale(1.04);}
.service-tag{display:inline-block;font-size:.72rem;letter-spacing:2px;text-transform:uppercase;color:var(--green);background:rgba(74,94,69,0.08);padding:5px 14px;border-radius:999px;margin-bottom:18px;font-weight:600;border:1px solid rgba(74,94,69,0.15);}
.service-body h3{margin-bottom:14px;color:var(--primary);}
.service-body > p{margin-bottom:20px;}
.service-benefits{list-style:none;margin-bottom:18px;}
.service-benefits li{padding:7px 0;border-bottom:1px solid rgba(74,55,40,0.08);font-size:.9rem;color:var(--text);display:flex;gap:10px;align-items:flex-start;}
.service-benefits li::before{content:"✓";color:var(--green);font-weight:700;flex-shrink:0;margin-top:1px;}
.service-for{font-size:.87rem;color:var(--muted);margin-bottom:24px;font-style:italic;}
.service-for strong{color:var(--text);font-style:normal;}

/* ======================== PROCESS ======================== */
.process{position:relative;padding:120px 0;}
.process-bg{position:absolute;inset:0;z-index:0;}
.process-bg img{height:100%;object-fit:cover;}
.process-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(74,94,69,0.93),rgba(42,36,32,0.88));}
.process-inner{position:relative;z-index:1;}
.process .section-header{text-align:center;margin-bottom:60px;}
.process .section-header h2{color:#fff;}
.steps-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;}
.step-card{background:rgba(255,255,255,0.1);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.15);border-radius:var(--radius);padding:28px 22px;color:#fff;transition:.3s;}
.step-card:hover{background:rgba(255,255,255,0.16);transform:translateY(-4px);}
.step-num{font-family:'Cormorant Garamond',serif;font-size:2.8rem;color:rgba(255,255,255,0.25);margin-bottom:14px;line-height:1;}
.step-card h4{font-family:'DM Sans',sans-serif;font-size:.95rem;font-weight:600;color:#fff;margin-bottom:10px;}
.step-card p{font-size:.85rem;color:rgba(255,255,255,0.72);line-height:1.6;margin:0;}

/* ======================== TESTIMONIALS ======================== */
.testimonials{padding:120px 0;}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.testi-card{background:#fff;border-radius:var(--radius);padding:40px 36px;box-shadow:var(--shadow-card);border:1px solid var(--sand-subtle);transition:transform .35s ease,box-shadow .35s ease;}
.testi-card:not(.testi-card--accent):hover{transform:translateY(-5px);box-shadow:var(--shadow-card-hover);}
.testi-card--accent{background:var(--primary);color:#fff;}
.testi-card--accent p,.testi-card--accent .testi-stars{color:rgba(255,255,255,0.85);}
.testi-stars{color:#C5A85A;font-size:1rem;margin-bottom:16px;letter-spacing:2px;}
.testi-card p{font-size:.93rem;line-height:1.75;margin-bottom:24px;font-style:italic;}
.testi-author{display:flex;gap:14px;align-items:center;}
.testi-author img{width:52px;height:52px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.testi-author strong{display:block;font-size:.9rem;color:var(--text);}
.testi-card--accent .testi-author strong{color:#fff;}
.testi-author span{font-size:.8rem;color:var(--muted);}
.testi-card--accent .testi-author span{color:rgba(255,255,255,0.6);}
.testi-avatar{width:52px;height:52px;border-radius:50%;background:var(--beige-warm);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:.88rem;font-weight:600;flex-shrink:0;font-family:'DM Sans',sans-serif;letter-spacing:.5px;}
.testi-card--accent .testi-avatar{background:rgba(255,255,255,0.15);color:#fff;}

/* ======================== BLOG ======================== */
.blog{padding:120px 0;background:linear-gradient(175deg,#F0E9DC 0%,#EAE0CF 100%);}
.blog .section-header{text-align:center;}
.blog .section-header p{margin:0 auto;}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.blog-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);border:1px solid var(--sand-subtle);transition:all .4s cubic-bezier(0.25,0.46,0.45,0.94);cursor:pointer;}
.blog-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-card-hover);border-color:rgba(74,94,69,0.15);}
.blog-img{position:relative;overflow:hidden;}
.blog-img img{height:220px;transition:transform .5s;}
.blog-card:hover .blog-img img{transform:scale(1.05);}
.blog-cat{position:absolute;top:16px;left:16px;background:var(--primary);color:#fff;font-size:.72rem;letter-spacing:1px;text-transform:uppercase;padding:5px 12px;border-radius:999px;}
.blog-body{padding:26px;}
.blog-date{font-size:.78rem;color:var(--sand);text-transform:uppercase;letter-spacing:1px;}
.blog-body h4{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:500;color:var(--primary);margin:8px 0 10px;}
.blog-body p{font-size:.88rem;margin-bottom:16px;}
.blog-link{font-size:.88rem;font-weight:600;color:var(--green);transition:color .3s;}
.blog-link:hover{color:var(--primary);}

/* ======================== CTA BANNER ======================== */
.cta-banner{padding:60px 0;background:transparent;}
.cta-inner-box{background:linear-gradient(135deg,rgba(74,94,69,0.82) 0%,rgba(58,80,54,0.70) 50%,rgba(46,61,43,0.78) 100%);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:inset 0 1px 0 rgba(255,255,255,0.10),0 24px 64px rgba(74,94,69,0.25);border-radius:24px;padding:64px 72px;display:flex;justify-content:space-between;align-items:center;gap:48px;}
.cta-logo{height:180px;width:auto;display:block;margin:24px auto;filter:brightness(0) invert(1);opacity:0.9;}
.cta-inner{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:40px;width:100%;}
.cta-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:0;}
.cta-content h2{color:#fff;margin-bottom:12px;}
.cta-content p{color:rgba(255,255,255,0.7);}
.cta-actions{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;}
.cta-actions .btn{width:280px;justify-content:center;}

/* ======================== CONTACT ======================== */
.contact{padding:120px 0;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;}
.contact-info h2{margin-bottom:16px;}
.contact-info > p{margin-bottom:36px;}
.contact-items{display:flex;flex-direction:column;gap:16px;}
.contact-item{display:flex;gap:12px;align-items:center;padding:12px 16px;border-radius:var(--radius-sm);border:1px solid var(--sand-subtle);background:#fff;transition:all .3s cubic-bezier(0.25,0.46,0.45,0.94);color:var(--text);}
.contact-item:hover{border-color:rgba(74,94,69,0.3);box-shadow:0 4px 20px rgba(74,94,69,0.09);transform:translateX(4px);}
.ci-icon{width:40px;height:40px;border-radius:50%;background:var(--green-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem;}
.ci-icon svg{width:22px;height:22px;color:var(--green);}
.contact-item:nth-child(1) .ci-icon{background:rgba(37,211,102,0.1);}
.contact-item:nth-child(1) .ci-icon svg{color:#1a9e4a;}
.contact-item:nth-child(2) .ci-icon{background:rgba(74,94,69,0.12);}
.contact-item:nth-child(3) .ci-icon{background:rgba(74,55,40,0.08);}
.contact-item:nth-child(4) .ci-icon{background:rgba(197,185,154,0.25);}
.contact-item strong{display:block;font-size:.88rem;font-weight:600;color:var(--text);}
.contact-item span{font-size:.85rem;color:var(--muted);}
.contact-form-wrap{background:var(--beige);border-radius:var(--radius);padding:40px;}
.contact-form h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;color:var(--primary);margin-bottom:28px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.form-group label{font-size:.82rem;font-weight:600;color:var(--text);letter-spacing:.3px;}
.form-group input,.form-group select,.form-group textarea{padding:13px 16px;border:1px solid rgba(74,55,40,0.15);border-radius:var(--radius-sm);font-family:'DM Sans',sans-serif;font-size:.92rem;color:var(--text);background:#fff;transition:.3s;outline:none;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(74,94,69,0.12);}
.form-group textarea{resize:vertical;min-height:100px;}
.form-note{text-align:center;font-size:.8rem;color:var(--muted);margin-top:12px;}

/* ======================== FOOTER ======================== */
.footer{background:#1C2B1A;padding:80px 0 0;}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:50px;padding-bottom:56px;}
.footer-brand p{color:rgba(197,185,154,0.55);font-size:.88rem;line-height:1.8;margin:16px 0 24px;}
.footer-contact-quick{display:flex;flex-direction:column;gap:10px;}
.footer-contact-quick a{color:rgba(197,185,154,0.65);font-size:.87rem;transition:color .25s ease;}
.footer-contact-quick a:hover{color:#F5F0E8;}
.footer-links h5{color:#fff;font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:500;letter-spacing:0.2px;text-transform:none;margin-bottom:22px;}
.footer-links ul{list-style:none;}
.footer-links li{margin-bottom:12px;}
.footer-links a{color:rgba(197,185,154,0.6);font-size:.87rem;transition:color .25s ease;}
.footer-links a:hover{color:#F5F0E8;}
.footer-bottom{border-top:1px solid rgba(197,185,154,0.1);padding:24px 0;}
.footer-bottom .container{display:flex;justify-content:space-between;align-items:center;}
.footer-bottom span{color:rgba(197,185,154,0.35);font-size:.79rem;}

/* ======================== WA FLOAT ======================== */
.wa-float{position:fixed;bottom:28px;right:28px;z-index:999;width:58px;height:58px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 6px 24px rgba(37,211,102,0.4);transition:.3s;}
.wa-float svg{width:28px;height:28px;}
.wa-float:hover{background:#1ebd5b;transform:scale(1.1);}
@keyframes pulse{0%,100%{box-shadow:0 6px 24px rgba(37,211,102,0.4);}50%{box-shadow:0 6px 32px rgba(37,211,102,0.65);}}
@media (prefers-reduced-motion: no-preference){.wa-float{animation:pulse 2.5s infinite;}}

/* ======================== FAMILIAS ======================== */
.familias{padding:120px 0;}
.familias-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;}
.familias-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}
.familias-img img{height:520px;}
.familias-content h2{margin-bottom:20px;}
.familias-content > p{margin-bottom:16px;}
.familias-list{list-style:none;margin:24px 0 32px;}
.familias-list li{padding:10px 0;border-bottom:1px solid var(--beige-dark);font-size:.93rem;color:var(--text);display:flex;gap:10px;align-items:center;}
.familias-list li::before{content:"✓";color:var(--green);flex-shrink:0;}

/* ======================== MODAL SERVICIOS ======================== */
.svc-modal{display:none;position:fixed;inset:0;background:rgba(30,20,14,0.65);z-index:9999;justify-content:center;align-items:center;padding:20px;backdrop-filter:blur(4px);}
.svc-modal.open{display:flex;}
.svc-modal-box{background:#fff;width:100%;max-width:660px;border-radius:var(--radius);padding:44px;position:relative;max-height:88vh;overflow-y:auto;animation:modalIn .3s ease;}
@keyframes modalIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
.svc-modal-close{position:absolute;top:16px;right:20px;background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--muted);line-height:1;transition:color .2s;}
.svc-modal-close:hover{color:var(--text);}
.svc-modal-box h2{font-family:'Cormorant Garamond',serif;color:var(--primary);margin-bottom:20px;font-size:2rem;}
#modalContent p{margin-bottom:14px;font-size:.95rem;line-height:1.75;color:var(--muted);}
#modalContent p strong{color:var(--text);}
#modalContent ul{list-style:none;margin:4px 0 16px;}
#modalContent li{padding:8px 0;border-bottom:1px solid var(--beige-dark);font-size:.92rem;color:var(--text);display:flex;gap:10px;}
#modalContent li::before{content:"✓";color:var(--green);font-weight:700;flex-shrink:0;}

/* ======================== HERO CLAIMS ======================== */
.hero-claims{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:20px;}
.hero-claims span{font-size:.9rem;color:rgba(255,255,255,0.9);font-weight:500;letter-spacing:.3px;}
.claim-dot{color:rgba(255,255,255,0.35);font-size:1.2rem;}
.btn-ghost{border:1px solid rgba(255,255,255,0.3);color:rgba(255,255,255,0.8);background:transparent;font-size:.88rem;}
.btn-ghost:hover{background:rgba(255,255,255,0.08);color:#fff;}

/* ======================== IDENTIDAD ======================== */
.identidad{padding:120px 0;background:var(--cream);}
section+section{border-top:1px solid rgba(74,55,40,0.06);}

/* Bloque quiénes somos */
.identidad-block{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;margin-bottom:90px;}
.identidad-text h2{margin-bottom:20px;}
.identidad-lead{font-size:1.08rem;color:var(--text);font-weight:400;margin-bottom:16px;line-height:1.75;}
.identidad-text > p{margin-bottom:14px;}
.identidad-visual{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);}
.identidad-visual img{height:480px;}

/* Pillars qué hacemos */
.identidad-pillars{margin-bottom:80px;}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.pillar-card{background:#fff;border-radius:var(--radius);padding:40px 34px;box-shadow:var(--shadow-card);border:1px solid var(--sand-subtle);border-left:none;border-top:none;transition:all .35s cubic-bezier(0.25,0.46,0.45,0.94);position:relative;overflow:hidden;}
.pillar-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--green),var(--sand));}
.pillar-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card-hover);}
.pillar-card:nth-child(2){background:var(--green);}
.pillar-card:nth-child(2) h4,.pillar-card:nth-child(2) p{color:rgba(255,255,255,0.9);}
.pillar-card:nth-child(2) .pillar-icon{filter:brightness(10);}
.pillar-card:nth-child(2)::before{background:rgba(255,255,255,0.2);}
.pillar-icon{font-size:2rem;margin-bottom:16px;}
.pillar-card h4{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:500;color:var(--primary);margin-bottom:12px;}
.pillar-card p{font-size:.9rem;line-height:1.7;margin:0;}

/* Enfoque cómo trabajamos */
.identidad-enfoque{background:var(--green);border-radius:var(--radius);overflow:hidden;}
.enfoque-inner{display:grid;grid-template-columns:1fr 1fr;gap:0;}
.enfoque-content{padding:60px;display:flex;flex-direction:column;justify-content:center;}
.enfoque-content h2{color:#fff;margin-bottom:20px;}
.enfoque-content p{color:rgba(255,255,255,0.78);margin-bottom:14px;line-height:1.75;}
.enfoque-content .btn-outline{align-self:flex-start;margin-top:10px;}
.enfoque-items{background:rgba(0,0,0,0.15);padding:60px 48px;display:flex;flex-direction:column;gap:28px;justify-content:center;}
.enfoque-item{display:flex;gap:18px;align-items:flex-start;}
.enfoque-num{font-family:'Cormorant Garamond',serif;font-size:2rem;color:rgba(255,255,255,0.25);line-height:1;flex-shrink:0;min-width:36px;}
.enfoque-item h4{font-family:'DM Sans',sans-serif;font-size:.95rem;font-weight:600;color:#fff;margin-bottom:4px;}
.enfoque-item p{font-size:.85rem;color:rgba(255,255,255,0.65);margin:0;line-height:1.5;}

/* ======================== HERO EXTRAS ======================== */
.hero-destacada{display:inline-block;margin-top:6px;margin-bottom:20px;font-size:.9rem;font-weight:600;color:rgba(255,255,255,0.9);letter-spacing:.5px;border-left:3px solid var(--sand);padding-left:12px;}

/* ======================== IDENTIDAD EXTRAS ======================== */
.identidad-diferencial{font-style:italic;color:var(--green);border-left:3px solid var(--sand);padding-left:16px;margin:20px 0;line-height:1.75;}
.identidad-destacada{background:var(--beige);border-radius:var(--radius-sm);padding:14px 18px;font-size:.9rem;color:var(--text);margin-top:16px;border-left:3px solid var(--sand);}
.enfoque-diferencial{font-style:italic;color:rgba(255,255,255,0.8);border-left:3px solid rgba(255,255,255,0.3);padding-left:14px;margin:16px 0;font-size:.9rem;line-height:1.7;}

/* ======================== RESPONSIVE ======================== */
@media(max-width:1024px){
  .about-grid,.service-item,.contact-grid,.familias-grid,.identidad-block,.enfoque-inner{grid-template-columns:1fr;}
  .service-item--reverse{direction:ltr;}
  .about-img-float{right:0;bottom:-20px;width:160px;}
  .steps-grid{grid-template-columns:repeat(2,1fr);}
  .footer-inner{grid-template-columns:1fr 1fr;}
  .cta-inner{grid-template-columns:1fr;}
  .cta-actions .btn{width:100%;}
  .pillars-grid{grid-template-columns:1fr 1fr;}
  .enfoque-content,.enfoque-items{padding:40px;}
}
@media(max-width:768px){
  .nav-menu{position:fixed;top:70px;left:0;width:100%;background:var(--cream);flex-direction:column;padding:24px;gap:4px;display:none;box-shadow:var(--shadow);border-top:1px solid var(--beige-dark);}
  .nav-menu.active{display:flex;}
  .nav-menu a{padding:12px 0;font-size:1rem;border-bottom:1px solid var(--beige-dark);}
  .mobile-toggle{display:flex;}
  .btn-wa-header{display:none;}
  .services{overflow:hidden;}
  .mv-card{padding:36px 28px;}
  .stat{min-width:50%;}
  .stat-divider{display:none;}
  .mv-row,.values-grid,.testimonials-grid,.blog-grid{grid-template-columns:1fr;}
  .mv-row{margin-bottom:48px;}
  .about-img-float{display:none;}
  .form-row{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;}
  .footer-bottom .container{flex-direction:column;gap:6px;text-align:center;}
  .pillars-grid{grid-template-columns:1fr;}
  .hero-claims{gap:8px;}
  .claim-dot{display:none;}
  .hero-claims span{font-size:.82rem;}
  .identidad-visual img{height:300px;}
  .cta-inner-box{flex-direction:column;padding:48px 32px;border-radius:16px;text-align:center;}
  .testimonials .section-header{text-align:center;}
  .testimonials .section-label{justify-content:center;}
}

/* ======================== SERVICES GRID ======================== */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:52px;}

.service-card{background:#fff;border-radius:20px;padding:38px 30px;box-shadow:var(--shadow-card);border:1px solid var(--sand-subtle);transition:all 0.4s cubic-bezier(0.25,0.46,0.45,0.94);display:flex;flex-direction:column;gap:16px;position:relative;overflow:hidden;cursor:pointer;}
.service-card::after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--sand);transition:background 0.4s ease;}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-card-hover);border-color:rgba(74,94,69,0.18);}
.service-card:hover::after{background:var(--green);}

.service-icon{width:56px;height:56px;background:var(--beige);border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background 0.35s ease;}
.service-card:hover .service-icon{background:var(--green-pale);}
.service-icon svg{width:28px;height:28px;stroke:var(--green);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;}

.service-card-title{font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-weight:500;color:var(--primary);line-height:1.2;letter-spacing:-0.01em;}
.service-card-desc{font-size:.88rem;color:var(--muted);line-height:1.65;flex:1;margin:0;}

.service-card .btn-modal{align-self:flex-start;background:transparent;border:1.5px solid rgba(197,185,154,0.55);color:var(--primary);padding:9px 22px;border-radius:999px;font-size:.78rem;font-weight:600;font-family:'DM Sans',sans-serif;cursor:pointer;transition:all 0.3s cubic-bezier(0.25,0.46,0.45,0.94);letter-spacing:0.5px;text-transform:uppercase;margin-top:auto;}
.service-card .btn-modal:hover{background:var(--green);border-color:var(--green);color:#fff;transform:translateY(-1px);box-shadow:0 4px 16px rgba(74,94,69,0.28);}

.service-card--dark{background:var(--green);border-color:transparent;box-shadow:0 20px 48px rgba(74,94,69,0.18);}
.service-card--dark::after{background:rgba(255,255,255,0.2);}
.service-card--dark:hover{background:#3d4f3a;border-color:transparent;transform:translateY(-8px);}
.service-card--dark:hover::after{background:rgba(255,255,255,0.35);}
.service-card--dark .service-card-title{color:#fff;}
.service-card--dark .service-card-desc{color:rgba(255,255,255,0.8);}
.service-card--dark .service-icon{background:rgba(255,255,255,0.15);color:#fff;}
.service-card--dark .service-icon svg{stroke:#ffffff;}
.service-card--dark:hover .service-icon{background:rgba(255,255,255,0.22);}
.service-card--dark .btn-modal{border-color:rgba(255,255,255,0.4);color:#fff;}
.service-card--dark .btn-modal:hover{background:#fff;color:var(--green);border-color:#fff;box-shadow:none;}

@media(max-width:1024px) and (min-width:769px){
  .services-grid{grid-template-columns:repeat(2,1fr);}
}

@media(max-width:768px){
  .services-grid{display:flex;flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:16px;padding:0 20px 16px;margin:0 -20px;scrollbar-width:none;}
  .services-grid::-webkit-scrollbar{display:none;}
  .services-grid .service-card{flex:0 0 80vw;max-width:320px;scroll-snap-align:start;}
}

.carousel-dots{display:none;justify-content:center;gap:6px;margin-top:20px;}
.carousel-dots .dot{width:6px;height:6px;border-radius:50%;background:var(--sand);transition:all .3s ease;}
.carousel-dots .dot.active{background:var(--green);width:20px;border-radius:3px;}
@media(max-width:768px){.carousel-dots{display:flex;}}

@media(prefers-reduced-motion:reduce){
  *{transition-duration:.01ms !important;animation-duration:.01ms !important;animation-iteration-count:1 !important;}
  .reveal{transition:none;}
  .wa-float{animation:none;}
}

@media (max-width: 768px) {
  .services .section-header { text-align: center; padding: 0 20px; }
  .services .section-label { justify-content: center; }
  .services-grid { padding-left: 20px; scroll-padding-left: 20px; margin-bottom: 0; }
  .carousel-dots { margin-top: 12px; margin-bottom: 0; }
  .services { padding-bottom: 60px; }
  .mv-card { padding: 24px 20px; }
  .mv-card p { font-size: .88rem; }
}

@media (max-width: 480px) {
  .cta-inner-box { padding: 32px 24px; }
  .cta-logo { height: 120px; margin: 16px auto; }
  .nav-menu { top: 68px; }
  .mv-card { padding: 28px 20px; }
  .enfoque-content, .enfoque-items { padding: 28px 20px; }
  .contact-form-wrap { padding: 24px 20px; }
  .svc-modal-box { padding: 28px 20px; }
}

/* LEGAL LINK (footer) */
.footer-legal-link{color:rgba(197,185,154,0.35);text-decoration:none;opacity:1;transition:color .25s ease;}
.footer-legal-link:hover{color:#F5F0E8;opacity:1;}

/* FORM CONSENT CHECKBOX */
.form-check{display:flex;gap:10px;align-items:flex-start;cursor:pointer;font-size:.85rem;color:var(--muted);}
.form-check input{margin-top:3px;flex-shrink:0;accent-color:var(--green);}
.form-check a{color:var(--green);text-decoration:underline;}

/* FAQ ACCORDION */
.faq{padding:100px 0;background:var(--cream);}
.faq-list{max-width:780px;margin:0 auto;}
.faq-item{border-bottom:1px solid rgba(74,55,40,0.12);}
.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:24px 0;background:none;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:500;color:var(--text);text-align:left;transition:color .2s;}
.faq-question:hover{color:var(--primary);}
.faq-icon{width:20px;height:20px;flex-shrink:0;transition:transform .3s ease;color:var(--green);}
.faq-question[aria-expanded="true"] .faq-icon{transform:rotate(180deg);}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;}
.faq-answer.open{max-height:300px;padding-bottom:20px;}
.faq-answer p{font-size:.95rem;}
.faq-answer a{color:var(--green);text-decoration:underline;}

/* MV QUOTE */
.mv-quote{padding:24px 0 80px;text-align:center;}
.mv-quote blockquote{font-family:'Cormorant Garamond',serif;font-size:clamp(1.3rem,2.5vw,1.8rem);font-style:italic;color:var(--primary);max-width:780px;margin:0 auto;line-height:1.6;border-left:3px solid var(--green);padding-left:28px;text-align:left;}