/* ===== Modular Rows: full-bleed image + full-bleed text with split ===== */

:root {
  --crs-radius: 16px;           /* curved corners on center-facing image edge */
  --crs-center-pad: 40px;       /* space from center seam for text */
  --crs-max-text-width: 640px;  /* reading width cap */
  --crs-image-vw: 50vw;         /* default image width (overridden per row inline) */
  --crs-content-vw: calc(100vw - var(--crs-image-vw));
  --crs-outer-pad: 20px;        /* distance from the screen edge for content */
}

/* Row wrapper */
.crs-row {
  position: relative;
  width: 100%;
  display: block;
  overflow: hidden;
}

/* Full-bleed image panel (width via CSS var) */
.crs-media {
  position: absolute;
  top: 0;
  bottom: 0;
  width: var(--crs-image-vw);
  overflow: hidden;
  z-index: 1;
}
.crs-media--right { right: 0; border-top-left-radius: var(--crs-radius); border-bottom-left-radius: var(--crs-radius); }
.crs-media--left  { left: 0;  border-top-right-radius: var(--crs-radius); border-bottom-right-radius: var(--crs-radius); }

.crs-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* Full-bleed content panel (takes the remaining vw) */
.crs-contentpane {
  position: absolute;
  top: 0;
  bottom: 0;
  width: var(--crs-content-vw);
  display: flex;
  align-items: center;
  z-index: 2;
  box-sizing: border-box; /* so padding doesn't expand width */
}
/* Anchor and add OUTER edge padding (20px) */
.crs-contentpane--left  { left: 0;  justify-content: flex-start; padding-left: var(--crs-outer-pad); }
.crs-contentpane--right { right: 0; justify-content: flex-end;  padding-right: var(--crs-outer-pad); }

/* Content block */
.crs-content {
  max-width: var(--crs-max-text-width);
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;     /* default: pin children to left edge */
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}

/* When IMAGE is RIGHT (row--right), content is LEFT */
.crs-row--right .crs-content {
  padding-right: var(--crs-center-pad); /* space from center seam */
  padding-left: 0;
  text-align: left;
  align-items: flex-start;
}

/* When IMAGE is LEFT (row--left), content is RIGHT */
.crs-row--left .crs-content {
  padding-left: var(--crs-center-pad);  /* space from center seam */
  padding-right: 0;
  text-align: right;
  align-items: flex-end;                 /* keep children flush to right edge */
}

/* Ensure heading + paragraph + actions align with the outer edge */
.crs-content > .crs-heading,
.crs-content > p,
.crs-content > .crs-actions {
  width: 100%;
}

/* Heading group */
.crs-heading {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.crs-row--left  .crs-heading { align-items: flex-end; }
.crs-row--right .crs-heading { align-items: flex-start; }

.crs-heading--inline {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 12px;
}
.crs-row--left .crs-heading--inline { flex-direction: row-reverse; }

.crs-content h2 {
  margin: 0 0 12px 0;
  font-size: 2rem;
  line-height: 1.1;
  letter-spacing: 0.2px;
}

.crs-content p {
  margin: 0;
  font-size: 18px;
  line-height: 1.6;
  max-width: 46ch;            /* readable measure; still hugs edge via alignment */
}

/* Actions & Button (default .button-link style) */
.crs-actions,
.button-link {
  text-align: center;
  margin-top: 16px;
  margin-bottom: 20px;
}

.crs-btn,
.button-link a {
  display: inline-block;
  padding: 10px 20px;
  background-color: #2c88d9;
  color: #fff;
  text-decoration: none;
  border-radius: 5px;
  font-weight: 600;
  line-height: 1;
  border: 1px solid rgba(0,0,0,0.1);
  transition: transform .08s ease, filter .15s ease, box-shadow .15s ease;
}

.crs-btn:hover,
.button-link a:hover { filter: brightness(0.97); }

.crs-btn:active,
.button-link a:active { transform: translateY(1px); }

.crs-btn:focus-visible,
.button-link a:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.35), 0 0 0 5px rgba(99,102,241,0.35);
}

/* Optional logo */
.crs-logo {
  max-width: 220px;
  height: auto;
  margin: 0 0 12px 0;
  display: block;
}

/* ---------- Mobile (stack) ---------- */
@media (max-width: 900px) {
  .crs-row { height: auto !important; padding: 28px 0; }

  .crs-media,
  .crs-contentpane {
    position: relative;
    width: 100%;
  }

  .crs-media {
    height: 260px;
    border-radius: var(--crs-radius);
    z-index: 1;
  }
  .crs-media--left,
  .crs-media--right { border-radius: var(--crs-radius); }

  /* Reset pane padding on mobile; content handles equal padding */
  .crs-contentpane { justify-content: flex-start; z-index: 2; padding: 0; }

  .crs-content {
    text-align: left;                 /* reset on phones */
    align-items: flex-start;          /* reset on phones */
    padding: 18px 20px 0 20px;        /* equal 20px edge padding on phones */
    max-width: none;                  /* allow full width */
  }
}
