/* Keep your existing site styles condensed (hero centering, cards, etc.) */
:root{
  --bg:#0e1323; --bg2:#111827; --text:#f3f4f6; --muted:#cbd5e1;
  --accent:#00ffef; --accent-2:#0099ff; --shadow:0 20px 60px rgba(0,0,0,.45);
}
*{box-sizing:border-box} html,body{height:100%}
body{ margin:0; font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text); background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%);
}
a{color:inherit;text-decoration:none} img{display:block;max-width:100%;height:auto}
.wrap{max-width:1140px;margin:0 auto;padding:0 20px}
.sec-title{font-size:clamp(1.6rem,1.2rem+1.5vw,2.2rem);margin:0 0 .25rem;line-height:1.2}
.sec-kicker{margin:0 0 1.5rem;color:var(--muted);font-size:1rem}
.btn{display:inline-block;padding:14px 22px;border-radius:14px;background:linear-gradient(180deg,var(--accent),var(--accent-2));color:#052e16;font-weight:600;box-shadow:var(--shadow)}
.chip{display:inline-block;font-size:.85rem;padding:.35rem .6rem;border-radius:999px;background:rgba(255,255,255,.08);color:var(--text)}

.hero{position:relative;min-height:72vh;display:grid;place-items:center;overflow:hidden;isolation:isolate}
.hero .hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(1.25) contrast(1.05) saturate(1.05)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25) 0%,rgba(0,0,0,.45) 60%,rgba(0,0,0,.60) 100%)}
.hero .panel{position:relative;z-index:1;margin:min(6vw,64px) auto;max-width:min(680px,90vw);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:clamp(18px,3vw,28px);text-align:center}
.hero h1{margin:0 0 .6rem;font-size:clamp(3rem,2rem+4vw,5rem);font-size:.95rem;color:#d1d5db;display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}

.steps,.popular,.benefits,.proof{padding:56px 0}
.steps .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:20px;box-shadow:var(--shadow)}
.step-card .badge{background:linear-gradient(180deg,var(--accent),var(--accent-2));color:#052e16;width:40px;height:40px;display:grid;place-items:center;border-radius:999px;font-weight:700;margin-bottom:10px}
.step-card h3{margin:.25rem 0 .25rem} .step-card p{margin:0;color:var(--muted)}

.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{display:flex;flex-direction:column;overflow:hidden;border-radius:18px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);box-shadow:var(--shadow)}
.card img{aspect-ratio:4/3;object-fit:cover}
.card .body{padding:16px} .card h3{margin:.25rem 0 .5rem;font-size:1.05rem} .card p{margin:0 0 .75rem;color:var(--muted)}

.bgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px 18px;list-style:none;margin:0;padding:0}
.bgrid li{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);border-radius:12px;padding:12px 14px;line-height:1.4}
.benefits .note{color:var(--muted);margin-top:12px;font-size:.95rem}

.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pbox{background:rgba(15,20,30,0.95);border:1px solid rgba(255,255,255,0.10);border-radius:18px;padding:20px;min-height:120px;box-shadow:0 10px 30px rgba(0,0,0,0.40);}
.center-cta{text-align:center;margin-top:22px}
.final{padding:36px 0 40px;text-align:center}

.footer{padding:16px 0 20px;color:#cbd5e1;background:rgba(255,255,255,.04);border-top:1px solid rgba(255,255,255,.12)}
.footer-inner{display:flex;flex-wrap:wrap;gap:10px 14px;align-items:center;justify-content:space-between}
.footer-nav{display:flex;gap:14px} .footer-nav a{opacity:.9} .footer-nav a:hover{opacity:1;text-decoration:underline}

@media (max-width:1024px){.cards{grid-template-columns:repeat(3,1fr)} .bgrid{grid-template-columns:repeat(2,1fr)} .pgrid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:768px){.steps .grid{grid-template-columns:1fr} .cards{grid-template-columns:repeat(2,1fr)} .hero{min-height:66vh}}
@media (max-width:520px){.cards{grid-template-columns:1fr} .bgrid{grid-template-columns:1fr} .pgrid{grid-template-columns:1fr} .hero .panel{margin:20px}}

.sr-only {
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  border:0;
}




@media (max-width:640px){
  
  
}

.sr-only {
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  border:0;
}
.hero-search {
  display:flex;
  justify-content:center;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px;
  margin-bottom:10px;
}
.hero-search input[type="search"] {
  flex:1 1 250px;
  max-width:320px;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.06);
  color:#f3f4f6;
  font-size:1rem;
}
.hero-search input::placeholder {
  color:#cbd5e1;
}


