/* =========================
   08. PROGRAM
   ========================= */
#program{
  --programGlass:rgba(255,255,255,.76);
  --programGlassStrong:rgba(255,255,255,.84);
  --programGlassBorder:rgba(255,255,255,.32);
  --programInk:rgba(132,111,66,.96);
  --programDivider:rgba(132,111,66,.22);
  --programShadow:0 18px 42px rgba(58,32,15,.16);

  --programRadius:20px;
  --programCardRadius:18px;

  --programContainerW:min(1680px,96vw);
  --programContainerPad:clamp(16px,2.2vh,28px) 0 clamp(28px,4vh,48px);
  --programShellGap:clamp(24px,3vh,36px);
  --programGridGap:clamp(34px,3.2vw,64px);
  --programColumnGap:clamp(22px,2.8vh,34px);

  --programTitleWidth:min(760px,86vw);
  --programTitlePad:clamp(18px,2.2vw,26px) clamp(28px,3.6vw,46px);
  --programTitleSize:clamp(2.2rem,3.7vw,3.7rem);

  --programGridCols2:repeat(2,minmax(360px,440px));
  --programGridCols3:repeat(3,minmax(280px,420px));

  --programDayWidth:min(440px,100%);
  --programDayMinH:84px;
  --programDayPad:14px 20px;
  --programDaySize:clamp(1.95rem,2.65vw,2.95rem);

  --programCardWidth:min(440px,100%);
  --programCardMinH:252px;
  --programCardPad:18px 18px 20px;
  --programPreviewH:214px;
  --programPreviewPadB:34px;

  --programIndicatorSize:34px;
  --programIndicatorOffset:-17px;
  --programIndicatorArrow:8px;
  --programIndicatorArrowOffset:-4px;

  position:relative;
  min-height:100svh;
  height:100svh;
  overflow:hidden;
  background:#23170f;
}

#program::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:linear-gradient(180deg, rgba(253,247,242,.10) 0%, rgba(253,247,242,.06) 100%);
}

.program-bg{
  position:absolute;
  inset:0;
  z-index:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.22) 0%, rgba(0,0,0,.18) 100%),
    url("tlo-program.jpg") center center / cover no-repeat;
  transform:scale(1.02);
}

#program > .container{
  position:relative;
  z-index:2;
  width:var(--programContainerW);
  min-height:100%;
  height:auto;
  padding:var(--programContainerPad);
}

#program .program-shell{
  display:grid;
  align-content:start;
  justify-items:center;
  gap:var(--programShellGap);
  min-height:100%;
}

/* =========================
   08a. TYTUŁ
   ========================= */
#program .program-title-box{
  display:grid;
  place-items:center;
  width:var(--programTitleWidth);
  margin:0 auto;
  padding:var(--programTitlePad);
  border-radius:var(--programRadius);
  text-align:center;
  background:var(--programGlass);
  border:1px solid var(--programGlassBorder);
  box-shadow:var(--programShadow);
}

#program .program-title-heading{
  display:grid;
  justify-items:center;
  align-content:center;
  gap:0;
  margin:0;
  font-family:var(--fontA);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.045em;
  line-height:.9;
  font-size:var(--programTitleSize);
  color:var(--programInk);
  text-align:center;
}

#program .program-title-heading span{
  display:block;
  width:fit-content;
  max-width:100%;
  margin-inline:auto;
  text-align:center;
  white-space:nowrap;
}

/* =========================
   08b. SIATKA
   ========================= */
#program .program-grid{
  display:grid;
  justify-content:center;
  align-items:start;
  width:100%;
  gap:var(--programGridGap);
}

#program .program-grid[data-days="2"]{
  grid-template-columns:var(--programGridCols2);
}

#program .program-grid[data-days="3"]{
  grid-template-columns:var(--programGridCols3);
}

#program .program-column{
  display:grid;
  justify-items:center;
  align-content:start;
  gap:var(--programColumnGap);
}

#program .program-day-box{
  display:flex;
  align-items:center;
  justify-content:center;
  width:var(--programDayWidth);
  min-height:var(--programDayMinH);
  padding:var(--programDayPad);
  border-radius:16px;
  text-align:center;
  background:var(--programGlass);
  border:1px solid var(--programGlassBorder);
  box-shadow:var(--programShadow);
  font-family:var(--fontA);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.05em;
  font-size:var(--programDaySize);
  line-height:1;
  color:var(--programInk);
}

/* =========================
   08c. KARTY
   ========================= */
#program .program-card{
  width:var(--programCardWidth);
  overflow:visible;
  border-radius:var(--programCardRadius);
  background:var(--programGlass);
  border:1px solid var(--programGlassBorder);
  box-shadow:var(--programShadow);
  transition:
    transform 220ms ease,
    box-shadow 220ms ease,
    background 220ms ease,
    border-color 220ms ease;
}

#program .program-card.is-clickable{
  cursor:pointer;
}

#program .program-card.is-clickable:hover{
  transform:translateY(-3px);
  background:var(--programGlassStrong);
  box-shadow:0 22px 48px rgba(58,32,15,.18);
}

#program .program-card.is-expanded{
  background:var(--programGlassStrong);
  box-shadow:0 22px 48px rgba(58,32,15,.18);
}

#program .program-card-surface{
  position:relative;
  display:block;
  width:100%;
  min-height:var(--programCardMinH);
  padding:var(--programCardPad);
  border:0;
  background:transparent;
  text-align:left;
  cursor:default;
}

#program .program-card.is-clickable .program-card-surface{
  cursor:pointer;
}

#program .program-card-surface:focus-visible{
  outline:3px solid rgba(98,57,29,.28);
  outline-offset:-3px;
}

