/* ==========================================================
   BDRShield M365 Landing Page — bdrshield-m365-landing.css
   Replicates all styles from bdrshield-m365-landing-input.html
   ========================================================== */

/* ── Buttons ──────────────────────────────────────────────── */
.m365-btn-dark {
  display: inline-block;
  background: #515151;
  color: #fff;
  border: 2px solid #515151;
  padding: 14px 32px;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  transition: background 0.2s, border-color 0.2s;
  text-decoration: none;
  line-height: 1;
}
.m365-btn-dark:hover,
.m365-btn-dark:focus {
  background: #202020;
  border-color: #202020;
  color: #fff;
  text-decoration: none;
}

.m365-btn-white {
  display: inline-block;
  background: #fff;
  color: #000;
  border: 2px solid #d7d7d7;
  padding: 14px 32px;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  transition: background 0.2s, border-color 0.2s;
  text-decoration: none;
  line-height: 1;
}
.m365-btn-white:hover,
.m365-btn-white:focus {
  background: #d7d7d7;
  border-color: #b0b0b0;
  color: #000;
  text-decoration: none;
}

/* ── Section labels & eyebrow ────────────────────────────── */
.m365-section-label {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #999;
  margin-bottom: 16px;
}

/* ── Hero Section ────────────────────────────────────────── */
.m365-hero-wrap {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 64px;
  align-items: start;
}

/* Hero eyebrow */
.m365-hero-eyebrow {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #666;
  border: 1px solid #e5e5e5;
  padding: 5px 12px;
  margin-bottom: 24px;
}

/* Hero H1 */
.m365-hero-wrap h1 {
  font-size: 48px !important;
  font-weight: 900 !important;
  line-height: 1.05 !important;
  letter-spacing: -1.5px !important;
  margin-bottom: 20px !important;
  color: #000 !important;
}
.m365-hero-wrap h1 em {
  font-style: normal;
  color: #666;
}

/* Hero sub-paragraph */
.m365-hero-sub {
  font-size: 16px;
  line-height: 1.7;
  color: #666;
  margin-bottom: 32px !important;
  max-width: 500px;
}

/* Hero CTA button row */
.m365-hero-btns {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

/* Hero trust chips */
.m365-hero-trust {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  margin-top: 20px;
  font-size: 13px;
  color: #666;
}

/* Hero Form Card */
.m365-hero-form-card {
  background: #f9f9f9;
  color: #000;
  padding: 32px 28px;
  border: 1px solid #e5e5e5;
  flex-shrink: 0;
}
.m365-hero-form-card h3 {
  font-size: 18px !important;
  font-weight: 900 !important;
  margin-bottom: 6px !important;
  letter-spacing: -0.3px;
}
.m365-hero-form-card .m365-form-sub {
  font-size: 12px;
  color: #777;
  margin-bottom: 20px !important;
  line-height: 1.4;
}
.m365-form-privacy {
  font-size: 10px;
  color: #999;
  margin-top: 10px !important;
  text-align: center;
  line-height: 1.4;
}

/* ── Stats Bar ────────────────────────────────────────────── */
.m365-stats-bar {
  background: #f9f9f9;
  border-top: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
  padding: 32px 24px;
}
.m365-stats-inner {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  gap: 24px;
  text-align: center;
}
.m365-stat-item {
  flex: 1;
  min-width: 140px;
}
.m365-stat-num {
  font-size: 34px !important;
  font-weight: 900 !important;
  letter-spacing: -1px;
  color: #000;
  display: block;
  margin-bottom: 2px !important;
}
.m365-stat-label {
  font-size: 12px;
  color: #666;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-top: 2px;
  display: block;
}

/* ── Audience Separator ──────────────────────────────────── */
.m365-audience-sep {
  background: #f9f9f9;
  color: #000;
  text-align: center;
  padding: 28px 24px;
  border-top: 3px solid #000;
  border-bottom: 1px solid #e5e5e5;
}
.m365-audience-sep .m365-sep-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #999;
  display: block;
  margin-bottom: 6px;
}
.m365-audience-sep h3 {
  font-size: 26px !important;
  font-weight: 900 !important;
  margin-top: 8px !important;
  margin-bottom: 0 !important;
  letter-spacing: -0.5px;
  color: #000;
}
.m365-audience-sep .m365-sep-sub {
  font-size: 14px;
  color: #666;
  margin-top: 6px !important;
  margin-bottom: 0 !important;
}

