/* 14-ct-import.css — CellarTracker import UI components + legal pages.
 *
 * Sections (added incrementally by tasks in the CT-import plan):
 *   - Empty-cellar editorial CTA
 *   - Drop zone (upload page)
 *   - Status dots (history page + progress page)
 *   - Count strip (progress page)
 *   - Now-reading line (progress page)
 *   - Review card (review queue)
 *   - History row (import history page)
 *   - Three-beat strip (upload page)
 *   - Done / failure states (progress + review queue)
 *   - Privacy policy page
 */

/* ─── Empty-cellar editorial CTA ─── */
.cellar-empty {
  padding: var(--space-7) 0;
  max-width: 56rem;
}

.cellar-empty__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--ivory-100);
  margin: var(--space-2) 0 var(--space-3);
  max-width: 22ch;
}

.cellar-empty__lead {
  font-size: 1.0625rem;
  line-height: 1.6;
  color: var(--ivory-200);
  max-width: 50ch;
  margin: 0 0 var(--space-5);
}

.cellar-empty__actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

/* ─── Drop zone (upload page) ─── */
/*
 * The real <input type="file"> is visually hidden but accessibility-
 * preserved. A <label> wraps it as the drop zone. State classes
 * (idle / dragover / has-file / submitting) flip via JS.
 */

.ct-drop-zone {
  position: relative;
  display: block;
  width: 100%;
  padding: var(--space-7) var(--space-5);
  background: var(--noir-900);
  border: 2px dashed var(--border-default);
  border-radius: var(--radius-lg);
  text-align: center;
  cursor: pointer;
  transition: border-color var(--duration-normal) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-out);
}

.ct-drop-zone:hover,
.ct-drop-zone:focus-within {
  border-color: var(--border-medium);
}

.ct-drop-zone--dragover {
  border-color: var(--border-accent-hover);
  border-style: dashed;
  box-shadow: var(--shadow-glow);
}

.ct-drop-zone--has-file {
  border-style: solid;
  border-color: var(--border-default);
}

.ct-drop-zone__input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.ct-drop-zone__input:focus-visible + .ct-drop-zone__visual {
  outline: 2px solid var(--amber-400);
  outline-offset: 4px;
  border-radius: var(--radius-md);
}

.ct-drop-zone__icon {
  display: inline-flex;
  margin-bottom: var(--space-3);
  color: var(--amber-400);
}

.ct-drop-zone__icon svg {
  width: 36px;
  height: 36px;
}

.ct-drop-zone__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--ivory-100);
  margin: 0 0 var(--space-2);
}

.ct-drop-zone__hint {
  font-size: 0.9rem;
  color: var(--ivory-300);
  margin: 0;
}

/* File-selected state — content swaps via JS to show filename + size */
.ct-drop-zone__file-name {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--ivory-100);
  margin: 0 0 var(--space-1);
  word-break: break-all;
}

.ct-drop-zone__file-meta {
  font-size: 0.85rem;
  color: var(--ivory-400);
  margin: 0 0 var(--space-3);
}

.ct-drop-zone__change {
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ivory-400);
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: color var(--duration-fast) var(--ease-out);
}

.ct-drop-zone__change:hover,
.ct-drop-zone__change:focus-visible {
  color: var(--amber-300);
  outline: none;
}

/* Submitting state — spinner overlay */
.ct-drop-zone--submitting .ct-drop-zone__visual {
  opacity: 0.6;
}

.ct-drop-zone__spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 28px;
  height: 28px;
  margin: -14px 0 0 -14px;
  border: 3px solid var(--border-default);
  border-top-color: var(--amber-400);
  border-radius: 50%;
  animation: cellar-spin 0.8s linear infinite;
  display: none;
}

.ct-drop-zone--submitting .ct-drop-zone__spinner {
  display: block;
}

/* ─── Upload page ─── */

.ct-upload__trust {
  margin: var(--space-3) 0 0;
  font-size: 0.85rem;
  color: var(--ivory-400);
  max-width: 56rem;
}

