/* ==========================================================================
   Together Form - Create/Edit Page Styles
   Header styles moved to components/header.css
   ========================================================================== */

/* ==========================================================================
   Page Layout
   ========================================================================== */
.create-project {
  height: 100vh;
  overflow-x: hidden;
  overflow-y: auto;
  /* Reserve scrollbar space even when content fits, so the sticky header's
     Next button never lands flush against a suddenly-appearing scrollbar. */
  scrollbar-gutter: stable;
  -webkit-overflow-scrolling: touch;
  padding-bottom: var(--spacing-page-bottom);
}

/* create-project 페이지에서 body 스크롤 방지 및 safe area 처리 */
body:has(.create-project) {
  overflow: hidden;
  padding-top: 0; /* safe area는 헤더가 처리 */
}

body:has(.create-project) main {
  padding-bottom: 0;
}

/* sticky 헤더의 negative margin으로 콘텐츠가 헤더 뒤에 가려지는 문제 보상 */
.create-project > .header--sticky + * {
  padding-top: env(safe-area-inset-top);
}

/* Mobile web: .create-project 컨테이너가 URL bar 뒤에 숨지 않도록 safe area 오프셋 */
@media (max-width: 767px) {
  body.web-layout:has(.create-project) {
    padding-top: env(safe-area-inset-top);
  }

  .web-layout .create-project {
    height: calc(100vh - env(safe-area-inset-top));
    height: calc(100dvh - env(safe-area-inset-top));
  }

  /* safe area는 body에서 이미 처리되므로 헤더의 negative margin 제거 */
  .web-layout .create-project > .header--sticky {
    margin-top: 0;
    padding-top: var(--spacing-4);
  }

  /* sticky 헤더 이후 콘텐츠의 safe area padding 제거 (중복 방지) */
  .web-layout .create-project > .header--sticky + * {
    padding-top: 0;
  }
}

/* ==========================================================================
   Form
   ========================================================================== */
.create-form {
  padding: 0;
}

.create-form .form-field:has(textarea) {
  margin-bottom: var(--spacing-list-sm);
}


/* Form Actions - Submit button container */
.form-actions {
  padding-top: var(--spacing-section);
}

/* Error Toast - Fixed overlay at top */
.form-error-toast {
  position: fixed;
  top: var(--header-height);
  left: var(--spacing-section);
  right: var(--spacing-section);
  z-index: var(--z-modal);
  background: var(--color-warning-light);
  border: 1px solid var(--color-warning);
  border-radius: var(--radius-base);
  padding: var(--spacing-list-md);
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-list-sm);
  box-shadow: var(--shadow-dropdown);
  animation: slideDown 0.3s ease;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.form-error-toast__content {
  flex: 1;
}

.form-error-toast__content p {
  margin: 0;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  color: var(--color-warning);
  line-height: 1.4;
}

.form-error-toast__content p + p {
  margin-top: var(--spacing-1);
}

.form-error-toast__close {
  width: var(--icon-size-lg);
  height: var(--icon-size-lg);
  background: none;
  border: none;
  color: var(--color-warning);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 0;
}

.form-error-toast.hidden {
  display: none;
}

/* ==========================================================================
   Cover Upload - Compact Button Style
   ========================================================================== */
.cover-add-btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-1);
  padding: var(--spacing-list-md);
  background: var(--color-bg-white);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-base);
  cursor: pointer;
  color: var(--color-text-secondary);
  transition: border-color 0.15s ease;
}

.cover-add-btn svg {
  flex-shrink: 0;
}

.cover-add-btn:hover {
  border-color: var(--color-text-secondary);
}

.cover-add-btn span:first-of-type {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.cover-add-btn__hint {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin-left: auto;
}

/* Cover Thumbnail - Compact preview after upload */
.cover-thumb {
  display: flex;
  align-items: center;
  gap: var(--spacing-list-sm);
  padding: var(--spacing-list-sm) var(--spacing-list-md);
  background: var(--color-bg-white);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-base);
}

.cover-thumb__image {
  width: 48px;
  height: 32px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}

.cover-thumb__text {
  flex: 1;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  color: var(--color-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cover-thumb__remove {
  width: 28px;
  height: 28px;
  background: none;
  border: none;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--color-text-muted);
  flex-shrink: 0;
  transition: color 0.15s ease, background-color 0.15s ease;
}

.cover-thumb__remove:hover {
  color: var(--color-danger);
  background: var(--color-danger-light);
}

/* Form field styles moved to components/form_field.css
   Use .form-field, .form-field__label, .form-field__hint, .form-field__input */

/* ==========================================================================
   Duration Fields
   ========================================================================== */
.create-duration {
  display: flex;
  gap: var(--spacing-section);
}

.create-duration__item {
  display: flex;
  align-items: center;
  gap: var(--spacing-list-sm);
  flex-wrap: wrap;
}

.create-duration__error {
  width: 100%;
  font-size: var(--font-size-xs);
  color: var(--color-warning);
  margin-top: -2px;
}

.create-duration__input {
  width: 48px;
  height: var(--btn-height-sm);
  padding: 0 var(--spacing-1);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  text-align: center;
  color: var(--color-text-primary);
  background: var(--color-bg-white);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-base);
  outline: none;
}

.create-duration__input--error,
.was-validated .create-duration__input:invalid {
  border-color: var(--color-warning);
}

.create-duration__label {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  color: var(--color-text-primary);
}

/* ==========================================================================
   Tags
   ========================================================================== */
.create-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-list-sm);
}

/* Tag selector styles moved to components/tag.css */
/* Use .tag-selector, .tag-selector__input, .tag-selector__label, .tag-add */

/* ==========================================================================
   Step 2 - Schedule Editor
   ========================================================================== */
