/* =========================================================
   Base Theme : “Retro” + Split-Complementary Palette
   Fonts      : Space Grotesk (headings) / DM Sans (body)
   ========================================================= */

:root{
  /* Core Palette (Split-Complementary) */
  --clr-primary:#0066cc;
  --clr-primary-dark:#004b91;
  --clr-secondary:#ff6b6b;
  --clr-secondary-dark:#c93d3d;
  --clr-tertiary:#ffd166;
  --clr-tertiary-dark:#d4a536;

  /* Neutrals */
  --clr-neutral-100:#ffffff;
  --clr-neutral-200:#f8f9fa;
  --clr-neutral-300:#e1e1e1;
  --clr-neutral-800:#222222;
  --clr-neutral-900:#111111;

  /* Typography */
  --ff-heading:'Space Grotesk',sans-serif;
  --ff-body:'DM Sans',sans-serif;

  /* Other */
  --radius-sm:6px;
  --radius-md:12px;
  --radius-lg:24px;

  --transition-fast:.3s ease;
  --transition-medium:.6s ease;
}

/* =========================================================
   Global Resets & Utilities
   ========================================================= */
*,
*::before,
*::after{box-sizing:border-box;margin:0;padding:0;}

html{scroll-behavior:smooth;}

body{
  font-family:var(--ff-body);
  color:var(--clr-neutral-800);
  background:var(--clr-neutral-200);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

img{max-width:100%;height:auto;display:block;}

.container{
  width:90%;
  max-width:1100px;
  margin:0 auto;
}

.is-two-thirds{max-width:1100px;}

.section-title{
  font-family:var(--ff-heading);
  font-size:clamp(1.8rem,4vw,2.6rem);
  text-align:center;
  margin-bottom:1.2rem;
  color:var(--clr-neutral-900);
  text-shadow:1px 1px 3px rgba(0,0,0,.15);
}

/* =========================================================
   Header & Navigation
   ========================================================= */
.header{
  position:fixed;top:0;left:0;width:100%;z-index:700;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--clr-neutral-300);
}

.header .container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:.75rem 0;
}

.logo{
  font-family:var(--ff-heading);
  font-size:1.6rem;
  color:var(--clr-primary);
  text-decoration:none;
}

.nav ul{
  list-style:none;
  display:flex;
  gap:1.25rem;
}

.nav a{
  text-decoration:none;
  color:var(--clr-neutral-900);
  font-weight:500;
  transition:color var(--transition-fast);
}

.nav a:hover{color:var(--clr-primary);}

/* Burger */
.burger{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;border:none;cursor:pointer;
}
.burger span,
.burger span::before,
.burger span::after{
  content:'';display:block;height:2px;width:22px;
  background:var(--clr-neutral-900);transition:var(--transition-fast);
}
@media(max-width:840px){
  .nav{position:fixed;inset:0 0 0 auto;background:var(--clr-neutral-100);transform:translateX(100%);transition:transform var(--transition-medium);}
  .nav.open{transform:translateX(0);}
  .nav ul{flex-direction:column;padding:6rem 3rem;}
  .burger{display:flex;}
}

/* =========================================================
   Hero
   ========================================================= */
.hero{
  position:relative;
  color:var(--clr-neutral-100);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:7rem 0 6rem;
}
.hero::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(rgba(0,0,0,.55),rgba(0,0,0,.55));
  z-index:0;
}
.hero .container{position:relative;z-index:1;}
.hero h1{font-family:var(--ff-heading);font-size:clamp(2.1rem,6vw,3.8rem);margin-bottom:1rem;}
.hero .lead{font-size:1.125rem;margin-bottom:2rem;}

/* =========================================================
   Buttons (Global)
   ========================================================= */
.btn,
button,
input[type='submit']{
  appearance:none;
  background:var(--clr-primary);
  color:var(--clr-neutral-100);
  border:none;
  padding:.75rem 1.75rem;
  border-radius:var(--radius-sm);
  font-weight:600;
  font-family:var(--ff-body);
  cursor:pointer;
  transition:background var(--transition-fast),transform var(--transition-fast);
}
.btn.primary{background:var(--clr-primary);}
.btn.secondary{background:var(--clr-secondary);}

.btn:hover,
button:hover,
input[type='submit']:hover{
  background:var(--clr-primary-dark);
  transform:translateY(-2px);
}
.btn:active,
button:active,
input[type='submit']:active{transform:translateY(0);}

/* =========================================================
   Curved / Skewed Sections
   ========================================================= */
.skewed{
  position:relative;
  padding:4rem 0;
}
.skewed::before,
.skewed::after{
  content:'';
  position:absolute;left:0;width:100%;height:60px;
  background:inherit;z-index:-1;
}
.skewed::before{top:-30px;transform:skewY(-3deg);}
.skewed::after{bottom:-30px;transform:skewY(3deg);}
@media(max-width:600px){
  .skewed::before,.skewed::after{display:none;}
}

/* =========================================================
   Section-Parallax
   ========================================================= */
.section-parallax{
  position:relative;
  color:var(--clr-neutral-100);
  padding:4rem 0;
  background-size:cover;
  background-repeat:no-repeat;
  background-attachment:fixed;
}
.section-parallax::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(rgba(0,0,0,.55),rgba(0,0,0,.55));
  z-index:0;
}
.section-parallax .container{position:relative;z-index:1;}

/* =========================================================
   Cards (Services, etc.)
   ========================================================= */
