/* ====================== QTC – Formulario 3 pasos (CSS completo) ====================== */
/* Paleta corporativa */
:root{
  --qtc-purple:#7A478E;
  --qtc-orange:#DE7328;
  --qtc-yellow:#FFC940;
  --qtc-black:#1E2024;
  --qtc-gray:#6E7074;      /* borde de steps */
  --qtc-gray-plate:#B4B6BA;
}

/* ===== Base (tema claro) ===== */
.cdq{
  --brand:var(--qtc-orange);
  --accent:var(--qtc-yellow);
  --text:#1E2024;
  --muted:#6B7280;
  --bg:#ffffff;
  --card:#ffffff;
  --card-br:#E5E7EB;
  --ring:rgba(255,201,64,.26);

  --r-1:8px; --r-2:12px; --r-3:16px; --r-4:20px; --r-5:24px; --r-6:32px; --r-7:40px;

  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", sans-serif;
  color:var(--text);
  line-height:1.55;
  background: var(--bg);
}
.cdq *{ box-sizing:border-box; }
.cdq a{ color:var(--qtc-orange); text-decoration:none; }
.cdq a:hover{ text-decoration:underline; }
.cdq input,.cdq select,.cdq textarea,.cdq button{ font:inherit; color:inherit; }

/* ===== Hero (centrado + subtítulo) ===== */
.cdq-hero{
  position:relative; text-align:center; color:#fff;
  padding: calc(var(--r-7) + 16px) var(--r-3) var(--r-6);
  background:
    radial-gradient(1200px 420px at 50% -15%, rgba(255,255,255,.15), transparent 60%),
    linear-gradient(90deg, var(--qtc-purple) 0%, var(--qtc-orange) 50%, var(--qtc-yellow) 100%);
  overflow:hidden;
}
.cdq-hero h1{
  margin:0 auto 10px; display:inline-block; color:#fff !important;
  font-weight:900; font-size:44px; letter-spacing:.5px;
  background:linear-gradient(to right, rgba(255,255,255,.14), rgba(255,255,255,.08));
  border:1px solid rgba(255,255,255,.20); border-radius:18px;
  padding:14px 24px; box-shadow:0 10px 26px rgba(0,0,0,.18), inset 0 0 0 6px rgba(255,255,255,.06);
  backdrop-filter:blur(8px);
}
.cdq-sub{
  display:block; margin:6px auto 0; padding:8px 14px; font-weight:700;
  color:#fff; background:rgba(0,0,0,.18); border:1px solid rgba(255,255,255,.16);
  border-radius:999px; backdrop-filter:blur(6px);
}

/* ===== Layout general (steps arriba, panel debajo) ===== */
.cdq-wrap{
  max-width:1160px;
  /* MÁS ESPACIO entre hero y steps (pedido) */
  margin: 20px auto var(--r-6);
  padding:0 var(--r-3);
  display:grid; grid-template-areas:"steps" "panel"; gap:var(--r-3);
}

/* ===== Stepper (desktop/tablet: 1 fila con progreso animado) ===== */
.cdq-steps{
  grid-area:steps;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  background:linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.02));
  border:1px solid var(--qtc-gray);
  border-radius:18px;
  padding:16px 20px 26px;
  box-shadow:0 14px 30px rgba(16,24,40,.06);
  position:relative;

  /* progreso (ancho controlado por :has() más abajo) */
  --prog: 0%;
}
.cdq-steps::before{
  /* pista gris */
  content:""; position:absolute; left:56px; right:56px; top:66px;
  height:6px; border-radius:999px;
  background:linear-gradient(90deg, rgba(0,0,0,.08), rgba(0,0,0,.04));
  z-index:0;
}
.cdq-steps::after{
  /* progreso naranja→amarillo */
  content:""; position:absolute; left:56px; top:66px;
  width: var(--prog); height:6px; border-radius:999px;
  background:linear-gradient(90deg, var(--qtc-orange), var(--qtc-yellow));
  box-shadow: 0 0 0 1px rgba(0,0,0,.02) inset;
  z-index:1;
  transition: width .35s ease-out;
}