/* Day Card Inline Validation Error */
.create-day-card--error {
  border-color: var(--color-warning);
}

.create-day-card__error {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-xs);
  color: var(--color-warning);
  margin-top: var(--spacing-1);
}

.create-week-pick-error {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-warning);
  margin-bottom: var(--spacing-list-sm);
}

/* Week Header */
.create-week-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 0 var(--spacing-list-md) 0;
  gap: var(--spacing-section);
}

.create-week-info {
  display: flex;
  align-items: center;
  gap: var(--spacing-list-md);
  flex-shrink: 0;
}

.create-week-info__label {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  white-space: nowrap;
}

.create-week-info__label strong {
  color: var(--color-text-primary);
  font-weight: var(--font-weight-semibold);
}

/* Copy Toggle */
.create-copy-toggle {
  display: flex;
  align-items: center;
  gap: var(--spacing-list-sm);
  cursor: pointer;
}

.create-copy-toggle__icon {
  color: var(--color-text-secondary);
  transition: color 0.2s ease;
}

.create-copy-toggle__checkbox:checked ~ .create-copy-toggle__icon,
.create-copy-toggle:has(.create-copy-toggle__checkbox:checked) .create-copy-toggle__icon {
  color: var(--color-accent-orange);
}

.create-copy-toggle__checkbox {
  display: none;
}

.create-copy-toggle__switch {
  width: 36px;
  height: var(--icon-size-md);
  background: var(--color-border-soft);
  border-radius: var(--radius-lg);
  position: relative;
  transition: background-color 0.2s ease;
}

.create-copy-toggle__switch::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  background: var(--color-bg-white);
  border-radius: var(--radius-full);
  transition: transform 0.2s ease;
}

.create-copy-toggle__checkbox:checked + .create-copy-toggle__switch {
  background: var(--color-accent-orange);
}

.create-copy-toggle__checkbox:checked + .create-copy-toggle__switch::after {
  transform: translateX(16px);
}

/* Week Navigator */
.create-week-nav {
  display: flex;
  align-items: center;
  gap: var(--spacing-1);
}

.create-week-nav__arrow {
  width: 28px;
  height: 28px;
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-secondary);
  padding: 0;
}

.create-week-nav__selector-wrapper {
  position: relative;
}

.create-week-nav__selector {
  display: flex;
  align-items: center;
  gap: var(--spacing-card-content);
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
}

/* Week Dropdown */
.create-week-dropdown {
  position: absolute;
  top: calc(100% + var(--spacing-list-sm));
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-bg-glass);
  backdrop-filter: blur(10px);
  border: 1.5px solid var(--color-glass-border);
  border-radius: var(--radius-base);
  box-shadow: var(--shadow-dropdown);
  padding: var(--spacing-list-sm);
  min-width: 120px;
  max-height: 240px;
  overflow-y: auto;
  overflow-x: hidden;
  z-index: var(--z-popover);
}

.create-week-dropdown__option {
  display: block;
  width: 100%;
  padding: var(--spacing-input-y) var(--spacing-section);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  background: none;
  border: none;
  border-radius: var(--radius-base);
  cursor: pointer;
  text-align: left;
  transition: background-color 0.15s ease;
}

.create-week-dropdown__option:hover {
  background: var(--color-hover-subtle);
}

.create-week-dropdown__option--active {
  color: var(--color-accent-orange);
}

.create-week-dropdown__option--active:hover {
  background: var(--color-warning-subtle-bg);
}

/* Week Panel */
.create-week-panel {
  /* padding handled by parent .create-form */
}

/* Days Container */
.create-days {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-list-sm);
}

.create-days--disabled {
  opacity: var(--opacity-disabled);
  pointer-events: none;
}

/* Day Card */
.create-day-card {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-list-md);
  padding: var(--spacing-section);
  background: var(--color-bg-primary);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-base);
  transition: all 0.15s ease;
}

.create-day-card--active {
  border-color: var(--color-text-secondary);
}

.create-day-card__left {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-1);
  flex-shrink: 0;
}

.create-day-card__checkbox {
  width: 28px;
  height: 28px;
  border-radius: var(--radius-full);
  border: 2px solid var(--color-border-soft);
  background: var(--color-bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.15s ease;
  color: transparent;
  flex-shrink: 0;
}

.create-day-card__checkbox svg {
  opacity: 0;
  transition: opacity 0.15s ease;
}

.create-day-card--selected .create-day-card__checkbox {
  border-color: var(--color-fill-dark);
  background: var(--color-fill-dark);
  color: var(--color-bg-white);
}

.create-day-card--selected .create-day-card__checkbox svg {
  opacity: 1;
  stroke: var(--color-bg-white);
}

.create-day-card__day {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
}

.create-day-card--selected .create-day-card__day,
.create-day-card--active .create-day-card__day {
  color: var(--color-text-secondary);
}

.create-day-card__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-title-subtitle);
  min-width: 0;
  padding: 2px 0;
}

.create-day-card__input {
  width: 100%;
  font-family: var(--font-family-primary);
  background: transparent;
  border: none;
  outline: none;
  padding: 0;
}

.create-day-card__input--title {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
}

.create-day-card__input--desc {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  resize: none;
  overflow: hidden;
  min-height: var(--icon-size-md);
  line-height: 1.4;
}

.create-day-card--active .create-day-card__input--title,
.create-day-card--selected .create-day-card__input--title {
  color: var(--color-text-primary);
}

.create-day-card--active .create-day-card__input--desc,
.create-day-card--selected .create-day-card__input--desc {
  color: var(--color-text-secondary);
}

.create-day-card__input::placeholder {
  color: var(--color-text-muted);
}

/* Week Picker styles moved to components/week_picker.css */
