/* ====================================================
   style.css  •  YPF Retro – Pastel Block Interface
   ==================================================== */

/* ----------  CSS Custom Properties  ---------- */
:root{
  /* Typography */
  --font-heading: 'Archivo Black', sans-serif;
  --font-body: 'Roboto', sans-serif;

  /* Pastel Palette */
  --clr-bg: #faf8f6;
  --clr-surface: #ffffff;
  --clr-primary: #ffd966;      /* amarillo pastel */
  --clr-primary-dark: #e6c359;
  --clr-accent: #9ad1d4;       /* turquesa pastel */
  --clr-accent-dark: #83b7ba;
  --clr-secondary: #f5a3b2;    /* rosa pastel */
  --clr-secondary-dark: #de8da0;
  --clr-text: #333333;
  --clr-heading: #222222;

  /* Gradients + Overlays */
  --grad-dark: linear-gradient(rgba(0,0,0,0.55),rgba(0,0,0,0.55));
  --grad-light: linear-gradient(rgba(255,255,255,0.7),rgba(255,255,255,0.7));

  /* Shadows */
  --shadow-elev-1: 0 4px 8px rgba(0,0,0,.05);
  --shadow-elev-2: 0 8px 20px rgba(0,0,0,.08);

  /* Radius */
  --radius-sm: .5rem;
  --radius-lg: 1.25rem;

  /* Animations */
  --transition: .3s ease;
}

/* ----------  Base Styles  ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--clr-text);
  background-color:var(--clr-bg);
  line-height:1.6;
}
img{max-width:100%;display:block;}
a{color:var(--clr-accent-dark);text-decoration:none;transition:color var(--transition);}
a:hover{color:var(--clr-accent);}
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-heading);
  color:var(--clr-heading);
  margin:0 0 .75em;
  line-height:1.2;
  text-align:center;
  text-shadow:1px 1px 3px rgba(0,0,0,.1);
}

/* Utility Containers */
.container{
  width:90%;
  max-width:1200px;
  margin-inline:auto;
}
.flex{display:flex;}
.between{justify-content:space-between;align-items:center;}
.grid{display:grid;gap:2rem;}
.two-col{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));}
.three-col{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));}

/* ----------  Header  ---------- */
.site-header{
  background-color:var(--clr-surface);
  position:sticky;top:0;z-index:1000;
  box-shadow:var(--shadow-elev-1);
}
.logo{font-family:var(--font-heading);font-size:1.4rem;color:var(--clr-heading);}
.main-nav ul{display:flex;gap:1.5rem;padding:0;margin:0;list-style:none;}
.main-nav a{font-weight:500;color:var(--clr-text);}
.main-nav a:hover,.main-nav a:focus{color:var(--clr-accent);}
.burger{display:none;flex-direction:column;gap:.3rem;background:none;border:none;cursor:pointer;padding:.5rem}
.burger span{width:24px;height:3px;background:var(--clr-heading);transition:var(--transition);}

/* ----------  Hero  ---------- */
.hero{
  background-size:cover;background-repeat:no-repeat;background-position:center;
  color:#ffffff; /* enforced white text */
  padding:6rem 0 5rem;
  text-align:center;
  position:relative;
}
.hero .lead{max-width:700px;margin:1rem auto 2rem;font-size:1.25rem;}
.hero .btn{box-shadow:var(--shadow-elev-2);}

/* ----------  Section Generic  ---------- */
.section{padding:4rem 0;}
.section-title{margin-bottom:3rem;}

/* ----------  Card Pattern  ---------- */
.card{
  background:var(--clr-surface);
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow-elev-1);
  transition:transform var(--transition),box-shadow var(--transition);
  display:flex;flex-direction:column;align-items:center;text-align:center;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-elev-2);}
.card-image{width:100%;height:240px;overflow:hidden;border-top-left-radius:var(--radius-sm);border-top-right-radius:var(--radius-sm);}
.card-image img{width:100%;height:100%;object-fit:cover;margin:0 auto;}
.card-content{padding:1.5rem;display:flex;flex-direction:column;gap:1rem;}

/* ----------  Process List  ---------- */
.process-steps{counter-reset:step;list-style:none;padding:0;max-width:700px;margin:0 auto;}
.process-steps li{position:relative;padding-left:3rem;margin-bottom:1.5rem;}
.process-steps li::before{
  counter-increment:step;content:counter(step);
  position:absolute;left:0;top:0;
  width:2rem;height:2rem;line-height:2rem;text-align:center;
  background:var(--clr-primary);color:var(--clr-heading);border-radius:50%;
  font-family:var(--font-heading);
}

