/* ==========================================================================
   ByteCore Stack — Homepage CSS  (bcs- scoped)
   ========================================================================== */

/* ── Wrapper ─────────────────────────────────────────────────────────────── */
/* Cancel .bpt-main padding AND pull up by header height so hero bleeds under
   the now-transparent sticky header */
.bpt-main:has(.bcs-home) { padding-block: 0; }
.bcs-home {
  margin-top:    calc(-1 * var(--bpt-header-h));
  margin-bottom: 0;
}

/* ── Section spacing ─────────────────────────────────────────────────────── */
.bcs-hero     { padding: calc(var(--bpt-header-h) + clamp(3rem, 5vw, 4.5rem)) 0 clamp(3rem, 5vw, 4.5rem); }
.bcs-about,
.bcs-plugins,
.bcs-process,
.bcs-oss,
.bcs-newsletter,
.bcs-cta { padding: clamp(4rem, 8vw, 7rem) 0; }
.bcs-strip { padding: clamp(1.75rem, 3vw, 2.5rem) 0; }

/* ── Section headings ────────────────────────────────────────────────────── */
.bcs-section-head {
  text-align:    center;
  max-width:     600px;
  margin:        0 auto clamp(3rem, 5vw, 4rem);
  display:       flex;
  flex-direction:column;
  align-items:   center;
  gap:           .75rem;
}
.bcs-section-head h2 {
  font-size:   clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 700;
  line-height: 1.2;
  color:       var(--bpt-text);
}
.bcs-section-head p {
  font-size:  .95rem;
  color:      var(--bpt-text-2);
  line-height:1.7;
}

/* ── Badge ───────────────────────────────────────────────────────────────── */
.bcs-badge {
  display:        inline-flex;
  align-items:    center;
  gap:            .4rem;
  padding:        .3rem .8rem;
  font-size:      .75rem;
  font-weight:    600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color:          var(--bpt-accent-h);
  background:     var(--bpt-accent-dim);
  border:         1px solid rgba(99, 102, 241, .3);
  border-radius:  999px;
  width: fit-content;
}

