/* Client website intake wizard — mobile-first */
:root {
  --int-bg: #0b0c10;
  --int-panel: #1f2833;
  --int-lime: #b9dd39;
  --int-accent: #b44a3e;
  --int-text: #e8eaed;
  --int-muted: #9aa0a6;
  --int-border: #374151;
  --int-radius: 12px;
}

* {
  box-sizing: border-box;
}

html {
  overflow-x: hidden;
  max-width: 100%;
}

.intake-req {
  color: #b9dd39;
  font-weight: 600;
}

.intake-honeypot {
  position: absolute !important;
  left: -10000px !important;
  top: auto !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

.intake-body {
  margin: 0;
  min-height: 100vh;
  font-family: "Poppins", system-ui, sans-serif;
  background: var(--int-bg);
  color: var(--int-text);
  line-height: 1.55;
}

.intake-wrap {
  max-width: 640px;
  margin: 0 auto;
  padding: 1.25rem 1rem 3rem;
}

.intake-brand {
  text-align: center;
  margin-bottom: 1rem;
}
.intake-brand a {
  color: var(--int-lime);
  font-weight: 700;
  text-decoration: none;
  letter-spacing: 0.04em;
}

.intake-progress {
  height: 6px;
  background: var(--int-border);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 1.5rem;
}
.intake-progress__bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--int-accent), var(--int-lime));
  border-radius: 999px;
  transition: width 0.35s ease;
}

.intake-card {
  background: var(--int-panel);
  border: 1px solid var(--int-border);
  border-radius: var(--int-radius);
  padding: 1.35rem 1.15rem;
  margin-bottom: 1rem;
}

.intake-card h1 {
  font-size: 1.35rem;
  margin: 0 0 0.5rem;
  color: var(--int-lime);
}

.intake-card h2 {
  font-size: 1.05rem;
  margin: 0 0 1rem;
  color: var(--int-text);
}

.intake-muted {
  color: var(--int-muted);
  font-size: 0.9rem;
  margin: 0 0 1rem;
}

.intake-field {
  margin-bottom: 1rem;
}
.intake-field label {
  display: block;
  font-weight: 600;
  font-size: 0.88rem;
  margin-bottom: 0.35rem;
  color: var(--int-text);
}

.intake-field input[type="text"],
.intake-field input[type="email"],
.intake-field input[type="tel"],
.intake-field input[type="url"],
.intake-field input[type="number"],
.intake-field textarea,
.intake-field select {
  width: 100%;
  padding: 0.65rem 0.75rem;
  border-radius: 8px;
  border: 1px solid var(--int-border);
  background: #0f1419;
  color: var(--int-text);
  font-size: 1rem;
}

.intake-field textarea {
  min-height: 88px;
  resize: vertical;
}

.intake-radio-row,
.intake-check-row {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin-bottom: 0.55rem;
}
.intake-radio-row input,
.intake-check-row input {
  margin-top: 0.25rem;
}

.intake-conditional {
  display: none;
  padding: 0.75rem 0 0;
  border-top: 1px dashed var(--int-border);
  margin-top: 0.75rem;
}
.intake-conditional.is-visible {
  display: block;
}

.intake-service-row {
  display: grid;
  grid-template-columns: 1fr minmax(5.5rem, 100px);
  gap: 0.5rem;
  margin-bottom: 0.5rem;
  align-items: stretch;
}

.intake-service-row input[type="text"],
.intake-service-row input[type="number"] {
  width: 100%;
  min-width: 0;
  padding: 0.65rem 0.75rem;
  border-radius: 8px;
  border: 1px solid var(--int-border);
  background: #0f1419;
  color: var(--int-text);
  font-size: 1rem;
  font-family: inherit;
}

@media (max-width: 480px) {
  .intake-service-row {
    grid-template-columns: 1fr;
  }
}

.intake-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1.25rem;
}

.intake-btn {
  border: none;
  border-radius: 999px;
  padding: 0.65rem 1.25rem;
  font-weight: 700;
  font-size: 0.95rem;
  cursor: pointer;
  font-family: inherit;
}
.intake-btn--primary {
  background: var(--int-lime);
  color: #0b0c10;
}
.intake-btn--ghost {
  background: transparent;
  color: var(--int-text);
  border: 1px solid var(--int-border);
}

.intake-save-hint {
  font-size: 0.8rem;
  color: var(--int-muted);
  margin-top: 0.75rem;
  min-height: 1.25rem;
}
.intake-save-hint.is-saving {
  color: var(--int-lime);
}
.intake-save-hint.is-error {
  color: #f87171;
}

.intake-error-banner {
  background: rgba(180, 74, 62, 0.2);
  border: 1px solid var(--int-accent);
  color: #fecaca;
  padding: 0.85rem 1rem;
  border-radius: var(--int-radius);
  margin-bottom: 1rem;
}

.intake-done {
  text-align: center;
  padding: 2rem 1rem;
}
.intake-done h1 {
  color: var(--int-lime);
}