@media (max-width:640px){
  .hero-search {flex-direction:column;align-items:center;}
  .hero-search input[type="search"]{} 
}


/* === Match Search button to main green buttons === */
.hero-search button.btn {
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  color: #052e16; /* same dark text color as other buttons */
  font-weight: 600;
  padding: 14px 22px;
  border-radius: 14px;
  box-shadow: var(--shadow);
  border: none;
}
.hero-search button.btn:hover {
  filter: brightness(1.05);
}



/* === Ensure same font and text size for Search button === */
.hero-search button.btn {
  font-family: inherit; /* inherit from body/system UI */
  font-size: 1rem; /* match other buttons */
  line-height: 1.2;
}



/* === Make Search bar slightly longer === */
.hero-search input[type="search"] {
  max-width: 325px; /* was 320px */
}



/* === Mobile-friendly search width === */
@media (max-width:640px){
  .hero-search input[type="search"]{ max-width:100%; width:100%; }
  .hero-search button.btn{ width:100%; }
}

/* === Accessible keyboard focus === */
:focus-visible { outline: 2px solid var(--accent-2); outline-offset: 2px; }


/* Popular links row */
.popular-links{display:flex;gap:12px;flex-wrap:wrap;margin:10px 0 6px;justify-content:center;text-align:center}
.popular-links a{padding:.35rem .6rem;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}
.popular-links a:hover{background:rgba(255,255,255,.12)}

/* FAQ block */
.faq{padding:36px 0}
.faq details{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:12px 14px;margin:10px 0}
.faq summary{cursor:pointer;font-weight:600}

html, body { height: 100%; }
main { min-height: 60vh; }

