@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700&family=Open+Sans:wght@400;600&display=swap');

:root{
  --color-primary:#2171ff;
  --color-secondary:#22d375;
  --color-accent:#28e781;
  --color-bg:#f3f4f6;
  --color-text:#423838;
  --color-heading:#0a0a0a;
  --color-white:#ffffff;
  --color-dark-header:#020f33;
  --color-dark-footer:#040e34;
  --color-subtle:#243673;
  --color-border-header:#e2e9ff;
  --ast-body-line-height:1.8em;
  --max-w:1200px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

html{font-size:87.5%;}

body{
  font-family:'Montserrat',sans-serif;
  font-weight:400;
  font-size:14px;
  font-size:1rem;
  line-height:var(--ast-body-line-height,1.8em);
  color:var(--color-text);
  background-color:var(--color-bg);
  background-image:none;
}

a{color:var(--color-primary);text-decoration:none;}
a:hover,a:focus{color:var(--color-secondary);}

img{max-width:100%;height:auto;display:block;}

::selection{background-color:var(--color-primary);color:#ffffff;}

h1,h2,h3,h4,h5,h6{
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  color:var(--color-heading);
}

h1{font-size:75px;font-size:5.3571428571429rem;line-height:1.4em;}
h2{font-size:38px;font-size:2.7142857142857rem;line-height:1.3em;}
h3{font-size:26px;font-size:1.8571428571429rem;line-height:1.3em;}
h4{font-size:20px;font-size:1.4285714285714rem;line-height:1.2em;}
h5{font-size:18px;font-size:1.2857142857143rem;line-height:1.2em;}
h6{font-size:15px;font-size:1.0714285714286rem;line-height:1.25em;}

p{margin-bottom:1.2em;}
p:last-child{margin-bottom:0;}

ul,ol{padding-left:1.5em;margin-bottom:1em;}
li{margin-bottom:0.4em;}

.container{
  max-width:var(--max-w);
  margin-left:auto;
  margin-right:auto;
  padding-left:20px;
  padding-right:20px;
}

/* BUTTONS */
.btn{
  display:inline-block;
  border-style:solid;
  border-top-width:0;border-right-width:0;border-left-width:0;border-bottom-width:0;
  color:var(--color-white);
  border-color:var(--color-secondary);
  background-color:var(--color-secondary);
  padding-top:15px;padding-right:40px;padding-bottom:15px;padding-left:40px;
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  font-size:16px;
  font-size:1.1428571428571rem;
  line-height:1em;
  text-transform:capitalize;
  border-top-left-radius:2px;border-top-right-radius:2px;border-bottom-right-radius:2px;border-bottom-left-radius:2px;
  cursor:pointer;
  transition:background-color 0.25s,border-color 0.25s;
  text-decoration:none;
}
.btn:hover,.btn:focus{
  color:var(--color-white);
  background-color:var(--color-heading);
  border-color:var(--color-heading);
}

.btn-outline{
  display:inline-block;
  border-style:solid;
  border-top-width:2px;border-right-width:2px;border-bottom-width:2px;border-left-width:2px;
  border-color:var(--color-secondary);
  color:var(--color-secondary);
  background-color:transparent;
  padding-top:13px;padding-right:38px;padding-bottom:13px;padding-left:38px;
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  font-size:16px;
  font-size:1.1428571428571rem;
  line-height:1em;
  border-top-left-radius:2px;border-top-right-radius:2px;border-bottom-right-radius:2px;border-bottom-left-radius:2px;
  cursor:pointer;
  transition:background-color 0.25s,color 0.25s;
  text-decoration:none;
}
.btn-outline:hover,.btn-outline:focus{
  background-color:var(--color-secondary);
  color:var(--color-white);
}

/* HEADER */
#site-header{
  background-color:#020f33;
  background-image:none;
  position:sticky;
  top:0;
  z-index:900;
  border-bottom-width:1px;
  border-bottom-color:#e2e9ff;
  border-bottom-style:solid;
  padding:1em 0;
  min-height:70px;
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:70px;
}

.site-logo a{
  display:flex;
  align-items:center;
  text-decoration:none;
}

.logo-svg-text{
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:18px;
  fill:#ffffff;
}

.main-nav ul{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  gap:0;
}

.main-nav .menu-item > .menu-link{
  display:block;
  color:#ffffff;
  padding:0 18px;
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  font-size:14px;
  line-height:70px;
  text-decoration:none;
  transition:color 0.2s;
}
.main-nav .menu-item > .menu-link:hover,
.main-nav .menu-item.current > .menu-link{
  color:var(--color-primary);
}

/* hamburger */
.menu-toggle{
  display:none;
  background:var(--color-white);
  border:none;
  color:var(--color-primary);
  border-top-left-radius:2px;border-top-right-radius:2px;border-bottom-right-radius:2px;border-bottom-left-radius:2px;
  padding:8px 10px;
  cursor:pointer;
  font-size:20px;
  line-height:1;
}

/* HERO */
.hero-section{
  position:relative;
  background-color:#020f33;
  background-image:url('../img/hero-bg.webp');
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  min-height:600px;
  display:flex;
  align-items:center;
}

.hero-overlay{
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  background-color:rgba(2,15,51,0.72);
  z-index:1;
}

.hero-content{
  position:relative;
  z-index:2;
  max-width:700px;
  padding:80px 0;
}

.hero-content h1{
  color:#ffffff;
  margin-bottom:20px;
}

.hero-content p{
  color:#ffffff;
  font-family:'Open Sans',sans-serif;
  font-size:143.75%;
  line-height:1.5;
  font-weight:400;
  margin-bottom:30px;
}

/* SECTIONS general */
.section{padding:80px 0;}
.section-alt{background-color:#ffffff;}
.section-dark{background-color:var(--color-subtle);color:#ffffff;}
.section-dark h2,.section-dark h3,.section-dark p{color:#ffffff;}

.section-heading{text-align:center;margin-bottom:50px;}
.section-heading h2{margin-bottom:15px;}
.section-heading p{max-width:650px;margin-left:auto;margin-right:auto;}

/* ABOUT section 2-col */
.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}

.about-text h2{margin-bottom:20px;}
.about-text p{margin-bottom:1em;}

.about-img img{
  width:100%;
  height:auto;
  border-radius:4px;
}

/* SERVICES cards */
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
}

.service-card{
  background-color:#ffffff;
  border-radius:4px;
  padding:40px 30px;
  text-align:center;
  border-top:3px solid var(--color-secondary);
  transition:box-shadow 0.25s;
}
.service-card:hover{box-shadow:0 8px 30px rgba(0,0,0,0.1);}

.service-card .icon{
  font-size:36px;
  color:var(--color-primary);
  margin-bottom:20px;
}

.service-card h3{
  font-size:20px;
  margin-bottom:12px;
}

/* HOW IT WORKS steps */
.steps-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:40px;
  text-align:center;
}

.step-item .step-num{
  width:60px;height:60px;
  border-radius:50%;
  background-color:var(--color-primary);
  color:#ffffff;
  font-size:24px;
  font-weight:700;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;
}

.step-item h3{font-size:20px;margin-bottom:10px;}

/* STATS */
.stats-section{
  background-color:var(--color-subtle);
  padding:80px 0;
}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px;
  text-align:center;
}

