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

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

  /* Old behavior (kept) */
  --adrasa-title-size: clamp(40px, 3.6vw, calc(56px * var(--adrasa-scale)));
  --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: 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 {
  /* Desktop/tablet gap must match Figma * scale */
  --adrasa-title-aside-gap: calc(70px * var(--adrasa-scale));

  /* Desktop/tablet container-like max widths (scaled) */
  --adrasa-title-max: calc(311px * var(--adrasa-scale));
  --adrasa-title-aside-max: calc(730px * var(--adrasa-scale));

  width: 100%;
  display: grid;

  /* each column is capped by its max-width */
  grid-template-columns:
    minmax(0, var(--adrasa-title-max))
    minmax(0, 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);
}

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

.adrasa-title__aside-lead {
  margin: 0 0 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)
   Figma values in px (NO --adrasa-scale)
   Also adds the missing left/right padding
========================================= */

@media (max-width: 991.98px) {
  .adrasa-title-wrap {
    /* Stack */
    grid-template-columns: 1fr;

    /* Figma: very tight gap between title and supporting text */
    row-gap: 2px;

    /* Figma container width */
    --adrasa-title-max: 391px;
    --adrasa-title-aside-max: 391px;

    /* Missing padding in your screenshots */
    padding-left: 24px;
    padding-right: 24px;

    /* Avoid padding causing overflow with fixed max widths */
    box-sizing: border-box;
  }

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

  /* Title spacing on mobile (Figma-like) */
  .adrasa-title {
    line-height: 1.5;
    gap: 6px;
  }

  /* IMPORTANT: on mobile, DO NOT scale — use Figma px */
  .adrasa-title__regular {
    font-size: 42px;
    line-height: 0.97;
  }

  .adrasa-title__italic {
    font-size: 51px;
    line-height: 0.97;
    margin: 0;
  }

  /* Supporting typography on mobile (from your capture: ~18px) */
  .adrasa-title__aside-lead {
    font-size: 18px;
    line-height: 1.15;
    margin: 0 0 20px 0;
  }

  .adrasa-title__aside-body {
    font-size: 18px;
    line-height: 1.25;
  }
  .adrasa-title-wrap .adrasa-title{
    margin-bottom: 45px!important;
  }
}

/* =========================================
   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: calc(64px * var(--adrasa-scale));
  --adrasa-title-size-italic:  calc(71px * var(--adrasa-scale));
  --adrasa-title-lh-regular: 0.92;
  --adrasa-title-lh-italic: 0.92;
}
