:root{
  --primary:#2D5B4E;
  --primary-50:#F1F7F5;
  --primary-100:#E6F0EB;
  --primary-200:#CCE1D6;
  --primary-300:#A3C6B3;
  --primary-600:#2D5B4E;
  --primary-700:#254D42;
  --secondary:#8FBC8F;
  --secondary-50:#F5FDF6;
  --secondary-100:#EDF9F0;
  --accent:#FFD166;
  --bg:#FFFFFF;
  --footer-bg:#1F3B34;
  --muted:#6B7280;
  --border:#E5E7EB;
  --text:#1F2937;
  --text-light:#6B7280;
  --shadow-1:0 2px 8px -2px rgba(45,91,78,0.08);
  --shadow-2:0 10px 30px -12px rgba(45,91,78,0.14);
  --shadow-3:0 22px 45px -16px rgba(45,91,78,0.22);
  --radius-sm:12px;
  --radius-md:18px;
  --radius-lg:24px;
  --radius-xl:32px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
  line-height:1.7;
  color:var(--text);
  background:
    radial-gradient(1400px 800px at 110% -10%, var(--primary-100) 0%, transparent 60%),
    radial-gradient(900px 600px at -10% 20%, var(--secondary-50) 0%, transparent 55%),
    var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-700);text-decoration:underline}
p{margin:0 0 1rem 0}
ul,ol{margin:0 0 1rem 1.25rem}
h1,h2,h3,h4,h5,h6{
  font-family:Poppins, Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Noto Sans";
  font-weight:600;
  line-height:1.25;
  letter-spacing:-0.01em;
  margin:0 0 0.75rem 0;
  color:var(--text);
}
h1{font-size:clamp(2rem, 3.5vw, 3rem)}
h2{font-size:clamp(1.5rem, 2.5vw, 2rem)}
h3{font-size:clamp(1.25rem, 2vw, 1.5rem)}
h4{font-size:1.125rem}
h5{font-size:1rem}
h6{font-size:0.95rem}

.container{
  width:100%;
  max-width:1200px;
  margin-inline:auto;
  padding-inline:1.2rem;
}
@media (min-width:768px){
  .container{padding-inline:2rem}
}

.section{
  padding-block:4.5rem;
  position:relative;
  isolation:isolate;
}
.section-soft{
  background:linear-gradient(180deg, var(--secondary-50) 0%, #F9FFFE 60%, var(--bg) 100%);
}

.card{
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-1);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  position:relative;
  overflow:hidden;
}
.card::after{
  content:"";
  position:absolute;
  inset:-2px -2px auto -2px;
  height:6px;
  background:linear-gradient(90deg, var(--primary), var(--secondary), var(--accent));
  opacity:.85;
  border-top-left-radius:var(--radius-lg);
  border-top-right-radius:var(--radius-lg);
}
.card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-2);
  border-color:rgba(45,91,78,0.2);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.6rem;
  border:0;
  padding:.9rem 1.2rem;
  border-radius:20px;
  font-weight:600;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .2s ease, color .2s ease;
  text-decoration:none;
  line-height:1.2;
}
.btn:focus-visible{
  outline:3px solid color-mix(in oklab, var(--primary) 70%, white 30%);
  outline-offset:2px;
}

.btn-primary{
  background:linear-gradient(135deg, var(--primary) 0%, color-mix(in oklab, var(--primary) 90%, var(--accent) 10%) 100%);
  color:white;
  box-shadow:0 10px 20px -12px rgba(45,91,78,.6);
}
.btn-primary:hover{
  transform:translateY(-1px);
  color:white;
  box-shadow:0 18px 32px -18px rgba(45,91,78,.7);
}
.btn-primary:active{transform:translateY(0)}

.btn-secondary{
  background:linear-gradient(135deg, var(--secondary) 0%, color-mix(in oklab, var(--secondary) 80%, white 20%) 100%);
  color:color-mix(in oklab, var(--primary) 70%, black 30%);
  box-shadow:0 10px 20px -12px rgba(143,188,143,.5);
}
.btn-secondary:hover{transform:translateY(-1px)}

.btn-outline{
  background:var(--bg);
  color:var(--primary);
  border:2px solid color-mix(in oklab, var(--primary) 70%, white 30%);
}
.btn-outline:hover{
  background:var(--primary);
  color:white;
  text-decoration:none;
}

.form .field{margin-bottom:1.1rem}
.form label{
  display:block;
  font-weight:600;
  font-size:.95rem;
  margin-bottom:.45rem;
  color:var(--text);
}
.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form input[type="url"],
.form textarea,
.form select{
  width:100%;
  padding:.85rem 1rem;
  border:1.5px solid var(--border);
  border-radius:var(--radius-md);
  background:var(--bg);
  color:var(--text);
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
  box-shadow:0 2px 8px -6px rgba(45,91,78,.25) inset;
}
.form textarea{min-height:140px;resize:vertical}
.form input::placeholder,
.form textarea::placeholder{color:var(--muted);opacity:.85}
.form input:focus,
.form textarea:focus,
.form select:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 4px color-mix(in oklab, var(--primary) 15%, white 85%);
}
.form input[aria-invalid="true"],
.form textarea[aria-invalid="true"],
.form select[aria-invalid="true"]{
  border-color:#E11D48;
  box-shadow:0 0 0 4px rgba(225,29,72,.12);
}