/* ── Gradient text ───────────────────────────────────────────────────────── */
.bcs-gradient-text {
  background:              linear-gradient(135deg, #818cf8 0%, #a78bfa 50%, #38bdf8 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip:         text;
}

/* ── Separator ───────────────────────────────────────────────────────────── */
.bcs-sep { color: var(--bpt-text-3); }

/* ════════════════════════════════════════════════════════════════════════════
   BUTTONS  (bcs-btn system — self-contained, no bpl- dependency)
   ════════════════════════════════════════════════════════════════════════════ */
.bcs-btn {
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  gap:             .5rem;
  padding:         .65rem 1.4rem;
  font-size:       .9rem;
  font-weight:     600;
  line-height:     1;
  border-radius:   var(--bpt-radius);
  border:          1px solid transparent;
  cursor:          pointer;
  text-decoration: none;
  white-space:     nowrap;
  transition:      background var(--bpt-t), border-color var(--bpt-t), box-shadow var(--bpt-t), transform var(--bpt-t);
  user-select:     none;
}
.bcs-btn:focus-visible {
  outline:        2px solid var(--bpt-accent-h);
  outline-offset: 3px;
}

/* Primary */
.bcs-btn--primary {
  background:   var(--bpt-accent);
  border-color: var(--bpt-accent);
  color:        #fff;
}
.bcs-btn--primary:hover {
  background:   var(--bpt-accent-h);
  border-color: var(--bpt-accent-h);
  box-shadow:   0 4px 20px rgba(99,102,241,.4);
  transform:    translateY(-1px);
  color:        #fff;
}

/* Ghost */
.bcs-btn--ghost {
  background:   transparent;
  border-color: var(--bpt-border-light);
  color:        var(--bpt-text-2);
}
.bcs-btn--ghost:hover {
  border-color: var(--bpt-accent-h);
  color:        var(--bpt-text);
  background:   rgba(99,102,241,.06);
  transform:    translateY(-1px);
}

/* Sizes */
.bcs-btn--lg  { padding: .8rem 1.75rem;  font-size: .95rem; }
.bcs-btn--xl  { padding: 1rem  2.25rem;  font-size: 1.05rem; }

/* ════════════════════════════════════════════════════════════════════════════
   1. HERO  — canvas line-pattern + cursor parallax
   ════════════════════════════════════════════════════════════════════════════ */
.bcs-hero {
  position:   relative;
  overflow:   hidden;
  background: var(--bpt-bg);
  text-align: center;
  min-height: clamp(460px, 70vh, 720px);
  display:    flex;
  align-items:center;
}

/* Background layer — canvas fills it */
.bcs-hero__bg {
  position:       absolute;
  inset:          0;
  pointer-events: none;
  z-index:        0;
}

.bcs-hero__canvas {
  position: absolute;
  inset:    0;
  width:    100%;
  height:   100%;
  display:  block;
}

/* Radial glows */
.bcs-hero__glow {
  position:  absolute;
  top:       -20%;
  left:      50%;
  transform: translateX(-50%);
  width:     clamp(600px, 90vw, 1200px);
  height:    clamp(500px, 70vw, 900px);
  background:radial-gradient(ellipse at center,
               rgba(99,102,241,.22) 0%,
               rgba(99,102,241,.06) 45%,
               transparent 70%);
  border-radius:50%;
  will-change:transform;
  transition: transform .1s ease-out;
}
.bcs-hero__glow--2 {
  top:       30%;
  left:      30%;
  width:     clamp(300px, 40vw, 600px);
  height:    clamp(300px, 40vw, 600px);
  background:radial-gradient(ellipse at center,
               rgba(167,139,250,.12) 0%,
               transparent 65%);
}

.bcs-hero__inner {
  position:       relative;
  z-index:        1;
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            1.25rem;
  padding-top:    clamp(2rem, 4vw, 3rem);
  padding-bottom: clamp(2rem, 4vw, 3rem);
  width:          100%;
}

.bcs-hero__eyebrow { margin-bottom: .1rem; }

.bcs-hero__title {
  font-size:      clamp(2.4rem, 6vw, 4.4rem);
  font-weight:    800;
  line-height:    1.1;
  color:          var(--bpt-text);
  letter-spacing: -.03em;
  max-width:      800px;
  margin:         0;
}

.bcs-hero__desc {
  font-size:   1.05rem;
  line-height: 1.75;
  color:       var(--bpt-text-2);
  max-width:   560px;
  margin:      0;
}

.bcs-hero__actions {
  display:         flex;
  flex-wrap:       wrap;
  gap:             .85rem;
  align-items:     center;
  justify-content: center;
  margin-top:      .25rem;
}

.bcs-hero__trust {
  display:         flex;
  align-items:     center;
  flex-wrap:       wrap;
  gap:             .5rem;
  font-size:       .82rem;
  color:           var(--bpt-text-3);
  justify-content: center;
  margin-top:      .25rem;
}

/* ════════════════════════════════════════════════════════════════════════════
   2. VALUE STRIP
   ════════════════════════════════════════════════════════════════════════════ */
.bcs-strip {
  background:    var(--bpt-surface);
  border-top:    1px solid var(--bpt-border);
  border-bottom: 1px solid var(--bpt-border);
}

.bcs-strip__inner {
  display:               grid;
  grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  align-items:           center;
  gap:                   0;
}

.bcs-strip__item {
  display:         flex;
  align-items:     center;
  gap:             1rem;
  padding:         .5rem clamp(1rem, 2.5vw, 2rem);
  justify-content: center;
}

.bcs-strip__item strong {
  display:     block;
  font-size:   .9rem;
  font-weight: 700;
  color:       var(--bpt-text);
  line-height: 1.3;
}

.bcs-strip__item span {
  display:   block;
  font-size: .78rem;
  color:     var(--bpt-text-2);
  line-height:1.4;
}

.bcs-strip__icon {
  width:           42px;
  height:          42px;
  flex-shrink:     0;
  border-radius:   var(--bpt-radius);
  background:      var(--bpt-accent-dim);
  border:          1px solid rgba(99,102,241,.2);
  display:         flex;
  align-items:     center;
  justify-content: center;
  color:           var(--bpt-accent-h);
}

.bcs-strip__div {
  width:           1px;
  height:          3rem;
  background:      var(--bpt-border-light);
  flex-shrink:     0;
  justify-self:    center;
}

/* ════════════════════════════════════════════════════════════════════════════
   3. ABOUT
   ════════════════════════════════════════════════════════════════════════════ */
.bcs-about {
  background: var(--bpt-bg);
  position:   relative;
  overflow:   hidden;
}
.bcs-about::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(99,102,241,.13) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: 0;
}
.bcs-about__inner { position: relative; z-index: 1; }

