/* Lab Seminar Board styles */

/* --- General & Theme --- */
:root {
  --badge-bg: #fff;
  --badge-fg: #000;
  --badge-border: var(--bs-border-color);

  /* New variables for consistency */
  --grid-gap: 0.5rem;
  --cell-border-radius: 0.75rem;
  --pill-border-radius: 0.75rem;
  --transition-speed: 0.2s ease-in-out;
}

[data-bs-theme="dark"] {
  --badge-bg: #000;
  --badge-fg: #fff;
  --badge-border: var(--bs-border-color);
}

/* 날짜 제목(h4)에 고정 너비를 주어 버튼 위치를 고정 */
#title {
  width: 220px;
  /* 가장 긴 September가 들어갈 정도의 너비 */
  text-align: center;
  /* 너비 안에서 텍스트는 중앙 정렬 */
}

/* --- Weekday Headers --- */
.week-headers {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  margin: .5rem 0;
  gap: var(--grid-gap);
  /* Use variable */
}

.week-headers .wh {
  text-align: center;
  font-size: 1rem;
  color: var(--badge-fg);
}

.week-headers .wh.wh-sat {
  color: var(--bs-blue);
}

.week-headers .wh.wh-sun {
  color: #c0001d;
}


/* --- Calendar Grid View --- */
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: var(--grid-gap);
  /* Use variable */
}

.calendar-grid .col {
  border: 1px solid var(--bs-border-color);
  border-radius: var(--cell-border-radius);
  position: relative;
  /* Use variable */
  color: var(--badge-fg);
  min-height: 120px;
  padding: .5rem;
  background: var(--bs-body-bg);
  transition: border-color var(--transition-speed), box-shadow var(--transition-speed);
  /* Add transition */
}

.calendar-grid .col:not(.muted) {
  /* 기본 테두리보다 살짝 진하게 설정 */
  border-color: var(--badge-fg);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.03);
}

/* 다크 모드일 때의 테두리 색상 */
[data-bs-theme="dark"] .calendar-grid .col:not(.muted) {
  border-color: var(--badge-fg);
}

/* 이번 달 날짜 숫자 스타일 */
.calendar-grid .col:not(.muted) .no-events .text-body-tertiary {
  color: var(--badge-fg) !important;
}

.calendar-grid .col:hover {
  border-color: var(--bs-primary);
  /* Highlight on hover */
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);

  /* Add subtle shadow */
  .badge {
    display: none;
  }
}

.calendar-grid .col:hover .day-add-btn {
  opacity: 1;
  transform: scale(1);
}

.calendar-grid .col .day-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 1rem;
  margin-bottom: .25rem;
}


/* 날짜와 공휴일 이름을 묶는 왼쪽 그룹 */
.day-info {
  display: flex;
  align-items: baseline;
  /* 숫자와 글자의 하단 라인을 맞춤 */
  gap: 0.4rem;
  /* 숫자와 공휴일 이름 사이의 간격 */
}

/* 공휴일 날짜 숫자 색상을 빨간색으로 */
.calendar-grid .col.is-holiday .day-head .small {
  color: var(--bs-red);
}

/* 공휴일 이름 스타일 */
.holiday-name {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--bs-red);
  white-space: normal;
  word-break: keep-all;
  /* 한글 단어 중간에 줄바꿈 방지 */
  line-height: 1.2;
  /* 줄 간격 살짝 추가 */
}

.calendar-grid .col.muted {
  opacity: 1;
  /* 투명도 대신 명확한 색상 사용으로 명도 대비 보장 */
  color: #757575;
  background-color: var(--bs-tertiary-bg);
}

.calendar-grid .col.is-today {
  outline: 2px solid var(--bs-primary);
  outline-offset: -2px;
  border-radius: .5rem;
}

.calendar-grid .col.is-today .day-head .small:first-child {
  font-weight: 700;
}

.calendar-grid .col.is-today.muted {
  opacity: 1;
  color: var(--bs-body-color);
}

