:root{
  --container: 1100px;
  --space-1: 8px; --space-2: 12px; --space-3: 16px; --space-4: 24px; --space-5: 32px; --space-6: 40px; --space-7: 56px; --space-8: 80px;
  --radius: 16px; --radius-lg: 20px;
  --text:#1a1a1a; --muted:#596172; --bg:#ffffff; --bg-soft:#f7f7f7;
  --primary:#002855; --primary-ink:#1E3BB5; --border:#dce1ea; --shadow:0 8px 26px rgba(16,24,40,.08);
}
*{box-sizing:border-box}html,body{height:100%} body{margin:0;font-family:Inter, Poppins, system-ui, -apple-system, Segoe UI, Roboto, Arial, Noto Sans, "Helvetica Neue", sans-serif;color:var(--text);background:var(--bg);line-height:1.6}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--space-5)} .flex{display:flex} .between{justify-content:space-between} .center-y{align-items:center}
.hide-sm{display:block} .only-sm{display:none} .desktop-only{display:block} .mobile-only{display:none}
@media (max-width:1024px){.hide-sm{display:none} .only-sm{display:inline-flex} .desktop-only{display:none} .mobile-only{display:inline-flex}}

/* Scrim */
.scrim{position:fixed;inset:0;background:rgba(17,24,39,.5);opacity:0;pointer-events:none;transition:opacity .2s;z-index:19}
body.nav-open .scrim{opacity:1;pointer-events:auto}