.bcs-about__inner {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   clamp(3rem, 6vw, 6rem);
  align-items:           center;
}

.bcs-about__copy {
  display:        flex;
  flex-direction: column;
  gap:            1.1rem;
}

.bcs-about__copy h2 {
  font-size:   clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 700;
  line-height: 1.2;
  margin:      0;
}

.bcs-about__copy p {
  font-size:   .95rem;
  color:       var(--bpt-text-2);
  line-height: 1.75;
  margin:      0;
}

.bcs-check-list {
  list-style:     none;
  padding:        0;
  margin:         .25rem 0 0;
  display:        flex;
  flex-direction: column;
  gap:            .65rem;
}

.bcs-check-list li {
  display:     flex;
  align-items: center;
  gap:         .6rem;
  font-size:   .9rem;
  color:       var(--bpt-text-2);
}

.bcs-check-list li svg { flex-shrink: 0; color: var(--bpt-success); }

/* Code block visual */
.bcs-code-block {
  background:    var(--bpt-surface);
  border:        1px solid var(--bpt-border-light);
  border-radius: var(--bpt-radius-lg);
  overflow:      hidden;
  box-shadow:    0 24px 60px rgba(0,0,0,.5), 0 0 0 1px rgba(99,102,241,.08);
}

.bcs-code-block__chrome {
  display:       flex;
  align-items:   center;
  gap:           .4rem;
  padding:       .6rem .9rem;
  background:    var(--bpt-surface-2);
  border-bottom: 1px solid var(--bpt-border);
}

