/* =========================================================================
   Mini-Tinder laboral · Andalu-SEO 2026
   Estética: atardecer mediterráneo · mobile first
   ========================================================================= */

:root {
  /* paleta */
  --night:        #1b1320;
  --night-2:      #261826;
  --bone:         #f4ead5;
  --bone-soft:    #ede2c9;
  --terracotta:   #d96941;
  --coral:        #ef8062;
  --mustard:      #f4b61c;
  --sea:          #2a6f7a;
  --sea-deep:     #173a44;
  --plum:         #6d1e4b;
  --like:         #59c47b;
  --nope:         #e94e4e;

  /* tipografía */
  --font-display: 'Fraunces', ui-serif, Georgia, serif;
  --font-body:    'Manrope', system-ui, -apple-system, sans-serif;

  /* spacing */
  --r-card: 28px;
  --r-input: 14px;
  --r-btn: 999px;

  /* sombras */
  --sh-soft: 0 10px 30px -10px rgba(0,0,0,.4);
  --sh-card: 0 25px 60px -15px rgba(0,0,0,.55), 0 10px 25px -10px rgba(0,0,0,.4);
}

* { box-sizing: border-box; }

html, body { height: 100%; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.5;
  color: var(--bone);
  background:
    radial-gradient(120% 80% at 80% 0%, #5a2236 0%, transparent 55%),
    radial-gradient(140% 90% at 0% 100%, #1f4a52 0%, transparent 55%),
    linear-gradient(180deg, var(--night) 0%, var(--night-2) 100%);
  background-attachment: fixed;
  min-height: 100dvh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
}

/* textura de grano */
.grain {
  position: fixed; inset: 0;
  pointer-events: none;
  opacity: .07;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  z-index: 1;
}

/* layout */
.wrap {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
  padding: 24px 20px 40px;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

/* ─── Topbar ─────────────────────────────────────────────────── */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 28px;
}
.brand {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 20px;
  letter-spacing: -.02em;
  color: var(--bone);
  text-decoration: none;
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
}
.brand em {
  font-style: italic;
  color: var(--mustard);
  font-weight: 400;
}
.topbar .back {
  color: var(--bone-soft);
  text-decoration: none;
  font-size: 14px;
  opacity: .75;
  padding: 6px 10px;
  border-radius: 8px;
}
.topbar .back:hover { opacity: 1; }

/* ─── Landing ────────────────────────────────────────────────── */
.hero {
  text-align: center;
  padding: 8vh 0 4vh;
}
.hero .badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(244,182,28,.12);
  border: 1px solid rgba(244,182,28,.35);
  color: var(--mustard);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 600;
}
.hero h1 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(42px, 12vw, 64px);
  line-height: .95;
  letter-spacing: -.04em;
  margin: 22px 0 14px;
}
.hero h1 i {
  font-style: italic;
  font-weight: 400;
  color: var(--coral);
  display: block;
}
.hero p {
  color: var(--bone-soft);
  opacity: .8;
  font-size: 16px;
  max-width: 32ch;
  margin: 0 auto;
}

.choice {
  margin-top: 6vh;
  display: grid;
  gap: 14px;
}
.choice button {
  appearance: none;
  border: none;
  cursor: pointer;
  font: inherit;
  color: var(--night);
  background: var(--bone);
  border-radius: var(--r-card);
  padding: 22px 22px;
  text-align: left;
  display: flex;
  gap: 16px;
  align-items: center;
  box-shadow: var(--sh-soft);
  transition: transform .25s ease, box-shadow .25s ease;
  position: relative;
  overflow: hidden;
}
.choice button::after {
  content: "→";
  margin-left: auto;
  font-size: 28px;
  font-family: var(--font-display);
  color: var(--terracotta);
  transition: transform .25s ease;
}
.choice button:hover { transform: translateY(-2px); box-shadow: var(--sh-card); }
.choice button:hover::after { transform: translateX(4px); }
.choice button.alt {
  background: linear-gradient(135deg, var(--terracotta), var(--plum));
  color: var(--bone);
}
.choice button.alt::after { color: var(--mustard); }
.choice .icon {
  flex: 0 0 56px; height: 56px;
  border-radius: 18px;
  display: grid; place-items: center;
  background: rgba(27,19,32,.08);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 26px;
}
.choice button.alt .icon { background: rgba(255,255,255,.15); }
.choice .title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -.02em;
  line-height: 1.1;
}
.choice .desc {
  font-size: 13px;
  opacity: .7;
  margin-top: 2px;
}

