/* Vouga · Diagnóstico — built on the site's tokens (main.css). */

:root{ --diag-red:#b3402e; --diag-yellow:#b8860b; --diag-green:#1d7a3a; }
html[data-theme="dark"]{ --diag-red:#e06a55; --diag-yellow:#e6b53c; --diag-green:#4fc06a; }

body.diag-page{overflow-x:hidden}
.diag{display:flex;flex-direction:column;min-height:calc(100vh - 62px);min-height:calc(100svh - 62px)}
.diag .label{display:block}
.diag-stage{flex:1 1 auto;display:flex;flex-direction:column;justify-content:center;padding:clamp(32px,6vh,64px) 0}
.diag-stage > .label,.diag-result > .diag-fade > .label{color:var(--path-accent,var(--accent))}

.diag-h1{font-family:var(--font-display);font-weight:400;font-size:clamp(34px,5.5vw,58px);line-height:1.06;letter-spacing:0;margin-top:16px;color:var(--text)}
.diag-h1.q{font-size:clamp(28px,4.4vw,46px)}
.diag-h1.center{text-align:center}
.diag-em{font-style:italic;color:var(--accent)}
.diag-lead{margin-top:16px;max-width:52ch;color:var(--text-dim);font-size:clamp(15px,1.4vw,18px);line-height:1.6}
.diag-lead.center{margin-left:auto;margin-right:auto;text-align:center}
.diag-terminal-text{display:flex;align-items:flex-start;gap:.65em;max-width:92ch;font-family:var(--font-mono);font-size:clamp(12px,1.1vw,14px);line-height:1.75;letter-spacing:.02em;color:var(--text-dim)}
.diag-terminal-text.center{justify-content:center;text-align:left}
.diag-terminal-prompt{flex:none;color:var(--path-accent,var(--accent))}
.diag-terminal-output{position:relative;min-width:0}
.diag-terminal-output::after{content:'';display:inline-block;width:.52em;height:1.1em;margin-left:.12em;background:var(--path-accent,var(--accent));transform:translateY(.18em);animation:diagCursor .8s steps(1) infinite}
.diag-terminal-text.is-complete .diag-terminal-output::after{opacity:.45}
@keyframes diagCursor{50%{opacity:0}}

/* start: modes + fields */
.diag-modes{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:28px}
.diag-mode{border:1px solid var(--divider);border-radius:12px;padding:18px;text-align:left;background:var(--surface);cursor:pointer;transition:border-color .25s ease,box-shadow .25s ease}
.diag-mode:hover{border-color:var(--text-faint)}
.diag-mode.is-active{border-color:var(--text)}
.diag-mode-t{display:block;font-family:var(--font-display);font-size:19px;color:var(--text)}
.diag-mode-s{display:block;margin-top:6px;font-size:13px;color:var(--text-dim)}
.diag-fields{margin-top:22px}
.diag-fields.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.diag-input{width:100%;background:var(--surface);border:1px solid var(--divider);border-radius:10px;padding:13px 15px;font-family:var(--font-sans);font-size:15px;color:var(--text);transition:border-color .25s ease}
.diag-input::placeholder{color:var(--text-faint)}
.diag-input:focus{outline:none;border-color:var(--accent)}
.diag-input.span2{grid-column:1 / -1}
.diag-anon-note{display:block;margin-bottom:12px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint)}

/* profile cards */
.diag-pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:36px}
.diag-pcard{display:flex;flex-direction:column;align-items:flex-start;border:1px solid var(--divider);border-radius:14px;padding:24px;background:var(--surface);text-align:left;cursor:pointer;transition:border-color .25s ease,transform .25s ease}
.diag-pcard:hover{border-color:var(--accent);transform:translateY(-4px)}
.diag-picon{display:inline-grid;place-items:center;width:34px;height:34px;border:1px solid var(--divider);border-radius:999px;font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;line-height:1;color:var(--path-accent,var(--accent))}
.diag-pt{margin-top:16px;font-family:var(--font-display);font-size:21px;color:var(--text)}
.diag-ptag{margin-top:8px;font-size:13px;color:var(--text-dim);line-height:1.5}
.diag-pgo{margin-top:18px;font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);opacity:0;transition:opacity .25s ease}
.diag-pcard:hover .diag-pgo{opacity:1}

/* questions */
.diag-choices{margin-top:32px;display:flex;flex-direction:column;gap:12px}
.diag-choice{display:flex;align-items:center;gap:16px;border:1px solid var(--divider);border-radius:12px;padding:18px 20px;background:var(--surface);text-align:left;cursor:pointer;width:100%;transition:border-color .25s ease,box-shadow .25s ease}
.diag-choice:hover{border-color:var(--accent)}
.diag-choice.is-active{border-color:var(--text)}
.diag-cdot{width:9px;height:9px;border-radius:50%;flex:none;background:var(--d)}
.diag-clabel{font-size:15px;color:var(--text);line-height:1.5}
.diag-check{margin-left:auto;flex:none;width:22px;height:22px;border-radius:50%;border:1px solid var(--divider);display:grid;place-items:center;color:transparent;transition:background-color .25s ease,border-color .25s ease,color .25s ease}
.diag-choice.is-active .diag-check{border-color:var(--accent);background:var(--accent);color:var(--cta-text)}
.diag-check svg{width:12px;height:12px}