.bcs-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.bcs-dot--red    { background: #f43f5e; }
.bcs-dot--yellow { background: #f59e0b; }
.bcs-dot--green  { background: #10b981; }

.bcs-code-block__lang {
  margin-left: .5rem;
  font-size:   .72rem;
  color:       var(--bpt-text-3);
  font-family: var(--bpt-font);
}

.bcs-code-block__body {
  margin:     0;
  padding:    1.5rem 1.75rem;
  font-family:var(--bpt-mono);
  font-size:  .82rem;
  line-height:1.85;
  color:      var(--bpt-text-2);
  white-space:pre;
  overflow-x: auto;
}

.bcs-c-comment { color: var(--bpt-text-3); }
.bcs-c-key     { color: var(--bpt-accent-h); }
.bcs-c-val     { color: var(--bpt-sky); }
.bcs-c-ok      { color: var(--bpt-success); }

/* ════════════════════════════════════════════════════════════════════════════
   4. PLUGINS
   ════════════════════════════════════════════════════════════════════════════ */
.bcs-plugins {
  background:    var(--bpt-surface);
  border-top:    1px solid var(--bpt-border);
  border-bottom: 1px solid var(--bpt-border);
}

.bcs-plugins__grid {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   1.5rem;
  align-items:           start;
}

.bcs-plugin-card {
  display:        flex;
  flex-direction: column;
  gap:            1.25rem;
  padding:        2rem 1.75rem;
  border-radius:  var(--bpt-radius-lg);
  border:         1px solid var(--bpt-border);
  background:     var(--bpt-surface-2);
  transition:     border-color var(--bpt-t), box-shadow var(--bpt-t);
  position:       relative;
  overflow:       hidden;
  height:         100%;
}

.bcs-plugin-card::before {
  content:    '';
  position:   absolute;
  top:        0; left: 0; right: 0;
  height:     2px;
  background: linear-gradient(90deg, var(--bpt-accent), #a78bfa, var(--bpt-sky));
  opacity:    0;
  transition: opacity var(--bpt-t);
}

.bcs-plugin-card--live::before { opacity: 1; }

.bcs-plugin-card--live:hover {
  border-color: var(--bpt-border-light);
  box-shadow:   0 12px 40px rgba(0,0,0,.4), 0 0 0 1px rgba(99,102,241,.15);
}

.bcs-plugin-card--soon {
  background:   var(--bpt-surface-3);
  border-style: dashed;
}

.bcs-plugin-card__header {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             1rem;
  flex-wrap:       wrap;
}

.bcs-plugin-card__icon {
  width:           52px;
  height:          52px;
  border-radius:   var(--bpt-radius);
  background:      var(--bpt-accent-dim);
  border:          1px solid rgba(99,102,241,.25);
  display:         flex;
  align-items:     center;
  justify-content: center;
  color:           var(--bpt-accent-h);
  flex-shrink:     0;
}

.bcs-plugin-card__icon--soon {
  background:   var(--bpt-surface-2);
  border-color: var(--bpt-border-light);
  color:        var(--bpt-text-3);
}

/* Status pills */
.bcs-status-pill {
  display:        inline-flex;
  align-items:    center;
  gap:            .4rem;
  padding:        .25rem .7rem;
  border-radius:  999px;
  font-size:      .72rem;
  font-weight:    600;
  letter-spacing: .04em;
  text-transform: uppercase;
  white-space:    nowrap;
}

.bcs-status-pill--live {
  background: var(--bpt-success-dim);
  color:      var(--bpt-success);
}

.bcs-status-pill--soon {
  background: var(--bpt-warning-dim);
  color:      var(--bpt-warning);
}

.bcs-status-dot {
  width:        7px;
  height:       7px;
  border-radius:50%;
  background:   var(--bpt-success);
  animation:    bcs-pulse 2s ease-in-out infinite;
}

@keyframes bcs-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: .3; }
}

.bcs-plugin-card__name {
  font-size:   1.2rem;
  font-weight: 700;
  color:       var(--bpt-text);
  margin:      0;
}

.bcs-plugin-card__desc {
  font-size:   .9rem;
  color:       var(--bpt-text-2);
  line-height: 1.7;
  margin:      0;
}

.bcs-plugin-card__desc code {
  font-family:   var(--bpt-mono);
  font-size:     .83em;
  color:         var(--bpt-accent-h);
  background:    var(--bpt-accent-dim);
  padding:       .15em .4em;
  border-radius: var(--bpt-radius-sm);
}

.bcs-plugin-card__features {
  list-style:     none;
  padding:        0;
  margin:         0;
  display:        flex;
  flex-direction: column;
  gap:            .55rem;
}

.bcs-plugin-card__features li {
  display:     flex;
  align-items: center;
  gap:         .55rem;
  font-size:   .875rem;
  color:       var(--bpt-text-2);
}

.bcs-plugin-card__features li svg { flex-shrink: 0; color: var(--bpt-success); }

.bcs-plugin-card__tags {
  display:  flex;
  flex-wrap:wrap;
  gap:      .4rem;
}

.bcs-tag {
  padding:        .2rem .6rem;
  border-radius:  999px;
  font-size:      .7rem;
  font-weight:    600;
  letter-spacing: .05em;
  background:     var(--bpt-surface-3);
  border:         1px solid var(--bpt-border);
  color:          var(--bpt-text-3);
  text-transform: uppercase;
}

.bcs-plugin-card__actions {
  display:     flex;
  flex-wrap:   wrap;
  gap:         .75rem;
  margin-top:  auto;
  padding-top: .5rem;
}

/* ── Roadmap ─────────────────────────────────────────────────────────────── */
.bcs-roadmap {
  display:        flex;
  flex-direction: column;
  gap:            0;
  padding:        .25rem 1.1rem;
  background:     var(--bpt-surface);
  border:         1px solid var(--bpt-border);
  border-radius:  var(--bpt-radius);
}

.bcs-roadmap__item {
  display:       flex;
  align-items:   center;
  gap:           .75rem;
  padding:       .75rem 0;
  border-bottom: 1px solid var(--bpt-border);
}
.bcs-roadmap__item:last-child  { border-bottom: none; }

.bcs-roadmap__icon {
  width:           32px;
  height:          32px;
  flex-shrink:     0;
  border-radius:   var(--bpt-radius-sm);
  background:      var(--bpt-surface-3);
  border:          1px solid var(--bpt-border);
  display:         flex;
  align-items:     center;
  justify-content: center;
  color:           var(--bpt-text-3);
}

.bcs-roadmap__item > div:nth-child(2) { flex: 1; min-width: 0; }

.bcs-roadmap__item strong {
  display:     block;
  font-size:   .85rem;
  font-weight: 600;
  color:       var(--bpt-text);
  line-height: 1.3;
}

.bcs-roadmap__item > div:nth-child(2) > span {
  display:   block;
  font-size: .75rem;
  color:     var(--bpt-text-3);
}

.bcs-roadmap__status {
  flex-shrink:    0;
  font-size:      .7rem;
  font-weight:    600;
  color:          var(--bpt-warning);
  background:     var(--bpt-warning-dim);
  padding:        .2rem .55rem;
  border-radius:  999px;
  white-space:    nowrap;
}

/* ════════════════════════════════════════════════════════════════════════════
   5. PROCESS
   ════════════════════════════════════════════════════════════════════════════ */
.bcs-process {
  background: var(--bpt-bg);
  position:   relative;
  overflow:   hidden;
}
.bcs-process::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(99,102,241,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(99,102,241,.06) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
  z-index: 0;
}
.bcs-process > .bpt-container { position: relative; z-index: 1; }

.bcs-steps {
  display:         flex;
  align-items:     flex-start;
  justify-content: center;
  gap:             0;
}

.bcs-step {
  flex:           1;
  max-width:      280px;
  text-align:     center;
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            1.1rem;
}

.bcs-step__num {
  font-family:    var(--bpt-mono);
  font-size:      .72rem;
  font-weight:    700;
  color:          var(--bpt-accent);
  letter-spacing: .14em;
}

.bcs-step__icon {
  width:           68px;
  height:          68px;
  border-radius:   var(--bpt-radius-lg);
  background:      var(--bpt-surface-2);
  border:          1px solid var(--bpt-border-light);
  display:         flex;
  align-items:     center;
  justify-content: center;
  color:           var(--bpt-accent-h);
  box-shadow:      0 4px 20px rgba(99,102,241,.12);
}

.bcs-step h3 {
  font-size:   1.05rem;
  font-weight: 700;
  color:       var(--bpt-text);
  margin:      0;
}

.bcs-step p {
  font-size:   .875rem;
  color:       var(--bpt-text-2);
  line-height: 1.7;
  margin:      0;
}

.bcs-step__connector {
  flex-shrink: 0;
  align-self:  center;
  margin-top:  -2.5rem;
  color:       var(--bpt-text-3);
  padding:     0 .5rem;
}

/* ════════════════════════════════════════════════════════════════════════════
   6. OPEN SOURCE
   ════════════════════════════════════════════════════════════════════════════ */
.bcs-oss {
  background:    var(--bpt-surface);
  border-top:    1px solid var(--bpt-border);
  border-bottom: 1px solid var(--bpt-border);
  position:      relative;
  overflow:      hidden;
}
.bcs-oss::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 18px,
    rgba(99,102,241,.05) 18px,
    rgba(99,102,241,.05) 19px
  );
  pointer-events: none;
  z-index: 0;
}
.bcs-oss__inner { position: relative; z-index: 1; }

