@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@500;600&family=Space+Grotesk:wght@400;500;600;700&display=swap");

:root{
  --bg:#f2f7ff;
  --panel:#ffffff;
  --card:#f7fbff;
  --text:#0c1a32;
  --muted:#4e658a;
  --brand:#4ea1ff;
  --brand2:#77d3ff;
  --border:rgba(12,38,74,.14);
  --shadow:0 18px 40px rgba(12,51,110,.12);
  --shadow-soft:0 10px 22px rgba(12,51,110,.10);
  --radius:20px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Space Grotesk", "Segoe UI", sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 520px at 10% 8%, rgba(78,161,255,.20), transparent 65%),
    radial-gradient(780px 480px at 85% 2%, rgba(119,211,255,.18), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #f3f8ff 38%, #eef6ff 100%);
  line-height:1.45;
}

a{color:inherit; text-decoration:none}
a:not(.btn):hover{color:#0c3c8f}
section[id]{scroll-margin-top:78px}

.wrap{
  width:min(1120px, calc(100% - 32px));
  margin:0 auto;
}

header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(10px);
  background:rgba(248,252,255,.85);
  border-bottom:1px solid var(--border);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 0;
  gap:14px;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  letter-spacing:.2px;
  line-height:1;
}

.brand span{
  font-size:clamp(1.5rem, 2.2vw, 2rem);
  font-weight:700;
  letter-spacing:.3px;
  color:#0b2f60;
}

.logo{
  height:50px;
  width:auto;
  margin-right:10px;
}

.navlinks{
  display:flex;
  align-items:center;
  gap:18px;
}

.navlinks a{
  color:var(--muted);
  padding:10px 10px;
  border-radius:12px;
  font-weight:500;
}

.navlinks a:hover{
  color:var(--text);
  background:rgba(78,161,255,.12);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:10px 13px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  font-weight:700;
  cursor:pointer;
  transition:transform .15s ease, background .15s ease;
}

.btn:hover{
  transform:translateY(-1px);
  background:#f1f7ff;
}

.btn:focus-visible{
  outline:3px solid rgba(78,161,255,.45);
  outline-offset:2px;
}

.btn.primary{
  border:none;
  background:linear-gradient(135deg, rgba(78,161,255,1), rgba(119,211,255,1));
  color:#041427;
  box-shadow:0 16px 30px rgba(78,161,255,.25);
}

.btn.primary:hover{
  background:linear-gradient(135deg, rgba(66,149,244,1), rgba(108,203,255,1));
}

main section{padding:22px 0}

.hero{padding:30px 0 10px}

.heroGrid{
  display:grid;
  grid-template-columns:1.3fr .7fr;
  gap:16px;
  align-items:stretch;
}

.pill{
  display:inline-flex;
  gap:10px;
  align-items:center;
  padding:10px 12px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.75);
  border-radius:999px;
  color:var(--muted);
  font-weight:600;
  font-family:"IBM Plex Mono", "SFMono-Regular", monospace;
  letter-spacing:.2px;
}

.dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(78,161,255,1), rgba(119,211,255,1));
}

h1{
  margin:12px 0 10px;
  font-size:clamp(32px, 3.6vw, 48px);
  line-height:1.05;
  letter-spacing:-.7px;
}

h2{
  margin:0 0 10px;
  font-size:clamp(24px, 2.4vw, 34px);
  letter-spacing:-.3px;
}

h3{margin:2px 0 8px}

.sub{
  margin:0 0 10px;
  color:var(--muted);
  font-size:.98rem;
  max-width:75ch;
}

.cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}

.panel{
  border:1px solid var(--border);
  background:#fff;
  border-radius:var(--radius);
  padding:14px;
  box-shadow:var(--shadow-soft);
}

.panel ul{
  margin:10px 0 0;
  padding-left:18px;
  color:var(--muted);
}

.panel li{margin:8px 0}
.panel strong{color:var(--text)}

.kpis{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:10px;
}

.kpi{
  border:1px solid var(--border);
  background:#fff;
  border-radius:16px;
  padding:10px;
}

.kpi b{
  display:block;
  font-weight:900;
  font-size:1.15rem;
  font-family:"IBM Plex Mono", "SFMono-Regular", monospace;
}

.kpi span{
  color:var(--muted);
  font-weight:600;
  font-size:.92rem;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(78,161,255,.12);
  color:var(--muted);
  font-weight:700;
  font-size:.88rem;
  font-family:"IBM Plex Mono", "SFMono-Regular", monospace;
  letter-spacing:.2px;
}

.badge.ai{background:rgba(78,161,255,.16)}
.badge.fx{background:rgba(119,211,255,.16)}
.badge.ok{background:rgba(46,181,142,.16)}

.grid3{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}

.card{
  border:1px solid var(--border);
  background:var(--card);
  border-radius:var(--radius);
  padding:12px;
  box-shadow:var(--shadow-soft);
}

.card h3{margin:2px 0 8px}

.card p{
  margin:0;
  color:var(--muted);
}

.card ul{
  margin:10px 0 0;
  padding-left:18px;
  color:var(--muted);
}

.card li{margin:8px 0}