/* 캘린더 그리드 안의 이벤트 스타일과 색상 가능 스타일을 하나로 통합합니다. */
.calendar-grid .event-pill {
  /* 변수 기본값 설정 */
  --ev-bg: var(--badge-bg);
  --ev-fg: var(--badge-fg);

  /* 스타일 정의 */
  display: block;
  background: var(--ev-bg);
  /* JS가 덮어쓸 수 있도록 background 속성 사용 */
  color: var(--ev-fg);
  border: 1px solid color-mix(in srgb, var(--ev-bg), #000 20%);
  border-radius: var(--pill-border-radius);
  padding: .15rem .5rem;
  font-size: .8rem;
  margin-bottom: .25rem;
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: filter var(--transition-speed), transform var(--transition-speed);
}

.calendar-grid .event-pill:hover {
  filter: brightness(.95);
  text-decoration: none;
  transform: translateY(-2px);
}

/* ':not(.muted)'를 추가하여 우선순위를 높여줍니다 */
.calendar-grid .col:not(.muted).is-saturday .day-head .small {
  color: var(--bs-blue) !important;
}

.calendar-grid .col:not(.muted).is-sunday .day-head .small {
  color: var(--bs-red) !important;
}

/* Agenda 뷰의 이벤트 pill은 별도로 유지할 수 있습니다. */
#agendaView .event-pill {
  --ev-bg: var(--badge-bg);
  --ev-fg: var(--badge-fg);
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  padding: .25rem .5rem;
  border-radius: .4rem;
  font-size: .875rem;
  background: var(--ev-bg);
  color: var(--ev-fg);
  border: 1px solid color-mix(in srgb, var(--ev-bg), #000 20%);
  text-decoration: none;
  white-space: nowrap;
}

.calendar-grid .event-pill,
#agendaView .event-pill {
  /* color-mix 대신 더 명확한 색상 혼합으로 테두리 명도 대비 확보 */
  border: 1px solid rgba(0, 0, 0, 0.25);
}

[data-bs-theme="dark"] .calendar-grid .event-pill,
[data-bs-theme="dark"] #agendaView .event-pill {
  border: 1px solid rgba(255, 255, 255, 0.3);
}

.event-pill:hover {
  filter: brightness(.95);
  text-decoration: none;
}

/* 색상 스와치 버튼(팔레트) */
#colorPalette .color-swatch {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 999px;
  border: 1px solid rgba(0, 0, 0, .1);
  padding: 0;
}

/* 날짜 헤더, 시간, 위치/설명 텍스트에 적용 */
#agendaView .text-muted,
#agendaView .event-time,
#agendaView .text-body-secondary {
  /* 부트스트랩의 기본 스타일이 !important를 사용할 수 있으므로,
    우리 규칙도 !important를 사용해서 확실하게 덮어씁니다.
  */
  color: var(--badge-fg) !important;
}

/* --- Agenda List View --- */
#agendaView .day-group {
  /* 1. 카드처럼 보이도록 배경색 추가 */
  background-color: var(--bs-tertiary-bg);
  /* 본문 배경보다 한 단계 밝은 색 */

  /* 2. 테두리를 그리고 모서리를 둥글게 */
  border: 1px solid var(--bs-border-color);
  border-radius: .75rem;

  /* 3. 카드 안쪽에 여백(padding)을 줘서 답답하지 않게 */
  padding: 1rem;

  /* 4. 기존에 있던 왼쪽 굵은 테두리는 일반 테두리로 대체 */
  border-left: 1px solid var(--bs-border-color);
}

#agendaView .event-row {
  display: flex;
  gap: .75rem;
  align-items: flex-start;
  padding: .35rem .5rem;
  border-radius: .5rem;
  transition: background-color var(--transition-speed);
  /* Add transition */
}

#agendaView .event-row:hover {
  background: var(--bs-tertiary-bg);
}

[data-bs-theme="dark"] #agendaView .day-group {
  /* 1. 카드처럼 보이도록 배경색 추가 */
  background-color: var(--bs-tertiary-bg);
  /* 본문 배경보다 한 단계 밝은 색 */

  /* 2. 테두리를 그리고 모서리를 둥글게 */
  border: 1px solid var(--bs-border-color);
  border-radius: .75rem;

  /* 3. 카드 안쪽에 여백(padding)을 줘서 답답하지 않게 */
  padding: 1rem;

  /* 4. 기존에 있던 왼쪽 굵은 테두리는 일반 테두리로 대체 */
  border-left: 1px solid var(--bs-border-color);
}