.pbox h3{margin:0 0 .4rem;font-size:1.1rem;color:#ffffff}

.pbox p{color:#e5e7eb;margin:0}

.pbox:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(0,0,0,0.5);transition:transform .2s ease, box-shadow .2s ease}


/* Solid 3D style for step-card boxes */
.step-card {
  background: rgba(15,20,30,0.95) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  border-radius: 18px !important;
  padding: 20px !important;
  box-shadow: 0 10px 30px rgba(0,0,0,0.40) !important;
}
.step-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 14px 40px rgba(0,0,0,0.5) !important;
  transition: transform .2s ease, box-shadow .2s ease !important;
}
.step-card h3 { color: #ffffff !important; margin:0 0 .4rem; font-size:1.1rem; }
.step-card p { color: #e5e7eb !important; margin:0; }
.step-card .badge {
  background: linear-gradient(180deg, var(--accent), var(--accent-2)) !important;
  color: #052e16 !important;
  width: 40px !important;
  height: 40px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  font-weight: 700 !important;
  margin-bottom: 10px !important;
}


.center-cta.hero-search{margin-top:80px;}

/* Force hero h1 large size */
.hero h1 {
  font-size:5rem !important;
  line-height:1.1 !important;
}
@media (max-width:640px){
  .hero h1 {
    font-size:3rem !important;
  }
}

/* Balanced hero h1 size */
.hero h1 {
  font-size:3.8rem !important;
  line-height:1.15 !important;
}
@media (max-width:640px){
  .hero h1 {
    font-size:2.4rem !important;
  }
}

/* Smaller balanced hero h1 size */
.hero h1 {
  font-size:3rem !important;
  line-height:1.2 !important;
}
@media (max-width:640px){
  .hero h1 {
    font-size:2rem !important;
  }
}

/* Smaller hero h1 with separator dash */
.hero h1 {
  font-size:2.6rem !important;
  line-height:1.2 !important;
  text-align:center;
}
.hero h1 .h1-part1::after {
  content:" — ";
  margin:0 .2em;
  opacity:0.8;
}
.hero h1 .h1-part2 {
  display:inline;
}
@media (max-width:640px){
  .hero h1 {
    font-size:1.8rem !important;
  }
}

/* Fit hero h1 on one line */
.hero h1 {
  font-size:2rem !important;
  line-height:1.2 !important;
  text-align:center;
}
@media (max-width:640px){
  .hero h1 {
    font-size:1.4rem !important;
  }
}


/* ===== Mobile polish (<=640px) ===== */
@media (max-width:640px){
  /* Make hero image more visible by reducing panel opacity */
  .hero .panel{
    background: rgba(15,20,30,0.35) !important; /* lighter glass */
    border: 1px solid rgba(255,255,255,0.18) !important;
    padding: 18px 14px !important;
  }
  .hero{ padding: 20px 0 !important; }

  /* Bigger title on mobile for readability */
  .hero h1{ font-size: 1.9rem !important; line-height: 1.2 !important; }

  /* Trim hero paragraph size/line-length */
  .hero p{ font-size: 1rem !important; line-height: 1.5 !important; }

  /* Compact search fields */
  .hero-search{ gap: 8px !important; }
  .hero-search input[type="search"]{
    max-width: 260px !important;
    padding: 10px 12px !important;
    font-size: 0.95rem !important;
    border-radius: 12px !important;
  }
  .hero-search .btn{
    padding: 12px 16px !important;
    border-radius: 12px !important;
    font-size: 0.95rem !important;
  }

  /* Bottom search field: slightly less spacing and smaller controls */
  .center-cta.hero-search{ margin-top: 24px !important; }
  .center-cta.hero-search input[type="search"]{ max-width: 240px !important; }
}



/* ===== Ultra-compact search fields for mobile ===== */
@media (max-width:640px){
  .hero-search input[type="search"],
  .center-cta.hero-search input[type="search"]{
    max-width:200px !important;
    padding:6px 8px !important;
    font-size:0.85rem !important;
    border-radius:8px !important;
  }
  .hero-search .btn,
  .center-cta.hero-search .btn{
    padding:6px 12px !important;
    font-size:0.85rem !important;
    border-radius:8px !important;
  }
  .hero-search{gap:6px !important;}
}



/* ===== FINAL MOBILE TWEAKS ===== */
@media (max-width:640px){
  /* Make hero image more visible and panel lighter */
  .hero .panel{ background: rgba(15,20,30,0.28) !important; padding:16px 12px !important; border-radius:14px !important; }

  /* Smaller balanced mobile H1 */
  .hero h1{ font-size:1.6rem !important; line-height:1.2 !important; text-align:center !important; }

  /* Body copy a bit smaller */
  .hero p{ font-size:0.95rem !important; line-height:1.5 !important; }

  /* Ensure the form itself isn't boxed */
  .hero-search{ background: transparent !important; border: 0 !important; padding: 0 !important; box-shadow:none !important; gap:6px !important; flex-direction:row !important; align-items:center !important; justify-content:center !important; }

  /* Compact inputs/buttons */
  .hero-search input[type="search"]{ width:200px !important; max-width:200px !important; padding:6px 8px !important; font-size:0.85rem !important; border-radius:8px !important; }
  .hero-search .btn{ width:auto !important; padding:6px 12px !important; font-size:0.9rem !important; border-radius:8px !important; }

  /* Bottom search form spacing trimmed */
  .center-cta.hero-search{ margin-top:20px !important; }
}



/* ===== Comfortable mobile search fields ===== */
@media (max-width:640px){
  .hero-search input[type="search"],
  .center-cta.hero-search input[type="search"]{
    max-width:230px !important;
    padding:8px 10px !important;
    font-size:0.9rem !important;
    border-radius:10px !important;
  }
  .hero-search .btn,
  .center-cta.hero-search .btn{
    padding:8px 14px !important;
    font-size:0.9rem !important;
    border-radius:10px !important;
  }
}