.stat-item .stat-number{
  font-size:48px;
  font-weight:700;
  color:var(--color-secondary);
  line-height:1;
  margin-bottom:10px;
  font-family:'Montserrat',sans-serif;
}

.stat-item .stat-label{
  color:#ffffff;
  font-size:14px;
}

/* TESTIMONIALS */
.testi-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
}

.testi-card{
  background-color:#ffffff;
  border-radius:4px;
  padding:30px;
  position:relative;
}

.testi-card::before{
  content:'\201C';
  font-size:60px;
  color:var(--color-secondary);
  line-height:1;
  position:absolute;
  top:15px;left:20px;
  font-family:Georgia,serif;
}

.testi-card blockquote{
  padding-top:30px;
  margin-bottom:20px;
  font-size:14px;
  color:var(--color-text);
}

.testi-author strong{
  display:block;
  font-weight:700;
  color:var(--color-heading);
}
.testi-author span{
  font-size:13px;
  color:#888;
}

/* CTA SECTION */
.cta-section{
  background-color:#020f33;
  padding:80px 0;
  text-align:center;
}
.cta-section h2,.cta-section p{color:#ffffff;}
.cta-section h2{margin-bottom:15px;}
.cta-section p{margin-bottom:30px;}

/* CONTACT PAGE */
.contact-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:60px;
}

