:root{
    --primary:#0b5fff;
    --text:#0f172a;
    --muted:#475569;
    --bg:#f8fafc;
    --card:#ffffff;
    --border:#e5e7eb;
    --shadow:0 12px 30px rgba(2,6,23,.08);
    --accent: var(--primary);
    --accent-600:#094bcc;
    --accent-100:#e9f1ff;
  }
  *{box-sizing:border-box}
  body{margin:0;background:var(--bg);color:var(--text);font:16px/1.55 system-ui,-apple-system,Segoe UI,Inter,Roboto,Arial,sans-serif}

  /* Cabeçalho */
  header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}
  .nav{max-width:1180px;margin:0 auto;padding:10px 20px;display:flex;align-items:center;justify-content:space-between}
  .brand a{display:inline-flex;align-items:center;text-decoration:none}
  .logo-img{height:44px;width:auto;display:block}
  @media (max-width:640px){.logo-img{height:38px}}
  nav{display:flex;align-items:center;gap:24px}
  nav a{color:#1e293b;text-decoration:none;font-weight:500}
  nav a:hover{color:var(--primary)}
  .btn-login{background:var(--primary);color:#fff;font-weight:700;padding:8px 18px;border-radius:12px;text-decoration:none}

  /* Aviso azul */
  .notice{background:var(--primary);color:#fff;text-align:center;font-weight:700;padding:10px 14px}
  .notice a{color:#fff;text-decoration:underline;font-weight:800}

  /* Conteúdo */
  .container{max-width:1100px;margin:0 auto;padding:28px}
  .card{background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:22px 22px 18px}
  .title{text-align:center;font-weight:800;color:var(--accent);letter-spacing:.02em;margin:8px 0 16px;text-transform:uppercase}
  .grid{display:grid;gap:16px}
  .field-label{font-weight:700;margin:0 0 6px}
  .subtle{color:#64748b;font-size:13px}
  .help{margin:18px 0 12px;padding:12px 18px;border-radius:18px;background:#c8f1ff;border:1px solid #7bcdf2;color:#0a4873;font-weight:500;font-size:14px;line-height:1.5;box-shadow:0 6px 18px rgba(10,72,115,.08)}
  .help strong{color:#0471b5}

  /* Select tipo de ato */
  .row{display:grid;grid-template-columns:1fr;gap:12px}
  @media(min-width:780px){.row{grid-template-columns:1fr 1fr}}
  select, .select-like{height:44px;border:1px solid #dbe2ea;border-radius:10px;padding:0 12px;background:#fff;font-weight:700;color:#0f172a}

  /* Uploaders */
  .uploader{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:44px;padding:0 16px;border-radius:10px;border:1px solid #dbe2ea;background:#fff;color:#0f172a;cursor:pointer;font-weight:700}
  .btn:hover{background:#f8fafc}
  .btn[disabled]{opacity:.55;cursor:not-allowed}
  .btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;min-width:240px}
  .btn-primary:hover{background:var(--accent-600);border-color:var(--accent-600)}

  /* Botão Analisar — ícone */
  .btn-run{width:100%;max-width:340px;gap:4px;line-height:1}
  .btn-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-left:0;transform-origin:center center;transform: translateY(1px);will-change: transform;animation: none}
  .btn-icon svg{display:block;width:100%;height:100%;fill:currentColor}
  @keyframes icon-spin{0%{transform: translateY(1px) rotate(0deg)}50%{transform: translateY(-1px) rotate(180deg)}100%{transform: translateY(1px) rotate(360deg)}}
  .btn-run.is-spinning .btn-icon{animation: icon-spin 1.8s linear infinite}
  @media (prefers-reduced-motion: reduce){.btn-run.is-spinning .btn-icon{animation:none!important}}

  .drop{flex:1 1 260px;min-height:68px;border:2px dashed #cbd5e1;border-radius:12px;background:#fff;display:flex;align-items:center;gap:10px;padding:10px 12px;color:#334155}
  .drop.drag{background:var(--accent-100);border-color:var(--accent)}
  .drop:focus{outline:3px solid rgba(11,95,255,.25);outline-offset:2px}
  .drop .name{font-weight:700}
  .drop .meta{color:#64748b;font-size:14px}
  .drop .badge{display:inline-block;background:#eef2ff;color:#1e40af;border-radius:999px;padding:2px 8px;font-size:12px;margin-left:8px}
  .drop .remove{margin-left:auto;background:#fff;border:1px solid #e2e80;border-radius:8px;padding:6px 10px;cursor:pointer}
  .drop .remove:hover{background:#f1f5f9}
  .filelist{width:100%;margin:6px 0 0;padding:0;list-style:none}
  .filelist li{display:flex;align-items:center;gap:8px;padding:4px 0;border-bottom:1px dashed #e5e7eb}
  .filelist .rm{margin-left:auto}

  /* Ação principal */
  .actions{display:flex;justify-content:center;margin-top:6px}

  /* Progresso */
  .progress{display:none;margin-top:10px;border-radius:10px;background:#e2e8f0;overflow:hidden;height:10px;position:relative}
  .progress .bar{height:100%;width:0;background:var(--accent);transition:width .25s ease}
  .progress .pct{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:12px;color:#0b1a39;font-weight:800;mix-blend-mode:multiply}

  /* ETA + logs */
  .runtime{display:none;margin-top:10px;background:#ffffff;border:1px dashed #cdd6e0;border-radius:10px;padding:10px 12px}
  .eta{display:flex;align-items:center;gap:10px;justify-content:space-between;flex-wrap:wrap}
  .eta .clock{font-weight:800;color:#1e40af}
  .eta .hint{color:#64748b;font-size:13px}
  .logs{margin-top:8px;background:#f8fafc;border:1px solid #e6ecf5;border-radius:8px;padding:8px 10px;max-height:160px;overflow:auto;font-size:13px;line-height:1.45}
  .logline{display:flex;gap:8px;margin:2px 0}
  .logtime{color:#64748b;min-width:60px;text-align:right;font-variant-numeric:tabular-nums}
  .logmsg{color:#0f172a}
  .log-ok{color:#0a7f2e}
  .log-warn{color:#b45309}

  /* Resultado */
  .result-wrap{display:none;margin-top:18px}
  .result-head{display:flex;align-items:center;justify-content:center;margin-bottom:8px}
  .result-title{margin:0;font-weight:800;color:#0f172a}
  .result{border:1px solid #dbe2ea;border-radius:10px;min-height:260px;background:#fff;padding:14px;overflow:auto;max-height:52vh}
  .result p{margin:0 0 0.9em;line-height:1.55}
  .result p:last-child{margin-bottom:0}
  .result strong{font-weight:800;color:#0f172a}
  .result .rt-color{font-weight:700}
  .toolbar{display:flex;gap:10px;justify-content:center;margin-top:12px;flex-wrap:wrap}
  .btn-ghost{background:#fff;border:1px solid #cbd5e1;color:#0f172a;border-radius:10px;height:40px;padding:0 14px;font-weight:700}
  .btn-ghost:hover{background:#f8fafc}
  .legal{margin-top:10px;color:#64748b;text-align:center;font-size:12.5px}
  .finalize{display:none;margin-top:8px;text-align:center;color:#64748b;font-size:12.5px}

  /* Rodapé */

  :focus-visible{outline:3px solid rgba(11,95,255,.35);outline-offset:2px}

  .page-assistente-matricula .footer{
    border-top:0 !important;
    box-shadow:none !important;
    background:transparent !important;
  }
