@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

:root{
  --bg:#e9f2ff;
  --card:#ffffff;
  --blue:#1e88e5;
  --blueDark:#0d47a1;
  --text:#16202b;
  --muted:#5c6b7a;
  --border:#d7e0ea;
  --shadow: 0 14px 34px rgba(0,0,0,.10);
  --radius: 18px;
}

*{ box-sizing:border-box; }

body{
  margin:0;
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 300;
  color: var(--text);
  background: var(--bg);
}

/* Header */
.app-header{
  position: fixed;
  top:0; left:0; right:0;
  height: 104px;
  background: var(--blueDark);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index: 999;
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
}

.app-header .logo-wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  width: 100%;
  pointer-events:none;
}

.app-header .logo{
  height: 56px;
  object-fit: contain;
  display:block;
}

.back-btn{
  position:absolute;
  left: 22px;
  top: 50%;
  transform: translateY(-50%);
  padding: 10px 14px;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.12);
  color:#fff;
  border-radius: 12px;
  cursor:pointer;
  font-weight: 600;
  white-space: nowrap;
}
.back-btn:hover{ background: rgba(255,255,255,.18); }

.exit-btn{
  position:absolute;
  right: 22px;
  top: 50%;
  transform: translateY(-50%);
  padding: 10px 14px;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.12);
  color:#fff;
  border-radius: 12px;
  cursor:pointer;
  font-weight: 600;
  white-space: nowrap;
}
.exit-btn:hover{ background: rgba(255,255,255,.18); }

/* Layout */
.main{
  max-width: 980px;
  margin: 132px auto 64px;
  padding: 0 18px;
}

.card{
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 26px;
  margin: 18px auto;
}

/* espaçamento padrão dentro de cards */
.card > * + *{
  margin-top: 12px;
}

h1,h2,h3{
  margin: 0;
  font-weight: 700;
  letter-spacing: -0.2px;
}
h1{ font-size: 20px; color: var(--blueDark); }
h2{ font-size: 16px; color: var(--blueDark); }
h3{ font-size: 14px; color: var(--blueDark); }

.muted{
  color: var(--muted);
  font-size: 12px;
}

.form-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px;
  align-items: end;
}

label{
  display:block;
  font-size: 13px;
  font-weight: 600;
  color: var(--blueDark);
  margin-bottom: 6px;
}

input, select{
  width: 100%;
  padding: 11px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  font-size: 14px;
  font-weight: 300;
  background: #fff;
  outline: none;
}
input:focus, select:focus{
  border-color: rgba(30,136,229,.55);
  box-shadow: 0 0 0 4px rgba(30,136,229,.10);
}

.table{
  width:100%;
  border-collapse: collapse;
  font-size: 12px;
  margin-top: 8px;
}
.table th, .table td{
  border-bottom: 1px solid var(--border);
  padding: 7px 7px;
  text-align:left;
}
.table th{
  color: var(--blueDark);
  font-weight: 700;
  background: rgba(30,136,229,.06);
}

.actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 14px;
}

button{
  padding: 12px 14px;
  border-radius: 14px;
  border: none;
  cursor:pointer;
  font-weight: 700;
  font-size: 14px;
}

.btn-primary{
  background: var(--blue);
  color:#fff;
}
.btn-primary:hover{ filter: brightness(.95); }

.btn-outline{
  background: transparent;
  border: 1px solid rgba(13,71,161,.25);
  color: var(--blueDark);
}
.btn-outline:hover{ background: rgba(13,71,161,.06); }

/* Login */
.login-page{
  background: linear-gradient(140deg, var(--blueDark), #1565c0);
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 18px;
}

.login-card{
  width: 100%;
  max-width: 420px;
  background: #fff;
  border-radius: 22px;
  box-shadow: 0 26px 60px rgba(0,0,0,.30);
  padding: 34px 28px;
}

.login-card .logo{
  height: 74px;
  margin: 0 auto 16px;
  display:block;
}

.login-card .muted{
  text-align:center;
  margin: 0 0 14px;
}

.login-form{
  display:flex;
  flex-direction: column;
  gap: 12px;
}

.login-form .btn-primary{
  width: 100%;
  margin-top: 6px;
}

.error{
  color: #c62828;
  font-size: 13px;
  margin-top: 10px;
  min-height: 18px;
  text-align:center;
}

/* Report / matriz (mantém o estilo que já tínhamos) */
.report{ margin-top: 18px; }
.report .section{
  margin-top: 16px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(227,242,253,.75);
}
.canvas-wrap{
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px;
}
.matrix-card{
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow);
  padding: 16px;
}
  


