/**
 * LiveAg Calendars — Calendar grid styles.
 *
 * @since   POC
 * @serial  20260504.2
 * @package LiveAg_Calendars
 */

.la-cal{
  --accent:var(--division-color);
  --line:rgba(73,118,55,.28);
  --muted:rgba(0,0,0,.55);
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  width:100%;
}

.la-cal .la-month{
  padding:14px 14px 12px;
  border:1px solid var(--line);
  border-radius:16px;
  background:transparent;
  overflow:visible;
}

.la-cal .la-month-title{
  margin:0 0 10px;
  color:var(--division-color);
  font-size:18px;
  font-weight:700;
  line-height:1.1;
  text-align:center;
}

.la-cal .la-weekdays,
.la-cal .la-days{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:6px;
}

.la-cal .la-weekdays{
  margin-bottom:8px;
}

.la-cal .la-weekdays span{
  font-size:11px;
  line-height:1;
  text-align:center;
  color:rgba(0,0,0,.75);
  font-weight:600;
}

.la-cal .la-days{
  overflow:visible;
}

.la-cal .la-days > span{
  display:flex;
  align-items:center;
  justify-content:center;
  aspect-ratio:1 / 1;
  border-radius:999px;
  font-size:14px;
  line-height:1;
  position:relative;
  overflow:visible;
}

.la-cal .la-days .empty{
  opacity:0;
  pointer-events:none;
}

.la-cal .la-days .hl{
  background:var(--division-color);
  color:#fff;
  font-weight:700;
}

.la-cal .la-days .hl-past{
  background:#9BBF7C;
  color:#2b2b2b;
  font-weight:700;
}

.la-cal .la-days .has-card{
  cursor:default;
}

.la-cal .la-days .has-card:focus{
  outline:none;
}

.la-cal .la-days .la-hover-card{
  position:absolute;
  left:50%;
  bottom:calc(100% + 12px);
  transform:translateX(-50%) translateY(8px);
  width:300px;
  max-width:min(300px, calc(100vw - 40px));
  background:#fff;
  color:#111;
  border:1px solid rgba(73,118,55,.45);
  border-top:4px solid var(--division-color);
  border-radius:14px;
  padding:14px 14px 13px;
  box-shadow:0 14px 30px rgba(0,0,0,.18);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
  z-index:50;
  text-align:left;
  line-height:1.35;
}

.la-cal .la-days .la-hover-card::after{
  content:"";
  position:absolute;
  left:calc(50% + var(--arrow-offset, 0px));
  top:100%;
  transform:translateX(-50%);
  border-width:8px 7px 0 7px;
  border-style:solid;
  border-color:#fff transparent transparent transparent;
}

.la-cal .la-days .la-hover-card::before{
  content:"";
  position:absolute;
  left:0;
  top:100%;
  width:100%;
  height:20px;
  background:transparent;
}

.la-cal .la-days .has-card:hover .la-hover-card,
.la-cal .la-days .has-card:focus .la-hover-card,
.la-cal .la-days .has-card:focus-visible .la-hover-card{
  opacity:1;
  visibility:visible;
  transform:translateX(-50%) translateY(0);
  pointer-events:auto;
}

/* touch tap-to-open state */
.la-cal .la-days .has-card.is-open .la-hover-card{
  opacity:1;
  visibility:visible;
  transform:translateX(-50%) translateY(0);
  pointer-events:auto;
}

.la-cal .hc-date{
  display:block;
  color:var(--division-color);
  font-size:13px;
  font-weight:700;
  margin-bottom:6px;
  text-transform:uppercase;
  letter-spacing:.04em;
}

.la-cal .hc-title{
  display:block;
  font-size:16px;
  font-weight:700;
  line-height:1.2;
  margin-bottom:2px;
}

.la-cal .hc-subtitle{
  display:block;
  font-size:14px;
  font-weight:600;
  line-height:1.25;
  margin-bottom:8px;
}

.la-cal .hc-line{
  display:block;
  font-size:13px;
  line-height:1.35;
  margin-top:4px;
}

.la-cal .hc-time{
  font-weight:700;
}

.la-cal .hc-link{
  display:inline-block;
  margin:6px 6px 0 0;
  padding:4px 10px;
  background:var(--division-color);
  color:#fff;
  font-size:12px;
  font-weight:600;
  border-radius:6px;
  text-decoration:none;
  line-height:1.3;
}

.la-cal .hc-link:hover{
  opacity:.85;
}

/* intro text — base rules MUST appear before media query overrides */
.la-cal-intro{
  margin:0 0 16px;
  text-align:center;
}

.la-cal-intro-line1{
  color:var(--division-color);
  font-size:22px;
  line-height:1.2;
  font-weight:700;
}

.la-cal-intro-line2{
  color:var(--division-color);
  font-size:16px;
  line-height:1.3;
  font-weight:600;
}

.la-cal-year-label{
  grid-column:1/-1;
  text-align:center;
  font-size:20px;
  font-weight:700;
  color:var(--division-color);
  margin:8px 0 4px;
}

@media (max-width:980px){
  .la-cal{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width:767px){
  .la-cal{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
    overflow-x:hidden;
    overflow-x:clip;
  }
  .la-cal .la-days .la-hover-card{
    width:min(250px, calc(100vw - 32px));
    max-width:min(250px, calc(100vw - 32px));
    box-shadow:0 16px 40px rgba(0,0,0,.25), 0 4px 12px rgba(0,0,0,.12);
  }
}

@media (max-width:540px){
  .la-cal{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
    overflow-x:hidden;
    overflow-x:clip;
  }
  .la-cal .la-days .la-hover-card{
    width:min(220px, calc(100vw - 24px));
    max-width:min(220px, calc(100vw - 24px));
    padding:12px 12px 11px;
    font-size:12px;
  }
  .la-cal .hc-title{
    font-size:14px;
  }
  .la-cal .hc-subtitle{
    font-size:13px;
  }
  .la-cal .hc-date{
    font-size:12px;
  }
  .la-cal .hc-line{
    font-size:12px;
  }
  .la-cal .la-month{
    padding:12px 12px 10px;
  }
  .la-cal .la-month-title{
    font-size:16px;
  }
  .la-cal .la-days > span{
    font-size:12px;
  }
  .la-cal .la-weekdays span{
    font-size:10px;
  }
  .la-cal-intro-line1{ font-size:18px; }
  .la-cal-intro-line2{ font-size:14px; }
}
