/* ==========================================================================
   Home Page - Calendar & Planner Styles
   ========================================================================== */

/* ===== Calendar Week View ===== */
.calendar-week {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: var(--spacing-card-content);
  padding: var(--spacing-2) 0;
}

/* ===== Home Calendar Container ===== */
#home-calendar {
  padding-bottom: var(--spacing-page-bottom);
}

/* ===== Calendar ===== */
.calendar {
  background: var(--color-bg-primary);
}

.calendar-header {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  margin-bottom: var(--spacing-2);
}

.calendar-dow {
  text-align: center;
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  padding: var(--spacing-1) 0;
}

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  transition: transform 0.2s ease;
}

.calendar-grid.swiping {
  transition: none;
}

.calendar-day {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--spacing-2) 0;
}

.calendar-day .dow {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
}

.calendar-day .date {
  width: var(--avatar-size-sm);
  height: var(--avatar-size-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  border-radius: var(--radius-full);
  cursor: pointer;
  border: none;
  background: transparent;
}

.calendar-day .date.selected {
  background: var(--color-fill-dark);
  color: var(--color-text-inverse);
  cursor: default;
}

html.dark .calendar-day .date.selected {
  background: var(--color-text-primary);
  color: var(--color-bg-primary);
}

.calendar-day .date.today {
  background: var(--color-accent-red);
  color: var(--color-text-inverse);
  cursor: default;
}

.calendar-day .date.today-text {
  color: var(--color-accent-red);
}

.calendar-day.active .date {
  background: var(--color-accent-red);
  color: var(--color-text-inverse);
  width: var(--avatar-size-sm);
  height: var(--avatar-size-sm);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
}

.calendar-day .dot {
  width: 5px;
  height: 5px;
  margin-top: var(--spacing-1);
  border-radius: var(--radius-full);
}

.calendar-day .dot.active {
  background: var(--color-fill-dark);
}

html.dark .calendar-day .dot.active {
  background: var(--color-text-primary);
}

/* ===== Event Item (formerly Schedule Item) ===== */
.event-item,
.schedule-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  padding: var(--spacing-2) 0;
  gap: var(--spacing-4);
  width: 100%;
  height: 56px;
  background: var(--color-bg-primary);
  border-radius: var(--radius-base);
}

.event-item .accent-bar,
.schedule-item .accent-bar {
  width: var(--spacing-1);
  height: var(--btn-icon-size);
  flex-shrink: 0;
  background: var(--color-fill-dark);
  border-radius: 2px;
}

.event-item .time-box,
.schedule-item .time-box {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 0;
  gap: 0;
  width: 46px;
  flex-shrink: 0;
}

.event-item .time,
.schedule-item .time {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-normal);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-text-primary);
}

.event-item .duration,
.schedule-item .duration {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-normal);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-text-secondary);
}

.event-item .title,
.schedule-item .title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-normal);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-text-primary);
}

/* ===== Todo Item ===== */
.todo-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-3);
  padding: var(--spacing-input-y) var(--spacing-4);
  background: var(--color-bg-secondary);
  border-radius: var(--radius-lg);
}

.todo-item.done .text {
  text-decoration: line-through;
  color: var(--color-text-secondary);
}

/* Checkbox styles moved to components/checkbox.css */

/* ===== Todo List Card ===== */
.todo-list-card {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--spacing-4) var(--spacing-4) var(--spacing-4) 0;
  gap: var(--spacing-card-content);
  width: 100%;
  background: var(--color-card-fill);
  border: none;
  border-radius: var(--radius-lg);
}

.todo-list-items {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding: 0;
  gap: var(--spacing-4);
  width: 100%;
}

.todo-list-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  padding: 0;
  padding-left: 21px;
  gap: 39px;
  width: 100%;
  box-sizing: border-box;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  position: relative;
}

.todo-list-item-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: var(--z-base);
}

/* Checkbox styles moved to components/checkbox.css */

.todo-list-text {
  font-family: var(--font-family-primary);
  font-style: normal;
  font-weight: var(--font-weight-normal);
  font-size: var(--font-size-xl);
  line-height: var(--line-height-normal);
  color: var(--color-text-primary);
  flex: 1;
}

.todo-list-item.done .todo-list-text {
  text-decoration-line: line-through;
  color: var(--color-text-secondary);
}

/* ===== Memo List Card ===== */
.memo-list-card {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--spacing-4) var(--spacing-4) var(--spacing-4) 0;
  gap: var(--spacing-card-content);
  width: 100%;
  background: var(--color-card-fill);
  border: none;
  border-radius: var(--radius-lg);
}

.memo-list-items {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 0;
  gap: var(--spacing-4);
  width: 100%;
}

