/* =============================================
   FortiEvents — style.css
   ============================================= */

/* ---------- Reset & Base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --white:#ffffff;
  --green:#166534;
  --emerald:#10B981;
  --gray-bg:#F9FAFB;
  --dark:#111827;
  --radius:10px;
  --max-w:1120px;
  --transition:.25s ease;
}
html{scroll-behavior:smooth}
body{
  font-family:'Open Sans',sans-serif;
  color:var(--dark);
  background:var(--white);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--emerald);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--green)}
ul{list-style:none}
h1,h2,h3,h4{font-family:'Nunito',sans-serif;line-height:1.25}

/* ---------- Utility ---------- */
.container{width:90%;max-width:var(--max-w);margin:0 auto}
.section{padding:80px 0}
.section--gray{background:var(--gray-bg)}
.text-center{text-align:center}
.btn{
  display:inline-block;
  padding:12px 28px;
  border-radius:var(--radius);
  font-weight:700;
  font-size:.95rem;
  cursor:pointer;
  transition:background var(--transition),transform var(--transition);
  border:none;
  font-family:'Nunito',sans-serif;
}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--emerald);color:var(--white)}
.btn--primary:hover{background:var(--green);color:var(--white)}
.btn--outline{border:2px solid var(--emerald);color:var(--emerald);background:transparent}
.btn--outline:hover{background:var(--emerald);color:var(--white)}
.btn--large{padding:16px 36px;font-size:1.05rem}
.tag{
  display:inline-block;
  background:var(--emerald);
  color:var(--white);
  font-size:.75rem;
  font-weight:700;
  padding:3px 10px;
  border-radius:20px;
  text-transform:uppercase;
  letter-spacing:.5px;
}

/* ---------- Header ---------- */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(8px);
  border-bottom:1px solid #e5e7eb;
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:64px;
}
.logo{
  font-family:'Nunito',sans-serif;
  font-size:1.4rem;
  font-weight:800;
  color:var(--dark);
}
.logo span{color:var(--emerald)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{color:var(--dark);font-size:.92rem;font-weight:600}
.nav-links a:hover{color:var(--emerald)}
.nav-cta{
  background:var(--emerald);
  color:var(--white) !important;
  padding:8px 20px;
  border-radius:var(--radius);
  font-size:.88rem !important;
}
.nav-cta:hover{background:var(--green);color:var(--white) !important}
.hamburger{
  display:none;
  background:none;
  border:none;
  cursor:pointer;
  flex-direction:column;
  gap:5px;
}
.hamburger span{
  display:block;
  width:24px;
  height:2.5px;
  background:var(--dark);
  border-radius:2px;
  transition:var(--transition);
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  min-height:520px;
  display:flex;
  align-items:center;
  color:var(--white);
  overflow:hidden;
}
.hero__bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  z-index:0;
}
.hero__bg::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(22,101,52,.88),rgba(16,185,129,.72));
}
.hero .container{position:relative;z-index:1;padding:80px 0}
.hero h1{font-size:2.8rem;margin-bottom:18px;max-width:600px}
.hero p{font-size:1.15rem;margin-bottom:30px;max-width:520px;opacity:.92}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:20px}
.step{text-align:center;padding:32px 20px}
.step__number{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;height:48px;
  border-radius:50%;
  background:var(--emerald);
  color:var(--white);
  font-family:'Nunito',sans-serif;
  font-weight:800;
  font-size:1.2rem;
  margin-bottom:16px;
}
.step h3{font-size:1.15rem;margin-bottom:8px}
.step p{font-size:.93rem;color:#4b5563}

/* ---------- Feature Cards ---------- */
.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.feature-card{
  background:var(--white);
  border:1px solid #e5e7eb;
  border-radius:var(--radius);
  padding:32px;
  transition:box-shadow var(--transition);
}
.feature-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.07)}
.feature-card__icon{
  font-size:1.8rem;
  margin-bottom:12px;
}
.feature-card h3{font-size:1.1rem;margin-bottom:8px}
.feature-card p{font-size:.93rem;color:#4b5563}

/* ---------- Image Band ---------- */
.image-band{
  position:relative;
  height:340px;
  overflow:hidden;
}
.image-band img{
  width:100%;height:100%;
  object-fit:cover;
}
.image-band__overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(22,101,52,.6),rgba(16,185,129,.4));
  display:flex;align-items:center;justify-content:center;
  color:var(--white);
  text-align:center;
  padding:20px;
}
.image-band__overlay h2{font-size:2rem;max-width:560px}