.link-card{
  display:flex;
  flex-direction:column;
  gap:7px;
  min-height:210px;
  text-decoration:none;
  overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.link-card:hover{
  transform:translateY(-3px);
  border-color:rgba(78,161,255,.45);
  box-shadow:0 18px 32px rgba(12,51,110,.18);
  color:var(--text);
}

.link-card:focus-visible{
  outline:3px solid rgba(78,161,255,.45);
  outline-offset:2px;
}

.card-thumb{
  width:100%;
  border-radius:14px;
  aspect-ratio:16 / 9;
  object-fit:cover;
  display:block;
  border:1px solid rgba(12,38,74,.12);
}

.card-link{
  margin-top:auto;
  font-weight:700;
  color:#0c3c8f;
  font-size:.95rem;
}

.detail-hero .panel{
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:4px;
}

.detail-hero h1{
  font-size:clamp(30px, 3.2vw, 44px);
}

.detail-media{
  margin:0;
  border:1px solid var(--border);
  background:linear-gradient(180deg, #ffffff 0%, #f6faff 100%);
  border-radius:calc(var(--radius) + 4px);
  padding:8px;
  box-shadow:var(--shadow);
}

.detail-media img{
  width:100%;
  display:block;
  border-radius:calc(var(--radius) - 6px);
  aspect-ratio:16 / 9;
  object-fit:cover;
  background:#e8f2ff;
}

.detail-media figcaption{
  margin:8px 2px 2px;
  color:var(--muted);
  font-size:.9rem;
}

.detail-list{
  margin:0;
  padding-left:18px;
  color:var(--muted);
}

.detail-list li{margin:8px 0}

.two{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  align-items:stretch;
}

.smallgrid{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
}

.tile{
  border:1px solid var(--border);
  background:linear-gradient(180deg, #ffffff 0%, #f6faff 100%);
  border-radius:16px;
  padding:12px 14px;
  box-shadow:0 12px 24px rgba(12,51,110,.1);
}

.tile b{
  display:block;
  color:#0c3c8f;
  margin-bottom:6px;
}

.tile span{
  margin:0;
  color:var(--muted);
  font-size:.95rem;
}

.pricing{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}

.plan{
  border:1px solid var(--border);
  background:var(--card);
  border-radius:var(--radius);
  padding:12px;
  box-shadow:0 12px 30px rgba(12,51,110,.12);
  display:flex;
  flex-direction:column;
  height:100%;
}

.plan h3{
  min-height:52px;
}

.plan.pop{
  outline:2px solid rgba(78,161,255,.55);
  box-shadow:0 18px 50px rgba(78,161,255,.12);
}

.amount{
  font-size:2.1rem;
  font-weight:900;
  letter-spacing:-.5px;
  margin:8px 0 10px;
}

.per{
  font-size:.95rem;
  font-weight:700;
  color:var(--muted);
  min-height:22px;
}

.plan ul{
  flex:1;
  margin-bottom:0;
}

.plan > div:last-child{
  margin-top:auto !important;
}

details{
  border:1px solid var(--border);
  background:#fff;
  border-radius:14px;
  padding:10px 12px;
}

details+details{margin-top:10px}
summary{cursor:pointer; font-weight:700}
details p{margin:10px 0 0; color:var(--muted)}

form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:8px;
}

label{
  display:block;
  font-weight:700;
  font-size:.94rem;
}

input,textarea{
  width:100%;
  padding:10px 11px;
  margin-top:5px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  outline:none;
  font-family:inherit;
}

input:focus,textarea:focus{border-color:rgba(78,161,255,.65)}

textarea{
  min-height:104px;
  resize:vertical;
  grid-column:1/-1;
}

.full{grid-column:1/-1}

footer{
  padding:26px 0 34px;
  border-top:1px solid var(--border);
  background:#e4ebf3;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr .9fr;
  gap:24px;
  align-items:flex-start;
}

.footer-title{
  margin:0 0 10px;
  color:#0d2748;
  font-size:1.05rem;
}

.footer-text{
  margin:0;
  color:#4a6388;
  font-size:1.02rem;
  max-width:56ch;
}

.footer-divider{
  height:1px;
  background:rgba(13,39,72,.16);
  margin:16px 0 14px;
}

.footer-copy{
  margin:0;
  color:#4a6388;
  font-size:.98rem;
}

.footer-links{
  display:grid;
  gap:5px;
}

.footer-links a{
  color:#334f74;
  font-size:1.02rem;
}

.footer-links a:hover{
  color:#0d2e56;
}

.footer-contact{
  display:grid;
  gap:5px;
  color:#334f74;
  font-size:1.02rem;
}

@media (max-width: 940px){
  .heroGrid{grid-template-columns:1fr}
  .grid3{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .two{grid-template-columns:1fr}
  .pricing{grid-template-columns:1fr}
  .navlinks{display:none}
  .smallgrid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}

@media (max-width: 560px){
  .brand span{font-size:1.3rem}
  .grid3{grid-template-columns:1fr}
  .kpis{grid-template-columns:1fr}
  .smallgrid{grid-template-columns:1fr}
  form{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