.bcs-oss__inner {
  display:               grid;
  grid-template-columns: 1fr 380px;
  gap:                   clamp(2.5rem, 5vw, 5rem);
  align-items:           center;
}

.bcs-oss__copy {
  display:        flex;
  flex-direction: column;
  gap:            1rem;
}

.bcs-oss__copy h2 {
  font-size:   clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 700;
  margin:      0;
}

.bcs-oss__copy p {
  font-size:   .95rem;
  color:       var(--bpt-text-2);
  max-width:   520px;
  margin:      0;
}

.bcs-oss__actions {
  display:  flex;
  flex-wrap:wrap;
  gap:      .75rem;
}

.bcs-oss__stats {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   .85rem;
  width:                 100%;
}

.bcs-oss__stat {
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  gap:             .4rem;
  padding:         1.5rem 1rem;
  background:      var(--bpt-surface-2);
  border:          1px solid var(--bpt-border);
  border-radius:   var(--bpt-radius);
  text-align:      center;
  color:           var(--bpt-accent-h);
  transition:      border-color var(--bpt-t), box-shadow var(--bpt-t);
}
.bcs-oss__stat:hover {
  border-color: rgba(99,102,241,.4);
  box-shadow:   0 4px 20px rgba(99,102,241,.1);
}

.bcs-oss__stat strong { font-size: 1.05rem; font-weight: 700; color: var(--bpt-text); }
.bcs-oss__stat span   { font-size: .75rem; color: var(--bpt-text-3); }