.ct-upload__trust a {
  color: var(--ivory-300);
  text-decoration: underline;
  text-decoration-thickness: from-font;
  text-underline-offset: 0.2em;
  transition: color var(--duration-fast) var(--ease-out);
}

.ct-upload__trust a:hover,
.ct-upload__trust a:focus-visible {
  color: var(--amber-300);
}

.ct-upload__form {
  max-width: 56rem;
}

.ct-upload__actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.ct-upload__history-link {
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ivory-400);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}

.ct-upload__history-link:hover,
.ct-upload__history-link:focus-visible {
  color: var(--amber-300);
}

.ct-upload__beats {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--noir-900);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  align-items: start;
  max-width: 56rem;
}

@media (min-width: 768px) {
  .ct-upload__beats {
    grid-template-columns: 1fr auto 1fr auto 1fr;
  }
}

.ct-upload__beat-eyebrow {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--amber-400);
  margin: 0 0 var(--space-1);
}

.ct-upload__beat-time {
  font-size: 0.8rem;
  color: var(--ivory-400);
  margin: 0 0 var(--space-2);
}

.ct-upload__beat-body {
  font-size: 0.9rem;
  color: var(--ivory-300);
  margin: 0;
  line-height: 1.45;
}

.ct-upload__beat-sep {
  color: var(--ivory-400);
  align-self: center;
  font-size: 1.2rem;
  display: none;
}

@media (min-width: 768px) {
  .ct-upload__beat-sep { display: inline; }
}

.ct-upload__instructions {
  max-width: 56rem;
  padding: var(--space-5);
  background: var(--noir-900);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}

.ct-upload__instructions > summary {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--ivory-100);
  cursor: pointer;
  list-style: none;
}

.ct-upload__instructions > summary::-webkit-details-marker,
.ct-upload__instructions > summary::marker {
  display: none;
}

.ct-upload__instructions-list {
  margin: var(--space-3) 0 0 var(--space-5);
  color: var(--ivory-200);
  line-height: 1.7;
}

/* mt-6 utility (not in 12-utilities.css; defined here local to CT import) */
.mt-6 { margin-top: var(--space-6) !important; }

/* ─── Progress page — count strip ─── */

.ct-progress__counts {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-5);
  padding: var(--space-5) 0;
  border-bottom: 1px solid var(--border-default);
}

.ct-progress__count {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-1);
}

.ct-progress__count-num {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ivory-100);
}

.ct-progress__count-label {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ivory-400);
}

.ct-progress__count-of {
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  color: var(--ivory-400);
  text-transform: none;
}

.ct-progress__bar {
  height: 1px;
  margin-top: var(--space-3);
  background: var(--noir-700);
  overflow: hidden;
  border-radius: 1px;
}

.ct-progress__bar-fill {
  height: 100%;
  background: var(--amber-400);
  transition: width var(--duration-slow) var(--ease-out);
}

/* ─── Progress page — body ─── */

.ct-progress__header h1 {
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  margin: var(--space-1) 0 0;
}

.ct-progress__now-reading {
  margin: var(--space-4) 0;
  font-size: 0.85rem;
  color: var(--ivory-400);
  font-style: italic;
}

.ct-progress__body {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-top: var(--space-5);
}

@media (min-width: 992px) {
  .ct-progress__body {
    grid-template-columns: 1fr 1fr;
  }
}

.ct-progress__matched-list,
.ct-progress__review-list {
  list-style: none;
  padding: 0;
  margin: var(--space-3) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.ct-progress__matched-item,
.ct-progress__review-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  animation: cellar-rise 0.7s var(--ease-out) both;
}

.ct-progress__matched-item .wine-type-dot,
.ct-progress__review-item .wine-type-dot {
  margin-top: 0.4em;
}

.ct-progress__matched-text,
.ct-progress__review-text {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
}

.ct-progress__matched-producer,
.ct-progress__review-csv {
  font-size: 0.9rem;
  color: var(--ivory-300);
}

.ct-progress__matched-wine {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 500;
  color: var(--ivory-100);
}

.ct-progress__review-link {
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ivory-400);
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--duration-fast) var(--ease-out);
}

.ct-progress__review-link:hover,
.ct-progress__review-link:focus-visible {
  color: var(--amber-300);
}