.event-time {
  width: 120px;
  flex-shrink: 0;
  /* Prevent shrinking */
  font-variant-numeric: tabular-nums;
  color: var(--bs-secondary-color);
}

.event-pill-time {
  font-size: 1em;
  opacity: 0.9;
  line-height: 1.2;
}

.event-pill-summary {
  font-weight: 500;
  text-overflow: ellipsis;
  white-space: normal;
  word-break: keep-all;
  /* 한글 단어 중간에 줄바꿈 방지 */
  line-height: 1.2;
  /* 줄 간격 살짝 추가 */
}

#eventEdit.btn {
  background-color: #fff;
  border-color: #0a58ca;
  color: #0a58ca;
}

#eventEdit.btn:hover {
  background-color: #0a58ca;
  border-color: #0a58ca;
  color: #fff;
}

[data-bs-theme="dark"] #eventEdit.btn {
  background-color: var(--bs-body-bg);
  /* 'color' 값을 더 밝은 색으로 변경 */
  color: var(--bs-primary);
  /* 예: #0d6efd */
  border-color: var(--bs-primary);
}

[data-bs-theme="dark"] #eventEdit.btn:hover {
  background-color: var(--bs-primary);
  color: #fff;
}

/* --- 중앙 날짜 탐색 화살표 스타일 --- */
.nav-arrow-btn {
  /* 버튼 기본 모양 제거 */

  --bs-btn-padding-x: 0.5rem;
  --bs-btn-padding-y: 0.5rem;

  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  /* 포커스 시 테두리 제거 */

  /* 화살표 아이콘 스타일 */
  font-size: 2.5rem;
  /* 아이콘 크기 */
  font-weight: 300;
  /* 아이콘 두께 */
  line-height: 1;
  color: var(--bs-secondary-color);

  /* 마우스 올렸을 때 효과 */
  transition: color 0.2s ease-in-out;

  position: relative;
  /* 위치를 수동으로 조절하기 위한 기준 설정 */
  top: -4px;
  /* 현재 위치에서 위로 2px 이동 */
}

.nav-arrow-btn:hover {
  color: var(--bs-primary);
}

/* 기본 링크 색상 */
.navbar .nav-link {
  color: var(--badge-fg);
  opacity: 0.7;
  /* 기본 상태는 살짝 연하게 */

}

/* 마우스를 올렸을 때 */
.navbar .nav-link:hover {
  opacity: 1;
  transition: all 0.2s ease-in-out;
}

/* 현재 활성화된 링크(.active) */
.navbar .nav-link.active {
  color: var(--bs-primary);
  /* 부트스트랩 기본 파란색으로 강조 */
  font-weight: 600;
  /* 폰트를 살짝 두껍게 */
  opacity: 1;
}

/* 1. 버튼 기본 스타일 */
:is(#themeToggle, #btnNewEvent, #todayBtn).btn {
  /* 배경은 투명하게 유지 */
  background-color: transparent;

  /* 완전히 투명한 대신, 은은한 테두리로 형태를 알려줌 */
  border: 1px solid var(--bs-border-color-translucent);

  color: var(--bs-secondary-color);
  /* 너무 튀지 않는 2차 색상 사용 */
  transition: all 0.2s ease-in-out;
  /* 부드러운 전환 효과 */
}

/* 2. 마우스를 올렸을 때 (Hover) 스타일 */
:is(#themeToggle, #btnNewEvent, #todayBtn).btn:hover {
  /* 마우스를 올리면 배경색이 나타나 버튼임을 확실히 인지시킴 */
  background-color: var(--bs-tertiary-bg);

  /* 테두리와 글자색도 살짝 더 선명하게 */
  border-color: var(--bs-secondary-bg);
  color: var(--bs-body-emphasis-color);
}

