/* =========================================================
   CAREFLOW · 통합 스타일시트
   브랜드 컬러: Blue #0046FF / Navy #061A3A
   ========================================================= */
:root{
  --blue:#0046FF;
  --blue2:#0B63FF;
  --navy:#061A3A;
  --deep:#031226;
  --sky:#EAF2FF;
  --pale:#F6F9FF;
  --mint:#E9F8FF;
  --line:#D7E3F3;
  --text:#111827;
  --muted:#526276;
  --white:#fff;
  --green:#12B886;
  --orange:#FF8A00;
  --shadow:0 18px 40px rgba(0,40,120,.10);
  --shadow-sm:0 10px 26px rgba(0,70,255,.06);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:#fff;color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Pretendard","Noto Sans KR","Segoe UI",Arial,sans-serif;
  line-height:1.72;letter-spacing:-.025em;-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ---------- Top bar ---------- */
.topbar{background:var(--deep);color:#cfe1ff;font-size:12.5px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar a{color:#cfe1ff;opacity:.85}
.topbar a:hover{opacity:1}
.topbar .tb-right{display:flex;gap:18px}

/* ---------- Header / Nav ---------- */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:9px;font-weight:900;font-size:23px;color:var(--navy);letter-spacing:-.03em}
.brand .loop{color:var(--blue)}
.nav-menu{display:flex;gap:6px;list-style:none;margin:0;padding:0}
.nav-menu a{display:block;padding:9px 14px;border-radius:999px;font-size:15px;font-weight:700;color:var(--navy)}
.nav-menu a:hover,.nav-menu a.active{background:var(--sky);color:var(--blue)}
.nav-cta{display:inline-flex;align-items:center;gap:7px;background:var(--blue);color:#fff;font-weight:800;padding:11px 18px;border-radius:999px;font-size:14.5px;box-shadow:var(--shadow-sm)}
.nav-cta:hover{background:#0039d6}
.nav-toggle{display:none;border:0;background:none;font-size:26px;color:var(--navy);cursor:pointer}

/* ---------- Logo mark (infinity) ---------- */
.mark{width:30px;height:18px;flex:0 0 auto}
.mark-lg{width:64px;height:38px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:800;border-radius:999px;padding:14px 24px;font-size:15.5px;border:2px solid transparent;cursor:pointer;transition:.15s;white-space:nowrap}
.btn .arr{transition:transform .15s}
.btn:hover .arr{transform:translateX(3px)}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:#0039d6}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:#0a2147}
.btn-light{background:#fff;color:var(--navy);border-color:var(--line)}
.btn-light:hover{border-color:var(--blue);color:var(--blue)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost:hover{background:rgba(255,255,255,.22)}
.btn-lg{padding:16px 30px;font-size:17px}

/* ---------- Section primitives ---------- */
section{position:relative}
.sec{padding:88px 0}
.sec-tight{padding:60px 0}
.kicker{font-size:12.5px;font-weight:900;color:var(--blue);letter-spacing:.16em;text-transform:uppercase;margin:0 0 10px}
.kicker.on-dark{color:#7aa6ff}
.h-xl{font-size:46px;line-height:1.16;letter-spacing:-.045em;margin:0 0 18px;color:var(--navy);font-weight:900}
.h-lg{font-size:34px;line-height:1.24;letter-spacing:-.04em;margin:0 0 16px;color:var(--navy);font-weight:900}
.h-md{font-size:22px;line-height:1.32;margin:0 0 10px;color:var(--navy);font-weight:800}
.lead{font-size:18px;color:var(--muted);max-width:760px;margin:0 auto 0}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}
.hl{background:linear-gradient(transparent 55%,#bcd2ff 55%);font-weight:900;color:var(--navy);padding:0 2px}
.accent{color:var(--blue)}
.sec-head{max-width:760px;margin:0 0 44px}
.sec-head.center{margin-left:auto;margin-right:auto}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;color:#fff;min-height:560px;display:flex;align-items:center;
  background:linear-gradient(115deg,rgba(3,18,38,.86),rgba(6,26,58,.62) 55%,rgba(0,60,230,.30)),var(--hero-img,linear-gradient(120deg,#0b2a5e,#0046FF));
  background-size:cover;background-position:center}
.hero .wrap{padding-top:70px;padding-bottom:70px;position:relative;z-index:2}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;padding:8px 15px;border:1px solid rgba(255,255,255,.34);background:rgba(255,255,255,.08);border-radius:999px;font-size:12.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#dbeafe;margin-bottom:22px}
.hero h1{font-size:54px;line-height:1.14;letter-spacing:-.045em;margin:0 0 18px;font-weight:900;max-width:780px}
.hero p.sub{font-size:19px;color:#dbeafe;max-width:600px;margin:0 0 30px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-mini{display:flex;gap:26px;margin-top:38px;flex-wrap:wrap}
.hero-mini b{display:block;font-size:13px;color:#bcd6ff;font-weight:700;letter-spacing:.04em}
.hero-mini span{font-size:22px;font-weight:900}

/* ---------- Cards & grids ---------- */
.grid{display:grid;gap:18px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{border:1px solid var(--line);border-radius:var(--radius);padding:26px;background:#fff;box-shadow:var(--shadow-sm)}
.card.soft{background:var(--pale);box-shadow:none}
.icon-card{border:1px solid var(--line);border-radius:22px;padding:24px;background:#fff;box-shadow:var(--shadow-sm);transition:.18s}
.icon-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#bcd0f5}
.icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:var(--sky);font-size:26px;margin-bottom:14px}
.icon-card h3{font-size:18px;margin:0 0 6px;color:var(--navy);font-weight:800}
.icon-card p{margin:0;font-size:14.5px;color:var(--muted)}

/* pillars (진단/차단/케어/증명) */
.pillar .num{font-size:13px;font-weight:900;color:var(--blue);letter-spacing:.1em}

/* dark band */
.band-dark{background:linear-gradient(135deg,var(--navy),var(--deep));color:#fff;overflow:hidden}
.band-dark .h-lg,.band-dark .h-md{color:#fff}
.band-dark .lead{color:#cfe1ff}
.band-blue{background:linear-gradient(135deg,var(--blue),#0026a8);color:#fff}
.band-blue .h-lg{color:#fff}
.band-blue .lead{color:#dbe7ff}
.band-pale{background:var(--pale)}

.bluebox{background:var(--sky);border-left:5px solid var(--blue);border-radius:16px;padding:22px 24px}
.bluebox strong{color:var(--navy)}
.strongline{font-size:23px;font-weight:900;color:var(--navy);line-height:1.5;margin:0}

/* tags */
.tag{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:5px 11px;background:var(--blue);color:#fff;font-size:12px;font-weight:800}
.tag.light{background:var(--sky);color:var(--blue)}
.tag.green{background:#E6FCF5;color:#099268}
.tag.orange{background:#FFF4E6;color:#E8590C}
.tagrow{display:flex;gap:8px;flex-wrap:wrap}

/* checklist */
.checklist{list-style:none;margin:0;padding:0}
.checklist li{position:relative;padding-left:28px;margin:10px 0;color:var(--text)}
.checklist li:before{content:"✓";position:absolute;left:0;top:0;color:var(--blue);font-weight:900;font-size:16px}
.list{margin:0;padding-left:20px}.list li{margin:7px 0}

/* tables */
.tbl-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:14.5px;border:1px solid var(--line);border-radius:18px;overflow:hidden}
.tbl th,.tbl td{padding:14px 16px;vertical-align:top;border-bottom:1px solid var(--line);border-right:1px solid var(--line);text-align:left}
.tbl th:last-child,.tbl td:last-child{border-right:none}
.tbl tr:last-child td{border-bottom:none}
.tbl th{background:var(--navy);color:#fff;font-weight:800}
.tbl tr:nth-child(even) td{background:var(--pale)}
.tbl td:first-child{font-weight:800;color:var(--navy)}

/* process flow */
.flow{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.flow .step{position:relative;border:1px solid var(--line);background:#fff;border-radius:16px;padding:18px;min-height:135px}
.flow .step b{display:block;color:var(--blue);font-size:12.5px;font-weight:900;letter-spacing:.06em}
.flow .step strong{display:block;color:var(--navy);font-size:16px;margin:5px 0}
.flow .step span{font-size:13px;color:var(--muted)}
.flow .step:not(:last-child):after{content:"→";position:absolute;right:-13px;top:42%;color:var(--blue);font-weight:900;z-index:2}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:stretch}
.price{border:1px solid var(--line);border-radius:22px;padding:26px 22px;background:#fff;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}
.price.hot{border:2px solid var(--blue);box-shadow:0 20px 44px rgba(0,70,255,.16)}
.price .pico{width:52px;height:52px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 14px}
.price h3{text-align:center;font-size:20px;color:var(--blue);margin:0 0 2px;font-weight:900}
.price .ko{text-align:center;font-size:13px;color:var(--muted);margin:0 0 14px}
.price .amt{text-align:center;font-size:15px;color:var(--navy);font-weight:700;padding:12px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:16px}
.price .amt b{font-size:24px;color:var(--blue)}
.price .feat{list-style:none;margin:0 0 18px;padding:0;flex:1}
.price .feat li{position:relative;padding-left:24px;margin:9px 0;font-size:13.5px;color:var(--text)}
.price .feat li:before{content:"✓";position:absolute;left:0;color:var(--blue);font-weight:900}
.price .desc{font-size:12px;color:var(--muted);margin:0 0 16px;line-height:1.6}
.ribbon{display:inline-block;background:var(--orange);color:#fff;font-size:11px;font-weight:800;border-radius:999px;padding:3px 10px;margin-left:6px;vertical-align:middle}

/* split feature row */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.feature.rev .media{order:2}
.media-ph{border-radius:var(--radius);min-height:300px;background:linear-gradient(135deg,#0b2a5e,#0046FF);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#cfe1ff;gap:8px;border:1px solid var(--line);text-align:center;padding:24px}
.media-ph .ico{font-size:46px}
.media-ph small{font-size:12px;opacity:.8}

/* problem cards */
.prob{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#fff}
.prob .top{height:150px;display:flex;align-items:center;justify-content:center;font-size:42px;background:linear-gradient(135deg,#dbe7ff,#aebff0)}
.prob .body{padding:18px}
.prob .body h4{margin:0 0 6px;font-size:16px;color:var(--navy)}
.prob .body p{margin:0;font-size:14px;color:var(--muted)}

/* CTA band */
.cta-band{position:relative;overflow:hidden;color:#fff;background:linear-gradient(120deg,rgba(3,18,38,.9),rgba(0,46,168,.7)),linear-gradient(120deg,#0b2a5e,#0046FF);background-size:cover;background-position:center}
.cta-band .wrap{padding:72px 24px;text-align:center}
.cta-band h2{font-size:36px;font-weight:900;margin:0 0 14px;letter-spacing:-.04em}
.cta-band p{color:#dbeafe;font-size:18px;margin:0 0 28px}
.cta-band .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* partner logos */
.logos{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.logo-chip{border:1px solid var(--line);border-radius:16px;height:84px;display:flex;align-items:center;justify-content:center;background:#fff;color:var(--navy);font-weight:900;gap:6px}
.logo-chip .loop{color:var(--blue)}

/* two-tone recruit */
.recruit{display:grid;grid-template-columns:1fr 1fr;border-radius:var(--radius);overflow:hidden}
.recruit .left{background:var(--blue);color:#fff;padding:42px}
.recruit .right{background:var(--navy);color:#fff;padding:42px}
.recruit h3{color:#fff;font-size:22px;margin:0 0 10px}
.recruit p{color:rgba(255,255,255,.85);margin:0 0 22px;font-size:15px}

/* form */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:800;color:var(--navy);font-size:14px;margin-bottom:7px}
.field .req{color:var(--blue)}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:13px 14px;font-size:15px;font-family:inherit;background:#fff;color:var(--text)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,70,255,.12)}
.field textarea{min-height:120px;resize:vertical}
.chip-select{display:flex;gap:8px;flex-wrap:wrap}
.chip-select label{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-weight:700;font-size:13.5px;color:var(--muted);cursor:pointer;margin:0}
.chip-select input{display:none}
.chip-select input:checked + span{color:var(--blue)}
.chip-select label:has(input:checked){border-color:var(--blue);background:var(--sky);color:var(--blue)}
.form-note{font-size:12.5px;color:var(--muted);margin-top:6px}

/* FAQ */
.faq{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff}
.faq details{border-bottom:1px solid var(--line)}
.faq details:last-child{border-bottom:none}
.faq summary{cursor:pointer;padding:20px 24px;font-weight:800;color:var(--navy);font-size:16px;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"+";color:var(--blue);font-size:24px;font-weight:400}
.faq details[open] summary:after{content:"−"}
.faq .ans{padding:0 24px 22px;color:var(--muted);font-size:15px}

/* page hero (sub pages) */
.page-hero{background:linear-gradient(120deg,var(--navy),var(--deep));color:#fff;padding:64px 0}
.page-hero .crumb{font-size:13px;color:#7aa6ff;font-weight:700;letter-spacing:.06em;margin-bottom:12px}
.page-hero h1{font-size:42px;font-weight:900;margin:0 0 12px;letter-spacing:-.04em}
.page-hero p{color:#cfe1ff;font-size:18px;max-width:680px;margin:0}

/* ---------- Footer ---------- */
.footer{background:#0a1526;color:#9fb3cc;font-size:14px;padding:60px 0 30px}
.footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:30px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer .brand{color:#fff;font-size:22px;margin-bottom:14px}
.footer h5{color:#fff;font-size:15px;margin:0 0 14px;font-weight:800}
.footer ul{list-style:none;margin:0;padding:0}
.footer li{margin:9px 0}
.footer a:hover{color:#fff}
.footer .tel{color:#fff;font-size:26px;font-weight:900;letter-spacing:-.02em;margin:4px 0}
.footer .hours{font-size:13px;color:#7e93ad}
.footer .sns{display:flex;gap:10px;margin-top:14px}
.footer .sns a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:16px}
.footer .sns a:hover{background:var(--blue)}
.footer .bottom{padding-top:24px;font-size:12.5px;color:#6f86a3;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer .biz{line-height:1.8}

/* ---------- Floating CTA ---------- */
.float{position:fixed;right:20px;bottom:22px;z-index:80;display:flex;flex-direction:column;gap:10px}
.float a{width:60px;height:60px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:800;gap:1px;box-shadow:0 10px 26px rgba(0,0,0,.22);transition:.15s}
.float a:hover{transform:translateY(-3px)}
.float .f-call{background:var(--blue)}
.float .f-kakao{background:#FAE100;color:#3a1d1d}
.float .f-top{background:var(--navy);font-size:18px}
.float .ico{font-size:20px}

/* ---------- Photo cards & media ---------- */
.photo-card{border:1px solid rgba(255,255,255,.14);border-radius:20px;overflow:hidden;background:rgba(255,255,255,.06);display:flex;flex-direction:column}
.photo-card .ph{height:200px;overflow:hidden;position:relative}
.photo-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.photo-card:hover .ph img{transform:scale(1.05)}
.photo-card .ph .tag{position:absolute;top:14px;left:14px}
.photo-card .bd{padding:22px}
.photo-card .bd h3{color:#fff;font-size:19px;margin:0 0 7px;font-weight:800}
.photo-card .bd p{color:#cfe1ff;margin:0;font-size:14.5px}
.media img{border-radius:var(--radius);width:100%;height:100%;max-height:440px;object-fit:cover;box-shadow:var(--shadow)}
.intro-loop{max-width:360px;width:100%;border-radius:24px}
.cta-photo{background:linear-gradient(120deg,rgba(3,18,38,.9),rgba(0,46,168,.62)),var(--cta-img) center/cover no-repeat !important}

/* DESIGN-faithful navy service card */
.svc-card{background:var(--navy);border-radius:20px;padding:14px;display:flex;flex-direction:column;transition:.18s;box-shadow:var(--shadow-sm)}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 22px 46px rgba(0,30,90,.28)}
.svc-card .ph{height:150px;border-radius:14px;overflow:hidden;margin-bottom:16px}
.svc-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.svc-card:hover .ph img{transform:scale(1.06)}
.svc-card .eng{font-size:10.5px;font-weight:800;letter-spacing:.12em;color:#6f9bff;text-transform:uppercase;padding:0 6px}
.svc-card h3{font-size:18px;font-weight:800;color:#fff;margin:6px 0 14px;padding:0 6px;line-height:1.3;letter-spacing:-.02em}
.svc-card .more{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding:10px 6px 4px;border-top:1px solid rgba(255,255,255,.12)}
.svc-card .more span{font-size:12.5px;color:#aebfd8;font-weight:600}
.svc-card .more .ic{width:34px;height:34px;border:1px solid rgba(255,255,255,.28);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px}
/* CTA cell in service grid */
.svc-cta{background:#fff;border:1px solid var(--line);border-radius:20px;padding:26px;display:flex;flex-direction:column;justify-content:center;box-shadow:var(--shadow-sm)}
.svc-cta .eng{font-size:13px;font-weight:900;color:var(--blue);letter-spacing:.14em}
.svc-cta strong{font-size:22px;color:var(--navy);font-weight:900;margin:4px 0 16px;letter-spacing:-.02em}

/* DESIGN-faithful numbered alternating rows */
.numrow{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin:0 0 34px}
.numrow.rev .nm-media{order:2}
.numrow .nm-media img{width:100%;height:320px;object-fit:cover;border-radius:22px;box-shadow:var(--shadow)}
.numrow .big-num{font-size:30px;font-weight:900;color:var(--blue);line-height:1;margin-bottom:8px}
.numrow .kipo{display:inline-flex;align-items:center;gap:7px;margin-top:12px;font-size:12.5px;font-weight:800;color:var(--blue);background:var(--sky);border-radius:999px;padding:6px 12px}

/* DESIGN-faithful B2G gradient-overlay card */
.b2g-card{position:relative;border-radius:20px;overflow:hidden;min-height:300px;display:flex;align-items:flex-end;border:1px solid rgba(255,255,255,.12)}
.b2g-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.b2g-card .ov{position:relative;z-index:2;width:100%;padding:26px 22px 22px;background:linear-gradient(to top,rgba(0,40,150,.92),rgba(0,50,180,.55) 55%,transparent)}
.b2g-card .eng{font-size:10.5px;font-weight:800;letter-spacing:.12em;color:#cfe0ff;text-transform:uppercase}
.b2g-card h3{font-size:20px;color:#fff;font-weight:800;margin:6px 0 12px;line-height:1.3}
.b2g-card .more{font-size:12.5px;color:#dbe7ff;font-weight:600}

/* ---------- Reveal anim ---------- */
html.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
html.js .reveal.in{opacity:1;transform:none}

/* ---------- 로딩 화면 + 페이지 전환 (Careflow ∞ 로고 애니메이션) ---------- */
#cf-loader{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;
  background:radial-gradient(circle at 50% 38%,#0b2a5e,#031226 72%);
  transition:opacity .55s ease,visibility .55s ease}
#cf-loader.hide{opacity:0;visibility:hidden}
#cf-loader .cf-mark{width:140px;height:86px;overflow:visible;filter:drop-shadow(0 8px 26px rgba(0,70,255,.45))}
#cf-loader .cf-mark path{fill:none;stroke-width:6;stroke-linecap:round}
#cf-loader .cf-base{stroke:rgba(255,255,255,.12)}
#cf-loader .cf-draw{stroke:url(#cfg);stroke-dasharray:240;stroke-dashoffset:240;animation:cf-draw 1.15s cubic-bezier(.65,0,.35,1) forwards}
#cf-loader .cf-comet{stroke:#cfe0ff;stroke-dasharray:16 224;stroke-dashoffset:240;animation:cf-comet 1.7s linear .35s infinite}
@keyframes cf-draw{to{stroke-dashoffset:0}}
@keyframes cf-comet{from{stroke-dashoffset:240}to{stroke-dashoffset:0}}
#cf-loader .cf-word{color:#fff;font-weight:900;font-size:25px;letter-spacing:-.02em;opacity:0;animation:cf-up .6s ease .45s forwards}
#cf-loader .cf-word .loop{color:#6ea6ff}
#cf-loader .cf-sub{color:#9fc0ff;font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;opacity:0;animation:cf-up .6s ease .65s forwards}
@keyframes cf-up{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion: reduce){
  #cf-loader .cf-draw,#cf-loader .cf-comet,#cf-loader .cf-word,#cf-loader .cf-sub{animation:none}
  #cf-loader .cf-draw{stroke-dashoffset:0}#cf-loader .cf-word,#cf-loader .cf-sub{opacity:1}
}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .g4{grid-template-columns:repeat(2,1fr)}
  .price-grid{grid-template-columns:repeat(2,1fr)}
  .flow{grid-template-columns:repeat(3,1fr)}
  .flow .step:not(:last-child):after{display:none}
  .logos{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:860px){
  .nav-menu,.nav-cta{display:none}
  .nav-menu.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;background:#fff;border-bottom:1px solid var(--line);padding:14px 24px;gap:4px;box-shadow:0 14px 26px rgba(0,30,90,.1)}
  .nav-toggle{display:block}
  .g3,.g2,.feature,.recruit,.numrow{grid-template-columns:1fr}
  .feature.rev .media,.numrow.rev .nm-media{order:0}
  .footer .top{grid-template-columns:1fr 1fr}
  .sec{padding:64px 0}
  .hero{min-height:auto;background-position:center;background-image:linear-gradient(180deg,rgba(3,18,38,.72),rgba(3,18,38,.5)),var(--hero-img)}
  .hero .wrap{padding:56px 20px}
  .hero-panel{max-width:none;padding:30px 24px;background:rgba(6,20,46,.6)}
  .hero h1{font-size:34px}.hero p.sub{font-size:16px}
  .h-xl{font-size:32px}.h-lg{font-size:27px}.h-md{font-size:20px}
  .numrow .nm-media img{height:240px}
}
@media(max-width:560px){
  .g4,.price-grid,.flow,.logos,.footer .top{grid-template-columns:1fr}
  .sec{padding:52px 0}.sec-tight{padding:44px 0}
  .wrap{padding:0 18px}
  .hero h1{font-size:29px}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{justify-content:center}
  .hero-mini{gap:16px}
  .topbar .tb-left{display:none}
  .cta-band h2{font-size:27px}.cta-band .row{flex-direction:column}
  .cta-band .row .btn{justify-content:center}
  .price-grid{gap:14px}
  .float a{width:54px;height:54px;font-size:10px}
  #cf-loader .cf-mark{width:110px}
}