.header{
  background:linear-gradient(180deg, var(--primary-600) 0%, var(--primary-700) 100%);
  color:white;
  position:relative;
  overflow:hidden;
}
.header::before,
.header::after{
  content:"";
  position:absolute;
  inset:auto auto  -40% -15%;
  width:70%;
  height:220%;
  background:radial-gradient(60% 60% at 50% 50%, rgba(143,188,143,.12), transparent 70%);
  filter:blur(6px);
  transform:rotate(-8deg);
  pointer-events:none;
}
.header::after{
  inset:-40% -25% auto auto;
  width:80%;
  height:240%;
  background:radial-gradient(60% 60% at 50% 50%, rgba(255,209,102,.14), transparent 70%);
  transform:rotate(8deg);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding-block:1rem;
}
.brand{
  display:flex;
  align-items:center;
  gap:.8rem;
  font-weight:700;
  font-size:1.15rem;
  color:white;
  text-decoration:none;
}
.brand:hover{color:white;text-decoration:none}
.brand-logo{
  width:36px;
  height:36px;
  border-radius:12px;
  background:linear-gradient(135deg, var(--secondary), var(--primary));
  display:grid;
  place-items:center;
  box-shadow:0 6px 16px -8px rgba(0,0,0,.35), inset 0 0 0 2px rgba(255,255,255,.22);
}
.brand-logo svg{width:22px;height:22px;fill:white}

.nav-links{
  display:flex;
  align-items:center;
  gap:1rem;
}
.nav-links a{
  color:rgba(255,255,255,.92);
  text-decoration:none;
  font-weight:500;
  padding:.5rem .75rem;
  border-radius:12px;
  transition:background .2s ease, color .2s ease;
}
.nav-links a:hover{
  background:rgba(255,255,255,.12);
  color:white;
}
.nav-cta{margin-left:.5rem}

.hero{
  padding-block:4.5rem 5rem;
  display:grid;
  gap:2.2rem;
}
@media (min-width:992px){
  .hero{
    grid-template-columns:1.1fr .9fr;
    align-items:center;
  }
}
.hero-visual{
  border-radius:var(--radius-xl);
  background:
    radial-gradient(120% 120% at 90% 10%, rgba(255,209,102,.25), transparent 60%),
    radial-gradient(120% 120% at 0% 100%, rgba(143,188,143,.18), transparent 60%),
    var(--bg);
  box-shadow:var(--shadow-3);
  padding:1rem;
  position:relative;
  overflow:hidden;
}
.hero-visual::after{
  content:"";
  position:absolute;
  inset:-40% -40% auto auto;
  width:80%;
  height:80%;
  background:
    radial-gradient(40% 40% at 50% 50%, rgba(45,91,78,.08), transparent 70%);
  filter:blur(8px);
  transform:rotate(12deg);
}
.hero-badges{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  margin-top:1rem;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.45rem .7rem;
  border-radius:999px;
  background:color-mix(in oklab, var(--secondary) 12%, white 88%);
  color:var(--primary-700);
  border:1px solid color-mix(in oklab, var(--primary) 10%, white 90%);
  font-size:.85rem;
  font-weight:600;
}
.badge svg{width:16px;height:16px;fill:currentColor}

.kicker{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:rgba(255,255,255,.9);
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.25);
  padding:.4rem .75rem;
  border-radius:999px;
}
.hero h1{color:white;margin-top:1rem}
.hero p{color:rgba(255,255,255,.95)}
.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.2rem}

.hero-graphic{
  position:relative;
  background:linear-gradient(180deg, var(--bg) 0%, var(--secondary-50) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:1.25rem;
  box-shadow:var(--shadow-2);
  overflow:hidden;
}
.hero-graphic::before{
  content:"";
  position:absolute;
  inset:-10% -10% auto -10%;
  height:50%;
  background:radial-gradient(60% 60% at 50% 50%, rgba(45,91,78,.12), transparent 70%);
}
.hero-graphic-inner{
  position:relative;
  z-index:2;
  background:var(--bg);
  border-radius:18px;
  padding:1rem;
  border:1px solid var(--border);
  box-shadow:0 6px 20px -12px rgba(45,91,78,.45);
}

.grid{
  display:grid;
  gap:1.2rem;
}
@media (min-width:768px){
  .grid.cols-2{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:992px){
  .grid.cols-3{grid-template-columns:repeat(3,1fr)}
}

.split{
  display:grid;
  gap:1.2rem;
}
@media (min-width:992px){
  .split{grid-template-columns:1.1fr .9fr;align-items:center}
}

.illustration{
  position:relative;
  border-radius:var(--radius-xl);
  background:linear-gradient(180deg, var(--bg) 0%, var(--secondary-50) 100%);
  border:1px solid var(--border);
  box-shadow:var(--shadow-2);
  overflow:hidden;
  padding:1.2rem;
}
.illustration::before{
  content:"";
  position:absolute;
  inset:-20% -20% auto -20%;
  height:60%;
  background:radial-gradient(50% 50% at 50% 50%, rgba(255,209,102,.18), transparent 70%);
  filter:blur(6px);
}

.feature{
  padding:1.1rem;
  display:flex;
  gap:.9rem;
}
.feature-icon{
  width:46px;
  height:46px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--secondary), var(--primary-100));
  color:var(--primary-700);
  box-shadow:0 6px 14px -10px rgba(45,91,78,.6);
  flex:0 0 auto;
}
.feature-icon svg{width:22px;height:22px;fill:currentColor}
.feature h3{margin:.1rem 0 .35rem 0}
.feature p{color:var(--muted)}