.memo-list-item {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  padding: 0;
  padding-left: 21px;
  gap: 39px;
  width: 100%;
  box-sizing: border-box;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

.memo-list-item.readonly {
  cursor: default;
}

.memo-list-emoji {
  font-size: var(--avatar-size-sm);
  line-height: 1;
  width: var(--avatar-size-sm);
  flex-shrink: 0;
}

.memo-list-text {
  font-family: var(--font-family-primary);
  font-style: normal;
  font-weight: var(--font-weight-normal);
  font-size: var(--font-size-xl);
  line-height: var(--line-height-normal);
  color: var(--color-text-primary);
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ===== Notice Banner Wrapper ===== */
.notice-banner-wrapper {
  margin: 0 calc(-1 * var(--spacing-section)) var(--spacing-section-gap);
}

/* ===== Notice Banner (Home) ===== */
#home-calendar .notice-banner {
  background: var(--color-fill-dark);
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 var(--spacing-4);
  cursor: pointer;
  border-radius: 0;
}

#home-calendar .notice-banner__text {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-inverse);
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  margin: 0;
}

/* ===== Notification Dot ===== */
.notification-dot {
  position: absolute;
  top: -2px;
  right: -2px;
  width: var(--spacing-input-y);
  height: var(--spacing-input-y);
  background: var(--color-fill-dark);
  border-radius: var(--radius-full);
  border: 2px solid var(--color-bg-primary);
}

/* ===== Status Tabs (Active/Completed) ===== */
.status-tabs {
  display: flex;
  margin-top: var(--spacing-2);
  margin-bottom: var(--spacing-4);
  gap: var(--spacing-5);
}

.status-tabs__tab {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color 0.15s ease;
  letter-spacing: var(--letter-spacing-tight);
}

.status-tabs__tab--active {
  color: var(--color-text-primary);
}

.status-tabs__count {
  color: inherit;
}

/* ===== Month Navigation ===== */
.month-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-4);
}

.month-nav__picker {
  position: relative;
}

.month-nav__btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-1);
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
}

.month-nav__label {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
}

/* ===== Announcement Banner ===== */
.announcement-banner-wrapper {
  margin-top: 0;
  margin-bottom: var(--spacing-section-gap);
  margin-left: calc(-1 * var(--spacing-section));
  margin-right: calc(-1 * var(--spacing-section));
}

.announcement-banner {
  background: var(--color-fill-dark);
  height: 30px;
  display: flex;
  align-items: center;
  padding: 0 var(--spacing-4);
  cursor: pointer;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

.announcement-banner::-webkit-scrollbar {
  display: none;
}

.announcement-text {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-inverse);
  white-space: nowrap;
  margin: 0;
}

/* ===== Project Empty State ===== */
.project-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 192px;
  margin-top: 64px;
}

.project-empty-state__text {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  text-align: center;
}

/* ---------------------------------------------------------------------------
   Year Group (Completed projects grouped by year - Strava style)
   --------------------------------------------------------------------------- */
.year-group + .year-group {
  margin-top: var(--spacing-list-sm);
}

.year-group__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-list-md) 0;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.year-group__title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  margin: 0;
}

.year-group__right {
  display: flex;
  align-items: center;
  gap: var(--spacing-list-sm);
}

.year-group__count {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-normal);
  color: var(--color-text-secondary);
}

.year-group__chevron {
  color: var(--color-text-secondary);
  transition: transform 0.2s ease;
}

.year-group__chevron--expanded {
  transform: rotate(90deg);
}

.year-group__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-section);
  padding-top: var(--spacing-list-sm);
}

/* ---------------------------------------------------------------------------
   Completed Project Card (Strava style - 3-column grid)
   --------------------------------------------------------------------------- */
.completed-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-2);
  text-decoration: none;
}

.completed-card__image {
  width: calc(var(--spacing-section) * 4);
  height: calc(var(--spacing-section) * 4);
  border-radius: var(--radius-lg);
  background-size: cover;
  background-position: center;
  background-color: var(--color-bg-secondary);
}

.completed-card__title {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  text-align: center;
  line-height: var(--line-height-tight);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.completed-card__date {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-normal);
  color: var(--color-text-secondary);
  margin-top: calc(-1 * var(--spacing-1));
  margin-bottom: 0;
}

/* Web: calendar navigation arrows */
.calendar-nav-wrapper {
  display: flex;
  align-items: center;
}

.calendar-nav-wrapper .calendar {
  flex: 1;
}

.calendar-nav-arrow--web {
  display: none;
}

/* Mobile: vertical gap between cards in same row */
.home-row {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-list-sm);
}

/* Web (desktop): horizontal scroll rows + nav arrows */
@media (min-width: 768px) {
  .web-layout .calendar-nav-arrow--web {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    color: var(--color-text-secondary);
    text-decoration: none;
    border-radius: var(--radius-full);
    transition: background var(--transition-fast), color var(--transition-fast);
  }

  .web-layout .calendar-nav-arrow--web:hover {
    background: var(--color-hover-subtle);
    color: var(--color-text-primary);
  }

  .web-layout .items-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
  }

  .web-layout .home-row {
    display: flex;
    gap: var(--spacing-3);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .web-layout .home-row::-webkit-scrollbar {
    display: none;
  }

  .web-layout .home-row > *,
  .web-layout .home-row > .planner-card-list {
    flex: 0 0 calc(50% - var(--spacing-3) / 2);
    min-width: calc(50% - var(--spacing-3) / 2);
    scroll-snap-align: start;
  }
}