.cards-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.75rem;
}
.card{
  background:var(--clr-neutral-100);
  border-radius:var(--radius-md);
  box-shadow:0 3px 8px rgba(0,0,0,.08);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  transition:transform var(--transition-fast),box-shadow var(--transition-fast);
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:0 5px 12px rgba(0,0,0,.12);
}
.card-image{
  width:100%;
  height:200px;
  overflow:hidden;
}
.card-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  margin:0 auto;
}
.card-content{padding:1.25rem 1rem;}
.card-content h3{
  font-family:var(--ff-heading);color:var(--clr-primary);
  margin-bottom:.5rem;font-size:1.25rem;
}

/* =========================================================
   Statistics
   ========================================================= */
.stats{padding:4rem 0;background:var(--clr-tertiary);}
.stats-list{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:2rem;
  color:var(--clr-neutral-900);
  font-weight:600;
}
.stat-number{
  display:block;
  font-family:var(--ff-heading);
  font-size:2rem;
  color:var(--clr-secondary-dark);
  margin-bottom:.25rem;
}

/* =========================================================
   Carousel (Events)
   ========================================================= */
.carousel{
  position:relative;
  display:flex;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  gap:1rem;
  padding-bottom:1rem;
}
.carousel-item{
  min-width:300px;
  background:var(--clr-neutral-100);
  border-radius:var(--radius-md);
  padding:1.5rem;
  scroll-snap-align:center;
  flex-shrink:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}

/* =========================================================
   Accordion (Webinars)
   ========================================================= */
.accordion-item{border-bottom:1px solid var(--clr-neutral-300);}
.accordion-header{
  width:100%;
  padding:1rem;
  background:var(--clr-primary);
  color:var(--clr-neutral-100);
  font-family:var(--ff-heading);
  font-size:1rem;
  cursor:pointer;
  text-align:left;
  display:flex;
  justify-content:space-between;
}
.accordion-header::after{
  content:'+';
  transition:transform var(--transition-fast);
}
.accordion-body{
  max-height:0;overflow:hidden;
  background:var(--clr-neutral-100);
  transition:max-height var(--transition-medium);
  padding:0 1rem;
}
.accordion-item.open .accordion-body{max-height:200px;padding:1rem;}
.accordion-item.open .accordion-header::after{transform:rotate(45deg);}

/* =========================================================
   Contact Form
   ========================================================= */
.contact{padding:4rem 0;}
form{
  display:grid;
  gap:1rem;
}
.form-group{
  display:flex;
  flex-direction:column;
}
label{font-weight:600;margin-bottom:.25rem;}
input,textarea{
  padding:.75rem;border:1px solid var(--clr-neutral-300);
  border-radius:var(--radius-sm);
  font-family:var(--ff-body);
  resize:vertical;
}
input:focus,textarea:focus{outline:2px solid var(--clr-primary);}

/* =========================================================
   Clientele / Testimonials
   ========================================================= */
.clientele blockquote{
  font-style:italic;
  font-size:1.15rem;
  color:var(--clr-neutral-100);
  max-width:700px;
  margin:0 auto;
}

/* =========================================================
   Footer
   ========================================================= */
.footer{
  background:var(--clr-neutral-900);
  color:var(--clr-neutral-100);
  text-align:center;
  padding:2rem 0;
}
.footer nav{margin:1rem 0;}
.footer a{
  color:var(--clr-tertiary);
  text-decoration:none;
  margin:0 .4rem;
}
.footer a:hover{text-decoration:underline;}

/* Social text links */
.footer p a{
  font-weight:600;
}

/* =========================================================
   Links “Leer más”
   ========================================================= */
a.read-more{
  color:var(--clr-secondary);
  font-weight:600;
  position:relative;
}
a.read-more::after{
  content:'';
  position:absolute;left:0;bottom:-2px;width:100%;height:2px;
  background:currentColor;transform:scaleX(0);transform-origin:right;
  transition:transform var(--transition-fast);
}
a.read-more:hover::after{transform:scaleX(1);transform-origin:left;}

/* =========================================================
   Success Page
   ========================================================= */
.success-page{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  background:var(--clr-neutral-100);
}

/* =========================================================
   Privacy & Terms top spacing
   ========================================================= */
.legal-page{padding-top:100px;}

/* =========================================================
   Parallax Fallback for Mobile
   ========================================================= */
@media(max-width:800px){
  .section-parallax{background-attachment:scroll;}
}

/* =========================================================
   Keyframe Animations – Hand-Drawn Style
   ========================================================= */
@keyframes scribble{
  0%{stroke-dashoffset:1200;}
  100%{stroke-dashoffset:0;}
}
.scribble-path{
  stroke-dasharray:1200;
  stroke-dashoffset:1200;
  animation:scribble 3s ease forwards;
}

/* Example usage: add class .scribble-path to any SVG path */

/* =========================================================
   ScrollReveal Helper Classes
   ========================================================= */
[data-sr]{opacity:0;transition:opacity .6s ease,transform .6s ease;}
[data-sr].sr-show{opacity:1;transform:none;}

/* =========================================================
   Glassmorphism Utility
   ========================================================= */
.glass{
  background:rgba(255,255,255,.2);
  backdrop-filter:blur(10px) saturate(180%);
  border:1px solid rgba(255,255,255,.4);
  border-radius:var(--radius-lg);
}

/* =========================================================
   Miscellaneous
   ========================================================= */
.section-grid{padding:4rem 0;}
.stats,.contact,.events,.webinars{background:var(--clr-neutral-100);}
.resources{background:var(--clr-primary);color:var(--clr-neutral-100);}

.carousel::-webkit-scrollbar{display:none;}
.burger{
  display: none;
}