/* ============================================================
   4Secure — DIAGNÓSTICO (assessment wizard + maturity report)
   Appended to site.css — layers on colors_and_type.css
   ============================================================ */

/* maturity level colors (mapped to brand tokens) */
:root {
  --lvl-critico: var(--danger);
  --lvl-inicial: var(--warning);
  --lvl-desenv: var(--accent-blue);
  --lvl-maduro: var(--success);
}

/* ---------- stage shell ---------- */
.diag-stage {
  position: relative; background: var(--ink-900); color: #fff;
  min-height: calc(100vh - 110px); overflow: hidden;
  display: flex; align-items: flex-start; justify-content: center;
}
.diag-stage .tex-lines { opacity: .45; }
.diag-inner {
  position: relative; z-index: 2; width: 100%; max-width: 760px;
  padding: 56px 28px 80px;
}

/* progress */
.diag-progress { margin-bottom: 30px; }
.diag-progress .pmeta { display: flex; align-items: center; justify-content: space-between; font-size: 13px; color: var(--fg-on-dark-2); margin-bottom: 10px; }
.diag-progress .pmeta .dom { display: inline-flex; align-items: center; gap: 8px; font-weight: 600; color: #fff; }
.diag-progress .pmeta .dom svg { width: 16px; height: 16px; color: #ff5a5f; }
.diag-progress .ptrack { height: 6px; border-radius: 99px; background: rgba(255,255,255,.12); overflow: hidden; }
.diag-progress .pfill { height: 100%; background: var(--primary); border-radius: 99px; transition: width .35s cubic-bezier(.4,0,.2,1); width: 0; }

/* ---------- screens ---------- */
.diag-screen { display: none; animation: diagIn .4s ease both; }
.diag-screen.active { display: block; }
@keyframes diagIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }

/* intro */
.diag-intro { text-align: center; max-width: 600px; margin: 0 auto; padding-top: 24px; }
.diag-intro .ico-badge { width: 76px; height: 76px; border-radius: 18px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); display: flex; align-items: center; justify-content: center; margin: 0 auto 26px; }
.diag-intro .ico-badge img { height: 38px; }
.diag-intro h1 { font: var(--h1); font-size: 42px; letter-spacing: var(--tracking-tight); text-wrap: balance; }
.diag-intro h1 .accent { color: var(--primary); }
.diag-intro p.lede { font: var(--body-lg); color: var(--fg-on-dark-2); margin-top: 18px; }
.diag-meta-row { display: flex; gap: 26px; justify-content: center; margin: 30px 0 8px; flex-wrap: wrap; }
.diag-meta-row span { display: inline-flex; align-items: center; gap: 9px; font-size: 14px; color: var(--fg-on-dark-2); }
.diag-meta-row svg { width: 17px; height: 17px; color: #ff5a5f; }
/* optional lead fields */
.diag-lead { margin: 34px auto 0; max-width: 460px; text-align: left; }
.diag-lead .lead-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.diag-lead .d-field { margin-top: 14px; }
.diag-lead .d-field.full { grid-column: 1 / -1; }
.diag-lead label { display: block; font-size: 12.5px; font-weight: 600; color: rgba(255,255,255,.78); margin-bottom: 7px; }
.diag-lead input {
  width: 100%; font-family: var(--font-sans); font-size: 15px; color: #fff;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.16);
  border-radius: var(--r-sm); padding: 12px 14px; transition: border-color .15s ease, background .15s ease;
}
.diag-lead input::placeholder { color: rgba(255,255,255,.4); }
.diag-lead input:focus { outline: none; border-color: var(--primary); background: rgba(255,255,255,.08); }
.diag-intro .start-cta { margin-top: 30px; }
.diag-intro .priv { font-size: 12.5px; color: var(--fg3); margin-top: 18px; }

/* question */
.diag-q .q-domain { font: var(--overline); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: #ff5a5f; display: inline-flex; align-items: center; gap: 8px; }
.diag-q .q-domain svg { width: 15px; height: 15px; }
.diag-q h2 { font: var(--h2); font-size: 30px; line-height: 1.25; letter-spacing: var(--tracking-snug); margin: 14px 0 4px; color: #fff; text-wrap: balance; }
.diag-q .q-help { font-size: 14.5px; color: var(--fg-on-dark-2); margin-bottom: 26px; }
.diag-options { display: flex; flex-direction: column; gap: 12px; }
.diag-opt {
  display: flex; align-items: center; gap: 15px; text-align: left; width: 100%;
  background: var(--ink-800); border: 1.5px solid rgba(255,255,255,.12); border-radius: var(--r-md);
  padding: 18px 20px; cursor: pointer; color: #fff; transition: all .15s ease; font-family: inherit;
}
.diag-opt:hover { border-color: rgba(255,255,255,.34); background: #26261f; transform: translateY(-1px); }
.diag-opt .mark { width: 24px; height: 24px; flex: none; border-radius: 50%; border: 2px solid rgba(255,255,255,.28); position: relative; transition: all .15s ease; }
.diag-opt .mark::after { content: ""; position: absolute; inset: 4px; border-radius: 50%; background: var(--primary); transform: scale(0); transition: transform .15s ease; }
.diag-opt .lbl { font-size: 16px; font-weight: 500; line-height: 1.4; }
.diag-opt.selected { border-color: var(--primary); background: rgba(188,29,34,.12); }
.diag-opt.selected .mark { border-color: var(--primary); }
.diag-opt.selected .mark::after { transform: scale(1); }
.diag-nav { display: flex; align-items: center; justify-content: space-between; margin-top: 30px; }
.diag-back { background: none; border: none; cursor: pointer; color: var(--fg-on-dark-2); font-family: inherit; font-size: 14.5px; font-weight: 600; display: inline-flex; align-items: center; gap: 7px; padding: 10px 4px; transition: color .15s ease; }
.diag-back:hover { color: #fff; }
.diag-back svg { width: 17px; height: 17px; }
.diag-back[disabled] { opacity: 0; pointer-events: none; }
.diag-hint { font-size: 13px; color: var(--fg3); }

/* calc screen */
.diag-calc { text-align: center; padding-top: 60px; }
.diag-calc .spin { width: 64px; height: 64px; margin: 0 auto 24px; border-radius: 50%; border: 3px solid rgba(255,255,255,.12); border-top-color: var(--primary); animation: diagSpin 0.8s linear infinite; }
@keyframes diagSpin { to { transform: rotate(360deg); } }
.diag-calc h2 { font: var(--h3); color: #fff; }
.diag-calc p { color: var(--fg-on-dark-2); margin-top: 10px; }

/* ============================================================
   REPORT
   ============================================================ */
.diag-report { display: none; }
.diag-report.active { display: block; }
.report-head { background: var(--ink-900); color: #fff; position: relative; overflow: hidden; }
.report-head .wrap { position: relative; z-index: 2; padding: 25px 28px; }
.report-badge { display: inline-flex; align-items: center; gap: 9px; font: var(--overline); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: #ff5a5f; }
.report-badge svg { width: 16px; height: 16px; }
.report-head h1 { font: var(--h1); font-size: 38px; letter-spacing: var(--tracking-tight); margin: 14px 0 0; text-wrap: balance; }
.report-meta { display: flex; gap: 22px; margin-top: 16px; flex-wrap: wrap; color: var(--fg-on-dark-2); font-size: 14px; }
.report-meta span { display: inline-flex; align-items: center; gap: 8px; }
.report-meta svg { width: 15px; height: 15px; color: #ff5a5f; }

/* score hero: gauge + summary */
.score-hero { display: grid; grid-template-columns: 320px 1fr; gap: 44px; align-items: center; margin-top: 36px; }
.gauge-wrap { position: relative; display: flex; flex-direction: column; align-items: center; }
.gauge-svg { width: 280px; height: 168px; }
.gauge-center { position: absolute; top: 78px; left: 0; right: 0; text-align: center; }
.gauge-center .score-num { font: var(--display); font-size: 60px; line-height: 1; letter-spacing: var(--tracking-tight); }
.gauge-center .score-den { font-size: 16px; color: var(--fg-on-dark-2); font-weight: 600; }
.gauge-level { margin-top: 8px; display: inline-flex; align-items: center; gap: 8px; padding: 7px 16px; border-radius: var(--r-pill); font-weight: 700; font-size: 14px; }
.gauge-level svg { width: 16px; height: 16px; }
.score-summary h2 { font: var(--h3); color: #fff; letter-spacing: var(--tracking-snug); text-wrap: balance; }
.score-summary p { color: var(--fg-on-dark-2); margin-top: 14px; font: var(--body); max-width: 480px; }
.score-legend { display: flex; gap: 16px; margin-top: 22px; flex-wrap: wrap; }
.score-legend span { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; color: var(--fg-on-dark-2); }
.score-legend .dot { width: 10px; height: 10px; border-radius: 3px; }

/* report body */
.report-body { background: var(--bg-subtle); }
.report-cols { display: grid; grid-template-columns: 420px 1fr; gap: 48px; align-items: start; padding: 72px 0; }
@media (max-width: 920px) { .report-cols { grid-template-columns: 1fr; gap: 40px; } }

/* radar panel */
.radar-panel { position: sticky; top: 96px; }
.radar-card { background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--shadow-sm); padding: 28px 26px; }
.radar-card h3 { font: var(--h4); letter-spacing: var(--tracking-snug); }
.radar-card .sub { font-size: 13.5px; color: var(--fg3); margin-top: 4px; margin-bottom: 8px; }
.radar-svg { width: 100%; height: auto; display: block; }

/* domain breakdown */
.brk-head { margin-bottom: 6px; }
.brk-head h2 { font: var(--h3); letter-spacing: var(--tracking-snug); }
.brk-head p { color: var(--fg2); margin-top: 8px; }
.dom-list { display: flex; flex-direction: column; gap: 14px; margin-top: 26px; }
.dom-row { background: #fff; border: 1px solid var(--border); border-radius: var(--r-md); box-shadow: var(--shadow-sm); padding: 20px 22px; border-left: 4px solid var(--ink-300); }
.dom-row .dr-top { display: flex; align-items: center; gap: 13px; }
.dom-row .dr-ico { width: 40px; height: 40px; flex: none; border-radius: 9px; background: var(--ink-50); display: flex; align-items: center; justify-content: center; }
.dom-row .dr-ico svg { width: 20px; height: 20px; color: var(--ink-700); }
.dom-row .dr-name { font: var(--h4); font-size: 17px; letter-spacing: var(--tracking-snug); }
.dom-row .dr-chip { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; padding: 5px 12px; border-radius: var(--r-pill); font-size: 12px; font-weight: 700; }
.dom-row .dr-chip svg { width: 13px; height: 13px; }
.dom-row .dr-bartrack { height: 8px; border-radius: 99px; background: var(--ink-100); overflow: hidden; margin: 16px 0 12px; }
.dom-row .dr-barfill { height: 100%; border-radius: 99px; width: 0; transition: width .9s cubic-bezier(.3,0,.2,1); }
.dom-row .dr-diag { font: var(--body-sm); color: var(--fg2); }
.dom-row .dr-link { display: inline-flex; align-items: center; gap: 6px; margin-top: 12px; font-size: 13px; font-weight: 600; color: var(--primary); }
.dom-row .dr-link svg { width: 14px; height: 14px; transition: transform .15s ease; }
.dom-row .dr-link:hover svg { transform: translateX(3px); }

/* priorities */
.prio-band { background: #fff; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.prio-band .wrap { padding: 64px 28px; }
.prio-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 32px; }
.prio-card { border-radius: var(--r-md); border: 1px solid var(--border); padding: 24px; background: #fff; box-shadow: var(--shadow-sm); position: relative; overflow: hidden; }
.prio-card .rule { position: absolute; top: 0; left: 0; right: 0; height: 4px; }
.prio-card .rank { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--fg3); }
.prio-card .pc-top { display: flex; align-items: center; gap: 11px; margin: 12px 0 14px; }
.prio-card .pc-ico { width: 42px; height: 42px; border-radius: 10px; background: var(--red-50); display: flex; align-items: center; justify-content: center; flex: none; }
.prio-card .pc-ico svg { width: 21px; height: 21px; color: var(--primary); }
.prio-card h3 { font: var(--h4); font-size: 17px; letter-spacing: var(--tracking-snug); }
.prio-card p { font: var(--body-sm); color: var(--fg2); margin-top: 4px; }
.prio-card .pc-cta { display: inline-flex; align-items: center; gap: 6px; margin-top: 16px; font-size: 13.5px; font-weight: 600; color: var(--primary); }
.prio-card .pc-cta svg { width: 15px; height: 15px; }
@media (max-width: 860px) { .prio-grid { grid-template-columns: 1fr; } }

/* report actions */
.report-actions { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; padding: 16px 0 0; }

@media (max-width: 760px) {
  .score-hero { grid-template-columns: 1fr; gap: 30px; justify-items: center; text-align: center; }
  .score-summary { text-align: center; }
  .score-legend { justify-content: center; }
  .diag-intro h1 { font-size: 32px; }
  .diag-q h2 { font-size: 24px; }
  .report-head h1 { font-size: 28px; }
  .diag-lead .lead-row { grid-template-columns: 1fr; }
}

/* ============================================================
   ON-SCREEN report: radar (centered) + email CTA
   ============================================================ */
.report-radar-section { background: var(--bg-subtle); }
.report-radar-section .wrap { padding: 56px 28px 72px; display: grid; grid-template-columns: 1.1fr .9fr; gap: 32px; align-items: stretch; max-width: 1040px; }
.radar-card.single { background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--shadow-sm); padding: 28px 26px; display: flex; flex-direction: column; }
.radar-card.single .rc-head { text-align: center; }
.radar-card.single .rc-head h3 { font: var(--h3); letter-spacing: var(--tracking-snug); }
.radar-card.single .rc-head .sub { font-size: 13.5px; color: var(--fg3); margin-top: 6px; }
.radar-card.single .radar-svg { width: 100%; max-width: 460px; margin: 8px auto 0; height: auto; }
.score-legend.center { justify-content: center; gap: 14px 18px; margin-top: 14px; }
.score-legend.center span { color: var(--fg2); }

.email-panel { background: var(--ink-900); color: #fff; border-radius: var(--r-lg); box-shadow: var(--shadow-md); padding: 36px 32px; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; position: relative; overflow: hidden; }
.email-panel .ep-ico { width: 54px; height: 54px; border-radius: 13px; background: var(--primary); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.email-panel .ep-ico svg { width: 26px; height: 26px; color: #fff; }
.email-panel .ep-ico.ok { background: #1F8A4D; }
.email-panel h3 { font: var(--h3); font-size: 24px; color: #fff; letter-spacing: var(--tracking-snug); text-wrap: balance; }
.email-panel p { color: var(--fg-on-dark-2); margin-top: 12px; font: var(--body); }
.email-panel p b { color: #fff; }
.email-panel .btn { margin-top: 22px; }
.email-panel .btn-ghost { color: #ff7a7e; margin-top: 10px; padding-left: 0; }
.email-panel.sent { align-items: flex-start; }
@media (max-width: 860px) {
  .report-radar-section .wrap { grid-template-columns: 1fr; }
}

/* ============================================================
   EMAIL MODAL
   ============================================================ */
.diag-modal { position: fixed; inset: 0; z-index: 300; display: none; align-items: center; justify-content: center; padding: 20px; }
.diag-modal.open { display: flex; animation: dmFade .2s ease; }
@keyframes dmFade { from { opacity: 0; } to { opacity: 1; } }
.diag-modal .ovl { position: absolute; inset: 0; background: rgba(30,30,28,.62); backdrop-filter: blur(4px); }
.diag-modal .box { position: relative; z-index: 2; background: #fff; border-radius: var(--r-lg); max-width: 440px; width: 100%; padding: 34px 32px 30px; box-shadow: var(--shadow-lg); animation: dmRise .26s cubic-bezier(.2,0,.2,1); }
@keyframes dmRise { from { transform: translateY(16px); opacity: 0; } to { transform: none; opacity: 1; } }
.diag-modal .dm-close { position: absolute; top: 16px; right: 16px; background: none; border: none; cursor: pointer; color: var(--fg3); padding: 4px; border-radius: 6px; }
.diag-modal .dm-close:hover { background: var(--ink-50); color: var(--fg1); }
.diag-modal .dm-close svg { width: 20px; height: 20px; }
.diag-modal .dm-ico { width: 50px; height: 50px; border-radius: 12px; background: var(--red-50); display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.diag-modal .dm-ico svg { width: 25px; height: 25px; color: var(--primary); }
.diag-modal h3 { font: var(--h4); font-size: 21px; letter-spacing: var(--tracking-snug); }
.diag-modal > .box > p { font: var(--body-sm); color: var(--fg2); margin-top: 8px; }
.diag-modal .dm-field { margin-top: 18px; }
.diag-modal .dm-field label { display: block; font-size: 13px; font-weight: 600; color: var(--fg1); margin-bottom: 7px; }
.diag-modal .dm-field label .req { color: var(--primary); }
.diag-modal .dm-field input { width: 100%; font-family: var(--font-sans); font-size: 15px; color: var(--fg1); border: 1px solid var(--border-strong); border-radius: var(--r-sm); padding: 12px 14px; transition: border-color .15s ease, box-shadow .15s ease; }
.diag-modal .dm-field input:focus { outline: none; border-color: var(--primary); box-shadow: var(--ring-focus); }
.diag-modal .dm-field.err input { border-color: var(--primary); }
.diag-modal .dm-msg { display: none; font-size: 12.5px; color: var(--primary); margin-top: 6px; }
.diag-modal .dm-field.err .dm-msg { display: block; }
.diag-modal .dm-consent { display: flex; gap: 10px; align-items: flex-start; margin-top: 16px; font-size: 13px; color: var(--fg2); cursor: pointer; line-height: 1.45; }
.diag-modal .dm-consent input { margin-top: 2px; width: 16px; height: 16px; accent-color: var(--primary); flex: none; }
.diag-modal .dm-consent.err span { color: var(--primary); }
.diag-modal .dm-actions { display: flex; flex-direction: column; gap: 10px; margin-top: 22px; }
.diag-modal .dm-actions .btn { justify-content: center; }

@media (max-width: 760px) {
  .diag-intro h1 { font-size: 32px; }
  .diag-q h2 { font-size: 24px; }
  .report-head h1 { font-size: 26px; }
  .diag-lead .lead-row { grid-template-columns: 1fr; }
}

/* ============================================================
   PDF DOCUMENT — print only (logo header + detail + action plan)
   ============================================================ */
#diag-pdf { display: none; }
#diag-pdf .pdf-page { color: var(--ink-900); font-family: var(--font-sans); }
#diag-pdf .pdf-head { display: flex; align-items: center; gap: 18px; padding-bottom: 18px; border-bottom: 3px solid var(--primary); }
#diag-pdf .pdf-logo { height: 40px; width: auto; }
#diag-pdf .pdf-kick { font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--primary); }
#diag-pdf .pdf-htxt h1 { font-size: 23px; font-weight: 800; letter-spacing: -0.02em; margin-top: 4px; color: var(--ink-900); line-height: 1.15; }
#diag-pdf .pdf-meta { display: flex; flex-wrap: wrap; gap: 8px 26px; margin-top: 16px; font-size: 12.5px; color: var(--ink-700); }
#diag-pdf .pdf-meta b { color: var(--ink-900); }
#diag-pdf .pdf-summary { font-size: 13px; color: var(--ink-700); margin-top: 14px; line-height: 1.6; }
#diag-pdf .pdf-section { margin-top: 26px; }
#diag-pdf .pdf-section h2 { font-size: 16px; font-weight: 800; letter-spacing: -0.01em; color: var(--ink-900); padding-bottom: 8px; border-bottom: 1px solid var(--ink-200); }
#diag-pdf .pdf-legend { display: flex; flex-wrap: wrap; gap: 8px 16px; margin: 12px 0 4px; }
#diag-pdf .pl-item { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; color: var(--ink-700); }
#diag-pdf .pl-dot { width: 9px; height: 9px; border-radius: 2px; }
#diag-pdf .pdf-rows { margin-top: 10px; }
#diag-pdf .pdf-row { padding: 10px 0; border-bottom: 1px solid var(--ink-100); break-inside: avoid; }
#diag-pdf .pr-top { display: flex; align-items: center; gap: 12px; }
#diag-pdf .pr-name { font-size: 13.5px; font-weight: 700; color: var(--ink-900); }
#diag-pdf .pr-chip { margin-left: auto; font-size: 10.5px; font-weight: 700; padding: 3px 9px; border-radius: 99px; }
#diag-pdf .pr-track { height: 6px; border-radius: 99px; background: var(--ink-100); overflow: hidden; margin: 7px 0 6px; }
#diag-pdf .pr-fill { height: 100%; border-radius: 99px; }
#diag-pdf .pr-diag { font-size: 11.5px; color: var(--ink-700); line-height: 1.5; }
#diag-pdf .pdf-plan-lede { font-size: 12px; color: var(--ink-700); margin: 8px 0 12px; line-height: 1.5; }
#diag-pdf .pdf-plan { display: flex; flex-direction: column; gap: 10px; }
#diag-pdf .pdf-prio { border: 1px solid var(--ink-200); border-left: 4px solid var(--primary); border-radius: 6px; padding: 12px 14px; break-inside: avoid; }
#diag-pdf .pp-rank { font-size: 10px; font-weight: 700; letter-spacing: .08em; color: var(--ink-600); font-family: var(--font-mono); }
#diag-pdf .pp-name { font-size: 13.5px; font-weight: 700; color: var(--ink-900); margin-top: 4px; }
#diag-pdf .pp-rec { font-size: 11.5px; color: var(--ink-700); margin-top: 4px; line-height: 1.5; }
#diag-pdf .pdf-foot { margin-top: 26px; padding-top: 14px; border-top: 1px solid var(--ink-200); display: flex; justify-content: space-between; gap: 16px; font-size: 10.5px; color: var(--ink-600); }

@media print {
  @page { margin: 14mm; }
  body > *:not(#diag-pdf) { display: none !important; }
  #diag-pdf { display: block !important; }
  #diag-pdf, #diag-pdf * { -webkit-print-color-adjust: exact !important; print-color-adjust: exact !important; }
  .pdf-plan-section { break-before: auto; }
}