.cdq-step{
  flex:1 1 0; min-width:0;
  display:flex; align-items:center; justify-content:center;
  gap:10px; padding:12px 0; margin:0; white-space:nowrap; color:rgba(30,32,36,.9);
  position:relative;
}
.cdq-step span{
  width:38px; height:38px; border-radius:50%; display:grid; place-items:center;
  font-weight:900; font-size:13px; color:#fff;
  background:linear-gradient(135deg, var(--qtc-orange), var(--qtc-yellow));
  border:2px solid rgba(255,255,255,.6);
  box-shadow:0 6px 18px rgba(0,0,0,.12);
  z-index:2; /* encima */
}
.cdq-step small{
  font-size:12px; font-weight:900; text-transform:uppercase; letter-spacing:.3px;
  padding:4px 8px; border-radius:8px;
  background:#ffffff; color:#1E2024; box-shadow:0 2px 6px rgba(0,0,0,.06);
  z-index:2; /* encima */
}

/* ----- Progreso (sin tocar JS) usando :has() ----- */
.cdq-steps:has(.cdq-step:nth-child(1).is-active){ --prog: 16.667%; }
.cdq-steps:has(.cdq-step:nth-child(2).is-active){ --prog: 50%; }
.cdq-steps:has(.cdq-step:nth-child(2).is-done){ --prog: 66.667%; }
.cdq-steps:has(.cdq-step:nth-child(3).is-active){ --prog: 83.333%; }
.cdq-steps:has(.cdq-step:nth-child(3).is-done){ --prog: 100%; }

/* ===== Panel contenedor ===== */
.cdq-panels{ grid-area:panel; }
.cdq-panel{
  background:var(--card);
  border:1px solid var(--card-br); border-radius:22px;
  padding:28px; box-shadow:0 18px 44px rgba(16,24,40,.06);
}
.cdq-panel.is-hidden{ display:none; }
.cdq-panel h2{
  margin:0 0 10px; font-size:26px; font-weight:900; color:#1E2024;
}
.cdq-panel h2::after{
  content:""; display:block; width:92px; height:4px; border-radius:999px;
  margin:12px 0 18px; background:linear-gradient(90deg, var(--qtc-purple), var(--qtc-orange), var(--qtc-yellow));
}

/* ===== Caja informativa ===== */
.cdq-box{
  background:#F8FAFC;
  border:1px solid #E5E7EB;
  border-radius:16px; padding:16px; margin:14px 0 22px; color:#1E2024;
}
.cdq-box strong{ color:var(--qtc-orange); display:block; margin-bottom:6px; }

/* ===== Grid de campos ===== */
.cdq-grid{
  display:grid; grid-template-columns: repeat(2, minmax(0,1fr));
  gap:20px; margin-top:6px;
}
.cdq-full{ grid-column:1/-1; }

/* ===== Campos ===== */
.cdq-field{ display:flex; flex-direction:column; gap:8px; }
.cdq-field label{
  font-weight:800; color:#1E2024; display:flex; align-items:center; gap:8px;
}
.cdq-help{ font-size:12px; color:var(--muted); }