/* ----------  Buttons & Inputs  ---------- */
.btn,button,input[type='submit']{
  appearance:none;border:none;border-radius:var(--radius-sm);
  background:var(--clr-primary);color:var(--clr-heading);
  font-weight:700;padding:.9rem 2rem;cursor:pointer;
  transition:background var(--transition),transform var(--transition);
}
.btn.secondary{background:var(--clr-accent);color:#fff;}
.btn:hover,button:hover,input[type='submit']:hover{background:var(--clr-primary-dark);transform:translateY(-2px);}
.btn.secondary:hover{background:var(--clr-accent-dark);}
input,textarea{
  width:100%;padding:.9rem 1rem;margin-bottom:1rem;
  border:2px solid var(--clr-accent-dark);border-radius:var(--radius-sm);
  background:#fff;font-family:var(--font-body);
}
input:focus,textarea:focus{outline:none;border-color:var(--clr-accent);}

/* ----------  Contact Form  ---------- */
.contact-form{max-width:700px;margin:0 auto;}
.contact-form .two-col{gap:1rem;}

/* ----------  FAQ  ---------- */
details{margin-bottom:1rem;border:1px solid var(--clr-accent-dark);border-radius:var(--radius-sm);background:var(--clr-surface);}
summary{padding:1rem;font-weight:700;cursor:pointer;list-style:none;}
details[open] summary{border-bottom:1px solid var(--clr-accent-dark);}
details p{padding:1rem;margin:0;}

/* ----------  Webinars  ---------- */
#webinars .card{background:rgba(255,255,255,0.15);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.25);}
#webinars .card-content{padding:2rem;}

/* ----------  Footer  ---------- */
.site-footer{
  background:var(--clr-heading);color:#fff;padding:3rem 0;text-align:center;
}
.site-footer a{color:#fff;text-decoration:underline;}
.site-footer a:hover{color:var(--clr-secondary);}
.footer-title{margin-bottom:1rem;font-size:1.2rem;}
.social{margin:1rem 0;}
.copy{margin-top:1rem;font-size:.875rem;}

/* ----------  Success Page  ---------- */
.centered{
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  min-height:100vh;text-align:center;padding:2rem;
}

/* ----------  Read-More Links  ---------- */
.read-more{font-weight:700;color:var(--clr-secondary);position:relative;padding-right:1.2rem;}
.read-more::after{
  content:'→';position:absolute;right:0;top:0;color:inherit;transition:transform var(--transition);
}
.read-more:hover::after{transform:translateX(4px);}

/* ----------  Modal  ---------- */
.modal{display:none;position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.5);justify-content:center;align-items:center;padding:2rem;}
.modal-content{
  background:var(--clr-surface);border-radius:var(--radius-lg);
  padding:2rem;max-width:500px;width:100%;box-shadow:var(--shadow-elev-2);
  animation:pop .4s ease;
}
.modal-close{margin-top:1.5rem;}

/* ----------  Cookie Popup (basic inherited) ---------- */
#cookiePopup{font-size:.9rem;}

/* ----------  Parallax Helper  ---------- */
.parallax{background-attachment:fixed;}

/* ----------  Animations  ---------- */
@keyframes pop{0%{transform:scale(.8);opacity:0;}100%{transform:scale(1);opacity:1;}}
@keyframes blob{
  0%,100%{border-radius:42% 58% 48% 52%/42% 42% 58% 58%;}
  50%{border-radius:58% 42% 52% 48%/58% 58% 42% 42%;}
}
.morph{
  animation:blob 8s infinite linear;
}

/* ----------  AOS-like Scroll Animations  ---------- */
.aos{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease;}
.aos.animate{opacity:1;transform:translateY(0);}

/* ----------  Media Queries  ---------- */
@media (max-width:768px){
  .main-nav ul{position:fixed;inset:0 0 0 auto;width:70%;background:var(--clr-surface);flex-direction:column;padding:5rem 2rem;transform:translateX(100%);transition:transform var(--transition);}
  .main-nav.open ul{transform:translateX(0);}
  .burger{display:flex;}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition:none!important;animation:none!important;}
}

/* ----------  Page Specific  ---------- */
.privacy main,.terms main{padding-top:100px;}
/* ensure hero text readability */
.hero *{text-shadow:1px 1px 3px rgba(0,0,0,.6);}