/* GoedOnline — pre-checkout intake form. */

.intake-page__container {
  max-width: 1180px;
}

.intake-layout {
  display: grid;
  gap: var(--sp-6);
  grid-template-columns: 1fr;
  align-items: start;
}

@media (min-width: 1040px) {
  .intake-layout {
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: var(--sp-7);
  }
}

/* Compact sticky sidebar */
.intake-aside {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  box-shadow: var(--sh-xs);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

@media (min-width: 1040px) {
  .intake-aside {
    position: sticky;
    top: 100px;
  }
}

.intake-aside__title {
  font-family: var(--font-display);
  font-size: 0.6875rem;
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-mute);
  margin: 0;
}

.intake-aside__items {
  display: grid;
  gap: var(--sp-3);
  margin: 0;
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--color-line-soft);
}

.intake-aside__items li {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-2);
  align-items: baseline;
  min-width: 0;
  font-size: 0.8125rem;
  line-height: 1.35;
}

.intake-aside__name {
  color: var(--color-ink);
  font-weight: var(--weight-medium);
  min-width: 0;
  overflow-wrap: anywhere;
}

.intake-aside__price {
  font-family: var(--font-display);
  font-weight: var(--weight-semibold);
  color: var(--color-ink);
  font-feature-settings: "tnum";
  white-space: nowrap;
  text-align: right;
  font-size: 0.8125rem;
}

.intake-aside__price small {
  display: block;
  font-weight: var(--weight-regular);
  color: var(--color-mute);
  font-size: 0.625rem;
  letter-spacing: 0.02em;
}

.intake-aside__totals {
  display: grid;
  gap: 4px;
}

.intake-aside__line {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 0.8125rem;
  color: var(--color-mute);
  font-feature-settings: "tnum";
}

.intake-aside__line--total {
  margin-top: var(--sp-2);
  padding-top: var(--sp-2);
  border-top: 1px solid var(--color-line-soft);
  color: var(--color-ink);
  font-family: var(--font-display);
}

.intake-aside__line--total span:first-child {
  font-weight: var(--weight-semibold);
  font-size: 0.875rem;
  color: var(--color-ink);
}

.intake-aside__line--total strong {
  font-family: var(--font-display);
  font-weight: var(--weight-bold);
  font-size: 1.0625rem;
  color: var(--color-ink);
}

.intake-aside__note {
  margin: 0;
  font-size: 0.75rem;
  color: var(--color-mute);
  line-height: 1.5;
  padding-top: var(--sp-3);
  border-top: 1px solid var(--color-line-soft);
}

.intake-card {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--r-2xl);
  padding: var(--sp-8) var(--sp-7);
  box-shadow: var(--sh-md);
}

@media (max-width: 720px) {
  .intake-card {
    padding: var(--sp-5) var(--sp-4);
    border-radius: var(--r-xl);
  }
}

/* Progress */
.intake-progress {
  margin-bottom: var(--sp-8);
}

.intake-progress__bar {
  position: relative;
  height: 3px;
  background: var(--color-line);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: var(--sp-4);
}

.intake-progress__fill {
  position: absolute;
  inset: 0;
  width: var(--p, 20%);
  background: var(--color-slate-900);
  transition: width var(--dur-3) var(--ease-out);
  border-radius: 2px;
}

.intake-progress__steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--sp-2);
  margin: 0;
  padding: 0;
  list-style: none;
}

.intake-progress__steps li {
  font-size: 0.6875rem;
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-mute);
  position: relative;
  padding-top: var(--sp-2);
  text-align: center;
}

.intake-progress__steps li::before {
  content: attr(data-step-label);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: var(--r-full);
  background: var(--color-slate-100);
  color: var(--color-mute);
  font-feature-settings: "tnum";
  margin: 0 auto var(--sp-2);
  transition: background var(--dur-2) var(--ease-out), color var(--dur-2) var(--ease-out);
  font-size: 0.75rem;
}

.intake-progress__steps li.is-active {
  color: var(--color-ink);
}

