:root {
  /* Light‑mode surface behind the left column */
  --c-light-bg: #F4F5F7;

  /* === Layout tuning knobs === */
  --asym-radius: 0.75rem;
  --asym-pad: clamp(1.3rem, 2.8vw, 2.45rem);
  --asym-gap: clamp(1rem, 2vw, 1.8rem);
  --asym-min-height: clamp(18rem, 26vw, 26rem);
}

/* Container */
.asym {
  display: flex;
  gap: var(--asym-gap);
  padding-block: 8rem;
  padding-inline: clamp(0.4rem, 1.8vw, 1.25rem);
  position: relative;
  align-items: center;
}

/* Shared column styles */
.asym .col {
  position: relative;
  padding: var(--asym-pad) !important;
  min-height: var(--asym-min-height);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

/* Left (narrow) column */
.asym .col:first-child {
  flex: 1 1 42%;
  background: var(--c-light-bg);
  color: var(--c-charcoal);
  border-radius: var(--asym-radius);
  --asym-media-fade-color: var(--c-light-bg);
  z-index: 2;
  max-width: none;
  height: auto;
}

/* Right (wide) column */
.asym .col:last-child {
  flex: 1.2 1 58%;
  background: #000;
  color: var(--c-white);
  margin-left: 0 !important;
  padding: var(--asym-pad) !important;
  border-radius: var(--asym-radius);
  --asym-media-fade-color: #000;
  z-index: 1;
  height: auto;
}

/* Image-only asym panel: larger media box, fixed gap, centered alignment */
.asym .col.asym-media-only{
  --asym-media-frame-pad: clamp(0.45rem, 0.9vw, 0.8rem);
  --asym-media-fade-edge: 10%;
  flex: 1.5 1 64%;
  align-self: center;
  padding: var(--asym-media-frame-pad) !important;
  aspect-ratio: var(--asym-media-ar, 16 / 10);
  min-height: clamp(18rem, 34vw, 34rem);
  max-height: min(82vh, 44rem);
  overflow: hidden;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  display: flex;
  align-items: center;
  justify-content: center;
}

.asym .col.asym-media-only.asym-media-portrait{
  flex: 1.05 1 46%;
  min-height: clamp(24rem, 46vw, 42rem);
  max-height: min(86vh, 50rem);
}

.asym .col.asym-media-only.asym-media-ultrawide{
  flex: 1.7 1 70%;
  min-height: clamp(17rem, 26vw, 28rem);
}

.asym .col.asym-has-media-sibling{
  flex: 0.9 1 36%;
}

.asym .col.asym-media-only > .colmedia{
  width: 100%;
  height: 100%;
  border-radius: inherit;
  overflow: hidden;
  background: var(--asym-media-fade-color);
}

.asym .col.asym-media-only > img,
.asym .col.asym-media-only > video,
.asym .col.asym-media-only > picture > img,
.asym .col.asym-media-only > .colmedia > img,
.asym .col.asym-media-only > .colmedia > video,
.asym .col.asym-media-only > .colmedia > picture > img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: none;
  transform-origin: center;
  border-radius: calc(var(--asym-radius) - 2px);
  border: 0;
  -webkit-mask-image: none;
  mask-image: none;
}

.asym .col.asym-media-only::after{
  content: "";
  position: absolute;
  inset: var(--asym-media-frame-pad);
  pointer-events: none;
  background:
    linear-gradient(to right,
      var(--asym-media-fade-color) 0%,
      transparent var(--asym-media-fade-edge),
      transparent calc(100% - var(--asym-media-fade-edge)),
      var(--asym-media-fade-color) 100%),
    linear-gradient(to bottom,
      var(--asym-media-fade-color) 0%,
      transparent var(--asym-media-fade-edge),
      transparent calc(100% - var(--asym-media-fade-edge)),
      var(--asym-media-fade-color) 100%);
}

.home-asym .home-asym-image {
  width: 100%;
  height: 100%;
  min-height: clamp(14rem, 24vw, 20rem);
  object-fit: cover;
  border-radius: 10px;
  transform: scale(0.92);
  transform-origin: center;
}

/* Add a subtle shadow so the overlap feels intentional */
.asym .col:first-child { box-shadow: 0 0 24px rgba(0,0,0,0.08); }

/* Tablet tighten */
@media (max-width: 1100px) {
  :root{
    --asym-pad: clamp(1.15rem, 3.4vw, 2rem);
    --asym-gap: clamp(0.9rem, 1.7vw, 1.45rem);
  }
  .asym{padding-block:5rem;}

  .asym .col.asym-media-only{
    min-height: clamp(17rem, 36vw, 30rem);
    max-height: min(78vh, 36rem);
  }
}

/* Mobile: stack the panels */
@media (max-width: 800px) {
  :root{
    --asym-pad: clamp(1rem, 4.5vw, 1.6rem);
    --asym-min-height: auto;
  }
  .asym {
    flex-direction: column;
    padding-top: clamp(1.75rem, 6vw, 2.75rem) !important;
    padding-bottom: clamp(1.75rem, 6vw, 2.75rem) !important;
    margin-top: 0;
    gap: clamp(0.8rem, 3vw, 1.25rem);
  }
  .asym .col {
    flex: 1 1 auto;
    margin-left: 0 !important;
    border-radius: 0;
    min-height: auto;
    padding: var(--asym-pad) !important;
    height: auto;
  }

  .asym .col.asym-media-only{
    flex: 1 1 auto;
    --asym-media-frame-pad: clamp(0.4rem, 1.8vw, 0.65rem);
    --asym-media-fade-edge: 11%;
    aspect-ratio: auto;
    min-height: clamp(14rem, 56vw, 24rem);
    max-height: none;
  }

  .asym .col.asym-media-only > img,
  .asym .col.asym-media-only > video,
  .asym .col.asym-media-only > picture > img,
  .asym .col.asym-media-only > .colmedia > img,
  .asym .col.asym-media-only > .colmedia > video,
  .asym .col.asym-media-only > .colmedia > picture > img{
    transform: none;
  }

  .asym .col:first-child { box-shadow: none; }
}
