/* ============================================================
   LEIZI SHARED STYLES
   Used by: home-14, home-15, home-16, home-18, home-19, home-20
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Barlow+Condensed:wght@400;500;600;700&display=swap');

/* ── TOKENS ── */
:root {
  --blue:       #1a6ff5;
  --blue-dark:  #0d4fd4;
  --blue-light: #e8f0ff;
  --dark:       #0a0f1e;
  --dark-2:     #0d1b3e;
  --gray:       #6b7280;
  --gray-light: #9ca3af;
  --light:      #f5f7fa;
  --border:     #e2e8f0;
  --white:      #ffffff;

  --font-display: 'Bebas Neue', sans-serif;
  --font-body:    'Barlow', sans-serif;
  --font-cond:    'Barlow Condensed', sans-serif;

  --radius: 4px;
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.06);
  --shadow-md: 0 8px 32px rgba(0,0,0,0.1);
  --shadow-blue: 0 8px 30px rgba(26,111,245,0.35);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:var(--font-body); color:#1e2a3a; background:var(--white); overflow-x:hidden; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
img { display:block; max-width:100%; }

/* ── SCROLL PROGRESS ── */
.scroll-progress {
  position:fixed; top:64px; left:0; height:3px;
  background:var(--blue); z-index:998;
  width:0%; transition:width .1s linear;
}

/* ── NAV ── */
.site-nav {
  position:fixed; top:0; left:0; right:0; z-index:999;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 48px; height:64px;
  box-shadow:var(--shadow-sm);
}
.nav-logo {
  font-family:var(--font-display);
  font-size:28px; color:var(--blue); letter-spacing:3px;
  display:flex; align-items:center; gap:8px;
}
.nav-logo svg { width:26px; height:26px; }
.nav-links { display:flex; gap:28px; }
.nav-links a {
  font-family:var(--font-cond);
  font-size:13px; font-weight:600;
  text-transform:uppercase; letter-spacing:1.2px;
  color:#1e2a3a; transition:color .2s;
  white-space:nowrap;
}
.nav-links a:hover,
.nav-links a.active { color:var(--blue); }
.nav-right { display:flex; align-items:center; gap:16px; }
.nav-search-btn {
  background:none; border:none; cursor:pointer;
  color:var(--gray); font-size:17px; line-height:1;
  transition:color .2s; padding:4px;
}
.nav-search-btn:hover { color:var(--blue); }

/* ── BUTTONS ── */
.btn {
  display:inline-block;
  font-family:var(--font-cond);
  font-size:13px; font-weight:700;
  text-transform:uppercase; letter-spacing:1.5px;
  padding:11px 26px; border-radius:var(--radius);
  transition:all .28s; cursor:pointer; border:2px solid transparent;
  white-space:nowrap;
}
.btn-primary {
  background:var(--blue); color:var(--white);
  border-color:var(--blue);
}
.btn-primary:hover {
  background:var(--blue-dark); border-color:var(--blue-dark);
  transform:translateY(-2px); box-shadow:var(--shadow-blue);
}
.btn-outline {
  background:transparent; color:var(--blue);
  border-color:var(--blue);
}
.btn-outline:hover {
  background:var(--blue); color:var(--white);
  transform:translateY(-2px);
}
.btn-white {
  background:var(--white); color:var(--blue);
  border-color:var(--white);
}
.btn-white:hover {
  background:var(--blue-light); transform:translateY(-2px);
}
.btn-sm { font-size:11px; padding:8px 18px; }
.btn-lg { font-size:15px; padding:14px 34px; }

/* ── SECTION WRAPPERS ── */
.section { padding:80px 60px; }
.section-sm { padding:56px 60px; }
.section-alt { background:var(--light); }
.section-dark { background:var(--dark); }
.section-blue { background:var(--blue); }
.container { max-width:1200px; margin:0 auto; }

