/* Security and responsive hardening added for strict CSP. */
img, video { max-width: 100%; height: auto; }
.text-red { color: #c00000; }
#temp-images, .u-hidden { display: none !important; }
a[data-prevent-default="true"] { cursor: pointer; }
.map-frame-wrap { height: auto; }

/* Optional content protection layer. It is a deterrent, not a cryptographic protection. */
body.os-copy-protection img,
body.os-copy-protection video{
}
body.os-copy-protection .content,
body.os-copy-protection #navbar,
body.os-copy-protection #footer,
body.os-copy-protection #bottom{
  user-select:none;
}
body.os-copy-protection input,
body.os-copy-protection textarea,
body.os-copy-protection select,
body.os-copy-protection button,
body.os-copy-protection a,
body.os-copy-protection .copy-allow,
body.os-copy-protection .copy-allow *{
  user-select:text;
}
.os-copy-notice{
  position:fixed;
  left:50%;
  bottom:24px;
  transform:translateX(-50%);
  z-index:10050;
  max-width:calc(100% - 40px);
  padding:12px 18px;
  border-radius:999px;
  background:#132247;
  color:#fff;
  font-size:14px;
  line-height:1.35;
  text-align:center;
  box-shadow:0 10px 35px rgba(0,0,0,.24);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease, bottom .18s ease;
}
.os-copy-notice.is-visible{
  opacity:1;
  bottom:34px;
}
body.contrast .os-copy-notice{
  background:#000 !important;
  color:#efff00 !important;
  border:2px solid #efff00 !important;
}

/* Security audits section - compact, consistent with the rest of the site. */
.security-audit-section{
  background:#f6f9ff;
  font-family:"Source Sans Pro", Arial, Helvetica, sans-serif;
}
.security-audit-section .section-title{
  padding-bottom:24px;
}
.security-audit-section h1,
.security-audit-section h2,
.security-audit-section h3,
.security-audit-section h4,
.security-audit-section p,
.security-audit-section li,
.security-audit-section span{
  font-family:"Source Sans Pro", Arial, Helvetica, sans-serif;
}
.security-audit-section h1{
  margin-bottom:8px;
  letter-spacing:.01em;
}
.security-audit-section h4{
  color:#172746;
  font-size:18px;
  line-height:1.35;
}
.security-audit-section .lead{
  max-width:980px;
  margin:18px auto 0 auto;
  color:#273653;
  font-size:17px;
  line-height:1.65;
}
.security-audit-section .audit-content{
  max-width:1180px;
  padding-top:0;
}
.audit-tags{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  margin:0 0 24px 0;
}
.audit-tags span{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:6px 14px;
  border:1px solid rgba(37,125,227,.24);
  border-radius:999px;
  background:#fff;
  color:#257de3;
  font-size:14px;
  font-weight:700;
  line-height:1.2;
  white-space:nowrap;
}
.audit-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
  width:100%;
}
.audit-card{
  display:flex;
  flex-direction:column;
  min-height:0;
  padding:22px 22px 20px 22px;
  background:#fff;
  border:1px solid rgba(37,125,227,.14);
  border-radius:14px;
  box-shadow:0 12px 34px rgba(21,48,94,.07);
}
.audit-card i{
  display:block;
  color:#257de3;
  font-size:26px;
  line-height:1;
  margin:0 0 14px 0;
}
.audit-card h3{
  margin:0 0 9px 0;
  color:#142647;
  font-size:21px;
  line-height:1.22;
  letter-spacing:.01em;
}
.audit-card p{
  margin:0 0 12px 0;
  color:#33405f;
  font-size:15.5px;
  line-height:1.52;
}
.audit-card ul{
  margin:0;
  padding-left:18px;
}
.audit-card li{
  margin:4px 0;
  color:#46536d;
  font-size:14.5px;
  line-height:1.42;
}
.audit-process{
  margin:28px auto 0 auto;
  padding:26px 28px;
  background:#132247;
  color:#fff;
  border-radius:16px;
  box-shadow:0 16px 44px rgba(19,34,71,.16);
}
.audit-process h3{
  margin:0 0 16px 0;
  color:#fff;
  font-size:24px;
  line-height:1.2;
}
.audit-process-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
}
.audit-process-grid div{
  padding:0 18px 0 0;
}
.audit-process-grid strong{
  display:block;
  color:#fff;
  font-size:16px;
  line-height:1.3;
  margin-bottom:6px;
}
.audit-process-grid span{
  display:block;
  color:#eef4ff;
  font-size:14.5px;
  line-height:1.45;
}
body.contrast .security-audit-section,
body.contrast .audit-card,
body.contrast .audit-process,
body.contrast .audit-tags span{
  background:#000 !important;
  color:#efff00 !important;
  border-color:#efff00 !important;
}
@media only screen and (max-width: 1080px){
  .audit-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .audit-process-grid{ grid-template-columns:1fr; }
}
@media only screen and (max-width: 680px){
  .security-audit-section .audit-content{ padding-left:20px; padding-right:20px; }
  .security-audit-section .lead{ font-size:16px; }
  .audit-tags{ justify-content:flex-start; overflow-x:auto; flex-wrap:nowrap; padding-bottom:4px; }
  .audit-grid{ grid-template-columns:1fr; gap:14px; }
  .audit-card{ padding:20px 18px; }
  .audit-card h3{ font-size:19px; }
  .audit-process{ padding:22px 20px; }
}


