/* Cornerstone /solutions pages — content layout (shell: marketing-shell.css) */
.legal.cs-page { max-width: 1080px; margin: 0 auto; }
.cs-hero { padding: 48px 0 36px; border-bottom: 1px solid var(--line); }
.cs-tier {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--blue);
  border: 1px solid var(--line-2);
  border-radius: 6px;
  padding: 4px 10px;
  margin-bottom: 10px;
}
.cs-tier.t2 { color: var(--ink-3); }
.cs-flag {
  background: #f4f7fe;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 16px 18px;
  margin: 20px 0;
  font-size: 14px;
  color: #33405c;
  line-height: 1.65;
}
.cs-search {
  background: #fffbeb;
  border: 1px solid #f5e6b8;
  border-radius: 10px;
  padding: 18px 20px;
  margin: 20px 0;
}
.cs-search h3 { font-size: 16px; font-weight: 800; margin: 0 0 10px; color: var(--ink); }
.cs-search p { margin: 0 0 10px; font-size: 14.5px; color: #33405c; line-height: 1.65; }
.cs-search .terms { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.cs-search .term {
  font-family: var(--mono);
  font-size: 11px;
  background: #fff;
  border: 1px solid var(--line-2);
  border-radius: 16px;
  padding: 5px 10px;
  color: var(--ink-2);
}
.cs-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 36px;
  align-items: start;
  margin: 36px 0;
}
.cs-visual {
  border-radius: 14px;
  border: 1px solid var(--line);
  overflow: hidden;
  background: #f4f7fe;
  box-shadow: 0 16px 40px -28px rgba(20, 40, 90, 0.22);
}
.cs-visual img { width: 100%; height: auto; display: block; }
.cs-visual .cap { padding: 14px 16px; font-size: 13px; color: var(--ink-2); margin: 0; line-height: 1.5; }
.cs-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 22px 24px;
  background: #fff;
  margin: 18px 0;
}
.cs-card h2 { font-size: 22px; font-weight: 800; margin: 0 0 12px; color: var(--ink); }
.cs-card h3 { font-size: 17px; font-weight: 800; margin: 0 0 10px; color: var(--ink); }
.cs-card p, .cs-card li { color: #33405c; font-size: 15.5px; line-height: 1.7; }
.cs-card ul { margin: 10px 0 16px 22px; }
.cs-steps { display: grid; gap: 16px; margin: 14px 0; }
.cs-step { border-left: 3px solid var(--blue); padding: 8px 0 8px 18px; }
.cs-step strong { display: block; font-size: 15px; margin-bottom: 6px; color: var(--ink); }
.cs-step p { margin: 0; font-size: 15px; }
.cs-example {
  border: 1px dashed var(--line-2);
  border-radius: 10px;
  padding: 14px 16px;
  margin: 12px 0;
  background: #fafbff;
}
.cs-example strong { color: var(--ink); display: block; margin-bottom: 6px; font-size: 14px; }
.cs-example p { margin: 0; font-size: 14.5px; color: #33405c; }
.cs-pills { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0; }
.cs-pill {
  font-family: var(--mono);
  font-size: 11px;
  border: 1px solid var(--line-2);
  border-radius: 20px;
  padding: 6px 12px;
  color: var(--ink-2);
}
.cs-gap {
  background: linear-gradient(180deg, #f0f7f4, #fff);
  border: 1px solid #d4ebe0;
  border-radius: 12px;
  padding: 20px 22px;
  margin: 20px 0;
}
.cs-gap h3 { margin: 0 0 10px; font-size: 17px; color: var(--ink); }
.cs-gap p { margin: 0; font-size: 15px; color: #33405c; line-height: 1.65; }
.cs-related { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; margin: 24px 0; }
.cs-related a {
  display: block;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px 16px;
  text-decoration: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.cs-related a:hover { border-color: var(--blue); box-shadow: 0 8px 24px -16px rgba(44, 108, 255, 0.35); }
.cs-related .ey { font-family: var(--mono); font-size: 10px; color: var(--ink-3); display: block; margin-bottom: 4px; }
.cs-related .ti { font-weight: 700; font-size: 14px; color: var(--ink); line-height: 1.35; }
.cs-hub-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; margin: 28px 0; }
.cs-hub-grid-pairs { grid-template-columns: repeat(2, 1fr); }
@media (min-width: 1100px) {
  .cs-hub-grid-pairs { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
  .cs-hub-grid,
  .cs-hub-grid-pairs { grid-template-columns: 1fr; }
}
.cs-hub-card {
  display: block;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 18px 20px;
  text-decoration: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.cs-hub-card:hover { border-color: var(--blue); }
.cs-hub-card.t1 { border-color: #b8d4ff; box-shadow: 0 10px 28px -20px rgba(44, 108, 255, 0.35); }
.cs-hub-card .ti { display: block; font-size: 16px; font-weight: 800; color: var(--ink); margin-top: 8px; }
.cs-hub-card .le { display: block; font-size: 13px; color: var(--ink-2); margin-top: 8px; line-height: 1.5; }
.breadcrumb { font-family: var(--mono); font-size: 12px; color: var(--ink-3); margin-bottom: 10px; }
.breadcrumb a { color: var(--blue); font-weight: 600; text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }
.cs-compare { width: 100%; border-collapse: collapse; margin: 16px 0; font-size: 14px; }
.cs-compare th, .cs-compare td { border: 1px solid var(--line); padding: 12px 14px; text-align: left; vertical-align: top; }
.cs-compare th { background: #f4f7fe; font-weight: 700; color: var(--ink); }
.cs-compare td:first-child { font-weight: 600; color: var(--ink); width: 28%; }
@media (max-width: 900px) { .cs-grid { grid-template-columns: 1fr; } .cs-compare { font-size: 13px; } }
