/* ==========================================================================
   GLOBAL CONFIG
   ========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700&family=Roboto:wght@400;700&display=swap');

:root{
  /* COLOR PALETTE --------------------------------------------------------- */
  --clr-primary:#29b55d;
  --clr-primary-dark:#1c8141;
  --clr-secondary:#16a085;
  --clr-secondary-dark:#0e6355;
  --clr-accent:#ffb703;
  --clr-accent-dark:#c98500;
  --clr-bg:#f4f7f5;
  --clr-surface:#e8eee9;

  --text-dark:#222222;
  --text-light:#ffffff;
  --text-muted:#555555;

  /* GRADIENTS ------------------------------------------------------------- */
  --gradient-primary:linear-gradient(135deg,var(--clr-primary)0%,var(--clr-secondary)100%);
  --gradient-accent:linear-gradient(135deg,var(--clr-accent)0%,var(--clr-primary)100%);
  --gradient-overlay:linear-gradient(rgba(0,0,0,0.55),rgba(0,0,0,0.55));

  /* NEUMORPHIC SHADOWS ---------------------------------------------------- */
  --neu-shadow:8px 8px 12px rgba(0,0,0,0.15),-8px -8px 12px rgba(255,255,255,0.6);
  --neu-inset:inset 6px 6px 8px rgba(0,0,0,0.1), inset -6px -6px 8px rgba(255,255,255,0.6);

  /* RADIUS  --------------------------------------------------------------- */
  --radius-s:6px;
  --radius-m:12px;
  --radius-l:24px;

  /* ANIMATION TIMING ------------------------------------------------------ */
  --ease-out:cubic-bezier(.19,1,.22,1);
}

/* ==========================================================================
   RESET & BASE
   ========================================================================== */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Lato',sans-serif;
  color:var(--text-dark);
  background:var(--clr-bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{font-family:'Roboto',sans-serif;font-weight:700;color:var(--text-dark);text-shadow:1px 1px 3px rgba(0,0,0,.15);}
img{max-width:100%;display:block;}

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

/* ==========================================================================
   HEADER
   ========================================================================== */
.main-header{
  width:100%;
  position:fixed;
  top:0;left:0;z-index:999;
  background:var(--clr-surface);
  box-shadow:0 3px 6px rgba(0,0,0,0.1);
}
.main-header .container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:0.8rem 0;
}
.logo a{font-size:1.6rem;color:var(--clr-primary);font-weight:700;text-decoration:none;}
.main-nav ul{display:flex;gap:1.2rem;list-style:none;}
.main-nav a{color:var(--text-dark);text-decoration:none;position:relative;padding:0.4rem 0;}
.main-nav a::after{content:'';position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--clr-primary);transition:width .3s var(--ease-out);}
.main-nav a:hover::after{width:100%;}
/* Burger */
.burger{display:none;background:none;border:none;cursor:pointer}
.burger span{display:block;width:22px;height:3px;background:var(--text-dark);margin:4px 0;border-radius:3px;transition:all .4s var(--ease-out);}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero-section{
  min-height:80vh;
  display:flex;
  align-items:center;
  background-size:cover;
  background-repeat:no-repeat;
  background-position:center;
  position:relative;
}
.hero-section .container{text-align:center}
.hero-title{font-size:2.5rem;margin-bottom:1rem;color:var(--text-light)}
.hero-text{font-size:1.1rem;margin-bottom:2rem;color:var(--text-light)}
.stats-widget{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}
.stats-widget .stat{background:rgba(255,255,255,0.15);backdrop-filter:blur(6px);padding:1rem 1.5rem;border-radius:var(--radius-m);color:#fff;box-shadow:var(--neu-shadow);}
.stats-widget .stat span{display:block;font-size:1.5rem;font-weight:700}

/* ==========================================================================
   SECTIONS
   ========================================================================== */
.section{padding:4.5rem 0}
.alt-bg{background:var(--clr-surface)}
.section-title{text-align:center;font-size:2rem;margin-bottom:2rem;position:relative;}
.section-title::after{content:'';width:60px;height:4px;background:var(--clr-primary);display:block;margin:0.6rem auto 0;border-radius:2px}

/* ==========================================================================
   CARDS
   ========================================================================== */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}
