/*========================================================
  VARIABLES
========================================================*/
:root{
    /* Core Palette : Eco-Minimal Monochrome (Green Scale) */
    --primary-900:#111111;
    --primary-700:#1f1f1f;
    --primary-500:#333333;
    --primary-300:#6b6b6b;
    --neutral-100:#f5f5f5;
    --white:#ffffff;

    --accent-500:#2e7d32;   /* Eco-green                      */
    --accent-400:#4caf50;   /* Hover / Lighter                */
    --accent-300:#76d275;   /* Focus / Active                 */

    --radius-sm:6px;
    --radius-md:12px;
    --shadow-sm:0 1px 4px rgba(0,0,0,.08);
    --shadow-md:0 4px 14px rgba(0,0,0,.12);

    --transition-fast:.2s ease;
    --transition-elastic:.5s cubic-bezier(.68,-0.55,.27,1.55);

    --container-max:1200px;
    --gap:2rem;
}

/*========================================================
  RESET & GLOBAL
========================================================*/
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
    font-family:'Work Sans',sans-serif;
    color:var(--primary-700);
    background:var(--neutral-100);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{
    font-family:'Poppins',sans-serif;
    font-weight:600;
    color:var(--primary-900);
    text-align:center;
    text-shadow:1px 1px 3px rgba(0,0,0,.5);
}
p{margin-bottom:1.2rem;font-size:1rem;}
a{text-decoration:none;color:var(--accent-500);transition:color var(--transition-fast);}
a:hover{color:var(--accent-400);}

/*========================================================
  UTILS
========================================================*/
.container{
    width:90%;
    max-width:var(--container-max);
    margin-inline:auto;
}
.section{padding:4rem 0;}
.section.alt-bg{background:var(--white);}
.section-description{max-width:60ch;margin:1rem auto 0;}
.tag{
    display:inline-block;
    background:var(--accent-500);
    color:var(--white);
    padding:.2rem .6rem;
    border-radius:var(--radius-sm);
    font-size:.8rem;
    letter-spacing:.5px;
}

/*========================================================
  BUTTONS
========================================================*/
.btn,
button,
input[type='submit']{
    display:inline-block;
    padding:.9rem 2.2rem;
    border:none;
    border-radius:var(--radius-md);
    font-family:'Poppins',sans-serif;
    font-weight:600;
    font-size:1rem;
    cursor:pointer;
    transition:transform var(--transition-elastic),background var(--transition-fast),color var(--transition-fast);
}
.btn-primary{background:var(--accent-500);color:var(--white);}
.btn-primary:hover{background:var(--accent-400);transform:scale(1.05);}
.btn-secondary{background:transparent;color:var(--accent-500);border:2px solid var(--accent-500);}
.btn-secondary:hover{background:var(--accent-400);color:var(--white);transform:scale(1.05);}

/*========================================================
  HEADER / NAV
========================================================*/
.site-header{
    width:100%;
    position:fixed;
    top:0;left:0;
    z-index:50;
    background:rgba(255,255,255,.95);
    backdrop-filter:saturate(180%) blur(12px);
    box-shadow:var(--shadow-sm);
}
.navbar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    height:70px;
}
.logo{font-family:'Poppins',sans-serif;font-weight:700;color:var(--primary-900);font-size:1.3rem;}
.nav-links{
    list-style:none;
    display:flex;
    gap:1.5rem;
}
.nav-links a{font-weight:500;color:var(--primary-700);}
.nav-links a:hover{color:var(--accent-500);}
.burger{
    display:none;
    flex-direction:column;
    gap:5px;
    background:none;
}
.burger span{
    width:25px;height:2px;background:var(--primary-700);transition:all var(--transition-fast);
}

