:root{--verde-oscuro: #1A3C2E;--verde-medio: #2D6A4F;--verde-claro: #52B788;--blanco: #FFFFFF;--gris-claro: #F5F5F5;--gris-borde: #E0E0E0;--texto: #1A1A1A;--texto-suave: #666666;--error: #D32F2F;--exito: #388E3C;--alerta: #F9A825;--sombra: 0 2px 12px rgba(0,0,0,.1);--radius: 12px;--radius-sm: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--gris-claro);color:var(--texto);font-size:15px;line-height:1.5}.btn-primary{background:var(--verde-medio);color:var(--blanco);border:none;border-radius:var(--radius-sm);padding:12px 28px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s;width:100%}.btn-primary:hover{background:var(--verde-oscuro)}.btn-primary:disabled{background:#aaa;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--verde-medio);border:2px solid var(--verde-medio);border-radius:var(--radius-sm);padding:10px 24px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--verde-medio);color:var(--blanco)}.card{background:var(--blanco);border-radius:var(--radius);box-shadow:var(--sombra);padding:24px}input,select,textarea{width:100%;padding:11px 14px;border:1.5px solid var(--gris-borde);border-radius:var(--radius-sm);font-size:14px;color:var(--texto);background:var(--blanco);transition:border .2s;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--verde-claro)}label{display:block;font-size:13px;font-weight:600;color:var(--texto-suave);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.progress-bar-track{background:var(--gris-borde);border-radius:999px;height:10px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--verde-claro),var(--verde-medio));border-radius:999px;transition:width .6s ease}.badge{display:inline-block;padding:3px 12px;border-radius:999px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-activo{background:#e8f5e9;color:#2e7d32}.badge-pendiente{background:#fff8e1;color:#f9a825}.badge-completado{background:#e3f2fd;color:#1565c0}.badge-inactivo{background:#ffebee;color:#c62828}.spinner{width:40px;height:40px;border:4px solid var(--gris-borde);border-top:4px solid var(--verde-claro);border-radius:50%;animation:spin .8s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.card{padding:16px}.btn-primary{font-size:14px}}