/* ── MSP Hero Two-Column ─────────────────────────────────── */
.m365-msp-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
  margin-bottom: 64px;
}
.m365-msp-hero-text h2 {
  font-size: 36px !important;
  font-weight: 900 !important;
  letter-spacing: -1px;
  line-height: 1.1 !important;
  margin-bottom: 20px !important;
}
.m365-msp-hero-text p {
  font-size: 16px;
  color: #666;
  line-height: 1.7;
  margin-bottom: 24px !important;
}

/* ── Pain Points ─────────────────────────────────────────── */
.m365-pain-points {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.m365-pain-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 16px;
  border: 1px solid #e5e5e5;
  background: #f9f9f9;
}
.m365-pain-icon {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  background: #000;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 900;
}
.m365-pain-text strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 2px;
}
.m365-pain-text span {
  font-size: 13px;
  color: #666;
  line-height: 1.5;
}

/* ── Features Grid (MSP) ─────────────────────────────────── */
.m365-features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: #e5e5e5;
  border: 1px solid #e5e5e5;
  margin-bottom: 48px;
}
.m365-feature-cell {
  background: #fff;
  padding: 28px 24px;
}
.m365-feature-cell .m365-f-icon {
  width: 36px;
  height: 36px;
  background: #000;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}
.m365-feature-cell .m365-f-icon svg {
  fill: #fff;
  width: 18px;
  height: 18px;
  stroke: #fff;
  stroke-width: 1.5;
  fill: none;
}
.m365-feature-cell h4 {
  font-size: 15px !important;
  font-weight: 700 !important;
  margin-bottom: 6px !important;
}
.m365-feature-cell p {
  font-size: 13px;
  color: #666;
  line-height: 1.55;
  margin: 0 !important;
}

/* ── MSP Pricing Box ─────────────────────────────────────── */
.m365-msp-pricing-box {
  background: #f9f9f9;
  color: #000;
  border: 1px solid #e5e5e5;
  border-left: 4px solid #000;
  padding: 40px 48px;
  display: flex;
  gap: 48px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: 32px;
}
.m365-price-left {
  flex: 1;
  min-width: 240px;
}
.m365-price-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #666;
  margin-bottom: 12px;
  display: block;
}
.m365-price-num {
  font-size: 56px !important;
  font-weight: 900 !important;
  letter-spacing: -2px;
  line-height: 1 !important;
  color: #000;
  margin: 0 !important;
}
.m365-price-num span {
  font-size: 24px !important;
  font-weight: 400 !important;
  opacity: 0.5;
  letter-spacing: 0;
}
.m365-price-per {
  font-size: 14px;
  color: #666;
  margin-top: 6px;
  display: block;
}
.m365-price-right {
  flex: 2;
  min-width: 280px;
}
.m365-price-right ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.m365-price-right ul li {
  font-size: 14px;
  color: #333;
  display: flex;
  align-items: center;
  gap: 10px;
}
.m365-price-right ul li::before {
  content: '✓';
  font-weight: 900;
  color: #000;
  flex-shrink: 0;
}
.m365-price-note {
  font-size: 11px;
  color: #aaa;
  margin-top: 16px !important;
  line-height: 1.5;
}

/* ── Inline Quote Bar ────────────────────────────────────── */
.m365-inline-quote-bar {
  background: #f9f9f9;
  border: 1px solid #e5e5e5;
  padding: 20px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.m365-inline-quote-bar p {
  font-size: 14px;
  font-weight: 700;
  margin: 0 0 4px !important;
}
.m365-inline-quote-bar span {
  font-size: 13px;
  color: #666;
}

/* ── IT Section Two-Column ───────────────────────────────── */
.m365-it-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
  margin-bottom: 56px;
}
.m365-it-hero h2 {
  font-size: 36px !important;
  font-weight: 900 !important;
  letter-spacing: -1px;
  line-height: 1.1 !important;
  margin-bottom: 20px !important;
}
.m365-it-hero p {
  font-size: 16px;
  color: #666;
  line-height: 1.7;
  margin-bottom: 24px !important;
}