.ct-progress__review-banner {
  font-size: 0.85rem;
  color: var(--ivory-200);
  background: rgba(212, 168, 83, 0.08);
  border: 1px solid rgba(212, 168, 83, 0.2);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  margin: var(--space-3) 0 0;
}

.ct-progress__empty {
  font-size: 0.85rem;
  color: var(--ivory-400);
  font-style: italic;
}

.ct-progress__done-actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

/* ─── Review queue card ─── */

.ct-review-card {
  background: var(--noir-900);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  margin-bottom: var(--space-4);
  transition: border-color var(--duration-normal) var(--ease-out);
}

.ct-review-card__eyebrow {
  margin: 0 0 var(--space-2);
}

.ct-review-card__eyebrow--muted {
  color: var(--ivory-400);
}

.ct-review-card__csv {
  font-style: italic;
  color: var(--ivory-300);
  margin: 0 0 var(--space-5);
  font-size: 1rem;
}

.ct-review-card__csv-vintage {
  font-style: normal;
}

.ct-review-card__csv-qty {
  font-style: normal;
  font-size: 0.9rem;
  color: var(--ivory-400);
}

.ct-review-card__suggestion {
  display: flex;
  gap: var(--space-3);
  margin: 0 0 var(--space-5);
}

.ct-review-card__suggestion .wine-type-dot {
  margin-top: 0.5em;
  flex-shrink: 0;
}

.ct-review-card__suggestion-text {
  flex: 1;
  min-width: 0;
}

.ct-review-card__suggestion-producer {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--ivory-100);
  margin: 0;
  letter-spacing: -0.01em;
}

.ct-review-card__suggestion-wine {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--ivory-100);
  margin: 0 0 var(--space-1);
  letter-spacing: -0.01em;
}

.ct-review-card__suggestion-meta {
  font-size: 0.85rem;
  color: var(--ivory-300);
  margin: 0;
}

.ct-review-card__no-match {
  color: var(--ivory-200);
  margin: 0 0 var(--space-4);
}

.ct-review-card__actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.ct-review-card__form {
  margin: 0;
}

.ct-review-card__search-toggle {
  background: transparent;
  border: 0;
  padding: 0;
  font-size: 0.85rem;
  color: var(--ivory-400);
  cursor: pointer;
  transition: color var(--duration-fast) var(--ease-out);
}

.ct-review-card__search-toggle:hover,
.ct-review-card__search-toggle:focus-visible {
  color: var(--amber-300);
  outline: none;
}

.ct-review-card__skip {
  background: transparent;
  border: 0;
  padding: 0;
  font-size: 0.85rem;
  color: var(--ivory-400);
  cursor: pointer;
  transition: color var(--duration-fast) var(--ease-out);
}

.ct-review-card__skip:hover,
.ct-review-card__skip:focus-visible {
  color: var(--amber-300);
  outline: none;
}

.ct-review-card__search {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-subtle);
}

.ct-review-card__search-results {
  margin-top: var(--space-3);
}

.ct-review-card__search-skip {
  margin-top: var(--space-3);
}

/* Resolved / skipped states */
.ct-review-card__resolved {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: 0.95rem;
  color: var(--ivory-300);
  margin: 0;
}

.ct-review-card__resolved-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ivory-400);
  flex-shrink: 0;
}

.ct-review-card__resolved-dot--sage { background: var(--sage-500); }
.ct-review-card__resolved-dot--rouge { background: var(--rouge-500); }

.ct-review-card__resolved--skipped { color: var(--ivory-400); }
.ct-review-card__resolved--failed { color: var(--rouge-400); }

/* ─── Review queue — page chrome ─── */

.ct-review__progress {
  font-size: 0.85rem;
  color: var(--ivory-400);
  margin-top: var(--space-2);
}

.ct-review__list {
  list-style: none;
  padding: 0;
  margin: var(--space-5) 0 0;
}

.ct-review__done {
  padding: var(--space-7) 0;
  text-align: left;
}

.ct-review__done-summary {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--ivory-100);
  margin: var(--space-2) 0 var(--space-5);
  letter-spacing: -0.01em;
}