.intake-progress__steps li.is-active::before {
  background: var(--color-slate-900);
  color: #fff;
}

.intake-progress__steps li.is-done::before {
  background: var(--color-success);
  color: #fff;
  content: "✓";
}

.intake-progress__steps li span {
  display: block;
}

@media (max-width: 720px) {
  .intake-progress__steps li span { display: none; }
}

/* Steps */
.intake-step {
  border: 0;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--sp-5);
}

.intake-step:not(.is-active) {
  display: none;
}

.intake-step__head {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-bottom: var(--sp-2);
}

.intake-step__head h2 {
  font-size: var(--fs-xl);
  font-family: var(--font-display);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-tight);
  margin: 0;
  line-height: var(--lh-snug);
}

.intake-step__head .text-soft {
  margin: 0;
  font-size: 0.9375rem;
  line-height: var(--lh-relaxed);
}

.intake-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--color-line-soft);
}

@media (max-width: 540px) {
  .intake-actions {
    flex-direction: column-reverse;
    align-items: stretch;
  }
  .intake-actions .btn { width: 100%; }
}

/* Radio grid (stijl, content-status) */
.intake-radio-grid {
  display: grid;
  gap: var(--sp-3);
  grid-template-columns: 1fr;
  margin-top: var(--sp-2);
}

@media (min-width: 720px) {
  .intake-radio-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.intake-radio-grid--3 {
  grid-template-columns: 1fr;
}

@media (min-width: 720px) {
  .intake-radio-grid--3 {
    grid-template-columns: repeat(3, 1fr);
  }
}

.intake-radio {
  display: block;
  position: relative;
  cursor: pointer;
}

.intake-radio input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.intake-radio__inner {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  padding: var(--sp-4);
  background: var(--color-surface);
  border: 1.5px solid var(--color-line);
  border-radius: var(--r-md);
  transition: border-color var(--dur-2) var(--ease-out),
              background var(--dur-2) var(--ease-out),
              box-shadow var(--dur-2) var(--ease-out);
}

.intake-radio:hover .intake-radio__inner {
  border-color: var(--color-slate-300);
  background: var(--color-cream-50);
}

.intake-radio input:checked + .intake-radio__inner {
  border-color: var(--color-slate-900);
  background: var(--color-slate-50);
  box-shadow: var(--sh-glow);
}

.intake-radio__title {
  font-family: var(--font-display);
  font-weight: var(--weight-semibold);
  font-size: 0.9375rem;
  color: var(--color-ink);
  letter-spacing: var(--tracking-tight);
}

.intake-radio__sub {
  font-size: 0.8125rem;
  color: var(--color-mute);
  line-height: var(--lh-snug);
}

/* File upload */
.intake-upload {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding: var(--sp-4);
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--r-md);
}

.intake-upload__head {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.intake-upload__head strong {
  font-family: var(--font-display);
  font-size: 0.9375rem;
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink);
}

.intake-upload__hint {
  font-size: 0.8125rem;
  color: var(--color-mute);
  line-height: var(--lh-snug);
}

.intake-upload__current {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-3);
  background: var(--color-cream-50);
  border-radius: var(--r-sm);
  font-size: 0.875rem;
}

