/**
 * Gutenberg Block Styles
 * Overrides and enhancements for WordPress blocks
 */

/* ==========================================================================
   NAVIGATION - MOBILE OVERLAY
   ========================================================================== */

/* Force black background and white text on mobile navigation overlay */
.wp-block-navigation__responsive-container.is-menu-open {
  background-color: #000000 !important;
  color: #FFFFFF !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
  background-color: transparent !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
  color: #FFFFFF !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-close {
  color: #FFFFFF !important;
}

/* ==========================================================================
   GENERAL BLOCK STYLES
   ========================================================================== */

/* Add spacing between blocks */
.wp-block-group,
.wp-block-columns,
.wp-block-cover,
.wp-block-media-text {
  margin-bottom: var(--space-8);
}

/* Remove bottom margin from last block */
.wp-block-group > *:last-child,
.entry-content > *:last-child {
  margin-bottom: 0;
}

/* ==========================================================================
   HEADINGS
   ========================================================================== */

.wp-block-heading {
  margin-top: var(--space-8);
  margin-bottom: var(--space-4);
}

.wp-block-heading:first-child {
  margin-top: 0;
}

/* ==========================================================================
   PARAGRAPHS
   ========================================================================== */

.wp-block-paragraph {
  margin-bottom: var(--space-4);
}

.has-large-font-size {
  font-size: var(--text-xl);
  line-height: var(--leading-relaxed);
}

.has-small-font-size {
  font-size: var(--text-sm);
}

/* ==========================================================================
   BUTTONS
   ========================================================================== */

.wp-block-button__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 12px 24px;
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  line-height: 1;
  text-decoration: none;
  border-radius: 8px !important;
  transition: all var(--transition-fast);
}

.wp-block-button.is-style-fill .wp-block-button__link,
.wp-block-button:not(.is-style-outline) .wp-block-button__link {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.wp-block-button.is-style-fill .wp-block-button__link:hover,
.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
  background-color: var(--color-primary-hover);
}

.wp-block-button.is-style-outline .wp-block-button__link {
  background-color: transparent;
  border: 2px solid var(--color-primary);
  color: var(--color-primary);
  border-radius: 8px;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
}