#program .program-card.is-clickable .program-card-surface::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:var(--programIndicatorOffset);
  z-index:3;
  width:var(--programIndicatorSize);
  height:var(--programIndicatorSize);
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(132,111,66,.26);
  box-shadow:0 8px 18px rgba(58,32,15,.14);
  transform:translateX(-50%);
  transition:border-color 180ms ease, box-shadow 180ms ease;
}

#program .program-card.is-clickable .program-card-surface::before{
  content:"";
  position:absolute;
  left:50%;
  bottom:var(--programIndicatorArrowOffset);
  z-index:4;
  width:var(--programIndicatorArrow);
  height:var(--programIndicatorArrow);
  border-right:2px solid var(--programInk);
  border-bottom:2px solid var(--programInk);
  transform:translateX(-50%) rotate(45deg);
  opacity:.92;
  pointer-events:none;
  transition:transform 180ms ease;
}

#program .program-card.is-clickable:hover .program-card-surface::after{
  border-color:rgba(132,111,66,.34);
  box-shadow:0 10px 20px rgba(58,32,15,.16);
}

#program .program-card.is-expanded .program-card-surface::before{
  transform:translateX(-50%) rotate(-135deg);
}

/* =========================
   08d. TREŚĆ KARTY
   ========================= */
#program .program-card-preview-wrap{
  display:block;
  height:var(--programPreviewH);
  overflow:hidden;
}

#program .program-card.is-clickable .program-card-preview-wrap{
  padding-bottom:var(--programPreviewPadB);
}

#program .program-card.is-expanded .program-card-preview-wrap{
  height:auto;
  overflow:visible;
}

#program .program-card-preview{
  width:100%;
  margin:0;
  font-family:var(--fontA);
  font-weight:600;
  font-size:1.1rem;
  line-height:1.5;
  letter-spacing:0;
  color:var(--text);
  text-transform:none;
  text-align:left;
  word-break:break-word;
}

#program .program-card-preview p{
  margin:0 0 10px;
  font-weight:600;
  line-height:1.5;
  color:var(--text);
}

#program .program-card-preview p:last-of-type{
  margin-bottom:0;
}

#program .program-card-preview ul{
  margin:12px 0 0;
  padding:12px 0 0 22px;
  border-top:1px solid var(--programDivider);
  color:var(--text);
}

#program .program-card-preview li{
  margin:5px 0;
  font-weight:600;
  line-height:1.45;
}

#program .program-card-panel{
  display:none !important;
}

/* =========================
   08m. PROGRAM DESKTOP SCROLL
   ========================= */
@media (min-width:901px){
  #program .program-card.is-expanded .program-card-preview-wrap.is-scrollable{
    max-height:420px;
    overflow:auto;
    padding-right:10px;
  }
}

/* =========================
   08m. PROGRAM TABLET
   ========================= */
@media (max-width:1200px){
  #program{
    --programTitleWidth:min(700px,90vw);
    --programGridCols2:repeat(2,minmax(300px,380px));
    --programGridCols3:repeat(3,minmax(220px,1fr));
    --programDayWidth:min(380px,100%);
    --programCardWidth:min(380px,100%);
    --programCardMinH:238px;
    --programPreviewH:200px;
  }

  #program .program-card-preview{
    font-size:1.06rem;
    line-height:1.48;
  }
}

/* =========================
   08m. PROGRAM MOBILE
   ========================= */
@media (max-width:900px){
  #program{
    --programContainerW:min(95vw,1680px);
    --programContainerPad:20px 0 28px;
    --programShellGap:20px;
    --programGridGap:20px;
    --programColumnGap:14px;

    --programTitleWidth:min(620px,100%);
    --programTitlePad:16px 18px;
    --programTitleSize:clamp(1.8rem,8vw,2.5rem);

    --programGridCols2:1fr;
    --programGridCols3:1fr;

    --programDayWidth:min(560px,100%);
    --programDayMinH:72px;
    --programDayPad:14px 16px;
    --programDaySize:1.6rem;

    --programCardWidth:min(560px,100%);
    --programCardMinH:170px;
    --programCardPad:16px 14px 18px;
    --programPreviewH:136px;
    --programPreviewPadB:32px;

    --programIndicatorSize:32px;
    --programIndicatorOffset:-16px;
    --programIndicatorArrow:7px;
    --programIndicatorArrowOffset:-3px;

    min-height:auto;
    height:auto;
    overflow:hidden;
  }

  .program-bg{
    position:absolute;
    inset:0;
    height:auto;
    margin:0;
    transform:none;
  }

  #program > .container{
    min-height:auto;
  }

  #program .program-title-heading{
    line-height:.92;
  }

  #program .program-title-heading span{
    white-space:normal;
  }

  #program .program-card-preview{
    font-size:1.04rem;
    line-height:1.48;
  }
}

@media (max-width:520px){
  #program{
    --programTitlePad:14px 14px;
    --programTitleSize:clamp(1.7rem,8.6vw,2.2rem);

    --programDayMinH:64px;
    --programDaySize:1.34rem;

    --programCardMinH:150px;
    --programCardPad:14px 12px 16px;
    --programPreviewH:120px;
    --programPreviewPadB:30px;

    --programIndicatorSize:30px;
    --programIndicatorOffset:-15px;
    --programIndicatorArrow:6px;
    --programIndicatorArrowOffset:-3px;
  }

  #program .program-card-preview{
    font-size:1.02rem;
    line-height:1.46;
  }
}

@media (hover:none), (pointer:coarse){
  .program-bg{transform:none}
}

@media (prefers-reduced-motion:reduce){
  #program .program-card,
  #program .program-card.is-clickable .program-card-surface::before,
  #program .program-card.is-clickable .program-card-surface::after{
    transition:none;
  }
}