[data-bs-theme="dark"] :is(#themeToggle, #btnNewEvent, #todayBtn).btn {
  color: var(--badge-fg);
  background-color: transparent;
  border-color: transparent;
  font-weight: 300;
}

/* [data-bs-theme="dark"] :is(#themeToggle, #btnNewEvent, #todayBtn).btn:hover {
  color: var(--badge-bg);
} */

/* --- Small Utilities --- */
.badge {
  background-color: var(--badge-bg);
  color: #0003c0;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: .2rem .55rem;
  padding-right: .8rem;
  font-weight: 600;
}

.js-countdown {
  font-variant-numeric: tabular-nums;
}

.day-add-btn {
  position: absolute;
  top: 0.3rem;
  right: 0.3rem;
  width: 1.7rem;
  height: 1.7rem;

  /* 버튼 모양 */
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background-color: #e9ecef;
  color: #495057;
  /* 명도 대비 4.5:1 이상 */
  border: 1px solid var(--bs-border-color);
  font-size: 1.5rem;
  /* line-height: 1; */
  padding: 0 0 6px 0;
  /* <- padding-bottom으로 미세하게 위치를 올림 */
  text-decoration: none;
  cursor: pointer;

  /* 숨김 및 애니메이션 효과 */
  opacity: 0;
  transform: scale(0.8);
  transition: all 0.2s ease-in-out;
}

/* 버튼에 마우스를 올렸을 때 효과 */
.day-add-btn:hover {
  background-color: #0a58ca;
  /* 기존 --bs-primary보다 어두움 */
  border-color: #0a58ca;
  color: white;
  /* 명도 대비 5.25:1 이상 */
}

/* 지난 이벤트 그룹에 적용될 스타일 */
.past-event {
  opacity: 0.65;
  /* 내용을 살짝 흐리게 처리 */
  transition: opacity 0.2s ease-in-out;
}

/* 마우스를 올리면 다시 선명하게 보여줌 */
.past-event:hover {
  opacity: 1;
}

/* 'Past Events' 제목 스타일 */
.past-event .past-events-header {
  color: var(--badge-fg);
  margin-top: 2.5rem;
  margin-bottom: 1.5rem;
  padding-bottom: 0.75rem;
  border-bottom: 2px solid var(--bs-border-color-translucent);
  color: var(--bs-secondary-color);
  font-size: 1.5rem;
  font-weight: 600;
  /* text-transform: uppercase; */
}

/* --- 모바일 반응형 스타일 --- */
/* 화면 너비가 768px 이하일 때 적용 */
@media (max-width: 768px) {

  /* 뷰 전환 버튼 숨기기 (새로 추가) */
  #navMain .navbar-nav {
    display: none;
  }

  /* 1. 글자 크기와 여백 조정으로 공간 확보 */
  .week-headers .wh {
    font-size: .7rem;
    /* 요일 헤더 글자 축소 */
  }

  .calendar-grid .col {
    min-height: 30px;
    /* 1. 날짜 칸 최소 높이를 80px -> 60px로 더 줄입니다 */
    padding: .2rem;
  }

  .calendar-grid .col .no-events {
    display: none;
  }

  .calendar-grid .event-pill {
    font-size: .7rem;
    /* 이벤트 글자 크기 축소 */
    padding: .1rem .3rem;
    /* 이벤트 내부 여백 축소 */
  }

  /* 이벤트 알약에서 시간을 숨겨서 공간 확보 */
  .calendar-grid .event-pill span {
    display: none;
  }

  /* 2. 상단/하단 여백 축소 */
  .navbar {
    padding-top: .5rem;
    padding-bottom: .5rem;
  }

  main.container-xxl {
    margin-top: .5rem !important;
    margin-bottom: .5rem !important;
  }

  /* 3. 모바일에서는 '+' 버튼이 항상 보이도록 처리 (선택 사항) */
  .day-add-btn {
    opacity: 1;
    transform: scale(0.5);
    background-color: var(--bs-primary);
    color: white;
  }

  .calendar-grid .col:hover .day-add-btn {
    transform: scale(0.1);
    /* 호버 시 살짝 커지는 효과 */
  }
}