.contact-info-block{
  background-color:#ffffff;
  padding:40px;
  border-radius:4px;
}

.contact-info-item{
  display:flex;
  align-items:flex-start;
  gap:15px;
  margin-bottom:25px;
}

.contact-info-item .ci-icon{
  color:var(--color-primary);
  font-size:20px;
  margin-top:3px;
  flex-shrink:0;
}

.map-placeholder{
  background-color:#e0e8ff;
  height:250px;
  border-radius:4px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--color-primary);
  font-weight:600;
  margin-top:30px;
}

/* FORM */
.contact-form .form-group{margin-bottom:20px;}

.contact-form label{
  display:block;
  font-weight:600;
  margin-bottom:6px;
  font-size:13px;
}

.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form textarea{
  width:100%;
  padding:12px 15px;
  border:1px solid #dddddd;
  border-radius:2px;
  font-family:'Montserrat',sans-serif;
  font-size:14px;
  color:var(--color-text);
  background:#ffffff;
  transition:border-color 0.2s;
}
.contact-form input[type="text"]:focus,
.contact-form input[type="email"]:focus,
.contact-form input[type="tel"]:focus,
.contact-form textarea:focus{
  outline:none;
  border-color:var(--color-primary);
}

.contact-form textarea{height:150px;resize:vertical;}

.form-error{
  border-color:#e74c3c !important;
}
.error-msg{
  color:#e74c3c;
  font-size:12px;
  margin-top:4px;
  display:none;
}

/* PAGE CONTENT (privacy/terms/cookie) */
.page-hero{
  background-color:#020f33;
  padding:60px 0;
  text-align:center;
}
.page-hero h1{color:#ffffff;font-size:48px;}

.content-section{
  padding:80px 0;
  background-color:#ffffff;
}

.content-body h2{
  font-size:24px;
  margin-top:40px;
  margin-bottom:15px;
  color:var(--color-heading);
}
.content-body h2:first-child{margin-top:0;}
.content-body p{margin-bottom:1em;}
.content-body ul{margin-bottom:1em;}

/* FOOTER */
#site-footer{
  background-color:#040e34;
  background-image:none;
  padding:60px 0 0;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr;
  gap:40px;
  padding-bottom:40px;
}

.footer-brand p{
  color:rgba(255,255,255,0.7);
  margin-top:15px;
  font-size:13px;
  max-width:280px;
}

.footer-widget-title{
  font-size:16px;
  font-weight:700;
  color:#ffffff;
  margin-bottom:20px;
}

.footer-menu{
  list-style:none;
  padding:0;margin:0;
}
.footer-menu li{margin-bottom:10px;}
.footer-menu a{
  color:rgba(255,255,255,0.7);
  font-size:13px;
  text-decoration:none;
  transition:color 0.2s;
}
.footer-menu a:hover{color:var(--color-secondary);}

.footer-social{
  display:flex;
  gap:12px;
  margin-top:15px;
}
.footer-social a{
  width:36px;height:36px;
  border-radius:50%;
  background-color:rgba(255,255,255,0.1);
  display:flex;align-items:center;justify-content:center;
  color:#ffffff;
  font-size:15px;
  transition:background-color 0.2s;
  text-decoration:none;
}
.footer-social a:hover{background-color:var(--color-primary);}