/* Restaurant extended (conditional on business_type) */
.intake-rx-h3 {
  color: var(--int-lime);
  font-size: 1rem;
  margin: 1.25rem 0 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px dashed var(--int-border);
}
.intake-rx-h3:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
.intake-rx-h4 {
  color: var(--int-text);
  font-size: 0.92rem;
  margin: 0.75rem 0 0.5rem;
}
.intake-rx-subsection {
  margin-top: 0.75rem;
}
.intake-rx-checkbox-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.15rem 0.75rem;
}
@media (max-width: 520px) {
  .intake-rx-checkbox-grid {
    grid-template-columns: 1fr;
  }
}
.intake-rx-group-title {
  font-weight: 600;
  margin: 0.85rem 0 0.35rem;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
}
.intake-rx-yesno-grid {
  display: grid;
  gap: 0.65rem;
}
.intake-rx-yesno .intake-radio-row {
  display: inline-flex;
  margin-right: 1rem;
}
.intake-rx-menu-cat {
  border: 1px solid var(--int-border);
  border-radius: 8px;
  padding: 0.75rem;
  margin-bottom: 0.75rem;
  background: rgba(15, 20, 25, 0.5);
}
.intake-rx-menu-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.4rem 0.6rem;
  padding: 0.5rem 0;
  border-bottom: 1px dashed var(--int-border);
  margin-bottom: 0.35rem;
}
.intake-rx-menu-item:last-of-type {
  border-bottom: none;
}
@media (max-width: 520px) {
  .intake-rx-menu-item {
    grid-template-columns: 1fr;
  }
}
.intake-rx-menu-item .intake-check-row {
  grid-column: 1 / -1;
  margin-bottom: 0.25rem;
}
.intake-rx-file-hint {
  font-size: 0.8rem;
  margin-top: 0.35rem;
}

/* Alquiler vacacional — layout */
.intake-rv-main-title {
  color: var(--int-lime);
  font-size: 1.2rem;
  margin: 0 0 0.35rem;
}
.intake-rv-h3 {
  color: var(--int-text);
  font-size: 1rem;
  margin: 1.25rem 0 0.65rem;
  padding-top: 0.75rem;
  border-top: 1px dashed var(--int-border);
}
.intake-rv-root .intake-rv-h3:first-of-type {
  border-top: none;
  padding-top: 0;
  margin-top: 0.5rem;
}
.intake-rv-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem 0.75rem;
}
@media (max-width: 520px) {
  .intake-rv-grid-2 {
    grid-template-columns: 1fr;
  }
}
.intake-rv-repeat-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
@media (max-width: 520px) {
  .intake-rv-repeat-row {
    grid-template-columns: 1fr;
  }
}
.intake-rv-repeat-row input[type="text"],
.intake-rv-repeat-row input[type="url"] {
  width: 100%;
  min-width: 0;
  padding: 0.65rem 0.75rem;
  border-radius: 8px;
  border: 1px solid var(--int-border);
  background: #0f1419;
  color: var(--int-text);
  font-size: 1rem;
  font-family: inherit;
}
.intake-amenity-group {
  background: rgba(15, 20, 25, 0.6);
  border: 1px solid var(--int-border);
  border-radius: 8px;
  margin-bottom: 0.5rem;
}
.intake-amenity-summary {
  cursor: pointer;
  font-weight: 600;
  padding: 0.65rem 0.75rem;
  list-style: none;
  color: var(--int-lime);
}
.intake-amenity-summary::-webkit-details-marker {
  display: none;
}
.intake-amenity-group[open] .intake-amenity-summary {
  border-bottom: 1px solid var(--int-border);
}
.intake-amenity-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.25rem 0.75rem;
  padding: 0.65rem 0.75rem 0.85rem;
}
@media (max-width: 560px) {
  .intake-amenity-grid {
    grid-template-columns: 1fr;
  }
}
.intake-amenity-item label {
  font-weight: 400;
  font-size: 0.88rem;
}

/* Taller técnico — bloque ampliado (technical_workshop) */
.intake-tw-extended {
  margin-top: 0.5rem;
}
.intake-tw-subh4 {
  color: var(--int-lime);
  font-size: 0.95rem;
  margin: 1.1rem 0 0.5rem;
  font-weight: 600;
}
.intake-check-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.25rem 0.75rem;
  margin-bottom: 0.35rem;
}
@media (max-width: 560px) {
  .intake-check-grid {
    grid-template-columns: 1fr;
  }
}
.intake-tw-callout {
  background: rgba(185, 221, 57, 0.08);
  border: 1px solid rgba(185, 221, 57, 0.25);
  border-radius: 8px;
  padding: 0.65rem 0.85rem;
  margin: 0.5rem 0 0.75rem;
}
.js-tw-svc-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
  margin-bottom: 0.65rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px dashed var(--int-border);
}
@media (max-width: 640px) {
  .js-tw-svc-row {
    grid-template-columns: 1fr;
  }
}
.js-tw-svc-row .intake-check-row {
  grid-column: 1 / -1;
}
.js-tw-team-row,
.js-tw-test-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
  margin-bottom: 0.65rem;
  padding: 0.65rem;
  border: 1px solid var(--int-border);
  border-radius: 8px;
  background: rgba(15, 20, 25, 0.5);
}
@media (max-width: 560px) {
  .js-tw-team-row,
  .js-tw-test-row {
    grid-template-columns: 1fr;
  }
}
.js-tw-team-row input[type="text"],
.js-tw-team-row textarea,
.js-tw-test-row input[type="text"],
.js-tw-test-row textarea,
.js-tw-svc-row input[type="text"],
.js-tw-svc-row select,
.js-tw-svc-row textarea {
  width: 100%;
  min-width: 0;
  padding: 0.55rem 0.65rem;
  border-radius: 8px;
  border: 1px solid var(--int-border);
  background: #0f1419;
  color: var(--int-text);
  font-size: 0.95rem;
  font-family: inherit;
}

.intake-step-counter {
  text-align: center;
  margin: 1rem 0 0;
  padding: 0.65rem 0.75rem;
  font-size: 0.9rem;
  color: var(--int-muted, #9aa4b2);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}
