*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:#f5f7fb;color:#111827}.app{display:flex;min-height:100vh}.sidebar{width:270px;background:linear-gradient(180deg,#07172e,#0b1220);color:#fff;padding:22px;position:fixed;inset:0 auto 0 0;z-index:10}.brand{display:flex;gap:12px;align-items:center;font-size:25px;font-weight:800;margin-bottom:35px}.brand span span{color:#38bdf8}.logo{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#2563eb,#38bdf8);display:grid;place-items:center;font-weight:900}nav a{display:flex;gap:12px;color:#dbeafe;text-decoration:none;padding:13px 14px;border-radius:12px;margin-bottom:8px;font-size:15px}nav a:hover{background:#2563eb;color:#fff}.side-footer{position:absolute;bottom:22px;left:22px;right:22px;border:1px solid rgba(255,255,255,.12);padding:15px;border-radius:12px;color:#cbd5e1}.content{margin-left:270px;width:calc(100% - 270px);padding:24px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.menu-btn{display:none;background:#fff;border:1px solid #dbe2ef;border-radius:10px;font-size:26px;padding:8px 12px}.title h1{margin:0;font-size:28px}.title p{margin:6px 0 0;color:#64748b}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:20px 0}.card,.panel{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 8px 20px rgba(15,23,42,.04)}.card{padding:20px}.card small{color:#64748b}.card strong{display:block;font-size:25px;margin-top:8px}.grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.panel{padding:20px;margin-bottom:18px}.panel h2{font-size:18px;margin:0 0 18px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field{margin-bottom:14px}.field label{font-size:13px;font-weight:700;display:block;margin-bottom:7px}.field input,.field select,.field textarea{width:100%;border:1px solid #d7deea;border-radius:10px;padding:12px;background:#fff}.field textarea{min-height:100px}.btn{border:0;border-radius:10px;padding:12px 18px;cursor:pointer;font-weight:700;text-decoration:none;display:inline-block}.btn-primary{background:#2563eb;color:#fff}.btn-purple{background:#7c3aed;color:#fff}.btn-danger{background:#ef4444;color:#fff}.btn-light{background:#eef2f7;color:#111827}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid #e5e7eb;padding:13px;text-align:left;font-size:14px}th{color:#64748b;font-size:12px;text-transform:uppercase}.badge{padding:5px 9px;border-radius:999px;font-size:12px;font-weight:700}.Concluido,.Concluida{background:#dcfce7;color:#166534}.Desenvolvimento,.Executando{background:#dbeafe;color:#1d4ed8}.Planejamento,.Planejado{background:#fef3c7;color:#92400e}.Teste{background:#ede9fe;color:#6d28d9}.Pausado{background:#fee2e2;color:#991b1b}.upload{border:2px dashed #cbd5e1;padding:24px;border-radius:16px;text-align:center;background:#f8fafc}.login-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#07172e,#2563eb)}.login-box{width:95%;max-width:430px;background:#fff;border-radius:22px;padding:32px;box-shadow:0 25px 70px rgba(0,0,0,.22)}.login-box h1{margin:0 0 6px}.alert{padding:12px;border-radius:10px;margin-bottom:12px}.alert-error{background:#fee2e2;color:#991b1b}.alert-ok{background:#dcfce7;color:#166534}@media(max-width:900px){.sidebar{transform:translateX(-105%);transition:.25s}.sidebar.open{transform:translateX(0)}.content{margin-left:0;width:100%;padding:16px}.menu-btn{display:block}.cards,.grid,.form-grid{grid-template-columns:1fr}.topbar{gap:12px}.title h1{font-size:23px}.card strong{font-size:22px}}
.muted{color:#64748b;font-size:13px}.kpi-list{display:grid;gap:12px}.kpi-list div{display:flex;justify-content:space-between;gap:12px;border:1px solid #e5e7eb;border-radius:12px;padding:14px;background:#f8fafc}.kpi-list span{color:#64748b}.progress{height:10px;background:#e5e7eb;border-radius:999px;overflow:hidden;margin-bottom:6px}.progress span{display:block;height:100%;background:linear-gradient(90deg,#2563eb,#7c3aed)}.chart-line{width:100%;min-height:260px}.chart-line svg{width:100%;height:auto}.chart-line .axis{stroke:#cbd5e1;stroke-width:1}.chart-line .area{fill:#dbeafe;opacity:.75}.chart-line .line{fill:none;stroke:#2563eb;stroke-width:4;stroke-linecap:round;stroke-linejoin:round}.chart-line .dot{fill:#7c3aed;stroke:#fff;stroke-width:2}.chart-line text{font-size:12px;fill:#64748b}.roadmap{position:relative}.road-item{display:grid;grid-template-columns:34px 1fr;gap:12px;padding-bottom:20px;position:relative}.road-item:before{content:"";position:absolute;left:13px;top:14px;bottom:-2px;width:2px;background:#dbeafe}.road-item:last-child:before{display:none}.road-dot{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#7c3aed);box-shadow:0 0 0 5px #eef2ff;z-index:1}.road-item h3{margin:0 0 8px;font-size:17px}.road-item p{margin:0 0 8px;color:#475569}.no-print{margin-bottom:14px}.print-cards{grid-template-columns:repeat(4,1fr)}
@media print{.sidebar,.topbar,.no-print{display:none!important}.content{margin:0!important;width:100%!important;padding:0!important}.panel{box-shadow:none;border:0}.cards{display:grid;grid-template-columns:repeat(4,1fr)}body{background:#fff}.btn{display:none}table{page-break-inside:auto}tr{page-break-inside:avoid}.report h1{font-size:26px}}