/* ── Shared Responsibility Callout ───────────────────────── */
.m365-shared-resp {
  background: #fff;
  border: 1px solid #e5e5e5;
  border-left: 4px solid #000;
  padding: 20px 24px;
  margin-top: 24px;
}
.m365-shared-resp .m365-sr-title {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px !important;
  display: block;
}
.m365-shared-resp p {
  font-size: 13px;
  color: #666;
  line-height: 1.55;
  margin: 0 !important;
}

/* ── IT Use Case Grid ────────────────────────────────────── */
.m365-usecase-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: #e5e5e5;
  border: 1px solid #e5e5e5;
}
.m365-usecase-cell {
  background: #fff;
  padding: 28px 24px;
}
.m365-usecase-cell .m365-uc-num {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #bbb;
  margin-bottom: 10px;
  display: block;
}
.m365-usecase-cell h4 {
  font-size: 16px !important;
  font-weight: 900 !important;
  margin-bottom: 8px !important;
  line-height: 1.2;
}
.m365-usecase-cell p {
  font-size: 13px;
  color: #666;
  line-height: 1.55;
  margin: 0 !important;
}

/* ── Coverage Table ──────────────────────────────────────── */
.m365-coverage-table-wrap {
  margin-bottom: 48px;
  overflow-x: auto;
}
.m365-coverage-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #e5e5e5;
  font-size: 13px;
}
.m365-coverage-table th {
  background: #000;
  color: #fff;
  padding: 12px 16px;
  text-align: left;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.m365-coverage-table td {
  padding: 12px 16px;
  border-bottom: 1px solid #e5e5e5;
  vertical-align: middle;
}
.m365-coverage-table tr:last-child td {
  border-bottom: none;
}
.m365-coverage-table tr:nth-child(even) td {
  background: #f9f9f9;
}
.m365-coverage-table tr:hover td {
  background-image: none !important;
}

/* ── Badge Styles ────────────────────────────────────────── */
.m365-badge-yes {
  display: inline-block;
  background: #dcfce7;
  color: #1a7a4a;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 8px;
  letter-spacing: 0.5px;
}
.m365-badge-no {
  display: inline-block;
  background: #fee2e2;
  color: #b91c1c;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 8px;
  letter-spacing: 0.5px;
}
.m365-savings-tag {
  display: inline-block;
  background: #dcfce7;
  color: #1a7a4a;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  letter-spacing: 0.5px;
}
.m365-competitor-pill {
  display: inline-block;
  background: #fee2e2;
  color: #b91c1c;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  letter-spacing: 0.3px;
}

/* ── TCO Comparison Table ────────────────────────────────── */
.m365-tco-wrap {
  overflow-x: auto;
  margin-bottom: 0;
}
.m365-tco-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #e5e5e5;
  font-size: 13px;
}
.m365-tco-table th {
  background: #000;
  color: #fff;
  padding: 12px 16px;
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.m365-tco-table th:first-child {
  text-align: left;
}
.m365-tco-table td {
  padding: 13px 16px;
  border-bottom: 1px solid #e5e5e5;
  text-align: center;
  vertical-align: middle;
}
.m365-tco-table td:first-child {
  text-align: left;
  font-weight: 700;
}
.m365-tco-table tr.m365-bdr-row td {
  background: #000;
  color: #fff;
  font-weight: 700;
}
.m365-tco-table tr.m365-bdr-row td:first-child {
  color: #fff;
}
.m365-tco-table tr:not(.m365-bdr-row):nth-child(even) td {
  background: #f9f9f9;
}
.m365-tco-table tr:hover td {
  background-image: none !important;
}
.m365-tco-disclaimer {
  font-size: 10px;
  color: #aaa;
  margin-top: 10px !important;
  line-height: 1.5;
  padding: 10px 0;
}

/* ── Workloads Grid ──────────────────────────────────────── */
.m365-workloads-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: #e5e5e5;
  border: 1px solid #e5e5e5;
  margin-top: 40px;
}
.m365-workload-cell {
  background: #fff;
  padding: 24px 20px;
}
.m365-workload-cell .m365-wl-name {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 10px !important;
  display: flex;
  align-items: center;
  gap: 8px;
}
.m365-workload-cell ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.m365-workload-cell ul li {
  font-size: 12px;
  color: #666;
  padding: 4px 0;
  border-bottom: 1px solid #f0f0f0;
  display: flex;
  align-items: center;
  gap: 6px;
}
.m365-workload-cell ul li:last-child {
  border-bottom: none;
}
.m365-workload-cell ul li::before {
  content: '→';
  font-size: 10px;
  color: #bbb;
  flex-shrink: 0;
}

