/* Make sure the page itself can scroll */
html, body {
  overflow: auto;         /* in case something upstream set hidden */
  height: auto;
}

/* The hero should not create its own scroll container */
.cxo-hero-bg {
  overflow: visible;      /* was: hidden */
  -webkit-overflow-scrolling: touch;  /* smooth on iOS */
  overscroll-behavior: auto;          /* allow normal scroll chaining */
}

/* Ensure decorative overlays cannot capture pointer/wheel events */
.cxo-hero-bg::before,
.cxo-hero-bg::after {
  pointer-events: none;
}

/* ===== CxO Insights – Hero (scoped, uses your root tokens) ================= */
.cxo-hero-bg{
  position: relative;
  isolation: isolate;
  color: var(--on-primary);
  background:
    url('https://iiot-world.com/wp-content/uploads/2021/01/CxO_1.jpg?id=19770')
    no-repeat center center / cover;

  display: flex;
  align-items: center;
  min-height: clamp(420px, 60vh, 720px);
  overflow: hidden;
}

/* Overlay built from your --secondary and --primary shades */
.cxo-hero-bg::before{
  content: "";
  position: absolute; inset: 0;
  /* deep vignette + L→R sweep; colors use your tokens */
  background:
    radial-gradient(1200px 1200px at -10% 110%,
      color-mix(in srgb, var(--secondary-color) 85%, black 0%) .78,
      color-mix(in srgb, var(--secondary-color) 70%, black 0%) .44 50%,
      transparent 70%),
    linear-gradient(90deg,
      color-mix(in srgb, var(--secondary-color) 92%, black 0%) 0%,
      color-mix(in srgb, var(--secondary-color) 80%, var(--primary) 10%) 45%,
      color-mix(in srgb, var(--secondary-color) 60%, var(--primary) 20%) 70%,
      color-mix(in srgb, var(--secondary-color) 35%, var(--primary) 25%) 100%);
  z-index: -1;
}

.cxo-hero-bg::after{
  /* subtle diagonal sheen for a 2025 look */
  content:"";
  position:absolute; inset:-10% -10% auto -10%;
  height: 60%;
  background: linear-gradient(110deg, rgba(255,255,255,.08), rgba(255,255,255,0) 40%);
  pointer-events:none;
  mix-blend-mode:screen;
}

/* inner spacing */
.cxo-hero{
  width: 100%;
  padding: clamp(56px, 8vw, 120px) 0;
}
.cxo-hero .container-1200{
  margin: 0 auto;
  max-width: var(--max-width);
  padding-inline: clamp(16px, 4vw, 32px);
}
.cxo-hero .align-left{ max-width: min(760px, 95%); }

/* type uses your fonts/tokens */
.cxo-kicker{
  display:inline-block;
  font-family: var(--font-condensed);
  font-size: .9rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--on-primary) 80%, transparent);
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.22);
  border-radius: var(--radius-pill);
  padding: .38rem .72rem;
  margin-bottom: .8rem;
  backdrop-filter: blur(6px);
}

.cxo-title{
  margin: 0 0 .6rem;
  font-family: var(--font-condensed);
  font-size: clamp(28px, 4vw, 52px);
  line-height: 1.08;
  letter-spacing: .2px;
  font-weight: 700;
  color:#fff;
}
.cxo-subtitle{
  margin: 0 0 1rem;
  color: color-mix(in srgb, var(--on-primary) 78%, transparent);
  font-family: var(--font-sans);
  font-size: clamp(16px, 1.3vw, 20px);
  line-height: 1.55;
}
.cxo-note{
  margin: .75rem 0 1.5rem;
  font-style: italic;
  color: color-mix(in srgb, var(--on-primary) 86%, transparent);
  max-width: 60ch;
}

/* CTA uses your primary + radius */
.cxo-actions{ display:flex; gap:12px; flex-wrap:wrap; }
.cxo-btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 14px 24px;
  border-radius: var(--border-radius);
  text-decoration:none;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .4px;
  border: 1px solid transparent;
  transition: transform .08s var(--transition), filter var(--transition), box-shadow var(--transition);
  will-change: transform, filter;
}
.cxo-btn--primary{
  background: var(--primary);
  color: var(--on-primary);
  box-shadow: 0 6px 18px color-mix(in srgb, var(--primary) 45%, transparent);
}
.cxo-btn--primary:hover{ filter: brightness(1.06); }
.cxo-btn--primary:focus-visible{ outline: 2px solid var(--ring); outline-offset: 2px; }
.cxo-btn--primary:active{ transform: translateY(1px) scale(.99); }