/* footer + steps */
.diag-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 0 28px}
.diag-steps{display:flex;align-items:center;gap:10px}
.diag-step{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;color:var(--text-faint);opacity:.5}
.diag-step.is-active{color:var(--accent);opacity:1}
.diag-step.is-done{color:var(--text-dim);opacity:1}
.diag-step-line{width:22px;height:1px;background:var(--divider)}
.diag-step-line.is-done{background:var(--accent)}
.diag-foot-right{display:flex;align-items:center;gap:18px}
.diag-back{background:none;border:none;cursor:pointer;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);transition:color .25s ease}
.diag-back:hover{color:var(--text)}

/* result */
.diag-result{flex:1;padding:clamp(40px,7vw,90px) 0 120px}
.diag-maturity{margin-top:46px;border:1px solid var(--divider);border-radius:14px;padding:clamp(22px,3vw,32px);background:var(--surface)}
.diag-mat-top{display:flex;align-items:flex-end;justify-content:space-between;gap:18px}
.diag-mat-label{margin-top:8px;font-family:var(--font-display);font-size:clamp(22px,3vw,30px);line-height:1.1}
.diag-mat-pct{font-family:var(--font-display);font-size:clamp(40px,6vw,60px);line-height:1;color:var(--text);font-variant-numeric:tabular-nums}
.diag-mat-track{margin-top:20px;height:6px;border-radius:999px;background:var(--divider);overflow:hidden}
.diag-mat-fill{display:block;height:100%;width:var(--pct);border-radius:999px;animation:diagFill 1s ease-out both}
@keyframes diagFill{from{width:0}}
.diag-stats{margin-top:14px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--divider);border:1px solid var(--divider);border-radius:14px;overflow:hidden}
.diag-stat{background:var(--surface);padding:24px}
.diag-stat .num{font-family:var(--font-display);font-size:clamp(30px,4vw,44px);color:var(--path-accent,var(--accent));line-height:1;font-variant-numeric:tabular-nums}
.diag-stat .lbl{display:block;margin-top:10px;font-size:13px;color:var(--text-dim);line-height:1.4}
.diag-service{margin-top:14px;border:1px solid color-mix(in srgb,var(--accent) 35%,var(--divider));border-radius:14px;padding:clamp(22px,3vw,32px);background:var(--surface)}
.diag-svc-name{margin-top:12px;font-family:var(--font-display);font-weight:400;font-size:clamp(26px,3.4vw,38px);color:var(--text);line-height:1.08}
.diag-svc-desc{margin-top:12px;max-width:60ch;color:var(--text-dim);font-size:15px;line-height:1.6}
.diag-svc-bullets{list-style:none;margin-top:20px;display:flex;flex-direction:column;gap:12px}
.diag-svc-bullets li{position:relative;padding-left:20px;font-size:15px;color:var(--text);line-height:1.5}
.diag-svc-bullets li::before{content:'';position:absolute;left:0;top:11px;width:14px;height:1px;background:var(--accent)}
.diag-cta{margin-top:14px;border:1px solid color-mix(in srgb,var(--accent) 35%,var(--divider));border-radius:14px;padding:clamp(30px,5vw,56px);text-align:center}
.diag-cta-t{font-family:var(--font-display);font-weight:400;font-size:clamp(26px,3.4vw,38px);color:var(--text);line-height:1.1}
.diag-cta-s{margin:12px auto 0;max-width:42ch;color:var(--text-dim);font-size:15px;line-height:1.5}
.diag-cta-btn{margin-top:26px}
.diag-cta .diag-back{display:block;margin:18px auto 0}