.footer-social a.fb:hover{background-color:#557dbc;}
.footer-social a.tw:hover{background-color:#7acdee;}
.footer-social a.yt:hover{background-color:#af0606;}

.footer-below{
  border-top-width:1px;
  border-top-color:rgba(255,255,255,0.16);
  border-top-style:solid;
  padding-top:2.1em;
  padding-bottom:2.1em;
  padding-left:1em;
  padding-right:1em;
  background-color:#020f33;
  background-image:none;
  min-height:80px;
  display:flex;
  align-items:center;
}

.footer-below-inner{
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  width:100%;
}

.footer-copyright{
  color:#ffffff;
  font-size:13px;
  text-align:left;
}

.footer-links-inline{
  display:flex;
  gap:20px;
  list-style:none;
  padding:0;margin:0;
}
.footer-links-inline a{
  color:rgba(255,255,255,0.7);
  font-size:13px;
  text-decoration:none;
}
.footer-links-inline a:hover{color:var(--color-secondary);}

/* COOKIE BANNER */
#cookie-banner{
  position:fixed;
  bottom:0;left:0;right:0;
  background-color:#020f33;
  color:#ffffff;
  padding:18px 20px;
  z-index:9999;
  display:none;
  border-top:2px solid var(--color-secondary);
}

.cookie-banner-inner{
  max-width:1200px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}

.cookie-banner-inner p{
  margin:0;
  font-size:13px;
  color:rgba(255,255,255,0.85);
}
.cookie-banner-inner a{color:var(--color-secondary);}

.cookie-actions{
  display:flex;
  gap:12px;
  flex-shrink:0;
}

#cookie-accept{
  background-color:var(--color-secondary);
  color:#ffffff;
  border:none;
  padding:10px 24px;
  border-radius:2px;
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  font-size:14px;
  cursor:pointer;
  transition:background-color 0.2s;
}
#cookie-accept:hover{background-color:var(--color-heading);}

/* ABOUT TEAM */
.team-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
  margin-top:40px;
}

.team-card{
  background-color:#ffffff;
  border-radius:4px;
  padding:30px;
  text-align:center;
  border-top:3px solid var(--color-primary);
}

.team-avatar{
  width:80px;height:80px;
  border-radius:50%;
  background-color:var(--color-subtle);
  color:#ffffff;
  display:flex;align-items:center;justify-content:center;
  font-size:28px;
  font-weight:700;
  margin:0 auto 15px;
  font-family:'Montserrat',sans-serif;
}

.team-card h3{font-size:18px;margin-bottom:5px;}
.team-card .role{color:var(--color-primary);font-size:13px;font-weight:600;margin-bottom:10px;}
.team-card p{font-size:13px;}

/* success message */
.form-success{
  background-color:#d4edda;
  border:1px solid #c3e6cb;
  color:#155724;
  padding:15px 20px;
  border-radius:2px;
  margin-bottom:20px;
  display:none;
}

/* ===== RESPONSIVE 922px ===== */
@media(max-width:921px){
  html{font-size:79.8%;}
  h1,.entry-content h1{font-size:53px;}
  h2{font-size:25px;}
  h3{font-size:22px;}

  .menu-toggle{display:block;}
  .main-nav{
    display:none;
    position:absolute;
    top:100%;left:0;right:0;
    background-color:#020f33;
    border-top:1px solid #e2e9ff;
    padding:10px 0;
  }
  .main-nav.is-open{display:block;}
  .main-nav ul{flex-direction:column;}
  .main-nav .menu-item > .menu-link{line-height:1;padding:14px 20px;}

  #site-header{position:relative;}

  .about-grid{grid-template-columns:1fr;}
  .services-grid{grid-template-columns:1fr 1fr;}
  .steps-grid{grid-template-columns:1fr 1fr;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .testi-grid{grid-template-columns:1fr 1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .team-grid{grid-template-columns:1fr 1fr;}
}

/* ===== RESPONSIVE 544px ===== */
@media(max-width:544px){
  html{font-size:79.8%;}
  h1{font-size:30px;}
  h2{font-size:25px;}
  h3{font-size:20px;}

  .hero-content{padding:60px 0;}
  .services-grid{grid-template-columns:1fr;}
  .steps-grid{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .testi-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:1fr;}
  .footer-below-inner{flex-direction:column;gap:10px;text-align:center;}
  .cookie-banner-inner{flex-direction:column;align-items:flex-start;}
  .contact-grid{grid-template-columns:1fr;}
}
