
:root{
  --bg:#f5f6fb;
  --bg-soft:#fbfbfe;
  --panel:rgba(255,255,255,0.72);
  --panel-strong:rgba(255,255,255,0.9);
  --text:#102038;
  --muted:#5e6b82;
  --line:rgba(16,32,56,0.08);
  --accent:#5a67ff;
  --accent-2:#7ad7c4;
  --accent-3:#ffd9b8;
  --shadow:0 24px 80px rgba(46,66,104,.12);
  --radius:28px;
  --max:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 10% 10%, rgba(122,215,196,.25), transparent 28%),
    radial-gradient(circle at 90% 6%, rgba(90,103,255,.16), transparent 24%),
    radial-gradient(circle at 85% 85%, rgba(255,217,184,.35), transparent 22%),
    linear-gradient(180deg, #fcfcff 0%, #f5f6fb 46%, #eef2f9 100%);
  min-height:100vh;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(calc(100% - 32px), var(--max)); margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(160%) blur(18px);
  background:rgba(255,255,255,.55);
  border-bottom:1px solid rgba(16,32,56,.06);
}
.site-header .inner{display:flex; align-items:center; justify-content:space-between; gap:22px; min-height:78px}
.logo{display:flex; align-items:center; gap:14px; font-weight:800; letter-spacing:-.04em}
.logo-mark{
  width:42px; height:42px; border-radius:14px; position:relative;
  background:linear-gradient(135deg, rgba(90,103,255,.98), rgba(122,215,196,.95));
  box-shadow:inset 0 1px 1px rgba(255,255,255,.7), 0 10px 30px rgba(90,103,255,.24);
}
.logo-mark:before,.logo-mark:after{
  content:""; position:absolute; border-radius:999px; background:rgba(255,255,255,.88)
}
.logo-mark:before{width:18px; height:18px; left:8px; top:8px}
.logo-mark:after{width:10px; height:10px; right:8px; bottom:8px}
.logo-copy{display:flex; flex-direction:column}
.logo-copy small{font-size:.76rem; color:var(--muted); font-weight:600; letter-spacing:.02em}
.nav-toggle{display:none}
.site-nav{display:flex; flex-wrap:wrap; gap:18px; align-items:center}
.site-nav a{font-size:.96rem; color:#26405f}
.site-nav .button-link{
  padding:12px 16px; background:#fff; border:1px solid var(--line); border-radius:999px; box-shadow:0 10px 30px rgba(16,32,56,.06)
}
.hero{
  position:relative; isolation:isolate; padding:82px 0 42px;
}
.hero-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:28px; align-items:center}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px; padding:10px 14px; border-radius:999px;
  background:rgba(255,255,255,.72); border:1px solid rgba(16,32,56,.08); color:#35506f;
  box-shadow:0 12px 30px rgba(16,32,56,.06); font-size:.9rem; font-weight:600
}
.eyebrow .dot{width:9px; height:9px; border-radius:50%; background:linear-gradient(135deg,var(--accent),var(--accent-2))}
h1,h2,h3{line-height:1.02; margin:0 0 18px; letter-spacing:-.05em}
h1{font-size:clamp(3rem,5vw,5.8rem); max-width:11.5ch}
h2{font-size:clamp(2rem,3.2vw,3.5rem)}
h3{font-size:clamp(1.3rem,2vw,1.8rem)}
.lead{font-size:1.14rem; line-height:1.8; color:var(--muted); max-width:68ch}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap; margin-top:30px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px; min-height:52px; padding:0 20px; border-radius:999px;
  font-weight:700; border:1px solid transparent; transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{
  color:#fff; background:linear-gradient(135deg,#4f61ff,#72cfc4); box-shadow:0 18px 34px rgba(79,97,255,.28)
}
.btn-secondary{
  color:#213955; background:rgba(255,255,255,.78); border-color:rgba(16,32,56,.08); box-shadow:0 16px 30px rgba(16,32,56,.08)
}
.hero-card{
  position:relative; min-height:560px; border-radius:38px; overflow:hidden;
  background:
    radial-gradient(circle at 24% 22%, rgba(255,255,255,.86), rgba(255,255,255,.18) 24%, transparent 34%),
    linear-gradient(165deg, rgba(255,255,255,.9), rgba(233,239,249,.78));
  border:1px solid rgba(255,255,255,.9);
  box-shadow:var(--shadow);
}
.orb{
  position:absolute; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.98), rgba(255,255,255,.35) 28%, rgba(90,103,255,.18) 62%, rgba(122,215,196,.14));
  filter:blur(.2px);
  box-shadow:inset 0 12px 36px rgba(255,255,255,.74), 0 28px 50px rgba(90,103,255,.12);
  animation:float 8s ease-in-out infinite;
}
.orb.one{width:210px;height:210px;right:38px;top:56px;animation-delay:-1s}
.orb.two{width:136px;height:136px;left:44px;bottom:120px;animation-delay:-2.4s}
.orb.three{width:88px;height:88px;right:72px;bottom:78px;animation-delay:-4.3s}
.grid-3d{
  position:absolute; inset:38px; border-radius:30px;
  background:
    linear-gradient(rgba(90,103,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(90,103,255,.06) 1px, transparent 1px);
  background-size:34px 34px;
  transform:perspective(1000px) rotateX(66deg) scale(1.5) translateY(24%);
  transform-origin:center;
  opacity:.62;
}
.floating-panel{
  position:absolute; padding:18px 18px 16px; border-radius:24px; background:rgba(255,255,255,.76);
  border:1px solid rgba(255,255,255,.75); box-shadow:0 18px 34px rgba(16,32,56,.08); backdrop-filter:blur(14px);
}
.panel-a{left:28px; top:32px; width:240px}
.panel-b{right:26px; top:272px; width:220px}
.panel-c{left:54px; bottom:36px; width:280px}
.metric{font-size:2.2rem; font-weight:800; letter-spacing:-.05em; margin-bottom:6px}
.muted{color:var(--muted)}
.section{padding:44px 0}
.section-lg{padding:86px 0}
.kicker{font-size:.88rem; text-transform:uppercase; letter-spacing:.14em; color:#60718d; font-weight:700; margin-bottom:14px}
.card-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.card{
  background:var(--panel); border:1px solid rgba(255,255,255,.88); border-radius:30px; padding:26px;
  box-shadow:0 16px 34px rgba(16,32,56,.08); backdrop-filter:blur(14px);
}
.card p,.copy p,.copy li,.service-copy p{color:var(--muted); line-height:1.84}
.stat-line{display:flex; align-items:flex-end; gap:12px; margin:22px 0 12px}
.stat-line strong{font-size:2.8rem; letter-spacing:-.06em}
.split{display:grid; grid-template-columns:1.02fr .98fr; gap:24px; align-items:start}
.surface{
  background:rgba(255,255,255,.68); border:1px solid rgba(255,255,255,.92); border-radius:34px; padding:32px; box-shadow:var(--shadow);
}
.surface.soft{background:rgba(255,255,255,.54)}
.mini-list{display:grid; gap:14px; margin-top:18px}
.mini-item{padding:15px 16px; border-radius:20px; border:1px solid rgba(16,32,56,.08); background:rgba(255,255,255,.66)}
.service-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:18px}
.service-card{
  position:relative; overflow:hidden; min-height:320px;
  background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(241,245,252,.92));
}
.service-card:before{
  content:""; position:absolute; width:180px; height:180px; border-radius:50%; top:-60px; right:-40px;
  background:radial-gradient(circle at 30% 30%, rgba(122,215,196,.42), rgba(90,103,255,.18), transparent 72%);
}
.service-card h3{max-width:12ch}
.service-card .link-arrow{margin-top:20px; display:inline-flex; gap:10px; align-items:center; color:#405b7d; font-weight:700}
.timeline{display:grid; gap:16px}
.timeline-item{display:grid; grid-template-columns:74px 1fr; gap:16px; align-items:start}
.timeline-item .num{
  height:74px; border-radius:22px; display:grid; place-items:center; font-weight:800; font-size:1.35rem;
  background:linear-gradient(135deg, rgba(90,103,255,.12), rgba(122,215,196,.18));
  border:1px solid rgba(16,32,56,.06)
}
.quote{
  font-size:1.18rem; line-height:1.75; color:#2d4664
}
.table-like{display:grid; gap:14px}
.table-row{
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
  padding:18px 20px; border-radius:22px; background:rgba(255,255,255,.72); border:1px solid rgba(16,32,56,.06)
}
.cta-band{
  padding:28px; border-radius:34px; background:linear-gradient(135deg, rgba(255,255,255,.88), rgba(242,245,251,.92)); border:1px solid rgba(255,255,255,.96); box-shadow:var(--shadow)
}
.site-footer{
  padding:36px 0 54px; color:#556983
}
.footer-grid{display:grid; grid-template-columns:1.2fr .8fr .8fr .9fr; gap:24px}
.footer-grid h3{font-size:1rem; letter-spacing:-.03em; margin-bottom:14px}
.footer-grid a{display:block; margin:10px 0; color:#3c5778}
.page-hero{padding:56px 0 18px}
.breadcrumbs{display:flex; gap:10px; flex-wrap:wrap; color:#62738e; font-size:.95rem}
.page-title{max-width:12ch}
.content-grid{display:grid; grid-template-columns:.8fr 1.2fr; gap:24px}
.sticky{position:sticky; top:98px}
.copy h2{margin-top:36px}
.copy ul{padding-left:20px}
.copy li{margin:8px 0}
.badge-list{display:flex; flex-wrap:wrap; gap:10px; margin-top:18px}
.badge{padding:10px 14px; border-radius:999px; background:rgba(255,255,255,.72); border:1px solid rgba(16,32,56,.08); color:#425d7d; font-weight:600}
.notice{
  padding:18px 20px; border-radius:20px; background:rgba(122,215,196,.12); border:1px solid rgba(122,215,196,.26); color:#24465d
}
.contact-list{display:grid; gap:12px}
.contact-item{padding:16px 18px; border-radius:18px; background:rgba(255,255,255,.72); border:1px solid rgba(16,32,56,.08)}
.form-shell{display:grid; gap:14px}
.field{display:grid; gap:8px}
input,textarea{
  width:100%; padding:14px 16px; border-radius:18px; border:1px solid rgba(16,32,56,.1); background:rgba(255,255,255,.88);
  font:inherit; color:var(--text)
}
textarea{min-height:160px; resize:vertical}
small.fineprint{display:block; color:#6c7a90; line-height:1.7}
.reveal{opacity:0; transform:translateY(20px); transition:opacity .7s ease, transform .7s ease}
.reveal.visible{opacity:1; transform:none}
@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-18px) rotate(4deg)}}
@media (max-width: 1080px){
  .hero-grid,.split,.content-grid,.footer-grid{grid-template-columns:1fr}
  .card-grid,.service-grid{grid-template-columns:1fr 1fr}
  .hero-card{min-height:460px}
  h1{max-width:none}
}
@media (max-width: 760px){
  .site-header .inner{min-height:72px}
  .nav-toggle{display:inline-flex; align-items:center; justify-content:center; width:46px; height:46px; border-radius:14px; border:1px solid var(--line); background:#fff}
  .site-nav{
    display:none; position:absolute; left:16px; right:16px; top:76px; padding:18px; border-radius:22px; background:rgba(255,255,255,.92); border:1px solid rgba(16,32,56,.08);
    box-shadow:0 20px 40px rgba(16,32,56,.12)
  }
  .site-nav.open{display:grid}
  .card-grid,.service-grid{grid-template-columns:1fr}
  .table-row,.timeline-item{grid-template-columns:1fr}
  .page-title{max-width:none}
  .hero{padding-top:46px}
}