/* Reset wrapper styles - remove background from wrapper */
.wp-block-button {
  background: transparent !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

.wp-block-button.btn--large,
.wp-block-button.btn--primary {
  background: transparent !important;
  padding: 0 !important;
}

/* Large button style */
.wp-block-button.btn--large .wp-block-button__link {
  padding: 16px 32px;
  font-size: var(--text-lg);
}

/* Primary button style */
.wp-block-button.btn--primary .wp-block-button__link {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.wp-block-button.btn--primary .wp-block-button__link:hover {
  background-color: var(--color-primary-hover);
}

.wp-block-buttons {
  gap: var(--space-4);
}

/* ==========================================================================
   COLUMNS
   ========================================================================== */

.wp-block-columns {
  gap: var(--grid-gap);
}

.wp-block-column {
  margin-bottom: 0;
}

/* ==========================================================================
   COVER
   ========================================================================== */

.wp-block-cover {
  min-height: 400px;
  padding: var(--space-12);
}

.wp-block-cover__inner-container {
  max-width: var(--container-max);
  margin: 0 auto;
}

/* ==========================================================================
   GROUP
   ========================================================================== */

.wp-block-group.has-background {
  padding: var(--space-8);
  border-radius: var(--radius-lg);
}

/* Background color classes */
.has-primary-background-color {
  background-color: var(--color-primary);
}

.has-secondary-background-color {
  background-color: var(--color-secondary);
}

.has-light-gray-background-color {
  background-color: var(--color-gray-50);
}

.has-dark-gray-background-color {
  background-color: var(--color-gray-900);
}

/* Text color classes */
.has-primary-color {
  color: var(--color-primary);
}

.has-secondary-color {
  color: var(--color-secondary);
}

.has-white-color {
  color: var(--color-white);
}

.has-black-color {
  color: var(--color-black);
}

/* ==========================================================================
   IMAGE
   ========================================================================== */

.wp-block-image {
  margin-bottom: var(--space-6);
}

.wp-block-image img {
  border-radius: var(--radius-md);
}

.wp-block-image.is-style-rounded img {
  border-radius: var(--radius-full);
}

.wp-block-image figcaption {
  text-align: center;
  font-size: var(--text-sm);
  color: var(--theme-text-muted);
  margin-top: var(--space-2);
}

/* ==========================================================================
   QUOTE
   ========================================================================== */

.wp-block-quote {
  border-left: 4px solid var(--color-primary);
  padding-left: var(--space-6);
  margin: var(--space-8) 0;
  font-style: italic;
}

.wp-block-quote p {
  font-size: var(--text-lg);
  margin-bottom: var(--space-2);
}

.wp-block-quote cite {
  font-style: normal;
  font-weight: var(--font-semibold);
  color: var(--theme-text);
}

.wp-block-quote.is-style-large {
  border-left: none;
  padding: var(--space-8);
  background-color: var(--theme-bg-alt);
  border-radius: var(--radius-lg);
}

.wp-block-quote.is-style-large p {
  font-size: var(--text-2xl);
}

/* ==========================================================================
   PULLQUOTE
   ========================================================================== */

.wp-block-pullquote {
  border-top: 4px solid var(--color-primary);
  border-bottom: 4px solid var(--color-primary);
  padding: var(--space-8) 0;
  text-align: center;
}

.wp-block-pullquote blockquote {
  border: none;
  padding: 0;
  margin: 0;
}

.wp-block-pullquote p {
  font-size: var(--text-2xl);
  font-style: italic;
}

.wp-block-pullquote cite {
  font-style: normal;
  font-size: var(--text-base);
}

/* ==========================================================================
   LIST
   ========================================================================== */

.wp-block-list {
  padding-left: var(--space-6);
  margin-bottom: var(--space-4);
}

.wp-block-list li {
  margin-bottom: var(--space-2);
}

/* ==========================================================================
   TABLE
   ========================================================================== */

.wp-block-table {
  margin-bottom: var(--space-6);
}

.wp-block-table table {
  width: 100%;
  border-collapse: collapse;
}

.wp-block-table th,
.wp-block-table td {
  padding: var(--space-3) var(--space-4);
  border: var(--border-width) solid var(--theme-border);
}

.wp-block-table th {
  background-color: var(--theme-bg-alt);
  font-weight: var(--font-semibold);
}

.wp-block-table.is-style-stripes tbody tr:nth-child(odd) {
  background-color: var(--theme-bg-alt);
}

/* ==========================================================================
   SEPARATOR
   ========================================================================== */

.wp-block-separator {
  border: none;
  border-top: var(--border-width) solid var(--theme-border);
  margin: var(--space-8) auto;
}

.wp-block-separator:not(.is-style-wide):not(.is-style-dots) {
  max-width: 100px;
}

.wp-block-separator.is-style-dots {
  border: none;
  text-align: center;
}

.wp-block-separator.is-style-dots::before {
  content: '···';
  font-size: var(--text-2xl);
  letter-spacing: 1em;
  color: var(--theme-text-muted);
}

/* ==========================================================================
   MEDIA & TEXT
   ========================================================================== */

.wp-block-media-text {
  gap: var(--space-8);
}

.wp-block-media-text .wp-block-media-text__content {
  padding: 0;
}

.wp-block-media-text .wp-block-media-text__media img {
  border-radius: var(--radius-lg);
}

/* ==========================================================================
   SPACER
   ========================================================================== */

.wp-block-spacer {
  margin: 0;
}

/* ==========================================================================
   EMBED
   ========================================================================== */

.wp-block-embed {
  margin-bottom: var(--space-6);
}

.wp-block-embed__wrapper {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  max-width: 100%;
  border-radius: var(--radius-lg);
}

.wp-block-embed__wrapper iframe,
.wp-block-embed__wrapper object,
.wp-block-embed__wrapper embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* ==========================================================================
   WIDE & FULL ALIGNMENTS
   ========================================================================== */

.alignwide {
  max-width: var(--container-wide);
  margin-left: auto;
  margin-right: auto;
}

.alignfull {
  max-width: none;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.aligncenter {
  margin-left: auto;
  margin-right: auto;
}

/* ==========================================================================
   CUSTOM BLOCK PATTERNS - INBOUND EFFECT
   ========================================================================== */

/* Section Header - centered */
.section-header {
  text-align: center;
  margin-bottom: var(--space-12);
}

.section-header.text-center,
.wp-block-group.text-center {
  text-align: center;
}

.section-header h2,
.section-header .wp-block-heading {
  margin-inline: auto;
}

.section-header p,
.section-header .lead {
  max-width: 60ch;
  margin-inline: auto;
}

/* Hero section */
.hero {
  text-align: center;
  padding: var(--space-16) 0;
}

.hero__eyebrow {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: var(--space-4);
}

.hero__title {
  max-width: 20ch;
  margin-inline: auto;
  margin-bottom: var(--space-6);
}

.hero__subtitle {
  max-width: 50ch;
  margin-inline: auto;
  margin-bottom: var(--space-8);
}

/* Credibility Bar - evenly distributed */
.credibility-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--space-8);
  padding: var(--space-8) 0;
  border-top: 1px solid var(--theme-border);
  border-bottom: 1px solid var(--theme-border);
}

.credibility-bar__item {
  text-align: center;
  padding: 0 var(--space-6);
  min-width: 120px;
}

.credibility-bar__metric {
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: var(--color-primary);
  display: block;
  line-height: 1;
  margin-bottom: var(--space-1);
}

.credibility-bar__label {
  font-size: var(--text-sm);
  color: var(--theme-text-muted);
}

/* Metrics - evenly distributed */
.metric {
  text-align: center;
  padding: var(--space-2);
}

.metric__value,
p.metric__value {
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: var(--color-primary);
  line-height: 1;
  display: block;
  margin-bottom: var(--space-1);
  max-width: none;
}

.metric__label,
p.metric__label {
  font-size: var(--text-sm);
  color: var(--theme-text-muted);
  max-width: none;
  margin-bottom: 0;
}

/* Case Study Cards */
.case-study-card {
  padding: var(--space-8);
}

.case-study-card > .wp-block-columns {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .case-study-card > .wp-block-columns {
    flex-wrap: nowrap;
  }
}

.case-study-card__eyebrow {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-2);
}

