/* ========================================================================== 
   Semioticom accordion refresh
   Applies to template-parts/_common/accordion.php
   Load after main.min.css and refresh.css.
   ========================================================================== */

section.accordion.accordion--refresh{
  position: relative;
  padding: clamp(72px, 8vw, 128px) 0;
  margin: 0;
  overflow: visible;
  background: transparent !important;
  color: var(--sem-text, #1e2f4a);
}

section.accordion.accordion--refresh:before,
section.accordion.accordion--refresh:after{
  content: "";
  position: absolute;
  z-index: 0;
  pointer-events: none;
  opacity: .42;
}

section.accordion.accordion--refresh:before{
  left: max(-260px, -16vw);
  top: 30%;
  width: min(520px, 40vw);
  height: min(520px, 40vw);
  border-radius: 999px;
  background: radial-gradient(circle, rgba(126,200,244,.22) 0%, rgba(126,200,244,.09) 42%, transparent 72%);
  filter: blur(10px);
}

section.accordion.accordion--refresh:after{
  right: max(-320px, -18vw);
  bottom: 6%;
  width: min(640px, 44vw);
  height: min(360px, 26vw);
  border-radius: 999px;
  background:
    repeating-radial-gradient(ellipse at center, rgba(126,200,244,.22) 0 1px, transparent 1px 13px),
    radial-gradient(circle, rgba(255,255,255,.88), transparent 58%);
  transform: rotate(-8deg);
}

section.accordion.accordion--refresh > .container{
  position: relative;
  z-index: 1;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.accordion--refresh .accordion__intro-row{
  margin-bottom: clamp(34px, 5vw, 58px);
}

.accordion--refresh .section-heading{
  max-width: 900px;
  margin: 0 auto;
  color: var(--sem-text, #1e2f4a) !important;
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.06;
  letter-spacing: -0.045em;
}

.accordion--refresh .section-description{
  max-width: 660px;
  margin-top: 18px;
  color: var(--sem-text-soft, rgba(30,47,74,.78)) !important;
  font-size: clamp(15px, 1.45vw, 17px);
  line-height: 1.65;
}

.accordion--refresh .section-description p:last-child{
  margin-bottom: 0;
}

.accordion--refresh .accordion__items-row{
  margin-top: 0;
}

.accordion--refresh .accordion--items{
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 980px;
  margin: 0 auto;
  gap: 10px;
}

.accordion--refresh .accordion-row{
  position: relative;
  margin: 0 !important;
  border-radius: 18px;
  overflow: visible !important;
  transition: box-shadow .25s ease, transform .25s ease;
}

.accordion--refresh .accordion-row.expanded{
  overflow: visible !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.accordion--refresh .accordion-row.collapsed:hover{
  transform: translateY(-1px);
}

.accordion--refresh .summary{
  appearance: none;
  -webkit-appearance: none;
  position: relative;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 16px;
  width: 100%;
  min-height: 62px;
  padding: 14px 18px !important;
  border: 1px solid rgba(30,47,74,.13);
  border-radius: 18px;
  cursor: pointer;
  user-select: none;
  text-align: left;
  font: inherit;
  transition: background-color .25s ease, border-color .25s ease, color .25s ease, box-shadow .25s ease;
}

.accordion--refresh .summary:focus-visible{
  outline: 3px solid rgba(126,200,244,.75);
  outline-offset: 4px;
}

.accordion--refresh .accordion-row.collapsed .summary{
  color: var(--sem-text, #1e2f4a) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.80), rgba(239,248,245,.90));
  box-shadow: 0 8px 22px rgba(30,47,74,.055);
}

.accordion--refresh .accordion-row.collapsed .summary:hover{
  border-color: rgba(13,122,117,.24);
  background:
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(234,247,242,.96));
  box-shadow: 0 12px 30px rgba(30,47,74,.08);
}

.accordion--refresh .accordion-row.expanded .summary{
  min-height: 76px;
  color: #ffffff !important;
  border-color: rgba(126,200,244,.18);
  border-radius: 999px;
  background:
    linear-gradient(135deg, #09223b 0%, #132d4d 62%, #183654 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 16px 36px rgba(30,47,74,.16);
}

.accordion--refresh .summary > svg{
  display: none !important;
}

.accordion--refresh .accordion-item-icon{
  position: relative;
  display: inline-flex;
  flex: 0 0 40px;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  overflow: hidden;
  border-radius: 14px;
  background: rgba(13,122,117,.08);
  border: 1px solid rgba(13,122,117,.14);
}

.accordion--refresh .accordion-row.expanded .accordion-item-icon{
  background: rgba(126,200,244,.10);
  border-color: rgba(126,200,244,.28);
}

.accordion--refresh .accordion-item-icon__image{
  display: block;
  width: 22px !important;
  height: 22px !important;
  max-width: 22px !important;
  max-height: 22px !important;
  object-fit: contain;
}

.accordion--refresh .summary-label{
  display: block;
  flex: 1 1 auto;
  min-width: 0;
  max-width: calc(100% - 58px);
  padding-right: 14px;
  color: inherit !important;
  font-family: PlusJakartaSansBold, "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 700;
  font-size: clamp(15px, 1.5vw, 18px);
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.accordion--refresh .accordion-row.has-icon .summary-label{
  max-width: calc(100% - 114px);
}

.accordion--refresh .summary-label *{
  color: inherit !important;
}

.accordion--refresh .summary-toggle{
  position: relative;
  flex: 0 0 34px;
  width: 34px;
  height: 34px;
  margin-left: auto;
  border-radius: 999px;
  color: currentColor;
}

.accordion--refresh .summary-toggle:before,
.accordion--refresh .summary-toggle:after{
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 18px;
  height: 2px;
  border-radius: 99px;
  background: currentColor;
  transform: translate(-50%, -50%);
  transition: transform .2s ease, opacity .2s ease;
}

.accordion--refresh .summary-toggle:after{
  transform: translate(-50%, -50%) rotate(90deg);
}

.accordion--refresh .accordion-row.expanded .summary-toggle:after{
  opacity: 0;
  transform: translate(-50%, -50%) rotate(0deg);
}

.accordion--refresh .details{
  display: none !important;
  padding: 0 !important;
  transform: none !important;
}

.accordion--refresh .accordion-row.expanded .details{
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 38%);
  gap: clamp(28px, 4vw, 54px);
  align-items: start;
  margin-top: 12px;
  padding: clamp(28px, 4vw, 46px) !important;
  border: 1px solid rgba(30,47,74,.10);
  border-radius: 24px;
  box-shadow: 0 18px 48px rgba(30,47,74,.12);
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,250,252,.96)),
    radial-gradient(circle at 82% 22%, rgba(166,230,197,.14), transparent 36%);
}

.accordion--refresh .accordion-row.expanded.no-image .details{
  grid-template-columns: minmax(0, 1fr);
}

.accordion--refresh .accordion-row .details > *{
  width: auto !important;
  min-width: 0;
}

.accordion--refresh .texts{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  max-width: 650px;
  min-height: clamp(260px, 24vw, 340px);
}

.accordion--refresh .tagline{
  margin: 0 0 16px;
  color: var(--sem-teal, #0d7a75) !important;
  font-family: PlusJakartaSansBold, "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: clamp(16px, 1.65vw, 19px);
  font-weight: 700;
  line-height: 1.35;
}

.accordion--refresh .tagline *{
  color: inherit !important;
}

.accordion--refresh .text{
  color: var(--sem-text, #1e2f4a) !important;
  font-size: clamp(15px, 1.35vw, 16px);
  line-height: 1.72;
}

.accordion--refresh .text p{
  margin-bottom: 18px;
  color: inherit !important;
}

.accordion--refresh .text p:last-child{
  margin-bottom: 0;
}

.accordion--refresh .btn{
  margin-top: auto;
}

.accordion--refresh .text + .btn,
.accordion--refresh .tagline + .btn{
  margin-top: auto;
}

.accordion--refresh .accordion-media{
  position: relative;
  display: block;
  width: 100% !important;
  max-width: 380px;
  margin: 0 0 22px auto;
  overflow: visible;
}

.accordion--refresh .accordion-media__image-wrap{
  position: relative;
  overflow: hidden;
  width: 100%;
  border-radius: 22px;
  box-shadow: 0 18px 42px rgba(30,47,74,.14);
}

.accordion--refresh .accordion-media__image{
  display: block;
  width: 100% !important;
  max-width: none !important;
  height: auto !important;
  aspect-ratio: 1.55 / 1;
  object-fit: cover;
  border-radius: 0 !important;
}

.accordion--refresh .accordion-media__caption{
  position: absolute;
  right: clamp(10px, 2vw, 22px);
  bottom: -22px;
  max-width: min(280px, 88%);
  padding: 14px 18px 14px 50px;
  border: 1px solid rgba(30,47,74,.10);
  border-radius: 14px;
  background: rgba(255,255,255,.94);
  color: var(--sem-text, #1e2f4a);
  font-family: PlusJakartaSansMedium, "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.45;
  box-shadow: 0 14px 34px rgba(30,47,74,.14);
  backdrop-filter: blur(8px);
}

.accordion--refresh .accordion-media__caption:before{
  content: "";
  position: absolute;
  left: 16px;
  top: 50%;
  width: 26px;
  height: 26px;
  border-radius: 9px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.22), transparent),
    var(--sem-teal, #0d7a75);
  box-shadow: 0 8px 18px rgba(13,122,117,.25);
  transform: translateY(-50%);
}

/* Light/dark section variants from the page builder can wrap this element.
   Keep the refreshed accordion readable even when a color class is selected. */
section.accordion--refresh.dark-blue,
section.accordion--refresh.light-blue,
section.accordion--refresh.light-green,
section.accordion--refresh.orange{
  color: var(--sem-text, #1e2f4a) !important;
}

section.accordion--refresh.dark-blue .section-heading,
section.accordion--refresh.dark-blue .section-description{
  color: var(--sem-text, #1e2f4a) !important;
}

@media (min-width: 1200px){
  .accordion--refresh .accordion--items{
    max-width: 1040px;
  }
}

@media (max-width: 991.98px){
  .accordion--refresh .accordion-row.expanded .details{
    grid-template-columns: 1fr;
  }

  .accordion--refresh .texts{
    min-height: 0;
  }

  .accordion--refresh .btn{
    margin-top: 28px;
  }

  .accordion--refresh .accordion-media{
    max-width: 520px;
    margin-right: auto;
    margin-left: 0;
  }
}

@media (max-width: 767.98px){
  .accordion--refresh .accordion-row.expanded .details{
    margin-top: 10px;
    border-radius: 20px;
  }

  section.accordion.accordion--refresh{
    padding: 56px 0;
  }

  .accordion--refresh .accordion__intro-row{
    margin-bottom: 28px;
  }

  .accordion--refresh .summary{
    min-height: 58px;
    gap: 12px;
    padding: 12px 14px !important;
  }

  .accordion--refresh .accordion-row.expanded .summary{
    min-height: 66px;
  }

  .accordion--refresh .accordion-item-icon{
    flex-basis: 36px;
    width: 36px;
    height: 36px;
    border-radius: 12px;
  }

  .accordion--refresh .accordion-item-icon__image{
    width: 20px !important;
    height: 20px !important;
    max-width: 20px !important;
    max-height: 20px !important;
  }

  .accordion--refresh .summary-label,
  .accordion--refresh .accordion-row.has-icon .summary-label{
    max-width: none;
  }

  .accordion--refresh .summary-toggle{
    flex-basis: 30px;
    width: 30px;
    height: 30px;
  }

  .accordion--refresh .accordion-row.expanded .details{
    grid-template-columns: 1fr;
    padding: 22px !important;
    gap: 18px;
    align-items: stretch;
  }

  /* Mobile content order:
     1. tagline/text
     2. image subtitle
     3. image
     4. button, anchored bottom-right */
  .accordion--refresh .texts{
    display: contents;
  }

  .accordion--refresh .tagline{
    order: 1;
    margin-bottom: 0;
  }

  .accordion--refresh .text{
    order: 2;
  }

  .accordion--refresh .accordion-media{
    order: 3;
    display: flex;
    flex-direction: column;
    width: 100% !important;
    max-width: none;
    margin: 2px 0 0;
  }

  .accordion--refresh .accordion-media__caption{
    order: 1;
    position: relative;
    right: auto;
    bottom: auto;
    width: 100%;
    max-width: none;
    margin: 0 0 14px;
    padding: 14px 16px 14px 50px;
  }

  .accordion--refresh .accordion-media__image-wrap{
    order: 2;
    width: 100%;
  }

  .accordion--refresh .accordion-media__image{
    aspect-ratio: 1.45 / 1;
  }

  .accordion--refresh .btn{
    order: 4;
    justify-self: end;
    align-self: end;
    margin-top: 4px;
    margin-left: auto;
  }
}