/* Optional: full-screen hero variant */
/* .cxo-hero-bg--full { min-height: 100vh; } */


/* ===== CXO Introduction (2025 clean) ==================== */
.cxo-intro{
  background:
    radial-gradient(1400px 600px at 15% -20%, color-mix(in srgb, var(--secondary) 8%, white 92%), transparent 55%),
    radial-gradient(1200px 500px at 85% 120%, color-mix(in srgb, var(--primary) 6%, white 94%), transparent 55%),
    var(--background);
  color: var(--text-color);
  padding: clamp(56px, 10vw, 96px) 0;
  text-align: center;
}

/* subtle hairline accent at top */
.cxo-intro::before{
  content:"";
  position:absolute; inset:0 0 auto 0; height:2px;
  background: linear-gradient(to right, transparent, color-mix(in srgb, var(--secondary) 45%, white 55%), transparent);
  opacity:.2;
}

/* container */
.cxo-intro .container-1200{
  max-width: var(--max-width);
  margin: 0 auto;
  padding-inline: clamp(16px, 4vw, 32px);
}

/* headline */
.cxo-intro__title{
  margin: 0 0 1rem;
  font-family: var(--font-condensed);
  font-weight: 700;
  font-size: clamp(28px, 3.5vw, 44px);
  color: var(--text-color);
}

/* paragraph */
.cxo-intro__text{
    text-align: left;
  margin: 0 auto;
  color: var(--text-muted);
  font: 400 clamp(16px, 1.2vw, 18px)/1.7 var(--font-sans);
}

/* ===== Featured Guests Episodes (scoped) =============================== */
.cxo-guests{
  background: var(--background);
  padding: clamp(48px, 8vw, 96px) 0;
  color: var(--text-color);
}
.cxo-guests .container-1200{
  max-width: var(--max-width);
  margin: 0 auto;
  padding-inline: clamp(16px, 4vw, 32px);
  text-align: center;
}
.cxo-guests__title{
  margin: 0 0 clamp(24px, 5vw, 40px);
  font-family: var(--font-condensed);
  font-weight: 700;
  font-size: clamp(22px, 3vw, 32px);
  color: var(--text-color);
}

/* grid */
.cxo-guests__grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(220px, 1fr));
  gap: clamp(24px, 3vw, 40px) clamp(24px, 3vw, 48px);
  justify-items: center;
}
@media (max-width: 1100px){
  .cxo-guests__grid{ grid-template-columns: repeat(3, minmax(220px, 1fr)); }
}
@media (max-width: 820px){
  .cxo-guests__grid{ grid-template-columns: repeat(2, minmax(220px, 1fr)); }
}
@media (max-width: 520px){
  .cxo-guests__grid{ grid-template-columns: 1fr; }
}

/* card */
.cxo-guest{
  width: 100%;
  max-width: 280px;
  display: grid;
  justify-items: center;
  text-align: center;
}

/* avatar */
.cxo-guest__avatar{
  width: 120px; height: 120px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  box-shadow: var(--shadow);
}

/* name / role */
.cxo-guest__name{
  margin: 12px 0 4px;
  font-size: 15px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--primary);
  letter-spacing: .25px;
}
.cxo-guest__role{
  margin: 0 0 10px;
  color: var(--text-muted);
  font: 400 14px/1.45 var(--font-sans);
}

/* episode pill */
.cxo-guest__episode{
  width: 100%;
  background: var(--muted);
  border: 1px solid var(--border);
  border-radius: var(--border-radius);
  text-decoration: none;
  color: var(--text-color);
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  transition: border-color var(--transition), box-shadow var(--transition), transform .06s ease;
}
.cxo-guest__episode:hover{
  border-color: color-mix(in srgb, var(--secondary-color) 22%, var(--border) 78%);
  box-shadow: 0 6px 20px rgba(0,0,0,.08);
  transform: translateY(-1px);
}

/* play icon */
.cxo-guest__play svg{ width: 28px; height: 28px; }
.cxo-guest__play circle{
  fill: #fff; stroke: var(--secondary-color); stroke-width: 2;
}
.cxo-guest__play path{ fill: var(--secondary-color); }

/* episode title */
.cxo-guest__ep-title{
  text-align: left;
  font: italic 400 14px/1.45 var(--font-sans);
  color: var(--text-muted);
}