/* ================= RELATÓRIO (PDF) ================= */
.report{ background:#fff; border-radius:18px; }
.report-header{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:16px 18px; border-bottom:2px solid rgba(13,71,161,.15);
}
.report-title{ flex:1; text-align:center; }
.report-title .t1{ font-weight:800; color:#0d47a1; font-size:15px; letter-spacing:.2px; }
.report-title .t2{ color:rgba(0,0,0,.55); font-size:10px; margin-top:4px; }
.report-meta{ text-align:right; min-width:170px; }
.report-logo{ width:42px; height:42px; object-fit:contain; }
.report-logo-top{ margin-left:2px; }
.report-logo-bottom{ width:36px; height:36px; }

.report-info{ padding:14px 18px; }
.info-grid{
  display:grid;
  grid-template-columns: 1fr 1fr; /* retrato: 2 colunas */
  gap: 8px 14px;
  align-items: baseline;
}
@media (min-width: 720px){
  .info-grid{ grid-template-columns: 1fr 1fr 1fr; } /* desktop volta 3 colunas */
}

.info-grid .k{ color:#0d47a1; font-weight:700; }
.info-grid .v{ color:#111; font-weight:600; }

.perfil-card{
  border:1px solid rgba(13,71,161,.18);
  border-radius:18px;
  padding:14px;
  overflow:hidden;
}
.perfil-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  margin-bottom:10px;
}
.perfil-table th, .perfil-table td{
  border:1px solid rgba(13,71,161,.18);
  padding:6px 4px;
  text-align:center;
  font-size:10.5px;
}
.perfil-table thead th.perfil-group{
  background:rgba(13,71,161,.10);
  font-weight:800;
  color:#0d47a1;
}
.perfil-table thead th.perfil-code{
  background:rgba(13,71,161,.06);
  font-weight:800;
  color:#0d47a1;
}
.perfil-table td.perfil-val{
  background:#fff;
  font-weight:800;
  color:#0d47a1;
}
.perfil-canvas{ height:260px; padding-top:8px; }

.matrix-card{
  border:1px solid rgba(13,71,161,.18);
  border-radius:18px;
  padding:12px;
  overflow:auto;
  background:#fff;
}

.wisc-matrix{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
}
.wisc-matrix th, .wisc-matrix td{
  border:1px solid rgba(13,71,161,.18);
  padding:6px 6px;
  vertical-align:middle;
  font-size:10.5px;
}
.wisc-matrix thead th{
  background:rgba(13,71,161,.08);
  color:#0d47a1;
  font-weight:800;
}
.wisc-matrix .idx{ text-align:center; width:64px; }
.wisc-matrix .col-sub{ min-width:260px; }
.wisc-matrix .col-pb, .wisc-matrix .col-pp{ width:90px; text-align:center; }
.wisc-matrix td.fill{ background:rgba(13,71,161,.12); }
.wisc-matrix td.empty{ background:rgba(13,71,161,.05); }
.wisc-matrix .pill{
  display:inline-block;
  min-width:28px;
  padding:3px 6px;
  border-radius:999px;
  background:#0d47a1;
  color:#fff;
  font-weight:800;
  font-size:10.5px;
}
.wisc-matrix .pill.sup{ background:rgba(13,71,161,.78); }
.wisc-matrix tfoot td{
  font-weight:900;
  background:rgba(13,71,161,.08);
  text-align:center;
}
.wisc-matrix tfoot .sum-label{
  text-align:left;
  color:#0d47a1;
}

.report-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 18px 16px;
  border-top:2px solid rgba(13,71,161,.15);
}

.no-break{ break-inside:avoid; page-break-inside:avoid; }

/* Melhor comportamento de impressão */
@media print{
  body{ background:#fff !important; }
  .app-header, .back-btn, .exit-btn{ display:none !important; }
  .main{
    margin: 0 !important;
    max-width: 100% !important;
    padding: 0 !important;
      }
  .card{ box-shadow:none !important; border:none !important; }
  .matrix-card, .perfil-card{ border:1px solid rgba(0,0,0,.15) !important; }
  .matrix-card{ overflow: visible !important; }
  .perfil-card{ overflow: visible !important; }
  .report{
    margin-top: 0 !important;
    }
  .report .section,
  .report .perfil-card,
  .report .canvas-wrap,
  .report .report-header,
  .report .report-info,
  .report .report-footer{
    break-inside: avoid !important;
    page-break-inside: avoid !important;
  }

  /* A matriz pode ser grande: permite quebrar, mas sem clipar */
  .report .matrix-card{
    break-inside: auto !important;
    page-break-inside: auto !important;
    overflow: visible !important;   /* MUITO importante p/ não cortar */
  }

  /* Evita cortar linhas da tabela no meio da página */
  .report .wisc-matrix tr{
    break-inside: avoid !important;
    page-break-inside: avoid !important;
  }
    .report .perfil-canvas{
    height: 340px !important; /* reduz só no PDF */
  }
  .page-break-after{
    break-after: page !important;
    page-break-after: always !important;
          }
  
    }
  }


/* =========================================
   CHECKLIST 1 — Cards em formato RETRATO
   (apenas tamanho de cada item, sem mudar estrutura)
   Baseado no modelo oficial do WISC-IV
   ========================================= */

.report .section{
  max-width: 420px;       /* item mais estreito */
  margin: 0 auto 18px;    /* centraliza + espaço vertical */
}

.report .canvas-wrap{
  max-width: 380px;       /* gráfico mais estreito */
  margin-left: auto;
  margin-right: auto;
}

.report .perfil-canvas{
  height: 420px;          /* mais alto para acomodar canvas 520 */
}

.report table.table{
  max-width: 420px;       /* tabelas não esticam */
  margin-left: auto;
  margin-right: auto;
}

.report .matrix-card{
  max-width: 420px;       /* matriz no mesmo padrão */
  margin-left: auto;
  margin-right: auto;
}

/* ===== Item 5: Matriz de conversão sem scroll (retrato) ===== */
.report .matrix-card{
  overflow-x: hidden;   /* remove scroll horizontal */
  overflow-y: visible;
}

.report .wisc-matrix th,
.report .wisc-matrix td{
  padding: 4px 4px;     /* mais compacto */
  font-size: 9.5px;     /* menor pra caber */
}

.report .wisc-matrix .col-sub{
  min-width: 0;         /* remove min-width que estoura */
  width: auto;
  white-space: normal;  /* permite quebrar linha */
  line-height: 1.15;
}

.report .wisc-matrix .col-pb,
.report .wisc-matrix .col-pp{
  width: 56px;          /* colunas numéricas mais estreitas */
}

.report .wisc-matrix .idx{
  width: 46px;          /* índices mais estreitos */
}

/* ===== Item 6: Tabelas do relatório mais compactas ===== */
.report .table{
  font-size: 10px;          /* reduz a tipografia no relatório */
}

.report .table th,
.report .table td{
  padding: 5px 6px;         /* menos altura */
}

.report .table th{
  background: rgba(13,71,161,.06); /* mais leve */
}

/* ===== Item 9: Hierarquia e espaçamento de seções (laudo clínico) ===== */
.report .section{
  margin-top: 12px;
  padding: 12px 14px;
}

.report h3{
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .2px;
  margin-bottom: 6px;
}

.report h3 + .perfil-card,
.report h3 + .matrix-card,
.report h3 + .canvas-wrap,
.report h3 + table{
  margin-top: 6px;
}

.report p.muted{
  font-size: 9.5px;
  margin-top: 6px;
}

/* ===== Item 10: Cabeçalho final do relatório ===== */
.report-header{
  padding: 12px 16px;
  gap: 12px;
}

.report-title .t1{
  font-size: 14px;
  font-weight: 800;
}

.report-title .t2{
  font-size: 9.5px;
  margin-top: 2px;
}

.report-meta{
  min-width: 140px;
  font-size: 9.5px;
}

.report-logo{
  width: 36px;
  height: 36px;
}

/* ===== Impressão clínica (Ctrl+P / window.print) ===== */
@media print{
  @page{ size: A4; margin: 12mm; }

  /* imprime cores direitinho */
  *{ -webkit-print-color-adjust: exact !important; print-color-adjust: exact !important; }

  /* some com tudo fora do relatório */
  body *{ visibility: hidden !important; }

  /* mostra só o relatório */
  #relatorio, #relatorio *{
    visibility: visible !important;
  }

  /* posiciona o relatório no topo da página */
  #relatorio{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
  }

  /* remove margens “de site” */
  .main{
    margin: 0 !important;
    padding: 0 !important;
    max-width: 100% !important;
  }

  /* não imprimir botões */
  .no-print{ display: none !important; }

  /* evita cortar blocos no meio */
  .report .section,
  .report .perfil-card,
  .report .matrix-card,
  .report .report-header,
  .report .report-info,
  .report .report-footer{
    break-inside: avoid !important;
    page-break-inside: avoid !important;
  }

  /* overflow em PDF costuma cortar: deixa visível */
  .report .matrix-card{
    overflow: visible !important;
  }

  /* altura do gráfico no PDF para evitar quebrar */
  .report .perfil-canvas{
    height: 340px !important;
  }
}

/* botão print (só visual) */
.btn-print{
  border: 1px solid rgba(13,71,161,.25);
  background: rgba(13,71,161,.06);
  color: rgba(13,71,161,.95);
  border-radius: 10px;
  padding: 8px 10px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}

.duas-colunas{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-top:12px;
}

.card-relatorio{
  background:#eef6ff;
  border:1px solid #cfe3ff;
  border-radius:12px;
  padding:12px;
}

/* evitar overflow de tabela */
.card-relatorio table{
  width:100%;
}

/* mobile */
@media(max-width:1100px){
  .duas-colunas{
    grid-template-columns:1fr;
  }
}

/* PDF */
@media print{
  .duas-colunas{
    grid-template-columns:1fr 1fr !important;
  }
}

.perfil-canvas{
  min-height: 560px;
}

.interp{
  text-align: justify;
  line-height: 1.55;
  margin: 8px 0;
}