.ct-review__done-actions {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}

/* ─── History page ─── */

.ct-history__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-6);
}

.ct-history__summary {
  font-size: 0.85rem;
  color: var(--ivory-400);
  margin-top: var(--space-2);
}

.ct-history__actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.ct-history__back-link {
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ivory-300);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}

.ct-history__back-link:hover,
.ct-history__back-link:focus-visible {
  color: var(--amber-300);
}

.ct-history__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.ct-history-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--border-subtle);
  transition: border-bottom-color var(--duration-fast) var(--ease-out);
}

.ct-history-row:hover {
  border-bottom-color: var(--border-accent-hover);
}

.ct-history-row__status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ivory-400);
  flex-shrink: 0;
}

.ct-history-row__status-dot--completed { background: var(--sage-500); }
.ct-history-row__status-dot--review_required { background: var(--amber-400); }
.ct-history-row__status-dot--uploaded,
.ct-history-row__status-dot--parsing,
.ct-history-row__status-dot--matching { background: var(--amber-400); }
.ct-history-row__status-dot--failed { background: var(--rouge-500); }

.ct-history-row__status-dot--pulse {
  animation: cellar-pulse 1.6s ease-in-out infinite;
}

.ct-history-row__body {
  min-width: 0;
}

.ct-history-row__top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-3);
}

.ct-history-row__filename {
  color: var(--ivory-100);
  font-size: 1rem;
}

.ct-history-row__time {
  font-size: 0.8rem;
  color: var(--ivory-400);
  white-space: nowrap;
}

.ct-history-row__stats {
  font-size: 0.85rem;
  color: var(--ivory-300);
  margin: var(--space-1) 0 0;
}

.ct-history-row__action {
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ivory-400);
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--duration-fast) var(--ease-out);
}

.ct-history-row__action:hover,
.ct-history-row__action:focus-visible {
  color: var(--amber-300);
}

.ct-history__empty {
  text-align: center;
  padding: var(--space-8) var(--space-4);
}

.ct-history__empty-title {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 500;
  color: var(--ivory-100);
  margin: var(--space-3) 0 var(--space-2);
}

.ct-history__empty-body {
  color: var(--ivory-300);
  margin: 0 0 var(--space-5);
}

/* ─── Onboarding rate (post-import) ─── */

.ct-onboarding-rate__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--space-4);
}

.ct-onboarding-rate__card {
  background: var(--noir-900);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}

.ct-onboarding-rate__producer {
  font-size: 0.85rem;
  color: var(--ivory-300);
  margin: 0 0 var(--space-1);
}

.ct-onboarding-rate__name {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ivory-100);
  margin: 0 0 var(--space-1);
}

.ct-onboarding-rate__vintage {
  font-size: 0.85rem;
  color: var(--ivory-400);
  margin: 0 0 var(--space-3);
}

.ct-onboarding-rate__stars {
  display: inline-flex;
  gap: 4px;
}

.ct-onboarding-rate__star {
  background: transparent;
  border: 0;
  padding: 4px;
  cursor: pointer;
  color: var(--ivory-400);
  transition: color var(--duration-fast) var(--ease-out);
}

.ct-onboarding-rate__star svg {
  width: 22px;
  height: 22px;
  fill: currentColor;
}

.ct-onboarding-rate__star--filled,
.ct-onboarding-rate__star:hover {
  color: var(--amber-400);
}

.ct-onboarding-rate__empty {
  font-style: italic;
  color: var(--ivory-400);
}

.ct-onboarding-rate__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* ─── Privacy policy page ─── */

.privacy {
  max-width: 56rem;
}

.privacy__header {
  margin-bottom: var(--space-7);
}

.privacy__body p {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--ivory-200);
  max-width: 65ch;
  margin: 0 0 var(--space-5);
}

.privacy__heading {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ivory-100);
  margin: var(--space-6) 0 var(--space-3);
}

.privacy__updated {
  margin-top: var(--space-7);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-subtle);
  font-size: 0.85rem;
  color: var(--ivory-400);
  font-style: italic;
}