/* dark-on-hover option (2025 feel) */
@media (hover:hover){
  .cxo-guest__episode:hover .cxo-guest__ep-title{
    color: color-mix(in srgb, var(--text-color) 80%, var(--text-muted) 20%);
    font-style: normal;
  }
}

/* --- Minimal hover & tidy clamping ---------------------------------- */

/* Episode card: calm hover (no transform, no shadow) */
.cxo-guest__episode{
  transition: border-color var(--transition), background-color var(--transition);
}
.cxo-guest__episode:hover{
  background-color: color-mix(in srgb, var(--muted) 92%, white 8%);
  border-color: color-mix(in srgb, var(--secondary-color) 18%, var(--border) 82%);
}

/* Play icon: subtle color shift only */
.cxo-guest__play svg{ transition: color var(--transition), fill var(--transition), stroke var(--transition); }
.cxo-guest__play circle{ fill:#fff; stroke: var(--secondary-color); stroke-width:2; }
.cxo-guest__play path{ fill: var(--secondary-color); }
.cxo-guest__episode:hover .cxo-guest__play circle{ stroke: var(--primary); }
.cxo-guest__episode:hover .cxo-guest__play path{ fill: var(--primary); }

/* Title clamp: two lines + ellipsis for symmetry */
.cxo-guest__ep-title{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.35;
  max-height: calc(1.35em * 3);   /* keeps episode cards same height */
  color: var(--text-muted);
}

/* Optional: keep name/role from pushing heights too much */
.cxo-guest__name{ min-height: 1.6em; }   /* one-line uppercased name */
.cxo-guest__role{
  min-height: calc(1.45em * 2);          /* up to two lines for role */
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ===== CXO Hosts (scoped) ============================================ */
.cxo-hosts{
  position: relative;
  isolation: isolate;
  padding: clamp(56px, 9vw, 96px) 0;
  color: var(--on-primary);
  /* subtle modern wash over brand secondary */
  background:
    radial-gradient(1000px 520px at 30% -10%,
      color-mix(in srgb, white 8%, var(--secondary-color) 92%),
      transparent 60%),
    radial-gradient(900px 520px at 80% 120%,
      color-mix(in srgb, white 6%, var(--secondary-color) 94%),
      transparent 62%),
    var(--secondary-color);
}
.cxo-hosts .container-1200{
  max-width: var(--max-width);
  margin: 0 auto;
  padding-inline: clamp(16px, 4vw, 32px);
  text-align: center;
}

.cxo-hosts__title{
  margin: 0 0 clamp(24px, 4vw, 40px);
  font-family: var(--font-condensed);
  font-weight: 700;
  font-size: clamp(22px, 3vw, 32px);
  color: var(--on-primary);
  letter-spacing: .02em;
}

/* grid with two hosts centered */
.cxo-hosts__grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  gap: clamp(28px, 4vw, 48px);
  justify-content: center;
  justify-items: center;
}
.cxo-hosts__grid-one{
  display: grid;
  gap: clamp(28px, 4vw, 48px);
  justify-content: center;
  justify-items: center;
}

@media (max-width: 640px){
  .cxo-hosts__grid{ grid-template-columns: 1fr; }
}

/* host card */
.cxo-host{
  display: grid;
  justify-items: center;
  text-align: center;
  max-width: 340px;
}

.cxo-host__avatar{
  width: 160px; height: 160px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  /* subtle ring + depth so it reads on blue */
  box-shadow:
    0 0 0 4px rgba(255,255,255,.25),
    0 10px 24px rgba(0,0,0,.18);
}

/* name / role */
.cxo-host__name{
  margin: 14px 0 6px;
  font-family: var(--font-condensed);
  font-weight: 700;
  font-size: clamp(16px, 1.6vw, 18px);
  text-transform: uppercase;
  letter-spacing: .02em;
  color: #fff;
}
.cxo-host__role{
  margin: 0;
  color: color-mix(in srgb, var(--on-primary) 85%, transparent);
  font: 400 14px/1.5 var(--font-sans);
  opacity: .95;
}

/* minimal hover polish (optional) */
@media (hover:hover){
  .cxo-host__avatar{ transition: transform .12s ease, box-shadow .2s ease; }
  .cxo-host:hover .cxo-host__avatar{
    transform: translateY(-2px);
    box-shadow:
      0 0 0 4px rgba(255,255,255,.3),
      0 14px 30px rgba(0,0,0,.22);
  }
}

/* ===== CXO – HubSpot form (scoped) ===================================== */
.cxo-form{
  background:
    radial-gradient(1200px 520px at 90% 120%, color-mix(in srgb, var(--primary) 6%, white 94%), transparent 60%),
    var(--background);
  color: var(--text-color);
  padding: clamp(56px, 9vw, 96px) 0;
}

.cxo-form .container-1200{
  max-width: var(--max-width);
  margin: 0 auto;
  padding-inline: clamp(16px, 4vw, 32px);
}

.cxo-form__head{
  text-align: center;
  margin-bottom: clamp(18px, 3vw, 28px);
}
.cxo-form__title{
  margin: 0 0 .35rem;
  font-family: var(--font-condensed);
  font-weight: 700;
  font-size: clamp(22px, 3vw, 32px);
  color: var(--text-color);
}
.cxo-form__intro{
  margin: 0 auto;
  max-width: 70ch;
  color: var(--text-muted);
  font: 400 clamp(15px, 1.1vw, 17px)/1.65 var(--font-sans);
}

/* Center the HubSpot form and keep it narrow for readability */
.cxo-form__wrap{
  max-width: 760px;
  margin: 0 auto;
}

/* ---------- HubSpot default class hooks (scoped to .cxo-form) ---------- */
.cxo-form .hs-form{
  --field-gap: 14px;
}
.cxo-form .hs-form fieldset{
  max-width: 100% !important;
}
.cxo-form .hs-form .hs-form-field{
  margin-bottom: var(--field-gap);
}

/* Labels */
.cxo-form .hs-form label{
  font: 600 14px/1.4 var(--font-sans);
  color: var(--text-color);
  margin-bottom: 6px;
  display: inline-block;
}

/* Text inputs / textareas / selects */
.cxo-form .hs-input,
.cxo-form .hs-form input[type="text"],
.cxo-form .hs-form input[type="email"],
.cxo-form .hs-form input[type="tel"],
.cxo-form .hs-form select,
.cxo-form .hs-form textarea{
  width: 100%;
  padding: 12px 14px;
  background: var(--background-light);
  color: var(--text-color);
  border: 1px solid var(--border);
  border-radius: var(--border-radius);
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition);
  box-shadow: none;
}

