/*
 * Seven Oceans — Elementor Pro markup overrides
 *
 * Targets the generated markup of specific Elementor widgets so that
 * the default Elementor styling does not fight our design system.
 * Only applies within our custom section classes to avoid collateral damage.
 */

/* ── Containers: remove default max-width when inside site-frame ── */
.site-frame .elementor-section.elementor-section-boxed > .elementor-container,
.site-frame .e-con {
  max-width: var(--page-max);
}

/* ── Headings inside our custom sections inherit display font ── */
.hero-content-grid .elementor-heading-title,
.split-text-col .elementor-heading-title,
.so-coverage .elementor-heading-title,
.so-blog-hero .elementor-heading-title {
  font-family: var(--font-display);
  color: #fff;
  text-transform: uppercase;
  letter-spacing: -.03em;
  text-wrap: balance;
}

/* ── Text editor widgets get the muted copy color by default ── */
.hero-content-grid .elementor-widget-text-editor,
.split-text-col .elementor-widget-text-editor,
.so-coverage .elementor-widget-text-editor {
  color: rgba(230,236,245,.82);
  font-size: 1.03rem;
  line-height: 1.7;
}
.hero-content-grid .elementor-widget-text-editor p,
.split-text-col .elementor-widget-text-editor p,
.so-coverage .elementor-widget-text-editor p {
  color: inherit;
}

/* ── Buttons: when a button widget has class "hero-btn-primary" or
      "hero-btn-secondary", force our styling over Elementor's defaults. ── */
.elementor-button-wrapper .elementor-button.hero-btn-primary,
.elementor-button-wrapper .elementor-button.hero-btn-secondary {
  padding: 15px 22px;
  min-height: 52px;
  border-radius: 12px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: .82rem;
}

/* ── Nav Menu widget styling (desktop + mobile) ── */
.so-navbar .elementor-nav-menu--main .elementor-item {
  color: rgba(245,247,251,.82);
  font-family: var(--font-sans);
  font-size: .86rem;
  letter-spacing: .02em;
  padding: 0 14px;
  transition: color .25s ease;
}
.so-navbar .elementor-nav-menu--main .elementor-item:hover,
.so-navbar .elementor-nav-menu--main .elementor-item.elementor-item-active {
  color: #fff;
}

/* Mobile dropdown panel */
.so-navbar .elementor-nav-menu--dropdown {
  background: rgba(7,10,16,.97) !important;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  box-shadow: 0 20px 45px rgba(0,0,0,.35);
  margin-top: 10px;
  padding: 14px !important;
}
.so-navbar .elementor-nav-menu--dropdown .elementor-item {
  color: rgba(245,247,251,.82) !important;
  border: none !important;
  padding: 10px 12px !important;
}

/* Hamburger toggle */
.so-navbar .elementor-menu-toggle {
  background: transparent !important;
  border: 1px solid rgba(255,255,255,.12);
  color: #fff !important;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
}
.so-navbar .elementor-menu-toggle svg {
  width: 20px;
  height: 20px;
  fill: #fff;
}

/* ── Posts / Loop Grid widget inside blog archive ── */
.elementor-widget-posts .elementor-posts-container .elementor-post,
.elementor-widget-loop-grid .e-loop-item {
  background: rgba(8,12,19,0.38);
  backdrop-filter: blur(18px) saturate(120%);
  -webkit-backdrop-filter: blur(18px) saturate(120%);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 12px;
  overflow: hidden;
  transition: transform .25s ease, background .25s ease, box-shadow .25s ease;
}
.elementor-widget-posts .elementor-posts-container .elementor-post:hover,
.elementor-widget-loop-grid .e-loop-item:hover {
  transform: translateY(-4px);
  background: rgba(10,16,26,0.55);
  box-shadow: 0 20px 35px rgba(0,0,0,.24), inset 0 0 0 1px rgba(132,183,255,.08);
}
.elementor-widget-posts .elementor-post__title,
.elementor-widget-posts .elementor-post__title a {
  font-family: var(--font-display);
  color: #fff;
  text-transform: uppercase;
  letter-spacing: -.01em;
}
.elementor-widget-posts .elementor-post__excerpt {
  color: var(--muted);
}
.elementor-widget-posts .elementor-post__meta-data {
  color: var(--accent);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .72rem;
}

/* ── Form widget dark theme (inside .so-form-card wrapper, styles live in style.css) ── */

/* ── Icon widget inside our feature card's icon ring ── */
.so-feature-icon-ring .elementor-icon {
  color: var(--accent-2);
  font-size: 18px;
}

/* ── Image widget: ensure logos in navbar/footer don't overflow ── */
.so-navbar .elementor-widget-image img,
.so-footer .elementor-widget-image img {
  display: block;
}

/* ── Editor preview: make our pseudo-element glows visible inside the
      Elementor editor too, so editors can see the design while working. ── */
body.elementor-editor-active .section-divider::after,
body.elementor-editor-active .section-divider::before {
  z-index: 10;
}

/* ── Safety: Elementor sometimes injects a `.elementor-section-wrap`
      that applies its own padding; reset that inside our sections. ── */
.section-divider.elementor-section > .elementor-container {
  padding: 0;
}