.card{
  background:var(--clr-surface);
  box-shadow:var(--neu-shadow);
  border-radius:var(--radius-m);
  padding:1rem;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  transition:transform .4s var(--ease-out);
}
.card:hover{transform:translateY(-6px)}
.card-image{width:100%;height:200px;overflow:hidden;border-radius:var(--radius-s);margin-bottom:1rem;display:flex;align-items:center;justify-content:center;}
.card-image img{width:100%;height:100%;object-fit:cover;margin:0 auto;}
.card-content h3{margin-bottom:0.5rem;font-size:1.25rem;}
.card-content p{font-size:0.95rem;color:var(--text-muted);}

/* ==========================================================================
   BUTTONS & LINKS
   ========================================================================== */
.btn-primary,
button,
input[type="submit"]{
  appearance:none;
  border:none;
  padding:0.75rem 2rem;
  background:var(--gradient-primary);
  color:var(--text-light);
  border-radius:var(--radius-m);
  font-weight:700;
  cursor:pointer;
  transition:all .4s var(--ease-out);
}
.btn-primary:hover,
button:hover,
input[type="submit"]:hover{
  background:var(--gradient-accent);
  transform:translateY(-2px);
  box-shadow:0 6px 12px rgba(0,0,0,0.15);
}
.external-links a,
a.read-more{
  color:var(--clr-secondary);
  font-weight:700;
  position:relative;
  text-decoration:none;
}
.external-links a::after,
a.read-more::after{
  content:'';
  position:absolute;
  left:0;bottom:-2px;
  width:100%;height:2px;
  background:var(--clr-secondary);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .3s var(--ease-out);
}
.external-links a:hover::after,
a.read-more:hover::after{transform:scaleX(1);}

/* ==========================================================================
   FORMS
   ========================================================================== */
form{max-width:650px;margin:0 auto;display:flex;flex-direction:column;gap:1rem}
.form-group{display:flex;flex-direction:column;}
label{font-weight:700;margin-bottom:0.3rem;}
input,textarea{
  padding:0.75rem 1rem;
  border-radius:var(--radius-s);
  border:1px solid #d1d9d2;
  background:var(--clr-surface);
  box-shadow:var(--neu-inset);
  font-family:'Lato',sans-serif;
  resize:vertical;
}
input:focus,textarea:focus{outline:none;border-color:var(--clr-primary)}

/* ==========================================================================
   FAQ
   ========================================================================== */
details{background:var(--clr-surface);padding:1rem;border-radius:var(--radius-s);box-shadow:var(--neu-shadow);margin-bottom:1rem;}
summary{cursor:pointer;font-weight:700;}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.main-footer{
  background:var(--clr-secondary-dark);
  color:var(--text-light);
  text-align:center;
  padding:2rem 0;
}
.main-footer nav a{color:#cdeee6;margin:0 0.4rem;text-decoration:none;}
.main-footer nav a:hover{text-decoration:underline;}
.social-links a{color:#ffffff;margin:0 0.4rem;text-decoration:none;font-weight:700;}
.social-links a:hover{color:var(--clr-accent);}
.main-footer small{display:block;margin-top:1rem;color:#cdeee6;}

/* ==========================================================================
   UTILITIES
   ========================================================================== */
.text-center{text-align:center}
.m-auto{margin:0 auto}
.parallax{background-attachment:fixed}
.shadow{box-shadow:var(--neu-shadow)}
/* Success page */
.success-page, .success-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center}
/* Pages padding */
.privacy-page, .terms-page{padding-top:100px}

/* ==========================================================================
   NON-LINEAR ANIMATIONS
   ========================================================================== */
@keyframes floatY{
  0%{transform:translateY(0)}
  50%{transform:translateY(-12px)}
  100%{transform:translateY(0)}
}
@keyframes swing{
  0%{transform:rotate(0deg)}
  50%{transform:rotate(4deg)}
  100%{transform:rotate(0deg)}
}
.stats-widget .stat{animation:floatY 6s ease-in-out infinite;}
.card:hover .card-image{animation:swing 1s ease-in-out}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media(max-width:992px){
  .main-nav ul{display:none;flex-direction:column;background:var(--clr-surface);position:absolute;top:100%;right:1rem;padding:1rem;border-radius:var(--radius-s);box-shadow:var(--neu-shadow);}
  .burger{display:block}
  .burger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.active span:nth-child(2){opacity:0}
  .burger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .main-nav.open ul{display:flex}
}

/* ==========================================================================
   BACKGROUND HELPERS
   ========================================================================== */
[data-prompt]{background-size:cover;background-repeat:no-repeat;background-position:center;}
.burger{
  display: none;
}