/* ════════════════════════════════════════════════════════════════════════════
   7. NEWSLETTER  (CF7 — centered card layout)
   ════════════════════════════════════════════════════════════════════════════ */
.bcs-newsletter {
  background:    var(--bpt-surface);
  border-top:    1px solid var(--bpt-border);
  border-bottom: 1px solid var(--bpt-border);
  position:      relative;
  overflow:      hidden;
}

.bcs-newsletter__bg {
  position:       absolute;
  inset:          0;
  background:     radial-gradient(ellipse 70% 80% at 50% 0%,
                    rgba(99,102,241,.1) 0%,
                    transparent 65%);
  pointer-events: none;
}

/* Two-col: copy left, form right */
.bcs-newsletter__inner {
  position:              relative;
  z-index:               1;
  display:               grid;
  grid-template-columns: 1fr 1.1fr;
  gap:                   clamp(2.5rem, 5vw, 5rem);
  align-items:           center;
}

/* Copy block */
.bcs-newsletter__copy {
  display:        flex;
  flex-direction: column;
  gap:            1rem;
}

.bcs-newsletter__copy h2 {
  font-size:      clamp(1.6rem, 3.5vw, 2.4rem);
  font-weight:    800;
  line-height:    1.15;
  letter-spacing: -.02em;
  margin:         0;
}

.bcs-newsletter__copy p {
  font-size:   .95rem;
  color:       var(--bpt-text-2);
  line-height: 1.7;
  margin:      0;
}

/* Perks pills row */
.bcs-newsletter__perks {
  display:   flex;
  flex-wrap: wrap;
  gap:       .5rem;
  list-style:none;
  padding:   0;
  margin:    .25rem 0 0;
}

.bcs-newsletter__perks li {
  display:       inline-flex;
  align-items:   center;
  gap:           .4rem;
  font-size:     .8rem;
  font-weight:   500;
  color:         var(--bpt-text-2);
  background:    var(--bpt-surface-2);
  border:        1px solid var(--bpt-border);
  border-radius: 999px;
  padding:       .3rem .8rem;
}

.bcs-newsletter__perks li svg { flex-shrink: 0; color: var(--bpt-success); }

/* Form side */
.bcs-newsletter__form-wrap { width: 100%; }

.bcs-newsletter__form-card {
  background:    var(--bpt-surface-2);
  border:        1px solid var(--bpt-border-light);
  border-radius: var(--bpt-radius-lg);
  padding:       2.25rem 2.5rem;
  box-shadow:    0 20px 60px rgba(0,0,0,.4), 0 0 0 1px rgba(99,102,241,.08);
  position:      relative;
  overflow:      hidden;
}