/* v17: dedicated security audit page and compact offer teaser. */
.security-audit-teaser h2,
.audit-intro h2{
  font-size:2.2em;
  line-height:1.12;
}
.security-audit-teaser p,
.audit-intro p{
  font-size:1em;
  line-height:1.55;
}
.security-audit-section{
  background:#f6f9ff;
  font-family:"Source Sans Pro", Arial, Helvetica, sans-serif;
}
.security-audit-section.title .section-title{
  display:block;
  padding-bottom:30px !important;
}
.security-audit-section .section-title .text{
  max-width:1000px;
  margin-left:auto;
  margin-right:auto;
}
.security-audit-section h1{
  font-size:2.8em;
  line-height:1.12;
  margin-bottom:8px;
}
.security-audit-section h4{
  color:#172746;
  font-size:18px;
  line-height:1.35;
}
.security-audit-section .lead{
  max-width:920px;
  margin:18px auto 0 auto;
  color:#273653;
  font-size:16px;
  line-height:1.62;
}
.security-audit-section .audit-content{
  max-width:1120px;
  padding-top:0;
  margin-top:0 !important;
}
.audit-tags{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  margin:0 auto 26px auto;
}
.audit-filter{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:7px 16px;
  border:1px solid rgba(37,125,227,.26);
  border-radius:999px;
  background:#fff;
  color:#257de3;
  font-family:"Source Sans Pro", Arial, Helvetica, sans-serif;
  font-size:15px;
  font-weight:700;
  line-height:1.2;
  white-space:nowrap;
  cursor:pointer;
  box-shadow:0 6px 18px rgba(21,48,94,.04);
}
.audit-filter:hover,
.audit-filter:focus,
.audit-filter.is-active{
  background:#257de3;
  color:#fff;
  outline:none;
}
.audit-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
  width:100%;
}
.audit-card{
  display:flex;
  flex-direction:column;
  min-height:0;
  padding:22px 22px 20px 22px;
  background:#fff;
  border:1px solid rgba(37,125,227,.14);
  border-radius:14px;
  box-shadow:0 12px 34px rgba(21,48,94,.07);
  transition:transform .16s ease, box-shadow .16s ease;
}
.audit-card:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 40px rgba(21,48,94,.10);
}
.audit-card.is-hidden{
  display:none;
}
.audit-card i{
  display:block;
  color:#257de3;
  font-size:24px;
  line-height:1;
  margin:0 0 12px 0;
}
.audit-card h3{
  margin:0 0 8px 0;
  color:#142647;
  font-size:20px;
  line-height:1.22;
  letter-spacing:.01em;
}
.audit-card p{
  margin:0 0 11px 0;
  color:#33405f;
  font-size:15px;
  line-height:1.48;
}
.audit-card ul{
  margin:0;
  padding-left:18px;
}
.audit-card li{
  margin:4px 0;
  color:#46536d;
  font-size:14px;
  line-height:1.38;
}
.audit-process-section{
  background:#f6f9ff;
}
.audit-process-content{
  max-width:1120px;
}
.audit-process{
  margin:0 auto;
  padding:28px 30px;
  background:#132247;
  color:#fff;
  border-radius:16px;
  box-shadow:0 16px 44px rgba(19,34,71,.16);
}
.audit-process h2,
.audit-process h3{
  margin:0 0 18px 0;
  color:#fff;
  font-size:26px;
  line-height:1.2;
}
.audit-process-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
}
.audit-process-grid div{
  padding:0 18px 0 0;
}
.audit-process-grid strong{
  display:block;
  color:#fff;
  font-size:16px;
  line-height:1.3;
  margin-bottom:6px;
}
.audit-process-grid span{
  display:block;
  color:#eef4ff;
  font-size:14.5px;
  line-height:1.45;
}
.audit-process-btns{
  margin-top:22px;
}
body.contrast .security-audit-section,
body.contrast .audit-card,
body.contrast .audit-process,
body.contrast .audit-filter,
body.contrast .audit-process-section{
  background:#000 !important;
  color:#efff00 !important;
  border-color:#efff00 !important;
}
body.contrast .audit-filter.is-active,
body.contrast .audit-filter:hover,
body.contrast .audit-filter:focus{
  background:#efff00 !important;
  color:#000 !important;
}
@media only screen and (max-width: 1080px){
  .audit-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .audit-process-grid{ grid-template-columns:1fr; }
}
@media only screen and (max-width: 680px){
  .security-audit-section .audit-content{ padding-left:20px; padding-right:20px; }
  .security-audit-section h1{ font-size:2.1em; }
  .security-audit-section .lead{ font-size:15.5px; }
  .audit-tags{ justify-content:flex-start; overflow-x:auto; flex-wrap:nowrap; padding-bottom:5px; }
  .audit-grid{ grid-template-columns:1fr; gap:14px; }
  .audit-card{ padding:20px 18px; }
  .audit-card h3{ font-size:19px; }
  .audit-process{ padding:22px 20px; }
}
