/* Opex responsive overrides and table responsiveness
   This file is loaded by the Opex Elementor Widgets plugin to fix
   mobile responsiveness issues without modifying the (read-only) theme files. */

/* 1) Ensure card grids remain responsive even when inline grid-template-columns
      is set via shortcode/widget Columns controls. */
@media (max-width: 991px) {
  /* Shortcodes: services/case studies (.opex-cs .cards) */
  .opex-cs .cards { grid-template-columns: repeat(2, 1fr) !important; }
  /* Elementor widgets: generic grid container */
  .opex-widget-grid .opex-cards { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 575px) {
  .opex-cs .cards { grid-template-columns: 1fr !important; }
  .opex-widget-grid .opex-cards { grid-template-columns: 1fr !important; }
}

/* 2) Make tables horizontally scrollable on small screens to avoid layout breakage. */
/* Base table sizing */
.entry-content table,
.elementor-widget-container table,
.wp-block-table table,
table {
  width: 100%;
  max-width: 100%;
  border-collapse: collapse;
}

/* Scroll wrapper behavior for common WordPress/Elementor containers and a utility class */
.entry-content table,
.elementor-widget-container table,
.wp-block-table,
.table-responsive {
  display: block;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* Avoid overly tall cells by preventing extreme wrapping on very small screens */
@media (max-width: 767px) {
  .entry-content table th,
  .entry-content table td,
  .elementor-widget-container table th,
  .elementor-widget-container table td,
  .wp-block-table td,
  .wp-block-table th {
    white-space: nowrap;
  }
}

/* Optional: nicer look for tables (non-intrusive) */
.entry-content table th,
.entry-content table td,
.elementor-widget-container table th,
.elementor-widget-container table td,
.wp-block-table td,
.wp-block-table th {
  padding: 8px 10px;
}


/* 3) Force 0.7 black overlay on images for Elementor widgets Style 3 */
.opex-widget-grid .opex-cards.style-3 .thumb::after {
  background: rgba(0,0,0,0.5) !important;
}

/* 4) Sitewide typography: use Helvetica on the frontend */
body:not(.wp-admin) {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif !important;
}
/* Ensure Opex components inherit Helvetica instead of Montserrat */
.opex-cs,
.opex-services-wrap,
.opex-widget-grid,
.entry-content,
.elementor-widget-container {
  font-family: inherit !important;
}

/* 5) Hide the top badge box (e.g., "Service") on cards */
.opex-cs .badge-cat,
.opex-widget-grid .badge-cat { display: none !important; }

/* 6) Remove border radius from all common card boxes */
.opex-cs .cardx,
.opex-cs .cardx .thumb img,
.opex-widget-grid .cardx,
.opex-widget-grid .cardx .thumb img,
.service-card,
.service-card img,
.service-content,
.service-img img { border-radius: 0 !important; }

/* 7) Shorten the text under headlines: clamp excerpts to 2 lines */
.opex-cs .excerpt,
.opex-widget-grid .excerpt,
.opex-home-teasers .excerpt {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* 8) Make the whole teaser card clickable using the existing title link */
.opex-home-teasers .cardx { position: relative; }
.opex-home-teasers .cardx .title.stretched {
  position: absolute;
  inset: 0;
  z-index: 3;
  text-indent: -9999px;
}
.opex-home-teasers .cardx .title.stretched:focus { outline: none; }

/* 9) Hide category tabs on Services by default (can be re-enabled later) */
.opex-services-wrap .opex-category-tabs { display: none !important; }

/* 10) Loader styling for dynamic load-more grids */
.opex-widget-grid .opex-grid-load-more {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 32px auto 0;
  min-height: 48px;
  width: 100%;
  text-align: center;
  color: inherit;
}

.opex-widget-grid .opex-grid-load-more .spinner {
  display: none;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 3px solid rgba(0,0,0,0.15);
  border-top-color: currentColor;
  animation: opex-spin 0.9s linear infinite;
  opacity: 0.8;
}

.opex-widget-grid .opex-grid-load-more[data-state="loading"] .spinner,
.opex-widget-grid .opex-grid-load-more[data-state="error"] .spinner {
  display: inline-block;
}

.opex-widget-grid .opex-grid-load-more[data-state="error"] .spinner {
  border-color: rgba(220,53,69,0.35);
  border-top-color: rgba(220,53,69,0.85);
  opacity: 1;
}

.opex-widget-grid .opex-grid-load-more[data-state="complete"] {
  display: none;
}

.opex-widget-grid .opex-grid-load-more .loader-text {
  display: none;
  font-size: 0.875rem;
  letter-spacing: 0.02em;
}

.opex-widget-grid .opex-grid-load-more[data-state="loading"] .loader-text,
.opex-widget-grid .opex-grid-load-more[data-state="error"] .loader-text {
  display: block;
}

.opex-widget-grid .opex-grid-load-more.has-button {
  gap: 12px;
}

.opex-widget-grid .opex-grid-load-more .load-more-button {
  padding: 10px 18px;
  border-radius: 999px;
  border: 1px solid currentColor;
  background: transparent;
  color: inherit;
  font-size: 0.875rem;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.opex-widget-grid .opex-grid-load-more .load-more-button:hover {
  background-color: rgba(0,0,0,0.08);
}

.opex-widget-grid .opex-grid-load-more .load-more-button:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

.opex-widget-grid .opex-grid-load-more .load-more-button[disabled] {
  opacity: 0.55;
  cursor: not-allowed;
}

@keyframes opex-spin {
  to { transform: rotate(360deg); }
}

.visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
