/* Security page styles. */
.sc-hero { padding: 112px 0 96px; background: var(--gradient-deep); color: #fff; position: relative; overflow: hidden; border-bottom: 1px solid var(--color-border); }
.sc-hero::before { content: ''; position: absolute; inset: 0; background:
  radial-gradient(900px 400px at 80% 0%, rgba(97,206,112,0.16), transparent 55%),
  radial-gradient(700px 320px at 10% 100%, rgba(97,206,112,0.08), transparent 55%);
  pointer-events: none; }
.sc-hero-inner { position: relative; max-width: 960px; margin: 0 auto; display: grid; grid-template-columns: 1.1fr 1fr; gap: 72px; align-items: center; }
.sc-hero .kicker { color: var(--green-text); letter-spacing: 0.1em; }
.sc-hero h1 { font-family: var(--font-display); font-weight: 600; font-size: 56px; line-height: 1.05; letter-spacing: -0.025em; color: #fff; margin: 20px 0 18px; }
.sc-hero p.lead { font-size: 18px; color: rgba(255,255,255,0.78); line-height: 1.55; margin-bottom: 16px; }
.sc-hero p.supp { font-size: 14.5px; color: rgba(255,255,255,0.55); line-height: 1.55; }
.sc-shield { aspect-ratio: 1/1; border-radius: 24px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); padding: 36px; position: relative; overflow: hidden; display: flex; flex-direction: column; justify-content: space-between; }
.sc-shield::before { content: ''; position: absolute; inset: 0; background: radial-gradient(400px 300px at 50% 30%, rgba(97,206,112,0.18), transparent 60%); pointer-events: none; }
.sc-shield .big { position: relative; width: 100px; height: 100px; border-radius: 24px; background: linear-gradient(135deg, #7FD48E, #1E7A2B); display: flex; align-items: center; justify-content: center; box-shadow: 0 16px 40px rgba(30,122,43,0.4); }
.sc-shield .big svg { width: 52px; height: 52px; stroke: #fff; fill: none; stroke-width: 1.8; }
.sc-shield-mini { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.sc-shield-mini > div { padding: 12px 14px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); border-radius: 10px; display: flex; flex-direction: column; gap: 4px; }
.sc-shield-mini strong { font-family: var(--font-display); font-weight: 600; font-size: 13px; color: #fff; }
.sc-shield-mini span { font-size: 11.5px; color: rgba(255,255,255,0.6); letter-spacing: 0.02em; }

.sc-sec { padding: 104px 0; }
.sc-sec.tinted { background: var(--off-white-60); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
/* Consecutive tinted sections collapse into a single continuous grey
 * panel — drop the inner border so they read as one unified block
 * (e.g. Certifications + Trust Center) and halve the inner padding
 * so the two content groups sit closer together than the standard
 * inter-section gap, while still having visible breathing room. */
.sc-sec.tinted + .sc-sec.tinted { border-top: 0; padding-top: 52px; }
.sc-sec.tinted:has(+ .sc-sec.tinted) { border-bottom: 0; padding-bottom: 52px; }
.sc-head { max-width: 720px; margin-bottom: 44px; }
.sc-head.center { text-align: center; margin-left: auto; margin-right: auto; }
.sc-head .kicker.green { color: var(--green-text); }
.sc-head h2 { font-family: var(--font-display); font-weight: 600; font-size: 40px; letter-spacing: -0.02em; line-height: 1.1; margin-top: 16px; margin-bottom: 14px; }
.sc-head p.lead { font-size: 16.5px; color: var(--color-text-muted); line-height: 1.6; }

.sc-pillars { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.sc-pillar { padding: 32px 28px; background: #fff; border: 1px solid var(--color-border); border-radius: 16px; display: flex; flex-direction: column; gap: 12px; min-height: 220px; transition: all var(--motion-base) var(--ease-standard); position: relative; overflow: hidden; }
.sc-pillar:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--green-100); }
.sc-pillar .ic { width: 44px; height: 44px; border-radius: 12px; background: var(--green-20); color: #1E7A2B; display: flex; align-items: center; justify-content: center; }
.sc-pillar .ic svg { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 2; }
.sc-pillar h4 { font-family: var(--font-display); font-weight: 600; font-size: 18px; line-height: 1.25; letter-spacing: -0.005em; margin-top: 4px; }
.sc-pillar p { font-size: 14px; color: var(--color-text-muted); line-height: 1.5; }

.sc-two { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start; }
.sc-two h2 { font-family: var(--font-display); font-weight: 600; font-size: 36px; letter-spacing: -0.02em; line-height: 1.12; margin-top: 16px; }
.sc-two p.supp { font-size: 15.5px; color: var(--color-text-muted); line-height: 1.6; margin-top: 18px; max-width: 460px; }
.sc-list { display: flex; flex-direction: column; gap: 12px; }
.sc-list li { list-style: none; padding: 16px 18px; background: #fff; border: 1px solid var(--color-border-subtle); border-radius: 12px; display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: start; font-size: 15px; line-height: 1.5; color: var(--color-text); }
.sc-sec.tinted .sc-list li { background: #fff; }
.sc-sec:not(.tinted) .sc-list li { background: var(--off-white-40); }
.sc-list li .tk { width: 22px; height: 22px; border-radius: 6px; background: var(--green-20); color: #1E7A2B; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.sc-list li .tk svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2.5; }

/* Trust Center section: CTA sits under the paragraph in the LEFT column
 * (alongside the bullet list on the right). 32px of breathing room above
 * so it reads as a separate beat from the body copy. Left-aligned, not
 * full-width. */
.sc-trust-center .sc-trust-cta { margin-top: 32px; }
.sc-trust-center .sc-trust-cta .btn { display: inline-flex; align-items: center; gap: 10px; }
.sc-trust-center .sc-trust-cta .btn .arr { width: 16px; height: 16px; flex-shrink: 0; }

.sc-audit { padding: 104px 0; }
.sc-audit-wrap { background: var(--gradient-deep); color: #fff; border-radius: 24px; padding: 72px 64px; position: relative; overflow: hidden; }
.sc-audit-wrap::before { content: ''; position: absolute; inset: 0; background:
  radial-gradient(800px 350px at 85% 0%, rgba(97,206,112,0.16), transparent 55%);
  pointer-events: none; }
.sc-audit-grid { position: relative; display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; }
.sc-audit-grid .kicker { color: var(--green-text); }
.sc-audit-grid h2 { font-family: var(--font-display); font-weight: 600; font-size: 40px; line-height: 1.1; letter-spacing: -0.02em; color: #fff; margin-top: 16px; margin-bottom: 18px; }
.sc-audit-grid p.lead { font-size: 16.5px; color: rgba(255,255,255,0.78); line-height: 1.6; margin-bottom: 24px; max-width: 480px; }
.sc-audit-list { display: flex; flex-direction: column; gap: 10px; }
.sc-audit-list li { list-style: none; padding: 14px 18px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); border-radius: 10px; display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: start; font-size: 14.5px; color: rgba(255,255,255,0.82); line-height: 1.5; }
.sc-audit-list li .tk { width: 22px; height: 22px; border-radius: 6px; background: rgba(127,212,142,0.16); color: #7FD48E; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.sc-audit-list li .tk svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2.5; }

.audit-log { background: rgba(0,0,0,0.28); border: 1px solid rgba(255,255,255,0.1); border-radius: 14px; overflow: hidden; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 12.5px; }
.audit-log .top { display: flex; align-items: center; gap: 8px; padding: 12px 16px; border-bottom: 1px solid rgba(255,255,255,0.08); color: rgba(255,255,255,0.65); font-size: 11.5px; letter-spacing: 0.08em; text-transform: uppercase; font-family: var(--font-display); font-weight: 600; }
.audit-log .top .dot { width: 8px; height: 8px; border-radius: 50%; background: #7FD48E; box-shadow: 0 0 8px rgba(127,212,142,0.6); }
.audit-log .row { padding: 12px 16px; border-bottom: 1px solid rgba(255,255,255,0.06); display: grid; grid-template-columns: 72px 1fr; gap: 14px; align-items: start; }
.audit-log .row:last-child { border-bottom: none; }
.audit-log .ts { color: rgba(127,212,142,0.8); }
.audit-log .ev strong { color: #fff; font-weight: 600; }
.audit-log .ev .meta { color: rgba(255,255,255,0.5); display: block; margin-top: 2px; font-size: 11.5px; }

.cert-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.cert-card { padding: 32px 28px; background: #fff; border: 1px solid var(--color-border); border-radius: 16px; display: flex; flex-direction: column; gap: 14px; min-height: 240px; transition: all var(--motion-base) var(--ease-standard); position: relative; overflow: hidden; }
.cert-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--green-100); }
.cert-card .seal { width: 72px; height: 72px; border-radius: 50%; background: var(--green-20); color: #1E7A2B; display: flex; align-items: center; justify-content: center; position: relative; flex-shrink: 0; }
.cert-card .seal::before { content: ''; position: absolute; inset: 4px; border-radius: 50%; border: 1.5px dashed rgba(30,122,43,0.28); }
.cert-card .seal svg { width: 32px; height: 32px; stroke: currentColor; fill: none; stroke-width: 1.75; position: relative; z-index: 1; }
.cert-card .name { font-family: var(--font-display); font-weight: 700; font-size: 15px; letter-spacing: -0.005em; line-height: 1.25; }
.cert-card .region { display: inline-flex; align-items: center; gap: 6px; padding: 2px 8px; border-radius: 999px; background: var(--off-white-60); color: var(--color-text-muted); font-family: var(--font-display); font-size: 11px; font-weight: 700; letter-spacing: 0.06em; align-self: flex-start; border: 1px solid var(--color-border-subtle); }
.cert-card p { font-size: 13.5px; color: var(--color-text-muted); line-height: 1.5; margin-top: 2px; }
.cert-note { margin-top: 28px; font-size: 14.5px; color: var(--color-text-muted); line-height: 1.6; max-width: 840px; }

.std-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.std-card { padding: 24px 22px; background: #fff; border: 1px solid var(--color-border); border-radius: 14px; display: flex; flex-direction: column; gap: 10px; min-height: 170px; transition: all var(--motion-base) var(--ease-standard); }
.std-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--green-100); }
.std-card .badge { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; background: var(--green-20); color: #1E7A2B; font-family: var(--font-display); font-size: 11px; font-weight: 700; letter-spacing: 0.06em; align-self: flex-start; }
.std-card h4 { font-family: var(--font-display); font-weight: 600; font-size: 16px; line-height: 1.25; letter-spacing: -0.005em; }
.std-card p { font-size: 13.5px; color: var(--color-text-muted); line-height: 1.5; }
.sc-note { margin-top: 24px; padding: 16px 20px; background: var(--off-white-60); border: 1px solid var(--color-border-subtle); border-left: 3px solid var(--green-100); border-radius: 10px; font-size: 14px; color: var(--color-text-muted); line-height: 1.55; max-width: 760px; }

.rel-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.rel-card { padding: 28px 26px; background: #fff; border: 1px solid var(--color-border); border-radius: 16px; display: grid; grid-template-columns: auto 1fr; gap: 18px; align-items: start; }
.sc-sec.tinted .rel-card { background: #fff; }
.rel-card .ic { width: 42px; height: 42px; border-radius: 12px; background: var(--green-20); color: #1E7A2B; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rel-card .ic svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 2; }
.rel-card h4 { font-family: var(--font-display); font-weight: 600; font-size: 16.5px; line-height: 1.3; letter-spacing: -0.005em; margin-bottom: 6px; }
.rel-card p { font-size: 14px; color: var(--color-text-muted); line-height: 1.55; }

.trust-logos { display: grid; grid-template-columns: repeat(6, 1fr); gap: 0; border: 1px solid var(--color-border); border-radius: 16px; overflow: hidden; background: #fff; }
.trust-logos .tile { aspect-ratio: 5/2; display: flex; align-items: center; justify-content: center; border-right: 1px solid var(--color-border-subtle); border-bottom: 1px solid var(--color-border-subtle); padding: 12px 18px; }
.trust-logos .tile:nth-child(6n) { border-right: none; }
.trust-logos .tile:nth-last-child(-n+6) { border-bottom: none; }
.trust-logos .tile span { font-family: var(--font-display); font-weight: 600; font-size: 16px; color: var(--color-text-muted); letter-spacing: -0.005em; opacity: 0.85; white-space: nowrap; }
.trust-logos .tile .customer-logo { max-height: 40px; max-width: 80%; }
.trust-quote { margin-top: 32px; padding: 32px 40px; background: #fff; border: 1px solid var(--color-border); border-radius: 16px; display: grid; grid-template-columns: 1fr auto; gap: 36px; align-items: center; }
.trust-quote q { font-family: var(--font-display); font-weight: 500; font-size: 20px; line-height: 1.45; color: var(--color-text); letter-spacing: -0.005em; quotes: '"' '"'; }
.trust-quote .who { display: flex; align-items: center; gap: 14px; border-left: 1px solid var(--color-border-subtle); padding-left: 24px; min-width: 220px; }
.trust-quote .who .av { width: 40px; height: 40px; border-radius: 50%; background: linear-gradient(135deg, #1E7A2B, #0E3B2E); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 13px; flex-shrink: 0; }
.trust-quote .who strong { display: block; font-family: var(--font-display); font-weight: 600; font-size: 14px; }
.trust-quote .who span { font-size: 12.5px; color: var(--color-text-subtle); }

.gov-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.gov-card { padding: 32px 28px; background: #fff; border: 1px solid var(--color-border); border-radius: 16px; display: flex; flex-direction: column; gap: 12px; transition: all var(--motion-base) var(--ease-standard); }
.gov-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--green-100); }
.gov-card .ic { width: 40px; height: 40px; border-radius: 10px; background: var(--green-20); color: #1E7A2B; display: flex; align-items: center; justify-content: center; }
.gov-card .ic svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 2; }
.gov-card h4 { font-family: var(--font-display); font-weight: 600; font-size: 18px; line-height: 1.25; letter-spacing: -0.005em; }
.gov-card p { font-size: 14px; color: var(--color-text-muted); line-height: 1.55; }

.sc-final { padding: 104px 0; background: #fff; border-top: 1px solid var(--color-border); }
.sc-final .inner { text-align: center; max-width: 720px; margin: 0 auto; }
.sc-final h2 { font-family: var(--font-display); font-weight: 600; font-size: 44px; line-height: 1.08; letter-spacing: -0.025em; margin: 20px 0 18px; }
.sc-final p { font-size: 17px; color: var(--color-text-muted); line-height: 1.55; margin-bottom: 32px; }
.sc-final .ctas { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

@media (max-width: 1020px) {
  .sc-hero-inner { grid-template-columns: 1fr; gap: 40px; }
  .sc-hero h1 { font-size: 44px; }
  .sc-pillars { grid-template-columns: repeat(2, 1fr); }
  .sc-two, .sc-audit-grid { grid-template-columns: 1fr; gap: 40px; }
  .std-grid { grid-template-columns: repeat(2, 1fr); }
  /* Certifications grid: 4 cards squashed into narrow columns on tablet —
   * drop to 2 columns so the seal + name + region + body copy can breathe. */
  .cert-grid { grid-template-columns: repeat(2, 1fr); }
  .rel-grid, .gov-grid { grid-template-columns: 1fr; }
  .trust-logos { grid-template-columns: repeat(3, 1fr); }
  .trust-logos .tile { border-right: 1px solid var(--color-border-subtle); }
  .trust-logos .tile:nth-child(6n) { border-right: 1px solid var(--color-border-subtle); }
  .trust-logos .tile:nth-child(3n) { border-right: none; }
  .trust-logos .tile:nth-last-child(-n+6) { border-bottom: 1px solid var(--color-border-subtle); }
  .trust-logos .tile:nth-last-child(-n+3) { border-bottom: none; }
  .trust-quote { grid-template-columns: 1fr; gap: 20px; }
  .trust-quote .who { border-left: none; border-top: 1px solid var(--color-border-subtle); padding-left: 0; padding-top: 20px; }
  .sc-audit-wrap { padding: 48px 32px; }
}
@media (max-width: 640px) {
  .sc-pillars, .std-grid, .cert-grid { grid-template-columns: 1fr; }
  .sc-hero h1, .sc-head h2, .sc-audit-grid h2, .sc-final h2 { font-size: 30px; }
  /* Tighter card chrome at phone width so the cert seal + body fit cleanly. */
  .cert-card { padding: 24px 22px; min-height: 0; }
}