.foot {
  margin-top: auto;
  padding-top: 32px;
  text-align: center;
  color: var(--bone-soft);
  font-size: 12px;
  opacity: .5;
}
.foot a { color: var(--mustard); text-decoration: none; }

/* ─── Formularios ────────────────────────────────────────────── */
.form-head {
  margin-bottom: 24px;
}
.form-head h2 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 34px;
  letter-spacing: -.03em;
  line-height: 1;
  margin: 0 0 8px;
}
.form-head h2 i {
  font-style: italic; font-weight: 400; color: var(--coral);
}
.form-head p { margin: 0; color: var(--bone-soft); opacity: .7; font-size: 14px; }

form.card-form {
  display: grid;
  gap: 18px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  backdrop-filter: blur(8px);
  border-radius: var(--r-card);
  padding: 22px 18px;
}

.field { display: grid; gap: 8px; }
.field label {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .02em;
  color: var(--bone);
}
.field label .opt {
  font-weight: 400;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: var(--mustard);
  margin-left: 8px;
}
.field .hint {
  font-size: 12px;
  color: var(--bone-soft);
  opacity: .55;
}
.field input[type=text],
.field input[type=email],
.field input[type=url],
.field input[type=number],
.field textarea,
.field select {
  font: inherit;
  color: var(--bone);
  background: rgba(0,0,0,.25);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-input);
  padding: 13px 14px;
  width: 100%;
  transition: border-color .2s, background .2s;
}
.field textarea { resize: vertical; min-height: 80px; }
.field input:focus,
.field textarea:focus,
.field select:focus {
  outline: none;
  border-color: var(--mustard);
  background: rgba(0,0,0,.35);
}
.field input::placeholder,
.field textarea::placeholder { color: rgba(244,234,213,.35); }

/* file input */
.field input[type=file] { display: none; }
.field .filebox {
  border: 1.5px dashed rgba(255,255,255,.2);
  border-radius: var(--r-input);
  padding: 18px;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  font-size: 14px;
  color: var(--bone-soft);
}
.field .filebox:hover { border-color: var(--mustard); }
.field .filebox.has-file {
  border-style: solid;
  border-color: var(--like);
  color: var(--bone);
  background: rgba(89,196,123,.08);
}
.field .filebox .fname { font-weight: 600; display: block; margin-top: 4px; word-break: break-all; }

/* salario doble input */
.salary {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 8px;
  align-items: center;
}
.salary input { text-align: center; }
.salary .sep { text-align: center; opacity: .5; font-weight: 600; }
.salary .unit {
  background: rgba(0,0,0,.25);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-input);
  padding: 13px 12px;
  font-size: 13px;
}

/* modo de salario candidato */
.salary-mode {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  background: rgba(0,0,0,.25);
  padding: 4px;
  border-radius: var(--r-btn);
  margin-bottom: 8px;
}
.salary-mode input { display: none; }
.salary-mode label {
  text-align: center;
  padding: 9px;
  border-radius: var(--r-btn);
  cursor: pointer;
  font-size: 13px;
  color: var(--bone-soft);
  transition: background .2s, color .2s;
}
.salary-mode input:checked + label {
  background: var(--mustard);
  color: var(--night);
  font-weight: 700;
}

/* radio remoto/presencial */
.radio-group {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.radio-group input { display: none; }
.radio-group label {
  cursor: pointer;
  text-align: center;
  padding: 14px;
  border-radius: var(--r-input);
  background: rgba(0,0,0,.25);
  border: 1.5px solid rgba(255,255,255,.08);
  font-size: 14px;
  font-weight: 600;
  transition: all .2s;
}
.radio-group input:checked + label {
  border-color: var(--mustard);
  background: rgba(244,182,28,.1);
  color: var(--mustard);
}

/* checkboxes regiones */
.regions {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
}
.regions input { display: none; }
.regions label {
  cursor: pointer;
  padding: 10px 10px;
  border-radius: 10px;
  background: rgba(0,0,0,.25);
  border: 1.5px solid rgba(255,255,255,.08);
  font-size: 13px;
  text-align: center;
  transition: all .15s;
}
.regions input:checked + label {
  border-color: var(--coral);
  background: rgba(239,128,98,.12);
  color: var(--coral);
  font-weight: 600;
}

/* ciudad concreta para empresa */
.city-field { display: none; }
.city-field.visible { display: grid; }

/* botón principal */
.btn-primary {
  appearance: none;
  border: none;
  cursor: pointer;
  font: inherit;
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -.01em;
  background: linear-gradient(135deg, var(--coral), var(--terracotta));
  color: var(--bone);
  padding: 16px 22px;
  border-radius: var(--r-btn);
  width: 100%;
  margin-top: 6px;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 10px 30px -10px rgba(217,105,65,.6);
}
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 14px 36px -10px rgba(217,105,65,.7); }
.btn-primary:active { transform: translateY(0); }
.btn-primary[disabled] { opacity: .6; cursor: wait; }