.case-study-card__title {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-3);
}

.case-study-card__text {
  color: var(--theme-text-muted);
  margin-bottom: var(--space-4);
}

.case-study-card__metrics {
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  padding: var(--space-6);
  background-color: var(--theme-bg-alt);
  border-radius: var(--radius-md);
  min-width: 280px;
  flex: 1 1 280px !important;
}

.case-study-card__metrics .wp-block-columns {
  display: flex !important;
  flex-wrap: nowrap !important;
  justify-content: space-evenly !important;
  align-items: flex-start;
  gap: var(--space-4) !important;
  width: 100%;
  margin: 0 !important;
}

.case-study-card__metrics .wp-block-column {
  flex: 1 1 auto !important;
  min-width: 60px;
  text-align: center;
  margin: 0 !important;
}

.case-study-card__metrics .wp-block-column.metric {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Case Studies List */
.case-studies-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

/* CTA Section */
.cta-section {
  text-align: center;
  padding: var(--space-16) 0;
}

.cta-section--dark {
  background-color: var(--color-gray-900);
  color: var(--color-gray-200);
}

.cta-section--dark h2,
.cta-section--dark .wp-block-heading {
  color: var(--color-white);
}

.cta-section__text {
  max-width: 50ch;
  margin-inline: auto;
  margin-bottom: var(--space-8);
}

/* Lead text - always centered when in centered container */
.lead,
p.lead {
  font-size: var(--text-xl);
  line-height: var(--leading-relaxed);
  color: var(--theme-text-muted);
}

.text-center .lead,
.text-center p.lead,
.has-text-align-center + .lead {
  margin-inline: auto;
}

/* Service cards in grid */
.service-card {
  text-align: center;
  padding: var(--space-8);
  height: 100%;
}

.service-card__link {
  margin-top: var(--space-4);
}

/* Cards */
.card {
  background-color: var(--card-bg, #fff);
  border-radius: var(--radius-lg);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  padding: var(--space-6);
}

/* ==========================================================================
   CODE BLOCK
   ========================================================================== */

.wp-block-code {
  background-color: var(--theme-bg-alt);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  overflow-x: auto;
}

.wp-block-code code {
  background: none;
  padding: 0;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

/* ==========================================================================
   PREFORMATTED
   ========================================================================== */

.wp-block-preformatted {
  background-color: var(--theme-bg-alt);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  overflow-x: auto;
  white-space: pre-wrap;
}