/* Focus ring using your tokens */
.cxo-form .hs-input:focus,
.cxo-form .hs-form input:focus,
.cxo-form .hs-form select:focus,
.cxo-form .hs-form textarea:focus{
  border-color: color-mix(in srgb, var(--secondary-color) 40%, var(--border) 60%);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--secondary-color) 18%, transparent);
}

/* Checkbox / radio spacing */
.cxo-form .hs-form .inputs-list{
  margin: 6px 0 0;
}
.cxo-form .hs-form .inputs-list > li{
  margin: 6px 0;
}

/* Errors */
.cxo-form .hs-error-msg{
  color: #b3261e;
  font-size: 13px;
  margin-top: 6px;
}

/* Submit button (HubSpot uses .hs-button) */
.cxo-form .hs-button{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 22px !important;
  background: var(--primary) !important;
  color: var(--on-primary) !important;
  border: 1px solid var(--primary) !important;
  border-radius: var(--border-radius) !important;
  font: 800 14px/1 var(--font-sans) !important;
  text-transform: uppercase;
  letter-spacing: .4px;
  cursor: pointer;
  transition: filter var(--transition), transform .06s ease, box-shadow var(--transition);
  box-shadow: 0 6px 18px color-mix(in srgb, var(--primary) 35%, transparent);
}
.cxo-form .hs-button:hover{ filter: brightness(1.06); }
.cxo-form .hs-button:active{ transform: translateY(1px); }
.cxo-form .hs-button:focus-visible{
  outline: 2px solid var(--ring);
  outline-offset: 2px;
}

/* Horizontal rule between field groups (optional) */
.cxo-form .hs-form .hs-richtext{ color: var(--text-muted); }

/* Responsive tweaks */
@media (max-width: 640px){
  .cxo-form__wrap{ max-width: 100%; }
}

/* --- Scroll hardening for Chrome/iOS/Android ------------------------- */


/* If you ever switch to full-height hero, prefer min-height over fixed height */
.cxo-hero-bg--full {
  min-height: 100svh;   /* safe viewport unit; avoids mobile 100vh bugs */
}

/* Safety: any full-width sections should never block scrolling */
.cxo-intro,
.cxo-guests,
.cxo-hosts,
.cxo-form {
  overflow: visible;
}
