
/*
Theme Name: Payer+Provider Block
Theme URI: https://payerprovider.com/
Author: OpenAI for Payer+Provider Syndicate
Author URI: https://payerprovider.com/
Description: A minimalist, mobile-first block theme for Payer+Provider Syndicate.
Requires at least: 6.5
Tested up to: 6.8
Requires PHP: 7.4
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: payerprovider-block
Tags: block-patterns, full-site-editing, custom-logo, one-column, two-columns, featured-images
*/

@font-face {
  font-family: 'PP Arvo';
  src: url('./assets/fonts/Arvo-Regular-webfont.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'PP Arvo';
  src: url('./assets/fonts/Arvo-Bold-webfont.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'PP Arvo';
  src: url('./assets/fonts/Arvo-Italic-webfont.ttf') format('truetype');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'PP Roboto';
  src: url('./assets/fonts/Roboto-Regular-webfont.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'PP Roboto';
  src: url('./assets/fonts/Roboto-Bold-webfont.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'PP Roboto';
  src: url('./assets/fonts/Roboto-Italic-webfont.ttf') format('truetype');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

html { scroll-behavior: smooth; }
body {
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.wp-site-blocks {
  padding-left: 0;
  padding-right: 0;
}


/* Normalize block-theme indentation and prevent constrained-layout auto-centering */
.pp-main-shell,
.page-shell {
  width: min(100% - 2rem, var(--wp--style--global--content-size));
  margin-left: auto;
  margin-right: auto;
}

.pp-main-shell.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)),
.page-shell.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)),
.page-content-block.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)),
.entry-content.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.page-content-block,
.entry-content {
  width: 100%;
  max-width: none;
}

.page-content-block > *,
.entry-content > * {
  max-width: none;
}

header.wp-block-template-part,
footer.wp-block-template-part {
  margin-block-start: 0;
}

.is-style-pp-panel,
.page-shell {
  border: 1px solid #b9b9b9;
  background: #ffffff;
}

.page-content-block {
  width: 100%;
  max-width: none;
  font-size: 1rem;
  line-height: 1.68;
  color: #222;
  box-sizing: border-box;
}
.page-content-block *,
.page-content-block *::before,
.page-content-block *::after { box-sizing: inherit; }
.page-content-block p { margin: 0 0 16px 0; max-width: 52rem; }
.page-content-block ul,
.page-content-block ol,
.page-content-block .services-matrix-wrap,
.page-content-block .services-highlight-grid,
.page-content-block .page-content-highlight,
.page-content-block .page-content-phase { max-width: none; }
.page-content-block .page-content-intro { font-size: 1.08em; line-height: 1.55; margin-bottom: 18px; max-width: 56rem; }
.page-content-block h2 { margin: 36px 0 12px 0; padding-top: 14px; border-top: 1px solid #dcdcdc; font-size: 1.3em; line-height: 1.25; font-weight: 700; }
.page-content-block h2:first-of-type { margin-top: 30px; }
.page-content-block h3 { margin: 18px 0 8px 0; font-size: 1.05em; line-height: 1.3; font-weight: 700; }
.page-content-block ul,
.page-content-block ol { margin: 0 0 18px 1.1em; padding-left: 1em; }
.page-content-block li { margin: 0 0 7px 0; line-height: 1.55; }
.page-content-block ul ul,
.page-content-block ol ol,
.page-content-block ul ol,
.page-content-block ol ul { margin-top: 8px; margin-bottom: 4px; padding-left: 1.05em; }
.page-content-block .page-content-highlight { margin: 14px 0 20px 0; padding: 10px 14px; background: #f6f6f6; border-left: 3px solid #c62828; font-size: 0.98em; line-height: 1.4; }
.page-content-block a.page-content-button,
.page-content-block a.page-content-button:visited { display: inline-flex; align-items: center; justify-content: center; margin-top: 2px; padding: 12px 16px; min-height: 44px; border: 1px solid #c62828; color: #c62828 !important; background: transparent; text-decoration: none; font-weight: 600; font-size: 16px; line-height: 1.2; }
.page-content-block a.page-content-button:hover,
.page-content-block a.page-content-button:focus { background: #c62828; color: #fff !important; text-decoration: none; }
.page-content-block .page-content-phase { margin: 0 0 22px 0; }
.page-content-block .page-content-phase h3 { margin-bottom: 10px; }
.page-content-block strong { font-weight: 700; }
.page-content-block img,
.entry-content img,
img { max-width: 100%; height: auto; }

.services-matrix-wrap { margin: 18px 0 28px 0; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.services-matrix { width: 100%; min-width: 700px; border-collapse: collapse; table-layout: fixed; }
.services-matrix th,
.services-matrix td { padding: 16px 14px; vertical-align: top; border: 1px solid #dcdcdc; }
.services-matrix thead th { background: #f6f6f6; text-align: center; font-size: 1.05em; font-weight: 700; }
.services-matrix tbody th { width: 24%; background: #fbfbfb; text-align: left; font-weight: 700; }
.services-matrix td { width: 38%; }
.services-matrix ul,
.services-matrix ol { margin: 0; padding-left: 1.1em; }
.services-matrix li { margin: 0 0 8px 0; }

.services-highlight-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin: 18px 0 10px 0; }
.services-highlight-card { padding: 18px 16px; border: 1px solid #dcdcdc; background: #fafafa; }
.services-highlight-card h3 { margin-top: 0; }
.services-highlight-card p:last-child { margin-bottom: 0; }

@media (max-width: 900px) {
  .services-highlight-grid { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .page-content-block { font-size: 15px; line-height: 1.6; }
  .page-content-block p { margin-bottom: 14px; max-width: none; }
  .page-content-block .page-content-intro { max-width: none; }
  .page-content-block h2 { margin: 28px 0 10px 0; padding-top: 12px; font-size: 1.15em; }
  .page-content-block h3 { margin: 16px 0 8px 0; font-size: 1em; }
  .page-content-block ul,
  .page-content-block ol { padding-left: 1em; }
  .page-content-block .page-content-highlight { padding: 10px 12px; }
  .page-content-block a.page-content-button,
  .page-content-block a.page-content-button:visited { width: auto; max-width: 100%; min-width: 0; }
}