/* motion */
.diag-fade{animation:diagFade .5s ease both}
@keyframes diagFade{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.diag-result > .diag-fade:nth-child(2){animation-delay:.08s}
.diag-result > .diag-fade:nth-child(3){animation-delay:.16s}
.diag-result > .diag-fade:nth-child(4){animation-delay:.24s}
.diag-result > .diag-fade:nth-child(5){animation-delay:.32s}

@media (prefers-reduced-motion:reduce){
  .diag-fade,.diag-mat-fill{animation:none}
  .diag-fade{opacity:1;transform:none}
}

@media (max-width:680px){
  .diag-page{--diag-mobile-w:min(342px,calc(100vw - 48px))}
  .diag-page .nav-inner{
    height:56px;
    gap:10px;
    padding:0 18px;
  }
  .diag-page .logo{font-size:19px;gap:8px;min-width:0}
  .diag-page .logo-mark{width:21px;height:21px}
  .diag-page .nav-right{gap:8px}
  .diag-page .nav-right > .theme-toggle{display:grid}
  .diag-page .theme-toggle{width:32px;height:32px}
  .diag-page .nav .btn{padding:.52em .92em;font-size:13px}
  .diag{
    align-items:center;
    min-height:calc(100svh - 56px);
    width:100%;
  }
  .diag-stage.wrap,
  .diag-foot.wrap,
  .diag-result.wrap{
    width:var(--diag-mobile-w) !important;
    max-width:none !important;
    margin:0 auto;
    padding-left:0 !important;
    padding-right:0 !important;
    box-sizing:border-box;
  }
  .diag-stage{
    justify-content:flex-start;
    padding-top:clamp(30px,7vh,50px) !important;
    padding-bottom:22px !important;
  }
  .diag-stage > .label,
  .diag-result > .diag-fade > .label{
    font-size:10px;
    letter-spacing:.12em;
  }
  .diag-h1{
    margin-top:12px;
    font-size:clamp(31px,9.4vw,38px);
    line-height:1.04;
  }
  .diag-h1.q{font-size:clamp(27px,8.2vw,34px)}
  .diag-lead{margin-top:14px;font-size:13px;line-height:1.62;max-width:100%}
  .diag-terminal-text{gap:.48em;font-size:11.5px;line-height:1.7;max-width:100%}
  .diag-terminal-output{overflow-wrap:break-word}
  .diag-modes{
    grid-template-columns:1fr;
    gap:10px;
    margin-top:26px;
  }
  .diag-mode{padding:15px 16px;border-radius:12px}
  .diag-mode-t{font-size:18px;line-height:1.05}
  .diag-mode-s{font-size:12.5px;line-height:1.45}
  .diag-fields.two{grid-template-columns:1fr;gap:10px}
  .diag-fields{margin-top:18px}
  .diag-input{padding:14px 15px;font-size:16px;border-radius:12px}
  .diag-pgrid{grid-template-columns:1fr}
  .diag-pgrid{gap:10px;margin-top:28px}
  .diag-pcard{padding:16px;border-radius:12px}
  .diag-pcard:hover{transform:none}
  .diag-picon{width:29px;height:29px}
  .diag-pt{margin-top:13px;font-size:21px;line-height:1.05}
  .diag-ptag{font-size:12.8px}
  .diag-pgo{opacity:1;margin-top:14px}
  .diag-choices{margin-top:26px;gap:10px}
  .diag-choice{align-items:flex-start;gap:12px;padding:15px;border-radius:12px}
  .diag-clabel{font-size:13.5px;line-height:1.48}
  .diag-check{margin-top:1px;width:20px;height:20px}
  .diag-stats{grid-template-columns:1fr}
  .diag-foot{
    flex-direction:column-reverse;
    align-items:stretch;
    gap:12px;
    padding-top:14px !important;
    padding-bottom:22px !important;
  }
  .diag-foot-right{justify-content:space-between;gap:10px}
  .diag-foot-right .btn{flex:1;justify-content:center;padding:.76em 1em;font-size:14px}
  .diag-back{font-size:10px;letter-spacing:.13em}
  .diag-steps{justify-content:center;gap:6px;width:100%;overflow:hidden}
  .diag-step{font-size:10px;letter-spacing:.12em}
  .diag-step-line{width:clamp(12px,5vw,22px)}
  .diag-result{padding-top:34px !important;padding-bottom:72px !important}
  .diag-mat-top{flex-direction:column;align-items:flex-start;gap:10px}
  .diag-maturity{margin-top:30px;border-radius:12px;padding:20px}
  .diag-mat-pct{font-size:44px}
  .diag-stat{padding:17px}
  .diag-stat .num{font-size:36px}
  .diag-service,.diag-cta{border-radius:12px}
  .diag-svc-name,.diag-cta-t{font-size:clamp(27px,8.4vw,34px)}
  .diag-svc-desc,.diag-svc-bullets li,.diag-cta-s{font-size:13.5px}
  .diag-cta{text-align:left;padding:24px 18px}
  .diag-cta-btn{width:100%;justify-content:center;margin-top:22px}
  .diag-cta .diag-back{text-align:center}
}

@media (max-width:380px){
  .diag-page{--diag-mobile-w:calc(100vw - 42px)}
  .diag-page .logo span{max-width:134px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .diag-page .nav .btn{padding:.5em .8em}
  .diag-h1{font-size:clamp(30px,9.7vw,36px)}
  .diag-h1.q{font-size:clamp(25px,8vw,32px)}
  .diag-mode,.diag-pcard,.diag-choice{padding:14px}
  .diag-foot{padding-bottom:20px}
  .diag-step-line{width:10px}
}