/* ── Trust Logos Placeholder ─────────────────────────────── */
.m365-trust-logos-placeholder {
  margin: 32px auto;
  border: 2px dashed #ddd;
  padding: 40px;
  max-width: 800px;
  color: #bbb;
  font-size: 13px;
  line-height: 2;
  text-align: center;
}

/* ── Testimonials Grid ───────────────────────────────────── */
.m365-trust-testimonials {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 40px;
}
.m365-testimonial-card {
  padding: 28px 24px;
  border: 1px solid #e5e5e5;
  background: #f9f9f9;
  text-align: left;
}
.m365-testimonial-card blockquote {
  font-size: 14px;
  line-height: 1.65;
  color: #333;
  font-style: italic;
  margin-bottom: 16px !important;
}
.m365-testimonial-card blockquote::before {
  content: '\201C';
}
.m365-testimonial-card blockquote::after {
  content: '\201D';
}
.m365-testimonial-author {
  font-size: 12px;
  font-weight: 700;
  display: block;
  margin: 0 !important;
}
.m365-testimonial-company {
  font-size: 11px;
  color: #999;
  margin-top: 2px !important;
  display: block;
}

/* ── CTA Section Layout ──────────────────────────────────── */
.m365-cta-inner {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 80px;
  align-items: start;
}
.m365-cta-text h2 {
  font-size: 36px !important;
  font-weight: 900 !important;
  letter-spacing: -1px;
  line-height: 1.1 !important;
  margin-bottom: 20px !important;
  color: #000;
}
.m365-cta-text p {
  font-size: 16px;
  color: #666;
  line-height: 1.7;
  margin-bottom: 28px !important;
}
.m365-cta-bullets {
  list-style: none;
  padding: 0;
  margin: 0 0 32px !important;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.m365-cta-bullets li {
  font-size: 14px;
  color: #333;
  display: flex;
  align-items: center;
  gap: 10px;
}
.m365-cta-bullets li::before {
  content: '✓';
  font-weight: 900;
  color: #000;
  flex-shrink: 0;
}

/* CTA Form Card */
.m365-cta-form-card {
  background: #fff;
  color: #000;
  padding: 36px 32px;
  border: 1px solid #e5e5e5;
}
.m365-cta-form-card h3 {
  font-size: 20px !important;
  font-weight: 900 !important;
  margin-bottom: 6px !important;
}
.m365-cta-form-card .m365-form-sub {
  font-size: 12px;
  color: #777;
  margin-bottom: 22px !important;
  line-height: 1.45;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .m365-hero-wrap {
    grid-template-columns: 1fr;
  }
  .m365-hero-wrap h1 {
    font-size: 36px !important;
  }
  .m365-msp-hero {
    grid-template-columns: 1fr;
    gap: 32px;
    margin-bottom: 40px;
  }
  .m365-it-hero {
    grid-template-columns: 1fr;
    gap: 32px;
    margin-bottom: 40px;
  }
  .m365-features-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .m365-usecase-grid {
    grid-template-columns: 1fr;
  }
  .m365-workloads-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .m365-trust-testimonials {
    grid-template-columns: 1fr;
  }
  .m365-cta-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .m365-msp-pricing-box {
    padding: 28px 24px;
    gap: 28px;
  }
}

@media (max-width: 600px) {
  .m365-hero-wrap h1 {
    font-size: 30px !important;
  }
  .m365-features-grid {
    grid-template-columns: 1fr;
  }
  .m365-workloads-grid {
    grid-template-columns: 1fr;
  }
  .m365-price-num {
    font-size: 40px !important;
  }
  .m365-msp-pricing-box {
    padding: 20px 16px;
  }
}