/* ---------- Testimonials ---------- */
.testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px}
.testimonial{
  background:var(--white);
  border:1px solid #e5e7eb;
  border-radius:var(--radius);
  padding:32px;
}
.testimonial blockquote{
  font-style:italic;
  font-size:1rem;
  margin-bottom:16px;
  color:#374151;
  line-height:1.7;
}
.testimonial cite{
  font-style:normal;
  font-weight:700;
  font-size:.9rem;
  color:var(--dark);
}
.testimonial cite span{
  display:block;
  font-weight:400;
  color:#6b7280;
  font-size:.82rem;
}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center}
.stat h3{font-size:2.2rem;color:var(--emerald);margin-bottom:4px}
.stat p{color:#4b5563;font-size:.9rem}

/* ---------- CTA Section ---------- */
.cta-section{
  background:linear-gradient(135deg,var(--green),var(--emerald));
  color:var(--white);
  text-align:center;
  padding:64px 0;
}
.cta-section h2{font-size:2rem;margin-bottom:12px}
.cta-section p{margin-bottom:28px;opacity:.9;max-width:480px;margin-left:auto;margin-right:auto}
.cta-section .btn{background:var(--white);color:var(--green)}
.cta-section .btn:hover{background:#f0fdf4}

/* ---------- How It Works Page ---------- */
.page-hero{
  background:linear-gradient(135deg,var(--green),var(--emerald));
  color:var(--white);
  text-align:center;
  padding:56px 0;
}
.page-hero h1{font-size:2.2rem;margin-bottom:10px}
.page-hero p{opacity:.9;max-width:520px;margin:0 auto}

.flow{counter-reset:flow-step}
.flow__item{
  display:flex;
  gap:24px;
  align-items:flex-start;
  padding:28px 0;
  border-bottom:1px solid #e5e7eb;
  counter-increment:flow-step;
}
.flow__item:last-child{border-bottom:none}
.flow__num{
  flex-shrink:0;
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  background:var(--emerald);
  color:var(--white);
  font-family:'Nunito',sans-serif;
  font-weight:800;
  font-size:1.1rem;
}
.flow__item h3{font-size:1.1rem;margin-bottom:4px}
.flow__item p{font-size:.93rem;color:#4b5563}

/* ---------- Pricing ---------- */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:32px;max-width:740px;margin:40px auto 0}
.pricing-card{
  border:2px solid #e5e7eb;
  border-radius:var(--radius);
  padding:40px 32px;
  text-align:center;
  transition:box-shadow var(--transition);
}
.pricing-card--featured{
  border-color:var(--emerald);
  box-shadow:0 8px 32px rgba(16,185,129,.15);
}
.pricing-card h3{font-size:1.3rem;margin-bottom:8px}
.pricing-card .price{font-size:2.4rem;font-family:'Nunito',sans-serif;font-weight:800;margin:12px 0;color:var(--dark)}
.pricing-card .price span{font-size:.9rem;font-weight:400;color:#6b7280}
.pricing-card ul{text-align:left;margin:24px 0;display:flex;flex-direction:column;gap:10px}
.pricing-card li{font-size:.93rem;padding-left:24px;position:relative;color:#374151}
.pricing-card li::before{content:'\2713';position:absolute;left:0;color:var(--emerald);font-weight:700}
.pricing-card .btn{width:100%;text-align:center}

/* FAQ */
.faq{max-width:700px;margin:0 auto}
.faq details{
  border-bottom:1px solid #e5e7eb;
  padding:18px 0;
}
.faq summary{
  font-family:'Nunito',sans-serif;
  font-weight:700;
  font-size:1.02rem;
  cursor:pointer;
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:1.3rem;color:var(--emerald)}
.faq details[open] summary::after{content:'\2212'}
.faq details p{margin-top:10px;font-size:.93rem;color:#4b5563}

/* ---------- Blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px}
.blog-card{
  border:1px solid #e5e7eb;
  border-radius:var(--radius);
  overflow:hidden;
  transition:box-shadow var(--transition);
}
.blog-card:hover{box-shadow:0 6px 20px rgba(0,0,0,.07)}
.blog-card__body{padding:24px}
.blog-card__meta{font-size:.82rem;color:#6b7280;margin-bottom:6px}
.blog-card h3{font-size:1.1rem;margin-bottom:8px}
.blog-card h3 a{color:var(--dark)}
.blog-card h3 a:hover{color:var(--emerald)}
.blog-card p{font-size:.9rem;color:#4b5563}

/* Blog Post */
.post{max-width:720px;margin:0 auto}
.post__meta{font-size:.88rem;color:#6b7280;margin-bottom:32px}
.post h2{font-size:1.5rem;margin:36px 0 12px}
.post h3{font-size:1.2rem;margin:28px 0 8px}
.post p{margin-bottom:16px}
.post ul,.post ol{margin:0 0 16px 24px;display:flex;flex-direction:column;gap:6px}
.post ul{list-style:disc}
.post ol{list-style:decimal}
.post li{font-size:.95rem;color:#374151}
.post blockquote{
  border-left:4px solid var(--emerald);
  padding:12px 20px;
  margin:20px 0;
  background:var(--gray-bg);
  border-radius:0 var(--radius) var(--radius) 0;
  font-style:italic;
  color:#374151;
}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
.form-group input,
.form-group textarea,
.form-group select{
  width:100%;
  padding:12px 14px;
  border:1px solid #d1d5db;
  border-radius:var(--radius);
  font-size:.95rem;
  font-family:'Open Sans',sans-serif;
  transition:border-color var(--transition);
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus{
  outline:none;
  border-color:var(--emerald);
  box-shadow:0 0 0 3px rgba(16,185,129,.12);
}
.form-group textarea{resize:vertical;min-height:120px}
.form-success{
  display:none;
  text-align:center;
  padding:40px;
}
.form-success svg{margin:0 auto 16px}
.form-success h3{margin-bottom:6px}
.form-success p{color:#4b5563;font-size:.93rem}

/* ---------- Privacy / 404 ---------- */
.legal{max-width:720px;margin:0 auto}
.legal h2{font-size:1.3rem;margin:32px 0 8px}
.legal p,.legal li{font-size:.93rem;color:#374151;margin-bottom:12px}
.legal ul{list-style:disc;margin-left:24px}
.four04{text-align:center;padding:100px 20px}
.four04 h1{font-size:5rem;color:var(--emerald);margin-bottom:8px}
.four04 p{font-size:1.1rem;color:#4b5563;margin-bottom:28px}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--dark);
  color:#9ca3af;
  padding:48px 0 28px;
  font-size:.88rem;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:40px;
  margin-bottom:36px;
}
.footer-grid h4{
  color:var(--white);
  font-family:'Nunito',sans-serif;
  font-size:1rem;
  margin-bottom:14px;
}
.footer-grid a{color:#9ca3af;display:block;margin-bottom:8px;font-size:.86rem}
.footer-grid a:hover{color:var(--emerald)}
.footer-grid p{line-height:1.7}
.footer-bottom{
  border-top:1px solid #1f2937;
  padding-top:20px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:.82rem;
}
.footer-bottom a{color:#9ca3af}
.footer-bottom a:hover{color:var(--emerald)}

/* ---------- Responsive ---------- */
@media(max-width:768px){
  .hamburger{display:flex}
  .nav-links{
    display:none;
    position:absolute;
    top:64px;left:0;right:0;
    background:var(--white);
    flex-direction:column;
    padding:20px;
    gap:16px;
    border-bottom:1px solid #e5e7eb;
    box-shadow:0 8px 24px rgba(0,0,0,.08);
  }
  .nav-links.active{display:flex}
  .hero h1{font-size:2rem}
  .hero{min-height:420px}
  .steps{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr;gap:32px}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .pricing-grid{grid-template-columns:1fr}
  .image-band{height:240px}
  .image-band__overlay h2{font-size:1.4rem}
}
@media(max-width:480px){
  .hero h1{font-size:1.6rem}
  .section{padding:56px 0}
  .page-hero{padding:40px 0}
}