.intake-upload__filename {
  color: var(--color-ink);
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.intake-upload__filename small {
  color: var(--color-mute);
  font-weight: var(--weight-regular);
  margin-left: var(--sp-2);
}

.intake-upload__remove {
  font-size: 0.8125rem;
  color: var(--color-danger);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.intake-upload__drop {
  display: block;
  cursor: pointer;
  position: relative;
}

.intake-upload__drop input[type="file"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.intake-upload__drop-inner {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  background: transparent;
  border: 1.5px dashed var(--color-slate-200);
  border-radius: var(--r-md);
  color: var(--color-ink-soft);
  font-size: 0.875rem;
  font-weight: var(--weight-medium);
  transition: border-color var(--dur-2) var(--ease-out),
              background var(--dur-2) var(--ease-out),
              color var(--dur-2) var(--ease-out);
  width: 100%;
  justify-content: center;
}

.intake-upload__drop:hover .intake-upload__drop-inner,
.intake-upload__drop:focus-within .intake-upload__drop-inner {
  border-color: var(--color-slate-900);
  background: var(--color-slate-50);
  color: var(--color-ink);
}

.intake-upload.is-uploaded .intake-upload__drop-inner {
  border-style: solid;
  border-color: var(--color-success);
  color: var(--color-success);
}

/* Summary on step 5 */
.intake-summary {
  display: grid;
  gap: var(--sp-3);
  background: var(--color-cream-50);
  border: 1px solid var(--color-line);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  font-size: 0.9375rem;
  line-height: var(--lh-relaxed);
}

.intake-summary__row {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: var(--sp-3);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--color-line-soft);
}

.intake-summary__row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.intake-summary__label {
  color: var(--color-mute);
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  font-weight: var(--weight-semibold);
}

.intake-summary__value {
  color: var(--color-ink);
}

@media (max-width: 720px) {
  .intake-summary__row {
    grid-template-columns: 1fr;
    gap: var(--sp-1);
  }
}

/* Order-summary boven de briefing — full-width kaart */
.intake-summary-bar {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--r-xl);
  padding: var(--sp-6) var(--sp-7);
  box-shadow: var(--sh-xs);
  display: grid;
  gap: var(--sp-4);
}

@media (max-width: 720px) {
  .intake-summary-bar {
    padding: var(--sp-5);
  }
}

.intake-summary-bar__head {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--color-line-soft);
}

.intake-summary-bar__sub {
  margin: 0;
  font-size: 0.875rem;
  color: var(--color-ink-soft);
  line-height: var(--lh-relaxed);
  max-width: 56rem;
}

.intake-summary-bar__items {
  display: grid;
  gap: var(--sp-3);
  margin: 0;
  padding: 0;
}

.intake-summary-bar__items li {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-3);
  align-items: baseline;
  padding-block: var(--sp-2);
  border-bottom: 1px dashed var(--color-line-soft);
}

.intake-summary-bar__items li:last-child {
  border-bottom: 0;
}

.intake-summary-bar__name {
  font-size: 0.9375rem;
  color: var(--color-ink);
  font-weight: var(--weight-medium);
  min-width: 0;
  overflow-wrap: anywhere;
}

.intake-summary-bar__price {
  font-family: var(--font-display);
  font-weight: var(--weight-semibold);
  color: var(--color-ink);
  font-feature-settings: "tnum";
  white-space: nowrap;
  font-size: 0.9375rem;
}

.intake-summary-bar__price small {
  display: block;
  font-weight: var(--weight-regular);
  color: var(--color-mute);
  font-size: 0.6875rem;
  letter-spacing: 0.02em;
  text-align: right;
}

.intake-summary-bar__totals {
  display: grid;
  gap: var(--sp-1);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--color-line-soft);
}

.intake-summary-bar__line {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--sp-3);
  font-size: 0.875rem;
  color: var(--color-ink-soft);
  font-feature-settings: "tnum";
}

.intake-summary-bar__line span:first-child {
  color: var(--color-mute);
}

.intake-summary-bar__line--total {
  margin-top: var(--sp-2);
  padding-top: var(--sp-2);
  border-top: 1px solid var(--color-line-soft);
  font-size: 1rem;
  color: var(--color-ink);
  font-family: var(--font-display);
}

.intake-summary-bar__line--total span:first-child {
  color: var(--color-ink);
  font-weight: var(--weight-semibold);
}

.intake-summary-bar__line--total strong {
  font-family: var(--font-display);
  font-weight: var(--weight-bold);
  font-size: 1.25rem;
  color: var(--color-ink);
}

.intake-cart__sub span,
.intake-cart__sub strong {
  font-feature-settings: "tnum";
}

.intake-cart__sub--strong {
  margin-top: var(--sp-2);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--color-line-soft);
  font-size: 0.9375rem;
  color: var(--color-ink);
}