.pricing{
  display:grid;
  gap:1.2rem;
}
@media (min-width:992px){
  .pricing{grid-template-columns:repeat(3,1fr)}
}
.price-card{
  padding:1.25rem;
  border-radius:var(--radius-xl);
  border:1.5px solid var(--border);
  background:var(--bg);
  box-shadow:var(--shadow-1);
  position:relative;
  overflow:hidden;
}
.price-card::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:6px;
  background:linear-gradient(90deg, var(--primary), var(--secondary), var(--accent));
}
.price{
  font-size:2rem;
  font-weight:800;
  color:var(--primary-700);
  margin:.5rem 0 1rem 0;
}
.price small{font-size:.9rem;color:var(--muted);font-weight:600}

.features-list{
  list-style:none;
  padding:0;
  margin:0 0 1.2rem 0;
  display:grid;
  gap:.55rem;
}
.features-list li{
  display:flex;
  align-items:flex-start;
  gap:.55rem;
  color:var(--text);
}
.features-list svg{
  width:18px;
  height:18px;
  fill:var(--secondary);
  margin-top:.2rem;
  flex:0 0 auto;
}

.testimonial{
  padding:1.2rem;
  display:flex;
  flex-direction:column;
  gap:.9rem;
}
.quote{
  font-size:1.05rem;
  line-height:1.65;
}
.author{
  display:flex;
  align-items:center;
  gap:.7rem;
}
.avatar{
  width:44px;
  height:44px;
  border-radius:14px;
  background:linear-gradient(135deg, var(--secondary-100), var(--primary-100));
  display:grid;
  place-items:center;
  font-weight:700;
  color:var(--primary-700);
  border:1px solid var(--border);
}

.cta{
  text-align:center;
  background:linear-gradient(180deg, var(--primary-100) 0%, var(--secondary-50) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-2);
  padding:2rem;
}
.cta h2{margin-bottom:.5rem}
.cta p{color:var(--muted);margin-bottom:1.2rem}

.footer{
  background:var(--footer-bg);
  color:rgba(255,255,255,.9);
  margin-top:4rem;
  position:relative;
  overflow:hidden;
}
.footer::before{
  content:"";
  position:absolute;
  inset:auto auto -20% -10%;
  width:60%;
  height:200%;
  background:radial-gradient(60% 60% at 50% 50%, rgba(255,255,255,.06), transparent 70%);
  filter:blur(8px);
  transform:rotate(-8deg);
}
.footer-top{
  padding-block:3rem;
  display:grid;
  gap:1.5rem;
}
@media (min-width:992px){
  .footer-top{
    grid-template-columns:1.2fr 1fr 1fr 1fr;
  }
}
.footer-col h5{
  color:white;
  margin-bottom:.75rem;
}
.footer-col a{
  color:rgba(255,255,255,.85);
  text-decoration:none;
  display:block;
  padding:.25rem 0;
}
.footer-col a:hover{color:white;text-decoration:underline}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  padding-block:1rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
  font-size:.95rem;
  color:rgba(255,255,255,.85);
}
.footer .brand{color:white}
.footer .brand:hover{color:white}

.note{
  font-size:.9rem;
  color:var(--muted);
}

.tag{
  display:inline-flex;
  align-items:center;
  padding:.35rem .6rem;
  border-radius:999px;
  background:var(--primary-50);
  border:1px solid var(--primary-200);
  color:var(--primary-700);
  font-weight:600;
  font-size:.85rem;
}

.section-header{
  margin-bottom:2rem;
  text-align:center;
}
.section-header .lead{
  color:var(--muted);
  margin-top:.4rem;
}

.hide-sm{display:none}
@media (min-width:768px){
  .hide-sm{display:initial}
}

.divider{
  height:1px;
  background:linear-gradient(90deg, transparent, var(--border), transparent);
  margin:2rem 0;
}

@media (prefers-reduced-motion:no-preference){
  .card{will-change:transform}
  .btn{will-change:transform}
}


/* Cookie Banner Additional Styles for Tailwind */
.cookie-banner-hover-effect:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

@media (prefers-reduced-motion: reduce) {
    .cookie-banner-hover-effect:hover {
        transform: none;
    }
}