.cdq-field input[type="text"],
.cdq-field input[type="date"],
.cdq-field input[type="email"],
.cdq-field select,
.cdq-field textarea{
  width:100%; border:1px solid #D1D5DB; border-radius:14px;
  padding:12px 14px; background:#ffffff; color:#1E2024;
  transition:border .15s, box-shadow .15s, background .15s;
  accent-color:var(--accent);
}
.cdq-field textarea{ min-height:130px; resize:vertical; }
.cdq-field input::placeholder, .cdq-field textarea::placeholder{ color:#9CA3AF; }
.cdq-field input:focus, .cdq-field select:focus, .cdq-field textarea:focus{
  outline:0; border-color:var(--qtc-yellow); box-shadow:0 0 0 6px var(--ring); background:#ffffff;
}

/* Select caret */
.cdq-field select{
  appearance:none;
  background-image:
    linear-gradient(45deg, transparent 50%, #6B7280 50%),
    linear-gradient(135deg, #6B7280 50%, transparent 50%),
    linear-gradient(to right, transparent 0, transparent 100%);
  background-position:
    calc(100% - 22px) calc(50% - 2px),
    calc(100% - 16px) calc(50% - 2px),
    100% 0;
  background-size:6px 6px, 6px 6px, 2.5em 2.5em;
  background-repeat:no-repeat;
}

/* Radios/checkbox alineados */
.cdq-checks{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.cdq-checks input{ accent-color:var(--accent); }

/* Línea de TyC */
.cdq-checkline{
  display:block; font-weight:700; border:1px dashed #E5E7EB;
  background:#F8FAFC; border-radius:12px; padding:12px 14px; margin-top:6px;
}
.cdq-checkline a{ color:var(--qtc-orange); font-weight:800; }

/* Archivo */
.cdq-field input[type="file"]{
  padding:10px 12px; border-radius:12px; background:#ffffff; border:1px solid #D1D5DB;
}
.cdq-field input[type="file"]::-webkit-file-upload-button,
.cdq-field input[type="file"]::file-selector-button{
  border:0; color:#111; padding:8px 12px; margin-right:10px;
  border-radius:10px; font-weight:900; cursor:pointer;
  background:linear-gradient(135deg, var(--qtc-orange), var(--qtc-yellow));
  transition:filter .15s, transform .05s;
}
.cdq-field input[type="file"]::file-selector-button:hover{ filter:brightness(1.06); }
.cdq-field input[type="file"]::file-selector-button:active{ transform:translateY(1px); }

/* ===== Acciones (botones) ===== */
.cdq-actions{
  display:flex; align-items:center; justify-content:space-between; gap:16px; margin-top:24px; flex-wrap:wrap;
}
.cdq-btn{
  border:0; border-radius:14px; padding:12px 18px; cursor:pointer;
  background:#F3F4F6; color:#111827; font-weight:900;
  transition:transform .05s, filter .15s, box-shadow .15s, background .15s;
}
.cdq-btn:hover{ filter:brightness(1.04); }
.cdq-btn:active{ transform:translateY(1px); }
.cdq-btn[disabled]{ opacity:.6; cursor:not-allowed; }
.cdq-btn.cdq-primary{
  background:linear-gradient(135deg, var(--qtc-orange), var(--qtc-yellow)); color:#111;
  box-shadow:0 12px 26px rgba(222,115,40,.18);
}

/* ===== Código (paso 3) ===== */
.cdq-code{
  display:inline-block; margin:12px 0 16px; padding:12px 16px;
  font-size:36px; font-weight:900; color:#111827;
  background:#F8FAFC; border:1px solid #E5E7EB; border-radius:14px;
}

/* ===== Condicionales ===== */
.cond-identifica,.cond-archivo,.cond-anon-solo-email,.cond-datos-denunciante{ display:block; }
.is-off{ display:none !important; }

/* ===== Overlay ===== */
.cdq-overlay{
  position:fixed; inset:0; background:rgba(2,6,23,.35);
  display:none; align-items:center; justify-content:center; z-index:9999; backdrop-filter:blur(2px);
}
.cdq-overlay.show{ display:flex; }
.cdq-ol-box{
  background:#ffffff; border:1px solid #E5E7EB; border-radius:16px; padding:22px 24px;
  box-shadow:0 20px 40px rgba(16,24,40,.12); max-width:560px; width:92%; text-align:center; color:#1E2024;
}
.cdq-ol-spinner{
  width:40px; height:40px; border-radius:50%; border:3px solid #E5E7EB; border-top-color:var(--qtc-yellow);
  margin:0 auto 10px; animation:cdqspin 1s linear infinite;
}
@keyframes cdqspin{ to{ transform:rotate(360deg); } }
.cdq-ol-msg{ font-weight:800; margin-bottom:6px; }
.cdq-ol-sub{ color:#475569; font-size:14px; }
.cdq-ol-progress{ margin-top:10px; height:8px; background:#EEF2F7; border-radius:999px; overflow:hidden; border:1px solid #E5E7EB; }
.cdq-ol-bar{ height:100%; width:0%; background:linear-gradient(90deg, var(--qtc-orange), var(--qtc-yellow)); transition:width .2s; }

/* ===== Responsive (tablet) ===== */
@media (max-width:900px){
  .cdq-hero h1{ font-size:38px; padding:12px 18px; }
  .cdq-sub{ font-size:14px; }
  .cdq-steps{ padding:14px 16px 24px; }
  .cdq-steps::before, .cdq-steps::after{ left:32px; right:32px; top:64px; height:5px; }
  .cdq-step{ gap:8px; padding:10px 0; }
  .cdq-step span{ width:34px; height:34px; font-size:12px; }
  .cdq-grid{ grid-template-columns:1fr; }
  .cdq-panel{ padding:22px; }
  .cdq-btn{ width:100%; }
}

/* ===== Responsive (móvil): pasos en columna con mini-barra por paso ===== */
@media (max-width:600px){
  /* Stepper vertical, sin pista/progreso global */
  .cdq-steps{
    flex-direction:column; align-items:stretch;
    gap:12px; padding:14px 12px 16px;
  }
  .cdq-steps::before, .cdq-steps::after{ display:none; }

  .cdq-step{
    justify-content:flex-start; gap:10px; padding:12px 10px;
    background:#fff; border:1px solid #E5E7EB; border-radius:12px;
    box-shadow:0 4px 12px rgba(16,24,40,.04);
  }
  .cdq-step small{
    background:transparent; box-shadow:none; padding:0;
    font-size:13px; line-height:1.1;
  }

  /* pista por paso */
  .cdq-step::before{
    content:""; position:relative; display:block; height:6px; border-radius:999px;
    background:#ECEFF3; flex:1; margin-left:8px; margin-top:18px;
  }
  /* progreso del paso (activo o completado) */
  .cdq-step.is-active::after,
  .cdq-step.is-done::after{
    content:""; position:relative; display:block; height:6px; border-radius:999px;
    background:linear-gradient(90deg, var(--qtc-orange), var(--qtc-yellow));
    flex:1; margin-left:-calc(100% - 56px); /* se alinea sobre la pista anterior */
    margin-top:-6px;
  }

  /* ajusta el número para que no tape las barras */
  .cdq-step span{ flex:0 0 34px; width:34px; height:34px; font-size:12px; }
}

/* Seguridad: el título siempre blanco en el hero */
.cdq-hero h1{ color:#fff !important; }

/* ===== Modal legales (Términos / Privacidad) ===== */
.cdq-legal-modal {
  position: fixed; inset: 0;
  display: none; z-index: 99999;
}
.cdq-legal-modal.show { display: block; }

.cdq-legal-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(2px);
}

.cdq-legal-dialog {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: min(920px, 96vw);
  height: min(90vh, 920px);
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  display: flex; flex-direction: column;
  overflow: hidden;
}

.cdq-legal-close {
  position: absolute; top: 8px; right: 10px;
  width: 36px; height: 36px; border-radius: 50%;
  border: none; background: rgba(0,0,0,.06);
  font-size: 22px; line-height: 1;
  cursor: pointer;
}
.cdq-legal-close:hover { background: rgba(0,0,0,.12); }

#cdq-legal-title {
  margin: 0; padding: 14px 52px 12px 16px;
  font-size: 16px; font-weight: 800; color: #1E2024;
  border-bottom: 1px solid #E5E7EB;
}

.cdq-legal-body {
  flex: 1; min-height: 0; /* para que el iframe flexione bien */
}
.cdq-legal-body iframe {
  width: 100%; height: 100%;
  border: 0; display: block;
}

/* Responsive: en móviles el modal casi a pantalla completa */
@media (max-width: 600px){
  .cdq-legal-dialog{
    width: 98vw; height: 92vh;
    border-radius: 12px;
  }
  #cdq-legal-title{
    padding: 12px 48px 10px 14px;
    font-size: 15px;
  }
  .cdq-legal-close{
    top: 6px; right: 8px;
    width: 34px; height: 34px; font-size: 20px;
  }
}