/* ── SECTION LABELS ── */
.sec-tag {
  display:block;
  font-family:var(--font-cond);
  font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:2.5px;
  color:var(--blue); margin-bottom:10px;
}
.sec-tag-light { color:#7eb3ff; }
.sec-title {
  font-family:var(--font-display);
  font-size:clamp(30px,3.2vw,50px);
  letter-spacing:.5px; line-height:1.05;
  color:var(--dark); margin-bottom:12px;
}
.sec-title-white { color:var(--white); }
.sec-sub {
  font-size:15px; color:var(--gray);
  line-height:1.75; max-width:560px;
}
.sec-sub-light { color:rgba(255,255,255,.72); }
.text-center { text-align:center; }
.text-center .sec-sub { margin:0 auto; }

/* ── PLACEHOLDER IMAGE BOXES ── */
.ph {
  background:linear-gradient(145deg,#dce8ff,#b8cff8);
  border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display);
  font-size:14px; color:rgba(0,0,0,.22);
  letter-spacing:1.5px; overflow:hidden; position:relative;
}
.ph-dark {
  background:linear-gradient(145deg,#1a2540,#0d1b3e);
  color:rgba(255,255,255,.15);
}

/* ── CARDS ── */
.card {
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:all .32s;
}
.card:hover {
  box-shadow:var(--shadow-md);
  transform:translateY(-4px);
}
.card-blue-top::before {
  content:''; display:block;
  height:3px; background:var(--blue);
  transform:scaleX(0); transform-origin:left;
  transition:transform .32s;
}
.card-blue-top:hover::before { transform:scaleX(1); }

/* ── GRID HELPERS ── */
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.grid-align-center { align-items:center; }
.col-gap-lg { gap:64px; }

/* ── SCROLL REVEAL ── */
.reveal {
  opacity:0; transform:translateY(28px);
  transition:opacity .7s ease, transform .7s ease;
}
.reveal.visible { opacity:1; transform:translateY(0); }
.rd-1 { transition-delay:.1s; }
.rd-2 { transition-delay:.2s; }
.rd-3 { transition-delay:.3s; }
.rd-4 { transition-delay:.4s; }
.rd-5 { transition-delay:.5s; }
.rd-6 { transition-delay:.6s; }

/* ── DIVIDER ── */
.divider { border:none; border-top:1px solid var(--border); margin:0; }
.divider-dark { border-top-color:rgba(255,255,255,.1); }

/* ── CHECKLIST ── */
.checklist { list-style:none; }
.checklist li {
  display:flex; align-items:flex-start; gap:10px;
  font-size:14px; color:#3a4a5c;
  padding:7px 0; border-bottom:1px solid #eef0f4;
  line-height:1.55;
}
.checklist li .ck-icon {
  flex-shrink:0; width:20px; height:20px; border-radius:50%;
  background:var(--blue); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:10px; font-weight:700; margin-top:1px;
}

/* ── STAT PILL ── */
.stat-row { display:flex; gap:0; border-top:1px solid var(--border); }
.stat-item {
  flex:1; text-align:center; padding:26px 16px;
  border-right:1px solid var(--border);
  transition:background .25s;
}
.stat-item:last-child { border-right:none; }
.stat-item:hover { background:var(--blue-light); }
.stat-icon { font-size:24px; margin-bottom:6px; }
.stat-val {
  font-family:var(--font-display);
  font-size:30px; color:var(--blue); letter-spacing:1px;
}
.stat-label {
  font-family:var(--font-cond);
  font-size:11px; font-weight:600;
  text-transform:uppercase; letter-spacing:1.5px;
  color:var(--gray); margin-top:2px;
}

/* ── CERT BADGES ── */
.cert-badges { display:flex; flex-wrap:wrap; gap:10px; }
.cert-badge {
  font-family:var(--font-cond);
  font-size:12px; font-weight:700;
  text-transform:uppercase; letter-spacing:1px;
  padding:7px 14px; border-radius:var(--radius);
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.8);
}
.cert-badge-light {
  background:var(--blue-light);
  border-color:#c5d8ff; color:var(--blue);
}

/* ── TESTIMONIAL ── */
.testi-stars { color:#f59e0b; font-size:13px; margin-bottom:12px; letter-spacing:2px; }
.testi-text { font-size:14px; color:#4a5568; line-height:1.72; margin-bottom:18px; font-style:italic; }
.testi-author { display:flex; align-items:center; gap:12px; }
.testi-avatar {
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue-dark));
  color:#fff; font-family:var(--font-display); font-size:16px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.testi-name { font-family:var(--font-cond); font-size:15px; font-weight:700; color:var(--dark); }
.testi-role { font-size:12px; color:var(--gray); }

/* ── NEWS CARD ── */
.news-date {
  font-family:var(--font-cond); font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:1.5px;
  color:var(--blue); margin-bottom:8px;
}
.news-title {
  font-family:var(--font-cond); font-size:17px; font-weight:700;
  color:var(--dark); margin-bottom:8px; line-height:1.3;
}
.news-excerpt { font-size:13px; color:var(--gray); line-height:1.65; }
.news-link {
  display:inline-block; margin-top:12px;
  font-family:var(--font-cond); font-size:12px;
  font-weight:700; text-transform:uppercase;
  letter-spacing:1px; color:var(--blue);
}
.news-link:hover { text-decoration:underline; }

/* ── FOOTER ── */
.site-footer {
  background:var(--dark); color:rgba(255,255,255,.65);
  padding:64px 60px 32px;
}
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px; margin-bottom:48px;
}
.footer-logo { font-family:var(--font-display); font-size:32px; color:#fff; letter-spacing:3px; margin-bottom:14px; }
.footer-tagline { font-size:13.5px; line-height:1.75; margin-bottom:24px; }
.footer-social { display:flex; gap:10px; }
.social-btn {
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; cursor:pointer; transition:all .25s; color:rgba(255,255,255,.7);
}
.social-btn:hover { background:var(--blue); border-color:var(--blue); color:#fff; }
.footer-col-title {
  font-family:var(--font-cond); font-size:13px; font-weight:700;
  text-transform:uppercase; letter-spacing:1.5px;
  color:#fff; margin-bottom:18px;
}
.footer-links li { margin-bottom:10px; }
.footer-links a { font-size:13.5px; color:rgba(255,255,255,.58); transition:color .2s; }
.footer-links a:hover { color:var(--blue); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:24px; margin-top:0;
  display:flex; justify-content:space-between; align-items:center;
  font-size:13px;
}

/* ── BACK TO TOP ── */
.back-top {
  position:fixed; bottom:32px; right:32px; z-index:900;
  width:44px; height:44px; border-radius:var(--radius);
  background:var(--blue); color:#fff; border:none;
  font-size:20px; cursor:pointer;
  box-shadow:0 4px 20px rgba(26,111,245,.4);
  opacity:0; transform:translateY(20px);
  transition:all .3s; display:flex; align-items:center; justify-content:center;
}
.back-top.show { opacity:1; transform:translateY(0); }
.back-top:hover { background:var(--blue-dark); transform:translateY(-3px); }

/* ── HERO BASE ── */
.hero-base {
  margin-top:64px;
  min-height:580px;
  background:linear-gradient(135deg,var(--dark) 0%,var(--dark-2) 55%,#1a3a7a 100%);
  display:flex; align-items:center;
  padding:80px 60px;
  position:relative; overflow:hidden;
}
.hero-base::before {
  content:'';
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%231a6ff5' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E");
}
.hero-content { position:relative; z-index:1; }
.hero-tag {
  display:inline-block;
  background:rgba(26,111,245,.18); border:1px solid rgba(26,111,245,.35);
  color:#7eb3ff; font-family:var(--font-cond);
  font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:2.5px; padding:6px 14px; border-radius:2px;
  margin-bottom:22px;
}
.hero-h1 {
  font-family:var(--font-display);
  font-size:clamp(52px,6.5vw,96px);
  line-height:.95; color:var(--white); letter-spacing:1px;
  margin-bottom:20px;
  animation:fadeUp .8s ease both;
}
.hero-h1 em { font-style:normal; color:var(--blue); }
.hero-p {
  color:rgba(255,255,255,.62); font-size:15.5px; line-height:1.75;
  margin-bottom:34px; max-width:500px;
  animation:fadeUp .8s .15s ease both;
}
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; animation:fadeUp .8s .3s ease both; }
.hero-img-badge {
  position:absolute; right:60px; top:50%; transform:translateY(-50%);
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);
  border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:18px;
  color:rgba(255,255,255,.2); letter-spacing:2px;
}

/* ── WIDE BANNER ── */
.wide-banner {
  height:280px;
  background:linear-gradient(135deg,var(--dark),#1a3a7a);
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.wide-banner::before {
  content:''; position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3z' fill='%231a6ff5' fill-opacity='0.1' fill-rule='evenodd'/%3E%3C/svg%3E");
}
.wide-banner-text { position:relative; z-index:1; text-align:center; }
.wide-banner-text .wbt-label {
  font-family:var(--font-cond); font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:3px; color:rgba(255,255,255,.4);
  margin-bottom:10px;
}
.wide-banner-text .wbt-title {
  font-family:var(--font-display); font-size:clamp(32px,4vw,58px);
  color:var(--white); letter-spacing:1px;
}
.wide-banner-text .wbt-sub { font-size:15px; color:rgba(255,255,255,.6); margin-top:8px; }
.wide-banner-text .btn { margin-top:24px; }

/* ── HOW-IT-WORKS SECTION ── */
.how-section { padding:72px 60px; }
.how-steps { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-top:48px; position:relative; }
.how-steps::before {
  content:''; position:absolute; top:32px; left:16.6%; right:16.6%;
  height:2px; background:rgba(26,111,245,.2); z-index:0;
}
.how-step { text-align:center; position:relative; z-index:1; }
.step-num {
  width:64px; height:64px; border-radius:50%;
  background:var(--blue); color:#fff;
  font-family:var(--font-display); font-size:26px;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 18px; box-shadow:0 4px 20px rgba(26,111,245,.35);
}
.how-section-blue .step-num { background:#fff; color:var(--blue); }
.step-title {
  font-family:var(--font-cond); font-size:16px; font-weight:700;
  text-transform:uppercase; letter-spacing:.8px;
  color:var(--dark); margin-bottom:8px;
}
.how-section-blue .step-title { color:#fff; }
.step-desc { font-size:13.5px; color:var(--gray); line-height:1.65; }
.how-section-blue .step-desc { color:rgba(255,255,255,.72); }

/* ── KEYFRAMES ── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(28px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes pulse {
  0%,100% { transform:scale(1); }
  50%      { transform:scale(1.04); }
}
@keyframes slideInLeft {
  from { opacity:0; transform:translateX(-40px); }
  to   { opacity:1; transform:translateX(0); }
}
@keyframes countUp {
  from { opacity:0; } to { opacity:1; }
}

/* ── TABS ── */
.tabs { display:flex; gap:4px; border-bottom:2px solid var(--border); margin-bottom:32px; }
.tab-btn {
  font-family:var(--font-cond); font-size:13px; font-weight:700;
  text-transform:uppercase; letter-spacing:1px;
  padding:10px 20px; border:none; background:none;
  color:var(--gray); cursor:pointer; border-bottom:2px solid transparent;
  margin-bottom:-2px; transition:all .22s;
}
.tab-btn:hover { color:var(--blue); }
.tab-btn.active { color:var(--blue); border-bottom-color:var(--blue); }
.tab-panel { display:none; }
.tab-panel.active { display:block; }

/* ── FAQ ACCORDION ── */
.faq-item { border-bottom:1px solid var(--border); }
.faq-q {
  width:100%; background:none; border:none; cursor:pointer;
  display:flex; justify-content:space-between; align-items:center;
  padding:18px 0; text-align:left;
  font-family:var(--font-cond); font-size:16px; font-weight:700;
  color:var(--dark); transition:color .2s;
}
.faq-q:hover { color:var(--blue); }
.faq-q .faq-icon { font-size:20px; font-weight:300; flex-shrink:0; transition:transform .3s; }
.faq-item.open .faq-icon { transform:rotate(45deg); color:var(--blue); }
.faq-a {
  max-height:0; overflow:hidden;
  transition:max-height .35s ease, padding .35s ease;
  font-size:14px; color:var(--gray); line-height:1.7;
}
.faq-item.open .faq-a { max-height:200px; padding-bottom:16px; }

/* ── QUOTE FORM ── */
.quote-form { display:grid; gap:14px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-field {
  display:flex; flex-direction:column; gap:6px;
}
.form-field label {
  font-family:var(--font-cond); font-size:12px; font-weight:700;
  text-transform:uppercase; letter-spacing:1px; color:#4a5568;
}
.form-field input,
.form-field select,
.form-field textarea {
  padding:10px 14px; border:1.5px solid var(--border);
  border-radius:var(--radius); font-family:var(--font-body);
  font-size:14px; color:var(--dark); background:#fff;
  transition:border-color .2s; outline:none;
  width:100%;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus { border-color:var(--blue); }
.form-field textarea { resize:vertical; min-height:90px; }

/* ── RESPONSIVE ── */
@media (max-width:960px) {
  .site-nav { padding:0 24px; }
  .nav-links { display:none; }
  .section, .section-sm, .how-section { padding:56px 24px; }
  .hero-base { padding:60px 24px; }
  .hero-img-badge { display:none; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .site-footer { padding:48px 24px 24px; }
  .how-steps { grid-template-columns:1fr; }
  .how-steps::before { display:none; }
  .form-row { grid-template-columns:1fr; }
}
@media (max-width:580px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns:1fr; }
  .hero-h1 { font-size:48px; }
  .footer-grid { grid-template-columns:1fr; }
  .stat-row { flex-wrap:wrap; }
  .stat-item { min-width:50%; }
}
