
:root{
  --bg:#f3f5f8;
  --surface:#ffffff;
  --text:#101828;
  --muted:#667085;
  --line:rgba(16,24,40,.08);
  --primary:#143b78;
  --accent:#1570ef;
  --cta:#39b174;
  --cta-dark:#2d9b61;
  --dark:#163b73;
  --shadow:0 2px 8px rgba(16,24,40,.04);
  --shadow-lg:0 12px 28px rgba(16,24,40,.10);
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'DM Sans',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(calc(100% - 32px), var(--max));margin:0 auto}
.section{padding:72px 0}
.section-tight{padding:56px 0}
.topbar{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.nav{min-height:84px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand img{width:220px;height:auto;object-fit:contain}
.navlinks{display:flex;align-items:center;gap:48px;color:var(--muted);font-weight:700;font-size:1.2rem}
.navlinks a:hover,.navlinks a[aria-current="page"]{color:var(--text)}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:50px;padding:0 22px;border-radius:14px;font-weight:700;
  transition:.2s ease;border:1px solid transparent
}
.btn:hover{transform:translateY(-1px)}
.btn-cta{background:var(--cta);color:#fff;box-shadow:0 8px 16px rgba(57,177,116,.16)}
.btn-cta:hover{background:var(--cta-dark)}
.btn-outline{background:transparent;border:1.5px solid rgba(21,112,239,.28);color:var(--primary)}
.btn-outline.light{border-color:rgba(255,255,255,.22);color:#fff}
.tag{display:inline-flex;align-items:center;color:var(--accent);font-size:.78rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
h1,h2,h3{
  font-family:'Space Grotesk',system-ui,sans-serif;
  margin:0 0 16px;
  letter-spacing:-.03em;
  overflow-wrap:break-word;
}
p{margin:0 0 16px;color:var(--muted);font-size:.97rem;line-height:1.65}
.skip-link{
  position:absolute;left:16px;top:-48px;background:#fff;color:#101828;padding:10px 14px;
  border-radius:12px;z-index:200;border:1px solid var(--line);box-shadow:var(--shadow)
}
.skip-link:focus{top:16px}
:focus-visible{outline:3px solid rgba(21,112,239,.55);outline-offset:3px}

.hero{
  position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden;color:#fff;
  background:
    linear-gradient(180deg, rgba(4,10,18,.64), rgba(4,10,18,.56) 42%, rgba(4,10,18,.74) 100%),
    url('hero-bg.jpg') center/cover no-repeat;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(2,8,15,.86) 0%, rgba(2,8,15,.64) 38%, rgba(2,8,15,.28) 100%)
}
.hero-inner{position:relative;z-index:2;padding:40px 0 36px}
.hero-badge{
  display:inline-flex;align-items:center;padding:12px 24px;border-radius:999px;
  background:rgba(11,31,54,.46);border:1px solid rgba(33,123,230,.55);
  color:#2c97ff;font-size:.76rem;font-weight:700;letter-spacing:.02em;margin-bottom:28px
}
.hero-title{
  max-width:760px;
  font-size:clamp(2.15rem,4.8vw,4rem);
  line-height:1.0;
  letter-spacing:-.055em;
  margin-bottom:22px;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  overflow:hidden;
  -webkit-line-clamp:2;
  text-wrap:balance;
}
.text-gradient{background:linear-gradient(135deg,#4fa4ff 0%,#7fc2ff 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-copy{max-width:820px;font-size:1rem;line-height:1.8;color:rgba(255,255,255,.8);margin-bottom:28px}
.hero-actions{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:54px}
.hero-actions .btn{min-height:62px;padding:0 30px;border-radius:18px}
.hero-meta{display:flex;flex-wrap:wrap;gap:36px;color:rgba(255,255,255,.68);font-size:.92rem}
.hero-meta span{display:inline-flex;align-items:center;gap:12px}
.hero-meta span::before{
  content:"";width:10px;height:10px;border-radius:999px;background:#21b36d;
  box-shadow:0 0 0 4px rgba(33,179,109,.08)
}

.page-hero{
  background:#fff;
  padding:56px 0 24px;
  border-bottom:1px solid var(--line);
}
.page-hero .container{max-width:980px}
.breadcrumb{font-size:.88rem;color:var(--muted);margin-bottom:12px}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{text-decoration:underline}
.page-title{
  font-size:clamp(1.95rem,3.8vw,3.1rem);
  line-height:1.08;
  letter-spacing:-.03em;
  max-width:840px;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  overflow:hidden;
  -webkit-line-clamp:2;
  text-wrap:balance;
}
.page-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}

.kicker{max-width:1180px;margin:0 auto 44px;text-align:center}
.kicker h2{
  max-width:920px;
  margin:12px auto 16px;
  font-size:clamp(1.75rem,3vw,2.55rem);
  line-height:1.08;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  overflow:hidden;
  -webkit-line-clamp:2;
  text-wrap:balance;
}

.cards-4,.cards-3,.cards-2{display:grid;gap:18px;align-items:stretch}
.cards-4{grid-template-columns:repeat(4,1fr)}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow);
  display:flex;flex-direction:column;justify-content:flex-start;
}
.icon{
  width:38px;height:38px;border-radius:12px;display:grid;place-items:center;
  background:#edf2fa;color:var(--accent);font-size:.95rem;font-weight:700;flex:0 0 auto
}
.service-head{
  display:flex;align-items:flex-start;gap:12px;margin-bottom:14px;min-height:60px
}
.service-head h3{
  font-size:1rem;
  line-height:1.16;
  margin:0;
}
.card p:last-child{margin-bottom:0}

.notice{padding:18px 20px;border-radius:16px;background:#eef7f1;border:1px solid rgba(57,177,116,.14)}
.notice p{margin:0;color:#2d4f3e}
.list{display:grid;gap:10px}
.list div{display:flex;gap:10px;align-items:flex-start;color:#344054}
.list div::before{content:"✓";color:var(--cta);font-weight:800}

.dark-section{background:var(--dark);color:#fff}
.dark-section .tag{color:#64a9ff}
.dark-section h2,.dark-section h3{color:#fff}
.dark-section p{color:rgba(255,255,255,.74)}
.proof-card{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  color:#fff;padding:26px;text-align:center;border-radius:16px
}
.proof-card p{color:rgba(255,255,255,.72)}
.proof-card .service-head{justify-content:center;min-height:58px}
.proof-card .icon{background:#1b4f97;color:#64a9ff}

.faq{display:grid;gap:14px;max-width:860px;margin:0 auto}
details{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow)}
summary{cursor:pointer;font-family:'Space Grotesk',system-ui,sans-serif;font-weight:700;list-style:none}
summary::-webkit-details-marker{display:none}
details p{margin-top:12px}

.cta-final{background:linear-gradient(90deg,#0d2957 0%, #1d3d70 100%);color:#fff}
.cta-final h2{
  max-width:1200px;margin:0 auto 16px;
  font-size:clamp(1.95rem,3.5vw,3rem);line-height:1.06;color:#fff
}
.cta-final p{max-width:860px;margin:0 auto 34px;color:rgba(255,255,255,.8);font-size:1.05rem;text-align:center}
.footer-wrap{border-top:1px solid rgba(255,255,255,.16);padding:30px 0 18px}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1.2fr;gap:34px;color:rgba(255,255,255,.76)}
.footer-grid p,.footer-grid a,.footer-grid div{color:rgba(255,255,255,.76)}
.footer-grid a:hover{text-decoration:underline}
.footer-title{font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.54);margin-bottom:18px}
.wa{
  position:fixed;right:18px;bottom:18px;z-index:70;width:68px;height:68px;border-radius:50%;
  display:grid;place-items:center;background:#39b174;color:#fff;font-size:1.7rem;
  box-shadow:0 10px 22px rgba(57,177,116,.22)
}

/* Home process carousel */
.flow-carousel{display:grid;grid-template-columns:56px 1fr 56px;align-items:center;gap:18px}
.flow-track{display:grid;grid-template-columns:1fr 2fr 1fr;gap:18px;align-items:stretch}
.flow-card{
  background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);
  padding:20px 18px 18px;cursor:pointer;transition:transform .25s ease,opacity .25s ease,box-shadow .25s ease;
  min-height:250px
}
.flow-card.side{
  opacity:.86;transform:scale(.92);display:flex;flex-direction:column;align-items:center;
  text-align:center;justify-content:flex-start;padding-top:24px
}
.flow-card.active{transform:scale(1);box-shadow:0 12px 28px rgba(16,24,40,.10)}
.flow-head{display:flex}
.flow-card.active .flow-head{
  align-items:center;justify-content:center;gap:14px;margin-bottom:18px;min-height:74px
}
.flow-card.side .flow-head{
  flex-direction:column;align-items:center;gap:14px;margin-bottom:16px
}
.flow-badge{
  width:58px;height:58px;border-radius:16px;display:grid;place-items:center;background:#edf2fa;
  color:var(--accent);font-size:1.5rem;font-weight:800;flex:0 0 auto
}
.flow-card.active h3{
  margin:0;font-size:clamp(1.1rem,1.35vw,1.4rem);line-height:1.1;
  max-width:360px;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;-webkit-line-clamp:2;text-wrap:balance;
  text-align:center
}
.flow-card.side h3{
  margin:0;font-size:1rem;line-height:1.14;max-width:190px;
  display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;-webkit-line-clamp:2;text-wrap:balance;
}
.flow-card.active p{
  text-justify: inter-word;
  line-height: 1.68;
  letter-spacing: 0.01em;
  max-width: 96%;
  margin: 0 auto;
  font-size: 1.03rem;
  color: #667085;}
.flow-card.side p{margin:0;font-size:1rem;line-height:1.4;color:var(--accent);font-weight:700}
.flow-arrow{
  width:56px;height:56px;border:1px solid var(--line);border-radius:999px;background:#fff;
  color:var(--primary);font-size:2rem;line-height:1;cursor:pointer;box-shadow:var(--shadow)
}
.flow-dots{display:flex;justify-content:center;gap:10px;margin-top:24px}
.flow-dot{width:12px;height:12px;border-radius:999px;border:0;background:rgba(20,59,120,.18);cursor:pointer}
.flow-dot.active{background:var(--accent)}

/* Services page unified grid */
.service-grid-10{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.service-grid-10 .card{min-height:188px}
.service-grid-10 .service-head{min-height:60px}
.service-grid-10 h3{
  display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;-webkit-line-clamp:2;text-wrap:balance
}

/* About carousel */
.work-carousel{display:grid;grid-template-columns:56px 1fr 56px;align-items:center;gap:18px}
.work-track{display:grid;grid-template-columns:1fr 2fr 1fr;gap:18px;align-items:stretch}
.work-card{
  background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);
  padding:26px 24px 24px;cursor:pointer;transition:transform .25s ease,opacity .25s ease,box-shadow .25s ease;
  min-height:260px
}
.work-card.side{
  opacity:.86;transform:scale(.92);display:flex;flex-direction:column;align-items:center;
  text-align:center;justify-content:flex-start;padding-top:24px
}
.work-card.active{transform:scale(1);box-shadow:0 12px 28px rgba(16,24,40,.10)}
.work-head{display:flex}
.work-card.active .work-head{
  align-items:center;justify-content:center;gap:14px;margin-bottom:18px;min-height:72px
}
.work-card.side .work-head{
  flex-direction:column;align-items:center;gap:14px;margin-bottom:16px
}
.work-badge{
  width:58px;height:58px;border-radius:16px;display:grid;place-items:center;background:#edf2fa;
  color:var(--accent);font-size:1.35rem;font-weight:800;flex:0 0 auto
}
.work-card.active h3{
  margin:0;font-size:clamp(1.08rem,1.3vw,1.35rem);line-height:1.1;max-width:320px;
  display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;-webkit-line-clamp:2;text-wrap:balance;
  text-align:center
}
.work-card.side h3{
  margin:0;font-size:1rem;line-height:1.14;max-width:180px;
  display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;-webkit-line-clamp:2;text-wrap:balance
}
.work-card.active p{margin:0;font-size:1.02rem;line-height:1.66}
.work-card.side p{margin:0;font-size:1rem;line-height:1.4;color:var(--accent);font-weight:700}
.work-arrow{
  width:56px;height:56px;border:1px solid var(--line);border-radius:999px;background:#fff;
  color:var(--primary);font-size:2rem;line-height:1;cursor:pointer;box-shadow:var(--shadow)
}
.work-dots{display:flex;justify-content:center;gap:10px;margin-top:24px}
.work-dot{width:12px;height:12px;border-radius:999px;border:0;background:rgba(20,59,120,.18);cursor:pointer}
.work-dot.active{background:var(--accent)}

.partner-layout{display:grid;grid-template-columns:1.7fr .9fr;gap:24px}
.partner-side .card{position:sticky;top:100px}

@media (max-width:1080px){
  .cards-4,.cards-3,.cards-2,.footer-grid,.service-grid-10,.partner-layout{grid-template-columns:1fr}
  .navlinks{display:none}
}
@media (max-width:980px){
  .flow-track,.work-track{grid-template-columns:1fr}
  .flow-card.side,.work-card.side{display:none}
  .flow-carousel,.work-carousel{grid-template-columns:46px 1fr 46px}
  .flow-card,.work-card{min-height:auto}
  .service-grid-10{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:760px){
  .section{padding:52px 0}
  .section-tight{padding:44px 0}
  .nav{min-height:74px}
  .brand img{width:190px}
  .hero{min-height:auto;background-position:center}
  .hero-inner{padding:34px 0 28px}
  .hero-title{max-width:100% !important;font-size:clamp(1.95rem,10vw,2.65rem) !important}
  .hero-copy{font-size:.95rem;line-height:1.7;margin-bottom:24px}
  .hero-actions{gap:14px;margin-bottom:34px}
  .hero-actions .btn,.btn{width:100%;min-height:56px;padding:0 20px;border-radius:16px}
  .hero-meta{gap:14px;font-size:.86rem}
  .hero-meta span{width:100%}
  .page-title{max-width:100%;font-size:clamp(1.75rem,8vw,2.3rem) !important}
  .kicker h2{max-width:100%;font-size:clamp(1.55rem,7vw,2rem)}
  .service-grid-10{grid-template-columns:1fr}
  .service-head{min-height:auto}
}


/* Premium section rhythm */
body{
  background:#ffffff;
}
.section-surface{
  background:#ffffff;
}
.section-alt{
  background:#f7f9fc;
  border-top:1px solid rgba(16,24,40,.04);
  border-bottom:1px solid rgba(16,24,40,.04);
}
.section-soft{
  background:linear-gradient(180deg,#fbfcfe 0%, #f4f7fb 100%);
  border-top:1px solid rgba(16,24,40,.04);
  border-bottom:1px solid rgba(16,24,40,.04);
}
.section-emphasis{
  background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%);
}
.page-hero{
  background:linear-gradient(180deg,#ffffff 0%, #fafcff 100%);
}
.kicker p{
  max-width:760px;
}
.card{
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(16,24,40,.08);
  border-color:rgba(21,112,239,.12);
}
.notice{
  background:linear-gradient(180deg,#eef7f1 0%, #f5fbf7 100%);
}
.hero-copy strong{
  color:#fff;
}
.partner-layout .card,
.service-grid-10 .card{
  min-height:100%;
}