/*========================================================
  HERO
========================================================*/
.hero{
    display:flex;
    align-items:center;
    justify-content:center;
    padding:6rem 0 4rem;
    min-height:70vh;
    background-size:cover;
    background-repeat:no-repeat;
    background-attachment:fixed;
    position:relative;
    text-align:center;
}
.hero::after{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(180deg,rgba(0,0,0,.6)0%,rgba(0,0,0,.35)70%);
}
.hero > .container{position:relative;z-index:1;}
.hero-title{font-size:2.8rem;line-height:1.15;color:var(--white);}
.hero-subtitle{color:var(--white);max-width:40ch;margin:1rem auto 2rem;}

/*========================================================
  PROCESS / CARDS
========================================================*/
.process-grid,
.events-grid,
.pricing-grid,
.webinar-list,
.blog-grid,
.case-grid,
.testimonials-grid{
    display:grid;
    gap:var(--gap);
}

.process-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}
.events-grid,
.testimonials-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}
.pricing-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}
.webinar-list,
.blog-grid,
.case-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));}

/* CARD BASE ---------------------------------------------*/
.card{
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    background:var(--white);
    border-radius:var(--radius-md);
    box-shadow:var(--shadow-sm);
    overflow:hidden;
    transition:transform var(--transition-elastic);
}
.card:hover{transform:translateY(-6px);}
.card-image{
    width:100%;
    height:200px;
    overflow:hidden;
}
.card-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    margin:0 auto;
}
.card-content{padding:1.5rem 1.3rem;}
.card-content h3{margin-bottom:.6rem;color:var(--primary-900);}
.card.highlight{background:var(--accent-500);color:var(--white);}
.card.highlight .card-content h3{color:var(--white);}
.price{font-size:2rem;font-weight:700;margin:.8rem 0;}

/*========================================================
  LINK ARROW
========================================================*/
.link-arrow{
    display:inline-block;
    font-weight:600;
    position:relative;
    padding-right:1.8rem;
    color:var(--accent-500);
}
.link-arrow::after{
    content:'→';
    position:absolute;
    right:.2rem;top:0;
    transition:transform var(--transition-fast);
}
.link-arrow:hover::after{transform:translateX(4px);}

/*========================================================
  COMMUNITY
========================================================*/
#comunidad .btn-primary{margin-top:2rem;}

/*========================================================
  FOOTER
========================================================*/
.site-footer{
    background:var(--primary-700);
    color:var(--white);
    padding:2.5rem 0;
}
.footer-grid{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    justify-content:space-between;
    gap:2rem;
}
.footer-brand p{font-weight:600;}
.footer-nav,
.footer-social{
    display:flex;
    gap:1.4rem;
    flex-wrap:wrap;
}
.footer-nav a,
.footer-social a{
    color:var(--white);
    font-weight:500;
    transition:color var(--transition-fast);
}
.footer-nav a:hover,
.footer-social a:hover{color:var(--accent-300);}

/*========================================================
  COOKIES POPUP (overrides inline)
========================================================*/
#cookiePopup{font-size:.9rem;}
#cookiePopup button:hover{background:var(--accent-300);}

/*========================================================
  SUCCESS PAGE
========================================================*/
body.success-page .section{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
}

/*========================================================
  PRIVACY & TERMS PADDING
========================================================*/
body.legal-page .section{padding-top:100px;}

/*========================================================
  RESPONSIVE NAV
========================================================*/
@media (max-width:880px){
    .burger{display:flex;}
    .nav-links{
        position:fixed;
        inset:70px 0 0 0;
        flex-direction:column;
        background:rgba(255,255,255,.98);
        padding:2rem;
        transform:translateX(100%);
        transition:transform var(--transition-fast);
    }
    .nav-links.open{transform:translateX(0);}
}
/* Style for active burger */
.burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}

/*========================================================
  ANIMATIONS (Elastic Entrance)
========================================================*/
@keyframes elastic-in{
    0%{transform:scale(.85);}
    60%{transform:scale(1.05);}
    100%{transform:scale(1);}
}
[data-aos]{animation:elastic-in .6s var(--transition-elastic) both;}

/*========================================================
  MISC
========================================================*/
.alt-bg.parallax,
.hero.parallax{background-attachment:fixed;}