/* public/assets/css/styles.css  (RESPONSIVE FIXED VERSION) */

:root{
  --card-radius: 18px;
}

.card-soft{
  border: 1px solid rgba(0,0,0,.06);
  border-radius: var(--card-radius);
  box-shadow: 0 10px 30px rgba(0,0,0,.04);
}

.calendar-grid{
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr)); /* ✅ prevents overflow */
  gap: .75rem;
}

.calendar-cell{
  min-height: 110px;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 16px;
  padding: .65rem;
  background: #fff;
  position: relative;
  cursor: pointer;
  overflow: hidden; /* ✅ keeps content inside cell */
}

/* Full-cell clickable overlay */
.calendar-cell .date-link-overlay{
  position: absolute;
  inset: 0;
  border-radius: 16px;
  z-index: 1;
  text-decoration: none !important;
  outline: none;
}

.calendar-cell .date-link-overlay:hover,
.calendar-cell .date-link-overlay:focus,
.calendar-cell .date-link-overlay:active{
  text-decoration: none !important;
}

/* Content above overlay */
.calendar-cell .cell-content{
  position: relative;
  z-index: 2;
  min-width: 0; /* ✅ allows ellipsis inside */
}

/* ✅ Day button (wide on desktop but auto-fit on small screens) */
.calendar-cell .daynum{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 76px;
  height: 38px;
  border-radius: 999px;
  font-size: 1.05rem;
  font-weight: 800;
  color: #111827;
  background: rgba(13,110,253,.10);
  border: 1px solid rgba(13,110,253,.20);
  user-select: none;
  text-decoration: none !important;
  max-width: 100%;
}

.calendar-cell .daynum:hover,
.calendar-cell .daynum:focus{
  text-decoration: none !important;
  background: rgba(13,110,253,.18);
  border-color: rgba(13,110,253,.35);
}

.calendar-cell .daynum:focus-visible{
  outline: 3px solid rgba(13,110,253,.45);
  outline-offset: 2px;
}

/* Today highlight */
.today{
  outline: 2px solid rgba(13,110,253,.35);
}

.today .daynum{
  background: rgba(13,110,253,.22);
  border-color: rgba(13,110,253,.45);
}

/* Event pill */
.event-pill{
  display: block;
  font-size: .8rem;
  padding: .25rem .5rem;
  border-radius: 999px;
  background: rgba(13,110,253,.12);
  color: #0b5ed7;
  text-decoration: none !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  position: relative;
  z-index: 3;
  min-width: 0;
}

.event-pill:hover,
.event-pill:focus{
  text-decoration: none !important;
}

.event-pill.private{
  background: rgba(108,117,125,.16);
  color: #495057;
}

/* Ministry style */
.ministry-involved{
  font-size: .85rem;
  font-style: italic;
  color: rgba(0,0,0,.65);
}

/* hover */
.calendar-cell:hover{
  box-shadow: 0 12px 30px rgba(0,0,0,.06);
  transform: translateY(-1px);
  transition: 120ms ease;
}

/* ✅ Make the top search/nav form responsive (wrap + full width inputs) */
.calendar-toolbar{
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
  justify-content: flex-end;
}
.calendar-toolbar .form-select,
.calendar-toolbar .btn{
  width: auto;
}
.calendar-toolbar .form-select{
  min-width: 140px;
}

/* ============ RESPONSIVE BREAKPOINTS ============ */

/* Tablets */
@media (max-width: 992px){
  .calendar-grid{
    gap: .6rem;
  }
  .calendar-cell{
    min-height: 100px;
  }
  .calendar-cell .daynum{
    width: 64px;
    height: 36px;
  }
}

/* Phones */
@media (max-width: 576px){
  .calendar-grid{
    gap: .5rem;
  }

  .calendar-cell{
    min-height: 92px;
    padding: .5rem;
    border-radius: 14px;
  }

  /* ✅ Day button fits small cells */
  .calendar-cell .daynum{
    width: 100%;
    height: 34px;
    font-size: 1rem;
    font-weight: 900;
  }

  /* ✅ show fewer pills visually; keep readable */
  .event-pill{
    font-size: .78rem;
    padding: .22rem .45rem;
  }

  /* ✅ make toolbar full width controls on mobile */
  .calendar-toolbar{
    justify-content: flex-start;
  }
  .calendar-toolbar .form-select,
  .calendar-toolbar .btn{
    width: 100%;
  }
}