.intake-cart__sub--strong strong {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: var(--weight-bold);
}

/* Empty state */
.intake-empty {
  text-align: center;
  padding: var(--sp-8) var(--sp-5);
}

.intake-empty h2 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  margin: 0 0 var(--sp-3);
}

/* Content-policy uitlegblok */
.intake__policy {
  margin-top: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: var(--color-cobalt-100);
  border: 1px solid rgba(42, 79, 184, .15);
  border-radius: var(--r-sm);
  font-size: 0.8125rem;
  color: var(--color-cobalt-700);
  line-height: 1.5;
}
.intake__policy strong { color: var(--color-cobalt-700); }

/* Pages-stepper */
.intake-pages__row {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
}

.intake-pages__btn {
  width: 36px;
  height: 36px;
  border-radius: var(--r-md);
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  color: var(--color-ink);
  font-size: 1.125rem;
  font-weight: var(--weight-bold);
  cursor: pointer;
  transition: background var(--dur-2) var(--ease-out), border-color var(--dur-2) var(--ease-out);
}
.intake-pages__btn:hover {
  background: var(--color-cream-50);
  border-color: var(--color-slate-300);
}

.intake-pages__row input[type="number"] {
  width: 60px;
  text-align: center;
  -moz-appearance: textfield;
}
.intake-pages__row input[type="number"]::-webkit-outer-spin-button,
.intake-pages__row input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.intake-pages__rate {
  font-size: 0.875rem;
  color: var(--color-mute);
  margin-left: var(--sp-2);
}

.intake-pages__total {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: var(--weight-bold);
  color: var(--color-ink);
  font-feature-settings: "tnum";
}

/* Mode picker (briefing fast-track) */
.intake-mode {
  background: var(--color-cream-50);
  border: 1px solid var(--color-line);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  margin-bottom: var(--sp-7);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.intake-mode__head {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.intake-mode__head strong {
  font-family: var(--font-display);
  font-weight: var(--weight-semibold);
  font-size: 0.9375rem;
  color: var(--color-ink);
  letter-spacing: var(--tracking-tight);
}

.intake-mode__head span {
  font-size: 0.8125rem;
  color: var(--color-mute);
  line-height: var(--lh-snug);
}

.intake-mode__opts {
  display: grid;
  gap: var(--sp-3);
  grid-template-columns: 1fr;
}

@media (min-width: 720px) {
  .intake-mode__opts {
    grid-template-columns: repeat(3, 1fr);
  }
}

.intake-mode__opt {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  padding: var(--sp-3) var(--sp-4);
  background: var(--color-surface);
  border: 1.5px solid var(--color-line);
  border-radius: var(--r-md);
  text-align: left;
  cursor: pointer;
  transition: border-color var(--dur-2) var(--ease-out),
              background var(--dur-2) var(--ease-out),
              box-shadow var(--dur-2) var(--ease-out);
  font-family: inherit;
  color: var(--color-ink);
}

.intake-mode__opt:hover {
  border-color: var(--color-slate-300);
  background: var(--color-cream-50);
}

.intake-mode__opt.is-active {
  border-color: var(--color-slate-900);
  background: var(--color-slate-50);
  box-shadow: var(--sh-glow);
}

.intake-mode__opt-title {
  font-family: var(--font-display);
  font-weight: var(--weight-semibold);
  font-size: 0.9375rem;
  letter-spacing: var(--tracking-tight);
}

.intake-mode__opt-sub {
  font-size: 0.75rem;
  color: var(--color-mute);
  line-height: var(--lh-snug);
}

.intake-mode__opt.is-active .intake-mode__opt-sub {
  color: var(--color-ink-soft);
}

/* Quick-track panel */
.intake-quick {
  border: 0;
  padding: 0;
  margin: 0;
}

.intake-quick:not([hidden]) {
  display: grid;
  gap: var(--sp-5);
}

[hidden] { display: none !important; }