.err {
  background: rgba(233,78,78,.12);
  border: 1px solid rgba(233,78,78,.4);
  color: #ffcfcf;
  padding: 12px 14px;
  border-radius: var(--r-input);
  font-size: 14px;
}

/* ─── Swipe cards ────────────────────────────────────────────── */
.swipe-head {
  text-align: center;
  margin-bottom: 16px;
}
.swipe-head h2 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  margin: 0;
  letter-spacing: -.02em;
}
.swipe-head p { margin: 4px 0 0; font-size: 13px; color: var(--bone-soft); opacity: .65; }

.deck {
  position: relative;
  flex: 1;
  display: grid;
  place-items: center;
  min-height: 460px;
  margin-bottom: 20px;
}

.card {
  position: absolute;
  inset: 0;
  background: var(--bone);
  color: var(--night);
  border-radius: var(--r-card);
  box-shadow: var(--sh-card);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transform-origin: center bottom;
  will-change: transform;
  cursor: grab;
  user-select: none;
  -webkit-user-drag: none;
}
.card.dragging { cursor: grabbing; transition: none !important; }
.card:not(.dragging) { transition: transform .35s cubic-bezier(.2,.7,.3,1.4); }

.card-media {
  position: relative;
  height: 220px;
  background:
    linear-gradient(135deg, var(--terracotta), var(--plum));
  display: block;
  place-items: center;
  color: var(--bone);
  overflow: hidden;
}
.card-media img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
}
.card-media .placeholder {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 72px;
  letter-spacing: -.05em;
  text-transform: uppercase;
  opacity: .9;
}
.card-tag {
  position: absolute;
  top: 14px; left: 14px;
  background: rgba(27,19,32,.6);
  color: var(--bone);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  padding: 5px 10px;
  border-radius: 999px;
  backdrop-filter: blur(8px);
}

.card-body {
  padding: 22px 20px 18px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
  overflow-y: auto;
}
.card-body h3 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 26px;
  letter-spacing: -.02em;
  line-height: 1.05;
  margin: 0;
}
.card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  font-size: 13px;
  color: var(--sea-deep);
  opacity: .85;
}
.card-meta .chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(42,111,122,.1);
  padding: 4px 9px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 12px;
  color: var(--sea-deep);
}
.card-meta .chip.salary {
  background: rgba(244,182,28,.18);
  color: #7a5a00;
}
.card-desc {
  font-size: 14px;
  line-height: 1.5;
  color: #4a3a45;
  white-space: pre-wrap;
}
.card-cv {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--sea-deep);
  color: var(--bone);
  text-decoration: none;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
  align-self: flex-start;
  margin-top: 4px;
}
.card-cv:hover { background: var(--night); }

/* swipe decisión overlay */
.decision {
  position: absolute;
  top: 24px;
  padding: 8px 16px;
  border-radius: 8px;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 28px;
  letter-spacing: .08em;
  opacity: 0;
  transition: opacity .12s;
  border: 3px solid currentColor;
  text-transform: uppercase;
  pointer-events: none;
}
.decision.like   { right: 20px; color: var(--like); transform: rotate(8deg); }
.decision.nope   { left: 20px;  color: var(--nope); transform: rotate(-8deg); }

/* botones de acción */
.actions {
  display: flex;
  justify-content: center;
  gap: 22px;
  padding: 4px 0 12px;
}
.actions button {
  appearance: none;
  border: none;
  cursor: pointer;
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--bone);
  font-size: 28px;
  display: grid;
  place-items: center;
  box-shadow: var(--sh-soft);
  transition: transform .2s;
  font-family: inherit;
  font-weight: 800;
}
.actions button:hover { transform: scale(1.06); }
.actions button.nope { color: var(--nope); }
.actions button.like { color: var(--like); }

/* estados vacíos / final */
.empty {
  text-align: center;
  padding: 40px 20px;
  color: var(--bone-soft);
}
.empty h3 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 30px;
  margin: 0 0 10px;
  letter-spacing: -.02em;
}
.empty p { opacity: .7; }
.empty .btn-primary { max-width: 280px; margin: 20px auto 0; }

