
*,
*::before,
*::after{box-sizing:border-box;margin:0;padding:0;}

body{
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  line-height:1.6;
  color:#111827;
  background:#f3f4f6;
}

a{color:#2563eb;text-decoration:none;}
a:hover{text-decoration:underline;}

.site-header{
  background:#ffffff;
  border-bottom:1px solid #e5e7eb;
  position:sticky;
  top:0;
  z-index:50;
}

.container{
  max-width:1120px;
  margin:0 auto;
  padding:0 1rem;
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0.75rem 0;
  gap:0.75rem;
}

.logo a{
  display:flex;
  flex-direction:column;
  font-weight:700;
  color:#111827;
}
.logo-mark{font-size:1.15rem;}
.logo-sub{font-size:0.75rem;color:#6b7280;}

.main-nav{
  display:flex;
  gap:0.9rem;
  font-size:0.95rem;
}

.main-nav a{
  padding:0.35rem 0.5rem;
  border-radius:999px;
  color:#374151;
}
.main-nav a:hover{
  background:#eff6ff;
  text-decoration:none;
}

.header-cta{
  display:flex;
  align-items:center;
  gap:0.5rem;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0.45rem 0.9rem;
  font-size:0.9rem;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:600;
  cursor:pointer;
  text-decoration:none;
  white-space:nowrap;
}

.btn-primary{
  background:#3b82f6;
  border-color:#3b82f6;
  color:#ffffff;
}
.btn-primary:hover{
  background:#2563eb;
}

.btn-outline{
  background:#ffffff;
  border-color:#3b82f6;
  color:#2563eb;
}
.btn-outline:hover{
  background:#e0f2fe;
}

.btn-block{
  width:100%;
  justify-content:center;
}

.nav-toggle{
  display:none;
  border:none;
  background:none;
  font-size:1.5rem;
  cursor:pointer;
}

main{
  padding-bottom:3rem;
}

.section{
  padding:2.5rem 0;
}

.section-alt{
  background:#e5f0ff1a;
}

.content h1{
  font-size:1.75rem;
  margin-bottom:1rem;
}
.content h2{
  font-size:1.35rem;
  margin:1.75rem 0 0.5rem;
}
.content h3{
  font-size:1.1rem;
  margin:1.2rem 0 0.4rem;
}
.content p{
  margin-bottom:0.75rem;
}
.content ul{
  margin:0.5rem 0 1rem 1.2rem;
}
.content li{
  margin-bottom:0.35rem;
}

.hero{
  display:grid;
  grid-template-columns: minmax(0,2.2fr) minmax(0,1.5fr);
  gap:2rem;
  align-items:flex-start;
}

.hero-text h1{
  font-size:2rem;
  margin-bottom:0.75rem;
}
.hero-text p.lead{
  font-size:1.05rem;
  color:#4b5563;
}

.hero-card{
  background:#ffffff;
  border-radius:1rem;
  padding:1.25rem;
  box-shadow:0 10px 25px rgba(15,23,42,0.08);
}

.hero-actions{
  margin-top:1rem;
  display:flex;
  flex-wrap:wrap;
  gap:0.6rem;
}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1.2rem;
  margin-top:1.2rem;
}

.grid-2{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1.2rem;
}

.card{
  background:#ffffff;
  border-radius:0.9rem;
  padding:1.1rem;
  border:1px solid #e5e7eb;
  box-shadow:0 4px 12px rgba(15,23,42,0.04);
}
.card h3{
  margin-bottom:0.45rem;
}
.card p{
  font-size:0.9rem;
  color:#4b5563;
}
.card .btn{
  margin-top:0.8rem;
}

.badge{
  display:inline-flex;
  align-items:center;
  padding:0.15rem 0.65rem;
  border-radius:999px;
  font-size:0.7rem;
  font-weight:600;
  background:#dbeafe;
  color:#1d4ed8;
}

.img-box{
  border-radius:1rem;
  overflow:hidden;
  background:#d1d5db;
  min-height:200px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#4b5563;
  font-size:0.9rem;
}

.form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1rem;
}
.form-grid-full{
  grid-column:1 / 3;
}
label{
  display:block;
  font-size:0.85rem;
  margin-bottom:0.25rem;
  color:#374151;
}
input,textarea{
  width:100%;
  padding:0.55rem 0.6rem;
  border-radius:0.6rem;
  border:1px solid #d1d5db;
  font-size:0.9rem;
}
textarea{
  min-height:130px;
  resize:vertical;
}

.site-footer{
  background:#0f172a;
  color:#e5e7eb;
  padding:2.5rem 0 1.25rem;
}
.footer-main{
  display:grid;
  grid-template-columns:2fr 1.5fr 1.5fr;
  gap:2rem;
  margin-bottom:1.5rem;
}
.footer-main h3,
.footer-main h4{
  margin-bottom:0.5rem;
}
.footer-main p{
  font-size:0.85rem;
  color:#e5e7eb;
}
.footer-nav{
  list-style:none;
  font-size:0.85rem;
}
.footer-nav li{
  margin-bottom:0.3rem;
}
.footer-nav a{
  color:#e5e7eb;
}
.footer-nav a:hover{
  text-decoration:underline;
}
.footer-bottom{
  border-top:1px solid #1f2937;
  padding-top:0.75rem;
  font-size:0.75rem;
  text-align:center;
  color:#9ca3af;
}

/* Cookie Banner */
.cookie-banner{
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  background:#111827;
  color:#e5e7eb;
  padding:0.75rem 1rem;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:0.75rem;
  font-size:0.8rem;
  z-index:60;
}
.cookie-banner p{
  margin:0;
}
.cookie-banner button{
  padding:0.3rem 0.8rem;
  border-radius:999px;
  border:none;
  background:#22c55e;
  color:#022c22;
  font-weight:600;
  cursor:pointer;
}

/* Responsive */
@media(max-width:900px){
  .hero{
    grid-template-columns: minmax(0,1fr);
  }
  .grid-3{
    grid-template-columns:minmax(0,1fr);
  }
  .grid-2{
    grid-template-columns:minmax(0,1fr);
  }
  .footer-main{
    grid-template-columns:minmax(0,1fr);
  }
  .header-inner{
    flex-wrap:wrap;
  }
  .main-nav{
    display:none;
    flex-wrap:wrap;
    gap:0.4rem;
    padding:0.5rem 0 0.75rem;
  }
  .main-nav.open{
    display:flex;
  }
  .header-cta{
    order:3;
    width:100%;
    justify-content:flex-start;
    gap:0.4rem;
  }
  .header-cta .btn-outline{
    flex:1;
  }
  .header-cta .btn-primary{
    flex:1;
  }
  .nav-toggle{
    display:block;
  }
}

@media(max-width:600px){
  .header-cta{
    flex-direction:column;
  }
}