/* Header & Nav */
.site-header{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--border);z-index:20}
.site-header .brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-weight:700}
.logo{height:20px;width:auto} .brand-text{font-weight:700}
.nav a{margin-left:var(--space-5);color:var(--muted);text-decoration:none} .nav a:hover{color:var(--text)}
.hamburger{background:#fff;border:1px solid var(--border);border-radius:10px;padding:8px 12px;cursor:pointer}

.mnav{position:fixed;top:0;right:0;bottom:0;width:min(84vw,360px);background:#fff;border-left:1px solid var(--border);box-shadow: -8px 0 24px rgba(16,24,40,.12);transform:translateX(100%);transition:transform .2s;z-index:20;display:flex;flex-direction:column;padding:20px}
.mnav a{text-decoration:none;color:var(--text);padding:12px 8px;border-radius:10px}
.mnav a.btn{margin-top:auto}
.mnav-close{align-self:flex-end;background:#fff;border:1px solid var(--border);border-radius:10px;padding:6px 10px;cursor:pointer}
body.nav-open .mnav{transform:translateX(0)}
body.nav-open{overflow:hidden}

/* Hero layout */
.hero{padding:72px 0;background:image-set(url('/assets/hero-bg.webp') type('image/webp'), url('/assets/hero-bg.jpg') type('image/jpeg')) center/cover no-repeat}
.hero-grid{display:grid;grid-template-columns: 1.1fr 460px;gap:28px;align-items:center}
.pill{display:inline-block;padding:6px 12px;border-radius:999px;background:#eef2ff;color:#2741c2;font-weight:600;margin-bottom:14px}
.hero h1{font-family:Poppins,Inter,sans-serif;font-weight:700;font-size:clamp(32px,4.6vw,52px);line-height:1.12;margin:0 0 10px}
.lede{color:var(--muted);margin:0 0 14px;font-size:18px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin:0 0 12px}
.hero-points{display:flex;gap:18px;color:#2a3551;list-style:none;padding:0;margin:0 0 10px;flex-wrap:wrap}
.form-card{background:#F5F5F5;border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow);padding:20px}
.form-card h2{margin:0 0 10px}
/* Smaller, refined form typography */
.form-card label{font-size:14px}
.form-card input, .form-card select{font-size:14px}
.form-card .error{font-size:12px}
.form-card .radios legend{font-size:14px}
.form-card .age label{font-size:14px}

@media (max-width:1024px){.hero-grid{grid-template-columns:1fr} .form-card{margin-top:8px}}

/* Form styles */
.field, .check{display:grid;gap:6px;margin-bottom:12px}
.field-inline{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
label{font-weight:600} .req{color:var(--primary);margin-left:4px}
input[type="text"], input[type="email"], input[type="tel"], input[type="number"], select{height:38px;border:1px solid var(--border);border-radius:12px;padding:0 14px;font-size:16px;outline:none;background:#fff;transition:border .15s, box-shadow .15s}
input:focus, select:focus{border-color:#b9c6ff; box-shadow:0 0 0 3px rgba(58,104,255,.15)}
.tel-wrap{display:flex;gap:8px} .tel-wrap select{width:128px}
.radios{display:flex;gap:18px;align-items:center;border:none;padding:0;margin:0} .radios legend{font-weight:600;margin-bottom:6px}
.age input{width:100%}
.error{min-height:18px;color:#e53935;font-size:13px;margin:0}
.hp{position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;}
.btn.xlarge{height:56px;border-radius:28px}

/* Blue checkbox label */
.check-blue label{color:#3A68FF;font-weight:600}

/* Strip */
.strip{background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.strip-inner{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;padding:12px 0}
.badge{padding:8px 14px;border-radius:999px;background:#f3f6ff;color:#2a3551;font-weight:600}

/* About */
.about{padding:72px 0;background:#fff}
.about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:32px;align-items:center}
.about-card{height:320px;border-radius:20px;border:1px solid var(--border);box-shadow:var(--shadow);background:linear-gradient(135deg,#f0f4ff,#fff)}
.about-copy h2{font-family:Poppins,Inter,sans-serif;font-size:32px;margin:0 0 8px}
.ticks{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:6px}
.ticks li::before{content:'✓';margin-right:10px;color:#2a8d3a;font-weight:700;margin-left:-18px}

/* Benefit */
.benefit{padding:72px 0;background:#fff}
.benefit h2{font-family:Poppins,Inter,sans-serif;font-size:32px;text-align:center;margin:0 0 24px}
.grid-3{display:grid;grid-template-columns: repeat(3,1fr);gap:20px}
.b-card{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:18px}
.b-card h3{margin:0 0 8px}

/* How timeline */
.how{padding:72px 0;background:#fff}
.how h2{font-family:Poppins,Inter,sans-serif;font-size:32px;text-align:center;margin:0 0 24px}
.timeline{position:relative;display:grid;grid-template-columns: repeat(4,1fr);gap:18px}
.timeline::before{content:'';position:absolute;top:28px;left:0;right:0;height:2px;background:#e6e8f5}
.t-item{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.dot{width:36px;height:36px;border-radius:50%;background:#eef2ff;color:#2741c2;display:inline-flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:8px}

/* Jobs */
.jobs{padding:72px 0;background:#fff}
.jobs h2{font-family:Poppins,Inter,sans-serif;font-size:32px;text-align:center;margin:0 0 24px}
.job-card{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:18px;display:grid;gap:6px}
.job-card .pay{font-weight:700;color:#192b7a}
.tags{display:flex;gap:8px;list-style:none;padding:0;margin:4px 0 8px;flex-wrap:wrap}
.tags li{padding:6px 10px;border-radius:999px;background:#f1f4ff;color:#2a3551;font-weight:600;font-size:13px}

/* Reviews */
.reviews{padding:72px 0;background:var(--bg-soft)}
.reviews h2{font-family:Poppins,Inter,sans-serif;font-size:32px;text-align:center;margin:0 0 24px}
.reviews-grid{display:grid;grid-template-columns: repeat(3,1fr);gap:20px}
.review-card{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;display:grid;grid-template-columns:100px 1fr;gap:16px;align-items:center;padding:16px}
.review-card img{width:100px;height:100px;object-fit:cover;border-radius:12px}

/* FAQ */
.faq{padding:72px 0;background:#fff}
.faq h2{font-family:Poppins,Inter,sans-serif;font-size:32px;text-align:center;margin:0 0 24px}
.acc{border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.q{width:100%;text-align:left;padding:18px 0;background:none;border:none;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-weight:700;cursor:pointer}
.a{display:none;padding:4px 0 18px;color:var(--muted)}
.q[aria-expanded="true"] + .a{display:block}.q[aria-expanded="true"] .ico{transform:rotate(45deg)}

/* Trust */
.trust{background:#fff;padding:56px 0}
.trust h2{font-family:Poppins,Inter,sans-serif;font-size:28px;text-align:center;margin:0 0 16px}
.trust-points{display:grid;gap:8px;list-style:none;padding:0;margin:0;max-width:760px;margin-inline:auto;text-align:center;color:#2a3551}

/* Footer */
.site-footer{border-top:1px solid var(--border);background:#fff;padding:40px 0 80px}
.grid-foot{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px}
.foot-links{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.muted{color:var(--muted)} .tiny{font-size:13px;color:var(--muted)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;height:48px;padding:0 var(--space-5);border-radius:28px;border:1px solid transparent;text-decoration:none;font-weight:700;cursor:pointer;transition:.2s ease}
.btn.primary{background:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-ink)}
.btn.ghost{background:#fff;border-color:var(--border);color:var(--text)}.btn.ghost:hover{border-color:#cbd2e0}
.btn.small{height:40px;padding:0 var(--space-4)}.btn.large{height:52px;padding:0 28px}.btn.xlarge{height:56px;padding:0 32px}

/* Floating CTA (mobile only) */
.float-cta{position:fixed;right:16px;bottom:16px;height:56px;padding:0 22px;border-radius:999px;background:var(--primary);color:#fff;text-decoration:none;font-weight:700;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(58,104,255,.35)}

/* Responsive tweaks */
@media (max-width:1000px){
  .about-grid{grid-template-columns:1fr}
  .timeline{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .timeline{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
}


/* === FORM-ONLY MICRO TUNING (do not change other sections) === */
.form-card label{font-size:12px}
.form-card input, .form-card select{font-size:12px}
.form-card .error{font-size:11px}
/* compact vertical rhythm */
.form-card .field, .form-card .check{margin-bottom:8px}
/* checkbox blue text */
.check-blue label{color:#3A68FF;font-weight:600;display:flex;align-items:center;gap:8px}


/* === APPLY FORM VISUAL TWEAKS (scoped, non-breaking) === */
.form-card{max-width:400px;padding:16px}
.form-card input[type="text"],
.form-card input[type="email"],
.form-card input[type="tel"],
.form-card input[type="number"],
.form-card select{height:38px;border-radius:14px}
.form-card .field, .form-card .check{margin-bottom:8px}
.form-card .tel-wrap{display:flex;gap:8px}
.form-card .tel-wrap select{width:110px}
.form-card .tel-wrap input{flex:1}

/* Checkbox label in blue on the right */
.check-blue label{color:#3A68FF;font-weight:600;display:flex;align-items:center;gap:8px}

/* Reviews stars */
.stars{margin-top:6px;font-size:15px;letter-spacing:1px;color:#FFB400;line-height:1}



/* === FORM: label-left layout & compact visuals === */
.form-card{max-width:400px;padding:16px}
.form-row{display:flex;align-items:center;gap:12px;margin-bottom:4px}
.form-row .form-label{width:100px;min-width:100px;color:#596172;font-weight:600;font-size:12px;display:flex;align-items:center;justify-content:flex-start}
.form-row .form-label .req{margin-left:4px;color:#3A68FF;font-weight:700}
.form-row .form-control{flex:1;display:flex;align-items:center}
.form-card input[type="text"], .form-card input[type="email"], .form-card input[type="tel"], .form-card input[type="number"], .form-card select{height:28px;border-radius:12px;font-size:12px}
.form-card .field, .form-card .check{margin-bottom:4px}
.form-card .tel-wrap{display:flex;gap:8px;width:100%}
.form-card .tel-wrap select{width:110px}
.form-card .tel-wrap input{flex:1}
.radios.no-legend legend{display:none}
.radios.no-legend label{margin-right:16px}

/* checkbox horizontal + blue text */
.check-blue label{color:#3A68FF;font-weight:600;display:flex;align-items:center;gap:8px}
.check-blue input[type="checkbox"]{width:16px;height:16px}

/* Reviews stars */
.stars{margin-top:4px;font-size:14px;color:#FFB400;line-height:1;letter-spacing:0.5px}



/* === WhatsApp overflow fix (CSS-only) === */
.form-row .form-control{width:100%}
.form-card .tel-wrap{display:flex;gap:8px;width:100%}
.form-card .tel-wrap select{width:110px;box-sizing:border-box;max-width:100%}
.form-card .tel-wrap input{flex:1;min-width:0;box-sizing:border-box;max-width:100%}



/* ===== WhatsApp Overflow Fix (A + B) ===== */
/* A) 文本层兜底：长串数字/链接换行，避免溢出 */
.whatsapp, .wa, a[href*="wa.me"], a[href*="whatsapp"], [class*="whatsapp"], [class*="wa-"], [id*="whatsapp"] {
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: normal;
}

/* B) 布局层兜底：flex 子项允许收缩 + 文本省略（小屏时更友好） */
.whatsapp, .wa, [class*="whatsapp"], [class*="wa-"] {
  min-width: 0;
}

.whatsapp a, .wa a, [class*="whatsapp"] a, [class*="wa-"] a {
  display: inline-block;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
}


/* ===== About Image Safety & Placeholder ===== */
.about-photo {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  border-radius: 1rem;
}

/* 当 about 图片不存在时，为容器提供占位背景（由 JS 添加 .about-placeholder 到容器） */
.about-placeholder {
  min-height: 280px;
  background: repeating-linear-gradient(
    45deg,
    #f2f4f7,
    #f2f4f7 10px,
    #e9edf3 10px,
    #e9edf3 20px
  );
  border-radius: 1rem;
}

/* === FINAL PATCHES === */
/* WhatsApp input row safety: no overflow */
.form-row .form-control{width:100%}
.form-card .tel-wrap{display:flex;gap:8px;width:100%}
.form-card .tel-wrap select{width:110px;box-sizing:border-box;max-width:100%}
.form-card .tel-wrap input{flex:1;min-width:0;box-sizing:border-box;max-width:100%}

/* About image + placeholder */
.about-photo{width:100%;height:auto;display:block;object-fit:cover;border-radius:16px}
.about-placeholder{min-height:280px;background:repeating-linear-gradient(45deg,#f2f4f7,#f2f4f7 10px,#e9edf3 10px,#e9edf3 20px);border-radius:16px}


/* === FIX: WhatsApp row overflow (scoped to #apply) === */
#apply .form-control{margin-left:0; min-width:0;}
#apply .tel-wrap{display:flex; align-items:center; gap:8px; width:100%; min-width:0;}
#apply .tel-wrap select{flex:0 0 110px; width:110px; max-width:100%; box-sizing:border-box;}
#apply .tel-wrap input{flex:1 1 0%; min-width:0; width:auto; max-width:100%; box-sizing:border-box;}

/* About image utility */
.about-photo{width:100%;height:auto;display:block;object-fit:cover;border-radius:16px}

/* === PATCH: Hero text color (bright, but professional) === */
.hero h1 { color: #FFFFFF; }   /* White-255 */
.hero .lead { color: #040273; }/* DarkBlue-115 */

/* === PATCH: Header hide image logo, keep text === */
header .logo img,
.header .logo img { display: none !important; }

/* === PATCH: Footer hide image logo === */
footer .footer-brand img,
.footer .footer-brand img,
footer .brand img,
.footer .brand img { display: none !important; }

/* === PATCH: Gradient color for brand text in header & footer === */
.site-header .brand .brand-text,
.site-footer .brand .brand-text,
.site-footer .brand-text {
  background: linear-gradient(90deg, #1F2B3A 70%, #22D3EE 30%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
  font-weight: 700;
  display: inline-block;
}
/* === PATCH: Hero subtitle and points stronger style === */
.hero .lede,
.hero-points li {
  color: #333333 !important;   /* 深灰色 */
  font-weight: 700 !important; /* 加粗 */
}
/* === PATCH: Hero subtitle & points stronger === */
.hero .lede,
.hero-points li { color:#333333 !important; font-weight:700 !important; }


.seo-text {
  font-size: 0.1px;
  line-height: 0;
  color: transparent;
  height: 0;
  overflow: hidden;
}

/* Brand color override */
.nav .brand, .brand, .logo, .logo a, .site-logo a { color: #0A2540 !important; }