/* match toast */
.match {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: radial-gradient(60% 60% at 50% 40%, rgba(217,105,65,.4), rgba(27,19,32,.92));
  backdrop-filter: blur(6px);
  display: grid;
  place-items: center;
  padding: 24px;
  animation: fadeIn .25s ease;
}
@keyframes fadeIn { from { opacity: 0 } to { opacity: 1 } }
.match-inner {
  background: var(--bone);
  color: var(--night);
  border-radius: var(--r-card);
  padding: 32px 26px;
  max-width: 340px;
  width: 100%;
  text-align: center;
  box-shadow: var(--sh-card);
  animation: pop .35s cubic-bezier(.2,.7,.3,1.4);
}
@keyframes pop { from { transform: scale(.85); opacity: 0 } to { transform: scale(1); opacity: 1 } }
.match-inner h3 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 38px;
  letter-spacing: -.03em;
  margin: 0;
}
.match-inner h3 i { font-style: italic; color: var(--coral); }
.match-inner p { margin: 8px 0 22px; font-size: 14px; opacity: .7; }
.match-inner .contact {
  background: var(--mustard);
  color: var(--night);
  padding: 12px 16px;
  border-radius: var(--r-input);
  font-weight: 700;
  font-size: 15px;
  display: block;
  text-decoration: none;
  margin-bottom: 10px;
  word-break: break-all;
}
.match-inner .close {
  display: inline-block;
  margin-top: 4px;
  padding: 10px 18px;
  background: transparent;
  border: 1.5px solid rgba(27,19,32,.2);
  border-radius: var(--r-btn);
  color: var(--night);
  cursor: pointer;
  font: inherit;
  font-weight: 600;
}

/* ─── Página de éxito tras publicar ─────────────────────────── */
.success {
  text-align: center;
  padding: 12vh 0 4vh;
}
.success .check {
  width: 86px; height: 86px;
  margin: 0 auto 18px;
  border-radius: 50%;
  background: var(--like);
  display: grid;
  place-items: center;
  font-size: 44px;
  color: var(--night);
  font-weight: 800;
  box-shadow: 0 10px 30px -10px rgba(89,196,123,.6);
}
.success h2 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 34px;
  letter-spacing: -.03em;
  margin: 0 0 6px;
}
.success p { color: var(--bone-soft); opacity: .75; margin: 0 auto 28px; max-width: 32ch; }

/* desktop ligero */
@media (min-width: 720px) {
  .wrap { padding-top: 40px; }
}

/* =========================================================================
   PATCH · añadir estos bloques al final de assets/style.css
   (o sustituir el archivo entero, no rompe nada de lo anterior)
   ========================================================================= */

/* ─── Curiosear: dos opciones lado a lado ────────────────────────────── */
.curiosear {
  margin-top: 14px;
  padding: 14px 8px 4px;
  text-align: center;
}
.curiosear-label {
  font-size: 11px;
  color: var(--bone-soft);
  opacity: .55;
  letter-spacing: .16em;
  text-transform: uppercase;
  margin: 0 0 10px;
  font-weight: 700;
}
.curiosear-opts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.curiosear-opts a {
  text-decoration: none;
  color: var(--bone-soft);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-input);
  padding: 14px 10px;
  font-size: 14px;
  font-weight: 600;
  transition: background .2s, border-color .2s, color .2s, transform .2s;
}
.curiosear-opts a:hover {
  background: rgba(244,182,28,.08);
  border-color: var(--mustard);
  color: var(--mustard);
  transform: translateY(-1px);
}
.curiosear-opts a:active {
  transform: translateY(0);
}

/* ─── Badge de "ya publicado" en la home ─────────────────────────────── */
.already-published {
  text-align: center;
  margin-bottom: 6px;
}
.badge-ok {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(89,196,123,.12);
  border: 1px solid rgba(89,196,123,.4);
  color: var(--like);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 700;
}
/* =========================================================================
   PATCH 2 · añadir al final de assets/style.css (después del PATCH anterior)
   Diferencia visualmente el correo (botón principal) de web/CV (secundarios)
   ========================================================================= */

.match-inner .contact.contact-alt {
  background: transparent;
  border: 1.5px solid rgba(27,19,32,.2);
  color: var(--night);
  font-weight: 600;
}
.match-inner .contact.contact-alt:hover {
  background: rgba(27,19,32,.04);
}