/* Decorative top accent line */
.bcs-newsletter__form-card::before {
  content:    '';
  position:   absolute;
  top:        0; left: 0; right: 0;
  height:     2px;
  background: linear-gradient(90deg, var(--bpt-accent), #a78bfa, var(--bpt-sky));
}

/* Form card heading */
.bcs-newsletter__form-header {
  display:        flex;
  flex-direction: column;
  gap:            .4rem;
  padding-bottom: 1.25rem;
  margin-bottom:  1.25rem;
  border-bottom:  1px solid var(--bpt-border);
}

.bcs-newsletter__form-header svg {
  color:      var(--bpt-accent-h);
  margin-bottom: .1rem;
}

.bcs-newsletter__form-header h3 {
  font-size:   1.05rem;
  font-weight: 700;
  color:       var(--bpt-text);
  margin:      0;
  line-height: 1.3;
}

.bcs-newsletter__form-header p {
  font-size:   .85rem;
  color:       var(--bpt-text-3);
  margin:      0;
  line-height: 1.55;
}

/* CF7 inner layout */
.bcs-newsletter__form-card .wpcf7 { margin: 0; }

.bcs-newsletter__form-card .wpcf7-form {
  display:        flex;
  flex-direction: column;
  gap:            1rem;
}

.bcs-newsletter__form-card .wpcf7-form p { margin: 0; }

/* Inline row: email field + submit side by side */
.bcs-newsletter__form-card .wpcf7-form .bcs-cf7-inline {
  display: flex;
  gap:     .6rem;
}

.bcs-newsletter__form-card input[type="text"],
.bcs-newsletter__form-card input[type="email"],
.bcs-newsletter__form-card textarea,
.bcs-newsletter__form-card select {
  width:         100%;
  padding:       .8rem 1.1rem;
  background:    var(--bpt-surface-3);
  border:        1px solid var(--bpt-border-light);
  border-radius: var(--bpt-radius);
  color:         var(--bpt-text);
  font-size:     .9rem;
  font-family:   var(--bpt-font);
  transition:    border-color var(--bpt-t), box-shadow var(--bpt-t);
  box-sizing:    border-box;
}

.bcs-newsletter__form-card input[type="text"]:focus,
.bcs-newsletter__form-card input[type="email"]:focus,
.bcs-newsletter__form-card textarea:focus {
  outline:      none;
  border-color: var(--bpt-accent-h);
  box-shadow:   0 0 0 3px rgba(99,102,241,.2);
}

.bcs-newsletter__form-card input::placeholder,
.bcs-newsletter__form-card textarea::placeholder { color: var(--bpt-text-3); }

.bcs-newsletter__form-card input[type="submit"],
.bcs-newsletter__form-card .wpcf7-submit {
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  width:           100%;
  padding:         .8rem 2rem;
  background:      var(--bpt-accent);
  border:          1px solid var(--bpt-accent);
  border-radius:   var(--bpt-radius);
  color:           #fff;
  font-size:       .95rem;
  font-weight:     600;
  cursor:          pointer;
  transition:      background var(--bpt-t), box-shadow var(--bpt-t), transform var(--bpt-t);
  font-family:     var(--bpt-font);
  white-space:     nowrap;
}

.bcs-newsletter__form-card input[type="submit"]:hover,
.bcs-newsletter__form-card .wpcf7-submit:hover {
  background:  var(--bpt-accent-h);
  box-shadow:  0 4px 20px rgba(99,102,241,.4);
  transform:   translateY(-1px);
}

.bcs-newsletter__form-card .wpcf7-not-valid-tip {
  font-size:  .78rem;
  color:      #f87171;
  margin-top: .3rem;
  display:    block;
  text-align: left;
}

.bcs-newsletter__form-card .wpcf7-response-output {
  margin:        .5rem 0 0;
  padding:       .75rem 1rem;
  border-radius: var(--bpt-radius);
  font-size:     .85rem;
  border:        1px solid var(--bpt-border);
  color:         var(--bpt-text-2);
}

.bcs-newsletter__form-card .wpcf7-mail-sent-ok {
  background:   var(--bpt-success-dim);
  border-color: var(--bpt-success);
  color:        var(--bpt-success);
}

.bcs-newsletter__form-card .wpcf7-mail-sent-ng,
.bcs-newsletter__form-card .wpcf7-validation-errors {
  background:   rgba(248,113,113,.1);
  border-color: #f87171;
  color:        #f87171;
}

.bcs-newsletter__form-card .wpcf7-spinner { display: none !important; }

/* ════════════════════════════════════════════════════════════════════════════
   8. CTA
   ════════════════════════════════════════════════════════════════════════════ */
.bcs-cta {
  position:   relative;
  overflow:   hidden;
  text-align: center;
  background: var(--bpt-bg);
  border-top: 1px solid var(--bpt-border);
}

.bcs-cta__bg {
  position:       absolute;
  inset:          0;
  pointer-events: none;
  z-index:        0;
}

.bcs-cta__glow {
  position:    absolute;
  top:         -30%;
  left:        50%;
  transform:   translateX(-50%);
  width:       min(900px, 100vw);
  height:      min(900px, 100vw);
  background:  radial-gradient(ellipse at center,
                 rgba(99,102,241,.28) 0%,
                 rgba(167,139,250,.1) 35%,
                 transparent 65%);
  border-radius:50%;
  animation:   bcs-cta-glow-pulse 6s ease-in-out infinite;
}

@keyframes bcs-cta-glow-pulse {
  0%, 100% { opacity: .8; transform: translateX(-50%) scale(1); }
  50%       { opacity: 1;  transform: translateX(-50%) scale(1.05); }
}

.bcs-cta__grid {
  position:         absolute;
  inset:            0;
  background-image: linear-gradient(rgba(99,102,241,.07) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(99,102,241,.07) 1px, transparent 1px);
  background-size:  60px 60px;
  mask-image:       radial-gradient(ellipse 90% 80% at 50% 50%, black 20%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 90% 80% at 50% 50%, black 20%, transparent 80%);
}

.bcs-cta__inner {
  position:       relative;
  z-index:        1;
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            1.5rem;
}

.bcs-cta__badge-wrap { margin-bottom: .25rem; }

.bcs-cta__title {
  font-size:      clamp(2rem, 5vw, 3.5rem);
  font-weight:    800;
  line-height:    1.1;
  letter-spacing: -.03em;
  color:          var(--bpt-text);
  margin:         0;
  max-width:      700px;
}

.bcs-cta__desc {
  font-size:   1.05rem;
  color:       var(--bpt-text-2);
  line-height: 1.7;
  max-width:   500px;
  margin:      0;
}

.bcs-cta__actions {
  display:         flex;
  flex-wrap:       wrap;
  gap:             .9rem;
  justify-content: center;
  margin-top:      .5rem;
}

.bcs-cta__trust {
  display:         flex;
  flex-wrap:       wrap;
  gap:             1.5rem;
  justify-content: center;
  font-size:       .82rem;
  color:           var(--bpt-text-3);
  margin-top:      .25rem;
}

.bcs-cta__trust span {
  display:     inline-flex;
  align-items: center;
  gap:         .35rem;
}

.bcs-cta__trust svg { color: var(--bpt-success); flex-shrink: 0; }

/* ════════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .bcs-about__inner  { grid-template-columns: 1fr; gap: 2.5rem; }
  .bcs-about__visual { order: -1; }
  .bcs-code-block    { max-width: 580px; margin: 0 auto; }

  .bcs-plugins__grid { grid-template-columns: 1fr; }

  .bcs-steps           { flex-direction: column; align-items: center; gap: 1.5rem; }
  .bcs-step            { max-width: 420px; }
  .bcs-step__connector { margin-top: 0; transform: rotate(90deg); }

  .bcs-oss__inner            { grid-template-columns: 1fr; }
  .bcs-oss__stats            { grid-template-columns: repeat(4, 1fr); }

  .bcs-newsletter__inner     { grid-template-columns: 1fr; }
  .bcs-newsletter__form-card { padding: 1.75rem; }
}

@media (max-width: 768px) {
  /* Strip: 2×2 grid on tablet */
  .bcs-strip__inner {
    grid-template-columns: 1fr 1fr;
    gap:                   1px;
    background:            var(--bpt-border);
  }
  .bcs-strip__item {
    background:      var(--bpt-surface);
    padding:         clamp(1.75rem, 3vw, 2.5rem) 20px;
    justify-content: flex-start;
  }
  .bcs-strip .bpt-container { padding-inline: 0; }
  .bcs-strip__div { display: none; }

  .bcs-oss__stats { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 640px) {
  .bcs-hero { padding-top: clamp(5rem, 10vw, 7rem); }
  .bcs-hero__inner { padding-top: clamp(2.5rem, 5vw, 4rem); }
  .bcs-hero__title   { font-size: clamp(2rem, 8vw, 2.8rem); }
  .bcs-hero__actions { flex-direction: column; align-items: stretch; }
  .bcs-hero__actions .bcs-btn { justify-content: center; }

  .bcs-plugin-card         { padding: 1.5rem 1.25rem; }
  .bcs-plugin-card__actions { flex-direction: column; }
  .bcs-plugin-card__actions .bcs-btn { justify-content: center; width: 100%; }

  .bcs-cta__actions { flex-direction: column; align-items: stretch; }
  .bcs-cta__actions .bcs-btn { justify-content: center; }

  .bcs-strip        { padding: clamp(1.75rem, 3vw, 2.5rem) 20px; }
  .bcs-strip__inner { grid-template-columns: 1fr; }
  .bcs-strip__item  { border-bottom: 1px solid var(--bpt-border); padding: clamp(1.75rem, 3vw, 2.5rem) 0px; }
  .bcs-strip__item:last-child { border-bottom: none; }

  .bcs-newsletter__form-card { padding: 1.5rem 1.25rem; }
  .bcs-newsletter__perks     { gap: .4rem; }

  .bcs-cta__trust { gap: .85rem; }
}

@media (max-width: 400px) {
  .bcs-oss__stats      { grid-template-columns: 1fr 1fr; }
  .bcs-roadmap__status { display: none; }
}
