/* =========================================
   ADRASA · Title (FLUID / CLAMP)
   Desktop/tablet scales fluidly
========================================= */

.adrasa-title {
  --adrasa-navy: #1c3066;

  /* Old behavior (kept) */
  --adrasa-title-size: clamp(2.5rem, 3.6vw, 3.5rem);
  --adrasa-title-lh: 0.95;

  /* New: allow different sizes per part (defaults keep old look) */
  --adrasa-title-size-regular: var(--adrasa-title-size);
  --adrasa-title-size-italic: var(--adrasa-title-size);
  --adrasa-title-lh-regular: var(--adrasa-title-lh);
  --adrasa-title-lh-italic: var(--adrasa-title-lh);

  /* Desktop/tablet uses scale */
  margin: 0;
  color: var(--adrasa-navy);
  line-height: var(--adrasa-title-lh);

  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;

  gap: var(--adrasa-cluster-xs, clamp(6px, 0.9vw, 10px));
}

/* Alignment mapping (desktop) */
.adrasa-title[data-align="left"]   { justify-content: flex-start; text-align: left; }
.adrasa-title[data-align="center"] { justify-content: center;     text-align: center; }
.adrasa-title[data-align="right"]  { justify-content: flex-end;   text-align: right; }

/* Tablet alignment mapping */
@media (max-width: 1024px) {
  .adrasa-title[data-align-tablet="left"]   { justify-content: flex-start; text-align: left; }
  .adrasa-title[data-align-tablet="center"] { justify-content: center;     text-align: center; }
  .adrasa-title[data-align-tablet="right"]  { justify-content: flex-end;   text-align: right; }
}

/* Mobile alignment mapping */
@media (max-width: 767.98px) {
  .adrasa-title[data-align-mobile="left"]   { justify-content: flex-start; text-align: left; }
  .adrasa-title[data-align-mobile="center"] { justify-content: center;     text-align: center; }
  .adrasa-title[data-align-mobile="right"]  { justify-content: flex-end;   text-align: right; }
}

/* Defaults only (Elementor Typography overrides) */
.adrasa-title__regular {
  font-family: "Roboto", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: var(--adrasa-title-size-regular);
  line-height: var(--adrasa-title-lh-regular);
}

.adrasa-title__italic {
  font-family: "Instrument Serif", serif;
  font-weight: 400;
  font-style: italic;
  font-size: var(--adrasa-title-size-italic);
  line-height: var(--adrasa-title-lh-italic);
  margin: 0;
}

/* =========================================
   Title + Supporting Text Layout
   - Desktop: 2 columns (scaled)
   - Mobile: stacked (Figma px, NOT scaled)
========================================= */

.adrasa-title-wrap {
  --adrasa-title-aside-gap: var(--adrasa-section-space-sm, 4.375rem);

  --adrasa-title-max: var(--adrasa-measure-xs, 19.4375rem);
  --adrasa-title-aside-max: var(--adrasa-measure-lg, 45.625rem);

  width: 100%;
  display: grid;

  grid-template-columns:
    minmax(0, min(100%, var(--adrasa-title-max)))
    minmax(0, min(100%, var(--adrasa-title-aside-max)));

  column-gap: var(--adrasa-title-aside-gap);
  align-items: start;
}

.adrasa-title-wrap .adrasa-title {
  margin: 0;
  width: 100%;
  max-width: var(--adrasa-title-max);
}

.elementor-widget-adrasa-title .elementor-widget-container {
  width: 100%;
}

@media (min-width: 992px) {
  .elementor-widget-adrasa-title .elementor-widget-container {
    max-width: 83.75rem;
    margin-left: auto;
    margin-right: auto;
  }
}

.adrasa-title__aside {
  width: 100%;
  max-width: var(--adrasa-title-aside-max);
  color: var(--adrasa-navy);
}

.adrasa-title__aside-lead {
  margin: 0 0 var(--adrasa-stack-2xs, 10px) 0;
  font-family: "Roboto", sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.15;
  color: var(--adrasa-navy);
}

.adrasa-title__aside-body {
  margin: 0;
  font-family: "Roboto", sans-serif;
  font-weight: 400;
  font-size: 18px;
  line-height: 1.25;
  color: var(--adrasa-navy);
}

/* =========================================
   MOBILE (≤ 991.98px)
   Preserve Figma proportion, not Figma canvas width
========================================= */

@media (max-width: 991.98px) {
  .adrasa-title-wrap {
    grid-template-columns: 1fr;
    row-gap: var(--adrasa-stack-2xs, 2px);
    --adrasa-title-max: 100%;
    --adrasa-title-aside-max: min(100%, var(--adrasa-measure-sm, 24rem));
  }

  .adrasa-title-wrap .adrasa-title,
  .adrasa-title-wrap .adrasa-title__aside {
    max-width: 100%;
  }

  .adrasa-title {
    line-height: 1;
    gap: var(--adrasa-cluster-xs, 6px);
  }

  .adrasa-title__regular {
    font-size: clamp(2rem, 7vw, 2.625rem);
    line-height: 0.97;
  }

  .adrasa-title__italic {
    font-size: clamp(2.375rem, 8vw, 3.1875rem);
    line-height: 0.97;
    margin: 0;
  }

  .adrasa-title__aside-lead {
    font-size: var(--adrasa-type-lg, 18px);
    line-height: 1.15;
    margin: 0 0 var(--adrasa-stack-sm, 20px) 0;
  }

  .adrasa-title__aside-body {
    font-size: var(--adrasa-type-lg, 18px);
    line-height: 1.25;
  }

  .adrasa-title-wrap .adrasa-title {
    margin-bottom: var(--adrasa-stack-lg, 45px);
  }
}

/* =========================================
   OPTIONAL: Figma preset sizing (opt-in)
   Desktop/tablet only uses scale.
   Mobile already forced to Figma px above.
========================================= */

.adrasa-title-wrap.is-figma-preset .adrasa-title {
  --adrasa-title-size-regular: 4rem;
  --adrasa-title-size-italic:  4.4375rem;
  --adrasa-title-lh-regular: 0.92;
  --adrasa-title-lh-italic: 0.92;
}
