/* ===== List View ===== */

.list-view__actions {
  display: flex;
  gap: var(--sp-sm);
  margin-bottom: var(--sp-md);
  align-items: center;
}

.list-view__actions .btn--leaf {
  flex: 0 0 auto;
}

.list-view__actions .btn--outline {
  margin-left: auto;
}

/* ===== Filter Panel ===== */

.filter-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-normal), margin var(--transition-normal);
  margin-bottom: 0;
}

.filter-panel--open {
  max-height: 200px;
  margin-bottom: var(--sp-md);
}

.filter-panel__inner {
  background: var(--green-light);
  border-radius: var(--radius-md);
  padding: var(--sp-md);
}

.filter-panel__title {
  display: block;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-medium);
  margin-bottom: var(--sp-sm);
}

.filter-panel__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-sm);
  margin-bottom: var(--sp-sm);
}

.filter-panel__clear {
  margin-top: var(--sp-xs);
}

/* ===== Detail View ===== */

.detail-view__photo {
  width: 100%;
  aspect-ratio: 4 / 3;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: var(--radius-md);
  margin-bottom: var(--sp-md);
}

.detail-view__name {
  font-size: 1.4rem;
  margin-bottom: var(--sp-xs);
}

.detail-view__description {
  font-size: 0.95rem;
  color: var(--text-medium);
  line-height: 1.4;
  margin-bottom: var(--sp-md);
}

.detail-view__section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-sm);
}

.detail-view__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-sm);
  margin-bottom: var(--sp-md);
}

.detail-view__section {
  margin-bottom: var(--sp-lg);
}

.detail-view__section h3 {
  color: var(--green-dark);
  margin-bottom: var(--sp-sm);
  font-size: 1rem;
}

.ingredient-list {
  list-style: none;
  padding: 0;
}

.ingredient-list li {
  padding: var(--sp-xs) 0;
  border-bottom: 1px solid var(--green-light);
  color: var(--text-dark);
  position: relative;
  padding-left: var(--sp-md);
}

.ingredient-list li::before {
  content: '\2022';
  color: var(--green-primary);
  font-weight: bold;
  position: absolute;
  left: 0;
}

/* Checkable ingredient list (detail view shopping mode) */
.ingredient-list--checkable {
  padding: 0;
}

.ingredient-check {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
  padding: var(--sp-sm) 0;
  border-bottom: 1px solid var(--green-light);
  position: relative;
  padding-left: 0;
}

.ingredient-check::before {
  display: none;
}

.ingredient-check__box {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  accent-color: var(--green-primary);
  cursor: pointer;
}

.ingredient-check__label {
  flex: 1;
  font-size: 0.95rem;
  cursor: pointer;
  transition: opacity var(--transition-fast), text-decoration var(--transition-fast);
}

.ingredient-check--done .ingredient-check__label {
  text-decoration: line-through;
  opacity: 0.5;
  color: var(--text-light);
}

.btn--share {
  width: 100%;
  margin-top: var(--sp-lg);
  padding: var(--sp-sm) var(--sp-md);
  background: var(--green-light);
  color: var(--green-dark);
  border: 1.5px solid var(--green-primary);
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--transition-fast);
}

.btn--share:active {
  background: var(--green-primary);
  color: var(--white);
}

.detail-view__actions {
  display: flex;
  gap: var(--sp-sm);
  margin-top: var(--sp-sm);
}

.detail-view__actions .btn {
  flex: 1;
}

/* ===== Edit View ===== */

.edit-form {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ingredient-inputs {
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
  margin-bottom: var(--sp-sm);
}

.ingredient-row {
  display: flex;
  gap: var(--sp-xs);
  align-items: center;
}

.ingredient-row .form-input {
  flex: 1;
}

.edit-form__actions {
  display: flex;
  gap: var(--sp-sm);
  margin-top: var(--sp-lg);
  padding-top: var(--sp-md);
  border-top: 1px solid var(--green-light);
}

.edit-form__actions .btn {
  flex: 1;
}

/* ===== Tags View ===== */

.tag-create-form {
  margin-bottom: var(--sp-lg);
}

.tag-create-form h3 {
  margin-bottom: var(--sp-sm);
  color: var(--green-dark);
}

.tag-create-form__row {
  display: flex;
  gap: var(--sp-sm);
  align-items: center;
}

.tag-create-form__row .form-input {
  flex: 1;
}

.tag-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-sm);
}

.tag-list__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-sm) var(--sp-md);
  background: var(--white);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
}

/* ===== Share Modal ===== */

.share-modal {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: var(--sp-lg);
  max-width: 360px;
  width: 100%;
  box-shadow: var(--shadow-panel);
  max-height: 85vh;
  overflow-y: auto;
}

.share-modal__title {
  text-align: center;
  color: var(--green-dark);
  margin-bottom: var(--sp-md);
}

.share-modal__img {
  width: 100%;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-light);
  margin-bottom: var(--sp-sm);
}

.share-modal__hint {
  font-size: 0.85rem;
  color: var(--text-medium);
  text-align: center;
  margin-bottom: var(--sp-md);
  line-height: 1.4;
}

.share-modal__actions {
  display: flex;
  gap: var(--sp-sm);
}

.share-modal__actions .btn {
  flex: 1;
}

/* ===== Backup Bar ===== */

.backup-bar {
  display: flex;
  gap: var(--sp-sm);
  justify-content: center;
  padding-top: var(--sp-lg);
  margin-top: var(--sp-lg);
  border-top: 1px solid var(--green-light);
}
